Doğrusal programlama

Python ile Optimizasyona Giriş

Jasmin Ludolf

Content Developer

Doğrusal programlama

  • Amaç fonksiyonları ve kısıtlar doğrusal ilişkilidir

  • Doğrusal kısıtlamaya karşıt: doğrusal ve doğrusal olmayan karışımı

Python ile Optimizasyona Giriş

Ürün karması

 

Tür Sayı Şişe (s/kap) Bardak (s/kap)
$M_A$ 4 1.5 1.3
$M_B$ 3 0.8 2.1

 

  • Her makine haftada 30 saat çalışır

 

  • Talep: içecek şişeleri, yoğurt bardakları
Python ile Optimizasyona Giriş

Kârı maksimize et

  • Kutu başına kâr
B ($/kutu) C ($/kutu)
480 510

 

  • Amaç fonksiyonu: $480B + 510C$
  • Kısıtlar
    • Makine A: $1.5B+1.3C\leq 4 \times 30$
    • Makine B: $0.8B+ 2.1C \leq 3\times 30$
    • Negatif olmama kısıtı: $B, C \geq 0$
Python ile Optimizasyona Giriş

PuLP kullanımı

from pulp import *


model = LpProblem('MaxProfit', LpMaximize)
B = LpVariable('B', lowBound=0) C = LpVariable('C', lowBound=0)
model += 480*B + 510*C
model += 1.5*B + 1.3*C - 120, "M_A" model += 0.8*B + 2.1*C - 90, "M_B"
  • LpMaximize veya LpMinimize
Python ile Optimizasyona Giriş

PuLP model çıktısı

print(model)
ProductMix:
MAXIMIZE
480*B + 510*C + 0
SUBJECT TO
M_A: 1.5 B + 1.3 C <= 120

M_B: 0.8 B + 2.1 C <= 90

VARIABLES
B Continuous
C Continuous
Python ile Optimizasyona Giriş

PuLP ile çözüm

status = model.solve()
print(status)
Welcome to the CBC MILP Solver 
...
1
print(f"Profit = {value(model.objective):.2f}")
print(f"Tons of bottles = {B.varValue:.2f}, tons of cups = {C.varValue:.2f}")
Profit = 40137.44
Boxes of bottles = 63.98, boxes of cups = 18.48
Python ile Optimizasyona Giriş

Çoklu değişken ve kısıtlar

variables = LpVariable.dicts("Product", ['B', 'C'], lowBound=0)

OR

variables = LpVariable.dicts("Product", range(2), 0)
A = LpVariable.matrix('A', (range(2), range(2)), 0)
box_profit = {'B': 480, 'C': 510}
model += lpSum([box_profit[i] * variables[i] for i in ['B', 'C']]) 

model += 1.5*variables['B'] + 1.3*variables['C'] <= 120, "M_A"
model += 0.8*variables['B'] + 2.1*variables['C'] <= 90, "M_B"
Python ile Optimizasyona Giriş

Hadi pratik yapalım!

Python ile Optimizasyona Giriş

Preparing Video For Download...