-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathSP_Final.py
105 lines (75 loc) · 2.66 KB
/
SP_Final.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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
import numpy as np
import matplotlib.pyplot as plt
import pandas as pd
import scipy.io as sio
def x_step(x_vec, y_mat, dt_x):
dx1 = x_der(x_vec, y_mat[0, :, :])
x_vec2 = x_vec + .5 * dt_x * dx1
dx2 = x_der(x_vec2, y_mat[4, :, :])
x_vec3 = x_vec + .5 * dt_x * dx2
dx3 = x_der(x_vec3, y_mat[4, :, :])
x_vec4 = x_vec + dt_x * dx3
dx4 = x_der(x_vec4, y_mat[9, :, :])
x_vec = x_vec + dt_x / 6 * (dx1 + 2 * dx2 + 2 * dx3 + dx4)
return x_vec
def x_der(x_vec, y_mat):
f = 20
h = 1
c = 10
b = 10
y_avg = np.sum(y_mat, 0).squeeze()
minus = [-1, 0, 1, 2, 3, 4, 5, 6]
minus2 = [-2, -1, 0, 1, 2, 3, 4, 5]
plus = [1, 2, 3, 4, 5, 6, 7, 0]
x_minus = x_vec[minus]
x_minus2 = x_vec[minus2]
x_plus = x_vec[plus]
dx = x_minus * (x_plus - x_minus2) - x_vec + f - (h * c / b) * y_avg
return dx
def y_step(x_vec, y_temp, dt_y, dt_x):
y_final = np.zeros((int(dt_x / dt_y), 8, 8))
for i in range(int(dt_x / dt_y)):
dy1 = y_der(x_vec, y_temp)
y_mat2 = y_temp + .5 * dt_y * dy1
dy2 = y_der(x_vec, y_mat2)
y_mat3 = y_temp + .5 * dt_y * dy2
dy3 = y_der(x_vec, y_mat3)
y_mat4 = y_temp + dt_y * dy3
dy4 = y_der(x_vec, y_mat4)
y_temp = y_temp + dt_y / 6 * (dy1 + 2 * dy2 + 2 * dy3 + dy4)
y_final[i, :, :] = y_final[i, :, :] + y_temp
return y_temp, y_final
def y_der(x_vec, y_mat):
h = 1
c = 10
b = 10
minus = [-1, 0, 1, 2, 3, 4, 5, 6]
plus = [1, 2, 3, 4, 5, 6, 7, 0]
plus2 = [2, 3, 4, 5, 6, 7, 0, 1]
y_minus = y_mat[minus, :]
y_plus = y_mat[plus, :]
y_plus2 = y_mat[plus2, :]
dy = -c * b * y_plus * (y_plus2 - y_minus) - c * y_mat + (h * c / b) * x_vec
return dy
dt_x=.05
dt_y=.005
t_max=10
t_vec=np.linspace(dt_x,t_max,int(t_max/dt_x))
x_store=np.zeros((20000,8))
data=np.load('truth_h_1_c_10_F_20.npy')
data[:8,:] = data[:8,:]*6.7887+3.5303
data[8:,:] = data[8:,:]*.3608+.1262
for j in range(100):
x_vec=data[:8,949999+int(j*2000)]
y_mat=data[8:,949999+int(j*2000)].reshape((8,8),order='F')
for i in range(0,int(t_max/dt_x)-1):
y_mat, y_final = y_step(x_vec, y_mat, dt_y, dt_x)
x_vec = x_step(x_vec, y_final, dt_x)
x_store[int(j*200)+i,:]=x_vec
truth=data[:8,950009:1150009]
tot_err_SP=np.zeros((200,100))
for i in range(0,100):
mean=np.mean(np.linalg.norm(truth[int(i*2000):int(i*2000)+2000],2,axis=1))
error=np.linalg.norm(x_store[int(i*200):int(i*200)+200]-truth[int(i*2000):int(i*2000)+2000],2,axis=1)/mean
tot_err_SP[:,i]=error
tot_err_SP=np.mean(tot_err_SP,axis=1)