python实现追赶法

数学原理

链接: link

python代码

'''
功能:求解线性方程组Ax=b,且A=[b1  c1  0   0   0   0
                             a1  b2  c2  0   0   0
                             0   a2  b3  c3  0   0
                             0   0   a3  b4  c4  0
                             0   0   0   a4  b5  c5
                             0   0   0   0   a5  b6]
                        b=[b1,b2,b3,b4,b5,b6]
输入:a=[a1,a2,a3,a4,a5],b[b1,b2,b3,b4,b5,b6],c=[c1,c2,c3,c4,c5],b=[b1,b2,b3,b4,b5,b6]
输出:线性方程组的解向量x
'''

import numpy as np


def thomas(a, b, c, d)
    n = len(b)
    beta = np.ones(n) * b[0]
    y = np.ones(n) * d[0]
    for i in range(1, n):
        beta[i] = b[i] - (a[i - 1] / beta[i - 1]) * c[i - 1]
        y[i] = d[i] - (a[i - 1] / beta[i - 1]) * y[i - 1]
    x = np.ones(n) * y[-1] / beta[-1]
    iter = np.linspace(n - 2, 0, n - 1)
    for i in iter:
        i = int(i)
        x[i] = (y[i] - c[i] * x[i + 1]) / beta[i]
    print("解向量x:{}".format(x))


a = np.array([-1, -1, -3])
b = np.array([2, 3, 2, 5])
c = np.array([-1, -2, -1])
d = np.array([6, 1, 0, 1])
thomas(a, b, c, d)

注:为了编写方便,代码对数学公式进行了一些修改,如代码中a,c阵都是从0开始n-1结束

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值