-
Notifications
You must be signed in to change notification settings - Fork 0
/
test_example_feas_iter.py
83 lines (73 loc) · 2.17 KB
/
test_example_feas_iter.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
import casadi as cs
import numpy as np
from matplotlib import pyplot as plt
from fslp import fslp
x = cs.MX.sym('x', 2)
f = x[0] - x[1]
# f = x[0]**2 + (x[1]-2)**2
g = x[0]**2 + x[1]**2
lbg = cs.vertcat(4)
ubg = cs.vertcat(4)
x0 = cs.vertcat(2, 0)
problem_dict = {}
problem_dict['x'] = x
problem_dict['f'] = f
problem_dict['g'] = g
init_dict = {}
init_dict['lbg'] = lbg
init_dict['ubg'] = ubg
init_dict['x0'] = x0
init_dict['tr_rad0'] = 1.0
max_iter = 1
max_inner_iter = 50
contraction_acceptance = 0.3
watchdog = 5
feas_tol = 1e-7
tr_eta1 = 0.25
tr_eta2 = 0.75
tr_alpha1 = 0.25
tr_alpha2 = 2
tr_tol = 1e-8
opts = {}
opts['subproblem_sol'] = 'cplex'
opts['subproblem_sol_opts'] = {'verbose':False, 'tol':1e-9, 'qp_method':2, 'warm_start':True, 'dep_check':0, 'cplex':{'CPXPARAM_Simplex_Display':0, 'CPXPARAM_ScreenOutput':0}, 'jit':True}
opts['max_iter'] = max_iter
opts['max_inner_iter'] = max_inner_iter
opts['contraction_acceptance'] = contraction_acceptance
opts['watchdog'] = watchdog
opts['feas_tol'] = feas_tol
opts['verbose'] = True
opts['tr_eta1'] = tr_eta1
opts['tr_eta2'] = tr_eta2
opts['tr_alpha1'] = tr_alpha1
opts['tr_alpha2'] = tr_alpha2
opts['tr_tol'] = tr_tol
opts['opt_check_slacks'] = False
opts['solver_type'] = 'SLP'
opts['use_anderson'] = True
opts['anderson_memory'] = 1
feasible_solver = fslp.FSLP_Method()
x_sol, f_sol = feasible_solver.solve(problem_dict, init_dict, opts)
print(x_sol)
list_x = [a[0] for a in feasible_solver.list_inner_iterates[0]]
list_x = cs.vertcat(*list_x)
list_y = [a[1] for a in feasible_solver.list_inner_iterates[0]]
list_y = cs.vertcat(*list_y)
# Plot the solution here
x_points = np.linspace(1, 2, 50)
y_points1 = np.sqrt((x_points-2)*(-x_points))
y_points2 = -2*np.sqrt((x_points-2)*(-x_points))
circle1 = plt.Circle((0, 0), 2, edgecolor='r', fill=False)
rect1 = plt.Rectangle((1, -1), 2, 2, edgecolor='b', fill=False)
fig, ax = plt.subplots()
ax.add_patch(circle1)
ax.add_patch(rect1)
ax.set_aspect('equal')
plt.vlines(2, -3, 3)
# plt.plot(x_points, y_points1, color='g')
# plt.plot(x_points, y_points2, color='g')
plt.plot(list_x, list_y, color='m', marker='o')
plt.xlim((1,2.1))
plt.ylim((0,1.1))
plt.show()
print(feasible_solver.list_inner_iterates[0])