All Downloads are FREE. Search and download functionalities are using the official Maven repository.

de.learnlib.algorithm.aaar.explicit.ExplicitAAARLearnerMoore Maven / Gradle / Ivy

Go to download

This artifact provides the implementation of the AAAR learning algorithm as described in the paper "Automata Learning with Automated Alphabet Abstraction Refinement" (https://dx.doi.org/10.1007/978-3-642-18275-4_19) by Falk Howar, Bernhard Steffen, and Maik Merten.

The newest version!
/* Copyright (C) 2013-2023 TU Dortmund
 * This file is part of LearnLib, http://www.learnlib.de/.
 *
 * 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 de.learnlib.algorithm.aaar.explicit;

import java.util.function.Function;

import de.learnlib.algorithm.LearnerConstructor;
import de.learnlib.algorithm.LearningAlgorithm.MooreLearner;
import de.learnlib.algorithm.aaar.ExplicitInitialAbstraction;
import de.learnlib.algorithm.aaar.TranslatingMooreMachine;
import de.learnlib.oracle.MembershipOracle;
import net.automatalib.alphabet.SupportsGrowingAlphabet;
import net.automatalib.automaton.transducer.CompactMoore;
import net.automatalib.automaton.transducer.MooreMachine;
import net.automatalib.word.Word;

/**
 * A {@link MooreLearner}-specific refinement of {@link AbstractExplicitAAARLearner}.
 *
 * @param 
 *         learner type
 * @param 
 *         abstract input symbol type
 * @param 
 *         concrete input symbol type
 * @param 
 *         output symbol type
 */
public class ExplicitAAARLearnerMoore & SupportsGrowingAlphabet, AI, CI, O>
        extends AbstractExplicitAAARLearner, MooreMachine, AI, CI, Word> {

    /**
     * Constructor.
     *
     * @param learnerConstructor
     *         the provider for constructing the internal (concrete) learner
     * @param oracle
     *         the (concrete) membership oracle
     * @param explicitInitialAbstraction
     *         the initial mapping between concrete and abstract input symbols
     * @param incrementor
     *         the function for creating new abstract input symbols given concrete one. This function only receives
     *         input symbols from the provided explicitInitialAbstraction
     */
    public ExplicitAAARLearnerMoore(LearnerConstructor> learnerConstructor,
                                    MembershipOracle> oracle,
                                    ExplicitInitialAbstraction explicitInitialAbstraction,
                                    Function incrementor) {
        super(learnerConstructor, oracle, explicitInitialAbstraction, incrementor);
    }

    @Override
    public MooreMachine getHypothesisModel() {
        final MooreMachine concrete = super.getLearnerHypothesisModel();
        final CompactMoore result = new CompactMoore<>(getAbstractAlphabet());

        super.copyAbstract(concrete, result);

        return result;
    }

    @Override
    public MooreMachine getTranslatingHypothesisModel() {
        return new TranslatingMooreMachine<>(super.getLearnerHypothesisModel(), this::getTreeForRepresentative);
    }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy