Sınır kısıtlı optimizasyon

Python ile Optimizasyona Giriş

Jasmin Ludolf

Content Developer

Sınır kısıtlı optimizasyon

 

  • Varsayılan çözücü: Broyden-Fletcher-Goldfarb-Shanno (BFGS)
  • Kısıt bir aralıktır
  • Günde 50–100 birim üretin

 

from scipy.optimize import Bounds

bounds = Bounds(50, 100)
Python ile Optimizasyona Giriş

L-BFGS-B

from scipy.optimize import minimize, Bounds

def objective_function(b):
  return (2*b[0] - 1.5*b[1])

bounds = Bounds([5, 10], [25, 30])
x0 = [10, 5] result = minimize(objective_function, x0, method='L-BFGS-B', bounds=bounds) print(result.x)
[ 5. 30.]
Python ile Optimizasyona Giriş

Doğrusal kısıtlı optimizasyon

Amaç fonksiyonu VEYA

  • Doğrusal
  • $p = 2x + 1.5y$

Amaç fonksiyonunun doğrusal grafiği

Kısıt

  • Doğrusal
  • $3x + 2y <= 100$

Kısıtların doğrusal grafikleri

Python ile Optimizasyona Giriş

Sert eşitsizlik

  • Bir koşul
  • Un biterse daha fazla bisküvi yok!

Un torbası

Python ile Optimizasyona Giriş

Doğrusal kısıtlı bir problemi çözün

from scipy.optimize import minimize


def objective_function(b): return (b[0]) ** 2 + (b[1]) ** 0.5
def constraint_function(x): return 2*x[0] + 3*x[1] - 6
constraint = {'type': 'ineq', 'fun': constraint_function}
x0 = [20, 20]
result = minimize(objective_function, x0, constraints=[constraint])
print(result)
     fun: 1.4000405652399073
     jac: array([0.24057153, 0.36086182])
 message: 'Optimization terminated successfully'
    nfev: 25
     nit: 8
    njev: 8
  status: 0
 success: True
       x: array([0.12028576, 1.9198095 ])
  • Kısıt türleri:
    • 'eq': eşitlik
    • 'ineq': eşitsizlik
Python ile Optimizasyona Giriş

Hadi pratik yapalım!

Python ile Optimizasyona Giriş

Preparing Video For Download...