线性代数中矩阵的运算(Python、Numpy)

Python中的Numpy包提供了强大的矩阵运算能力,下面我们简单的介绍一下这些运算的代码,让大家能够顺利地使用numpy去实现这些基本运算。除此之外我还将介绍一些矩阵基本概念的通俗理解,持续更新中……
首先我们要导入numpy这个包,两种导入方式:

In [1]: from numpy import *

In [2]: import numpy as py

个人建议使用第二种方式,这里由于我们要演示绝大部分的操作,所以就不一一使用np.去调用那些方法了,而采用导入全部库函数的方式。

首先矩阵是什么,我们就不做过多的介绍了,让我们看看numpy是怎么创建矩阵的:

两种创建方式,直接创建,或者是先创建数组,再转换成矩阵,它们之间是等价的
In [3]: a1 = array([1,2,3])

In [5]: a1
Out[5]: array([1, 2, 3])

In [6]: a1 = mat(a1)

In [7]: a1
Out[7]: matrix([[1, 2, 3]])

In [8]: shape(a1)
Out[8]: (1, 3)

In [9]: b = matrix([1,2,3])

In [10]: b
Out[10]: matrix([[1, 2, 3]])

In [11]: shape(b)
Out[11]: (1, 3)

有很多常见的矩阵shape很大,我们不可能一个一个去输入吧,比如一个10*10的零矩阵,如果我们一个一个去输入那肯定是不靠谱的,不用担心,numpy提供了创建这些矩阵的函数,我们所要做的就只是输入我们的shape就可以啦。

In [17]: data1 = zeros(shape=(3,3))

In [18]: data1
Out[18]: 
array([[ 0.,  0.,  0.],
       [ 0.,  0.,  0.],
       [ 0.,  0.,  0.]])

In [19]: data1 = mat(data1)

In [20]: data1
Out[20]: 
matrix([[ 0.,  0.,  0.],
        [ 0.,  0.,  0.],
        [ 0.,  0.,  0.]])

In [21]: data1=mat(zeros((3,3)))

In [22]: data1
Out[22]: 
matrix([[ 0.,  0.,  0.],
        [ 0.,  0.,  0.],
        [ 0.,  0.,  0.]])

In [28]: data2=mat(ones(shape=(2,4),dtype=int)) #可以选择你想要的任意数据类型

In [29]: data2
Out[29]: 
matrix([[1, 1, 1, 1],
        [1, 1, 1, 1]])

In [31]: data3 = mat(random.rand(2,2))

In [32]: data3
Out[32]: 
matrix([[ 0.45544031,  0.02462429],
        [ 0.8394628 ,  0.38270193]])

In [33]: data4 = mat(random.randint(10,size=(3,3))) #生成0-10之间3*3的随机矩阵

In [34]: data4
Out[34]: 
matrix([[8, 3, 7],
        [1, 0, 6],
        [7, 5, 0]])

In [35]: data5 = eye(2,2,dtype=float) #生成相应的对角矩阵

In [36]: data5
Out[36]: 
array([[ 1.,  0.],
       [ 0.,  1.]])

In [37]: data5 = mat(data5)

In [38]: data5
Out[38]: 
matrix([[ 1.,  0.],
        [ 0.,  1.]])

In [39]: a1 = [1,2,3]

In [40]: a2 = mat((diag(a1))) #生成【1,2,3】的对角矩阵

In [41]: a2
Out[41]: 
matrix([[1, 0, 0],
        [0, 2, 0],
        [0, 0, 3]])

下面介绍常见的矩阵运算:
1、矩阵相乘

In [42]: a1 = mat([1,2])

In [43]: a2 = mat([[1],[2]])

In [44]: a3 = a1*a2

In [45]: a3
Out[45]: matrix([[5]])

2、矩阵点乘

#元素点乘
In [46]: a1 = mat([1,1])

In [47]: a2 = mat([2,2])

In [48]: a3 = multiply(a1,a2)

In [49]: a3
Out[49]: matrix([[2, 2]])

In [50]: a1 = mat([2,2])

In [51]: a2 = a1*2

In [52]: a2
Out[52]: matrix([[4, 4]])

3、矩阵求逆和转置
求逆

In [56]: a1 = mat(eye(2,2)*0.5)

In [57]: a1
Out[57]: 
matrix([[ 0.5,  0. ],
        [ 0. ,  0.5]])

In [58]: a2 = a1.I

In [59]: a2
Out[59]: 
matrix([[ 2.,  0.],
        [ 0.,  2.]])

转置

In [60]: a1 = mat([[1,1],[0,0]])

In [61]: a2 = a1.T

In [62]: a2
Out[62]: 
matrix([[1, 0],
        [1, 0]])

4、计算对应行列的最大值最小值,和
计算对应行列的和

In [63]: a1 = mat([[1,1],[2,4],[3,5]])

In [64]: a2 = a1.sum(axis=0)

In [65]: a2
Out[65]: matrix([[ 6, 10]])

In [66]: a3 = a1.sum(axis=1)

In [67]: a3
Out[67]: 
matrix([[2],
        [6],
        [8]])
In [68]: a1.max() #计算全部元素的最大值
Out[68]: 5

In [69]: a2=max(a1[:,1]) #计算第二列的最大值,这里得到的是一个1*1的矩阵

In [70]: a2
Out[70]: matrix([[5]])

In [72]: a1[1,:].max() #计算第二行的最大值,这里得到的是一个一个数值
Out[72]: 4

In [75]: np.max(a1,0) #计算所有列的最大值,这里使用的是numpy中的max函数,注意需要导入 import numpy as np,主要是为了区别一般的max函数
Out[75]: matrix([[3, 5]])

In [76]: np.max(a1,1)#计算所有行的最大值,这里得到是一个矩阵
Out[76]: 
matrix([[1],
        [4],
        [5]])

In [77]: np.argmax(a1,0)#计算所有列的最大值对应在该列中的索引
Out[77]: matrix([[2, 2]])

In [78]: np.argmax(a1[1,:])#计算第二行中最大值对应在该行的索引
Out[78]: 1

5、矩阵的分割和合并

In [79]: a = mat(ones((3,3)))

In [80]: a
Out[80]: 
matrix([[ 1.,  1.,  1.],
        [ 1.,  1.,  1.],
        [ 1.,  1.,  1.]])

In [81]: b = a[1:,1:] #分割出第二行以后的行和第二列以后的列的所有元素

In [82]: b
Out[82]: 
matrix([[ 1.,  1.],
        [ 1.,  1.]])

In [83]: a = mat(ones((2,2)))

In [84]: b = mat(eye(2))

In [85]: c = vstack((a,b))#按列合并,即增加行数

In [86]: c
Out[86]: 
matrix([[ 1.,  1.],
        [ 1.,  1.],
        [ 1.,  0.],
        [ 0.,  1.]])

In [87]: d = hstack((a,b))#按行合并,即行数不变,扩展列数

In [88]: d
Out[88]: 
matrix([[ 1.,  1.,  1.,  0.],
        [ 1.,  1.,  0.,  1.]])

6、求解矩阵的迹

In [89]: E=np.array([[1,2,3],[4,5,6],[7,8,9]])

In [90]: E
Out[90]: 
array([[1, 2, 3],
       [4, 5, 6],
       [7, 8, 9]])

In [91]: np.trace(E)
Out[91]: 15
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容