ASCEND capabilities: Difference between revisions

From ASCEND
Jump to navigation Jump to search
No edit summary
 
(11 intermediate revisions by the same user not shown)
Line 1: Line 1:
{{stub}}
The following is a summary of current ASCEND capabilities. It is intended to be a complete list. If you want a more general/introductory overview, see the [[ASCEND overview]]. The main page for accessing greater detail on these topics is our [[:Category:Documentation|documentation]] index. This page emphasises the newer PyGTK-based GUI for ASCEND. An overview of the features of the older Tcl/Tk GUI is can be obtained from the [[TclTk screenshots]].


At present, the best summary of ASCEND capabilities can be seen in the [[ASCEND overview]]. More detail comes from reading the [[:Category:Documentation|documentation]].
== Language features ==
 
* Equation-based language, see ''[http://ascend.cheme.cmu.edu/ftp/pdfPapersRptsSlides/processModeling.pdf Equation-based Process Modeling]'' for an overview.
* Full support for [[units of measurement]]; user never needs to worry about conversion factors.
* Hierarchical [[MODEL]]s allowing modular system models built from reused components
* Procedural initialisation of models and solver parameters using [[METHOD]]s
* [[WHEN]] syntax for [[conditional modelling]] also known as 'variable-structure modelling'.
* Differential as well as algebraic equations can be expressed
* Constants are declared separately from variables
* Multi-modal models with [[SWITCH]] statement (switching based on values assigned to constants).
* Externally-defined equations ('[[external relations]]') can be added to models via shared libries and the [[IMPORT]] statement
* Can run arbitrary Python code in [[METHOD]]s via [[ExtPy]] linkage, useful for custom plotting, reporting, and model initialisation.
 
== Solver features ==
 
* Detection of singular and non-square equation systems; user is advised on what modifications would help to make system square.
* Steady-state [[QRSlv]] solver with block decomposition
* Optimisation solver [[IPOPT]] as well as linking to commercial [[CONOPT]] solver
* ODE and DAE solver for [[dynamic modelling]]: [[IDA]], [[RADAU5]], [[LSODE]]
* Some preliminary support for dynamic switching models with boundaries, see [[integration of conditional models]].
* Solver parameters can be set from within the model code (see [[SOLVER]] and [[OPTION]] statements)
* New solvers can easily be added, implemented as [[external libraries]] that access our Solver API.
 
== GUI features ==
 
* View all aspects of a model in a hierarchical tree view
* [[FIX]] and [[FREE]] variables interactively, set their values, and quickly re-solve the model.
* Interactive exploration of the numerical/convergence behaviour of the model
* Capture the state of selected variables for export/plotting via [[Observer]] functionality
* View [[incidence matrix]] showing block-decomposed structure of steady-state systems
* Diagnose blocks in the model which have been giving numerical problems
* View [[incidence graph]] (aka dependency graph) for solution process
* Plot the time-varying values from the solution of dynamic problems
* Alpha-quality [[canvas-based modeller for ASCEND]] allows 'wiring up' of graphical 'blocks' to construct complex flowsheets
 
== Thermodynamics and Engineering features ==
 
* {{src|models/thermodynamics.a4l}} code for basic-level accuracy of pure species as well as mixtures
* [[FPROPS]] code for accurate calculation of pure species properties
* linkage to [[freesteam]] library for calculation of steam properties by official IAPWS-IF97 correlations.
* A range of models for [[Energy system modelling with ASCEND|energy system modelling], including [[Brayton cycle]], [[Rankine cycle]] and several solar thermal energy component models.
* Models of mixers, separators and reactors for chemical process modelling (eg {{src|models/flash.a4l}})
* A growing [[model library]] with a wide range of examples and reusable models.


[[Category:Documentation]]
[[Category:Documentation]]

Latest revision as of 05:09, 3 April 2013

The following is a summary of current ASCEND capabilities. It is intended to be a complete list. If you want a more general/introductory overview, see the ASCEND overview. The main page for accessing greater detail on these topics is our documentation index. This page emphasises the newer PyGTK-based GUI for ASCEND. An overview of the features of the older Tcl/Tk GUI is can be obtained from the TclTk screenshots.

Language features

  • Equation-based language, see Equation-based Process Modeling for an overview.
  • Full support for units of measurement; user never needs to worry about conversion factors.
  • Hierarchical MODELs allowing modular system models built from reused components
  • Procedural initialisation of models and solver parameters using METHODs
  • WHEN syntax for conditional modelling also known as 'variable-structure modelling'.
  • Differential as well as algebraic equations can be expressed
  • Constants are declared separately from variables
  • Multi-modal models with SWITCH statement (switching based on values assigned to constants).
  • Externally-defined equations ('external relations') can be added to models via shared libries and the IMPORT statement
  • Can run arbitrary Python code in METHODs via ExtPy linkage, useful for custom plotting, reporting, and model initialisation.

Solver features

  • Detection of singular and non-square equation systems; user is advised on what modifications would help to make system square.
  • Steady-state QRSlv solver with block decomposition
  • Optimisation solver IPOPT as well as linking to commercial CONOPT solver
  • ODE and DAE solver for dynamic modelling: IDA, RADAU5, LSODE
  • Some preliminary support for dynamic switching models with boundaries, see integration of conditional models.
  • Solver parameters can be set from within the model code (see SOLVER and OPTION statements)
  • New solvers can easily be added, implemented as external libraries that access our Solver API.

GUI features

  • View all aspects of a model in a hierarchical tree view
  • FIX and FREE variables interactively, set their values, and quickly re-solve the model.
  • Interactive exploration of the numerical/convergence behaviour of the model
  • Capture the state of selected variables for export/plotting via Observer functionality
  • View incidence matrix showing block-decomposed structure of steady-state systems
  • Diagnose blocks in the model which have been giving numerical problems
  • View incidence graph (aka dependency graph) for solution process
  • Plot the time-varying values from the solution of dynamic problems
  • Alpha-quality canvas-based modeller for ASCEND allows 'wiring up' of graphical 'blocks' to construct complex flowsheets

Thermodynamics and Engineering features

  • models/thermodynamics.a4l code for basic-level accuracy of pure species as well as mixtures
  • FPROPS code for accurate calculation of pure species properties
  • linkage to freesteam library for calculation of steam properties by official IAPWS-IF97 correlations.
  • A range of models for [[Energy system modelling with ASCEND|energy system modelling], including Brayton cycle, Rankine cycle and several solar thermal energy component models.
  • Models of mixers, separators and reactors for chemical process modelling (eg models/flash.a4l)
  • A growing model library with a wide range of examples and reusable models.