2015-02-27 14:43:33 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
from math import pi, sin, cos, exp
|
|
|
|
from numpy import arange
|
2015-02-27 22:34:25 +00:00
|
|
|
from collections import namedtuple
|
|
|
|
|
|
|
|
Result = namedtuple("Result", ["p1", "p2", "error"])
|
|
|
|
|
|
|
|
def main():
|
2015-03-08 21:11:49 +00:00
|
|
|
# f(x) = p1 * cos(p2 * x)
|
2015-02-27 22:34:25 +00:00
|
|
|
|
2015-03-08 21:11:49 +00:00
|
|
|
parameter_cos_1=0.3
|
|
|
|
parameter_cos_2=1.5
|
2015-02-27 22:34:25 +00:00
|
|
|
|
2015-03-08 21:11:49 +00:00
|
|
|
transition_point = (1/parameter_cos_2) * pi/2 * 0.65
|
2015-02-27 22:34:25 +00:00
|
|
|
|
2015-03-08 21:11:49 +00:00
|
|
|
cos_value = parameter_cos_1 * cos(parameter_cos_2 * transition_point)
|
2015-02-27 22:34:25 +00:00
|
|
|
|
2015-03-08 21:11:49 +00:00
|
|
|
derived_cos_value = parameter_cos_1 * parameter_cos_2 * -sin(parameter_cos_2 * transition_point)
|
2015-02-27 22:34:25 +00:00
|
|
|
|
|
|
|
#g(x) = e^(p1 - p2 * x)
|
|
|
|
result = Result(10, 10, 1)
|
|
|
|
step = 10
|
|
|
|
while (result.error > 0.0001):
|
|
|
|
parameter_ex_p1 = list(arange(result.p1 - step, result.p1 + step, step/10))
|
|
|
|
parameter_ex_p2 = list(arange(result.p2 - step, result.p2 + step, step/100))
|
|
|
|
step /= 10
|
|
|
|
|
2015-03-08 21:11:49 +00:00
|
|
|
result = calculate(parameter_ex_p1, parameter_ex_p2, transition_point, cos_value, derived_cos_value)
|
2015-02-27 22:34:25 +00:00
|
|
|
|
2015-03-08 21:11:49 +00:00
|
|
|
print("cos p1: " + str(parameter_cos_1))
|
|
|
|
print("cos p2: " + str(parameter_cos_2))
|
2015-02-27 22:34:25 +00:00
|
|
|
print("transition point: " + str(transition_point))
|
|
|
|
print("p1: " + str(result.p1))
|
|
|
|
print("p2: " + str(result.p2))
|
|
|
|
print("combined error: " + str(result.error))
|
|
|
|
|
2015-03-08 21:11:49 +00:00
|
|
|
def calculate(parameter_ex_p1, parameter_ex_p2, transition_point, cos_value, derived_cos_value):
|
2015-02-27 22:34:25 +00:00
|
|
|
best_parameter_ex_p1 = -1
|
|
|
|
best_parameter_ex_p2 = -1
|
|
|
|
best_combined_error = 100
|
|
|
|
for p1 in parameter_ex_p1:
|
|
|
|
for p2 in parameter_ex_p2:
|
|
|
|
value = exp(p1 - p2 * transition_point)
|
|
|
|
derived_value = - p2 * exp(p1 - p2 * transition_point)
|
2015-03-08 21:11:49 +00:00
|
|
|
error = abs(value - cos_value)
|
|
|
|
derived_error = abs(derived_value - derived_cos_value)
|
2015-02-27 22:34:25 +00:00
|
|
|
combined_error = error + derived_error
|
|
|
|
if combined_error < best_combined_error:
|
|
|
|
best_parameter_ex_p1 = p1
|
|
|
|
best_parameter_ex_p2 = p2
|
|
|
|
best_combined_error = combined_error
|
|
|
|
return Result(best_parameter_ex_p1, best_parameter_ex_p2, best_combined_error)
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|