当前位置:   article > 正文

Jacobi迭代法的python实现_编写python代码,针对线性方程组ax=b,基于jacobi迭代法编写通用的函数进行求解。要

编写python代码,针对线性方程组ax=b,基于jacobi迭代法编写通用的函数进行求解。要

设有线性方程组Ax=b,其中n阶矩阵A=(aij)使非奇异矩阵
将A分解为A=M-N,因而Mx=Nx+b,求解Ax=b转化为求解x=M的逆Nx+M的逆b
可构造一阶梯定常迭代法x(k+1)=B
x(k)+f
令A=D-L-U,其中D是有A的主对角元组成的对角矩阵,L是A的下三角矩阵每一行乘以-1,U是A的上三角矩阵每一行乘以-1
Jacobi迭代法中,令M=D,A=D-N,因而B=M的逆N=M的逆(M-A)=D的逆*(L+U)
f=D的逆b
确定初值x0,开始迭代
若x最终收敛于x
,则线性方程组有解x*,否则无解
确定需要的绝对误差限或相对误差限e,确定相应的迭代次数

下面给出一个例子
矩阵A
10.0 3.0 1.0
2.0 -10.0 3.0
1.0 3.0 10.0
b=(14.0,-5.0,14.0)’
要求绝对误差限e=0.00001即精确到小数点后5位
代码如下

# -*- coding: utf-8 -*-
"""
Created on Wed Feb 13 08:09:46 2019

@author: 鹰皇
"""

#jacobi迭代法
import numpy as np
A=[[10.0,3.0,1.0],[2.0,-10.0,3.0],[1.0,3.0,10.0]]
b=[[14.0,-5.0,14.0]]

def get_base(A):#获得一个基,在基
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/78136
推荐阅读
相关标签
  

闽ICP备14008679号