Compare commits

...

2 Commits

Author SHA1 Message Date
schrom01 6c893b33b0 solved Task 2 2022-12-08 20:23:28 +01:00
schrom01 b74e3eee77 solved Task 1 2022-12-08 14:31:50 +01:00
4 changed files with 46 additions and 0 deletions

Binary file not shown.

View File

@ -0,0 +1,25 @@
import numpy as np
print("*********Jacobi-Verfahren*********")
def Jacobi(A,b,x,steps):
L = np.tril(A,k=-1)
D = np.diag(np.diag(A))
R = np.triu(A, k=1)
for steps in range(steps):
x = -np.linalg.inv(D) @ (L + R) @ x + np.linalg.inv(D) @ b
#print(np.linalg.norm((-np.linalg.inv(D) @ (L + R)),np.inf))
return x
A = np.array([[8,5,2],[5,9,1],[4,2,7]])
b = np.array([[19],[5],[34]])
x = np.array([[1],[-1],[3]])
steps = 3
print(Jacobi(A,b,x,steps))
print("Sum of vector:")
#print(np.sum(Jacobi(A,b,x,steps)))
#print(np.linalg.norm(Jacobi(A,b,x,3)-Jacobi(A,b,x,2),np.inf)*7)
print(np.linalg.norm(Jacobi(A,b,x,3)-Jacobi(A,b,x,2),np.inf))
print((0.0001*0.125)/0.7693452380952384)

Binary file not shown.

View File

@ -0,0 +1,21 @@
import numpy as np
print("*********Gauss Seidel*********")
def Gauss_Seidel(A,b,x,steps):
L = np.tril(A,k=-1)
D = np.diag(np.diag(A))
R = np.triu(A, k=1)
print(np.linalg.norm(-np.linalg.inv(D+L) @ R,np.inf))
for steps in range(steps):
x = -np.linalg.inv(D+L) @ R @ x + np.linalg.inv(D+L) @ b
return x
A = np.array([[8,5,2],[5,9,1],[4,2,7]])
b = np.array([[19],[5],[34]])
x = np.array([[1],[-1],[3]])
steps = 3
print(Gauss_Seidel(A,b,x,steps))
print("Sum of vector:")
print(np.sum(Gauss_Seidel(A,b,x,steps)))
print(np.linalg.norm(Gauss_Seidel(A,b,x,3)-Gauss_Seidel(A,b,x,2),np.inf))