Ottimizzazione convessa con vincoli di disuguaglianza

Introduzione all'ottimizzazione in Python

Jasmin Ludolf

Content Developer

Soluzione angolare vs interna

  • Alexia ha solo 5 ore di lavoro

$$ w\leq 5$$

  • Due vincoli:
    • 24 ore al giorno
    • 5 ore di lavoro
  • I vincoli formano un angolo
  • La soluzione interna non è un'intersezione

Curve di indifferenza e vincoli. La curva di indifferenza al livello ottimo passa per l'intersezione dei vincoli.

Introduzione all'ottimizzazione in Python

Produttore con vincoli di capacità

  • Casa automobilistica produce auto identiche in due impianti $A$, $B$
    • Quantità: $q_A$, $q_B$
    • Capacità: $q_A\leq 90$, $q_B\leq 90$
    • Costo: $C_A(q)=3q$, $C_B(q)=3.5q$
  • Domanda:
    • $P=120-Q$
  • Contratto:
    • $Q\geq 92$
  • Obiettivo: massimizzare il profitto
    • $\displaystyle\max \Pi(q_A,q_B)$

Linea di produzione di auto

Introduzione all'ottimizzazione in Python

Massimizzare il profitto

  • Obiettivo:
    • $\Pi = R-C$
      • $R = PQ$
Introduzione all'ottimizzazione in Python

Massimizzare il profitto

  • Obiettivo:
    • $\Pi = R-C$
      • $R = PQ = (120-Q)Q $
Introduzione all'ottimizzazione in Python

Massimizzare il profitto

  • Obiettivo:

    • $\Pi = R-C$
      • $R = PQ = (120-Q)Q=\left[120-(q_A+q_B)\right](q_A+q_B)$
      • $C=C_A+C_B=3q_A+3.5q_B$
  • Limiti

    • $0\leq q_A, q_B\leq 90$
  • Vincoli
    • $Q\geq92\Leftrightarrow 92\leq q_A+q_B$
Introduzione all'ottimizzazione in Python

Formulazione

$$\max_{q_A,q_B}R(q_A,q_B)-C(q_A,q_B)$$

$$s.t.$$

$$R(q_A,q_B)=\left[120-(q_A+q_B)\right](q_A+q_B)$$

$$\ \ \ \ \ C(q_A,q_B)=3q_A+3.5q_B$$

$$\ \ \ 0\leq q_A, q_B\leq 90$$

$$ \ \ \ \ 92\leq q_A+q_B$$

from scipy.optimize import minimize,\
        Bounds, LinearConstraint


def R(q): return (120 - (q[0] + q[1] )) * (q[0] + q[1])
def C(q): return 3*q[0] + 3.5*q[1]
def profit(q): return R(q) - C(q)
bounds = Bounds([0, 0], [90, 90])
constraints = LinearConstraint([1, 1], lb=92)
Introduzione all'ottimizzazione in Python

Massimizza il profitto con SciPy

result = minimize(lambda q: -profit(q),

[50, 50],
bounds=bounds, constraints=constraints)
print(result.message) print(f'The optimal number of cars produced in plant A is: {result.x[0]:.2f}') print(f'The optimal number of cars produced in plant B is: {result.x[1]:.2f}') print(f'The firm made: ${-result.fun:.2f}')
Optimization terminated successfully
The optimal number of cars produced in plant A is: 90.00
The optimal number of cars produced in plant B is: 2.00
The firm made: $2299.00
Introduzione all'ottimizzazione in Python

Vincoli non lineari in SciPy

from scipy.optimize import NonlinearConstraint 
import numpy as np


constraints = NonlinearConstraint(lambda q: q[0] + q[1], lb=92, ub=np.inf)
result = minimize(lambda q: -profit(q), [50, 50], bounds=Bounds([0, 0], [90, 90]), constraints=constraints)
Introduzione all'ottimizzazione in Python

Soluzione con NonlinearConstraint

print(result.message)
print(f'The optimal number of cars produced in plant A is: {result.x[0]:.2f}')
print(f'The optimal number of cars produced in plant B is: {result.x[1]:.2f}')
print(f'The firm made: ${-result.fun:.2f}') 
Optimization terminated successfully
The optimal number of cars produced in plant A is: 90.00
The optimal number of cars produced in plant B is: 2.00
The firm made: $2299.00 
  • Usa LinearConstraint() per problemi lineari semplici
  • Altrimenti usa NonlinearConstraint()
Introduzione all'ottimizzazione in Python

Passiamo alla pratica!

Introduzione all'ottimizzazione in Python

Preparing Video For Download...