python向量运算_Python中的线性代数运算

本文介绍了如何在Python中通过自定义函数实现向量和矩阵的基本运算,包括向量的加减法、数乘、点乘、模长、距离计算以及矩阵的形状获取、行和列提取等。示例代码详细展示了这些操作的过程。
摘要由CSDN通过智能技术生成

Python中的线性代数运算

这里,为了熟悉Python语言的特性,我们采用一种最原始的方式去定义线性代数运算的相关函数。

如果是真实应用场景,则直接使用NumPy的函数即可。

1.向量

创建一个向量

我们可以把Python中的向量理解为有限维空间中的点。

height_weight_age=[70,170,40]

grades=[95,80,75,62]

向量运算

#### 加法定义——两个向量

defvector_add(v,w):

"""add coresponding elements"""

return[v_i+w_i

forv_i,w_iinzip(v,w)]

#### 减法定义

defvector_substract(v,w):

"""substracts coresponding elements"""

return[v_i-w_i

forv_i,w_iinzip(v,w)]

#### 向量加法——多个向量(list of vectors)

####### method 1:

defvector_sum(vectors):

"""sums of all coresponding elements"""

result=vectors[0]

forvectorinvectors[1:]:

result=vector_add(result,vector)

returnresult

######## mothod 2:

defvector_sum(vecotrs):

returnreduce(vector_add,vectors)

######## mothod 3:

fromfunctoolsimportpartial

vector_sum=partial(reduce,vector_add)

### 向量的数乘运算

defscalar_multiply(c,v):

"""c is a number,v is a vector"""

return[c*v_iforv_iinv]

### 向量的均值运算

defvector_mean(vectors):

"""compute the vector whose i-th element is the mean of

the i-th elements of the input vectors"""

n=len(vecotrs)

returnscalar_multiply(1/n,vector_sum())

### 向量的点乘

defdot(v,w):

returnsum(v_i*w_i

forv_i,w_iinzip(v,w))

### 向量的平房和

defsum_of_squares(v):

"""v_1*v_1+v_2*v_2+...+v_n*v_n"""

returndot(v,v)

### 向量的模

importmath

defmagnitude(v):

returnmath.sqrt(sum_of_squares(v))

### 向量的距离

##### method 1:

defsquared_distance(v,w):

""""""

returnsum_of_squares(vector_substract(v,w))

##### method 2:

defdistance(v,w):

returnmagnitude(vector_substract(v,w))

##### method 3:

defdistance(v,w):

returnmath.sqrt(squared_distance(v,w))

2.矩阵

矩阵是一个二维的数字集合。我们可以通过列表的列表来表达一个矩阵,这样,内层列表是等长的,并且每个内层列表表达矩阵的一行。

### 定义一个向量

A=[[1,2,3],

[4,5,6]]

B=[[1,2],

[3,4],

[7,8]]

### 获得矩阵的行数和列数

defshape(A):

num_rows=len(A)

num_cols=len(A[0])ifAelse0

returnnum_rows,num_cols

### 提取某一行

defget_row(A,i):

returnA[i]

###提取某一列

defget_column(A,j):

return[A_i[j]# j-th element of row A_i

forA_iinA]# for each row in A

### 定制特殊矩阵生成函数:如单位矩阵

defmake_matrix(num_rows,num_cols,entry_fn):

"""return a matrix whose (i,j)-th entry is entry_fn(i,j)"""

return[[entry_fn(i,j)

forjinrange(num_cols)]

foriinrange(num_rows)]

###

defis_diagonal(i,j):

return1ifi==jelse0

make_matrix(5,5,is_diagonal)

[[1,0,0,0,0],

[0,1,0,0,0],

[0,0,1,0,0],

[0,0,0,1,0],

[0,0,0,0,1]]我有建立一个python学习交流群,在群里我们相互帮助,相互关心,相互分享内容,这样出问题帮助你的人就比较多,群号是301,还有056,最后是069,这样就可以找到大神聚合的群,如果你只愿意别人帮助你,不愿意分享或者帮助别人,那就请不要加了,你把你会的告诉别人这是一种分享。

学习是对自己最好的投资,而机会属于有准备的人,这是一个看脸的时代,但最终拼的是实力。人和人之间的差距不在于智商,而在于如何利用业余时间,所以没有等出来的辉煌,只有干出来的精彩。其实只要你想学习,什么时候开始都不晚,不要担心这担心那,你只需努力,剩下的交给时间,而你之所以还没有变强,只因你还不够努力,要记得付出不亚于任何人的努力。

你的想法再精彩,那是想法的价值

而你的价值,永远体现在行动之中

如果还停留在想的价值中,请赶快行动,

如果你学习还停止在原处,请咨询我帮助你开始

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值