返回顶部
首页 > 资讯 > 后端开发 > Python >python如何生成任意n阶的三对角矩阵
  • 911
分享到

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

2024-04-02 19:04:59 911人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录如何生成任意n阶的三对角矩阵python矩阵分成上三角下三角和对角三个矩阵如何生成任意n阶的三对角矩阵 数学作业要求实现共轭梯度法的算法。 题目中的矩阵A是n=400/500/6

如何生成任意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]])

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: python如何生成任意n阶的三对角矩阵

本文链接: https://lsjlt.com/news/117856.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python如何生成任意n阶的三对角矩阵
    目录如何生成任意n阶的三对角矩阵python矩阵分成上三角下三角和对角三个矩阵如何生成任意n阶的三对角矩阵 数学作业要求实现共轭梯度法的算法。 题目中的矩阵A是n=400/500/6...
    99+
    2024-04-02
  • Python生成对角矩阵和对角块矩阵
    文章目录 对角矩阵scipy中的函数numpy.diagflatnumpy.tri 对角块矩阵 对角矩阵 scipy中的函数 在scipy.linalg中,通过tri(N, M=...
    99+
    2023-10-09
    python numpy scipy 对角矩阵 对角块矩阵
  • Python实现生成对角矩阵和对角块矩阵
    目录对角矩阵scipy中的函数numpy.diagflatnumpy.tri对角块矩阵对角矩阵 scipy中的函数 在scipy.linalg中,通过tri(N, M=None, k...
    99+
    2023-05-15
    Python生成对角矩阵 Python生成对角块矩阵 Python生成矩阵 Python矩阵
  • 如何生成对角矩阵numpy.diag
    目录生成对角矩阵 numpy.diagnumpy.diag()结构及用法||参数参数详解示例生成对角矩阵 numpy.diag 给定对角线上元素,我想生成对角矩阵,在网上搜了一下,竟...
    99+
    2024-04-02
  • Python如何生成n行n列的矩阵
    要生成n行n列的矩阵,可以使用嵌套的列表推导式。下面是一个示例代码:```pythonn = 3 # 矩阵的大小,这里为3x3# ...
    99+
    2023-09-26
    python
  • 怎么使用Python实现生成对角矩阵和对角块矩阵
    这篇文章主要介绍了怎么使用Python实现生成对角矩阵和对角块矩阵的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Python实现生成对角矩阵和对角块矩阵文章都会有所收获,下面我们一起来看看吧。对角矩阵s...
    99+
    2023-07-06
  • python生成单位阵或对角阵的三种方式小结
    目录python生成单位阵或对角阵1.identity2.eye3.diag(可以指定对角元素)python创建对角阵的np.eye()函数看下面两个例子就明白用法啦python生成...
    99+
    2024-04-02
  • python生成单位阵或对角阵的三种方式是什么
    本篇内容介绍了“python生成单位阵或对角阵的三种方式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!python生成单位阵或对角阵前...
    99+
    2023-06-30
  • 如何使用Python生成Hilbert矩阵
    目录1.什么是Hilbert矩阵矩阵2.找规律3.代码展示4.输出展示5.初始化解为1,1,(1)以生3*4的增广矩阵为例(2)输出结果1.什么是Hilbert矩阵矩阵 下面分别列举...
    99+
    2024-04-02
  • 用Python生成N层的杨辉三角的实现方法
    【杨辉三角简介】   杨辉三角,是二项式系数在三角形中的一种几何排列。在欧洲,这个表叫做帕斯卡三角形。 【代码实现】 n = eval(input("...
    99+
    2024-04-02
  • python如何使用生成器输出杨辉三角形
    小编给大家分享一下python如何使用生成器输出杨辉三角形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!生成器def triangle_2(n):&nb...
    99+
    2023-06-17
  • Python如何生成任意波形并存为txt
    这篇文章主要介绍了Python如何生成任意波形并存为txt,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一. 脚本功能根据采样点数,采样周期数等参数以及波形的数学表达式,生成...
    99+
    2023-06-25
  • python如何计算一行中任意数字的阶乘
    小编给大家分享一下python如何计算一行中任意数字的阶乘,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!计算一行中任意数字的阶乘。Python 2.x.resul...
    99+
    2023-06-27
  • Python中如何针对任意多的分隔符进行拆分字符串
    这篇文章给大家介绍Python中如何针对任意多的分隔符进行拆分字符串,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。我们需要将字符串拆分为不同的字段,但是分隔符(以及分隔符之间的空格)在整个字符串中并不一致。字符串对象的...
    99+
    2023-06-02
  • 如何对Python编译PyInstaller打包生成的exe文件进行反编译生成pyc、py源代码文件
    目录准备工作根据exe生成pyc文件根据pyc文件反编译为py文件参考总结准备工作 没有加壳的python编译并打包的exe文件python反打包代码(不知道这样叫是否合理):pyt...
    99+
    2023-01-18
    exe可以反编译成源码 exe程序反编译教程 如何反编译pyc文件
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作