python如何生成任意n阶的三对角矩阵

作者:潮一 时间:2021-09-18 07:41:37 

如何生成任意n阶的三对角矩阵

数学作业要求实现共轭梯度法的算法。

题目中的矩阵A是n=400/500/600的三对角矩阵。

在网上查阅资料未果后,自己解决了。

import numpy as np
def generate_matrix(n):
   # 使用对角矩阵相加得到三对角矩阵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)

结果输出:

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矩阵分成上三角下三角和对角三个矩阵

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.

先讲一个方阵的对角线下的下三角阵和对角线上的上三角阵提取出来(如果只需要上下三角阵,则去掉tril/triu中的第二个参数)

上代码(这里使用tril和triu都是返回array形式,还需使用mat转换回矩阵):

>>> 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]])

而单独要提取对角线上的元素作为一个矩阵有如下两种方法:

1、运用np.diag两次,再使用mat转换回矩阵:

>>> 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、运用下三角矩阵减去次下三角矩阵(即对角线下的下三角阵):

>>> 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]])

来源:https://blog.csdn.net/qq_41821608/article/details/120593046

标签:python,n阶,三对角,矩阵
0
投稿

猜你喜欢

  • Python Django 母版和继承解析

    2023-02-21 09:44:59
  • python中enumerate函数遍历元素用法分析

    2021-08-07 10:07:18
  • pygame 键盘事件的实践

    2023-09-29 18:56:10
  • Python操作Sql Server 2008数据库的方法详解

    2024-01-20 04:47:01
  • 浅谈Python在pycharm中的调试(debug)

    2023-05-04 15:33:20
  • python3.5基于TCP实现文件传输

    2021-08-17 08:22:24
  • 深入浅析python的第三方库pandas

    2021-06-05 03:13:03
  • 浅析Python 简单工厂模式和工厂方法模式的优缺点

    2023-08-04 00:15:00
  • python基于windows平台锁定键盘输入的方法

    2021-01-03 07:46:03
  • SQL server不支持utf8 php却用utf8的矛盾问题解决方法

    2023-07-20 12:01:28
  • 详解如何用SQLyog来分析MySQL数据库

    2008-10-13 12:35:00
  • 使用Python对Csv文件操作实例代码

    2023-04-17 23:50:57
  • Python中处理无效数据的详细教程

    2021-11-18 06:11:07
  • Pandas的AB BA类型数据框去重复

    2022-09-26 07:48:16
  • 在pandas中遍历DataFrame行的实现方法

    2022-02-16 13:13:26
  • block 和 inline 的区别是?

    2009-12-08 13:00:00
  • Python面向对象基础入门之设置对象属性

    2021-10-21 19:25:10
  • python利用元类和描述器实现ORM模型的详细步骤

    2023-11-13 14:54:12
  • pycharm重命名文件的方法步骤

    2021-10-21 23:16:42
  • PHP用PDO如何封装简单易用的DB类详解

    2023-11-23 16:05:39
  • asp之家 网络编程 m.aspxhome.com