Python創(chuàng)建對(duì)稱矩陣的方法示例【基于numpy模塊】
本文實(shí)例講述了Python創(chuàng)建對(duì)稱矩陣的方法。分享給大家供大家參考,具體如下:
對(duì)稱(實(shí)對(duì)稱)矩陣也即:
step 1:創(chuàng)建一個(gè)方陣
>>> import numpy as np >>> X = np.random.rand(5**2).reshape(5, 5) >>> X array([[ 0.26984148, 0.25408384, 0.12428487, 0.0194565 , 0.91287708], [ 0.31837673, 0.35493156, 0.74336268, 0.31810561, 0.04409245], [ 0.06644445, 0.8967897 , 0.10990936, 0.05036292, 0.72581982], [ 0.94758512, 0.21375975, 0.36781736, 0.1633904 , 0.36070709], [ 0.53263787, 0.18380491, 0.0225521 , 0.91239367, 0.75521585]])
step 2:保留其上三角部分
>>> X = np.triu(X) # 保留其上三角部分 >>> X array([[ 0.26984148, 0.25408384, 0.12428487, 0.0194565 , 0.91287708], [ 0. , 0.35493156, 0.74336268, 0.31810561, 0.04409245], [ 0. , 0. , 0.10990936, 0.05036292, 0.72581982], [ 0. , 0. , 0. , 0.1633904 , 0.36070709], [ 0. , 0. , 0. , 0. , 0.75521585]])
step 3:將上三角”拷貝”到下三角部分
>>> X += X.T - np.diag(X.diagonal()) >>> X array([[ 0.26984148, 0.25408384, 0.12428487, 0.0194565 , 0.91287708], [ 0.25408384, 0.35493156, 0.74336268, 0.31810561, 0.04409245], [ 0.12428487, 0.74336268, 0.10990936, 0.05036292, 0.72581982], [ 0.0194565 , 0.31810561, 0.05036292, 0.1633904 , 0.36070709], [ 0.91287708, 0.04409245, 0.72581982, 0.36070709, 0.75521585]])
注意,要減去一次對(duì)角線上的元素。因?yàn)樯先?code>cov,和下三角cov.T
在進(jìn)行相加時(shí)會(huì)把主對(duì)角線上的元素相加兩次。
step 4:測(cè)試
>>> X.T == X array([[ True, True, True, True, True], [ True, True, True, True, True], [ True, True, True, True, True], [ True, True, True, True, True], [ True, True, True, True, True]], dtype=bool)
更多關(guān)于Python相關(guān)內(nèi)容可查看本站專題:《Python數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Python正則表達(dá)式用法總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門(mén)與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
pyinstaller打包python3.6和PyQt5中各種錯(cuò)誤的解決方案匯總
pyinstaller是打包python很方便的一個(gè)套件,我們可以很輕易地使用他,下面這篇文章主要給大家介紹了關(guān)于pyinstaller打包python3.6和PyQt5中各種錯(cuò)誤解決的相關(guān)資料,需要的朋友可以參考下2022-08-08Python的Flask框架中實(shí)現(xiàn)簡(jiǎn)單的登錄功能的教程
這篇文章主要介紹了Python的Flask框架中實(shí)現(xiàn)簡(jiǎn)單的登錄功能的教程,登錄是各個(gè)web框架中的基礎(chǔ)功能,需要的朋友可以參考下2015-04-04Python 實(shí)現(xiàn)遞歸法解決迷宮問(wèn)題的示例代碼
這篇文章主要介紹了Python 實(shí)現(xiàn)遞歸法解決迷宮問(wèn)題的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01python數(shù)據(jù)分析之將爬取的數(shù)據(jù)保存為csv格式
Python內(nèi)置了CSV模塊,可直接通過(guò)該模塊實(shí)現(xiàn)csv文件的讀寫(xiě)操作,在web應(yīng)用中導(dǎo)出數(shù)據(jù)是比較常見(jiàn)操作,下面這篇文章主要給大家介紹了關(guān)于python數(shù)據(jù)分析之將爬取的數(shù)據(jù)保存為csv格式的相關(guān)資料,需要的朋友可以參考下2022-06-06Python實(shí)現(xiàn)批量自動(dòng)整理文件
本文將利用Python制作一個(gè)批量自動(dòng)整理文件的小工具,可以自定義整理某一個(gè)路徑下面的所有需要被整理的文件。感興趣的小伙伴可以了解一下2022-03-03JSON Web Tokens的實(shí)現(xiàn)原理
本文主要介紹了JSON Web Tokens的實(shí)現(xiàn)原理。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-04-04