Skip to content

Fan-written linear program file (.lp) parser which returns an or-tools solver object.

License

Notifications You must be signed in to change notification settings

snkas/python-ortools-lp-parser

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fan-written Python LP Parser for OR-Tools

build codecov license: Apache GitHub release version

It is remarkable that the or-tools open source project (https://developers.google.com/optimization/) enables a decent linear solver to be included in Python via pip without manual compilation. The Python wrapper of the or-tools optimization API (i.e. python3 -m pip install ortools) unfortunately does not support the reading of linear program files. This small module is to enable Python developers to read in LP formatted linear program files.

This fan-written LP parser is NOT IN ANY WAY affiliated with or endorsed by the or-tools developers. This parser is distributed on an "as is" basis, without warranties or conditions of any kind (see also the Apache 2.0 License in ./LICENSE).

It aims to follow the LPSolve 5.1 LP format (http://lpsolve.sourceforge.net/5.1/lp-format.htm). The format accepted by this parser is different in the following ways:

  1. An objective function / constraint / declaration must be on a single line terminated by a semicolon (;)
  2. Multi-line comments are not allowed
  3. The objective function must have "max:" or "min:" at the start of it
  4. Keywords (i.e., "max", "min", "int") must be lowercase
  5. Semi-continuous variables are not allowed
  6. Special ordered sets (SOS) are not allowed
  7. Constraint names are completely ignored (e.g., "my_constraint_row_1: x1 >= x2" is just parsed to "x1 >= x2")
  8. At most 1 detached (whitespaced) sign and 1 directly in front of a coefficient/variable is permitted (e.g., "max: --x1 + +3.0" is allowed, "max: --x1 + + +3.0" is not, "max: --x1 + + 3.0" is also not).
  9. Variable names are more restrictive. A variable name is case sensitive. It must start with an alphabetic character. It must consist solely of alphabetic characters, numeric characters, and underscore characters. This corresponds to the following regular expression: [A-Za-z]+[A-Za-z0-9_]*.

Installation

Requirements

  • Python 3.7+
  • python3 -m pip install ortools

Option 1

python3 -m pip install git+https://github.com/snkas/[email protected]

You can now include it using: import ortoolslpparser

Option 2

Clone/download this Git repository. Then, execute the following to install the package locally:

cd python-ortools-lp-parser
python3 -m pip install .

You can now include it using: import ortoolslpparser

Getting started

Create a LP formatted linear program called program.lp:

max: x1 - x2;
x1 >= 0.3;
x1 <= 30.6;
x2 >= 24.9;
x2 <= 50.1;

Create a Python file called example.py:

import ortoolslpparser

parse_result = ortoolslpparser.parse_lp_file("program.lp")
solver = parse_result["solver"]
solver.Solve()
print("Objective value: %f" % solver.Objective().Value())
for var_name in parse_result["var_names"]:
    print("Variable %s: %f" % (var_name, solver.LookupVariable(var_name).solution_value()))

Then run python3 example.py. It should output:

Objective value: 5.700000
Variable x1: 30.600000
Variable x2: 24.900000

Development

Run tests:

python3 -m pip install pytest
python3 -m pytest

Calculate coverage (outputs .coverage, coverage.xml and htmlcov/):

python3 -m pip install coverage
python3 -m coverage run --branch --include="ortoolslpparser/*" -m pytest
python3 -m coverage xml
python3 -m coverage html

General advice

  • Declare the tightest bounds possible. The default type of a variable is a floating point number in the range (-inf, inf). Make sure that you declare for each variable as tight bounds as possible: this can help the solver. In particular, if you know a certain variable x is a non-negative number, add a x >= 0; constraint to limit the range to [0, inf). The Glop solver tends to not be as fast at solving (-inf, inf)-bounded variables.

About

Fan-written linear program file (.lp) parser which returns an or-tools solver object.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages