Class WMethodEQOracle<I>
- java.lang.Object
-
- de.learnlib.oracle.equivalence.AbstractTestWordEQOracle<SBA<?,I>,I,Boolean>
-
- de.learnlib.oracle.equivalence.sba.WMethodEQOracle<I>
-
- Type Parameters:
I
- input symbol type
- All Implemented Interfaces:
EquivalenceOracle<SBA<?,I>,I,Boolean>
public class WMethodEQOracle<I> extends AbstractTestWordEQOracle<SBA<?,I>,I,Boolean>
AnSBA
version ofWMethodEQOracle
which generates test sequences based on theW-method
for each procedure.
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface de.learnlib.oracle.EquivalenceOracle
EquivalenceOracle.DFAEquivalenceOracle<I>, EquivalenceOracle.MealyEquivalenceOracle<I,O>, EquivalenceOracle.MooreEquivalenceOracle<I,O>
-
-
Constructor Summary
Constructors Constructor Description WMethodEQOracle(MembershipOracle<I,Boolean> sulOracle, int lookahead)
Constructor.WMethodEQOracle(MembershipOracle<I,Boolean> sulOracle, int lookahead, int expectedSize)
Constructor.WMethodEQOracle(MembershipOracle<I,Boolean> sulOracle, int lookahead, int expectedSize, int batchSize)
Constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected Stream<Word<I>>
generateTestWords(SBA<?,I> hypothesis, Collection<? extends I> inputs)
Generate the stream of test words that should be used for the current equivalence check cycle.-
Methods inherited from class de.learnlib.oracle.equivalence.AbstractTestWordEQOracle
findCounterExample
-
-
-
-
Constructor Detail
-
WMethodEQOracle
public WMethodEQOracle(MembershipOracle<I,Boolean> sulOracle, int lookahead)
Constructor. Convenience method forWMethodEQOracle(MembershipOracle, int, int)
that setsexpectedSize
to 0.- Parameters:
sulOracle
- interface to the system under learninglookahead
- the maximum length of the "middle" part of the test cases
-
WMethodEQOracle
public WMethodEQOracle(MembershipOracle<I,Boolean> sulOracle, int lookahead, int expectedSize)
Constructor. Convenience method forWMethodEQOracle(MembershipOracle, int, int, int)
that setsbatchSize
to 1.- Parameters:
sulOracle
- interface to the system under learninglookahead
- the (minimal) maximum length of the "middle" part of the test casesexpectedSize
- the expected size of the system under learning
-
WMethodEQOracle
public WMethodEQOracle(MembershipOracle<I,Boolean> sulOracle, int lookahead, int expectedSize, int batchSize)
Constructor. UsesMath.max
(lookahead, expectedSize -
hypothesis.size()
)
to determine the maximum length of sequences, that should be appended to the transition-cover part of the test sequence to account for the fact that the system under learning may have more states than the current hypothesis.- Parameters:
sulOracle
- interface to the system under learninglookahead
- the (minimal) maximum length of the "middle" part of the test casesexpectedSize
- the expected size of the system under learningbatchSize
- size of the batches sent to the membership oracle- See Also:
WMethodTestsIterator
-
-
Method Detail
-
generateTestWords
protected Stream<Word<I>> generateTestWords(SBA<?,I> hypothesis, Collection<? extends I> inputs)
Description copied from class:AbstractTestWordEQOracle
Generate the stream of test words that should be used for the current equivalence check cycle.- Specified by:
generateTestWords
in classAbstractTestWordEQOracle<SBA<?,I>,I,Boolean>
- Parameters:
hypothesis
- the current hypothesis of the learning algorithminputs
- the collection of inputs to consider- Returns:
- the stream of test words used for equivalence testing
- See Also:
EquivalenceOracle.findCounterExample(Object, Collection)
-
-