1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
|
import org.gnu.glpk.*;
/**
* Minimum Cost Flow.
*
*/
public class MinimumCostFlow {
/**
* Main method.
* @param args Command line arguments
*/
public static void main(String[] args) {
glp_prob lp;
glp_arc arc;
glp_java_arc_data adata;
glp_java_vertex_data vdata;
try {
glp_graph graph =
GLPK.glp_create_graph(
GLPKConstants.GLP_JAVA_V_SIZE,
GLPKConstants.GLP_JAVA_A_SIZE);
GLPK.glp_set_graph_name(graph,
MinimumCostFlow.class.getName());
int ret = GLPK.glp_add_vertices(graph, 9);
GLPK.glp_set_vertex_name(graph, 1, "v1");
GLPK.glp_set_vertex_name(graph, 2, "v2");
GLPK.glp_set_vertex_name(graph, 3, "v3");
GLPK.glp_set_vertex_name(graph, 4, "v4");
GLPK.glp_set_vertex_name(graph, 5, "v5");
GLPK.glp_set_vertex_name(graph, 6, "v6");
GLPK.glp_set_vertex_name(graph, 7, "v7");
GLPK.glp_set_vertex_name(graph, 8, "v8");
GLPK.glp_set_vertex_name(graph, 9, "v9");
vdata = GLPK.glp_java_vertex_data_get(graph, 1);
vdata.setRhs(20);
vdata = GLPK.glp_java_vertex_data_get(graph, 9);
vdata.setRhs(-20);
arc = GLPK.glp_add_arc(graph, 1, 2);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(14); adata.setCost(0);
arc = GLPK.glp_add_arc(graph, 1, 4);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(23); adata.setCost(0);
arc = GLPK.glp_add_arc(graph, 2, 4);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(9); adata.setCost(3);
arc = GLPK.glp_add_arc(graph, 2, 3);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(10); adata.setCost(2);
arc = GLPK.glp_add_arc(graph, 4, 5);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(26); adata.setCost(0);
arc = GLPK.glp_add_arc(graph, 5, 2);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(11); adata.setCost(1);
arc = GLPK.glp_add_arc(graph, 3, 8);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(18); adata.setCost(0);
arc = GLPK.glp_add_arc(graph, 3, 5);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(2); adata.setCap(12); adata.setCost(1);
arc = GLPK.glp_add_arc(graph, 5, 6);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(25); adata.setCost(5);
arc = GLPK.glp_add_arc(graph, 5, 7);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(4); adata.setCost(7);
arc = GLPK.glp_add_arc(graph, 6, 7);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(7); adata.setCost(0);
arc = GLPK.glp_add_arc(graph, 6, 8);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(4); adata.setCap(8); adata.setCost(0);
arc = GLPK.glp_add_arc(graph, 8, 9);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(20); adata.setCost(9);
arc = GLPK.glp_add_arc(graph, 7, 9);
adata = GLPK.glp_java_arc_get_data(arc);
adata.setLow(0); adata.setCap(15); adata.setCost(3);
GLPK.glp_write_mincost(graph,
GLPKConstants.GLP_JAVA_V_RHS,
GLPKConstants.GLP_JAVA_A_LOW,
GLPKConstants.GLP_JAVA_A_CAP,
GLPKConstants.GLP_JAVA_A_COST,
"mincost.dimacs");
lp = GLPK.glp_create_prob();
GLPK.glp_mincost_lp(lp, graph,
GLPKConstants.GLP_ON, // use symbolic names
GLPKConstants.GLP_JAVA_V_RHS,
GLPKConstants.GLP_JAVA_A_LOW,
GLPKConstants.GLP_JAVA_A_CAP,
GLPKConstants.GLP_JAVA_A_COST);
GLPK.glp_delete_graph(graph);
GLPK.glp_write_lp(lp, null, "mincost.lp");
GLPK.glp_delete_prob(lp);
} catch (org.gnu.glpk.GlpkException ex) {
System.out.println(ex.getMessage());
System.exit(1);
}
}
}
|