Releases: LearnLib/automatalib
automatalib-0.11.0
Added
- Added the incremental
AdaptiveMealyBuilder
that allows for overriding previous traces (#56, thanks to @tiferrei). - Added modal transition systems (MTSs) including related utilities such as composition, conjunction, refinement (thanks to @mjasper, @Conturing, and @dvs23).
- Added the M3C model-checker for verifying µ-calculus and CTL formulas on context-free modal process systems (thanks to @AlnisM).
- Added the ability to M3C to generate witnesses for negated safety properties (thanks to @Viperish-byte).
- Added support for procedural systems (SPAs, SBA, SPMMs) as well as related concepts such as verification, testing, and transformations thereof (thanks to @mtf90).
- Added
SubsequentialTransducer
interface and implementations/utilities (thanks to @mtf90).
Changed
- Refactorings
-
Many AutomataLib packages have been refactored from plural-based keywords to singular-based keywords. Some examples are
- renamed
net.automatalib.automata.*
tonet.automatalib.automaton.*
. - renamed
net.automatalib.automata.concepts.*
tonet.automatalib.automaton.concept.*
. - renamed
net.automatalib.automata.graphs.*
tonet.automatalib.automaton.graph.*
. - renamed
net.automatalib.automata.helpers.*
tonet.automatalib.automaton.helper.*
. - renamed
net.automatalib.automata.transducers.*
tonet.automatalib.automaton.transducer.*
. - renamed
net.automatalib.graphs.*
tonet.automatalib.graph.*
. - renamed
net.automatalib.graph.concepts.*
tonet.automatalib.graph.concept.*
. - renamed
net.automatalib.graph.helpers.*
tonet.automatalib.graph.helper.*
. - renamed
net.automatalib.ts.acceptors.*
tonet.automatalib.ts.acceptor.*
. - renamed
net.automatalib.settignssources.*
tonet.automatalib.settingsource.*
. - renamed
net.automatalib.words.*
tonet.automatalib.word.*
. - renamed
net.automatalib.commons.smartcollections.*
tonet.automatalib.common.smartcollection.*
. - renamed
net.automatalib.commons.util.*
tonet.automatalib.common.util.*
. - renamed
net.automatalib.modelcheckers.*
tonet.automatalib.modelchecker.*
. - renamed
net.automatalib.util.automata.*
tonet.automatalib.util.automaton.*
. - etc.
While this may cause some refactoring, it should only affect import statements as the names of most classes remain identical.
- renamed
-
Some actual re-namings concern
- all code around visibly push-down automata which now uses the "vpa" acronym (previously "vpda"). This includes package names, class names and (Maven) module names.
- many of the
automata-core
packages have been aligned with their correspondingautomata-api
ones which often results in dropping the.impl
or.compact
sub-packages. Alphabet
-related code which has been moved from thenet.automatlib.word
package to thenet.automatalib.alphabet
package.net.automatalib.automata.transducers.impl.compact.CompactMealyTransition
->net.automatalib.automaton.CompactTransition
.net.automatalib.commons.util.BitSetIterator
->net.automatalib.common.util.collection.BitSetIterator
.net.automatalib.graphs.base.compact.AbstractCompactGraph#getNodeProperties(int)
->net.automatalib.graph.base.AbstractCompactGraph#getNodeProperty(int)
.net.automatalib.graphs.FiniteKTS
->net.automatalib.ts.FiniteKTS
andFiniteKTS
no longer extends theGraph
interface but theAutomaton
interface and has its type variables re-ordered.net.automatalib.graphs.FiniteLTS
->net.automatalib.graph.FiniteLabeledGraph
.GraphTraversal#dfIterator
->GraphTraversal#depthFirstIterator
.- moved the
net.automatalib.incremental.mealy.dynamic.*
classes tonet.automatalib.incremental.mealy
. - moved the
net.automatalib.settingssource.*
classes tonet.automatalib
. - moved
SupportsGrowingAlphabet
class tonet.automatalib.alphabet
. - moved the package
net.automatalib.ts.comp
tonet.automatalib.util.ts.comp
in theautomata-util
module. - moved
TS#bfs{Order,Iterator}
toTSTraversal#breadthFirst{Order,Iterator}
.
-
AbstractOneSEVPA
no longer implements theGraph
interface, butSEVPA
s are nowGraphViewable
.- The
automata-dot-visualizer
module has been refactored and many Swing-related classes have been made package-private. TheDOT
class is now the central factory class to access the functionality of the module. The previousDOTFrame
(whose functionality is now accessible via, e.g.,DOT#renderDOTStrings
) is now based on aJDialog
which offers blocking modal semantics (e.g., for debugging purposes). - The
{Deterministc,NearLinear}EquivalenceTest
classes have become factories that cannot be instantiated anymore and only offer static methods. Graph
'sadjacentTarget{,Iterator}
(and related) methods have been renamed togetAdjacentNodes{,Iterator}
.- Many classes of the
automata-incremental
artifact have been cleaned up to no longer expose internal classes in public interfaces. - The
Indefinite{,Simple}Graph
classes no longer haveCollection
-based getters butIterable
-based ones since indefinite structures typically cannot specify sizes. TheCollection
-based getters are delegated to theGraph
class. Minimizer
no longer provides agetInstance()
method but can be instantiated directly.- The
OneSEVPA
interface has been generalized to an arbitrary (k-)SEVPA
interface. The oldOneSEVPA
specialization is still available and unchanged. - The
OneSEVPAUtils
class has been merged into theOneSEVPAs
class. - The
RandomUtil
class has been made a factory (non-instantiable, only static methods) and its methods now require the random object as first parameter. - AutomataLib classes no longer implement
Serializable
. We never fully supported the semantics of the interface and never intended to do so. In fact, the old approach failed miserably if any class was involved where we missed an "implements Serializable" statement. In order to prevent confusion by promising false contracts, implementing this markup interface has been removed. Serialization should now be done in user-land via one of the many external (and more optimizable) serialization frameworks such as FST, XStream, etc. ShortestPaths
now offers fewer but less confusing methods. Previously there were methods such asshortestPath
that took an initial node and multiple target nodes which much better fits to the idea of computingshortestPath*s*
rather than any shortest path to one of the target nodes. The old behavior can still be replicated with the genericPredicate
-based versions.StrictPriorityQueue
is now package-private as it is only meant for internal use.Symbol
now has a type-safe user object and id-basedhashcode
/equals
semantics.
Removed
- Removed the (package-private) classes
net.automatalib.util.automata.predicates.{AcceptanceStatePredicate,OutputSatisfies,TransitionPropertySatisfies}
. - Removed the
IndefiniteSimpleGraph#asNormalGraph()
method. Existing code should not need the transformation. - Removed
AbstractCompactNPGraph
, useAbstractCompactGraph
instead. - Removed
AbstractCompactSimpleGraph
. All functionality is provided inCompactSimpleGraph
. - Removed
CmpUtil#safeComparator
. UseComparators#nullsFirst
orComparators#nullsLast
instead. - Removed
DelegateVisualizationHelper
without replacement. Instead, directly override/extend theVisualizationHelper
you want to delegate to. - Removed the DFS-specific
DFSTraversalVisitor
(and related classes) without replacement. Client-code that relied on this class can re-implement the functionality by providing an own implementation of the more generalGraphTraversalVisitor
. See the changes on theDFSExample
for reference. - Removed (unused)
DisjointSetForestInt
class without replacement. - Removed non-static methods on
RandomAutomata
factory (including thegetInstance()
method). - Removed
net.automatalib.graphs.IndefiniteLTS.java
. By naming, this class should denote aTransitionSystem
and not aGraph
structure. However, sinceTransitionSystem
s are inherently labeled, this class serves no more real purpose. To re-establish the previous functionality, simply implementGraph
andEdgeLabels
. - The
Stream
-based getters ofIndefinite{,Simple}Graph
have been removed in favor of theIterator
-based ones. - Removed (unused)
SuffixTrie
class without replacement. Similar functionality can be achieved with AutomataLib's incremental module. - The
automata-dot-visualizer
module has been refactored and many Swing-related classes have been made package-private. TheDOT
class is now the central factory class to access the functionality of the module. The previousDOTFrame
(whose functionality is now accessible via, e.g.,DOT#renderDOTStrings
) is now based on aJDialog
which offers blocking modal semantics (e.g., for debugging purposes).
Fixed
- Fixed a regression in
AbstractLTSminMonitorMealy
regarding BBC (#46). - Fixed a bug in
CharacterizingSets
which ignored the semantics of acceptors, i.e., not all states of an acceptor could be distinguished solely based on acceptance. - Fixed a bug in
Covers#transitionCoverIterator
which previously included undefined transitions. - Fixed a cache consistency bug in various DAG-based incremental builders.
New Contributors
- @AlnisM made their first contribution in #47
- @tiferrei made their first contribution in #50
- @ericcccsliu made their first contribution in #52
- @MokonaNico made their first contribution in https://github.com/LearnLib/automatalib/pull...
automatalib-0.10.0
Added
- All de-serializers now can also parse GZIP'ed contents from either
InputStream
s,File
s,URL
s orbyte[]
s.
Changed
- We overhauled the handling of input and output streams for all (de-)serializers. Input and output streams are no longer closed automatically. This is to prevent asymmetric code where we would close a stream that we haven't opened. This is problematic in cases where e.g.
System.out
is passed as an output stream to simply print a serialized automaton and theSystem.out
stream would be closed afterwards. Since input and output streams are usually opened in client-code, they should be closed in client-code as well. We suggest to simply wrap calls to the serializers in a try-with-resource block. - Due to the DOT parsers rewrite (see Fixed), the attribute parsers now receive a
Map<String, String>
instead of aMap<String, Object>
. - The
State
class (used by theOneSEVPA
automaton) not longer supports the notion of a sink state. TheAbstractOneSEVPA
class now conforms with the default semantics of aDeterministicTransitionSystem
that undefined transitions simply returnnull
.
Removed
- Removed
IOUtil#copy
,IOUtil#skip
,NullOutputStream
. Use the Guava equivalents fromByteStreams
andCharStreams
.
Fixed
- Correctly enquote outputs containing whitespaces in
TAFWriter
(#37, thanks to @aschieweck) - Fixed a bug in the
Graph
representation ofAbstractOneSEVPA
s (#39, thanks to @DonatoClun) - Fixed wrong default values in the overloaded methods of the
Minimizer
class (#41). - Replaced the 3rd-party DOT parser with our own implementation to fix the issue that multi-edges between nodes were not properly handled.
automatalib-0.9.0
Added
- A new alphabet implementation
MapAlphabet
that is based on the oldSimpleAlphabet
but without implementing theGrowingAlphabet
interface. IntRangeIterator
now implementsPrimitiveIterator.OfInt
.- A parser for
dot
files has been added and is available in theautomata-serialization-dot
module via theDOTParsers
factory. - A new
PaigeTarjanMinimization
factory that offers convenience methods for PaigeTarjan-based automata minimization (with support for e.g. partial automata) has been added. - Performance improvements for some alphabet implementations (
DefaultVPDAlphabet
,ListAlphabet
,{Int,Char}Range
, ...). - An
LTSminLTLParser
to verify if LTL properties match the expected syntax of LTSmin. - A
WordCollector
for collecting words from symbolStream
s.
Changed
- Refactored the following packages/classes:
net.automatalib.words.impl.SimpleAlphabet
->net.automatalib.words.impl.GrowingMapAlphabet
net.automatalib.serialization.AutomatonSerializationException
->net.automatalib.serialization.FormatException
net.automatalib.serialization.fsm.parser.FSMParseException
->net.automatalib.serialization.fsm.parser.FSMFormatException
net.automatalib.serialization.taf.parser.TAFParseException
->net.automatalib.serialization.taf.parser.TAFFormatException
net.automatalib.automata.transducers.impl.map.SimpleMapGraph
->net.automatalib.graphs.map.SimpleMapGraph
- The
BackedGeneralPriorityQueue(Class<T> c)
constructor was replaced with a more idiomaticBackedGeneralPriorityQueue(Supplier<T> s)
constructor. - The TAF serialization code now forwards (i.e.
throws
)IOException
s that occur when reading from the various data sources. - JSR305 annotations have been replaced with checker-framework annotations.
- AutomataLib now follows checker-framework's convention that (non-annotated) types are usually considered non-null unless explicitly annotated with
@Nullable
. - AutomataLib no longer has a (runtime-) dependency on JSR305 (and other
javax.*
) annotations or includes them in the distribution artifact. This now makes AutomataLib compliant with Oracle's binary code license and allows AutomataLib artifacts as-is to be bundled in binary distributions with Oracle's JDKs/JREs.
- AutomataLib now follows checker-framework's convention that (non-annotated) types are usually considered non-null unless explicitly annotated with
Removed
StringIndexGenerator
has been removed. Its (streamlined) functionality is now available asMapping
viaMappings#stringToIndex
andMappings#indexToString
.DelegatingIterator
: If you used this class, switch to Guavas equivalentForwardingIterator
.ParameterMismatchException
: Was unused and never thrown.StateIDDynamicMapping
: Equivalent functionality is provided byArrayMapping
.ResizingIntArray
: Internal data structure was unused.- The
VPDAlphabet
interface no longer specifies theget{Internal,Call,Return}Symbols()
methods, as theget{Internal,Call,Return}Alphabet()
methods supersede their functionality. PaigeTarjan{Initializers,Extractors}
methods for nonIntAbstraction
s have been removed. You may use the new convenience methods provided byPaigeTarjanMinimization
.- Further
@Deprecated
methods have been removed. - Removed
ProbMealyTransition
and replaced it with the genericMealyTransition
directly carrying theProbabilisticOutput
. It is no longer allowed to passnull
as transition property. - Removed
OutputAndLocalInputs
,StateLocalInputIncrementalMealyTreeBuilder
andStateLocalInputMealyUtil
. The (LearnLib) code related to inferring partial Mealy machines no longer requires these transformed automata. Whoever used this code for transforming a partial Mealy machine to a complete one, may useMealyMachines#complete
instead.
Fixed
- Fixed a bug, where the PaigeTarjan-based minimization would return a wrong automaton when pruning was enabled and the initial automaton was partial.
- Fixed a bug in our Tarjan SCC implementation (#35, thanks to Malte Mues)
- Fixed a bug in the computation of characterizing sets (#36).
- Several (null-related) bugs detected by our ongoing efforts to write tests.
automatalib-0.8.0
Added
- Added support for model checking automata using the LTSmin model checker (thanks to Jeroen Meijer).
- Added a
CompactMoore
implementation. - Added an
AutomatonBuilder
for Moore Machines. - Added support for adding input symbols to incremental constructions (tree caches, DAG caches).
- Support for Java 11. Note: AutomataLib still targets Java 8, and thus needs classes provided by this environment (specifically: annotations from
javax.annotation
). If you plan to use AutomataLib in a Java 11+ environment, make sure to provide these classes. They are not shipped with AutomataLib.
Changed
- Refactored the following packages/classes:
net.automatalib.automata.transout
->net.automatalib.automata.transducers
net.automatalib.ts.transout
->net.automatalib.ts.output
net.automatalib.util.automata.transout
->net.automatalib.util.automata.transducers
net.automatalib.automata.GrowableAlphabetAutomaton
->net.automatalib.SupportsGrowingAlphabet
- Some runtime properties for dynamically configuring AutomataLib have been renamed. There now exists the
AutomataLibProperty
enum as a single reference point for all available properties. - Several of the
AbstractCompact*
automata classes have been refactored to share common functionality. While this shouldn't affect its implementations (such asCompactDFA
orCompactMealy
) user-land code using the abstract classes may break. - The
BricsDFA
wrapper previously allowed (via a boolean flag) to trigger determinization of the BRICS automaton. This determinization is now performed automatically if necessary. Instead the boolean flag now triggers a totalization of the transition function, which allows to properly useBricsDFA
s in structural equivalence tests (as BRICS automata do not allow to limit their input alphabet to certain characters). - Adding new symbols to automata (via the
SupportsGrowingAlphabet
interface) now requires the automaton to be initialized with aGrowingAlphabet
instance. This is to make sure that the user has full control over which alphabet instance should be used instead of AutomataLib making decisions on behalf of the user.
Removed
- The mutable
Pair
class has been removed. The previously immutable pair classIPair
has been renamed toPair
. - Some utility classes and functions (especially from the
automata-common-util
package) have been removed without replacement, since equivalent functionality is provided by the Google Guava library we depend on. If you used any of this code, switch to the Guava equivalent. RichArray
has been removed. At least regarding storage,ArrayStorage
can be used as a replacement.SymbolHidingAlphabet
has been removed without replacement. Changes to the logic of adding new input symbols should no longer make this class necessary.
Fixed
- Serializers now use platform dependent newlines. This shouldn't affect deserialization code.
- Several bugs detected by our ongoing efforts to write tests.
automatalib-0.7.1
Added
- Added
SymbolHidingAlphabet
, which is required for a bugfix release of LearnLib.
Fixed
- Fixed an issue where initial states were not copied in copy-constructor of NFAs.
- Fixed an NPE when traversing partially defined NFAs.
- Fixed an issue, where input alphabets were unnecessarily wrapped in
SimpleAlphabet
s in compact automata implementations. - Fixed an out-of-bounds error in incremental automata builders.
- Fixed an error in Paige/Tarjan algorithm for partially defined automata.
- Fixed wrong computation of strongly connected components (see #21).
- General consolidations (typos, wrong documentation, etc.).
automatalib-0.7.0
Added
- Added algorithms for computing adaptive distinguishing sequences for Mealy machines.
- Added support for adding alphabet symbols after initial automaton construction.
- Added support for Visibly Push-Down Automata (VPDA) in form of 1-SEVPAs.
- Added (de-)serializers for the AUT format (see #14).
- Added lazy (iterator based) methods for computing state- and transition covers, W-Method and Wp-Method tests.
- Added a serializer for the SAF format.
Changed
-
Refactored the Maven artifact and Java package structure. Have a look at the List of AutomataLib Artifacts for an updated overview of available artifacts. In general, no functionality should have been removed (except of code marked with
@Deprecated
). The easiest way to migrate your code to the new version is probably by using the Auto-Import feature of your IDE of choice.The non-trivial refactorings include:
- API methods no longer use wildcards in generic return parameters. This allows your code to not having to deal with them.
- The visualization facade has been generified. Any
getGraphDOTHelper()
related code has been renamed to the more generalgetVisualizationHelper()
terminology. TheVisualization
class now works by providing either theautomata-dot-visualizer
orautomata-jung-visualizer
JAR at runtime. This allows for potentially more visualizers in the future.
-
Replaced
System.out
logging, with calls to an SLF4j facade. -
Code improvements due to employment of several static code-analysis plugins (findbugs, checkstyle, PMD, etc.) as well as setting up continuous integration at Travis CI.
Removed
- Several classes and methods annotated with
@Deprecated
.
Fixed
- Several bugs detected either by our newly employed static code-analysis toolchain or by our ongoing efforts to write tests.