認(rèn)識(shí)矩陣
矩陣是向量的集合,把多個(gè)向量組織在一起就構(gòu)成了一個(gè)矩陣。例如在三維空間內(nèi),有A、B、C三個(gè)向量。
將A、B、C三個(gè)向量按照行的方式組織在一起構(gòu)成了矩陣M:
將A、B、C三個(gè)向量按照列的方式組織在一起構(gòu)成了矩陣T:
矩陣M的向量稱為行向量,矩陣T的向量稱為列向量。下面給出矩陣的定義:
矩陣是由m X n個(gè)數(shù)aij排列成的m行n列的數(shù)表,稱為m行n列矩陣,簡(jiǎn)稱m X n 矩陣。矩陣表示如下:
在上述定義中,可以把矩陣A看作是由m個(gè):
向量構(gòu)成的。
如果矩陣的行和列相同,即矩陣是由n X n個(gè)數(shù)aij排列成的n行n列的數(shù)表,稱為n階矩陣。
矩陣的轉(zhuǎn)置運(yùn)算
前面的矩陣M和矩陣T可以互相轉(zhuǎn)換,這種轉(zhuǎn)換稱為矩陣的轉(zhuǎn)置運(yùn)算。矩陣的轉(zhuǎn)置就是把矩陣的行列互換,行變成列,列變成行。例如對(duì)M矩陣行列互換后,就構(gòu)成了矩陣T。
下面給出矩陣的轉(zhuǎn)置概念:
把m X n矩陣A的行列依次互換得到n X m矩陣,稱為矩陣A的轉(zhuǎn)置矩陣,記作AT。
矩陣的轉(zhuǎn)置運(yùn)算滿足下面的運(yùn)算律:
(AT)T = A
轉(zhuǎn)置矩陣的轉(zhuǎn)置矩陣是原矩陣。
(A + B)T = AT + BT
A與B和的轉(zhuǎn)置矩陣等于A的轉(zhuǎn)置矩陣與B的轉(zhuǎn)置矩陣的和。
(AB)T = BTAT
A與B矩陣積的轉(zhuǎn)置矩陣等于B的轉(zhuǎn)置矩陣與A的轉(zhuǎn)置的積(順序不能顛倒)。
矩陣的加法運(yùn)算
設(shè)有矩陣A和矩陣B:
如何計(jì)算A+B和A-B呢?
兩個(gè)矩陣進(jìn)行加法和減法運(yùn)算有一個(gè)前提條件,就是兩個(gè)矩陣的行數(shù)和列數(shù)相同,在這種情況下,兩個(gè)矩陣相加和相減的結(jié)果是一個(gè)新的矩陣,新矩陣的行數(shù)和列數(shù)和原來(lái)矩陣的行列數(shù)相同,其元素分別是兩個(gè)矩陣對(duì)應(yīng)元素的和值和差值。
矩陣的加法和減法運(yùn)算可以看作矩陣內(nèi)對(duì)應(yīng)向量的加法或減法運(yùn)算。例如在計(jì)算A+B的過(guò)程中,A的列向量或行向量分別與B的列向量或行向量相加,結(jié)果是新矩陣的列向量或行向量。
純量與矩陣的乘法運(yùn)算
純量與矩陣相乘,結(jié)果矩陣與原矩陣的行列數(shù)相同,其元素的值是原矩陣中每個(gè)對(duì)應(yīng)元素與純量相乘的數(shù)值。
(-1)* B的計(jì)算過(guò)程如下所示:
例1:編寫Python程序,實(shí)現(xiàn)前面矩陣A和B的加法運(yùn)算和減法運(yùn)算。
在Python程序中,使用嵌套列表定義一個(gè)二維數(shù)組,這個(gè)二維數(shù)組就是一個(gè)矩陣。
#使用嵌套列表定義矩陣A和B
A = [[-1,3,2],[5,7,-2],[-3,0,1]]
B = [[8,2,-1],[6,4,0],[-2,3,5]]
#定義矩陣C,存儲(chǔ)A+B的結(jié)果
C = [[0,0,0],[0,0,0],[0,0,0]]
#定義矩陣D,存儲(chǔ)A-B的結(jié)果
D = [[0,0,0],[0,0,0],[0,0,0]]
遍歷A矩陣的行
for i in range(len(A)):
遍歷A矩陣的列
for j in range(len(A[0])):
C[i][j] = A[i][j] + B[i][j]
D[i][j] = A[i][j] - B[i][j]
print(C)
print(D)
在實(shí)際應(yīng)用中,一般使用numpy對(duì)矩陣進(jìn)行運(yùn)算。
導(dǎo)入numpy模塊
import numpy as np
定義矩陣
A = np.array([[-1,3,2],[5,7,-2],[-3,0,1]])
B = np.array([[8,2,-1],[6,4,0],[-2,3,5]])
矩陣運(yùn)算
print(A+B)
print(A-B)
矩陣的線性變換
變換本質(zhì)是一個(gè)函數(shù),它是一個(gè)映射,它接受輸入內(nèi)容并輸出對(duì)應(yīng)結(jié)果。
例如函數(shù):
當(dāng)x取不同實(shí)數(shù)時(shí),都會(huì)有唯一對(duì)應(yīng)的輸出結(jié)果來(lái)對(duì)應(yīng)輸入的x。
對(duì)線性代數(shù)來(lái)說(shuō),變換是接受一個(gè)向量,并輸出一個(gè)向量。在線性代數(shù)中,一個(gè)向量到另外一個(gè)向量的映射之所以稱為變換,不稱為函數(shù),是因?yàn)榭紤]到了向量的變換實(shí)際是向量的運(yùn)動(dòng)。
如:二維空間的向量A到向量B的變換,實(shí)際是向量A通過(guò)變換移動(dòng)到了向量B的位置。
A =(10,0,60.0) B=(56.6,22.3)
圖中向量A到向量B的變換是一種旋轉(zhuǎn)變換,該變換為線性變換,它滿足下面的性質(zhì)。
設(shè)旋轉(zhuǎn)變換為T,對(duì)線性空間V中的任意向量A和B及實(shí)數(shù)k,均有
T(A+B)= T(A)+T(B)
T(kA) = kT(A)
要驗(yàn)證旋轉(zhuǎn)變換是否是線性變換,需要求出變換T,看變換T是否滿足線性變換的兩個(gè)性質(zhì)。下圖是二維空間向量V圍繞原點(diǎn)逆時(shí)針旋轉(zhuǎn)的示意圖。
如上圖所示,向量V繞原點(diǎn)逆時(shí)針旋轉(zhuǎn)θ角,得到向量V’,假設(shè)向量V=(x,y),則向量V’為:
旋轉(zhuǎn)變換T為:
若T是線性變換,應(yīng)滿足線性變換的兩個(gè)性質(zhì)。下面我們用Python程序來(lái)驗(yàn)證T是線性變換。驗(yàn)證代碼如下:
import numpy as np
# 定義向量A
A = np.array([3,2])
# 定義向量B
B = np.array([-1,5])
# 定義純量K
k = 3.14
# 定義旋轉(zhuǎn)角度
r = 30
# 定義變換T函數(shù)
# v:向量 a:旋轉(zhuǎn)的角度
def T(v,a):
# 轉(zhuǎn)換為弧度
a = a / 180 * np.pi
# 向量v旋轉(zhuǎn)a到m
m = np.array([v[0]*np.cos(a)-v[1]*np.sin(a),
v[0]*np.sin(a)+v[1]*np.cos(a)])
return m
print("T(A+B)=T(A)+T(B):%s:%s" % (str(T(A+B,r)),str(T(A,r)+T(B,r))))
print("kT(A)=T(kA):%s:%s" % (str(k*T(A,r)),str(T(k*A,r))))
輸出結(jié)果如下圖所示:
旋轉(zhuǎn)變換T可以用矩陣表示,T也稱為旋轉(zhuǎn)變換矩陣:
計(jì)算向量V到向量V’的轉(zhuǎn)換可以使用矩陣乘法:
使用矩陣乘法可以對(duì)多個(gè)二維向量組進(jìn)行旋轉(zhuǎn):
Python代碼如下:
import numpy as np
#定義旋轉(zhuǎn)矩陣T
# a:旋轉(zhuǎn)角度
def T(a):
# 轉(zhuǎn)換為弧度
a = a / 180 * np.pi
return np.array([
[np.cos(a),-np.sin(a)],
[np.sin(a),np.cos(a)]
])
# 定義矩陣A
# 矩陣A為待旋轉(zhuǎn)的向量組
A = np.array([[3,2],
[-1,5],
[5,-2],
[2,-3],
[1,-1]
])
# 對(duì)矩陣A進(jìn)行轉(zhuǎn)置再相乘
C = np.matmul(T(30),np.transpose(A))
print(C)
輸出結(jié)果如下圖所示:
-
矩陣
+關(guān)注
關(guān)注
1文章
434瀏覽量
35077 -
python
+關(guān)注
關(guān)注
56文章
4825瀏覽量
86276 -
數(shù)組
+關(guān)注
關(guān)注
1文章
419瀏覽量
26397
發(fā)布評(píng)論請(qǐng)先 登錄
設(shè)計(jì)IIR濾波器的雙線性變換法
模擬信號(hào)線性變換該如何設(shè)計(jì)
如何用雙線性變換法來(lái)設(shè)計(jì)數(shù)字濾波器?
變換矩陣無(wú)法實(shí)現(xiàn)正常變換
濾波器設(shè)計(jì)與信號(hào)處理的MATLAB實(shí)現(xiàn)
用雙線性變換法實(shí)現(xiàn)IIR數(shù)字濾波器
Stein方程的線性變換解法
用雙線性變換法設(shè)計(jì)IIR濾波器
雙線性變換法設(shè)計(jì)數(shù)字Butterworth和Chebyshe
a穩(wěn)定分布噪聲中諧波恢復(fù)的非線性變換方法
雙線性變換法中預(yù)畸變概念的補(bǔ)充
傳遞函數(shù) 2.3狀態(tài)空間表達(dá)式的建立 2.4線性變換
基于Matrix矩陣變換的圖形變換技巧分享

評(píng)論