亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python如何生成任意n階的三對(duì)角矩陣

 更新時(shí)間:2022年05月11日 09:30:43   作者:潮一  
這篇文章主要介紹了python如何生成任意n階的三對(duì)角矩陣,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

如何生成任意n階的三對(duì)角矩陣

數(shù)學(xué)作業(yè)要求實(shí)現(xiàn)共軛梯度法的算法。

題目中的矩陣A是n=400/500/600的三對(duì)角矩陣。

在網(wǎng)上查閱資料未果后,自己解決了。

import numpy as np
def generate_matrix(n):
    # 使用對(duì)角矩陣相加得到三對(duì)角矩陣A
    array_a = np.diag([-2] * n)
    array = np.diag([1] * (n-1))
    a = np.zeros((n-1))
    b = np.zeros(n)
    array_b = np.insert(array, 0, values=a, axis=0)# 添加行
    array_b = np.insert(array_b, (n-1), values=b, axis=1)# 添加列
    array_c = np.insert(array, (n-1), values=a, axis=0)
    array_c = np.insert(array_c, 0, values=b, axis=1)
    matrix_A = array_a + array_b + array_c
    print(array_a)
    print(array_b)
    print(array_c)
    print(matrix_A)

# Press the green button in the gutter to run the script.
if __name__ == '__main__':
    n = 5
    generate_matrix(n)

結(jié)果輸出:

C:\Users\87167\Anaconda3\envs\tf\python.exe C:/Users/87167/PycharmProjects/GongETiDuFa/main.py
[[-2  0  0  0  0]
 [ 0 -2  0  0  0]
 [ 0  0 -2  0  0]
 [ 0  0  0 -2  0]
 [ 0  0  0  0 -2]]
[[0 0 0 0 0]
 [1 0 0 0 0]
 [0 1 0 0 0]
 [0 0 1 0 0]
 [0 0 0 1 0]]
[[0 1 0 0 0]
 [0 0 1 0 0]
 [0 0 0 1 0]
 [0 0 0 0 1]
 [0 0 0 0 0]]
[[-2  1  0  0  0]
 [ 1 -2  1  0  0]
 [ 0  1 -2  1  0]
 [ 0  0  1 -2  1]
 [ 0  0  0  1 -2]]

python矩陣分成上三角下三角和對(duì)角三個(gè)矩陣

diagonal

Return specified diagonals.

diagflat

Create a 2-D array with the flattened input as a diagonal.

trace

Sum along diagonals.

triu

Upper triangle of an array.

tril

Lower triangle of an array.

先講一個(gè)方陣的對(duì)角線下的下三角陣和對(duì)角線上的上三角陣提取出來(lái)(如果只需要上下三角陣,則去掉tril/triu中的第二個(gè)參數(shù))

上代碼(這里使用tril和triu都是返回array形式,還需使用mat轉(zhuǎn)換回矩陣):

>>> m = np.mat("1,2,3;4,5,6;7,8,9")
>>> m
matrix([[1, 2, 3],
        [4, 5, 6],
        [7, 8, 9]])
>>> L = np.tril(m,-1)
>>> L
array([[0, 0, 0],
       [4, 0, 0],
       [7, 8, 0]])
>>> U = np.triu(m,1)
>>> U
array([[0, 2, 3],
       [0, 0, 6],
       [0, 0, 0]])

而單獨(dú)要提取對(duì)角線上的元素作為一個(gè)矩陣有如下兩種方法:

1、運(yùn)用np.diag兩次,再使用mat轉(zhuǎn)換回矩陣:

>>> D = np.diag(np.diag(m))
>>> D
array([[1, 0, 0],
? ? ? ?[0, 5, 0],
? ? ? ?[0, 0, 9]])
>>> D = np.mat(D)
>>> D
matrix([[1, 0, 0],
? ? ? ? [0, 5, 0],
? ? ? ? [0, 0, 9]])

2、運(yùn)用下三角矩陣減去次下三角矩陣(即對(duì)角線下的下三角陣):

>>> D = np.tril(m) - L
>>> D
array([[1, 0, 0],
? ? ? ?[0, 5, 0],
? ? ? ?[0, 0, 9]])
>>> D = np.mat(D)
>>> D
matrix([[1, 0, 0],
? ? ? ? [0, 5, 0],
? ? ? ? [0, 0, 9]])

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python閉包與裝飾器原理及實(shí)例解析

    Python閉包與裝飾器原理及實(shí)例解析

    這篇文章主要介紹了Python閉包與裝飾器原理及實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 簡(jiǎn)單了解python中的f.b.u.r函數(shù)

    簡(jiǎn)單了解python中的f.b.u.r函數(shù)

    這篇文章主要介紹了簡(jiǎn)單了解python中的f.b.u.r函數(shù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Python中規(guī)范定義命名空間的一些建議

    Python中規(guī)范定義命名空間的一些建議

    命名空間是Python程序的一大根本,編程時(shí)持命名空間的整潔還是十分必要的,這里就來(lái)為大家總結(jié)Python中規(guī)范定義命名空間的一些建議,需要的朋友可以參考下
    2016-06-06
  • python使用xlrd與xlwt對(duì)excel的讀寫和格式設(shè)定

    python使用xlrd與xlwt對(duì)excel的讀寫和格式設(shè)定

    最近在用python處理excel表的時(shí)候出現(xiàn)了一些問(wèn)題,所以想著記錄下最后的實(shí)現(xiàn)方式和問(wèn)題解決方法。方便自己或者大家在有需要的時(shí)候參考借鑒,下面這篇文章主要就介紹了python使用xlrd與xlwt對(duì)excel的讀寫和格式設(shè)定的相關(guān)資料,一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。
    2017-01-01
  • pytest自動(dòng)化測(cè)試數(shù)據(jù)驅(qū)動(dòng)yaml/excel/csv/json

    pytest自動(dòng)化測(cè)試數(shù)據(jù)驅(qū)動(dòng)yaml/excel/csv/json

    這篇文章主要為大家介紹了pytest自動(dòng)化測(cè)試數(shù)據(jù)驅(qū)動(dòng)yaml/excel/csv/json的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 在Python 2.7即將停止支持時(shí),我們?yōu)槟銕?lái)了一份python 3.x遷移指南

    在Python 2.7即將停止支持時(shí),我們?yōu)槟銕?lái)了一份python 3.x遷移指南

    這篇文章主要介紹了在Python 2.7即將停止支持時(shí)我們?yōu)槟銣?zhǔn)備了一份python 3.x遷移指南的相關(guān)資料,需要的朋友可以參考下
    2018-01-01
  • Python連接Redis的基本配置方法

    Python連接Redis的基本配置方法

    本文分享了Linux系統(tǒng)下Python連接Redis的基本配置方法,Python連接Redis需要Redis的Python包支持
    2018-09-09
  • 解決keras使用cov1D函數(shù)的輸入問(wèn)題

    解決keras使用cov1D函數(shù)的輸入問(wèn)題

    這篇文章主要介紹了解決keras使用cov1D函數(shù)的輸入問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-06-06
  • python實(shí)現(xiàn)飛行棋游戲

    python實(shí)現(xiàn)飛行棋游戲

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)飛行棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • python求兩個(gè)時(shí)間的時(shí)間差(實(shí)例代碼)

    python求兩個(gè)時(shí)間的時(shí)間差(實(shí)例代碼)

    我們?cè)谟胮ython進(jìn)行分析的時(shí)候,可能會(huì)碰到計(jì)算兩個(gè)日期的時(shí)間差。下面為大家介紹一下如何計(jì)算兩個(gè)時(shí)間的時(shí)間差,需要的朋友可以參考下
    2022-11-11

最新評(píng)論