Difference between revisions of "Category:APMonitor"
(Creation of APMonitor page) |
m (→Availibility: minor clarification) |
||
Line 18: | Line 18: | ||
</source> | </source> | ||
− | Similar interfaces are available for MATLAB and Julia with minor differences in syntax between the languages. APMonitor is freely available as a web service or a locally installed web server for Linux or Windows. | + | Similar interfaces are available for MATLAB and Julia with minor differences in APMonitor syntax between the languages. APMonitor is freely available as a web service or a locally installed web server for Linux or Windows. |
== Supported Problem Classes == | == Supported Problem Classes == |
Latest revision as of 22:43, 20 November 2017
Advanced process monitor (APMonitor), is a modeling language for mixed integer and differential algebraic equations. It is a free web-service or locally installed service for solving this class of problems. APMonitor is suited for large-scale problems and allows solutions of linear programming, integer programming, nonlinear programming, nonlinear mixed integer programming, dynamic simulation, moving horizon estimation, and nonlinear model predictive control. APMonitor does not solve the problems directly, but calls nonlinear programming solvers such as APOPT, BPOPT, IPOPT, MINOS, and SNOPT.
Contents
Programming Language Integration
Julia, MATLAB, and Python are mathematical programming languages that have APMonitor integration through web-service APIs. The interfaces are built-in optimization toolboxes or modules to both load and process solutions of optimization problems. APMonitor is an object-oriented modeling language and optimization suite that relies on programming languages to load, run, and retrieve solutions. APMonitor models and data are compiled at run-time and translated into objects that are solved by an optimization engine such as APOPT (MINLP) or IPOPT (NLP). The optimization engine is not specified by APMonitor, allowing several different optimization engines to be switched out. The simulation or optimization mode is also configurable to reconfigure the model for dynamic simulation, nonlinear model predictive control, moving horizon estimation or general problems in mathematical optimization.
High Index DAEs
The highest order of a derivative that is necessary to return a DAE to ODE form is called the differentiation index. A standard way for dealing with high-index DAEs is to differentiate the equations to put them in index-1 DAE or ODE form with Pantelides algorithm. However, this approach can cause a number of undesirable numerical issues such as instability. While the syntax is similar to other modeling languages, APMonitor solves DAEs of any index without rearrangement or differentiation.
Availibility
The APMonitor Python package can be installed with pip install APMonitor or from the following Python code.
# Install APMonitor import pip pip.main(['install','APMonitor'])
Similar interfaces are available for MATLAB and Julia with minor differences in APMonitor syntax between the languages. APMonitor is freely available as a web service or a locally installed web server for Linux or Windows.
Supported Problem Classes
- NLP, LP, QP, MILP, MINLP
- Optimal Control Problems with ODEs or DAEs
- Minimum Time Problems
- Optimal Design
- Model Calibration
- Parameter Estimation
Algorithms
Dynamic optimization uses direct collocation solved with large-scale nonlinear programming solvers. APMonitor provides exact first and second derivatives of continuous functions to the solvers through automatic differentiation and in sparse matrix form.
References
Pages in category "APMonitor"
This category contains only the following page.