Algorithms Library Toolkit
A toolkit for algorithms, especially for algorithms on formal languages
VisiblyPushdownNPDA.h
Go to the documentation of this file.
1
6/*
7 * This file is part of Algorithms library toolkit.
8 * Copyright (C) 2017 Jan Travnicek (jan.travnicek@fit.cvut.cz)
9
10 * Algorithms library toolkit is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
14
15 * Algorithms library toolkit is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19
20 * You should have received a copy of the GNU General Public License
21 * along with Algorithms library toolkit. If not, see <http://www.gnu.org/licenses/>.
22 */
23
24#pragma once
25
26#include <core/xmlApi.hpp>
28#include "../common/AutomatonFromXMLParser.h"
29#include "../common/AutomatonToXMLComposer.h"
30
31namespace core {
32
33template < class InputSymbolType, class PushdownStoreSymbolType, class StateType >
34struct xmlApi < automaton::VisiblyPushdownNPDA < InputSymbolType, PushdownStoreSymbolType, StateType > > {
42 static std::string xmlTagName() {
43 return "VisiblyPushdownNPDA";
44 }
45
53 static bool first ( const ext::deque < sax::Token >::const_iterator & input ) {
55 }
56
65
73
81
89};
90
91template < class InputSymbolType, class PushdownStoreSymbolType, class StateType >
94
95 ext::set<StateType> states = automaton::AutomatonFromXMLParser::parseStates<StateType>(input);
96 ext::set<InputSymbolType> callInputAlphabet = automaton::AutomatonFromXMLParser::parseCallInputAlphabet<InputSymbolType>(input);
97 ext::set<InputSymbolType> returnInputAlphabet = automaton::AutomatonFromXMLParser::parseReturnInputAlphabet<InputSymbolType>(input);
98 ext::set<InputSymbolType> localInputAlphabet = automaton::AutomatonFromXMLParser::parseLocalInputAlphabet<InputSymbolType>(input);
99 ext::set<PushdownStoreSymbolType> stackSymbols = automaton::AutomatonFromXMLParser::parsePushdownStoreAlphabet<PushdownStoreSymbolType>(input);
100 ext::set<StateType> initialStates = automaton::AutomatonFromXMLParser::parseInitialStates<StateType>(input);
101 PushdownStoreSymbolType bottomOfTheStackSymbol = automaton::AutomatonFromXMLParser::parseBottomOfTheStackSymbol<PushdownStoreSymbolType>(input);
102 ext::set<StateType> finalStates = automaton::AutomatonFromXMLParser::parseFinalStates<StateType>(input);
103
105 automaton.setStates(std::move(states));
106 automaton.setCallInputAlphabet(std::move(callInputAlphabet));
107 automaton.setReturnInputAlphabet(std::move(returnInputAlphabet));
108 automaton.setLocalInputAlphabet(std::move(localInputAlphabet));
109 automaton.setPushdownStoreAlphabet(std::move(stackSymbols));
110 automaton.setInitialStates(std::move(initialStates));
111 automaton.setFinalStates(std::move(finalStates));
112
114
116 return automaton;
117}
118
119template < class InputSymbolType, class PushdownStoreSymbolType, class StateType >
123 StateType from = automaton::AutomatonFromXMLParser::parseTransitionFrom<StateType>(input);
124 InputSymbolType inputSymbol = automaton::AutomatonFromXMLParser::parseTransitionInputSymbol < InputSymbolType > ( input );
125 StateType to = automaton::AutomatonFromXMLParser::parseTransitionTo<StateType>(input);
126 PushdownStoreSymbolType push = automaton::AutomatonFromXMLParser::parseTransitionSinglePush<PushdownStoreSymbolType>(input);
127
128 automaton.addCallTransition(std::move(from), std::move(inputSymbol), std::move(to), std::move(push));
130 } else if(sax::FromXMLParserHelper::isToken(input, sax::Token::TokenType::START_ELEMENT, "returnTransition")) {
132 StateType from = automaton::AutomatonFromXMLParser::parseTransitionFrom<StateType>(input);
133 InputSymbolType inputSymbol = automaton::AutomatonFromXMLParser::parseTransitionInputSymbol < InputSymbolType > ( input );
134 PushdownStoreSymbolType pop = automaton::AutomatonFromXMLParser::parseTransitionSinglePop<PushdownStoreSymbolType>(input);
135 StateType to = automaton::AutomatonFromXMLParser::parseTransitionTo<StateType>(input);
136
137 automaton.addReturnTransition(std::move(from), std::move(inputSymbol), std::move(pop), std::move(to));
139 } else {
141 StateType from = automaton::AutomatonFromXMLParser::parseTransitionFrom<StateType>(input);
142 InputSymbolType inputSymbol = automaton::AutomatonFromXMLParser::parseTransitionInputSymbol < InputSymbolType > ( input );
143 StateType to = automaton::AutomatonFromXMLParser::parseTransitionTo<StateType>(input);
144
145 automaton.addLocalTransition(std::move(from), std::move(inputSymbol), std::move(to));
147 }
148}
149
150template < class InputSymbolType, class PushdownStoreSymbolType, class StateType >
152 out.emplace_back ( xmlTagName ( ), sax::Token::TokenType::START_ELEMENT );
153
162 composeTransitions ( out, automaton );
163
164 out.emplace_back ( xmlTagName ( ), sax::Token::TokenType::END_ELEMENT );
165}
166
167template < class InputSymbolType, class PushdownStoreSymbolType, class StateType >
169 out.emplace_back("transitions", sax::Token::TokenType::START_ELEMENT);
170 for(const auto& transition : automaton.getCallTransitions()) {
171 out.emplace_back("callTransition", sax::Token::TokenType::START_ELEMENT);
172
175 automaton::AutomatonToXMLComposer::composeTransitionTo(out, transition.second.first);
177
178 out.emplace_back("callTransition", sax::Token::TokenType::END_ELEMENT);
179 }
180 for(const auto& transition : automaton.getReturnTransitions()) {
181 out.emplace_back("returnTransition", sax::Token::TokenType::START_ELEMENT);
182
183 automaton::AutomatonToXMLComposer::composeTransitionFrom(out, std::get<0>(transition.first));
184 automaton::AutomatonToXMLComposer::composeTransitionInputSymbol(out, std::get<1>(transition.first));
185 automaton::AutomatonToXMLComposer::composeTransitionSinglePop(out, std::get<2>(transition.first));
187
188 out.emplace_back("returnTransition", sax::Token::TokenType::END_ELEMENT);
189 }
190 for(const auto& transition : automaton.getLocalTransitions()) {
191 out.emplace_back("localTransition", sax::Token::TokenType::START_ELEMENT);
192
196
197 out.emplace_back("localTransition", sax::Token::TokenType::END_ELEMENT);
198 }
199 out.emplace_back("transitions", sax::Token::TokenType::END_ELEMENT);
200}
201
202} /* namespace core */
203
static void parseTransitions(ext::deque< sax::Token >::iterator &input, T &automaton)
Definition: AutomatonFromXMLParser.h:114
static void composeLocalInputAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:136
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 composeInitialStates(ext::deque< sax::Token > &, const ext::set< StateType > &states)
Definition: AutomatonToXMLComposer.h:154
static void composeTransitionSinglePush(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:309
static void composeReturnInputAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:127
static void composeTransitionSinglePop(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:293
static void composeFinalStates(ext::deque< sax::Token > &, const ext::set< StateType > &states)
Definition: AutomatonToXMLComposer.h:170
static void composeBottomOfTheStackSymbol(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:229
static void composeTransitionInputSymbol(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:316
static void composePushdownStoreAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:179
static void composeCallInputAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:118
Nondeterministic visibly pushdown automaton. Accepts subset of context free languages.
Definition: VisiblyPushdownNPDA.h:81
Class extending the deque class from the standard library. Original reason is to allow printing of th...
Definition: deque.hpp:44
Definition: set.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
Definition: ToGrammar.h:31
Definition: normalize.hpp:10
static std::string xmlTagName()
The XML tag name of class.
Definition: VisiblyPushdownNPDA.h:42
static bool first(const ext::deque< sax::Token >::const_iterator &input)
Tests whether the token stream starts with this type.
Definition: VisiblyPushdownNPDA.h:53
Definition: xmlApi.hpp:27