在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

用Python實(shí)現(xiàn)矩陣與線性變換

CHANBAEK ? 來(lái)源:郎哥編程課堂 ? 作者:郎宏林 ? 2023-11-01 11:19 ? 次閱讀

認(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é)果如下圖所示:

圖片

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 矩陣
    +關(guān)注

    關(guān)注

    1

    文章

    434

    瀏覽量

    35077
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4825

    瀏覽量

    86276
  • 數(shù)組
    +關(guān)注

    關(guān)注

    1

    文章

    419

    瀏覽量

    26397
收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    設(shè)計(jì)IIR濾波器的雙線性變換

    設(shè)計(jì)IIR濾波器的雙線性變換法1、脈沖響應(yīng)不變法的主要缺點(diǎn):對(duì)時(shí)域的采樣會(huì)造成頻域的“混疊效應(yīng)”,故有可能使所設(shè)計(jì)數(shù)字濾波器的頻率響應(yīng)與原來(lái)模擬濾波器的頻率響應(yīng)相差很大,而且不能用來(lái)設(shè)計(jì)高
    發(fā)表于 08-01 17:02

    模擬信號(hào)線性變換該如何設(shè)計(jì)

    設(shè)計(jì)要求:將一個(gè)-15V---+15V的模擬信號(hào)線性變換到0--5V,然后傳給一個(gè)芯片,AD轉(zhuǎn)換后發(fā)送給FPGA。我現(xiàn)在有點(diǎn)不明白該如何設(shè)計(jì),倒相比例器么,還是該怎么辦,希望各位大神可以指點(diǎn)一下~?。。?!
    發(fā)表于 03-25 16:56

    如何用雙線性變換法來(lái)設(shè)計(jì)數(shù)字濾波器?

    線性變換法來(lái)設(shè)計(jì)數(shù)字濾波器有哪些設(shè)計(jì)過(guò)程?
    發(fā)表于 04-12 07:13

    變換矩陣無(wú)法實(shí)現(xiàn)正常變換

    最近可能臨近畢業(yè),做畢業(yè)設(shè)計(jì)的同學(xué)多了,經(jīng)常會(huì)有同學(xué)問(wèn)我為什么在搭建仿真過(guò)程中,按照書本給出的變換矩陣無(wú)法實(shí)現(xiàn)正常變換?這篇文章就細(xì)致的講一下原因。在剛開(kāi)始使用matlab對(duì)電機(jī)進(jìn)行建
    發(fā)表于 08-27 06:43

    濾波器設(shè)計(jì)與信號(hào)處理的MATLAB實(shí)現(xiàn)

    2 步模擬濾波器的設(shè)計(jì),我們主要學(xué)習(xí)的是巴特沃斯設(shè)計(jì)方法,因此這里以“巴特沃斯濾波器雙線性變換”設(shè)計(jì)法為例來(lái)闡述 IIR 濾波器的設(shè)計(jì)方法和 matlab 實(shí)現(xiàn)。
    發(fā)表于 09-26 07:22

    線性變換實(shí)現(xiàn)IIR數(shù)字濾波器

    線性變換的頻率對(duì)應(yīng)關(guān)系雙線性變換法雖然避免了“頻率混疊效應(yīng)”,但出現(xiàn)了模擬頻率與數(shù)字頻率為一種非線性的關(guān)系情形。即:可見(jiàn):模擬濾波器與數(shù)字濾波器的響應(yīng)在
    發(fā)表于 08-01 17:04 ?52次下載

    Stein方程的線性變換解法

    利用線性變換及方陣Jordan標(biāo)準(zhǔn)型的方法,給出了Stein矩陣方程存在唯一解的充分必要條件以及解的形式。采用的方法是初等的,所得的結(jié)果比已有結(jié)論豐富。該方法也可用來(lái)研究一
    發(fā)表于 12-10 17:26 ?9次下載

    線性變換法設(shè)計(jì)IIR濾波器

    線性變換法設(shè)計(jì)IIR濾波器一、實(shí)驗(yàn)?zāi)康?、了解兩種工程上最常用的變換方法:脈沖響應(yīng)不變法和雙線性變換法。2、掌握雙線性變換法設(shè)計(jì)IIR濾
    發(fā)表于 05-10 09:51 ?48次下載

    線性變換法設(shè)計(jì)數(shù)字Butterworth和Chebyshe

    線性變換法設(shè)計(jì)IIR濾波器一、實(shí)驗(yàn)?zāi)康?、了解兩種工程上最常用的變換方法:脈沖響應(yīng)不變法和雙線性變換法。2、掌握雙線性變換法設(shè)計(jì)IIR濾
    發(fā)表于 05-10 10:00 ?77次下載

    a穩(wěn)定分布噪聲中諧波恢復(fù)的非線性變換方法

    本文研究a穩(wěn)定分布噪聲中諧波恢復(fù)的問(wèn)題。文中首先引入a穩(wěn)定分布作為模擬脈沖性噪聲的模型,然后采用非線性變換方法使噪聲得到抑制,并證明了變換后的含噪觀測(cè)值具有二階統(tǒng)
    發(fā)表于 01-12 21:46 ?8次下載

    線性變換法中預(yù)畸變概念的補(bǔ)充

    現(xiàn)有數(shù)字信號(hào)處理教材在講述雙線性變換法中預(yù)畸變概念時(shí)略有不足,在一定程度上影響了讀者對(duì)畸變、預(yù)畸變以及為什么叫預(yù)畸變等概念的理解和掌握。通過(guò)一個(gè)濾波器設(shè)計(jì)實(shí)例,較自
    發(fā)表于 04-07 11:31 ?23次下載

    傳遞函數(shù) 2.3狀態(tài)空間表達(dá)式的建立 2.4線性變換

    現(xiàn)代控制理論-2.2傳遞函數(shù) 2.3狀態(tài)空間表達(dá)式的建立 2.4線性變換
    發(fā)表于 12-13 22:20 ?0次下載

    基于Matrix矩陣變換的圖形變換技巧分享

    矩陣變換在圖形學(xué)上經(jīng)常用到?;镜某S?b class='flag-5'>矩陣變換操作包括平移、縮放、旋轉(zhuǎn)、斜切。每種變換都對(duì)應(yīng)一個(gè)變換
    發(fā)表于 09-06 08:54 ?7次下載
    基于Matrix<b class='flag-5'>矩陣</b><b class='flag-5'>變換</b>的圖形<b class='flag-5'>變換</b>技巧分享

    深度學(xué)習(xí)和神經(jīng)網(wǎng)絡(luò)的學(xué)習(xí)是什么樣的?

    怎樣理解非線性變換和多層網(wǎng)絡(luò)后的線性可分,神經(jīng)網(wǎng)絡(luò)的學(xué)習(xí)就是學(xué)習(xí)如何利用矩陣線性變換加激活函數(shù)的非線性變換。
    的頭像 發(fā)表于 10-23 14:44 ?4137次閱讀

    西門子PLC模擬量線性變換子程序的編寫

    在plc編程中,只要涉及到數(shù)據(jù)采集和輸出,都會(huì)遇到模擬量的線性變換。在西門子300plc編程中,系統(tǒng)自帶的兩個(gè)線性變換功能塊FC105和FC106是最常用的兩個(gè)數(shù)據(jù)轉(zhuǎn)換模塊。
    發(fā)表于 03-19 08:59 ?5257次閱讀
    主站蜘蛛池模板: 国产二区三区毛片 | 欧美伊人 | 可以免费观看的黄色网址 | 网站在线观看视频 | 美女好紧好大好爽12p | 亚洲成年网站 | 潘金莲国产三级视频在线 | 国产午夜精品一区二区理论影院 | 中国美女毛片 | 成人在线视频网址 | 国产精品影视 | 综合亚洲色图 | 成人欧美一区二区三区黑人3p | 插白浆| 天堂精品视频 | 天天摸夜夜摸夜夜狠狠摸 | 双性强迫开宫灌满h | 国产免费高清福利拍拍拍 | 国产三级国产精品国产普男人 | 国产精品你懂的在线播放 | 丁香婷婷综合网 | 丁香亚洲综合五月天婷婷 | 久久天天躁狠狠躁夜夜爽蜜月 | 一级毛片免费毛片一级毛片免费 | 97理论三级九七午夜在线观看 | 免费毛片网 | 天天射天天操天天干 | 久久精品免费 | 免费视频性 | 一色屋精品免费视频 视频 一色屋免费视频 | 你懂得的在线观看免费视频 | 六月丁香色婷婷 | 黑人黄色大片 | 国产精品性 | 奇米99| 亚洲色图综合网 | 亚洲区 欧美区 | 久色网| 国产色啪午夜免费视频 | 日本69sex护士xxx| 日韩视频 中文字幕 视频一区 |