KEMBAR78
Python I - Intro To Python Modeling | PDF | Python (Programming Language) | Mathematical Optimization
0% found this document useful (0 votes)
83 views29 pages

Python I - Intro To Python Modeling

Uploaded by

Amit
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
83 views29 pages

Python I - Intro To Python Modeling

Uploaded by

Amit
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 29

Python I: Intro to Python Modeling

Webinar Overview

Part 1. Introduction

An overview of Python, why you should consider using Python and getting started

Part 2. Getting Started

Introductory examples, key concepts, best practices and getting help

Part 3: Extended Example

Practical aspects of modeling, solving, and analyzing solutions


Gurobi and community resources to help you

Part 4. Questions & Answers Session

Copyright 2017, Gurobi Optimization, Inc. 2


Part 1. Introduction
Python, Gurobi and Jupyter Notebook

Copyright 2017, Gurobi Optimization, Inc. 3


Python in a Nutshell

• Python is powerful programming language

• Very easy to learn


• Runs on every major operating system
• Suitable for beginners and professional developers
• Clean, simple and compact syntax
• Open Source community: Tons of ready-made libraries and frameworks

• Python is also a great choice for mathematical modeling

• Many popular packages for scientific computing


• Jupyter Notebooks: Interactive graphical environment
• Key language features look similar to mathematical notations
• Language extensibility

Copyright 2017, Gurobi Optimization, Inc. 4


Why Python?

• Different Gurobi customers use different interfaces


• Python
• Java
• C++
• .NET (C#, Visual Basic, …)
• MATLAB,
• R
• ...

• Gurobi is committed to all of these interfaces

• This presentation focuses on Python since


• Python is simple to learn for new Gurobi users
• Python has special features that make it easy to build and maintain optimization models

Copyright 2017, Gurobi Optimization, Inc. 5


Python Installation

• The Gurobi Optimizer installation includes a small Python 2.7


distribution with a basic set of packages.

• Gurobi Optimizer works with multiple Python distributions


(including http://www.python.org).

• In this presentation, we use Anaconda Python

• Download from http://www.gurobi.com/downloads/get-anaconda


• Windows, Mac, Linux; 32/64-bit
• All basic packages in the default installation
• Easy-to-use package management (conda)
• Gurobi provides/maintains Anaconda packages
• Recommended version: Python 2.7
• Gurobi will support Python 3.6 in the next release

Copyright 2017, Gurobi Optimization, Inc. 6


Basic Concepts

• Python is an “interpreted language”


• No need for a manual compiling step before running a program.
• Performance optimization is done in the background (byte-code compilation/execution).

• Two basic ways to use Python


• Put your code in a text file (e.g. example.py) and run the command “python example.py”.
• Start the Python Interactive Shell (command “python”) and enter commands line by line.

• In this webinar we will furthermore use a rich graphical interactive environment instead of the
command line shell: Jupyter Notebooks.

Copyright 2017, Gurobi Optimization, Inc. 7


Jupyter Notebook

• The Jupyter Notebook is a web application that allows you to create and share documents that
contain live code, equations, visualizations and explanatory text.

• Free software with an active open source community


• Born out of the IPython Project in 2014
• Already included in Anaconda Python

• Simply change to your working directory and


run jupyter notebook on the command-line

• Learn more at http://jupyter.org/

Copyright 2017, Gurobi Optimization, Inc. 8


Connecting Python and Gurobi

• The Python API is a first-class citizen of Gurobi

• To use Gurobi from Python you need to install the


gurobipy module (included in the Gurobi installation).

• Automatic installation with Anaconda:


conda config --add channels http://conda.anaconda.org/gurobi
conda install gurobi

http://www.gurobi.com/documentation/current/quickstart_windows/installing_the_anaconda_py.html

• Manual installation:
• Change to GUROBI_HOME directory
• Run python setup.py install

Copyright 2017, Gurobi Optimization, Inc. 9


Optimization Workflow

Problem • The real-world problem instance is usually


Instance derived from a specific planning problem.

• A configurable model generator is used to


Model build the model instance using data sources.
Analysis
Generator
User • Gurobi is used to find an optimal solution of
Interface the model instance.
Solution Model
Retrieval Instance • The solution is transferred back to the
planning system for further analysis.

Gurobi • The cycle repeats until a satisfying real-world


Optimizer solution has been found.

Image: http://optano.net/en/production-planning/

Copyright 2017, Gurobi Optimization, Inc. 10


Part 2. Getting Started
Building and Solving Your First Models

Copyright 2017, Gurobi Optimization, Inc. 11


Live Demo 1: Solving a Model File

• Goals:
• Make yourself familiar with Jupyter Notebook
• Solve a model file in MPS format

• Example file: afiro.mps (included in the examples


directory of the Gurobi installation)

• Steps:

• Import the gurobipy module


• Create model object from model file
• Solve model to optimality
• Print solution values

Copyright 2017, Gurobi Optimization, Inc. 12


Interactive Demo 1: Details

• The gurobipy module provides access to all Gurobi Optimizer functionality


through Python API

• read() is a global function which returns an object of type Model

• Model.optimize() and Model.printAttr() are methods (functions on


the Model object)

• You can choose any name for the Model object variable:

model = read('afiro.mps') m = read('afiro.mps')


model.optimize() or m.optimize()
model.printAttr('X') m.printAttr('X')

Copyright 2017, Gurobi Optimization, Inc. 13


Basic Gurobi Concepts
• Parameters control the operation of the Gurobi solvers. They
must be modified before the optimization begins.
Model Attributes Parameters
http://www.gurobi.com/documentation/current/parameters.html

• Attributes are the primary mechanism for querying and Constraints Attributes

modifying properties of a Gurobi model.


Variables Attributes
http://www.gurobi.com/documentation/current/refman/attributes.html

Special Ordered Sets Attributes


Attributes can be associated with
• the model as a whole (e.g. the objective function value)
• variables (e.g. lower bounds)
• constraints (e.g. the right-hand side)
• SOSs (e.g. IIS membership)
Environment Global Parameter Settings

• Environments are the containers for models and global


Model 1 Local Parameter Settings
parameter settings. When a model is created inside an
environment, it creates a local copy of all global parameter
Model 2 Local Parameter Settings
settings.
• The Python API automatically provides a default environment.

Copyright 2017, Gurobi Optimization, Inc. 14


Python API Fundamentals #1
• Important global functions
• setParam() set (global) parameters for new models in this session
• read() create model object from a model file

• Primary objects
• Model the model
• Var a variable
• Constr a constraint

• Parameter/attribute examples:
• setParam('TimeLimit', 60) Set global parameter
• model.TimeLimit = 60 Set local parameter
• variable.VarName = 'TotalCosts' Set variable attribute
• constraint.RHS = 0 Set constraint attribute

• Other important methods:


• Model.setObjective(expression) Set objective function
• Model.optimize() Start optimization
• Model.reset() Reset model state

Copyright 2017, Gurobi Optimization, Inc. 15


Python API Fundamentals #2
• Model summary information methods
• Model.printAttr() display nonzero attribute values
• Model.printStats() display sizes, coefficient statistics, etc.
• Model.printQuality() display info about solution quality

• Model introspection methods


• Model.getVars() get variables as a list of Var objects
• Model.getConstrs() get constraints as a list of Constr objects
• Model.getRow() get LHS expression for a given constraint
• Model.getCol() get list of constraints for a given variable

• Python control statements


• for i in <some list>:
<do something for each i here>
• if <condition>:
<do something if condition is true here>
• Must indent body of each statement (at least one space or tab)

Copyright 2017, Gurobi Optimization, Inc. 16


Model Generator Best Practices

• For performance reasons we recommend the following structure when building a model instance
with the Gurobi Python API:

Create all Set


Create Run
variable objective
constraints optimization
objects function(s)
addVar() addConstr()
setObjective() optimize()
addVars() addConstrs()

• The Python API supports (linear and quadratic) expressions similar to the mathematical notation:

2*x + (1/2)*y <= 10

Copyright 2017, Gurobi Optimization, Inc. 17


Creating and Solving Your First Model #1

• Simple example:
• You want to decide about three activities
(do or don‘t do) and aim for maximum value
• You need to choose at least activity 1 or 2 (or both)
• The total time limit is 4 hours
• Activity 1 takes 1 hour
• Activity 2 takes 2 hours
• Activity 3 takes 3 hours
• Activity 3 is worth twice as much as 1 and 2

• This can be modelled as a linear mixed-integer


problem
• Binary variables x,y,z for activities 1,2,3
• Linear constraint for time limit
• Linear constraint for condition (1 or 2)

Copyright 2017, Gurobi Optimization, Inc. 18


Creating and Solving Your First Model #2
# Create a new model
• Open a new Jupyter Notebook
m = Model()
• Follow the Best Practices
• Create decision variables # Add variables
x = m.addVar(vtype=GRB.BINARY, name="x")
• Set objective function
y = m.addVar(vtype=GRB.BINARY, name="y")
• Create linear expressions and use them to z = m.addVar(vtype=GRB.BINARY, name="z")
create constraints
• Call optimize() # Set objective function
m.setObjective(x + y + 2*z, GRB.MAXIMIZE)
• Print out results
# Add constraints
c1 = m.addConstr(x + 2*y + 3*z <= 4)
c2 = m.addConstr(x + y >= 1)
This model is the mip1 example that you can find
for all APIs in the examples directory of the Gurobi # Solve model
installation. m.optimize()

Copyright 2017, Gurobi Optimization, Inc. 19


Live Demo 2: Creating and Solving Your First Model

Copyright 2017, Gurobi Optimization, Inc. 20


Getting Help
• Use the help() function with no arguments to get general help

• You can get help on specific Gurobi objects


• help(Model) Gurobi model object (or help(m) if m is a model)
• help(Var) Gurobi variable object (or help(v) if v is a variable)
• help(Constr) Gurobi constraint object (or help(c) if c is a constraint)
• help(GRB.attr) Gurobi attributes

• You can get help on specific functions or methods


• Ex: help(read)
• Ex: help(Model.printAttr)

• You can get help on any parameter


• Ex: paramHelp('Method')

Copyright 2017, Gurobi Optimization, Inc. 21


Deciphering Errors

• Errors are raised when something goes wrong


• Trace specifies where error occurred
• Last line specifies error type and may provide additional details

• Ex: IndentationError raised when block spacing is incorrect (must indent before if)

for v in model.getVars():
if v.x != 0:
File "<stdin>", line 2
if v.x != 0:
^
IndentationError: expected an indented block

• <stdin> corresponds to interactive shell

Copyright 2017, Gurobi Optimization, Inc. 22


Part 3. Extended Example
Factory Planning

Copyright 2017, Gurobi Optimization, Inc. 23


Iterating in Python and Aggregate Sums

• Loops iterate over collections of elements • Combining loops with sums is ideal when building
(list, dictionary, …) constraints
• Useful when representing the for-all modeling construct
• Example: Example:

for c in cities:
print c # must indent all loop statements can be built with

• List comprehension efficiently builds lists via set notation for i in I:


• penaltyarcs = [a for a in arcs if cost[a] > m.addConstr(quicksum(x[i,j] for j in J) <= 5)
1000]

• quicksum() is direct replacement for Python's sum()


• Convenient batch creation of variables and constraints
function
has been introduced as part of Gurobi 7.0. Example:
• Gurobi feature that is more efficient when working with Var
objects m.addConstrs((x.sum(i,'*') <= 5) for i in I))

• obj = quicksum(cost[a]*x[a] for a in arcs)

Copyright 2017, Gurobi Optimization, Inc. 24


Factory Planning

• Example from our website:


http://www.gurobi.com/resources/examples/factory-planning-I

• In production planning problems, choices must be made about how many of what
products to produce using what resources (variables) in order to maximize profits or
minimize costs (objective function), while meeting a range of constraints. These
problems are common across a broad range of manufacturing situations.

• We will develop the mathematical model, the Python Implementation and a nice tabular
output of the result all within a single Jupyter Notebook.

Copyright 2017, Gurobi Optimization, Inc. 25


Live Demo 3: Interactive Model Development

Copyright 2017, Gurobi Optimization, Inc. 26


Use our Gurobi Online Resources
• The Gurobi Reference Manual is freely available at

http://www.gurobi.com/documentation/current/refman/index.html

It contains detailed descriptions of our algorithms and APIs.

• We provide API examples for all major programming languages as well as


interactive examples at

http://www.gurobi.com/resources/examples/example-models-overview

Copyright 2017, Gurobi Optimization, Inc. 27


Outlook

• Interactive examples for commonly faced business problems


• http://www.gurobi.com/resources/examples/example-models-overview

• Learn the powerful new Python features of Gurobi 7


• Easily create multi-indexes variables using Model.addVars()
• Build advanced expressions and constraints with Model.addConstrs()

• More control over when Gurobi environments are created/released


• Default environment not created until first used
• Released with new disposeDefaultEnv() method

• Build you own model!


• Connect with the community in our discussion group ( http://groups.google.com/group/gurobi)

Copyright 2017, Gurobi Optimization, Inc. 28


Thank you for joining us

• Please register at gurobi.com and then visit http://www.gurobi.com/downloads/get-anaconda to try


Gurobi and Python for yourself

• There will be two more Python webinars


• Python II: Advanced Algebraic Modeling with Python and Gurobi
• Python III: Optimization and Heuristics
• Learn more at http://www.gurobi.com/company/events/webinars-python

• For questions about pricing please contact either sales@gurobi.com or sales@gurobi.de.

• A recording of the webinar will be available in roughly one week.

Copyright 2017, Gurobi Optimization, Inc. 29

You might also like