Separable Programming
Separable Programming
Separable Programming
Spring 07/08
Separable Programming
Refer to the following example in which we solve an optimization problem with
non-linear objective function and linear constraints by a linear program. Later we will
extend the idea to solve, at least approximately, convex optimization problems with separable
non-linear objective functions and convex feasible sets defined by separable convex functions.
The technique, called separable programming, basically replaces all separable convex
functions, in objectives and constraints, by piecewise linear convex functions.
Example 1. (Example 1.4.2 of Prof. Murtys notes MS-1.pdf): A company makes
products P1, P2, P3 using limestone (LI), electricity (EP), water (W), fuel (F), and labor (L)
as inputs. Labor is measured in manhours, other inputs in suitable units. Each input is
available from one or more sources. The company has its own quarry for LI, which can
supply upto 250 units/day at a cost of $20/unit. Beyond that, LI can be purchased in any
amounts from an outside supplier at $50/unit. EP is only available from the local utility.
Their charges for EP are: $30/unit for the first 1000 units/day, $45/unit for upto an additional
500 units/day beyond the initial 1000units/day, $75/unit for amounts beyond 1500 units/day.
Upto 800 units/day of W (water) is available from the local utility at $6/unit, beyond that they
charge $7/unit of water/day. There is a single supplier for F who can supply at most 3000
units/day at $40/unit, beyond that there is currently no supplier for F. From their regular
workforce they have upto 640 manhours of labor/day at $10/manhour, beyond that they can
get upto 160 manhours/day at $17/manhour from a pool of workers. They can sell upto 50
units of P1 at $3000/unit/day in an upscale market; beyond that they can sell upto 50 more
units/day of P1 to a wholesaler at $250/unit. They can sell upto 100 units/day of P2 at
$3500/unit. They can sell any quantity of P3 produced at a constant rate of $4500/unit. Data
on the inputs needed to make the various products is given in the following table. Formulate
the product mix problem to maximize the net profit/day at this company.
Input units/unit of output
Product
LI
EP
P1
1/2
P2
1/4
P3
3/2
Sol. Let Pi be the number of units that product i is produced, i = 1, 2, 3; LI, EP, W, F, and
L be the numbers of units limestone, electricity, water, fuel, and labor used to produce the
products. Then the problem can be formulated as the non-linear optimization problem OP1:
GSLM53400
Spring 07/08
GSLM53400
Spring 07/08
As we know, there is another formulation that can turn OP1 into a linear program. Let
LI1 and LI2 be the numbers of units of limestone obtained in its two prices; W1 and W2 be
the numbers of units of water obtained in its two prices; EP1, EP2, and EP3 be the numbers
of units of electricity obtained in its three prices; L1 and L2 be the numbers of units of labor
obtained in its two prices; and P11 and P12 be the numbers of units of product 1 sold in its
two prices. Then OP1 can be reformulated as OP3.
Min z = 20LI1 + 50LI2 + 30EP1 + 45EP2 + 75EP3 + 6W1 + 7W2 + 40F + 10L1 + 17L2
3000P11 250P12 3500P2 4500P3
subject to
(1/2)P1 + P2
+ (3/2)P3
= LI
(limestone used by products)
3P1
+ 2P2
+ 5P3
= EP
(electricity used by products)
P1
+ (1/4)P2 + 2P3
=W
(water used by products)
P1
+ P2
+ 3P3
=F
(fuel used by products)
2P1
+ P2
+ P3
=L
(labor used by products)
LI1 + LI2
= LI
(limestone obtained in its 2 prices)
W1 + W2
=W
(water obtained in its 2 prices)
EP1 + EP2 + EP3 = EP
(electricity obtained in its 3 prices)
L1 + L2
=L
(labor obtained in its 2 prices)
P11 + P12
= P1
(product 1 sold in its 2 prices)
All variables
0
(LI1, EP1, EP2, W1)
(250, 1000, 500, 800)
(3000, 640, 160)
(F, L1, L2)
(P11, P12, P2)
(50, 50, 100).
We will see how to extend the above idea to general non-linear separable convex objective
functions and constraints defined by non-linear separable convex functions.
Fact 2.
GSLM53400
Spring 07/08
can lead to approximate minimum objective function value and approximate minimum
solution that are arbitrarily close to the respective true values.
Example 3.
20.25
NLP1 is:
16
min x12 2 x1 x2
s.t.
x1 + 2x2 5,
2x1 + x2 9,
x1, x2 0.
9
4
1
The above is a separable program with f1(x1) = x12 2x1 and f2(x2) = -x2. f2 is linear.
The
a piecewise linear function. For simplicity, we take a function of three linear pieces, with
break points at 0, 2, 4, and 4.5. The same procedure can be applied to any number of break
points at any values.
points
x1
4.5
16
20.25
-form: For any point within a linear segment, its functional value is the convex
combination of the values of the two break points of the linear segment. Let i 0 be the
weight of break point i, i = O, A, B, and C.
x1 = 0 O + 2 A + 4 B + 4.5 C ,
y = 0 O + 4 A + 16 B + 20.25 C ,
O + A + B + C = 1,
(1)
(2)
(3)
(4)
GSLM53400
Spring 07/08
min y 2 x1 x2
s.t.
x1 + 2x2 5,
2x1 + x2 9,
(1), (2), (3), and (4),
x1, x2, i, i = O, A, B, C 0.
is violated by a set of i, the value of the corresponding y is above the three-piece linear
function, and hence the set of i cannot be a minimum point.
In general, if NLP1 is not a convex program, constraints (4) are needed, though they are
implemented implicitly through the separable programming extension of the simplex method.
The pivoting step of the separable programming extension simply ensures that at any time at
most two adjacent i are in the basis. It can be shown that such a restricted basis rule will
lead to the optimum solution.
The idea of separable program is applicable to non-convex programs.
cases, the optimum solution can be a local rather than global optimum.
Of course, in those
-form:
Instead of taking weighted value of break points, we can add up the contribution
from each linear segment. Let i be the proportion of the ith segment taken, i = OA, AB, BC.
x1 = 2OA + 2 AB + 0.5 BC ,
y = 4OA + 12 AB + 4.25 BC ,
0 OA , AB , BC 1,
there exists j > 0 such that i = 1 for i < j and i = 0 for i > j .
(5)
(6)
(7 )
(8)
As for the -form, the -form may also give a local optimum if the original program is
non-convex. When the original program is convex, constraint (8) is not necessary.
Remark 4. To get more accurate result, the piecewise linear approximation of fi can be
GSLM53400
Spring 07/08
refined with more linear segments. There are studies on segment refinement to get the best
trade off between accuracy and computational effort.
Remark 5. It is possible to approximate constraints by similar procedure.
Remark 6. A product term x1x2 can be transformed to separable form.
and s2 = (x1-x2)/2. Then x1x2 = s12 s22 .
Let s1 = (x1+x2)/2