- Added support for input of a Hanoi Omega Automaton (HOA) rather than an LTL formula. Use this feature by passing --hoa instead --ltl and providing a TGBA or Buchi automaton in this format.
- Added support for Sentential Decision Diagrams (SDDs). Use this feature by setting the command line parameter --vset=sdd when running, e.g., dve2lts-sym.
- Improvements to the symbolic back-end (*lts-sym):
- The ProB front-end now allows low level parallel decision diagram operations when using Sylvan.
- A parallel saturation algorithm is now available.
- Great refactor of the symbolic back-end to make it more accessible to developers.
- Build completely static Linux binaries.
- Add support for Windows.
- Fix an issue where libxml2 was unnecessarily made a mandatory dependency.
- Fix an issue on macOS where libxml2 is not detected correctly.
-
Improvements to the symbolic back-end (*2lts-sym):
- Precise counting of sets using the bignum interface. Meaning you can now print the size of a set arbitrarily large without loss of precision.
- Add feature that allows counting the size of a set using long doubles (in addition to doubles). The symbolic back-end will automatically switch to long doubles when necessary.
- Add option --next-union that computes the application of a transition relation together with the identity.
- The symbolic back-end is now capable of invariant checking.
- Multiple formulas, invariants are now supported through their respective commandline options. If LACE is used, these properties will be checked in parallel.
- It is now possible to output all Sylvan statistics, such as the size of the node table, number of GCs etc.
- Add option --mu-opt that enables a faster mu-calculus model checker.
- Sylvan's LDDmc is now the default decision diagram package.
-
Improvements to the static variable ordering:
- Invert the permutation of rows/columns (transition groups/state variables) using options --regroup=hf --regroup=vf respectively.
- Transformations on the dependency matrix ignore read dependencies, since write dependencies seem to influence the actual size of Decision Diagrams to a much greater extent.
- Add option --col-ins (see manpage) that can pick a column/state variable and insert it at a specific index.
- A vast amount of static variable reordering algorithms have been added available through Boost and ViennaCL. Furthermore the FORCE algorithm and Noack's algorithms have been implemented, see [1]. In addition to these algorithms metrics related to the quality of the static variable order can be shown with option --regroup=mm.
- A manual group/variable order can now be given with --row-perm/--col-perm respectively.
-
Improvements to the LTSmin language (see
man ltsmin-pred
):- Added the enabledness operator
??
to the LTSMin language, seeman ltsmin-pred
. - Native LTSmin support for signed 32-bit integers is added, including some basic arithmatic operators.
- Added a type format checker.
- Added the enabledness operator
-
A new Petri net front-end has been added to LTSmin, see [2]. The front-end reads Petri nets in the PNML format.
-
A front-end for B, Event-B CSP, and Z is now available through ProB, see [3].
-
The mCRL2 front-end now accepts files with .txt extension.
-
Added support for SPOT's LTL to Büchi translation [5]
-
Improvements to the multi-core backend (*2lts-mc):
- Added a parallel Strongly Connected Components algorithm [4] (--strategy=ufscc).
- Added Renault's parallel SCC algorithm (--strategy=renault).
- Added support for transition-based general büchi automata (TGBAs) via UFSCC/Renault and SPOT.
- Added Bosnacki's closed-set proviso to preserve safety under POR.
- Support for weak LTS formulae in DFS-FIFO. Simply combine --ltl with --strategy=dfsfifo to benefit from this highly scalable algorithm (if the property is not weak, an error is raised).
- Support for tracing in DFS-FIFO and all new SCC algorithms.
-
Improvements to the PINS interface:
- A new PINS2PINS layer is added that checks the validity of dependency matrices. The option --check activates the layer. By default, all read/write matrices are checked. When partial-order reduction (--por) is used, then the POR matrices are checked as well via an expensive reachability over the unreduced state space (because commutativity should hold in all futures).
- Added experimental support for leaping partial-order reduction. Leap sets sequentially combine multiple disjoint POR sets to 'leap' through the state space (--leap in combination with --por).
- Add GBExit function that is called before a back-end exits.
- Factored out chunk tables and other functionality from pins.c.
- Add functions GB<set|get>VarPerm and GB<set|get>GroupPerm that allows language front-ends to provide permutations. This is useful when front-ends have language specific algorithms for static variable reordering.
-
Miscellaneous:
- All default autoconf files such as README, NEWS are moved to *.md and sym-linked to their old file names. The markdown styling works better with Github.
- Major refactor to the PINS regrouping layer, simplifying its use for developers.
- LTSmin now uses Travis CI.
- LTSmin now fully supports the Windows platform, since CygWin is available in 64 bit.
- Bandwidth and Wavefront Reduction for Static Variable Ordering in Symbolic Reachability Analysis - http://dx.doi.org/10.1007/978-3-319-40648-0_20
- Complete Results for the 2016 Edition of the Model Checking Contest - http://mcc.lip6.fr/
- Symbolic Reachability Analysis of B Through ProB and LTSmin - http://dx.doi.org/10.1007/978-3-319-33693-0_18
- Multi-Core On-The-Fly SCC Decomposition - http://eprints.eemcs.utwente.nl/26873/
- Multi-core SCC-Based LTL Model Checking http://dx.doi.org/10.1007/978-3-319-49052-6_2
This release is accompanied by the tool paper: LTSmin: High-Performance Language-Independent Model Checking [6].
-
Improvements to symbolic backend (*2lts-sym):
- Parallelized transition relatioBandwidth and Wavefront Reduction for Static Variable Ordering in Symbolic Reachability Analysisn learning and application using Lace [5]
- Exploiting read, write and copy dependencies [3]
- Parallelized guard learning and application (--pins-guards, --no-soundness-check) [1]
- Improved regrouping algorithm for bandwidth reduction (-rcw)
- New parallel MDD implementation from the Sylvan package: LDDmc (--vset=lddmc) [5,7]
- Support maximal progress for probabilistic LTSs
-
New mu-calculus PINS layer (--mucalc):
- Enables verification of mu-calculus properties for any of the supported languages and all backends
- A parity game is generated (instead of an LTS), which can be solved with --pg-solve in the symbolic tool, or with any parity game solver that supports the pgsolver format.
-
Symbolic Parity game solver (--pg-solve, spgsolver) [4]:
- Added parallel attractor computation (--attr=par)
-
New frontend for MAPA: Scoop (mapa2lts{sym,dist})
-
New frontend for dl-open (pins2*):
- Example can be found in section 3.4 in [6].
-
Improvements to the POR layer (PINS2PINS wrapper):
- Added Valmari's weak POR dependencies (--weak)
- Added deletion algorithm [1] (--por=del)
- Added Valmari's SCC-based algorithm (--por=scc)
-
Improvements to the multi-core backend (*2lts-mc):
- Added CNDFS proviso for efficient POR in LTL (--proviso=cndfs) [2]
- Refactored code and separated search algorithms in objects
-
Improvements to distributed backend (*2lts-dist):
- Added counter example tracing
- Tau confluence detection
- Support maximal progress for probabilistic LTSs
- Guard-based Partial-Order Reduction (Extended Version) - http://dx.doi.org/10.1007/s10009-014-0363-9
- Partial-Order Reduction for Multi-Core LTL Model Checking - http://dx.doi.org/10.1007/978-3-319-13338-6_20
- Read, Write and Copy Dependencies for Symbolic Model Checking - http://dx.doi.org/10.1007/978-3-319-13338-6_16
- Generating and Solving Symbolic Parity Games - http://dx.doi.org/10.4204/EPTCS.159.2
- Lace: non-blocking split deque for work-stealing - http://dx.doi.org/10.1007/978-3-319-14313-2_18
- LTSmin: High-Performance Language-Independent Model Checking - http://wwwhome.ewi.utwente.nl/~meijerjjg/LTSmin_High-performance_Language-Independent_Model_Checking.pdf
- Sylvan: Multi-core Decision Diagrams - http://www.tvandijk.nl/wp-content/uploads/2015/01/sylvan_tacas15.pdf
- Refactored runtime and IO libraries, organized source and renamed tools:
- *-reach -> *2lts-sym (Symbolic CTL/mu model checking, ETF output)
- *2lts-mc -- *2lts-mc (Multi-core LTL model checking, compression)
- *2lts-mpi -> *2lts-dist (Distributed LTS generation, LTS output)
- *2lts-gsea -> *2lts-seq (Sequential POR, LTL, LTS gen., BDD storage)
- *2lts-grey -- REMOVED (Old sequential tool)
- lts-compare -- NEW (Branching/Strong bisim. equivalence check)
- ltsmin-tracepp-> ltsmin-printtrace (Trace pretty printing)
- ltsmin(-mpi) -> ltsmin-reduce(-dist) (LTS minimization:LTSmin's origin)
- ltstrans -> lts-convert (LTS file format conversion)
- New parallel BDD package: Sylvan [1,2]
- BDD operations are parallelized using the Wool framework (included)
- Use: *2lts-sym --vset=sylvan *2lts-seq --state=vset --vset=sylvan
- New frontend for UPPAAL xml timed automata via opaal [10] (only opaal2lts-mc).
This adds semi-symbolic states and inclusion checks to PINS [3]:
- Multi-core reachability on timed automata using inclusion abstraction
- Supports all multi-core features, including NDFS with abstraction [4]
- Added a strict BFS algorithm [3] to reduce abstracted state counts (--strategy=sbfs, default for opaal)
- New frontend for PBESs generating parity games for the symbolic solver [5]:
- All backends: pbes2lts-sym, pbes2lts-mc, pbes2lts-dist, and pbes2lts-seq
- Added a symbolic parity game solver: spgsolver
- PGSolver file output format ('{ast}.pg')
- Extensions to the multi-core backend (*2lts-mc):
- Support for muCRL/mCRL2/PBES using processes ({lpo,lps,pbes}2lts-mc)
- Added CNDFS algorithm [6]
- Added OWCTY algorithm [11] in the multi-core backends
- Added DFS_FIFO algorithm for parallel livelock detection using POR [7]
- Added strict BFS algorithms (--strategy=sbfs,pbfs, see [3,12])
- Elementary support for writing LTSs (using pbfs) and POR (single core)
- Renamed SpinJa to SpinS [8], and added:
- Valid end-state filter, assertions (--action=assert) and never claims
- Guards and dependencies for POR
- Support for Java 1.5 and VMs from different vendors (previously JDK 1.7)
- Optimized multi-core data structures (mc-lib):
- Reduced initialization times by using calloc instead of malloc+memset
- Reduced tree memory usage by 50% by splitting table for roots and leafs. Set the relative ratio using: --ratio=n (n=2 by default)
- Parallel Cleary tree (--state=cleary-tree) halving memory usage [9,8]
- Reduced memoized hash sizes to 16 bit
- Thread-local allocation for better NUMA performance
- New load balancer with simplified interface
- Added test suite, called via 'make check' (requires DejaGNU)
- Multi-Core BDD Operations for Symbolic Reachability - http://eprints.eemcs.utwente.nl/22166/
- Multi-core and/or Symbolic Model Checking - http://eprints.eemcs.utwente.nl/22550/
- Multi-Core Reachability for Timed Automata - http://eprints.eemcs.utwente.nl/21972/
- Multi-Core Emptiness Checking of Timed Buchi Automata using Inclusion Abstraction - http://eprints.eemcs.utwente.nl/23158
- Efficient Instantiation of Parameterised Boolean Equations Systems to Parity Games - http://eprints.eemcs.utwente.nl/22278/
- Improved Multi-Core Nested Depth First Search - http://eprints.eemcs.utwente.nl/21967/
- Improved On-The-Fly Livelock Detection - http://eprints.eemcs.utwente.nl/23159
- SpinS: Extending LTSmin with Promela via SpinJa - http://eprints.eemcs.utwente.nl/22042/
- A Parallel Compact Hash Table - http://eprints.eemcs.utwente.nl/20648/
- opaal: https://code.launchpad.net/~opaal-developers/opaal/opaal-ltsmin-succgen
- J. Barnat et al. - A Time-Optimal On-the-Fly parallel algorithm for model checking of weak LTL properties
- G.J. Holzmann - Parallelizing the Spin Model Checker
- Implementation of Evangelista et al.'s parallel NDFS and variations, see: http://eprints.eemcs.utwente.nl/20618/ (Variations on Multi-Core NDFS)
- Native implementations of Ciardo et al.'s saturation algorithms for AtermDD and ListDD (-reach --saturation=sat) (Tien-Loong Siaw)
- Dependency matrix regrouping using simulated annealing (-rgsa, -rcsa)
- SpinJa support for channel operations, run expressions with arguments, and preprocessor defines
- New experimental I/O library and run-time environment
- New tools employing the new I/O library and run-time environment: o lts-tracepp for pretty printing traces o sigmin-mpi for distributed reduction of labeled transition systems o sigmin-one for sequential reduction of labeled transition systems o ltstrans for conversion of labeled transition systems o ltscmp-one for sequential comparison of labeled transition systems o 2lts-hre for distributed state space generation
- Fix for Multi-Core NDFS algorithm: introduced wait counter (2lts-mc)
- Introduced/improved color counters and option no-all-red (2lts-mc)
- New tools 2lts-gsea (General State Exploring Algorithms)
- PINS LTL layer
- Several multi-core LTL search algorithms (2lts-mc)
- Several sequential LTL search algorithms (2lts-grey, 2lts-gsea)
- PINS Partial-Order Reduction Layer (2lts-gsea)
- Bare-bones symbolic model checker for state-based mu-calculus
- New SpinJa frontend
- Patched DiVinE 2.4 frontend required
- Reimplementation of mcrl2 PINS frontend
- Read/Write dependency matrices and combined printing
- Vector set improvements and clean-up
- Connection to the libDDD decision diagram package
- Conversion from ETF to DVE (etf-convert)
- New frontend DVE2 (requires DiVinE 2.2)
- Enumerative Multi-Core backend (2lts-mc)
- Multi-Core TreeDBS compression for state vectors (2lts-mc)
- Finding error actions symbolically (-reach --action)
- Symbolic saturation-like strategies
- Faster trace generation for -reach
- BDD reordering for BuDDy vset
- New frontend DVE (requires DiVinE-cluster)
- Bignum support for state counts in spec-reach tools (Jeroen Ketema)
- spec-reach clean-up
- 'tree' vector set implementation based on AtermDD
- New tool ce-mpi for distributed cycle elimination (Simona Orzan)
- New tool ltsmin-tracepp for pretty-printing traces to deadlock states
- TorX support factored out into separate tools {lpo,lps,nips}2torx
- Enumerative DFS support
- Enumerative deadlock detection and trace output
- Reworked ETF support (non-backwards compatible)
- bash completion for LTSmin tools (see contrib/)
- Regrouping optimizations of the PINS matrix
- Connection to the CADP toolkit via pins_open
- Tuning of the BDD usage
- Significant performance improvements
- Symbolic deadlock detection and trace output
The main improvements in this release are:
- Option parsing is now performed using the popt library. Thus, all long options now start with a double minus.
- The user can choose between BuDDy and ATermDD as the decision diagram library used in the symbolic tools.
- A new compressed file format for labeled transition systems with arbitrary numbers of state and edge labels has been implemented.
- The symbolic tools can write the results of the reachability analysis in the form of an ETF (Enumerated Table Format) file. This ETF file can be used as input for the reachabilty tools and can be directly translated to DVE.