Supply Chain Analytics in Python
Aaren Stubberfield
Supply Chain Analytics Mgr.
Modelleert:

Welke waarden verwachten we voor onze beslisvariabelen?
Productiehoeveelheden:
Fabriek open of dicht:
Totale productie = totale vraag:
shadow prices = Verandering in totale kosten per stijging van de vraag per regioslack = Zou nul moeten zijnTotale productie ≤ totale capaciteit:
shadow prices = Verandering in totale kosten per stijging van de capaciteitslack = Regio’s met overcapaciteitfrom pulp import *
import pandas as pd
# Initialize Class
model =
LpProblem("Capacitated Plant Location Model",
LpMinimize)
# Define Decision Variables
loc = ['A', 'B', 'C', 'D', 'E']
size = ['Low_Cap','High_Cap']
x = LpVariable.dicts(
"production_",
[(i,j) for i in loc for j in loc],
lowBound=0, upBound=None,
cat='Continuous')
y = LpVariable.dicts(
"plant_",
[(i,s) for s in size for i in loc],
cat='Binary')
# Define Objective Function
model +=
(lpSum([fix_cost.loc[i,s]*y[(i,s)]
for s in size for i in loc])
+ lpSum([var_cost.loc[i,j]*x[(i,j)]
for i in loc for j in loc]))
# Define the Constraints
for j in loc: model +=
lpSum([x[(i, j)]
for i in loc]) == demand.loc[j,'Dmd']
for i in loc: model +=
lpSum([x[(i, j)] for j in loc]) <= lpSum(
[cap.loc[i,s]*y[(i,s)]for s in size])
# Solve model.solve()# Print Decision Variables and Objective Value print(LpStatus[model.status]) o = [{'prod':"{} to {}".format(i,j), 'quant':x[(i,j)].varValue} for i in loc for j in loc] print(pd.DataFrame(o)) o = [{'loc':i, 'lc':y[(i,size[0])].varValue, 'hc':y[(i,size[1])].varValue} for i in loc] print(pd.DataFrame(o)) print("Objective = ", value(model.objective))# Print Shadow Price and Slack o = [{'name':name, 'shadow price':c.pi, 'slack': c.slack} for name, c in model.constraints.items()] print(pd.DataFrame(o))
Waarschijnlijke vragen:
Wat zijn de verwachte kosten van dit supplychainmodel?
Als de vraag in een regio stijgt, hoeveel extra marge is nodig om productie- en verzendkosten daar te dekken?
Welke regio’s hebben nog productieruimte voor toekomstige groei?
Herhaald:
shadow prices en slack)Supply Chain Analytics in Python