Python實現(xiàn)生成對角矩陣和對角塊矩陣
對角矩陣
scipy中的函數(shù)
在scipy.linalg中,通過tri(N, M=None, k=0, dtype=None)可生成N×M對角矩陣,若M=None,則M默認為N。k表示矩陣中用1填充的次對角線個數(shù)。
print(tri(3,5,2,dtype=int)) ''' [[1 1 1 0 0] [1 1 1 1 0] [1 1 1 1 1]] '''
在numpy中也提供了多種對角矩陣生成函數(shù),包括diag, diagflat, tri, tril, triu等,
numpy.diagflat
diagflat用于生成對角矩陣,diag在diagflat基礎上,添加了提取對角元素的功能,例如
>>> np.diagflat([1,2,3]) array([[1, 0, 0], [0, 2, 0], [0, 0, 3]]) >>> np.diag([1,2,3]) array([[1, 0, 0], [0, 2, 0], [0, 0, 3]]) >>> np.diag(np.ones([3,3])) #提取對角元素 array([1., 1., 1.])
numpy.tri
tri(M,N,k)用于生成M行N列的三角陣,其元素為0或者1,k用于調節(jié)0和1的分界線相對于對角線的位置,例如
>>> np.tri(3,5,1) array([[1., 1., 0., 0., 0.], [1., 1., 1., 0., 0.], [1., 1., 1., 1., 0.]]) >>> np.tri(3,5,2) array([[1., 1., 1., 0., 0.], [1., 1., 1., 1., 0.], [1., 1., 1., 1., 1.]]) >>> np.tri(3,5,3) array([[1., 1., 1., 1., 0.], [1., 1., 1., 1., 1.], [1., 1., 1., 1., 1.]])
tril, triu可用于提取出矩陣的左下和右上的三角陣,其輸入?yún)?shù)除了待提取矩陣之外,另一個參數(shù)與tri中的k相同。
x = np.arange(12).reshape(4,3) >>> np.tril(x,-1) array([[ 0, 0, 0], [ 3, 0, 0], [ 6, 7, 0], [ 9, 10, 11]]) >>> np.triu(x,-1) array([[ 0, 1, 2], [ 3, 4, 5], [ 0, 7, 8], [ 0, 0, 11]])
對角塊矩陣
對于scipy.linalg.block_diag(A,B,C)而言,會生成如下形式矩陣
from scipy.linalg import * import numpy as np A = np.ones([2,2]) B = np.round(np.random.rand(3,3),2) C = np.diag([1,2,3]) bd = block_diag(A,B,C) print(bd) ''' [[1. 1. 0. 0. 0. 0. 0. 0. ] [1. 1. 0. 0. 0. 0. 0. 0. ] [0. 0. 0.8 0.38 0.41 0. 0. 0. ] [0. 0. 0.84 0.45 0.24 0. 0. 0. ] [0. 0. 0.32 0.22 0.25 0. 0. 0. ] [0. 0. 0. 0. 0. 1. 0. 0. ] [0. 0. 0. 0. 0. 0. 2. 0. ] [0. 0. 0. 0. 0. 0. 0. 3. ]] '''
其中
到此這篇關于Python實現(xiàn)生成對角矩陣和對角塊矩陣的文章就介紹到這了,更多相關Python矩陣內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python學習筆記之抓取某只基金歷史凈值數(shù)據(jù)實戰(zhàn)案例
這篇文章主要介紹了Python學習筆記之抓取某只基金歷史凈值數(shù)據(jù)案例,結合具體實例形式分析了Python基于selenium庫的數(shù)據(jù)抓取及mysql交互相關實現(xiàn)技巧,需要的朋友可以參考下2019-06-06Python實現(xiàn)判斷一個字符串是否包含子串的方法總結
這篇文章主要介紹了Python實現(xiàn)判斷一個字符串是否包含子串的方法,結合實例形式總結分析了四種比較常用的字符串子串判定方法,需要的朋友可以參考下2017-11-11利用Django框架中select_related和prefetch_related函數(shù)對數(shù)據(jù)庫查詢優(yōu)化
這篇文章主要介紹了利用Python的Django框架中select_related和prefetch_related函數(shù)對數(shù)據(jù)庫查詢的優(yōu)化的一個實踐例子,展示如何在實際中利用這兩個函數(shù)減少對數(shù)據(jù)庫的查詢次數(shù),需要的朋友可以參考下2015-04-04Python3實現(xiàn)從排序數(shù)組中刪除重復項算法分析
這篇文章主要介紹了Python3實現(xiàn)從排序數(shù)組中刪除重復項算法,結合3個完整實例形式分析了Python3針對排序數(shù)組的遍歷、去重、長度計算等相關操作技巧,需要的朋友可以參考下2019-04-04