Globale optimalisatie in SciPy

Introductie tot optimalisatie in Python

Jasmin Ludolf

Content Developer

Globale optimalisatie

  • Productiekosten wisselen tussen hoog en laag
    • $\rightarrow$ $\Pi(q)$ heeft twee maxima bij $5$ en $18$. Minimum bij $10$.

Vraag, kosten, opbrengst en winst vs. hoeveelheid. Winst blauwe doorgetrokken lijn, bimodaal met 0 bij 0 en 25, twee maxima bij 5 en 18 en een lokaal minimum bij 10

Introductie tot optimalisatie in Python

Vastlopen in een lokaal optimum

from scipy.optimize import minimize_scalar, minimize


def profit(q): return -q**4 / 4 + 11 * q**3 - 160 * q**2 + 900 * q
result_min_scalar = minimize_scalar(lambda q: -profit(q))
print(f"{result_min_scalar.message}") print(f"Het maximum volgens minimize_scalar is {-result_min_scalar.fun:.2f} \ en ligt op {result_min_scalar.x:.2f}\n")
Optimization terminated successfully;
The returned value satisfies the termination criteria
(using xtol = 1.48e-08 )
The maximum according to minimize_scalar is 1718.75 and achieved at 5.00
Introductie tot optimalisatie in Python

Vastlopen in een lokaal optimum

x0 = 9
result = minimize(lambda q: -profit(q), x0, bounds=[(0, 20)])
print(f"{result.message}")
print(f"Het maximum volgens minimize(x0={x0}) is {-result.fun:.2f} op {result.x[0]:.2f}\n")
CONVERGENCE: REL_REDUCTION_OF_F_<=_FACTR*EPSMCH
The maximum according to minimize(x0=9) is 1718.75 at 5.00
x0 = 10 + 1e-8
result = minimize(lambda q: -profit(q), x0)
print(f"{result.message}")
print(f"Het maximum volgens minimize(x0={x0}) is {-result.fun:.2f} op {result.x[0]:.2f}\n")
Optimization terminated successfully.
The maximum according to minimize(x0=10.00000001) is 1500.00 at 10.00
Introductie tot optimalisatie in Python

Loskomen met basinhopping

from scipy.optimize import basinhopping


x0 = 0 result = basinhopping(lambda q: -profit(q), x0, niter=10000)
print(f"{result.message}") print(f"Het maximum volgens basinhopping(x0={x0}, niter=10000) \ is {-result.fun:.2f} op {result.x[0]:.2f}\n")
['requested number of basinhopping iterations completed successfully']
The maximum according to basinhopping(x0=0, niter=10000) is 2268.00 at 18.00
Introductie tot optimalisatie in Python

basinhopping met kwargs en grenzen

from scipy.optimize import basinhopping, NonlinearConstraint

x0 = 0
kwargs = {"constraints": NonlinearConstraint(lambda x: x, lb=0, ub=30)}


result = basinhopping(lambda q: -profit(q), x0, minimizer_kwargs=kwargs) print(f"{result.message}") print(f"Het maximum volgens basinhopping(x0={x0}) ligt op {result.x[0]:.2f}\n")
['requested number of basinhopping iterations completed successfully']
The maximum according to basinhopping(x0=0) is at 18.00
Introductie tot optimalisatie in Python

basinhopping met callback

from scipy.optimize import basinhopping, LinearConstraint

x0 = 0
kwargs = {"constraints": LinearConstraint([1], lb=0, ub=30)} 


maxima = [] def callback(x, f, accept): if accept: maxima.append(*x)
result = basinhopping(lambda q: -profit(q), x0, callback=callback, minimizer_kwargs=kwargs, niter=5)
Introductie tot optimalisatie in Python

basinhopping - callback-uitvoer

print(f"{result.message}")
print(f"Het maximum volgens basinhopping(x0={x0}) ligt op {result.x[0]:.2f}\n")
print(f"(Lokale) maxima gevonden door basinhopping: {[round(x, 2) for x in maxima]}")

$$ $$

['requested number of basinhopping iterations completed successfully']
The maximum according to basinhopping(x0=0) is at 18.00 
(Local) maxima found by basinhopping are: [5.0, 5.0, 5.0, 5.0, 5.0, 18.0]

 

  • Zet het argument seed om resultaten te reproduceren
Introductie tot optimalisatie in Python

Laten we oefenen!

Introductie tot optimalisatie in Python

Preparing Video For Download...