![JAR search and dependency download from the Maven repository](/logo.png)
net.automatalib.incremental.IncrementalConstruction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of automata-incremental Show documentation
Show all versions of automata-incremental Show documentation
A library for incremental automata construction. This artifact contains algorithms for incrementally
constructing DFAs (prefix-closed and non-prefix-closed), Mealy machines, and Moore machines from a finite,
incrementally growing set of example inputs/outputs.
/* Copyright (C) 2013 TU Dortmund
* This file is part of AutomataLib, http://www.automatalib.net/.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.automatalib.incremental;
import java.util.Collection;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.ParametersAreNonnullByDefault;
import net.automatalib.graphs.Graph;
import net.automatalib.ts.DeterministicTransitionSystem;
import net.automatalib.words.Alphabet;
import net.automatalib.words.Word;
/**
* Basic interface for incremental automata constructions. An incremental automaton construction
* creates an (acyclic) automaton by iterated insertion of example words.
*
* @author Malte Isberner
*
* @param the automaton model which is constructed
* @param input symbol class
*/
@ParametersAreNonnullByDefault
public interface IncrementalConstruction {
/**
* Retrieves the input alphabet of this construction.
* @return the input alphabet
*/
@Nonnull
public Alphabet getInputAlphabet();
/**
* Checks the current state of the construction against a given target model,
* and returns a word exposing a difference if there is one.
* @param target the target automaton model
* @param inputs the set of input symbols to consider
* @param omitUndefined if this is set to true, then undefined transitions in
* the target model will be interpreted as "unspecified/don't know" and omitted
* in the equivalence test. Otherwise, they will be interpreted in the usual manner
* (e.g., non-accepting sink in case of DFAs).
* @return a separating word, or null if no difference could be found.
*/
@Nullable
public Word findSeparatingWord(A target, Collection extends I> inputs, boolean omitUndefined);
/**
* Checks whether this class has definitive information about a given word.
* @param word the word
* @return true if this class has definitive information about the word,
* false otherwise.
*/
public boolean hasDefinitiveInformation(Word extends I> word);
/**
* Retrieves a graph view of the current state of the construction. The graph model should be
* backed by the construction, i.e., subsequent changes will be reflected in the graph model.
* @return a graph view on the current state of the construction
*/
@Nonnull
public Graph,?> asGraph();
/**
* Retrieves a transition system view of the current state of the construction. The transition
* system model should be backed by the construction, i.e., subsequent changes will be reflected in
* the transition system.
* @return a transition system view on the current state of the construction
*/
@Nonnull
public DeterministicTransitionSystem, I, ?> asTransitionSystem();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy