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

de.learnlib.algorithm.aaar.TranslatingMooreMachine 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;

import java.util.Collection;
import java.util.function.Function;

import de.learnlib.algorithm.aaar.abstraction.AbstractAbstractionTree;
import net.automatalib.automaton.transducer.MooreMachine;
import org.checkerframework.checker.nullness.qual.Nullable;

public class TranslatingMooreMachine implements MooreMachine {

    private final MooreMachine delegate;
    private final Function> treeFetcher;

    public TranslatingMooreMachine(MooreMachine delegate,
                                   Function> treeFetcher) {
        this.delegate = delegate;
        this.treeFetcher = treeFetcher;
    }

    @Override
    public Collection getStates() {
        return this.delegate.getStates();
    }

    @Override
    public O getStateOutput(S s) {
        return this.delegate.getStateOutput(s);
    }

    @Override
    public @Nullable T getTransition(S s, CI i) {
        final AbstractAbstractionTree tree = treeFetcher.apply(i);
        final AI ai = tree.getAbstractSymbol(i);
        final CI ci = tree.getRepresentative(ai);

        return this.delegate.getTransition(s, ci);
    }

    @Override
    public S getSuccessor(T t) {
        return this.delegate.getSuccessor(t);
    }

    @Override
    public @Nullable S getInitialState() {
        return this.delegate.getInitialState();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy