examples/sql/transp_mysql.mod
author Alpar Juttner <alpar@cs.elte.hu>
Sun, 05 Dec 2010 17:35:23 +0100
changeset 2 4c8956a7bdf4
permissions -rw-r--r--
Set up CMAKE build environment
     1 # A TRANSPORTATION PROBLEM
     2 #
     3 # This problem finds a least cost shipping schedule that meets
     4 # requirements at markets and supplies at factories.
     5 #
     6 #  References:
     7 #              Dantzig G B, "Linear Programming and Extensions."
     8 #              Princeton University Press, Princeton, New Jersey, 1963,
     9 #              Chapter 3-3.
    10 
    11 set I;
    12 /* canning plants */
    13 
    14 param a{i in I};
    15 /* capacity of plant i in cases */
    16 
    17 table plants IN "MySQL"
    18   'Database=glpk;UID=glpk;PWD=gnu'
    19   'SELECT PLANT, CAPA AS CAPACITY FROM transp_capa' :
    20    I <- [ PLANT ], a ~ CAPACITY;
    21 
    22 set J;
    23 /* markets */
    24 
    25 param b{j in J};
    26 /* demand at market j in cases */
    27 
    28 table markets IN "MySQL"
    29   'Database=glpk;UID=glpk;PWD=gnu'
    30   'transp_demand' :
    31   J <- [ MARKET ], b ~ DEMAND;
    32 
    33 param d{i in I, j in J};
    34 /* distance in thousands of miles */
    35 
    36 table dist IN "MySQL"
    37   'Database=glpk;UID=glpk;PWD=gnu'
    38   'transp_dist' :
    39   [ LOC1, LOC2 ], d ~ DIST;
    40 
    41 param f;
    42 /* freight in dollars per case per thousand miles */
    43 
    44 param c{i in I, j in J} := f * d[i,j] / 1000;
    45 /* transport cost in thousands of dollars per case */
    46 
    47 var x{i in I, j in J} >= 0;
    48 /* shipment quantities in cases */
    49 
    50 minimize cost: sum{i in I, j in J} c[i,j] * x[i,j];
    51 /* total transportation costs in thousands of dollars */
    52 
    53 s.t. supply{i in I}: sum{j in J} x[i,j] <= a[i];
    54 /* observe supply limit at plant i */
    55 
    56 s.t. demand{j in J}: sum{i in I} x[i,j] >= b[j];
    57 /* satisfy demand at market j */
    58 
    59 solve;
    60 
    61 table result{i in I, j in J: x[i,j]} OUT "MySQL"
    62   'Database=glpk;UID=glpk;PWD=gnu'
    63   'DELETE FROM transp_result;'
    64   'INSERT INTO transp_result VALUES (?,?,?)' :
    65   i ~ LOC1, j ~ LOC2, x[i,j] ~ QUANTITY;
    66 
    67 data;
    68 
    69 param f := 90;
    70 
    71 end;