高斯消去法的python实现

数值分析中,高斯消去法的原理和python代码

原理

高斯消去法(Gauss)的原理如下:在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

python代码

import numpy as np #首先确保python安装了numpy包


def gauss(a, b):   #自己定义一个函数,自变量是a,b
    cout = 0           #定义计算次数
    m, n = a.shape   #矩阵a的行数和列数
    if ( m < n ):
        print("There is a 解空间。")#保证方程个数大于未知数个数
    else:
        l = np.zeros((n,n))
        for i in range(n):
            # 限制条件
            if (a[i][i] == 0):
                print("no answer")


        # j表示列
        for k in range(n - 1):          # k表示第一层循环,(0,n-1)for i in range(k + 1, n):   # i表示第二层循环,(k+1,n),计算该行消元的系数
                l[i][k] = a[i][k] / a[k][k]     #计算l
                cout += 1               #计算次数加一
                for j in range(m):      # j表示列,对每一列进行运算
                    a[i][j] = a[i][j] - l[i][k] * a[k][j]
                    cout += 1
                b[i] = b[i] - l[i][k] * b[k]
        # 回代求出方程解
        x = np.zeros(n)                       #先将解赋值为零,再一一计算
        x[n - 1] = b[n - 1] / a[n - 1][n - 1] #先算最后一位的x解

        for i in range(n - 2, -1, -1):      #依次回代倒着算每一个解
            for j in range(i + 1, n):
                b[i] -= a[i][j] * x[j]       #自增自减
            x[i] = b[i] / a[i][i]
        for i in range(n):
            print("x" + str(i + 1) + " = ", x[i])
        print("x" " = ", x)
        print("计算次数", "=", cout)

#---------------以上是主程序,以下是输入程序

if __name__ == '__main__':      #当模块被直接运行时,以下代码块将被运行,当模块是被导入时,代码块不被运行。
    a = np.array([[0.5, 1.1, 3.1], [2.0, 4.5, 0.36], [5.0, 0.96, 6.5]])    #输入的系数矩阵
    b = np.array([-6.0, 0.020, 0.96])                                      #增广的一列矩阵
    gauss(a, b)                                                          #进行函数guassin运算


  • 12
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值