摘要:提到线性代数,又不得不吐槽国内教材了,学起来真的是实力劝退。线性代数概念较多,计划在另一篇总结基本概念,这里仅总结线性代数里一些重要概念的程序。
提到线性代数,又不得不吐槽国内教材了,学起来真的是实力劝退。有多少跟着国内教材学完线性代数课程后,知道线性代数是什么,它到底是干什么的?
事实上如果你后面想做科研、想研究机器学习、深度学习,你会发现处处是线性代数。这么抽象又重要的课程,一本书里基本看不到几张图,就好比是没有注释的代码,大概以为我的脑子就是记公式的机器吧…
如果你还未开始学习线性代数,那么强烈建议你把学校发的紫色教材放在一边,找几本国外的线性代数教材看看。然后在B站里搜一下麻省理工公开课Gilbert Strang老爷子的线性代数视频,相信你会打开新世界的大门(文末有彩蛋)——
吐槽就到这,我们先来看一个涉及线性代数本质问题的式子:
y = A x y=Ax y=Ax
可以说,线性代数的很多问题都是从这个式子出发的。那么在线性代数中,如何理解这个式子呢?
直观上看,这个式子跟我们熟悉的一次函数 y = kx比较像。对于y=kx,我们可以理解为将标量x经过 某种线性变换,得到另一个标量y。
这里,我们把x和y换成向量,对于y = Ax,我们可以理解为将矩阵A(线性变换)作用于向量x ,得到另一个向量y。
由于向量就是空间中的一个点,这个种线性变换的作用就是将空间中的一个点变为空间中的另一个点。
对于函数y=kx,如果我们知道y和k,就能够求解出x。对于y=Ax也一样,如果y和A已知,我们同样可以求出x,这就是求解线性方程组的问题了。
其他知识点都是从这些基本的概念衍生出来的,这里就不一一列举了。任何新知识都不是凭空出来的,都是建立在以前的理论基础之上。在学习数学的时候,可以多联系以前的知识,类比着学习。
线性代数概念较多,计划在另一篇总结基本概念,这里仅总结线性代数里一些重要概念的python程序。
1 矩阵基本操作
注:向量操作与矩阵类似。
1.1 创建矩阵
(1)通过列表创建矩阵
#通过列表创建矩阵import numpy as npm = [[1,2,3],[4,5,6],[7,8,9]] a1 = np.array(m)print("a1:",a1)print("a1的大小:" ,a1.shape)print("a1的类型:",type(a1))
(2)通过元组创建矩阵
#通过元组创建矩阵t = ((1,2,3),(4,5,6),(7,8,9)) a2 = np.array(t)print("a2:",t)print("a2的大小:" ,a2.shape)print("a2的类型:",type(a2))
(3)使用random()和randint()函数
random()函数随机生成矩阵中指定范围的浮点数:
import numpy as npa1 = np.random.random((3,4)) #3×4阶,取值范围为0~1print(a1)
randint()函数随机生成矩阵中指定范围的整数:
a2 = np.random.randint(1,10,size=[3,4]) #3×4阶,取值范围为1~10(不包括10)print(a2)
1.2 改变矩阵的大小
import numpy as npm = [1,2,3,4,5,6,7,8,9,10,11,12]a = np.array(m)a1 = a.reshape(3,4)a2 = a.reshape(4,3)print("原矩阵a: /n",a)print("转换为3行4列矩阵a1:/n",a1)print("转换为4行3列矩阵a2:/n",a2)
1.3 获取矩阵元素
print("a2的第0行元素a2[0]: /n",a2[0])print("a2的前2行元素a2[0:2]: /n",a2[0:2])print("a2的第0行和第2行元素a2[[0,2]]: /n",a2[[0,2]])print("a2的第0列元素a2[:,1]: /n",a2[:,1])print("a2的前2行元素a2[:,0:2]: /n",a2[:,0:2])print("a2的第0列和第2列元素a2[:,[0,2]]: /n",a2[:,[0,2]])print("a2的第2行第2列元素a2[2,2]: /n",a2[2,2])
1.4 特殊矩阵生成
(1)单位矩阵
import numpy as npe1 = np.eye(5)e2 = np.identity(5)print("通过eye()创建五阶单位矩阵e1: /n",e1)print("通过identity()创建五阶单位矩阵e2: /n",e2)
(2)零矩阵
import numpy as npa = np.zeros((3,4)) print("3×4阶零矩阵a: /n",a)
(3)对角矩阵
import numpy as npm = [1,2,3,4,5]a = np.diag(m)print("创建对角线为1,2,3,4,5的对角矩阵: /n",a)
(4)上三角矩阵和下三角矩阵
import numpy as npm = [[1,1,1,1],[2,2,2,2],[3,3,3,3],[4,4,4,4]]a = np.array(m)a1 = np.triu(a,0)a2 = np.tril(a,0)print("a矩阵:/n",a)print("a矩阵的上三角矩阵: /n",a1)print("a矩阵的下三角矩阵: /n",a2)
1.5 矩阵运算
(1)矩阵加减法运算
import numpy as npm1 = [[1,1,1],[2,2,2]]m2 = [[3,3,3],[4,4,4]]a1 = np.array(m1)a2 = np.array(m2)print("a1 + a2 = /n",a1 + a2)print("a1 - a2 = /n",a1 - a2)
(2)矩阵数乘运算
import numpy as npm = [[5,5,5],[6,6,6]]a = np.array(m)print("矩阵数乘2a = /n",2*a)
(3)矩阵乘法运算
import numpy as npa1 = np.array([[1,1,1],[2,2,2],[3,3,3]])a2 = np.array([[4,4,4],[5,5,5],[6,6,6]])a3 = np.dot(a1,a2)a4 = a1.dot(a2)a5 = a1*a2a6 = np.multiply(a1,a2)print("矩阵乘法a1×a2 = /n",a3)print("矩阵乘法a1×a2 = /n",a4)print("对应元素的乘积: /n",a5)print("对应元素的乘积: /n",a6)
(4)矩阵乘方运算
import numpy as npm = [[1,1,1],[2,2,2],[3,3,3]]a = np.array(m)a1 = a**2print("a的二次方a1: /n",a1)
(5)生成逆矩阵
import numpy as npm = [[2,5],[2,3]]a = np.array(m)a1 = np.linalg.inv(a)a2 = np.mat(a)a3 = a2.Iprint("使用np.linalg.inv()求a的逆矩阵a1: /n",a1)print("使用I属性求a的逆矩阵a3: /n",a3)
(6)生成转置矩阵
import numpy as npm = [[1,2,3],[4,5,6]]a = np.array(m)a1 = a.Ta2 = np.transpose(a)print("使用T属性求a的转置a1: /n",a1)print("使用np.transpose()函数求a的转置a2: /n",a2)
2 行列式
2.1 行列式与矩阵的区别
(1)行列式是一个数值,矩阵是一个数表;
(2)行列式的行数等于列数,矩阵的行数不等于列数。
2.2 计算行列式
(1)使用np.linalg.det()函数计算行列式
官方手册用法:
python程序:
#计算行列式dimport numpy as npd = [[1, 2, -4],[-2, 2, 1],[-3, 4, -2]]a = np.array(d)result = np.linalg.det(a) print(result) #-14.000000000000004
(2)使用scipy.linalg.det()函数计算行列式
官方手册用法:
python程序:
# 计算行列式dfrom scipy import linalgd = [[1, 2, -4],[-2, 2, 1],[-3, 4, -2]]a = np.array(d)linalg.det(a)
2.3 计算矩阵的秩
使用np.linalg.matrix_rank() 函数计算矩阵的秩。
官方手册用法:
python程序:
# 计算矩阵d的秩import numpy as npm = [[2, -1, -1, 1, 2],[1, 1, -2, 1, 4],[4, -6, 2, -2, 4],[3, 6, -9, 7, 9]]a = np.array(m)rank = np.linalg.matrix_rank(m)print(rank) #3
3 向量基本运算
3.1 向量的内积
python程序:
# 计算向量v1与向量v2的内积import numpy as npv1 = [[1,1,1]]v2 = [[1,-2,1]]a1 = np.array(v1).reshape(3,1)a2 = np.array(v2).reshape(3,1)result = a1.T.dot(a2)print(result) #[[0]]
3.2 向量的长度
使用np.linalg.norm()函数:
官方手册用法:
python程序:
# 计算向量v的长度import numpy as np v = [[1,2,2]]a = np.array(v)result =np.linalg.norm(a)print(result) #3
4 计算线性方程组的解
(1)使用np.linalg.solve()函数
官方手册用法:
注意:这里系数矩阵必须是满秩,即所有行必须是线性无关的。
python程序:
#计算线性方程组的解import numpy as np l1 = [[3, 2, -3],[2, -3, 3],[1, -1, 2]]l2 = [[-2, 5, 5]]a1 = np.array(l1)a2 = np.array(l2).reshape(3,1)result = np.linalg.solve(a1,a2)print(result)
(2)使用scipy.linalg.solve()函数
官方手册用法(内容有点长):
https://docs.scipy.org/doc/scipy/reference/reference/generated/scipy.linalg.solve.html#scipy.linalg.solve
python程序:
#计算线性方程组的解from scipy import linalgl1 = [[3, 2, -3],[2, -3, 3],[1, -1, 2]]l2 = [[-2, 5, 5]]a1 = np.array(l1)a2 = np.array(l2).reshape(3,1)result = linalg.solve(a1,a2)print(result)
5 特征值与特征向量
5.1 计算特征值与特征向量
使用np.linalg.eig()函数:
官方手册用法:
python程序:
# 计算特征值和特征向量import numpy as npm = [[3,-1],[-1,3]]a = np.array(m)eig_val,eig_vex = np.linalg.eig(a)print(eig_val) print(eig_vex)
输出
特征值: [4. 2.]特征向量: [[ 0.70710678 0.70710678] [-0.70710678 0.70710678]]
5.2 特征值分解
特征值分解要求带分解的矩阵必须是n维方阵。
python程序:
import numpy as npm1 = [[-2, 1, 1],[0, 2, 0],[-4, 1, 3]] #m1为原始矩阵a = np.array(m1)eig_val,eig_vex = np.linalg.eig(a)print("特征值为:",eig_val)eig_val_diag = np.diag(eig_val) #特征值对角化print("对角矩阵:",eig_val_diag)m2 = eig_vex.dot(eig_val_diag.dot(np.linalg.inv(eig_vex))) #m2为新生成的矩阵print(m2)print("m1和m2是否相等:",np.allclose(m1,m2))
6 SVD
6.1 SVD要点
SVD(Singular Value Decompostion)可以对任意矩阵进行分解,它是一种抽取重要特征的方法,将一个复杂的大矩阵用三个小矩阵来表示,而这三个小矩阵包含大矩阵的重要特征信息。
6.2 使用SVD重构矩阵
python程序:
#奇异值分解import numpy as npm1 = [[1, 2, 2, 1],[2, 1, -2, -2],[1, -1, -4, -3]] # 原矩阵m1a = np.array(m1)u,s,vt = np.linalg.svd(a) diagma = np.zeros(np.shape(a))diagma[:len(s),:len(s)] = np.diag(s)print("左奇异值矩阵: /n",u) print("奇异值: /n",s)print("右奇异值矩阵: /n",vt)print("奇异值矩阵: /n",diagma)m2 = u.dot(diagma.dot(vt)) # 重构后的矩阵m2print("原矩阵m1与重构后矩阵m2是否相同:",np.allclose(m1,m2)) #判断重构后矩阵与原矩阵是否相等
输出:
左奇异值矩阵: [[-0.34819307 -0.73853115 0.57735027] [ 0.4654902 -0.67080962 -0.57735027] [ 0.81368327 0.06772153 0.57735027]]奇异值: [6.38092733e+00 3.04692736e+00 1.50350788e-16]右奇异值矩阵: [[ 0.21885073 -0.16370335 -0.76510817 -0.58302235] [-0.66047812 -0.72715663 -0.13335703 0.13125468] [ 0.28819959 -0.02107189 -0.52371947 0.80138311] [-0.65788602 0.66633357 -0.35006188 0.02534264]]奇异值矩阵: [[6.38092733e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00] [0.00000000e+00 3.04692736e+00 0.00000000e+00 0.00000000e+00] [0.00000000e+00 0.00000000e+00 1.50350788e-16 0.00000000e+00]]原矩阵m1与重构后矩阵m2是否相同: True
6.3 使用SVD进行矩阵近似
for k in range(3
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/119315.html
摘要:值得一提的是每篇文章都是我用心整理的,编者一贯坚持使用通俗形象的语言给我的读者朋友们讲解机器学习深度学习的各个知识点。今天,红色石头特此将以前所有的原创文章整理出来,组成一个比较合理完整的机器学习深度学习的学习路线图,希望能够帮助到大家。 一年多来,公众号【AI有道】已经发布了 140+ 的原创文章了。内容涉及林轩田机器学习课程笔记、吴恩达 deeplearning.ai 课程笔记、机...
摘要:数据科学其实就是机器学习,数据分析和数据可视化。机器学习通过实现算法,该算法能够自动检测输入中的模式。一般应用于人脸识别语音识别热门机器学习算法包括神经网络深度学习支持向量机随机森林进行数据分析可视化进行数据可视化时,是非常热门的库。 ...
摘要:最后还是强调一下自学的重要性,深度学习及其分支都是一个大坑,知识量巨大,希望大家充分利用搜索引擎对已学知识点进行补充或解疑,观摩大佬们的代码,不要满足于这小小的系列 【DL-CV】计算机视觉前置了解 showImg(https://segmentfault.com/img/bVbeOwJ?w=1464&h=1000); 闲了就要找事做,不能被四公主和NS诱惑。所以在搞完了爬虫进入假期时...
阅读 1957·2021-11-16 11:45
阅读 3668·2021-09-06 15:02
阅读 2013·2019-08-30 15:44
阅读 2282·2019-08-30 11:21
阅读 1844·2019-08-29 16:31
阅读 3421·2019-08-29 13:55
阅读 1893·2019-08-29 12:15
阅读 3250·2019-08-28 18:05