发布于2020-03-25 08:15 阅读(3067) 评论(0) 点赞(15) 收藏(5)
首先要了解高斯消去法的原理和代码,高斯消去法的原理和python实现,高斯列主元消去法是高斯消去法的改进。
import numpy as np
def swap(a, b, k, n): # 找到主元并交换,这仅是一个仅用来交换的函数
ans = 0
for i in range(k, n):
if ans < np.fabs(a[i][k]): #fabs是绝对值,将a中绝对值最大的找出来
ans = a[i][k]
maxn = i
a[[k, maxn], :] = a[[maxn, k], :] #交换
b[k], b[maxn] = b[maxn], b[k]
#主算法
def gaussin(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)行
swap(a, b, k, n) #在每次计算前,找到最大主元,进行换行
for i in range(k + 1, n): # i表示第二层循环,(k+1,n)行,计算该行消元的系数
l[i][k] = a[i][k] / a[k][k] #计算
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])
gaussin(a, b)
作者:dfd323
链接:https://www.pythonheidong.com/blog/article/281653/b7eedd91cf6f9a5e611c/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!