Optimization Services Instance Language (OSiL)

Slides:



Advertisements
Similar presentations
Optimization Services Robert Fourer, Jun Ma, Kipp Martin Optimization Services OS Server and OS Libraries Jun Ma Industrial Engineering.
Advertisements

SCIP Optimization Suite
Solver and modelling support for stochastic programming H.I. Gassmann, Dalhousie University Happy Birthday András, November 2009.
What is GAMS?. While they are not NLP solvers, per se, attention should be given to modeling languages like: GAMS- AIMMS-
1 COS 425: Database and Information Management Systems XML and information exchange.
XML(EXtensible Markup Language). XML XML stands for EXtensible Markup Language. XML is a markup language much like HTML. XML was designed to describe.
XML –Query Languages, Extracting from Relational Databases ADVANCED DATABASES Khawaja Mohiuddin Assistant Professor Department of Computer Sciences Bahria.
AMPL Presentation 1 By Raymond Kleinberg Outline AMPL - Ugh! - What is it good for? Basics Starting a Problem Running the Problem Example.
Optimization Services (OS) Framework and OSP Protocols (OSxL) “Combining Operations Research with Computing Technology” Jun Ma 10/24/2004.
1 Advanced Topics XML and Databases. 2 XML u Overview u Structure of XML Data –XML Document Type Definition DTD –Namespaces –XML Schema u Query and Transformation.
1 LPFML: A W3C XML Schema for Linear and Integer Programming Robert Fourer Northwestern University Leonardo Lopes University.
10/06/041 XSLT: crash course or Programming Language Design Principle XSLT-intro.ppt 10, Jun, 2004.
Robert Fourer, Jun Ma, Kipp Martin, Optimization Services, January 18, 2005 Optimization Services (OS) Jun Ma Motorola, Schaumburg 01/18/2005 Robert Fourer.
Robert Fourer, Jun Ma, Kipp Martin Optimization Services Instance Language (OSiL), Solvers, and Modeling Languages Kipp Martin University of Chicago
Quantitative Methods of Management
Lecture 6 of Advanced Databases XML Schema, Querying & Transformation Instructor: Mr.Ahmed Al Astal.
Maziar Sanaii Ashtiani – SCT – EMU, Fall 2011/12.
CSE4500 Information Retrieval Systems XML Schema – Part 1.
XP 1 CREATING AN XML DOCUMENT. XP 2 INTRODUCING XML XML stands for Extensible Markup Language. A markup language specifies the structure and content of.
Optimization Services Robert Fourer, Jun Ma, Kipp Martin Setting Up and Hosting Your Solver as Web Services via Optimization Services (OS) Jun Ma
Recent Changes to the Optimization Services Project H.I. Gassmann, Faculty of Management J. Ma, Northwestern University R.K. Martin, The University of.
Robert Fourer, Jun Ma, Kipp Martin Copyright 2006 An Enterprise Computational System Built on the Optimization Services (OS) Framework and Standards Jun.
Extensions to the OSiL schema: Matrix and cone programming Horand I. Gassmann, Dalhousie University Jun Ma, Kipp Martin, Imre Polik.
Electronic Commerce COMP3210 Session 4: Designing, Building and Evaluating e-Commerce Initiatives – Part II Dr. Paul Walcott Department of Computer Science,
Jun Ma, Optimization Services, July 19, 2006 Optimization Services (OS) Today: open Interface for Hooking Solvers to Modeling Systems Jun Ma Northwestern.
Robert Fourer, Jun Ma, Kipp Martin Optimization Services and the Stylized “OS” Logo are registered in the US Patent & Trademark Office. All other product.
1 Credits Prepared by: Rajendra P. Srivastava Ernst & Young Professor University of Kansas Sponsored by: Ernst & Young, LLP (August 2005) XBRL Module Part.
Jun Ma, Optimization Services, June 23, 2005 Optimization Services (OS) Jun Ma Industrial Engineering and Management Sciences Northwestern University T.J.
Fourer, Ma, Martin, An Open Interface for Hooking Solvers to Modeling Systems INFORMS International, Puerto Rico, July 8-11, INFORMS International.
Robert Fourer, Jun Ma, Kipp Martin, Optimization Services, May 06, 2005 Optimization Services (OS) Jun Ma Industrial Engineering and Management Sciences.
Diego Klabjan, Jun Ma, Robert Fourer – Northwestern University.
CS 157B: Database Management Systems II February 11 Class Meeting Department of Computer Science San Jose State University Spring 2013 Instructor: Ron.
XML eXtensible Markup Language. XML A method of defining a format for exchanging documents and data. –Allows one to define a dialect of XML –A library.
Internet & World Wide Web How to Program, 5/e. © by Pearson Education, Inc. All Rights Reserved.2.
An XML-based schema for stochastic programs H.I. Gassmann, R. Fourer, J. Ma, R.K. Martin EURO XXI, June 2006, Reykjavik.
COMP9321 Web Application Engineering Semester 2, 2015 Dr. Amin Beheshti Service Oriented Computing Group, CSE, UNSW Australia Week 4 1COMP9321, 15s2, Week.
Robert Fourer, Jun Ma, Kipp Martin Copyright 2006 Optimization Services hookup Language (OShL) Jun Ma INFORMS, Pittsburgh 11/08/2006 Jun Ma Robert Fourer.
Jun Ma, Optimization Services, May 18, 2005 Optimization Services (OS) Jun Ma Industrial Engineering and Management Sciences Northwestern University Lindo.
XP New Perspectives on XML, 2 nd Edition Tutorial 7 1 TUTORIAL 7 CREATING A COMPUTATIONAL STYLESHEET.
Martin Kruliš by Martin Kruliš (v1.1)1.
XML Validation II Advanced DTDs + Schemas Robin Burke ECT 360.
OSiL: An XML-based schema for stochastic programs H.I. Gassmann, R. Fourer, J. Ma, R.K. Martin SP XI Vienna, August 2007.
Jun Ma, Sanjay Mehrotra and Huanyuan Sheng Impact Solver for Optimization Services, November 8, 2006 On Implementing a Parallel Integer Solver Using Optimization.
Robert Fourer, Jun Ma, Kipp Martin Copyright 2005 Optimization Services (OS) Jun Ma Annapolis, 01/07/2005 Robert Fourer Jun Ma Northwestern University.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke1 The Relational Model Chapter 3.
CITA 330 Section 4 XML Schema. XML Schema (XSD) An alternative industry standard for defining XML dialects More expressive than DTD Using XML syntax Promoting.
CS 480: Database Systems Lecture 26 March 18, 2013.
XML: Extensible Markup Language
Unit 4 Representing Web Data: XML
ACG 4401 XML Schemas XML Namespaces XLink.
Coopr: A Python Repository for Optimization
ACG 4401 XML Schemas XML Namespaces XLink.
XML in CCSDS CCSDS Spring Meeting - Montreal
XML QUESTIONS AND ANSWERS
CMP 051 XML Introduction Session IV
XML in Web Technologies
Data Modeling II XML Schema & JAXB Marc Dumontier May 4, 2004
Discussion on XSD open issues
Chapter 7 Representing Web Data: XML
Optimization Services (OS)
Optimization Services Instance Language (OSiL)
Chapter 6 Intermediate-Code Generation
A Mathematical Programming Language
CMP 051 XML Introduction Session III
Presented by: Jacky Ma Date: 11 Dec 2001
A QUICK START TO OPL IBM ILOG OPL V6.3 > Starting Kit >
An XML-based schema for stochastic programs
More XML XML schema, XPATH, XSLT
XML: The new standard -Eric Taylor.
XML Schema Diyar A. Abdulqder
Presentation transcript:

Optimization Services Instance Language (OSiL) Robert Fourer Jun Ma Northwestern University Kipp Martin University of Chicago Kipp Martin University of Chicago kipp.martin@chicagogsb.edu

Outline 1. Background and motivation for an instance standard Why use XML for the instance standard 3. Optimization Services instance Language (OSiL) - this replaces LPFML for the linear case and can be used to represent a wide variety of optimization problems. The OSiL schema 5. The OSExpressTree data structure 6. Real time data and user defined functions 7. Extensions

A Distributed Modeling Environment

A Distributed Modeling Environment In a loosely coupled setting we have a separation of the modeling language process and solver process. Key idea: model versus instance The solver wants an instance as opposed to a model

A MODEL This is a model. It is symbolic, general, concise, set PROD; # products set DEP; # processing departments param hours {DEP}; # time available in each department param rate {DEP,PROD}; # hours used in each dept per product unit made param profit {PROD}; # profit per unit of each product made var Make {PROD} >= 0; # number of units of each product to be made maximize TotalProfit: sum {j in PROD} profit[j] * Make[j]; subject to HoursAvailable {i in DEP}: sum {j in PROD} rate[i,j] * Make[j] <= hours[i]; This is a model. It is symbolic, general, concise, and understandable (Fourer, 1983).

DATA param: PROD: profit := std 10 del 9 ; param: DEP: hours := cutanddye 630 sewing 600 finishing 708 inspectandpack 135 ; param: rate: std del := cutanddye 0.7 1.0 sewing 0.5 0.8333 finishing 1.0 0.6667 inspectandpack 0.1 0.25 ;

MODEL + DATA = INSTANCE maximize TotalProfit: 10*Make[‘std’] + 9*Make[‘del’]; subject to HoursAvailable[‘cutanddye’]: 0.7*Make[‘std’] + Make[‘del’] <= 630; subject to HoursAvailable[‘sewing’]: 0.5*Make[‘std’] + 0.8333*Make[‘del’] <= 600; subject to HoursAvailable[‘finishing’]: Make[‘std’] + 0.6667*Make[‘del’] <= 708; subject to HoursAvailable[‘inspectandpack’]: 0.1*Make[‘std’] + 0.25*Make[‘del’] <= 135; Objective: represent a model instance using XML.

AIMMS CLP AMPL CPLEX GAMS GLPK LINGO LINDO Mosel MINOS MPL MOSEK OPL There is a proliferation of modeling languages and solvers AIMMS CLP AMPL CPLEX GAMS GLPK LINGO LINDO Mosel MINOS MPL MOSEK OPL Xpress-MP

Consequence: a lot of drivers are need for every modeling language to talk to every solver

It would be nice to have an instance representation language.

The Case for XML 1. Validation against a schema provides for error checking 2. Validation against a schema promotes stability of a standard 3. The schema can restrict data values to appropriate types, e.g. row names to string, indices to integer, coefficients to double 4. The schema can define keys to insure, for example, no row or column name is used more than once. 5. The schema can be extended to include new constraint types or solver directives 6. There is a lot of open source software to make parsing easy.

XML and Optimization Systems When instances are stored in XML format, optimization technology solutions are more readily integrated into broader IT infrastructures 2. XML is used for Web Services – important for distributed computing 3. The XML format lends itself well to compression – more on this later 4. The XML format can be combined with other technologies, e.g. XSLT to present results in human readable formats Encryption standards are emerging for XML – possibly important in a commercial setting.

XML Concepts XML (Extensible Markup Language) – an XML file contains both data and Markup (Elements (tags) and Attributes) The tags are organized in a tree like structure. The closing tag of a child element preceding the closing tag of its parent. <constraints> <con name=“cutanddye" ub="630"/> <con name="sewing" ub="600"/> <con name="finishing" ub="708"/> <con name="inspectandpack" ub="135"/> </constraints> ATTRIBUTE ELEMENT

OSiL Instance Representation

OSiL Instance Representation The variables: <variables number="2"> <var lb="0" name="x0" type="C"/> <var lb="0" name="x1" type="C"/> </variables> -OR- <variables number="2"> <var lb="0" ub=“INF” name="x0" type="C"/> <var lb="0" ub=“INF” name="x1" type="C"/> </variables>

OSiL Instance Representation The objective functions: <objectives number="1"> <obj maxOrMin="min" name="minCost">] <coef idx="1">9</coef> </obj> </objectives>

OSiL Instance Representation The constraints: <constraints number="2"> <con name=“row0” ub="10.0"/> <con name=“row1” lb="10.0"/> </constraints>

OSiL Instance Representation The linear constraint terms: <linearConstraintCoefficients> <start> <el>0</el><el>2</el><el>3</el> </start> <rowIdx> <el>0</el><el>1</el><el>1</el> </rowIdx> <value> <el>1.0</el><el>7.0</el><el>5.0</el> </value> </linearConstraintCoefficients>

OSiL Instance Representation The nonlinear terms: <nl idx="1"> <ln> <times> <var idx="0"/> <var idx="1"/> </times> </ln> </nl>

OSiL Instance Representation The nonlinear terms: <nl idx="0"> <quadratic> <qpTerm idxOne="0" idxTwo="1" coef="3"/> <qpTerm idxOne="0" idxTwo=”0" coef=”1"/> </quadratic> </nl>

XML Schema Key idea – a schema. Similar to the concept of a class in object orient programming. Critical for parsing! Schema Class XML File Object We need a schema to represent an instance.

Schema – a Constraints Object <constraints number="2"> <con name=“row0” ub="10.0"/> <con name=“row1” lb="10.0"/> </constraints>

Schema – a Constraints and Con Class <xs:complexType name="constraints"> <xs:sequence> <xs:element name="con" type="con" maxOccurs="unbounded"/> </xs:sequence> <xs:attribute name="number" type="xs:nonNegativeInteger" use="required"/> </xs:complexType> <xs:complexType name="con"> <xs:attribute name="name" type="xs:string" use="optional"/> <xs:attribute name="lb" type="xs:double" use="optional" default="-INF"/> <xs:attribute name="ub" type="xs:double" use="optional" default="INF"/> <xs:attribute name="mult" type="xs:positiveInteger" use="optional" default="1"/>

The OSiL Schema

The OSiL Schema

OSnLNode Problem: parsing, doing function and gradient evaluations, etc. a real PAIN with numerous operators and operands. We avoid this by having EVERY nonlinear node an OSnLNode instance. <xs:complexType name="OSnLNode" mixed="false"/> <xs:element name="OSnLNode" type="OSnLNode" abstract="true">

OSnLNode The Multiplication Operator Extend OSnLNode <xs:complexType name="OSnLNodeTimes"> <xs:complexContent> <xs:extension base="OSnLNode"> <xs:sequence minOccurs="2" maxOccurs="2"> <xs:element ref="OSnLNode"/> </xs:sequence> </xs:extension> </xs:complexContent> </xs:complexType> <xs:element name="times" type="OSnLNodeTimes" substitutionGroup="OSnLNode"/>

OSExpressionTree

OSExpressionTee (Parsing) A traditional C approach for parsing. Construct *e a pointer to root of expression tree. Then process the expression tree. double evaluate\_function (expr *e, double x[]){ ... opnum = e->op switch(opnum){ case PLUS_opno: ... case MINU_opno: ... }

OSExpressionTree (Parsing) We take an object oriented approach, every node in the expression tree is an instance in the OSnLNode class OSnLNode nlNode = null; String sNodeName = ""; try{ sNodeName = ele.getLocalName(); String sNlNodeClass = m\_sPackageName + "." + m\_sNlNodeStartString +] sNodeName.substring(0, 1).toUpperCase() + sNodeName.substring(1); Class nlNodeClass = Class.forName(sNlNodeClass); nlNode = (OSnLNode)nlNodeClass.newInstance(); } // now process attributes “OSnLNodeTimes” An instance of OSnLNode which is an OSnLNodeTimes

Real Time Data In many cases the instance generated by the solver contains time sensitive data. For example, in many financial models. Before solving we can: Repeat entire modeling process and have modeling language generate a new model from scratch. OR 2. Have the “reader” library update only the necessary data before sending it to the solver.

Real Time Data Real time data

Real Time Data

Real Time Data

Markowitz Example

Markowitz and Real Time Data <variables number="4"> <var name="msft" lb="0.0" ub=".75"/> <var name="pg" lb="0.0" ub=".75"/> <var name="ge" lb="0.0" ub=".75"/> <var name="RBAR" lb=".05"/> </variables> <realTimeData> <defaultURI>http://www.stockdata.com/stockdata.xml</defaultURI> <variables> <var idx="3" type="lb"> <xPath path="/xmlData/portfolioReturn/text()" /> </var> </variables> </realTimeData>

User Defined Functions Many istances often: Contain terms repeated many times, either verbatim or With small systematic changes 2. Contain definitional variables

User Defined Functions <userFunction name="stockRet" numArg="2"> <xPath path="//scenario[@id=$scenario]/stock[@name=$name]/@return"> <xPathIndex indexName="scenario"> <arg idx="0"/> </xPathIndex> <xPathIndex indexName="name"> <arg idx="1"/> </xPath> </userFunction> Idx=0 idx = 1

User Defined Functions <userFunction name = "scenarioRet" numArg="1"> <sum> <times> <userF name="stockRet"> <arg idx="0"/> <string value="msft"/> </userF> <var idx="0"/> </times> </sum> </userFunction>

OSrL - Optimization Services Result Language

OSrL - Optimization Services Result Language

OSrL - Optimization Services Result Language

A Distributed Modeling Environment

QUESTIONS? http://www.optimizationservices.org