-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcomparison.py
36 lines (27 loc) · 1 KB
/
comparison.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
import numpy as np
import scipy
def compare_approximation_interpolation(fx, px, xn, interval, n):
def f(x):
return eval(fx)
# interval points
a, b = interval
x = np.linspace(a, b, 200)
# approximation in n + 2 points
def Approx_func(x):
return eval(px)
Approx_err_xn = [f(i) - Approx_func(i) for i in xn]
Approx_err_interval = [f(j) - Approx_func(j) for j in x]
# Interpolation in n + 1 points
Interp_x = np.array(
[
(a + b + (b - a) * np.cos(((2 * k + 1) * np.pi) / (2 * (n + 1)))) / 2
for k in range(n + 1)
]
)
Interp_y = np.array([f(i) for i in Interp_x])
interpolate = scipy.interpolate.BarycentricInterpolator(Interp_x, Interp_y)
def Interp_func(x):
return interpolate(x)
Interp_err_xn = [f(i) - Interp_func(i) for i in Interp_x]
Interp_err_interval = [f(j) - Interp_func(j) for j in x]
return x, xn, Interp_x, Approx_err_xn, Approx_err_interval, Interp_err_xn, Interp_err_interval