Я пытаюсь написать программу, которая может выполнять устранение по Гауссу без частичного поворота. Это то, что у меня есть, я знаю, что что-то напутал, но не могу понять, что. Он продолжает печатать ту же матрицу, с которой начал, а не 0 с 1 по диагонали. Любая помощь приветствуется!
import numpy as np
import math
#A = np.array([[1,2,-1],[5,2,2],[-3,5,-1]])
#b = np.array([[2,9,1]])
A = np.array([[8,-2,-1,0,0],[-2,9,-4,-1,0],[-1,-3,7,-1,2],[0,-4,-2,12,-5],[0,0,-7,-3,15]])
b = np.array([[5],[2],[0],[1],[5]])
def forward_elim(A, b, n):
#calculates the forward part of Gaussian elimination.
for row in range(0, n-1):
for i in range(row+1, n):
factor = A[i,row] / A[row,row]
for j in range(row, n):
A[i,j] = A[i,j] - factor * A[row,j]
b[i] = b[i] - factor * b[row]
print("A = \n%s and b = %s" % (A,b))
return A, b
def back_sub(A, b, n):
#back substitution and returns result
x = np.zeros((n,1))
x[n-1] = b[n-1] / A[n-1, n-1]
for row in range(n-2, -1, -1):
sums = b[row]
for j in range(row+1, n):
sums = sums - A[row,j] * x[j]
x[row] = sums / A[row,row]
return x
def gauss_elim(A, b):
#performs gaussian elimination without pivoting
n = A.shape[0]
#checks for zero diagonal elements
if any(np.diag(A)==0):
raise ZeroDivisionError(("Can't divide by 0")) #raise used to raise exception
A, b = forward_elim(A, b, n)
return back_sub(A, b, n)
print(A)