>>m=np.mat([1,2,3])#創(chuàng)建矩陣>>>mmatrix([[1,2,3]])>>>m[0]#取一行matrix([[1,2,3]])>>>m[0,1]#第一行,第2個(gè)數(shù)據(jù)2>>>m[0][1]#注意不能像數(shù)組那樣取值了Traceback(mostrecentcalllast):File"",line1,inFile" />

日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Python中Numpy mat的使用詳解

系統(tǒng) 2211 0

前面介紹過用dnarray來(lái)模擬,但mat更符合矩陣,這里的mat與Matlab中的很相似。(mat與matrix等同)

基本操作

            
>>> m= np.mat([1,2,3]) #創(chuàng)建矩陣
>>> m
matrix([[1, 2, 3]])

>>> m[0]        #取一行
matrix([[1, 2, 3]])
>>> m[0,1]       #第一行,第2個(gè)數(shù)據(jù)
2
>>> m[0][1]       #注意不能像數(shù)組那樣取值了
Traceback (most recent call last):
 File "
            
              ", line 1, in 
              
                
 File "/usr/lib64/python2.7/site-packages/numpy/matrixlib/defmatrix.py", line 305, in __getitem__
  out = N.ndarray.__getitem__(self, index)
IndexError: index 1 is out of bounds for axis 0 with size 1

#將Python的列表轉(zhuǎn)換成NumPy的矩陣
>>> list=[1,2,3]
>>> mat(list)
matrix([[1, 2, 3]])

#Numpy dnarray轉(zhuǎn)換成Numpy矩陣
>>> n = np.array([1,2,3])
>>> n
array([1, 2, 3])
>>> np.mat(n)
matrix([[1, 2, 3]])

#排序
>>> m=np.mat([[2,5,1],[4,6,2]])  #創(chuàng)建2行3列矩陣
>>> m
matrix([[2, 5, 1],
    [4, 6, 2]])
>>> m.sort()          #對(duì)每一行進(jìn)行排序
>>> m
matrix([[1, 2, 5],
    [2, 4, 6]])

>>> m.shape           #獲得矩陣的行列數(shù)
(2, 3)
>>> m.shape[0]         #獲得矩陣的行數(shù)
2
>>> m.shape[1]         #獲得矩陣的列數(shù)
3

#索引取值
>>> m[1,:]           #取得第一行的所有元素
matrix([[2, 4, 6]])
>>> m[1,0:1]          #第一行第0個(gè)元素,注意左閉右開
matrix([[2]])
>>> m[1,0:3]
matrix([[2, 4, 6]])
>>> m[1,0:2]
matrix([[2, 4]])
              
            
          

矩陣求逆、行列式

與Numpy array相同,可參考鏈接。

矩陣乘法

矩陣乘,與Numpy dnarray類似,可以使用np.dot()和np.matmul(),除此之外,由于matrix中重載了“*”,因此“*”也能用于矩陣乘。

            
>>> a = np.mat([[1,2,3], [2,3,4]])
>>> b = np.mat([[1,2], [3,4], [5,6]])
>>> a
matrix([[1, 2, 3],
    [2, 3, 4]])
>>> b
matrix([[1, 2],
    [3, 4],
    [5, 6]])
>>> a * b     #方法一
matrix([[22, 28],
    [31, 40]])
>>> np.matmul(a, b)  #方法二
matrix([[22, 28],
    [31, 40]])
>>> np.dot(a, b)   #方法三
matrix([[22, 28],
    [31, 40]])
          

點(diǎn)乘,只剩下multiply方法了。

            
>>> a = np.mat([[1,2], [3,4]])
>>> b = np.mat([[2,2], [3,3]])
>>> np.multiply(a, b)
matrix([[ 2, 4],
    [ 9, 12]])


          

矩陣轉(zhuǎn)置

轉(zhuǎn)置有兩種方法:

            
>>> a
matrix([[1, 2],
    [3, 4]])
>>> a.T      #方法一,ndarray也行
matrix([[1, 3],
    [2, 4]])
>>> np.transpose(a)  #方法二
matrix([[1, 3],
    [2, 4]])


          

值得一提的是,matrix中求逆還有一種簡(jiǎn)便方法(ndarray中不行):

            
>>> a
matrix([[1, 2],
    [3, 4]])
>>> a.I
matrix([[-2. , 1. ],
    [ 1.5, -0.5]])
          

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 巴楚县| 邢台县| 新安县| 隆子县| 温州市| 公安县| 通海县| 绥江县| 益阳市| 三明市| 铁力市| 湟源县| 阿坝县| 瑞金市| 新竹市| 罗江县| 江源县| 江川县| 邮箱| 永城市| 昌吉市| 乐陵市| 晴隆县| 石阡县| 楚雄市| 独山县| 游戏| 于田县| 呼图壁县| 巴中市| 得荣县| 永修县| 龙南县| 舒兰市| 凉城县| 滦平县| 遵义县| 林甸县| 安岳县| 昌图县| 基隆市|