-
Notifications
You must be signed in to change notification settings - Fork 0
Uppaal Timed Automata Parser Library (forked from https://people.cs.aau.dk/~marius/utap/)
License
LGPL-2.1 and 2 other licenses found
Licenses found
LGPL-2.1
LICENSE
LGPL-2.1
COPYING
LGPL-2.1
COPYING.LIB
MASKOR/libutap
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
libutap, version 0.94 Mini HOWTO Gerd Behrmann Marius Mikucionis 1. What is libutap 2. Compiling 3. Simple use 4. Architecture 5. Contact 1. What is libutap libutap is the Uppaal Timed Automata Parser. Uppaal is an integrated tool environment for designing, simulating and verifying real time systems modeled as extended timed automata. libutap is the parser of Uppaal. libutap has the ability to parse and type check Uppaal models in any of the three file formats supported by Uppaal. libutap is licensed under the LGPL. 2. Compiling libutap uses automake and autoconf to make compilation on various platforms easy. You will need gcc 3.3 or newer, GNU make, libxml2 from http://www.xmlsoft.org (at least version 2.6.10), libsbml from http://www.sbml.org. Simply run to compile libutap and use it: ./configure make Run the following to install libutap: make install Read the INSTALL file in the distribution for more information on how to compile. NOTE: if you want to regenerate automatically created files like the configure script and Makefile, use autoreconf -i. Do *not* run autoconf directly, it will mess up your Makefile. You need autoconf version 2.53 or newer and automake. 3. Simple use There are two ways one can use the library. In its simplest form, one calls one of the top level parsing functions defined in utap/utap.h, e.g. example.cpp: #include <stdio.h> #include "utap/utap.h" int main() { UTAP::TimedAutomataSystem system; parseXMLFile("myfile.xml", &system, true); } The first argument is the file to read. The second is the output of the parser and the third is a flag indicating whether we want to use the new or the old syntax (the old syntax is the one used in Uppaal 3.4, the new is the one that will be used since Uppaal 3.6). After the call to parseXMLFile, one can access the network of timed automata in the system variable. Take a look at utap/system.h to see what kind of structures you can access. Distribution also includes pretty.cpp for pretty-printing a model files. See also doxygen API documentation in doc/api/index.html. Use the following command to compile the example: g++ example.cpp -o example -lutap -lxml2 If UTAP was configured with --prefix=$MYPATH to install in custom location then use the following to compile: g++ -I$MYPATH/include example.cpp -o example -L$MYPATH/lib -lutap -lxml2 4. Architecture The following ASCII figure shows the initial information flow through the library. +----\ | |\ | +-\ | | --> libxml2 --[SAX-interface]--> "xmlreader.cc" | .xml | | | | | +------+ | | +----\ | | |\ | | +-\ v | .ta | +--------------------------+ | .xta | -----------------------> | bison parser (parser.yy) | | | +--------------------------+ +------+ | | +------+ | | | | | TAS | | | | +---------------+ | | | <--- | SystemBuilder |<--[ParserBuilder]--/ | | +---------------+ +------+ The BNF implemented by the bison generated parser is split into several sections and to some extend duplicated for the old and new syntax. It can read .ta and .xta files directly. XML files are read using the libxml2 library. Each text-block in the XML file is then parser wrt. the BNF for that block (see xmlreader.cpp). For this, the bison generated parser is reused. The parser calls methods in the abstract ParserBuilder class. The methods in the ParserBuilder class are implemented by the SystemBuilder class which is a subclass of ExpressionBuilder which is a subclass of AbstractBuilder. The SystemBuilder writes the model to an instance of the TimedAutomataSystem (TAS) class. The design abstracts the differences between the .xml, .xta and .ta input formats and also hides the differences between the 3.4 and 3.6/4.0 formats from any implementation of the ParserBuilder interface (for equivalent input the parser will call the same methods in the ParserBuilder class). A TAS object represents the templates, variables, locations, transitions and processes of a model. Symbols are represented by symbol_t objects (see the API documentation). A symbol is a name (a string) with a type. The type is represented by a type_t object. Symbols are grouped into frames (represented by frame_t objects). Frames are used to represent scopes and other collections of symbols such as records or parameters of templates and functions. All expressions are represented using a tree structure where the leaves represent values or variables and the inner nodes represent operations. Each node is referenced using an expression_t object. 5. Contact If you have questions or comments to libutap, you can contact me on the following email address: marius@cs.aau.dk. For a list of known bugs or for reporting new bugs take a look at the UPPAAL bugzilla installation at http://www.uppaal.org/.
About
Uppaal Timed Automata Parser Library (forked from https://people.cs.aau.dk/~marius/utap/)
Resources
License
LGPL-2.1 and 2 other licenses found
Licenses found
LGPL-2.1
LICENSE
LGPL-2.1
COPYING
LGPL-2.1
COPYING.LIB
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published