6.8 KiB
Optimization Model
In this page, we describe the precise mathematical optimization model used by RELOG to find the optimal logistics plan. This model is a variation of the classical Facility Location Problem, which has been widely studied in the operations research literature. To simplify the exposition, we present the simplified case where there is only one type of plant.
Mathematical Description
Sets
L- Set of locations holding the original material to be recycledM- Set of materials recovered during the reverse manufacturing processP- Set of potential plants to openT = \{ 1, \ldots, t^{max} \}- Set of time periods
Constants
Plants:
c^\text{disp}_{pmt}- Cost of disposing one tonne of materialmat plantpduring timet($/tonne/km)c^\text{exp}_{pt}- Cost of adding one tonne of capacity to plantpat timet($/tonne)c^\text{open}_{pt}- Cost of opening plantpat timet, at minimum capacity ($)c^\text{f-base}_{pt}- Fixed cost of keeping plantpopen during time periodt($)c^\text{f-exp}_{pt}- Increase in fixed cost for each additional tonne of capacity ($/tonne)c^\text{var}_{pt}- Variable cost of processing one tonne of input at plantpat timet($/tonne)c^\text{store}_{pt}- Cost of storing one tonne of original material at plantpat timet($/tonne)m^\text{min}_p- Minimum capacity of plantp(tonne)m^\text{max}_p- Maximum capacity of plantp(tonne)m^\text{disp}_{pmt}- Maximum amount of materialmthat plantpcan dispose of during timet(tonne)m^\text{store}_p- Maximum amount of original material that plantpcan store for later processing.
Products:
\alpha_{pm}- Amount of materialmrecovered by planttfor each tonne of original material (tonne/tonne)m^\text{initial}_{lt}- Amount of original material to be recycled at locationlduring timet(tonne)
Transportation:
c^\text{tr}_{t}- Transportation cost during timet($/tonne/km)d_{lp}- Distance between plantpand locationl(km)
Decision variables
q_{mpt}- Amount of materialmrecovered by plantpduring timet(tonne)u_{pt}- Binary variable that equals 1 if plantpstarts operating at timet(bool)w_{pt}- Extra capacity (amount above the minimum) added to plantpduring timet(tonne)x_{pt}- Binary variable that equals 1 if plantpis operational at timet(bool)y_{lpt}- Amount of product sent from locationlto plantpduring timet(tonne)z^{\text{disp}}_{mpt}- Amount of materialmdisposed of by plantpduring timet(tonne)z^{\text{store}}_{pt}- Amount of original material in storage at plantpby the end of time periodt(tonne)z^{\text{proc}}_{mpt}- Amount of original material processed by plantpduring time periodt(tonne)
Objective function
RELOG minimizes the overall capital, production and transportation costs:
\begin{align*} \text{minimize} ;; & \sum_{t \in T} \sum_{p \in P} \left[ c^\text{open}{pt} u{pt} + c^\text{f-base}{pt} x{pt} + \sum_{i=1}^t c^\text{f-exp}{pt} w{pi} + c^{\text{exp}}{pt} w{pt} \right] + \ & \sum_{t \in T} \sum_{p \in P} \left[ c^{\text{store}}{pt} z^{\text{store}}{pt} + c^{\text{proc}}{pt} z^{\text{proc}}{pt} \right] + \ & \sum_{t \in T} \sum_{l \in L} \sum_{p \in P} c^{\text{tr}}t d{lp} y_{lpt} \ & \sum_{t \in T} \sum_{p \in P} \sum_{m \in M} c^{\text{disp}}{pmt} z{pmt} \end{align*}
In the first line, we have (i) opening costs, if plant starts operating at time t, (ii) fixed operating costs, if plant is operational, (iii) additional fixed operating costs coming from expansion performed in all previous time periods up to the current one, and finally (iv) the expansion costs during the current time period.
In the second line, we have storage and variable processing costs.
In the third line, we have transportation costs.
In the fourth line, we have the disposal costs.
Constraints
- All original materials must be sent to a plant:
\begin{align} & \sum_{p \in P} y_{lpt} = m^\text{initial}_{lt} & \forall l \in L, t \in T \end{align}
- Amount received equals amount processed plus stored. Furthermore, all original material should be processed by the end of the simulation.
\begin{align} & \sum_{l \in L} y_{lpt} + z^{\text{store}}{p,t-1} = z^{\text{proc}}{pt} + z^{\text{store}}{p,t} & \forall p \in P, t \in T \ & z^{\text{store}}{p,0} = 0 & \forall p \in P \ & z^{\text{store}}_{p,t^{\max}} = 0 & \forall p \in P \end{align}
- Plants have a limited processing capacity. Furthermore, if a plant is closed, it has zero processing capacity:
\begin{align} & z^{\text{proc}}_{pt} \leq m^\text{min}p x_p + \sum{i=1}^t w_p & \forall p \in P, t \in T \end{align}
- Plants have limited storage capacity. Furthermore, if a plant is closed, is has zero storage capacity:
\begin{align} & z^{\text{store}}_{pt} \leq m^\text{store}_p x_p & \forall p \in P, t \in T \end{align}
- Plants can only be expanded up to their maximum capacity. Furthermore, if a plant is closed, it cannot be expanded:
\begin{align} & \sum_{i=1}^t w_p \leq m^\text{max}_p x_p & \forall p \in P, t \in T \end{align}
- Amount of recovered material is proportional to amount processed:
\begin{align} & q_{mpt} = \alpha_{pm} z^{\text{proc}}_{pt} & \forall m \in M, p \in P, t \in T \end{align}
- Because we only consider a single type of plant, all recovered material must be immediately disposed of. In RELOG's full model, recovered materials may be sent to another plant for further processing.
\begin{align} & q_{mpt} = z_{mpt} & \forall m \in M, p \in P, t \in T \end{align}
- A plant is operational at time
tif it was operational at timet-1or it was built at timet. This constraint also prevents a plant from being built multiple times.
\begin{align} & x_{pt} = x_{p,t-1} + u_{pt} & \forall p \in P, t \in T \setminus {1} \ & x_{p,1} = u_{p,1} & \forall p \in P \end{align}
- Variable bounds:
\begin{align} & q_{mpt} \geq 0 & \forall m \in M, p \in P, t \in T \ & u_{pt} \in {0,1} & \forall p \in P, t \in T \ & w_{pt} \geq 0 & \forall p \in P, t \in T \ & x_{pt} \in {0,1} & \forall p \in P, t \in T \ & y_{lpt} \geq 0 & \forall l \in L, p \in P, t \in T \ & z^{\text{store}}{pt} \geq 0 & p \in P, t \in T \ & z^{\text{disp}}{mpt}, z^{\text{proc}}_{mpt} \geq 0 & \forall m \in M, p \in P, t \in T \end{align}