-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathSOR.py
47 lines (45 loc) · 1.45 KB
/
SOR.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
ax = int(input("Value of the only purely numeric term in x "))
cyx = int(input("Coeffcient of y in equation of x "))
czx = int(input("Coeffcient of z in equation of x "))
dx = int(input("Denominator of equation of x "))
print() #Line break
ay = int(input("Value of the only purely numeric term in y "))
cxy = int(input("Coeffcient of x in equation of y "))
czy = int(input("Coeffcient of z in equation of y "))
dy = int(input("Denominator of equation of y "))
print() #Line break
az = int(input("Value of the only purely numeric term in z "))
cxz = int(input("Coeffcient of x in equation of z "))
cyz = int(input("Coeffcient of y in equation of z "))
dz = int(input("Denominator of equation of z "))
print() #Line break
xi = int(input("Value of x "))
yi = int(input("Value of y "))
zi = int(input("Value of z "))
n = int(input("Up to how many decimals ? ")) #Precision
xf=yf=zf=0.0
i=0
w = float(input("Value of w "))
x0 = xi
y0 = yi
z0 = zi
while(True):
xi = (1-w)*xi + (w/dx)*(ax+cyx*yi+czx*zi)
yi = (1-w)*yi + (w/dy)*(ay+cxy*xi+czy*zi)
zi = (1-w)*zi + (w/dz)*(az+cxz*xi+cyz*yi)
if(xf==round(xi,n) and yf==round(yi,n) and zf==round(zi,n)):
break
xf = round(xi,n)
yf = round(yi,n)
zf = round(zi,n)
i+=1
print ("Iteration no. {}:".format(i))
print("""
x = {0}
y = {1}
z = {2}
""".format(xf,yf,zf))
print() #Line break
print("Final x is: {}".format(xf))
print("Final y is: {}".format(yf))
print("Final z is: {}".format(zf))