-
Notifications
You must be signed in to change notification settings - Fork 16
/
testA.py
37 lines (32 loc) · 1.22 KB
/
testA.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
from FastAmericanOptionSolverA import *
from multiprocessing import Pool
if __name__ == '__main__':
# unit test one for valuing American option
r = 0.04 # risk free
q = 0.01 # dividend yield
K = 100.0 # strike
S = 80.0 # underlying spot
sigma = 0.2 # volatility
T = 3.0 # maturity
option_type = qd.OptionType.Put
solver = FastAmericanOptionSolverA(r, q, sigma, K, T, option_type)
solver.use_derivative = False
solver.iter_tol = 1e-5
solver.max_iters = 20
price = solver.solve(0.0, S) # t and S
print("european price = ", solver.european_price)
print("american price = ", price)
#make a plot for exercise boundary
plt.plot(solver.shared_tau, solver.shared_B, 'o-')
plt.plot(solver.shared_tau, solver.shared_B0, 'r--')
plt.legend(["real exercise boundary", "initial guess"])
plt.xlabel("Time to maturity tau")
plt.ylabel("Exercise boundary [$]")
plt.show()
plt.figure(2)
iters = np.array([float(x[0]) for x in solver.iter_records])
errors = np.array([x[1] for x in solver.iter_records])
plt.loglog(iters, errors, 'o-')
plt.xlabel("Number of iterations")
plt.ylabel("Match condition error")
plt.show()