Introduction to Management Science 8th Edition by Bernard W. Taylor III Chapter 9 Integer Programming Chapter 9 - Integer Programming 1 Chapter Topics Integer Programming (IP) Models Still “linear programming models” Variables must be integers, and so form a subset of the original, real-number models Integer Programming Graphical Solution Computer Solution of Integer Programming Problems With Excel and QM for Windows Chapter 9 - Integer Programming 2 Integer Programming Models Types of Models Total Integer Model: All decision variables required to have integer solution values. 0–1 Integer Model: All decision variables required to have integer values of zero or one. Also referred to as Boolean and True/False Mixed Integer Model: Some of the decision variables (but not all) required to have integer values. Chapter 9 - Integer Programming 3 A Total Integer Model (1 of 2) Machine shop obtaining new presses and lathes. Marginal profitability: each press $100/day; each lathe $150/day. Resource constraints: $40,000, 200 sq. ft. floor space. Machine purchase prices and space requirements: Required Floor Space (sq. ft.) Purchase Price Press 15 $8,000 Lathe 30 4,000 Machine Chapter 9 - Integer Programming 4 A Total Integer Model (2 of 2) Integer Programming Model: Maximize Z = $100x1 + $150x2 subject to: 8,000x1 + 4,000x2 $40,000 15x1 + 30x2 200 ft2 x1, x2 0 and integer x1 = number of presses x2 = number of lathes Chapter 9 - Integer Programming 5 A 0–1 Integer Model (1 of 2) Recreation facilities selection to maximize daily usage by residents. Resource constraints: $120,000 budget; 12 acres of land. Selection constraint: either swimming pool or tennis center (not both). Data: Recreation Facility Swimming pool Tennis Center Athletic field Gymnasium Chapter 9 - Integer Programming Expected Usage (people/day) Cost ($) Land Requirement (acres) 300 90 400 150 35,000 10,000 25,000 90,000 4 2 7 3 6 A 0–1 Integer Model (2 of 2) Integer Programming Model: Maximize Z = 300x1 + 90x2 + 400x3 + 150x4 subject to: $35,000x1 + 10,000x2 + 25,000x3 + 90,000x4 $120,000 4x1 + 2x2 + 7x3 + 3x4 12 acres x1 + x2 1 facility x1, x2, x3, x4 = 0 or 1 (either do or don’t) x1 = construction of a swimming pool x2 = construction of a tennis center x3 = construction of an athletic field x4 = construction of a gymnasium Chapter 9 - Integer Programming 7 A Mixed Integer Model (1 of 2) $250,000 available for investments providing greatest return after one year. Data: Condominium cost $50,000/unit, $9,000 profit if sold after one year. Land cost $12,000/ acre, $1,500 profit if sold after one year. Municipal bond cost $8,000/bond, $1,000 profit if sold after one year. Only 4 condominiums, 15 acres of land, and 20 municipal bonds available. Chapter 9 - Integer Programming 8 A Mixed Integer Model (2 of 2) Integer Programming Model: Maximize Z = $9,000x1 + 1,500x2 + 1,000x3 subject to: 50,000x1 + 12,000x2 + 8,000x3 $250,000 x1 4 condominiums x2 15 acres x3 20 bonds x2 0 x1, x3 0 and integer x1 = condominiums purchased x2 = acres of land purchased x3 = bonds purchased Chapter 9 - Integer Programming 9 Integer Programming Graphical Solution Rounding non-integer solution values up (down) to the nearest integer value can result in an infeasible solution A feasible solution may be found by rounding down (up) non-integer solution values, but may result in a less than optimal (sub-optimal) solution. Whether a variable is to be rounded up or down depends on where the corresponding point is with respect to the constraint boundaries. Chapter 9 - Integer Programming 10 Integer Programming Example Graphical Solution of Maximization Model Maximize Z = $100x1 + $150x2 subject to: 8,000x1 + 4,000x2 $40,000 15x1 + 30x2 200 ft2 x1, x2 0 and integer Optimal Solution: Z = $1,055.56 x1 = 2.22 presses x2 = 5.55 lathes Both of these may be found by judicious rounding, but the value of the objective function needs to be checked for each. Chapter 9 - Integer Programming Figure 9.1 Feasible Solution Space with Integer Solution Points 11 Branch and Bound Method Traditional approach to solving integer programming problems. Based on principle that total set of feasible solutions can be partitioned into smaller subsets of solutions. Smaller subsets evaluated until best solution is found. Method is a tedious and complex mathematical process. Excel and QM for Windows used in this book. See CD-ROM Module C – “Integer Programming: the Branch and Bound Method” for detailed description of method. Chapter 9 - Integer Programming 12 Computer Solution of IP Problems 0–1 Model with Excel (1 of 5) Recreational Facilities Example: Maximize Z = 300x1 + 90x2 + 400x3 + 150x4 subject to: $35,000x1 + 10,000x2 + 25,000x3 + 90,000x4 $120,000 4x1 + 2x2 + 7x3 + 3x4 12 acres x1 + x2 1 facility x1, x2, x3, x4 = 0 or 1 Chapter 9 - Integer Programming 13 Computer Solution of IP Problems 0–1 Model with Excel (2 of 5) Exhibit 9.2 Chapter 9 - Integer Programming 14 Computer Solution of IP Problems 0–1 Model with Excel (3 of 5) Instead, one could just specify $C$12:$C$15 as “binary” (= ‘0’ or ‘1’). Exhibit 9.3 Chapter 9 - Integer Programming 15 Computer Solution of IP Problems 0–1 Model with Excel (4 of 5) To constrain a range of variables to be integers, enter: Exhibit 9.4 Instead, specify the “bin” what optionyou (= ‘0’put or ‘1’), … and one notecould thatjust it doesn’t matter in thus the side additional, 0” and “≤ 1”not constraints. the avoiding right-hand field,“≥but it must be empty. Chapter 9 - Integer Programming 16 Computer Solution of IP Problems 0–1 Model with Excel (5 of 5) Exhibit 9.5 Chapter 9 - Integer Programming 17 Computer Solution of IP Problems 0–1 Model with QM for Windows (1 of 3) Recreational Facilities Example: Maximize Z = 300x1 + 90x2 + 400x3 + 150x4 subject to: $35,000x1 + 10,000x2 + 25,000x3 + 90,000x4 $120,000 4x1 + 2x2 + 7x3 + 3x4 12 acres x1 + x2 1 facility x1, x2, x3, x4 = 0 or 1 Chapter 9 - Integer Programming 18 Computer Solution of IP Problems 0–1 Model with QM for Windows (2 of 3) Exhibit 9.6 Chapter 9 - Integer Programming 19 Computer Solution of IP Problems 0–1 Model with QM for Windows (3 of 3) Exhibit 9.7 Chapter 9 - Integer Programming 20 Computer Solution of IP Problems Total Integer Model with Excel (1 of 5) Integer Programming Model: Maximize Z = $100x1 + $150x2 subject to: 8,000x1 + 4,000x2 $40,000 15x1 + 30x2 200 ft2 x1, x2 0 and integer Chapter 9 - Integer Programming 21 Computer Solution of IP Problems Total Integer Model with Excel (2 of 5) Exhibit 9.8 Chapter 9 - Integer Programming 22 Computer Solution of IP Problems Total Integer Model with Excel (3 of 5) Exhibit 9.9 … and, again, just to note that this field will automatically fill, but Excel wants you to put something in it anyway. Chapter 9 - Integer Programming 23 Computer Solution of IP Problems Total Integer Model with Excel (4 of 5) Exhibit 9.10 Chapter 9 - Integer Programming 24 Computer Solution of IP Problems Total Integer Model with Excel (5 of 5) Exhibit 9.11 Chapter 9 - Integer Programming 25 Computer Solution of IP Problems Mixed Integer Model with Excel (1 of 3) Integer Programming Model: Maximize Z = $9,000x1 + 1,500x2 + 1,000x3 subject to: 50,000x1 + 12,000x2 + 8,000x3 $250,000 x1 4 condominiums x2 15 acres x3 20 bonds x2 0 x1, x3 0 and integer Chapter 9 - Integer Programming 26 Computer Solution of IP Problems Total Integer Model with Excel (2 of 3) Exhibit 9.12 Chapter 9 - Integer Programming 27 Computer Solution of IP Problems Solution of Total Integer Model with Excel (3 of 3) Exhibit 9.13 Chapter 9 - Integer Programming 28 Computer Solution of IP Problems Mixed Integer Model with QM for Windows (1 of 2) Exhibit 9.14 Chapter 9 - Integer Programming 29 Computer Solution of IP Problems Mixed Integer Model with QM for Windows (2 of 2) Exhibit 9.15 Chapter 9 - Integer Programming 30 0–1 Integer Programming Modeling Examples Capital Budgeting Example (1 of 4) University bookstore expansion project. Not enough space available for both a computer department and a clothing department. Data: Project 1. Website 2. Warehouse 3. Clothing department 4. Computer department 5. ATMs Available funds per year Chapter 9 - Integer Programming NPV Return ($1000) 120 85 105 140 75 Project Costs per Year ($1000) 1 2 3 55 45 60 50 30 40 35 25 35 30 25 20 -30 -- 150 110 60 31 0–1 Integer Programming Modeling Examples Capital Budgeting Example (2 of 4) x1 = selection of web site project x2 = selection of warehouse project x3 = selection clothing department project x4 = selection of computer department project x5 = selection of ATM project xi = 1 if project “i” is selected, 0 if project “i” is not selected Maximize Z = $120x1 + $85x2 + $105x3 + $140x4 + $70x5 subject to: 55x1 + 45x2 + 60x3 + 50x4 + 30x5 150 40x1 + 35x2 + 25x3 + 35x4 + 30x5 110 25x1 + 20x2 + 30x4 60 x3 + x4 1 xi = 0 or 1 Chapter 9 - Integer Programming 32 0–1 Integer Programming Modeling Examples Capital Budgeting Example (3 of 4) Exhibit 9.16 Chapter 9 - Integer Programming 33 0–1 Integer Programming Modeling Examples Capital Budgeting Example (4 of 4) Could have chosen ‘bin’ (= ‘0’ or ‘1’) instead! Exhibit 9.17 Chapter 9 - Integer Programming 34 0–1 Integer Programming Modeling Examples Fixed Charge and Facility Example (1 of 4) Which of the six farms should be purchased that will meet current production capacity at minimum total cost, including annual fixed costs and shipping costs? Data: Farms 1 2 3 4 5 6 Available Capacity (tons,1000s) 12 10 14 Plant Annual Fixed Costs ($1000) 405 390 450 368 520 465 Chapter 9 - Integer Programming Projected Annual Harvest (tons, 1000s) 11.2 10.5 12.8 9.3 10.8 9.6 A B C Farm A Plant B 1 2 3 4 5 6 18 13 16 19 17 14 15 10 14 15 19 16 C 12 17 18 16 12 12 35 0–1 Integer Programming Modeling Examples Fixed Charge and Facility Example (2 of 4) yi = 0 if farm i is not selected, and 1 if farm i is selected, i = 1,2,3,4,5,6 xij = potatoes (tons, 1000s) shipped from farm i, i = 1,2,3,4,5,6 to plant j, j = A,B,C. Minimize Z = 18x1A + 15x1B + 12x1C + 13x2A + 10x2B + 17x2C + 16x3A + 14x3B + 18x3C + 19x4A + 15x4B + 16x4C + 17x5A + 19x5B + 12x5C + 14x6A + 16x6B + 12x6C + 405y1 + 390y2 + 450y3 + 368y4 + 520y5 + 465y6 subject to: x1A + x1B + x1C - 11.2y1 ≤ 0 x2A + x2B + x2C -10.5y2 ≤ 0 x3A + x3B + x3C - 12.8y3 ≤ 0 x4A + x4B + x4C - 9.3y4 ≤ 0 x5A + x5B + x5B - 10.8y5 ≤ 0 x6A + x6B + X6C - 9.6y6 ≤ 0 x1A + x2A + x3A + x4A + x5A + x6A =12 The 6 farms’ capacities•. x1B + x2B + x3A + x4B + x5B + x6B = 10 x1C + x2C + x3C+ x4C + x5C + x6C = 14 The 3 plants’ capacities. xij ≥ 0 yi = 0 or 1 Chapter 9 - Integer Programming 36 0–1 Integer Programming Modeling Examples Fixed Charge and Facility Example (3 of 4) Exhibit 9.18 Chapter 9 - Integer Programming 37 0–1 Integer Programming Modeling Examples Fixed Charge and Facility Example (4 of 4) Exhibit 9.19 Chapter 9 - Integer Programming 38 0–1 Integer Programming Modeling Examples Set Covering Example (1 of 4) APS wants to construct the minimum set of new hubs in the following twelve cities such that there is a hub within 300 miles of every city: Cities 1. Atlanta 2. Boston 3. Charlotte 4. Cincinnati 5. Detroit 6. Indianapolis 7. Milwaukee 8. Nashville 9. New York 10. Pittsburgh 11. Richmond 12. St. Louis Cities within 300 miles Atlanta, Charlotte, Nashville Boston, New York Atlanta, Charlotte, Richmond Cincinnati, Detroit, Nashville, Pittsburgh Cincinnati, Detroit, Indianapolis, Milwaukee, Pittsburgh Cincinnati, Detroit, Indianapolis, Milwaukee, Nashville, St. Louis Detroit, Indianapolis, Milwaukee Atlanta, Cincinnati, Indianapolis, Nashville, St. Louis Boston, New York, Richmond Cincinnati, Detroit, Pittsburgh, Richmond Charlotte, New York, Pittsburgh, Richmond Indianapolis, Nashville, St. Louis Chapter 9 - Integer Programming 39 0–1 Integer Programming Modeling Examples Set Covering Example (2 of 4) xi = city i, i = 1 to 12, xi = 0 if city is not selected as a hub and xi = 1if it is. Minimize Z = x1 + x2 + x3 + x4 + x5 + x6 + x7 + x8 + x9 + x10 + x11 + x12 subject to: Atlanta: Boston: Charlotte: Cincinnati: Detroit: Indianapolis: Milwaukee: Nashville: New York: Pittsburgh: Richmond: St Louis: Chapter 9 - Integer Programming x1 + x3 + x8 1 x2 + x10 1 x1 + x3 + x11 1 x4 + x5 + x8 + x10 1 x4 + x5 + x6 + x7 + x10 1 x4 + x5 + x6 + x7 + x8 + x12 1 x5 + x6 + x7 1 x1 + x4 + x6+ x8 + x12 1 x2 + x9+ x11 1 x4 + x5 + x10 + x11 1 x3 + x9 + x10 + x11 1 x6 + x8 + x12 1 xij = 0 or 1 40 0–1 Integer Programming Modeling Examples Set Covering Example (3 of 4) Exhibit 9.20 Chapter 9 - Integer Programming the decision variables 41 0–1 Integer Programming Modeling Examples Set Covering Example (4 of 4) Exhibit 9.21 For “N7”, enter “= sumproduct(B7:M7,B$20:M$20)” and the down; the last constraint requires that these (hubs within 300 mi) equal at least one. Chapter 9 - Integer Programming 42 Total Integer Programming Modeling Example Problem Statement (1 of 3) Textbook company developing two new regions. Planning to transfer some of its 10 salespeople into new regions. Average annual expenses for sales person: Region 1 - $10,000/salesperson Region 2 - $7,500/salesperson Total annual expense budget is $72,000. Sales generated each year: Region 1 - $85,000/salesperson Region 2 - $60,000/salesperson How many salespeople should be transferred into each region in order to maximize increased sales? Chapter 9 - Integer Programming 43 Total Integer Programming Modeling Example Model Formulation (2 of 3) Step 1: Formulate the Integer Programming Model Maximize Z = $85,000x1 + 60,000x2 subject to: x1 + x2 10 salespeople $10,000x1 + 7,000x2 $72,000 expense budget x1, x2 0 or integer Step 2: Solve the Model using QM for Windows Chapter 9 - Integer Programming 44 Total Integer Programming Modeling Example Solution with QM for Windows (3 of 3) Chapter 9 - Integer Programming 45 Chapter 9 - Integer Programming 46