forked from libprima/prima
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrosenbrock.py
59 lines (45 loc) · 2.28 KB
/
rosenbrock.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
#!/usr/bin/env python3
"""Illustration of how to use prima."""
import numpy as np
from prima import minimize, Bounds, LinearConstraint, NonlinearConstraint
# Print NumPy array nicely.
np.set_printoptions(precision=4, threshold=7, edgeitems=3)
def chrosen(x):
"""Chained Rosenbrock function."""
return sum((1 - x[:-1]) ** 2 + 4 * (x[1:] - x[:-1] ** 2) ** 2)
def nlc_ineq(x):
"""Example of nonlinear inequality constraint function."""
return x[:-1] ** 2 - x[1:]
def nlc_eq(x):
"""Example of nonlinear equality constraint function."""
return sum(x ** 2) - 1
if __name__ == '__main__':
print('Minimize the chained Rosenbrock function with three variables subject to various constraints:', end='\n\n')
x0 = np.array([0, 0, 0]) # starting point
print('1. Nonlinear constraints --- ||x||_2^2 = 1, x(i)^2 >= x(i+1) >= 0.5*x(i) >= 0 for i = 1, 2:', end='\n\n')
lb = [0, 0, 0]
ub = [np.inf, np.inf, np.inf]
bounds = Bounds(lb, ub) # bound constraints: lb <= x <= ub
A = [[0.5, -1, 0], [0, 0.5, -1]]
lin_lb = [-np.inf, -np.inf]
lin_ub = [0, 0]
lin_con = LinearConstraint(A, lin_lb, lin_ub) # inequality constraints: lin_lb <= A*x <= lin_ub
nonlinear_lb = [0, 0]
nonlinear_ub = [np.inf, np.inf]
nonlinear_con_ineq = NonlinearConstraint(nlc_ineq, nonlinear_lb, nonlinear_ub) # inequality constraints: nonlinear_lb <= nlc_ineq(x) <= nonlinear_ub
nonlinear_con_eq = NonlinearConstraint(nlc_eq, 0, 0) # equality constraint: nlc_eq(x) = 0
res = minimize(chrosen, x0, bounds=bounds, constraints=[lin_con, nonlinear_con_ineq, nonlinear_con_eq])
print(res, end='\n\n')
print('2. Linear constraints --- sum(x) = 1, x(i+1) <= x(i) <= 1 for i = 1, 2:', end='\n\n')
bounds = Bounds([-np.inf, -np.inf, -np.inf], [1, 1, 1])
A = [[-1, 1, 0], [0, -1, 1], [1, 1, 1]]
lin_con = LinearConstraint(A, [-np.inf, -np.inf, 1], [0, 0, 1])
res = minimize(chrosen, x0, bounds=bounds, constraints=lin_con)
print(res, end='\n\n')
print('3. Bound constraints --- -0.5 <= x(1) <= 0.5, 0 <= x(2) <= 0.25:', end='\n\n')
bounds = Bounds([-0.5, 0, -np.inf], [0.5, 0.25, np.inf])
res = minimize(chrosen, x0, bounds=bounds)
print(res, end='\n\n')
print('4. No constraints:', end='\n\n')
res = minimize(chrosen, x0)
print(res)