Linear Programming II HSPM J716
Crawling along the simplex The simplex method moves from one corner to the next until the amount to be maximized stops rising.
Learning Objectives Learning Objective 1: Recognize problems that linear programming can handle: Linear programming lets you optimize an objective function subject to some constraints. The objective function and constraints are all linear.
Learning Objectives Learning objective 2: Know the elements of a linear programming problem: an objective function that shows the cost or profit depending on what choices you make, constraint inequalities that show the limits of what you can do, and non-negativity restrictions, because you cannot turn outputs back into inputs.
Learning Objectives Learning objective 2: Know the elements of a linear programming problem: an objective function that shows the cost or profit depending on what choices you make, constraint inequalities that show the limits of what you can do, and non-negativity restrictions, because you cannot turn outputs back into inputs.
Learning Objectives Learning objective 3: Understand the principles that the computer uses to solve a linear programming problem. The computer uses the simplex method to systematically move along the edges of the feasible area (the simplex). It goes from one corner to the next and stops when the objective function stops getting better.
Learning Objectives Learning objective 3: Understand the principles that the computer uses to solve a linear programming problem. The computer uses the simplex method to systematically move along the edges of the feasible area (the simplex). It goes from one corner to the next and stops when the objective function stops getting better.
Learning Objectives Learning objective 4a: What linear programming problems have no solution? Those that have no feasible area. This means it's impossible to satisfy all the constraints at once.
Learning Objectives Learning objective 4b: What difference does linearity make? If the constraints are not linear, the feasible area has curved edges. The simplex method doesn't work because you can't be sure that the solution is at a corner. The solution may be in the middle of a curved edge. If the objective function is not linear, the solution may not even be on an edge. It may be in the interior of the feasible area.
Minimization problem Animals need: – 14 units of nutrient A, – 12 units of nutrient B, and – 18 units of nutrient C. A bag of X has 2 units of A, 1 unit of B, and 1 unit of C. A bag of Y has 1 unit of A, 1 unit of B, and 3 units of C. A bag of X costs $2. A bag of Y costs $4.
Minimization problem Constraints: 2X + 1Y >= 14 nutrient A requirement 1X + 1Y >= 12 nutrient B requirement 1X + 3Y >= 18 nutrient C requirement – Read vertically to see how much of each nutrient is in each grain. Cost = 2X + 4Y – objective function to be minimized
Minimization problem
Learning Objectives Learning objective 5: Be able to solve small linear programming problems yourself. The tricky part is setting up the objective function and the constraints. Write them on paper. Then set up your spreadsheet and solve. Then comes the other tricky part – coaxing Excel to work!
Rear Admiral Grace Hopper Navy Reserve Lt.(J.G.) 1943 (age 36) 3 rd programmer of Mark I computer at Harvard Invented the compiler “Mother” of COBOL First female Admiral
Bug in Mark II (1947)
Learning Objectives Learning objective 6: Understand shadow prices. Shadow Prices are what-it’s-worth-to-you-for- another-unit-of-input prices. Other names for shadow prices: Lagrange Multiplier (if you don’t check Assume Linear Model) Opportunity Cost (other spreadsheets use this) Reduced Cost (if you check Assume Linear Model) Reduced Gradient (if you don’t)
Shadow prices for nutrient example
Multiple optima if Iso-cost line and constraint are parallel
Mixed constraints if constraint is D9 >= E9 Shadow prices are below
Mixed constraints if constraint is B2 >= 5 its shadow price is “Reduced Cost”
Primal and Dual PrimalDual
Primal and Dual Solutions Primal Dual
Applications framework Identify the activities Specify the constraints Specify the objective function
Scheduling Application DayNeed for Staff Mon180 Tue160 Wed150 Thu160 Fri190 Sat140 Sun120 Staff work 5 days, then get 2 off.
Scheduling Application Identify the activities – Each hiring schedule is an activity Specify the constraints – How many people you need at different times Specify the objective function – Minimize the total number of people hired
Transportation Application
Identify the activities – Each route from distribution center to customer is an activity Specify the constraints – Only so much at each distribution center – Each customer’s requirement Specify the objective function – Minimize total cost of all product movements