// Copyright 2010-2025 Google LLC // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // Minimal example to call the GLOP solver. // [START program] package com.google.ortools.linearsolver.samples; // [START import] import com.google.ortools.Loader; import com.google.ortools.modelbuilder.LinearExpr; import com.google.ortools.modelbuilder.ModelBuilder; import com.google.ortools.modelbuilder.ModelSolver; import com.google.ortools.modelbuilder.SolveStatus; import com.google.ortools.modelbuilder.Variable; // [END import] /** Minimal Linear Programming example to showcase calling the solver. */ public final class SimpleLpProgramMb { public static void main(String[] args) { Loader.loadNativeLibraries(); // [START model] // Create the linear model. ModelBuilder model = new ModelBuilder(); // [END model] // [START variables] double infinity = java.lang.Double.POSITIVE_INFINITY; // Create the variables x and y. Variable x = model.newNumVar(0.0, infinity, "x"); Variable y = model.newNumVar(0.0, infinity, "y"); System.out.println("Number of variables = " + model.numVariables()); // [END variables] // [START constraints] // x + 7 * y <= 17.5. model.addLessOrEqual(LinearExpr.newBuilder().add(x).addTerm(y, 7), 17.5).withName("c0"); // x <= 3.5. model.addLessOrEqual(x, 3.5).withName("c1"); System.out.println("Number of constraints = " + model.numConstraints()); // [END constraints] // [START objective] // Maximize x + 10 * y. model.maximize(LinearExpr.newBuilder().add(x).addTerm(y, 10.0)); // [END objective] // [START solve] // Solve with the GLOP LP solver. ModelSolver solver = new ModelSolver("glop"); final SolveStatus status = solver.solve(model); // [END solve] // [START print_solution] if (status == SolveStatus.OPTIMAL) { System.out.println("Solution:"); System.out.println("Objective value = " + solver.getObjectiveValue()); System.out.println("x = " + solver.getValue(x)); System.out.println("y = " + solver.getValue(y)); } else { System.err.println("The problem does not have an optimal solution!"); } // [END print_solution] // [START advanced] System.out.println("\nAdvanced usage:"); System.out.println("Problem solved in " + solver.getWallTime() + " seconds"); // [END advanced] } private SimpleLpProgramMb() {} } // [END program]