欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python 稀疏矩陣-sparse 存儲(chǔ)和轉(zhuǎn)換

 更新時(shí)間:2017年05月27日 11:47:20   作者:soul_mate  
這篇文章主要介紹了Python 稀疏矩陣-sparse 存儲(chǔ)和轉(zhuǎn)換的相關(guān)資料,需要的朋友可以參考下

稀疏矩陣-sparsep

from scipy import sparse

稀疏矩陣的儲(chǔ)存形式

在科學(xué)與工程領(lǐng)域中求解線性模型時(shí)經(jīng)常出現(xiàn)許多大型的矩陣,這些矩陣中大部分的元素都為0,被稱為稀疏矩陣。用NumPy的ndarray數(shù)組保存這樣的矩陣,將很浪費(fèi)內(nèi)存,由于矩陣的稀疏特性,可以通過(guò)只保存非零元素的相關(guān)信息,從而節(jié)約內(nèi)存的使用。此外,針對(duì)這種特殊結(jié)構(gòu)的矩陣編寫運(yùn)算函數(shù),也可以提高矩陣的運(yùn)算速度。

scipy.sparse庫(kù)中提供了多種表示稀疏矩陣的格式,每種格式都有不同的用處,其中dok_matrix和lil_matrix適合逐漸添加元素。

dok_matrix從dict繼承,它采用字典保存矩陣中不為0的元素:字典的鍵是一個(gè)保存元素(行,列)信息的元組,其對(duì)應(yīng)的值為矩陣中位于(行,列)中的元素值。顯然字典格式的稀疏矩陣很適合單個(gè)元素的添加、刪除和存取操作。通常用來(lái)逐漸添加非零元素,然后轉(zhuǎn)換成其它支持快速運(yùn)算的格式。

a = sparse.dok_matrix((10, 5))
a[2:5, 3] = 1.0, 2.0, 3.0
print a.keys()
print a.values()
[(2, 3), (3, 3), (4, 3)]
[1.0, 2.0, 3.0]

lil_matrix使用兩個(gè)列表保存非零元素。data保存每行中的非零元素,rows保存非零元素所在的列。這種格式也很適合逐個(gè)添加元素,并且能快速獲取行相關(guān)的數(shù)據(jù)。

b = sparse.lil_matrix((10, 5))
b[2, 3] = 1.0
b[3, 4] = 2.0
b[3, 2] = 3.0
print b.data
print b.rows
[[] [] [1.0] [3.0, 2.0] [] [] [] [] [] []]
[[] [] [3] [2, 4] [] [] [] [] [] []]

coo_matrix采用三個(gè)數(shù)組row、col和data保存非零元素的信息。這三個(gè)數(shù)組的長(zhǎng)度相同,row保存元素的行,col保存元素的列,data保存元素的值。coo_matrix不支持元素的存取和增刪,一旦創(chuàng)建之后,除了將之轉(zhuǎn)換成其它格式的矩陣,幾乎無(wú)法對(duì)其做任何操作和矩陣運(yùn)算。

coo_matrix支持重復(fù)元素,即同一行列坐標(biāo)可以出現(xiàn)多次,當(dāng)轉(zhuǎn)換為其它格式的矩陣時(shí),將對(duì)同一行列坐標(biāo)對(duì)應(yīng)的多個(gè)值進(jìn)行求和。在下面的例子中,(2, 3)對(duì)應(yīng)兩個(gè)值:1和10,將其轉(zhuǎn)換為ndarray數(shù)組時(shí)這兩個(gè)值加在一起,所以最終矩陣中(2, 3)坐標(biāo)上的值為11。

許多稀疏矩陣的數(shù)據(jù)都是采用這種格式保存在文件中的,例如某個(gè)CSV文件中可能有這樣三列:“用戶ID,商品ID,評(píng)價(jià)值”。采用numpy.loadtxt或pandas.read_csv將數(shù)據(jù)讀入之后,可以通過(guò)coo_matrix快速將其轉(zhuǎn)換成稀疏矩陣:矩陣的每行對(duì)應(yīng)一位用戶,每列對(duì)應(yīng)一件商品,而元素值為用戶對(duì)商品的評(píng)價(jià)。

row = [2, 3, 3, 2]
col = [3, 4, 2, 3]
data = [1, 2, 3, 10]
c = sparse.coo_matrix((data, (row, col)), shape=(5, 6))
print c.col, c.row, c.data
print c.toarray()
[3 4 2 3] [2 3 3 2] [ 1 2 3 10]
[[ 0 0 0 0 0 0]
 [ 0 0 0 0 0 0]
 [ 0 0 0 11 0 0]
 [ 0 0 3 0 2 0]
 [ 0 0 0 0 0 0]]

個(gè)人操作中選擇,coo_matrix 選在因?yàn)樯婕跋∈杈仃囘\(yùn)算,但是如果不用其他形式存儲(chǔ)則復(fù)雜度太高(時(shí)間和空間)1000*1000的matrix大約話2h,也是要命了。無(wú)奈想到了Pajek軟件中數(shù)據(jù)的輸入格式三元組:

所以想到將自己的數(shù)據(jù)處理成類似的三元組!

即“matrix矩陣”—>"tuple三元組"—>"sparseMatrix2tuple"—>"scipy.sparse"

 感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • 解決pytorch GPU 計(jì)算過(guò)程中出現(xiàn)內(nèi)存耗盡的問(wèn)題

    解決pytorch GPU 計(jì)算過(guò)程中出現(xiàn)內(nèi)存耗盡的問(wèn)題

    今天小編就為大家分享一篇解決pytorch GPU 計(jì)算過(guò)程中出現(xiàn)內(nèi)存耗盡的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • Python系統(tǒng)監(jiān)控模塊psutil功能與經(jīng)典用法分析

    Python系統(tǒng)監(jiān)控模塊psutil功能與經(jīng)典用法分析

    這篇文章主要介紹了Python系統(tǒng)監(jiān)控模塊psutil功能與經(jīng)典用法,簡(jiǎn)單講述了psutil模塊的功能、原理并結(jié)合具體實(shí)例形式分析了Python使用psutil模塊針對(duì)CPU、內(nèi)存、磁盤、網(wǎng)絡(luò)等信息的讀取相關(guān)操作技巧,需要的朋友可以參考下
    2018-05-05
  • 淺談python 里面的單下劃線與雙下劃線的區(qū)別

    淺談python 里面的單下劃線與雙下劃線的區(qū)別

    這篇文章主要介紹了淺談python 里面的單下劃線與雙下劃線的區(qū)別,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • python sort、sorted高級(jí)排序技巧

    python sort、sorted高級(jí)排序技巧

    這篇文章主要介紹了python sort、sorted高級(jí)排序技巧,本文講解了基礎(chǔ)排序、升序和降序、排序的穩(wěn)定性和復(fù)雜排序、cmp函數(shù)排序法等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • Python類定義和類繼承詳解

    Python類定義和類繼承詳解

    這篇文章主要介紹了Python類定義和類繼承詳解,本文講解了類的私有屬性、類的方法、私有的類方法、類的專有方法、類的定義、類的單繼承、類的多繼承等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 在macOS上搭建python環(huán)境的實(shí)現(xiàn)方法

    在macOS上搭建python環(huán)境的實(shí)現(xiàn)方法

    今天小編就為大家分享一篇在macOS上搭建python環(huán)境的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • Python使用Pandas對(duì)csv文件進(jìn)行數(shù)據(jù)處理的方法

    Python使用Pandas對(duì)csv文件進(jìn)行數(shù)據(jù)處理的方法

    這篇文章主要介紹了Python使用Pandas對(duì)csv文件進(jìn)行數(shù)據(jù)處理的方法,本文通過(guò)實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-08-08
  • python 字符串split的用法分享

    python 字符串split的用法分享

    python 字符串的split方法是用的頻率還是比較多的。比如我們需要存儲(chǔ)一個(gè)很長(zhǎng)的數(shù)據(jù),并且按照有結(jié)構(gòu)的方法存儲(chǔ),方便以后取數(shù)據(jù)進(jìn)行處理。當(dāng)然可以用json的形式。但是也可以把數(shù)據(jù)存儲(chǔ)到一個(gè)字段里面,然后有某種標(biāo)示符來(lái)分割
    2013-03-03
  • Python開啟線程,在函數(shù)中開線程的實(shí)例

    Python開啟線程,在函數(shù)中開線程的實(shí)例

    今天小編就為大家分享一篇Python開啟線程,在函數(shù)中開線程的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • Python列表推導(dǎo)式、字典推導(dǎo)式與集合推導(dǎo)式用法實(shí)例分析

    Python列表推導(dǎo)式、字典推導(dǎo)式與集合推導(dǎo)式用法實(shí)例分析

    這篇文章主要介紹了Python列表推導(dǎo)式、字典推導(dǎo)式與集合推導(dǎo)式用法,結(jié)合實(shí)例形式分析了Python三種推導(dǎo)式的概念、使用方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2018-02-02

最新評(píng)論