ComparisonWithStateGraph2

class ComparisonWithStateGraph2 "Comparison with StateGraph2"
    extends Modelica.Icons.Information;

    annotation (Documentation(info = "<html>\n<p>\nThere is a much improved library available called \"Modelica_StateGraph2\".\nIf this library is not yet distributed with your Modelica tool, you can download\nit from <a href=\"https://github.com/modelica/Modelica_StateGraph2\">https://github.com/modelica/Modelica_StateGraph2</a>.\nFind below a comparison with respect to Modelica.StateGraph.\nIt is not yet clear whether Modelica_StateGraph2 will be included in a\nfuture version of the Modelica package. Another option is to provide\nbuilt-in support for state machines in a future Modelica language version\nwhich would allow an even more powerful treatment of state machines in Modelica.\n</p>\n\n<p>\nThe Modelica_StateGraph2 library (called <u>StateGraph2</u> below)\nis based on the experience with the current\nModelica.StateGraph library (called <u>StateGraph1</u> below) and is\na significantly further development of StateGraph1. Furthermore, it is heavily\nbased on the article (Malmheden et. al. 2008), see Literature below,\nbut uses a different implementation\ntechnique as described in this article. The StateGraph2\nlibrary has the following improvements with respect to the StateGraph1\nlibrary:\n</p>\n\n<ul>\n<li> <strong>3 Basic Components (Step, Transition, Parallel)</strong><br>\n     All multiple versions of a component are\n     combined in only one version (e.g., one step and not 4 step components).\n     This is easier to understand and more convenient to use.\n     The \"Parallel\" component is both used as \"composite step\" (so only one branch),\n     as well as \"parallel step\" (so several execution branches).<br>&nbsp;</li>\n\n<li> <strong>Conveniently connecting components</strong><br>\n     Connecting components of a state machine in Modelica means to provide\n     new vector dimensions and to provide a vector index to connect to.\n     In StateGraph2, the new \"connectorSizing\" annotation is used and\n     therefore all this is now performed automatically (from a users point\n     of view, these actions are hidden; this is not the case in\n     StateGraph1 and makes the usage of the StateGraph1 library clumsy).<br>&nbsp;</li>\n\n<li> <strong>Safer state machines</strong><br>\n     It is no longer possible to construct a wrong state machine in the sense that properties\n     of the graph are violated (e.g., two initial steps, or branching wrongly out of a parallel\n     component). Contrary to StateGraph2, in StateGraph1 such wrong graphs do not lead to an\n     error but to unexpected simulation results. Still, other desirable properties\n     of a state machine,  such as \"no deadlock\" or \"lifeliness\" or \"every step reachable\",\n     are not (yet) guaranteed with the current StateGraph2.<br>&nbsp;</li>\n\n<li> <strong>Composite, autonomous, synchronized, preempted subgraphs</strong><br>\n     Composite steps and parallel steps are described in a much better and more powerful\n     way as in StateGraph1: Either by component \"Parallel\" or\n     by inheriting from \"PartialParallel\". The first alternative has the advantage that it\n     is simple to use (not necessary to construct a new class and instantiating this class, and\n     easy variable access since no new hierarchy is constructed), the second alternative\n     has the advantage that it introduces a Modelica hierarchy (useful for large subgraphs).\n     In both cases, various options are possible, such as\n     <ol>\n     <li> autonomous subgraphs (branches are executed in parallel autonomously),</li>\n     <li> synchronized subgraphs (branches are executed in parallel and are synchronized\n           before leaving the subgraph via the outPort),</li>\n     <li> subgraphs with preemption and exception (a parallel step can be interrupted via\n          the suspend ports and can continue execution via the resume ports).</li>\n     </ol>\n     This is achieved by enabling/disabling the different ports.<br>&nbsp;</li>\n<li> <strong>No infinite looping</strong>:<br>\n     As in StateGraph1, there are two types of transitions: immediate transitions (during event\n     iteration all immediate transitions fire until no transition condition is true anymore) and\n     delayed transitions (a transition fires only after a delay). Contrary to StateGraph1,\n     in StateGraph2 every loop must have at least one delayed transition. If this is not the case\n     a translation error occurs which states that the model contains an algebraic loop\n     between Booleans with the name \"checkOneDelayedTransitionPerLoop\".<br>\n     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;This property guarantees that an event\n     iteration over a StateGraph2 converges after a\n     finite number of iterations, provided the modeller does not introduce an unsafe construct\n     in the actions associated with a StateGraph2 (e.g., \"i = pre(i) + 1\" in the equation section\n     outside of a when-clause will give an event iteration that never stops).<br>\n     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;It is possible to switch off this feature, by setting parameter\n     \"loopCheck = <strong>false</strong>\" in one transition of a loop, instead of using a \"delayed transition\"\n     at this place (in cases where immediate transitions are\n     important and the transition conditions are in a form that they cannot fire at the\n     same time instant).</li>\n</ul>\n\n<h4> Literature </h4>\n\n<p>\nThe Modelica_StateGraph2 library is described in detail in\n(Otter et. al. 2009, see below) and is additionally\nbased on the following references:\n</p>\n\n<dl>\n<dt>Andr&eacute;, C. (2003):</dt>\n<dd><a href=\"http://www.i3s.unice.fr/~map/WEBSPORTS/Documents/2003a2005/SSMsemantics.pdf\">\n     Semantics of S.S.M (Safe State Machine).</a>.\n     I3S Laboratory, UMR 6070 University of Nice-Sophia Antipolis / CNRS.<br>&nbsp;</dd>\n\n<dt>&Aring;rz&eacute;n K.-E. (2004):</dt>\n<dd> <strong>JGrafchart User Manual. Version 1.5</strong>.\n     Department of Automatic Control, Lund Institute of Technology,\n     Lund, Sweden, Feb. 13, 2004.<br>&nbsp;</dd>\n\n<dt>Dressler I. (2004):</dt>\n<dd> <a href=\"http://www.control.lth.se/documents/2004/5726.pdf\">\n     Code Generation From JGrafchart to Modelica.</a>.\n     Master thesis, supervisor: Karl-Erik &Aring;rz&eacute;n,\n     Department of Automatic Control, Lund Institute of Technology,\n     Lund, Sweden, March 30, 2004.<br>&nbsp;</dd>\n\n<dt>Elmqvist H., Mattsson S.E., Otter M. (2001):</dt>\n<dd> <strong>Object-Oriented and Hybrid Modeling in Modelica</strong>.\n     Journal Europeen des systemes automatises (JESA),\n     Volume 35 - n. 1, 2001.<br>&nbsp;</dd>\n\n<dt>Harel, D. (1987):</dt>\n<dd> <a href=\"http://www.inf.ed.ac.uk/teaching/courses/seoc1/2005_2006/resources/statecharts.pdf\">\n      A Visual Formalism for Complex Systems</a>.\n      Science of Computer Programming 8, 231-274. Department of Applied Mathematics,\n      The Weizmann Institute of Science, Rehovot, Israel.<br>&nbsp;</dd>\n\n<dt>Malmheden M. (2007):</dt>\n<dd> <a href=\"http://www.control.lth.se/documents/2007/5808.pdf\">\n      ModeGraph - A Mode-Automata-Based Modelica Library for Embedded Control</a>.\n      Master thesis, Department of Automatic Control, Lund University, Sweden.<br>&nbsp;\n     </dd>\n\n<dt>Malmheden M., Elmqvist H., Mattsson S.E., Henrisson D., Otter M. (2008):</dt>\n<dd> <a href=\"https://www.modelica.org/events/modelica2008/Proceedings/sessions/session3a3.pdf\">\n      ModeGraph - A Modelica Library for Embedded Control based on Mode-Automata</a>.\n      Modelica'2008 Conference, March 3-4, 2008.<br>&nbsp;\n     </dd>\n\n<dt>Maraninchi F., R&eacute;mond, Y. (2002):</dt>\n<dd> <a href=\"http://dx.doi.org/10.1016/S0167-6423(02)00093-X\">Mode-Automata:\n     A New Domain-Specific Construct for the Development of Safe Critical Systems</a>.<br>&nbsp;\n     </dd>\n\n<dt>Mosterman P., Otter M., Elmqvist H. (1998):</dt>\n<dd><a href=\"https://www.modelica.org/publications/papers/scsc98fp.pdf\">\n     Modeling Petri Nets as Local Constraint Equations for\n     Hybrid Systems using Modelica</a>.\n     SCSC'98, Reno, Nevada, USA,\n     Society for Computer Simulation International, pp. 314-319, 1998.<br>&nbsp;\n     </dd>\n\n<dt>Otter M., Malmheden M., Elmqvist H., Mattsson S.E., Johnsson C. (2009):</dt>\n<dd> <a href=\"https://www.modelica.org/events/modelica2009\">\n     A New Formalism for Modeling of Reactive and Hybrid Systems</a>.\n      Modelica'2009 Conference, Como, Italy, Sept. 20-22, 2009.\n     </dd>\n</dl>\n\n</html>"));
end ComparisonWithStateGraph2;