28#include "../common/AutomatonFromXMLParser.h"
29#include "../common/AutomatonToXMLComposer.h"
33template <
class SymbolType,
class StateType >
91template <
class SymbolType,
class StateType >
95 ext::set<StateType> states = automaton::AutomatonFromXMLParser::parseStates<StateType>(input);
96 ext::set<SymbolType> tapeSymbols = automaton::AutomatonFromXMLParser::parseTapeAlphabet<SymbolType>(input);
97 ext::set<SymbolType> inputSymbols = automaton::AutomatonFromXMLParser::parseInputAlphabet<SymbolType>(input);
98 SymbolType blank = automaton::AutomatonFromXMLParser::parseBlankSymbol<SymbolType>(input);
99 StateType initialState = automaton::AutomatonFromXMLParser::parseInitialState<StateType>(input);
100 ext::set<StateType> finalStates = automaton::AutomatonFromXMLParser::parseFinalStates<StateType>(input);
104 automaton.setTapeAlphabet(std::move(tapeSymbols));
105 automaton.setInputAlphabet(std::move(inputSymbols));
106 automaton.setFinalStates(std::move(finalStates));
114template<
class SymbolType,
class StateType >
117 StateType from = automaton::AutomatonFromXMLParser::parseTransitionFrom<StateType>(input);
118 SymbolType inputSymbol = automaton::AutomatonFromXMLParser::parseTransitionInputSymbol<SymbolType>(input);
119 StateType to = automaton::AutomatonFromXMLParser::parseTransitionTo<StateType>(input);
120 SymbolType outputSymbol = automaton::AutomatonFromXMLParser::parseTransitionOutputSymbol<SymbolType>(input);
124 automaton.addTransition(std::move(from), std::move(inputSymbol), std::move(to), std::move(outputSymbol), shift);
127template<
class SymbolType,
class StateType >
142template<
class SymbolType,
class StateType >
145 for(
const auto& transition :
automaton.getTransitions()) {
static Shift parseTransitionShift(ext::deque< sax::Token >::iterator &input)
Definition: AutomatonFromXMLParser.h:95
static void parseTransitions(ext::deque< sax::Token >::iterator &input, T &automaton)
Definition: AutomatonFromXMLParser.h:114
static void composeTransitionTo(ext::deque< sax::Token > &, const StateType &state)
Definition: AutomatonToXMLComposer.h:252
static void composeStates(ext::deque< sax::Token > &, const ext::set< StateType > &states)
Definition: AutomatonToXMLComposer.h:100
static void composeTransitionFrom(ext::deque< sax::Token > &, const StateType &state)
Definition: AutomatonToXMLComposer.h:259
static void composeInputAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:109
static void composeTransitionOutputSymbol(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:323
static void composeBlankSymbol(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:222
static void composeTransitionShift(ext::deque< sax::Token > &out, Shift shift)
Definition: AutomatonToXMLComposer.h:91
static void composeFinalStates(ext::deque< sax::Token > &, const ext::set< StateType > &states)
Definition: AutomatonToXMLComposer.h:170
static void composeTapeAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:213
static void composeTransitionInputSymbol(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:316
static void composeInitialState(ext::deque< sax::Token > &, const StateType &state)
Definition: AutomatonToXMLComposer.h:163
Deterministic single tape turing machine. Accepts recursive languages.
Definition: OneTapeDTM.h:71
Class extending the deque class from the standard library. Original reason is to allow printing of th...
Definition: deque.hpp:44
static void popToken(ext::deque< Token >::iterator &input, Token::TokenType type, const std::string &data)
Definition: FromXMLParserHelper.cpp:39
static bool isToken(ext::deque< Token >::const_iterator input, Token::TokenType type, const std::string &data)
Definition: FromXMLParserHelper.cpp:29
typename T::StateType StateType
Definition: ToGrammarLeftRG.h:64
typename T::SymbolType SymbolType
Definition: ReachableStates.h:176
Definition: ToGrammar.h:31
Shift
Definition: Shift.h:15
Definition: normalize.hpp:10
static std::string xmlTagName()
The XML tag name of class.
Definition: OneTapeDTM.h:42
static bool first(const ext::deque< sax::Token >::const_iterator &input)
Tests whether the token stream starts with this type.
Definition: OneTapeDTM.h:53
Definition: xmlApi.hpp:27