当前位置:   article > 正文

【机器学习-02】矩阵基础运算---numpy操作,头条面试有几面

【机器学习-02】矩阵基础运算---numpy操作,头条面试有几面

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Python全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img



既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Python知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注Python)
img

正文

np.triu(a1, -1)
array([[0, 1, 2],
[3, 4, 5],
[0, 7, 8]])

上三角矩阵向右上偏移一位

np.triu(a1, 1)
array([[0, 1, 2],
[0, 0, 5],
[0, 0, 0]])

下三角矩阵

np.tril(a1)
array([[0, 0, 0],
[3, 4, 0],
[6, 7, 8]])


#### 3.NumPy中矩阵基本运算


  由于NumPy中我们使用二维数组来表述矩阵,因此二维数组也就具备了数组和矩阵的两重属性。其中数组属性决定的基本运算相对简单,基础运算(如加减乘除)就是对应位置元素进行逐元素计算,而矩阵属性决定的运算则稍显复杂,当然矩阵的相关线性代数运算将在下一小节讨论,在基础运算上,矩阵和数组核心的区别在于乘法运算。  
   当然,从另一个角度考虑,其实对于向量和矩阵这种具备一定结构的对象,有很多种容易混淆的计算规则。对于常用的计算规则,我们通过将其划分成三类以帮助大家理解:




| **描述** | **解释/函数** |
| --- | --- |
| 逐元素相乘 | 向量、矩阵通用 |
| 每个对应位置元素相乘 | \* |
| 逐元素相乘后相加 | 也被称为点积(内积),向量,矩阵通用 |
| 向量点积 | vdot、dot、inner |
| 矩阵点积 | vdot |
| 矩阵乘法 | 代数学意义的矩阵相乘 |
| 矩阵乘法 | dot、matmul、@ |


* \* :逐元素相乘



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

a = np.arange(4)
a
array([0, 1, 2, 3])

a * a
array([0, 1, 4, 9])

A = a.reshape(2, 2)
A
array([[0, 1],
[2, 3]])

A * A
array([[0, 1],
[4, 9]])


* 向量点积  
   所谓点积(也被称为内积),指的是向量或矩阵对应位置元素相乘后相加。向量点积有三种实现方法,分别是dot、vdot和ineer。



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

np.dot(a, a)
14

a.dot(a)
14

(a * a).sum()
14

np.vdot(a, a)
14

np.inner(a, a)
14


* 矩阵点积  
   值得注意的是,矩阵内积只有vdot一种方式实现。



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

A
array([[0, 1],
[2, 3]])

np.vdot(A, A)
14

(A * A).sum()
14



> 
> 注意,高维数组的inner并不是内积,而是一种类似tensordot的沿着尾轴实现和积的计算过程,该方法并不通用,此处暂不做介绍。
> 
> 
> 


* 矩阵乘法  
   NumPy中,我们可以使用诸多方法实现矩阵乘法,包括dot、@、matmul等。



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

a1 = np.arange(1, 7).reshape(2, 3)
a1
array([[1, 2, 3],
[4, 5, 6]])

a2 = np.arange(1, 10).reshape(3, 3)
a2
array([[1, 2, 3],
[4, 5, 6],
[7, 8, 9]])

矩阵乘法

np.matmul(a1, a2)
array([[30, 36, 42],
[66, 81, 96]])


此处也简单回顾矩阵乘法运算,上述相乘过程如下所示:  
 ![5](https://img-blog.csdnimg.cn/img_convert/36df4390ff19a8bab94b663fedd19391.jpeg)



> 
> 值得注意的是,矩阵相乘要求左乘矩阵列数和右乘矩阵行数相同,而内积计算过程则严格要求两个向量/矩阵形状完全一致。
> 
> 
> 


#### 4.NumPy中矩阵代数运算


  如果说矩阵的基本运算是矩阵基本性质,那么矩阵的线性代数运算,则是我们利用矩阵数据类型在求解实际问题过程中经常涉及到的线性代数方法,具体相关函数如下:  
 



 矩阵的线性代数运算 




| **函数** | **描述** |
| --- | --- |
| np.trace(A) | 矩阵的迹 |
| np.linalg.matrix\_rank(A) | 矩阵的秩 |
| np.linalg…det(A) | 计算矩阵A的行列式 |
| np.linalg.inv(A) | 矩阵求逆 |


同时,由于线性代数所涉及的数学基础知识较多,从实际应用的角度出发,我们将有所侧重的介绍实际应用过程中需要掌握的相关内容,并通过本节末尾的实际案例,来加深线性代数相关内容的理解。



> 
> NumPy中的linalg是linear algebra(线性代数)的简写,也是NumPy中保存线性代数相关计算函数的模块。
> 
> 
> 


* 矩阵的迹(trace)


  矩阵的迹的运算相对简单,就是矩阵对角线元素之和,在NumPy中,可以使用trace函数进行计算。



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52

A = np.array([[1, 2], [4, 5]])
A
array([[1, 2],
[4, 5]])

np.trace(A)
6


当然,对于矩阵的迹来说,计算过程不需要是方正



  • 1
  • 2
  • 3
  • 4
  • 5

B = np.arange(1, 7).reshape(2, 3)
B
array([[1, 2, 3],
[4, 5, 6]])

np.trace(B)
6


* 矩阵的秩(rank)  
   矩阵的秩(rank),是指矩阵中行或列的极大线性无关数,且矩阵中行、列极大无关数总是相同的,任何矩阵的秩都是唯一值,满秩指的是方阵(行数和列数相同的矩阵)中行数、列数和秩相同,满秩矩阵有线性唯一解等重要特性,而其他矩阵也能通过求解秩来降维,同时,秩也是奇异值分解等运算中涉及到的重要概念。



> 
> 所谓线性相关,其实也就是线性表示,如果 
>  
>  
>  
>  
>  y 
>  
>  
>  = 
>  
>  
>  w 
>  
>  
>  x 
>  
>  
>  + 
>  
>  
>  b 
>  
>  
>  
>  y=wx+b 
>  
>  
>  y=wx+b,我们则称y可以由x线性表示,二者线性相关,反之则线性无关。类似,如果 
>  
>  
>  
>  
>  y 
>  
>  
>  = 
>  
>  
>  
>  w 
>  
>  
>  1 
>  
>  
>  
>  
>  x 
>  
>  
>  1 
>  
>  
>  
>  
>  w 
>  
>  
>  2 
>  
>  
>  
>  
>  x 
>  
>  
>  2 
>  
>  
>  
>  + 
>  
>  
>  b 
>  
>  
>  
>  y=w\_1x\_1w\_2x\_2+b 
>  
>  
>  y=w1​x1​w2​x2​+b,则我们称y可以由 
>  
>  
>  
>  
>  
>  x 
>  
>  
>  1 
>  
>  
>  
>  、 
>  
>  
>  
>  x 
>  
>  
>  2 
>  
>  
>  
>  
>  x\_1、x\_2 
>  
>  
>  x1​、x2​线性表示,y与 
>  
>  
>  
>  
>  
>  x 
>  
>  
>  1 
>  
>  
>  
>  、 
>  
>  
>  
>  x 
>  
>  
>  2 
>  
>  
>  
>  
>  x\_1、x\_2 
>  
>  
>  x1​、x2​线性相关。
> 
> 
> 


* matrix\_rank计算矩阵的秩



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153

A = np.array([[1, 3, 4], [2, 1, 3], [1, 1, 2]])
A
array([[1, 3, 4],
[2, 1, 3],
[1, 1, 2]])

np.linalg.matrix_rank(A)
2


对于矩阵A来说,第三列明显可以由第一列和第二列相加得出,因此极大线性无关组只有两列。



  • 1
  • 2
  • 3
  • 4
  • 5

B = np.array([[1, 3, 4], [2, 1, 3], [1, 1, 10]])
B
array([[ 1, 3, 4],
[ 2, 1, 3],
[ 1, 1, 10]])

np.linalg.matrix_rank(B)
3


* 矩阵的行列式(det)  
   所谓行列式,我们可以简单将其理解为矩阵的一个基本性质或者属性,通过行列式的计算,我们能够知道矩阵是否可逆,从而可以进一步求解矩阵所对应的线性方程。当然,更加专业的解释,行列式的作为一个基本数学工具,实际上就是矩阵进行线性变换的伸缩因子。


对于任何一个n维方正,行列式计算过程如下:  
 ![7](https://img-blog.csdnimg.cn/img_convert/1f882d8521935eb1bd57f67abc72a857.jpeg)


更为简单的情况,如果对于一个2\*2的矩阵,行列式的计算就是主对角线元素之积减去另外两个元素之积



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

A = np.array([[1, 2], [4, 5]])
A
array([[1, 2],
[4, 5]])

np.linalg.det(A)
-2.9999999999999996


A的秩计算过程如下:  
 ![6](https://img-blog.csdnimg.cn/img_convert/c5d9d9e620301f9a421c39c95e18b8af.jpeg)


对于行列式的计算,要求矩阵必须是方阵,也就是行列数必须一致。



  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

B = np.arange(1, 7).reshape(2, 3)
B
array([[1, 2, 3],
[4, 5, 6]])

np.linalg.det(B)

A = np.array([[1, 3, 4], [2, 1, 3], [1, 1, 2]])
A
array([[1, 3, 4],
[2, 1, 3],
[1, 1, 2]])

np.linalg.det(A)
0.0


* 矩阵的逆  
   对于满秩的方正来说,可以求其逆矩阵。从基本定义上来看,如果矩阵B和矩阵A相乘能够得到单位矩阵,即:  
  
 
 
 
 
 B 
 
 
 ⋅ 
学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!



### 一、Python所有方向的学习路线



Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。



![](https://img-blog.csdnimg.cn/img_convert/9f49b566129f47b8a67243c1008edf79.png)



### 二、学习软件

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。



![](https://img-blog.csdnimg.cn/img_convert/8c4513c1a906b72cbf93031e6781512b.png)



### 三、全套PDF电子书



书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。

![](https://img-blog.csdnimg.cn/img_convert/46506ae54be168b93cf63939786134ca.png)



### 四、入门学习视频

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。



![](https://img-blog.csdnimg.cn/afc935d834c5452090670f48eda180e0.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA56iL5bqP5aqb56eD56eD,size_20,color_FFFFFF,t_70,g_se,x_16#pic_center)



### 五、实战案例



光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。



![](https://img-blog.csdnimg.cn/img_convert/252731a671c1fb70aad5355a2c5eeff0.png)



### 六、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。



![](https://img-blog.csdnimg.cn/img_convert/6c361282296f86381401c05e862fe4e9.png)  

![](https://img-blog.csdnimg.cn/img_convert/d2d978bb523c810abca3abe69e09bc1a.png)




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)**
![img](https://img-blog.csdnimg.cn/img_convert/bbea95e7618fb99e8b4af423345bdd3b.png)

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
## 六、面试资料

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。



![](https://img-blog.csdnimg.cn/img_convert/6c361282296f86381401c05e862fe4e9.png)  

![](https://img-blog.csdnimg.cn/img_convert/d2d978bb523c810abca3abe69e09bc1a.png)




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)**
[外链图片转存中...(img-itr7TAqK-1713053384432)]

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/479574
推荐阅读
相关标签
  

闽ICP备14008679号