diff --git a/alib2data/src/automaton/PDA/RealTimeHeightDeterministicDPDA.h b/alib2data/src/automaton/PDA/RealTimeHeightDeterministicDPDA.h
index 915ddaf9181baaa326e7854a4bbed62a0550b956..c3a3f8f8677c50f02f394e91d5bb9c394ba32e7b 100644
--- a/alib2data/src/automaton/PDA/RealTimeHeightDeterministicDPDA.h
+++ b/alib2data/src/automaton/PDA/RealTimeHeightDeterministicDPDA.h
@@ -1,5 +1,21 @@
 /*
- * REAL_TIME_HEIGHT_DETERMINISTIC_DPDA.h
+ * RealTimeHeightDeterministicDPDA.h
+ *
+ * This file is part of Algorithms library toolkit.
+ * Copyright (C) 2017 Jan Travnicek (jan.travnicek@fit.cvut.cz)
+
+ * Algorithms library toolkit is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+
+ * Algorithms library toolkit is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+
+ * You should have received a copy of the GNU General Public License
+ * along with Algorithms library toolkit.  If not, see <http://www.gnu.org/licenses/>.
  *
  *  Created on: Mar 25, 2013
  *      Author: Jan Travnicek
@@ -39,237 +55,774 @@ class FinalStates;
 class InitialState;
 
 /**
- * Represents Finite Automaton.
- * Can store nondeterministic finite automaton without epsilon transitions.
+ * \brief
+ * Deterministic real time height deterministic pushdown automaton. Accepts subset of context free languages.
+
+ * \details
+ * Definition
+ * A = (Q, T, G, I, Z, \delta, F),
+ * Q (States) = nonempty finite set of states,
+ * T (TerminalAlphabet) = finite set of terminal symbols
+ * G (PushdownStoreAlphabet) = finite set of pushdown store symbol - having this empty makes the automaton equivalent to DFA
+ * I (InitialState) = initial state,
+ * Z (BottomOfTheStackSymbol) = initial pushdown store symbol
+ * \delta is split to three disjoint parts
+ *   - \delta_{call} of the form A \times a -> B \times g, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+ *   - \delta_{return} of the form A \times a \times g -> B, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+ *   - \delta_{local} of the form A \times a -> B, where A, B \in Q, a \in T \cup { \eps }
+ * F (FinalStates) = set of final states
+ *
+ * The transition functions must meet following criteria. Othervise adding conflicting transition will cause exception.
+ * $|\delta_{call} (q, a)| \leq 1$, $\forall q \in Q, a \in T \cup { \eps }$
+ * $|\delta_{return} (q, a, g)| \leq 1$, $\forall q \in Q, a \in T \cup { \eps }, g \in G$
+ * $|\delta_{local} (q, a)| \leq 1$, $\forall q \in Q, a \in T \cup { \eps }$
+ *
+ * if $|\delta_{call} (q, \eps)|$ == 1 then $|\delta_{return} (q, a, g)|$ == 0, $|\delta_{local} (q, a)|$ == 0, \forall q \in Q, a \in T \cup { \eps }, and g \in G
+ * if $|\delta_{return} (q, \eps, g)|$ == 1 then $|\delta_{call} (q, a)|$ == 0, $|\delta_{return} (q, b, g)|$ == 0, $|\delta_{local} (q, \eps)|$ == 0, \forall q \in Q, a \in T \cup { \eps }, b \in T, and g \in G
+ * if $|\delta_{local} (q, \eps)|$ == 1 then $|\delta_{call} (q, a)|$ == 0, $|\delta_{return} (q, a, g)|$ == 0, \forall q \in Q, a \in T \cup { \eps }, and g \in G
+ *
+ * if $|\delta_{call} (q, a)|$ == 1 then $|\delta_{call} (q, \eps)|$ == 0, $|\delta_{return} (q, a, g)|$ == 0, $|\delta_{return} (q, \eps, g)|$ == 0, $|\delta_{local} (q, a)|$ == 0, $|\delta_{local} (q, \eps)|$ == 0, \forall q \in Q, a \in T, and g \in G
+ * if $|\delta_{return} (q, a, g)|$ == 1 then $|\delta_{call} (q, a)|$ == 0, $|\delta_{call} (q, \eps)|$ == 0, $|\delta_{return} (q, \eps, g)|$ == 0, $|\delta_{local} (q, a)|$ == 0, $|\delta_{local} (q, \eps)|$ == 0, \forall q \in Q, a \in T, and g \in G
+ * if $|\delta_{local} (q, a)|$ == 1 then $|\delta_{call} (q, a)|$ == 0, $|\delta_{call} (q, \eps)|$ == 0, $|\delta_{return} (q, a, g)|$ == 0, $|\delta_{return} (q, \eps, g)|$ == 0, $|\delta_{local} (q, \eps)|$ == 0, \forall q \in Q, a \in T, and g \in G
+ *
+ * \tparam InputSymbolType used for the terminal alphabet
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet
+ * \tparam StateType used to the states, and the initial state of the automaton.
  */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class RealTimeHeightDeterministicDPDA final : public AutomatonBase, public core::Components < RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, ext::set < InputSymbolType >, component::Set, InputAlphabet, ext::set < PushdownStoreSymbolType >, component::Set, PushdownStoreAlphabet, PushdownStoreSymbolType, component::Value, BottomOfTheStackSymbol, ext::set < StateType >, component::Set, std::tuple < States, FinalStates >, StateType, component::Value, InitialState > {
 protected:
+	/**
+	 * Call transition function as mapping from a state times an input symbol or epsilon on the left hand side to a state times pushdown store symbol on the right hand side.
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::pair < StateType, PushdownStoreSymbolType > > callTransitions;
+
+	/**
+	 * Return transition function as mapping from a state times an input symbol or epsilon times pushdown store symbol on the left hand side to a state on the right hand side.
+	 */
 	ext::map < ext::tuple < StateType, ext::variant < EpsilonType, InputSymbolType >, PushdownStoreSymbolType >, StateType > returnTransitions;
+
+	/**
+	 * Local transition function as mapping from a state times an input symbol or epsilon on the left hand side to a state on the right hand side.
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, StateType > localTransitions;
 
 public:
+	/**
+	 * StateType template param
+	 */
 	using StateType_t = StateType;
+
+	/**
+	 * PushdownStoreSymbolType template param
+	 */
 	using PushdownStoreSymbolType_t = PushdownStoreSymbolType;
 
+	/**
+	 * \brief Creates a new instance of the automaton with a concrete set of states, call, return, and local alphabets, pushdown store alphabet, initial state, bottom of the stack symbol, and a set of final states.
+	 *
+	 * \param states the initial set of states of the automaton
+	 * \param callAlphabet the initial input alphabet
+	 * \param returnAlphabet the initial input alphabet
+	 * \param localAlphabet the initial input alphabet
+	 * \param pushdownStoreAlphabet the initial set of symbols used in the pushdown store by the automaton
+	 * \param initialState the initial state of the automaton
+	 * \param bottomOfTheStackSymbol the initial pushdown symbol of the automaton
+	 * \param finalStates the initial set of final states of the automaton
+	 */
 	explicit RealTimeHeightDeterministicDPDA ( ext::set < StateType > states, ext::set < InputSymbolType > inputAlphabet, ext::set < PushdownStoreSymbolType > pushdownStoreSymbol, StateType initialState, PushdownStoreSymbolType bottomOfTheStackSymbol, ext::set < StateType > finalStates );
+
+	/**
+	 * \brief Creates a new instance of the automaton with a concrete initial state and bottom of the stack symbol.
+	 *
+	 * \param initialState the initial state of the automaton
+	 * \param bottomOfTheStackSymbol the bottom of the stack symbol of the automaton
+	 */
 	explicit RealTimeHeightDeterministicDPDA ( StateType initialState, PushdownStoreSymbolType bottomOfTheStackSymbol );
 
-	virtual AutomatonBase * clone ( ) const;
+	/**
+	 * @copydoc automaton::AutomatonBase::clone()
+	 */
+	virtual AutomatonBase * clone ( ) const override;
 
-	virtual AutomatonBase * plunder ( ) &&;
+	/**
+	 * @copydoc automaton::AutomatonBase::plunder()
+	 */
+	virtual AutomatonBase * plunder ( ) && override;
 
+	/**
+	 * Getter of the initial state.
+	 *
+	 * \returns the initial state of the automaton
+	 */
 	const StateType & getInitialState ( ) const & {
-		return this->template accessComponent < InitialState > ( ).get ( );
+		return this-> template accessComponent < InitialState > ( ).get ( );
 	}
 
+	/**
+	 * Getter of the initial state.
+	 *
+	 * \returns the initial state of the automaton
+	 */
 	StateType && getInitialState ( ) && {
-		return std::move ( this->template accessComponent < InitialState > ( ).get ( ) );
+		return std::move ( this-> template accessComponent < InitialState > ( ).get ( ) );
 	}
 
+	/**
+	 * Setter of the initial state.
+	 *
+	 * \param state new initial state of the automaton
+	 *
+	 * \returns true if the initial state was indeed changed
+	 */
 	bool setInitialState ( StateType state ) {
-		return this->template accessComponent < InitialState > ( ).set ( std::move ( state ) );
+		return this-> template accessComponent < InitialState > ( ).set ( std::move ( state ) );
 	}
 
+	/**
+	 * Getter of states.
+	 *
+	 * \returns the states of the automaton
+	 */
 	const ext::set < StateType > & getStates ( ) const & {
-		return this->template accessComponent < States > ( ).get ( );
+		return this-> template accessComponent < States > ( ).get ( );
 	}
 
+	/**
+	 * Getter of states.
+	 *
+	 * \returns the states of the automaton
+	 */
 	ext::set < StateType > && getStates ( ) && {
-		return std::move ( this->template accessComponent < States > ( ).get ( ) );
+		return std::move ( this-> template accessComponent < States > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a state.
+	 *
+	 * \param state the new state to be added to a set of states
+	 *
+	 * \returns true if the state was indeed added
+	 */
 	bool addState ( StateType state ) {
-		return this->template accessComponent < States > ( ).add ( std::move ( state ) );
+		return this-> template accessComponent < States > ( ).add ( std::move ( state ) );
 	}
 
+	/**
+	 * Setter of states.
+	 *
+	 * \param states completely new set of states
+	 */
 	void setStates ( ext::set < StateType > states ) {
-		this->template accessComponent < States > ( ).set ( std::move ( states ) );
+		this-> template accessComponent < States > ( ).set ( std::move ( states ) );
 	}
 
-	void removeState ( const StateType & state ) {
-		this->template accessComponent < States > ( ).remove ( state );
+	/**
+	 * Remover of a state.
+	 *
+	 * \param state a state to be removed from a set of states
+	 *
+	 * \returns true if the state was indeed removed
+	 */
+	bool removeState ( const StateType & state ) {
+		return this-> template accessComponent < States > ( ).remove ( state );
 	}
 
+	/**
+	 * Getter of final states.
+	 *
+	 * \returns the final states of the automaton
+	 */
 	const ext::set < StateType > & getFinalStates ( ) const & {
-		return this->template accessComponent < FinalStates > ( ).get ( );
+		return this-> template accessComponent < FinalStates > ( ).get ( );
 	}
 
+	/**
+	 * Getter of final states.
+	 *
+	 * \returns the final states of the automaton
+	 */
 	ext::set < StateType > && getFinalStates ( ) && {
-		return std::move ( this->template accessComponent < FinalStates > ( ).get ( ) );
+		return std::move ( this-> template accessComponent < FinalStates > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a final state.
+	 *
+	 * \param state the new state to be added to a set of final states
+	 *
+	 * \returns true if the state was indeed added
+	 */
 	bool addFinalState ( StateType state ) {
-		return this->template accessComponent < FinalStates > ( ).add ( std::move ( state ) );
+		return this-> template accessComponent < FinalStates > ( ).add ( std::move ( state ) );
 	}
 
+	/**
+	 * Setter of final states.
+	 *
+	 * \param states completely new set of final states
+	 */
 	void setFinalStates ( ext::set < StateType > states ) {
-		this->template accessComponent < FinalStates > ( ).set ( std::move ( states ) );
+		this-> template accessComponent < FinalStates > ( ).set ( std::move ( states ) );
 	}
 
-	void removeFinalState ( const StateType & state ) {
-		this->template accessComponent < FinalStates > ( ).remove ( state );
+	/**
+	 * Remover of a final state.
+	 *
+	 * \param state a state to be removed from a set of final states
+	 *
+	 * \returns true if the state was indeed removed
+	 */
+	bool removeFinalState ( const StateType & state ) {
+		return this-> template accessComponent < FinalStates > ( ).remove ( state );
 	}
 
+	/**
+	 * Getter of the pushdown store alphabet.
+	 *
+	 * \returns the pushdown store alphabet of the automaton
+	 */
 	const ext::set < PushdownStoreSymbolType > & getPushdownStoreAlphabet ( ) const & {
 		return this->template accessComponent < PushdownStoreAlphabet > ( ).get ( );
 	}
 
+	/**
+	 * Getter of the pushdown store alphabet.
+	 *
+	 * \returns the pushdown store alphabet of the automaton
+	 */
 	ext::set < PushdownStoreSymbolType > && getPushdownStoreAlphabet ( ) && {
 		return std::move ( this->template accessComponent < PushdownStoreAlphabet > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a pushdown store symbol.
+	 *
+	 * \param symbol the new symbol to be added to a pushdown store alphabet
+	 *
+	 * \returns true if the symbol was indeed added
+	 */
 	bool addPushdownStoreSymbol ( PushdownStoreSymbolType symbol ) {
 		return this->template accessComponent < PushdownStoreAlphabet > ( ).add ( std::move ( symbol ) );
 	}
 
+	/**
+	 * Adder of pushdown store symbols.
+	 *
+	 * \param symbols new symbols to be added to a pushdown store alphabet
+	 */
 	void addPushdownStoreSymbols ( ext::set < PushdownStoreSymbolType > symbols ) {
 		this->template accessComponent < PushdownStoreAlphabet > ( ).add ( std::move ( symbols ) );
 	}
 
+	/**
+	 * Setter of a pushdown store alphabet.
+	 *
+	 * \param symbols completely new pushdown store alphabet
+	 */
 	void setPushdownStoreAlphabet ( ext::set < PushdownStoreSymbolType > symbols ) {
 		this->template accessComponent < PushdownStoreAlphabet > ( ).set ( std::move ( symbols ) );
 	}
 
-	void removePushdownStoreSymbol ( const PushdownStoreSymbolType & symbol ) {
-		this->template accessComponent < PushdownStoreAlphabet > ( ).remove ( symbol );
+	/**
+	 * Remover of an pushdown store symbol.
+	 *
+	 * \param symbol a symbol to be removed from a pushdown store alphabet
+	 *
+	 * \returns true if the symbol was indeed removed
+	 */
+	bool removePushdownStoreSymbol ( const PushdownStoreSymbolType & symbol ) {
+		return this->template accessComponent < PushdownStoreAlphabet > ( ).remove ( symbol );
 	}
 
+	/**
+	 * Getter of the bottom of the stack symbol.
+	 *
+	 * \returns the bottom of the stack symbol of the automaton
+	 */
 	const PushdownStoreSymbolType & getBottomOfTheStackSymbol ( ) const & {
 		return this->template accessComponent < BottomOfTheStackSymbol > ( ).get ( );
 	}
 
+	/**
+	 * Getter of the bottom of the stack symbol.
+	 *
+	 * \returns the bottom of the stack symbol of the automaton
+	 */
 	PushdownStoreSymbolType && getBottomOfTheStackSymbol ( ) && {
 		return std::move ( this->template accessComponent < BottomOfTheStackSymbol > ( ).get ( ) );
 	}
 
+	/**
+	 * Setter of the bottom of the stack symbol.
+	 *
+	 * \param symbol new bottom of the stack symbol of the automaton
+	 *
+	 * \returns true if the bottom of the stack symbol was indeed changed
+	 */
 	bool setBottomOfTheStackSymbol ( PushdownStoreSymbolType symbol ) {
 		return this->template accessComponent < BottomOfTheStackSymbol > ( ).set ( std::move ( symbol ) );
 	}
 
+	/**
+	 * Getter of the input alphabet.
+	 *
+	 * \returns the input alphabet of the automaton
+	 */
 	const ext::set < InputSymbolType > & getInputAlphabet ( ) const & {
-		return this->template accessComponent < InputAlphabet > ( ).get ( );
+		return this-> template accessComponent < InputAlphabet > ( ).get ( );
 	}
 
+	/**
+	 * Getter of the input alphabet.
+	 *
+	 * \returns the input alphabet of the automaton
+	 */
 	ext::set < InputSymbolType > && getInputAlphabet ( ) && {
-		return std::move ( this->template accessComponent < InputAlphabet > ( ).get ( ) );
+		return std::move ( this-> template accessComponent < InputAlphabet > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a input symbol.
+	 *
+	 * \param symbol the new symbol to be added to an input alphabet
+	 *
+	 * \returns true if the symbol was indeed added
+	 */
 	bool addInputSymbol ( InputSymbolType symbol ) {
-		return this->template accessComponent < InputAlphabet > ( ).add ( std::move ( symbol ) );
+		return this-> template accessComponent < InputAlphabet > ( ).add ( std::move ( symbol ) );
 	}
 
+	/**
+	 * Adder of input symbols.
+	 *
+	 * \param symbols new symbols to be added to an input alphabet
+	 */
 	void addInputSymbols ( ext::set < InputSymbolType > symbols ) {
-		this->template accessComponent < InputAlphabet > ( ).add ( std::move ( symbols ) );
+		this-> template accessComponent < InputAlphabet > ( ).add ( std::move ( symbols ) );
 	}
 
+	/**
+	 * Setter of input alphabet.
+	 *
+	 * \param symbols completely new input alphabet
+	 */
 	void setInputAlphabet ( ext::set < InputSymbolType > symbols ) {
-		this->template accessComponent < InputAlphabet > ( ).set ( std::move ( symbols ) );
+		this-> template accessComponent < InputAlphabet > ( ).set ( std::move ( symbols ) );
 	}
 
+	/**
+	 * Remover of an input symbol.
+	 *
+	 * \param symbol a symbol to be removed from an input alphabet
+	 *
+	 * \returns true if the symbol was indeed removed
+	 */
 	void removeInputSymbol ( const InputSymbolType & symbol ) {
-		this->template accessComponent < InputAlphabet > ( ).remove ( symbol );
+		this-> template accessComponent < InputAlphabet > ( ).remove ( symbol );
 	}
 
 	/**
-	 * Adds call transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a call transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
 	 */
 	bool addCallTransition ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, StateType next, PushdownStoreSymbolType push );
-	bool addCallTransition ( StateType current, StateType next, PushdownStoreSymbolType push );
+
+	/**
+	 * \brief Adds a call transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	bool addCallTransition ( StateType current, InputSymbolType input, StateType next, PushdownStoreSymbolType push );
 
 	/**
-	 * Adds return transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a call transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B \times g, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
+	bool addCallTransition ( StateType current, StateType next, PushdownStoreSymbolType push );
+
+	/**
+	 * \brief Adds a return transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
 	 */
 	bool addReturnTransition ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, PushdownStoreSymbolType pop, StateType next );
-	bool addReturnTransition ( StateType current, PushdownStoreSymbolType pop, StateType next );
+
+	/**
+	 * \brief Adds a return transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	bool addReturnTransition ( StateType current, InputSymbolType input, PushdownStoreSymbolType pop, StateType next );
 
 	/**
-	 * Adds local transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a return transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps \times g -> B, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
+	bool addReturnTransition ( StateType current, PushdownStoreSymbolType pop, StateType next );
+
+	/**
+	 * \brief Adds a local transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T \cup { \eps }
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
 	 */
 	bool addLocalTransition ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, StateType next );
-	bool addLocalTransition ( StateType current, StateType next );
+
+	/**
+	 * \brief Adds a local transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T
+	 *
+	 * \param from the source state (A)
+	 * \param input the call input symbol (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	bool addLocalTransition ( StateType current, InputSymbolType input, StateType next );
 
 	/**
-	 * Removes call transition from the automaton.
-	 * @param transition transition to remove
-	 * @throws AutomatonException when transition doesn't exists.
+	 * \brief Adds a local transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B, where A, B \in Q
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
+	bool addLocalTransition ( StateType current, StateType next );
+
+	/**
+	 * \brief Removes a call transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
 	 */
 	bool removeCallTransition ( const StateType & current, const ext::variant < EpsilonType, InputSymbolType > & input, const StateType & next, const PushdownStoreSymbolType & push );
-	bool removeCallTransition ( const StateType & current, const StateType & next, const PushdownStoreSymbolType & push );
+
+	/**
+	 * \brief Removes a call transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
 	bool removeCallTransition ( const StateType & current, const InputSymbolType & input, const StateType & next, const PushdownStoreSymbolType & push );
 
 	/**
-	 * Removes return transition from the automaton.
-	 * @param transition transition to remove
-	 * @throws AutomatonException when transition doesn't exists.
+	 * \brief Removes a call transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B \times g, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
+	bool removeCallTransition ( const StateType & current, const StateType & next, const PushdownStoreSymbolType & push );
+
+	/**
+	 * \brief Removes a return transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
 	 */
 	bool removeReturnTransition ( const StateType & current, const ext::variant < EpsilonType, InputSymbolType > & input, const PushdownStoreSymbolType & pop, const StateType & next );
-	bool removeReturnTransition ( const StateType & current, const PushdownStoreSymbolType & pop, const StateType & next );
+
+	/**
+	 * \brief Removes a return transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
 	bool removeReturnTransition ( const StateType & current, const InputSymbolType & input, const PushdownStoreSymbolType & pop, const StateType & next );
 
 	/**
-	 * Removes transition local from the automaton.
-	 * @param transition transition to remove
-	 * @throws AutomatonException when transition doesn't exists.
+	 * \brief Removes a return transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps \times g -> B, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
+	bool removeReturnTransition ( const StateType & current, const PushdownStoreSymbolType & pop, const StateType & next );
+
+	/**
+	 * \brief Removes a local transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T \cup { \eps }
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
 	 */
 	bool removeLocalTransition ( const StateType & current, const ext::variant < EpsilonType, InputSymbolType > & input, const StateType & next );
-	bool removeLocalTransition ( const StateType & current, const StateType & next );
+
+	/**
+	 * \brief Removes a local transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
 	bool removeLocalTransition ( const StateType & current, const InputSymbolType & input, const StateType & next );
 
+	/**
+	 * \brief Removes a local transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B, where A, B \in Q
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
+	bool removeLocalTransition ( const StateType & current, const StateType & next );
+
+	/**
+	 * Get the call transition function of the automaton in its natural form.
+	 *
+	 * \returns call transition function of the automaton
+	 */
 	const ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::pair < StateType, PushdownStoreSymbolType > > & getCallTransitions ( ) const &;
 
+	/**
+	 * Get the call transition function of the automaton in its natural form.
+	 *
+	 * \returns call transition function of the automaton
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::pair < StateType, PushdownStoreSymbolType > > && getCallTransitions ( ) &&;
 
+	/**
+	 * Get the return transition function of the automaton in its natural form.
+	 *
+	 * \returns return transition function of the automaton
+	 */
 	const ext::map < ext::tuple < StateType, ext::variant < EpsilonType, InputSymbolType >, PushdownStoreSymbolType >, StateType > & getReturnTransitions ( ) const &;
 
+	/**
+	 * Get the return transition function of the automaton in its natural form.
+	 *
+	 * \returns return transition function of the automaton
+	 */
 	ext::map < ext::tuple < StateType, ext::variant < EpsilonType, InputSymbolType >, PushdownStoreSymbolType >, StateType > && getReturnTransitions ( ) &&;
 
+	/**
+	 * Get the local transition function of the automaton in its natural form.
+	 *
+	 * \returns local transition function of the automaton
+	 */
 	const ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, StateType > & getLocalTransitions ( ) const &;
 
+	/**
+	 * Get the local transition function of the automaton in its natural form.
+	 *
+	 * \returns local transition function of the automaton
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, StateType > && getLocalTransitions ( ) &&;
 
-	virtual int compare ( const ObjectBase & other ) const {
+	/**
+	 * @copydoc alib::CommonBase<ObjectBase>::compare ( const ObjectBase & )
+	 */
+	virtual int compare ( const ObjectBase & other ) const override {
 		if ( ext::type_index ( typeid ( * this ) ) == ext::type_index ( typeid ( other ) ) ) return this->compare ( ( decltype ( * this ) )other );
 
 		return ext::type_index ( typeid ( * this ) ) - ext::type_index ( typeid ( other ) );
 	}
 
-	virtual int compare ( const RealTimeHeightDeterministicDPDA & other ) const;
+	/**
+	 * The actual compare method
+	 *
+	 * \param other the other instance
+	 *
+	 * \returns the actual relation between two by type same automata instances
+	 */
+	int compare ( const RealTimeHeightDeterministicDPDA & other ) const;
 
-	virtual void operator >>( std::ostream & os ) const;
+	/**
+	 * @copydoc alib::CommonBase<ObjectBase>::operator >> ( std::ostream & )
+	 */
+	virtual void operator >>( std::ostream & os ) const override;
 
-	virtual explicit operator std::string ( ) const;
+	/**
+	 * @copydoc alib::CommonBase<ObjectBase>::operator std::string ( )
+	 */
+	virtual explicit operator std::string ( ) const override;
 
+	/**
+	 * \brief The XML tag name of class.
+	 *
+	 * \details Intentionaly a static member function to be safe in the initialisation before the main function starts.
+	 *
+	 * \returns string representing the XML tag name of the class
+	 */
 	static const std::string & getXmlTagName() {
 		static std::string xmlTagName = "RealTimeHeightDeterministicDPDA";
 
 		return xmlTagName;
 	}
 
+	/**
+	 * Parsing from a sequence of xml tokens helper.
+	 *
+	 * \params input the iterator to sequence of xml tokens to parse from
+	 *
+	 * \returns the new instance of the automaton
+	 */
 	static RealTimeHeightDeterministicDPDA parse ( ext::deque < sax::Token >::iterator & input );
+
+	/**
+	 * Helper for parsing of individual transitions of the automaton from a sequence of xml tokens.
+	 *
+	 * \params input the iterator to sequence of xml tokens to parse from
+	 * \params automaton the automaton to add the rule to
+	 */
 	static void parseTransition ( ext::deque < sax::Token >::iterator & input, RealTimeHeightDeterministicDPDA & automaton );
 
+	/**
+	 * Composing to a sequence of xml tokens helper.
+	 *
+	 * \param out the sink for new xml tokens representing the automaton
+	 * \param automaton the automaton to compose
+	 */
 	static void compose ( ext::deque < sax::Token > & out, const RealTimeHeightDeterministicDPDA & automaton );
+
+	/**
+	 * Helper for composing transitions of the automaton to a sequence of xml tokens.
+	 *
+	 * \param out the sink for xml tokens representing the rules of the automaton
+	 * \param automaton the automaton to compose
+	 */
 	static void composeTransitions ( ext::deque < sax::Token > & ou, const RealTimeHeightDeterministicDPDA & automatont );
 
-	virtual object::ObjectBase * inc ( ) &&;
+	/**
+	 * @copydoc alib::GrammarBase::inc()
+	 */
+	virtual object::ObjectBase * inc ( ) && override;
 
+	/**
+	 * Type of normalized automaton.
+	 */
 	typedef RealTimeHeightDeterministicDPDA < > normalized_type;
 };
 
@@ -739,9 +1292,25 @@ object::ObjectBase* RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonTy
 
 namespace core {
 
+/**
+ * Helper class specifying constraints for the automaton's internal input alphabet component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, InputSymbolType, automaton::InputAlphabet > {
 public:
+	/**
+	 * Returns true if the symbol is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 *
+	 * \returns true if the symbol is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const InputSymbolType & symbol ) {
 		for ( const std::pair<const ext::pair<StateType, ext::variant < EpsilonType, InputSymbolType >>, ext::pair<StateType, PushdownStoreSymbolType> >& callTransition : automaton.getCallTransitions())
 			if (callTransition.first.second.template is < InputSymbolType >() && symbol == callTransition.first.second.template get < InputSymbolType >())
@@ -758,17 +1327,47 @@ public:
 		return false;
 	}
 
+	/**
+	 * Returns true as all symbols are possibly available to be elements of the input alphabet.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const InputSymbolType & ) {
 		return true;
 	}
 
+	/**
+	 * All symbols are valid as input symbols.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const InputSymbolType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal pushdown store alphabet component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, PushdownStoreSymbolType, automaton::PushdownStoreAlphabet > {
 public:
+	/**
+	 * Returns true if the symbol is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 *
+	 * \returns true if the symbol is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const PushdownStoreSymbolType & symbol ) {
 		for ( const std::pair<const ext::pair<StateType, ext::variant < EpsilonType, InputSymbolType >>, ext::pair<StateType, PushdownStoreSymbolType> >& callTransition : automaton.getCallTransitions())
 			if (symbol == callTransition.second.second)
@@ -784,28 +1383,80 @@ public:
 		return false;
 	}
 
+	/**
+	 * Returns true as all symbols are possibly available to be elements of the pushdown store alphabet.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const PushdownStoreSymbolType & ) {
 		return true;
 	}
 
+	/**
+	 * All symbols are valid as pushdown store symbols.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const PushdownStoreSymbolType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal bottom of the stack symbol element.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class ElementConstraint< automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, PushdownStoreSymbolType, automaton::BottomOfTheStackSymbol > {
 public:
+	/**
+	 * Determines whether the bottom of the stack symbol is available in the automaton's pushdown store alphabet.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 *
+	 * \returns true if the pushdown store symbol is already in the pushdown store alphabet of the automaton
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const PushdownStoreSymbolType & symbol ) {
 		return automaton.template accessComponent < automaton::PushdownStoreAlphabet > ( ).get ( ).count ( symbol );
 	}
 
+	/**
+	 * All pushdown store symbols are valid as a bottom of the stack symbol of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const PushdownStoreSymbolType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal states component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, StateType, automaton::States > {
 public:
+	/**
+	 * Returns true if the state is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const StateType & state ) {
 		if ( automaton.getInitialState ( ) == state )
 			return true;
@@ -828,36 +1479,102 @@ public:
 		return false;
 	}
 
+	/**
+	 * Returns true as all states are possibly available to be elements of the states.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 		return true;
 	}
 
+	/**
+	 * All states are valid as a state of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal final states component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, StateType, automaton::FinalStates > {
 public:
+	/**
+	 * Returns true if the state is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 		return false;
 	}
 
+	/**
+	 * Determines whether the state is available in the automaton's states set.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is already in the set of states of the automaton
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const StateType & state ) {
 		return automaton.template accessComponent < automaton::States > ( ).get ( ).count ( state );
 	}
 
+	/**
+	 * All states are valid as a final state of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal initial state element.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class ElementConstraint< automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, StateType, automaton::InitialState > {
 public:
+	/**
+	 * Determines whether the state is available in the automaton's states set.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is already in the set of states of the automaton
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const StateType & state ) {
 		return automaton.template accessComponent < automaton::States > ( ).get ( ).count ( state );
 	}
 
+	/**
+	 * All states are valid as an initial state of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicDPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 	}
 };
diff --git a/alib2data/src/automaton/PDA/RealTimeHeightDeterministicNPDA.h b/alib2data/src/automaton/PDA/RealTimeHeightDeterministicNPDA.h
index 1a530cf0990c517d6a48a23718f1bf67dd6cd014..345c48eb3b7bba74cfdbf49c122ebde53bfd1892 100644
--- a/alib2data/src/automaton/PDA/RealTimeHeightDeterministicNPDA.h
+++ b/alib2data/src/automaton/PDA/RealTimeHeightDeterministicNPDA.h
@@ -1,5 +1,21 @@
 /*
- * REAL_TIME_HEIGHT_DETERMINISTIC_NPDA.h
+ * RealTimeHeightDeterministicNPDA.h
+ *
+ * This file is part of Algorithms library toolkit.
+ * Copyright (C) 2017 Jan Travnicek (jan.travnicek@fit.cvut.cz)
+
+ * Algorithms library toolkit is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+
+ * Algorithms library toolkit is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+
+ * You should have received a copy of the GNU General Public License
+ * along with Algorithms library toolkit.  If not, see <http://www.gnu.org/licenses/>.
  *
  *  Created on: Mar 25, 2013
  *      Author: Jan Travnicek
@@ -39,275 +55,894 @@ class FinalStates;
 class InitialStates;
 
 /**
- * Represents Finite Automaton.
- * Can store nondeterministic finite automaton without epsilon transitions.
+ * \brief
+ * Nondeterministic real time height deterministic pushdown automaton. Accepts subset of context free languages.
+
+ * \details
+ * Definition
+ * A = (Q, T, G, I, Z, \delta, F),
+ * Q (States) = nonempty finite set of states,
+ * T (TerminalAlphabet) = finite set of terminal symbols
+ * G (PushdownStoreAlphabet) = finite set of pushdown store symbol - having this empty makes the automaton equivalent to DFA
+ * I (InitialState) = initial state,
+ * Z (BottomOfTheStackSymbol) = initial pushdown store symbol
+ * \delta is split to three disjoint parts
+ *   - \delta_{call} of the form A \times a -> B \times g, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+ *   - \delta_{return} of the form A \times a \times g -> B, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+ *   - \delta_{local} of the form A \times a -> B, where A, B \in Q, a \in T \cup { \eps }
+ * F (FinalStates) = set of final states
+ *
+ * \tparam InputSymbolType used for the terminal alphabet
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet
+ * \tparam StateType used to the states, and the initial state of the automaton.
  */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class RealTimeHeightDeterministicNPDA final : public AutomatonBase, public core::Components < RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, ext::set < InputSymbolType >, component::Set, InputAlphabet, ext::set < PushdownStoreSymbolType >, component::Set, PushdownStoreAlphabet, PushdownStoreSymbolType, component::Value, BottomOfTheStackSymbol, ext::set < StateType >, component::Set, std::tuple < States, InitialStates, FinalStates > > {
 protected:
+	/**
+	 * Call transition function as mapping from a state times an input symbol or epsilon on the left hand side to a state times pushdown store symbol on the right hand side.
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::set < ext::pair < StateType, PushdownStoreSymbolType > > > callTransitions;
+
+	/**
+	 * Return transition function as mapping from a state times an input symbol or epsilon times pushdown store symbol on the left hand side to a state on the right hand side.
+	 */
 	ext::map < ext::tuple < StateType, ext::variant < EpsilonType, InputSymbolType >, PushdownStoreSymbolType >, ext::set < StateType > > returnTransitions;
+
+	/**
+	 * Local transition function as mapping from a state times an input symbol or epsilon on the left hand side to a state on the right hand side.
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::set < StateType > > localTransitions;
 
 public:
+	/**
+	 * \brief Creates a new instance of the automaton with a concrete set of states, call, return, and local alphabets, pushdown store alphabet, initial state, bottom of the stack symbol, and a set of final states.
+	 *
+	 * \param states the initial set of states of the automaton
+	 * \param callAlphabet the initial input alphabet
+	 * \param returnAlphabet the initial input alphabet
+	 * \param localAlphabet the initial input alphabet
+	 * \param pushdownStoreAlphabet the initial set of symbols used in the pushdown store by the automaton
+	 * \param initialState the initial state of the automaton
+	 * \param bottomOfTheStackSymbol the initial pushdown symbol of the automaton
+	 * \param finalStates the initial set of final states of the automaton
+	 */
 	explicit RealTimeHeightDeterministicNPDA ( ext::set < StateType > states, ext::set < InputSymbolType > inputAlphabet, ext::set < PushdownStoreSymbolType > pushdownStoreSymbol, ext::set < StateType > initialStates, PushdownStoreSymbolType bottomOfTheStackSymbol, ext::set < StateType > finalStates );
+
+	/**
+	 * \brief Creates a new instance of the automaton with a concrete initial state and bottom of the stack symbol.
+	 *
+	 * \param initialState the initial state of the automaton
+	 * \param bottomOfTheStackSymbol the bottom of the stack symbol of the automaton
+	 */
 	explicit RealTimeHeightDeterministicNPDA ( PushdownStoreSymbolType bottomOfTheStackSymbol );
 
-	virtual AutomatonBase * clone ( ) const;
+	/**
+	 * @copydoc automaton::AutomatonBase::clone()
+	 */
+	virtual AutomatonBase * clone ( ) const override;
 
-	virtual AutomatonBase * plunder ( ) &&;
+	/**
+	 * @copydoc automaton::AutomatonBase::plunder()
+	 */
+	virtual AutomatonBase * plunder ( ) && override;
 
+	/**
+	 * Getter of states.
+	 *
+	 * \returns the states of the automaton
+	 */
 	const ext::set < StateType > & getStates ( ) const & {
-		return this->template accessComponent < States > ( ).get ( );
+		return this-> template accessComponent < States > ( ).get ( );
 	}
 
+	/**
+	 * Getter of states.
+	 *
+	 * \returns the states of the automaton
+	 */
 	ext::set < StateType > && getStates ( ) && {
-		return std::move ( this->template accessComponent < States > ( ).get ( ) );
+		return std::move ( this-> template accessComponent < States > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a state.
+	 *
+	 * \param state the new state to be added to a set of states
+	 *
+	 * \returns true if the state was indeed added
+	 */
 	bool addState ( StateType state ) {
-		return this->template accessComponent < States > ( ).add ( std::move ( state ) );
+		return this-> template accessComponent < States > ( ).add ( std::move ( state ) );
 	}
 
+	/**
+	 * Setter of states.
+	 *
+	 * \param states completely new set of states
+	 */
 	void setStates ( ext::set < StateType > states ) {
-		this->template accessComponent < States > ( ).set ( std::move ( states ) );
+		this-> template accessComponent < States > ( ).set ( std::move ( states ) );
 	}
 
-	void removeState ( const StateType & state ) {
-		this->template accessComponent < States > ( ).remove ( state );
+	/**
+	 * Remover of a state.
+	 *
+	 * \param state a state to be removed from a set of states
+	 *
+	 * \returns true if the state was indeed removed
+	 */
+	bool removeState ( const StateType & state ) {
+		return this-> template accessComponent < States > ( ).remove ( state );
 	}
 
+	/**
+	 * Getter of initial state.
+	 *
+	 * \returns the states of the automaton
+	 */
 	const ext::set < StateType > & getInitialStates ( ) const & {
 		return this->template accessComponent < InitialStates > ( ).get ( );
 	}
 
+	/**
+	 * Getter of initial state.
+	 *
+	 * \returns the states of the automaton
+	 */
 	ext::set < StateType > && getInitialStates ( ) && {
 		return std::move ( this->template accessComponent < InitialStates > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of an initial state.
+	 *
+	 * \param state the new state to be added to a set of initial states
+	 *
+	 * \returns true if the state was indeed added
+	 */
 	bool addInitialState ( StateType state ) {
 		return this->template accessComponent < InitialStates > ( ).add ( std::move ( state ) );
 	}
 
+	/**
+	 * Setter of initial states.
+	 *
+	 * \param states completely new set of initial states
+	 */
 	void setInitialStates ( ext::set < StateType > states ) {
 		this->template accessComponent < InitialStates > ( ).set ( std::move ( states ) );
 	}
 
-	void removeInitialState ( const StateType & state ) {
-		this->template accessComponent < InitialStates > ( ).remove ( state );
+	/**
+	 * Remover of an initial state.
+	 *
+	 * \param state a state to be removed from a set of initial states
+	 *
+	 * \returns true if the state was indeed removed
+	 */
+	bool removeInitialState ( const StateType & state ) {
+		return this->template accessComponent < InitialStates > ( ).remove ( state );
 	}
 
+	/**
+	 * Getter of final states.
+	 *
+	 * \returns the final states of the automaton
+	 */
 	const ext::set < StateType > & getFinalStates ( ) const & {
-		return this->template accessComponent < FinalStates > ( ).get ( );
+		return this-> template accessComponent < FinalStates > ( ).get ( );
 	}
 
+	/**
+	 * Getter of final states.
+	 *
+	 * \returns the final states of the automaton
+	 */
 	ext::set < StateType > && getFinalStates ( ) && {
-		return std::move ( this->template accessComponent < FinalStates > ( ).get ( ) );
+		return std::move ( this-> template accessComponent < FinalStates > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a final state.
+	 *
+	 * \param state the new state to be added to a set of final states
+	 *
+	 * \returns true if the state was indeed added
+	 */
 	bool addFinalState ( StateType state ) {
-		return this->template accessComponent < FinalStates > ( ).add ( std::move ( state ) );
+		return this-> template accessComponent < FinalStates > ( ).add ( std::move ( state ) );
 	}
 
+	/**
+	 * Setter of final states.
+	 *
+	 * \param states completely new set of final states
+	 */
 	void setFinalStates ( ext::set < StateType > states ) {
-		this->template accessComponent < FinalStates > ( ).set ( std::move ( states ) );
+		this-> template accessComponent < FinalStates > ( ).set ( std::move ( states ) );
 	}
 
-	void removeFinalState ( const StateType & state ) {
-		this->template accessComponent < FinalStates > ( ).remove ( state );
+	/**
+	 * Remover of a final state.
+	 *
+	 * \param state a state to be removed from a set of final states
+	 *
+	 * \returns true if the state was indeed removed
+	 */
+	bool removeFinalState ( const StateType & state ) {
+		return this-> template accessComponent < FinalStates > ( ).remove ( state );
 	}
 
+	/**
+	 * Getter of the pushdown store alphabet.
+	 *
+	 * \returns the pushdown store alphabet of the automaton
+	 */
 	const ext::set < PushdownStoreSymbolType > & getPushdownStoreAlphabet ( ) const & {
 		return this->template accessComponent < PushdownStoreAlphabet > ( ).get ( );
 	}
 
+	/**
+	 * Getter of the pushdown store alphabet.
+	 *
+	 * \returns the pushdown store alphabet of the automaton
+	 */
 	ext::set < PushdownStoreSymbolType > && getPushdownStoreAlphabet ( ) && {
 		return std::move ( this->template accessComponent < PushdownStoreAlphabet > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a pushdown store symbol.
+	 *
+	 * \param symbol the new symbol to be added to a pushdown store alphabet
+	 *
+	 * \returns true if the symbol was indeed added
+	 */
 	bool addPushdownStoreSymbol ( PushdownStoreSymbolType symbol ) {
 		return this->template accessComponent < PushdownStoreAlphabet > ( ).add ( std::move ( symbol ) );
 	}
 
+	/**
+	 * Adder of pushdown store symbols.
+	 *
+	 * \param symbols new symbols to be added to a pushdown store alphabet
+	 */
 	void addPushdownStoreSymbols ( ext::set < PushdownStoreSymbolType > symbols ) {
 		this->template accessComponent < PushdownStoreAlphabet > ( ).add ( std::move ( symbols ) );
 	}
 
+	/**
+	 * Setter of a pushdown store alphabet.
+	 *
+	 * \param symbols completely new pushdown store alphabet
+	 */
 	void setPushdownStoreAlphabet ( ext::set < PushdownStoreSymbolType > symbols ) {
 		this->template accessComponent < PushdownStoreAlphabet > ( ).set ( std::move ( symbols ) );
 	}
 
-	void removePushdownStoreSymbol ( const PushdownStoreSymbolType & symbol ) {
-		this->template accessComponent < PushdownStoreAlphabet > ( ).remove ( symbol );
+	/**
+	 * Remover of an pushdown store symbol.
+	 *
+	 * \param symbol a symbol to be removed from a pushdown store alphabet
+	 *
+	 * \returns true if the symbol was indeed removed
+	 */
+	bool removePushdownStoreSymbol ( const PushdownStoreSymbolType & symbol ) {
+		return this->template accessComponent < PushdownStoreAlphabet > ( ).remove ( symbol );
 	}
 
+	/**
+	 * Getter of the bottom of the stack symbol.
+	 *
+	 * \returns the bottom of the stack symbol of the automaton
+	 */
 	const PushdownStoreSymbolType & getBottomOfTheStackSymbol ( ) const & {
 		return this->template accessComponent < BottomOfTheStackSymbol > ( ).get ( );
 	}
 
+	/**
+	 * Getter of the bottom of the stack symbol.
+	 *
+	 * \returns the bottom of the stack symbol of the automaton
+	 */
 	PushdownStoreSymbolType && getBottomOfTheStackSymbol ( ) && {
 		return std::move ( this->template accessComponent < BottomOfTheStackSymbol > ( ).get ( ) );
 	}
 
+	/**
+	 * Setter of the bottom of the stack symbol.
+	 *
+	 * \param symbol new bottom of the stack symbol of the automaton
+	 *
+	 * \returns true if the bottom of the stack symbol was indeed changed
+	 */
 	bool setBottomOfTheStackSymbol ( PushdownStoreSymbolType symbol ) {
 		return this->template accessComponent < BottomOfTheStackSymbol > ( ).set ( std::move ( symbol ) );
 	}
 
+	/**
+	 * Getter of the input alphabet.
+	 *
+	 * \returns the input alphabet of the automaton
+	 */
 	const ext::set < InputSymbolType > & getInputAlphabet ( ) const & {
-		return this->template accessComponent < InputAlphabet > ( ).get ( );
+		return this-> template accessComponent < InputAlphabet > ( ).get ( );
 	}
 
+	/**
+	 * Getter of the input alphabet.
+	 *
+	 * \returns the input alphabet of the automaton
+	 */
 	ext::set < InputSymbolType > && getInputAlphabet ( ) && {
-		return std::move ( this->template accessComponent < InputAlphabet > ( ).get ( ) );
+		return std::move ( this-> template accessComponent < InputAlphabet > ( ).get ( ) );
 	}
 
+	/**
+	 * Adder of a input symbol.
+	 *
+	 * \param symbol the new symbol to be added to an input alphabet
+	 *
+	 * \returns true if the symbol was indeed added
+	 */
 	bool addInputSymbol ( InputSymbolType symbol ) {
-		return this->template accessComponent < InputAlphabet > ( ).add ( std::move ( symbol ) );
+		return this-> template accessComponent < InputAlphabet > ( ).add ( std::move ( symbol ) );
 	}
 
+	/**
+	 * Adder of input symbols.
+	 *
+	 * \param symbols new symbols to be added to an input alphabet
+	 */
 	void addInputSymbols ( ext::set < InputSymbolType > symbols ) {
-		this->template accessComponent < InputAlphabet > ( ).add ( std::move ( symbols ) );
+		this-> template accessComponent < InputAlphabet > ( ).add ( std::move ( symbols ) );
 	}
 
+	/**
+	 * Setter of input alphabet.
+	 *
+	 * \param symbols completely new input alphabet
+	 */
 	void setInputAlphabet ( ext::set < InputSymbolType > symbols ) {
-		this->template accessComponent < InputAlphabet > ( ).set ( std::move ( symbols ) );
+		this-> template accessComponent < InputAlphabet > ( ).set ( std::move ( symbols ) );
 	}
 
+	/**
+	 * Remover of an input symbol.
+	 *
+	 * \param symbol a symbol to be removed from an input alphabet
+	 *
+	 * \returns true if the symbol was indeed removed
+	 */
 	void removeInputSymbol ( const InputSymbolType & symbol ) {
-		this->template accessComponent < InputAlphabet > ( ).remove ( symbol );
+		this-> template accessComponent < InputAlphabet > ( ).remove ( symbol );
 	}
 
 	/**
-	 * Adds call transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a call transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
 	 */
 	bool addCallTransition ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, StateType next, PushdownStoreSymbolType push );
-	bool addCallTransition ( StateType current, StateType next, PushdownStoreSymbolType push );
+
+	/**
+	 * \brief Adds a call transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	bool addCallTransition ( StateType current, InputSymbolType input, StateType next, PushdownStoreSymbolType push );
 
 	/**
-	 * Adds return transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a call transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B \times g, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
+	bool addCallTransition ( StateType current, StateType next, PushdownStoreSymbolType push );
+
+	/**
+	 * \brief Adds a return transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
 	 */
 	bool addReturnTransition ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, PushdownStoreSymbolType pop, StateType next );
-	bool addReturnTransition ( StateType current, PushdownStoreSymbolType pop, StateType next );
+
+	/**
+	 * \brief Adds a return transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	bool addReturnTransition ( StateType current, InputSymbolType input, PushdownStoreSymbolType pop, StateType next );
 
 	/**
-	 * Adds local transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a return transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps \times g -> B, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
+	bool addReturnTransition ( StateType current, PushdownStoreSymbolType pop, StateType next );
+
+	/**
+	 * \brief Adds a local transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T \cup { \eps }
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
 	 */
 	bool addLocalTransition ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, StateType next );
-	bool addLocalTransition ( StateType current, StateType next );
+
+	/**
+	 * \brief Adds a local transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T
+	 *
+	 * \param from the source state (A)
+	 * \param input the call input symbol (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	bool addLocalTransition ( StateType current, InputSymbolType input, StateType next );
 
 	/**
-	 * Adds call transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a local transition to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B, where A, B \in Q
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components or when the transition would cause nondeterminism
+	 *
+	 * \returns true if the transition was indeed added
+	 */
+	bool addLocalTransition ( StateType current, StateType next );
+
+	/**
+	 * \brief Adds a call transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g | C \times h | ..., where A, B, C, ... \in Q, a \in T \cup { \eps }, and g, h, ... \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param targets the set of target state (B, C ...) and symbols to be pushed to the pushdown store on the transition use (g, h, ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
+	 *
+	 * \returns true if the transition was indeed added
 	 */
 	void addCallTransitions ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, ext::set < ext::pair < StateType, PushdownStoreSymbolType > > targets );
+
+	/**
+	 * \brief Adds a call transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g | C \times h | ..., where A, B, C, ... \in Q, a \in T, and g, h, ... \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param targets the set of target state (B, C ...) and symbols to be pushed to the pushdown store on the transition use (g, h, ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	void addCallTransitions ( StateType current, ext::set < ext::pair < StateType, PushdownStoreSymbolType > > targets );
+
+	/**
+	 * \brief Adds a call transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B \times g | C \times h | ..., where A, B, C, ... \in Q, and g, h, ... \in G
+	 *
+	 * \param from the source state (A)
+	 * \param targets the set of target state (B, C ...) and symbols to be pushed to the pushdown store on the transition use (g, h, ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
+	 *
+	 * \returns true if the transition was indeed added
+	 */
 	void addCallTransitions ( StateType current, InputSymbolType input, ext::set < ext::pair < StateType, PushdownStoreSymbolType > > targets );
 
 	/**
-	 * Adds return transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a return transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B | C | ..., where A, B, C, ... \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param targets the set of target state (B, C ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
 	 */
 	void addReturnTransitions ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, PushdownStoreSymbolType pop, ext::set < StateType > next );
+
+	/**
+	 * \brief Adds a return transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B | C | ..., where A, B, C, ... \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param targets the set of target state (B, C ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
+	 */
 	void addReturnTransitions ( StateType current, PushdownStoreSymbolType pop, ext::set < StateType > next );
+
+	/**
+	 * \brief Adds a return transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps \times g -> B | C | ..., where A, B, C, ... \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param targets the set of target state (B, C ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
+	 */
 	void addReturnTransitions ( StateType current, InputSymbolType input, PushdownStoreSymbolType pop, ext::set < StateType > next );
 
 	/**
-	 * Adds local transition defined by parameters to the automaton.
-	 * @param current current state
-	 * @param input input symbol
-	 * @param next next state
-	 * @throws AutomatonException when transition already exists or when transition contains state or symbol not present in the automaton
+	 * \brief Adds a local transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B | C | ..., where A, B, C, ... \in Q and a \in T \cup { \eps }
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param targets the set of target state (B, C ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
 	 */
 	void addLocalTransitions ( StateType current, ext::variant < EpsilonType, InputSymbolType > input, ext::set < StateType > next );
+
+	/**
+	 * \brief Adds a local transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B | C | ..., where A, B, C, ... \in Q and a \in T
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param targets the set of target state (B, C ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
+	 */
 	void addLocalTransitions ( StateType current, ext::set < StateType > next );
+
+	/**
+	 * \brief Adds a local transitions to the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B | C | ..., where A, B, C, ... \in Q
+	 *
+	 * \param from the source state (A)
+	 * \param targets the set of target state (B, C ...)
+	 *
+	 * \throws AutomatonException when transition contains state or symbol not present in the automaton components
+	 */
 	void addLocalTransitions ( StateType current, InputSymbolType input, ext::set < StateType > next );
 
 	/**
-	 * Removes call transition from the automaton.
-	 * @param transition transition to remove
-	 * @throws AutomatonException when transition doesn't exists.
+	 * \brief Removes a call transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
 	 */
 	bool removeCallTransition ( const StateType & current, const ext::variant < EpsilonType, InputSymbolType > & input, const StateType & next, const PushdownStoreSymbolType & push );
-	bool removeCallTransition ( const StateType & current, const StateType & next, const PushdownStoreSymbolType & push );
+
+	/**
+	 * \brief Removes a call transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B \times g, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
 	bool removeCallTransition ( const StateType & current, const InputSymbolType & input, const StateType & next, const PushdownStoreSymbolType & push );
 
 	/**
-	 * Removes return transition from the automaton.
-	 * @param transition transition to remove
-	 * @throws AutomatonException when transition doesn't exists.
+	 * \brief Removes a call transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B \times g, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 * \param push symbol to be pushed to the pushdown store on the transition use (g)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
+	bool removeCallTransition ( const StateType & current, const StateType & next, const PushdownStoreSymbolType & push );
+
+	/**
+	 * \brief Removes a return transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T \cup { \eps }, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
 	 */
 	bool removeReturnTransition ( const StateType & current, const ext::variant < EpsilonType, InputSymbolType > & input, const PushdownStoreSymbolType & pop, const StateType & next );
-	bool removeReturnTransition ( const StateType & current, const PushdownStoreSymbolType & pop, const StateType & next );
+
+	/**
+	 * \brief Removes a return transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a \times g -> B, where A, B \in Q, a \in T, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
 	bool removeReturnTransition ( const StateType & current, const InputSymbolType & input, const PushdownStoreSymbolType & pop, const StateType & next );
 
 	/**
-	 * Removes transition local from the automaton.
-	 * @param transition transition to remove
-	 * @throws AutomatonException when transition doesn't exists.
+	 * \brief Removes a return transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps \times g -> B, where A, B \in Q, and g \in G
+	 *
+	 * \param from the source state (A)
+	 * \param pop symbol to be poped to the pushdown store on the transition use (g)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
+	bool removeReturnTransition ( const StateType & current, const PushdownStoreSymbolType & pop, const StateType & next );
+
+	/**
+	 * \brief Removes a local transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T \cup { \eps }
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol or epsilon (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
 	 */
 	bool removeLocalTransition ( const StateType & current, const ext::variant < EpsilonType, InputSymbolType > & input, const StateType & next );
-	bool removeLocalTransition ( const StateType & current, const StateType & next );
+
+	/**
+	 * \brief Removes a local transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times a -> B, where A, B \in Q and a \in T
+	 *
+	 * \param from the source state (A)
+	 * \param input the input symbol (a)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
 	bool removeLocalTransition ( const StateType & current, const InputSymbolType & input, const StateType & next );
 
+	/**
+	 * \brief Removes a local transition from the automaton.
+	 *
+	 * \details The transition is in a form A \times \eps -> B, where A, B \in Q
+	 *
+	 * \param from the source state (A)
+	 * \param to the target state (B)
+	 *
+	 * \throws AutomatonException when removed transition left hand side was found but the right hand side did not match.
+	 *
+	 * \returns true if the transition was indeed removed
+	 */
+	bool removeLocalTransition ( const StateType & current, const StateType & next );
+
+	/**
+	 * Get the call transition function of the automaton in its natural form.
+	 *
+	 * \returns call transition function of the automaton
+	 */
 	const ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::set < ext::pair < StateType, PushdownStoreSymbolType > > > & getCallTransitions ( ) const &;
 
+	/**
+	 * Get the call transition function of the automaton in its natural form.
+	 *
+	 * \returns call transition function of the automaton
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::set < ext::pair < StateType, PushdownStoreSymbolType > > > && getCallTransitions ( ) &&;
 
+	/**
+	 * Get the return transition function of the automaton in its natural form.
+	 *
+	 * \returns return transition function of the automaton
+	 */
 	const ext::map < ext::tuple < StateType, ext::variant < EpsilonType, InputSymbolType >, PushdownStoreSymbolType >, ext::set < StateType > > & getReturnTransitions ( ) const &;
 
+	/**
+	 * Get the return transition function of the automaton in its natural form.
+	 *
+	 * \returns return transition function of the automaton
+	 */
 	ext::map < ext::tuple < StateType, ext::variant < EpsilonType, InputSymbolType >, PushdownStoreSymbolType >, ext::set < StateType > > && getReturnTransitions ( ) &&;
 
+	/**
+	 * Get the local transition function of the automaton in its natural form.
+	 *
+	 * \returns local transition function of the automaton
+	 */
 	const ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::set < StateType > > & getLocalTransitions ( ) const &;
 
+	/**
+	 * Get the local transition function of the automaton in its natural form.
+	 *
+	 * \returns local transition function of the automaton
+	 */
 	ext::map < ext::pair < StateType, ext::variant < EpsilonType, InputSymbolType > >, ext::set < StateType > > && getLocalTransitions ( ) &&;
 
-	virtual int compare ( const ObjectBase & other ) const {
+	/**
+	 * @copydoc alib::CommonBase<ObjectBase>::compare ( const ObjectBase & )
+	 */
+	virtual int compare ( const ObjectBase & other ) const override {
 		if ( ext::type_index ( typeid ( * this ) ) == ext::type_index ( typeid ( other ) ) ) return this->compare ( ( decltype ( * this ) )other );
 
 		return ext::type_index ( typeid ( * this ) ) - ext::type_index ( typeid ( other ) );
 	}
 
-	virtual int compare ( const RealTimeHeightDeterministicNPDA & other ) const;
+	/**
+	 * The actual compare method
+	 *
+	 * \param other the other instance
+	 *
+	 * \returns the actual relation between two by type same automata instances
+	 */
+	int compare ( const RealTimeHeightDeterministicNPDA & other ) const;
 
-	virtual void operator >>( std::ostream & os ) const;
+	/**
+	 * @copydoc alib::CommonBase<ObjectBase>::operator >> ( std::ostream & )
+	 */
+	virtual void operator >>( std::ostream & os ) const override;
 
-	virtual explicit operator std::string ( ) const;
+	/**
+	 * @copydoc alib::CommonBase<ObjectBase>::operator std::string ( )
+	 */
+	virtual explicit operator std::string ( ) const override;
 
+	/**
+	 * \brief The XML tag name of class.
+	 *
+	 * \details Intentionaly a static member function to be safe in the initialisation before the main function starts.
+	 *
+	 * \returns string representing the XML tag name of the class
+	 */
 	static const std::string & getXmlTagName() {
 		static std::string xmlTagName = "RealTimeHeightDeterministicNPDA";
 
 		return xmlTagName;
 	}
 
+	/**
+	 * Parsing from a sequence of xml tokens helper.
+	 *
+	 * \params input the iterator to sequence of xml tokens to parse from
+	 *
+	 * \returns the new instance of the automaton
+	 */
 	static RealTimeHeightDeterministicNPDA parse ( ext::deque < sax::Token >::iterator & input );
+
+	/**
+	 * Helper for parsing of individual transitions of the automaton from a sequence of xml tokens.
+	 *
+	 * \params input the iterator to sequence of xml tokens to parse from
+	 * \params automaton the automaton to add the rule to
+	 */
 	static void parseTransition ( ext::deque < sax::Token >::iterator & input, RealTimeHeightDeterministicNPDA & automaton );
 
+	/**
+	 * Composing to a sequence of xml tokens helper.
+	 *
+	 * \param out the sink for new xml tokens representing the automaton
+	 * \param automaton the automaton to compose
+	 */
 	static void compose ( ext::deque < sax::Token > & out, const RealTimeHeightDeterministicNPDA & automaton );
+
+	/**
+	 * Helper for composing transitions of the automaton to a sequence of xml tokens.
+	 *
+	 * \param out the sink for xml tokens representing the rules of the automaton
+	 * \param automaton the automaton to compose
+	 */
 	static void composeTransitions ( ext::deque < sax::Token > & out, const RealTimeHeightDeterministicNPDA & automaton );
 
-	virtual object::ObjectBase * inc ( ) &&;
+	/**
+	 * @copydoc alib::GrammarBase::inc()
+	 */
+	virtual object::ObjectBase * inc ( ) && override;
 
+	/**
+	 * Type of normalized automaton.
+	 */
 	typedef RealTimeHeightDeterministicNPDA < > normalized_type;
 };
 
@@ -759,9 +1394,25 @@ object::ObjectBase* RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonTy
 
 namespace core {
 
+/**
+ * Helper class specifying constraints for the automaton's internal input alphabet component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, InputSymbolType, automaton::InputAlphabet > {
 public:
+	/**
+	 * Returns true if the symbol is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 *
+	 * \returns true if the symbol is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const InputSymbolType & symbol ) {
 		for ( const std::pair<const ext::pair<StateType, ext::variant < EpsilonType, InputSymbolType >>, ext::set<ext::pair<StateType, PushdownStoreSymbolType> > >& callTransition : automaton.getCallTransitions())
 			if (callTransition.first.second.template is < InputSymbolType >() && symbol == callTransition.first.second.template get < InputSymbolType >())
@@ -778,17 +1429,47 @@ public:
 		return false;
 	}
 
+	/**
+	 * Returns true as all symbols are possibly available to be elements of the input alphabet.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const InputSymbolType & ) {
 		return true;
 	}
 
+	/**
+	 * All symbols are valid as input symbols.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const InputSymbolType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal pushdown store alphabet component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, PushdownStoreSymbolType, automaton::PushdownStoreAlphabet > {
 public:
+	/**
+	 * Returns true if the symbol is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 *
+	 * \returns true if the symbol is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const PushdownStoreSymbolType & symbol ) {
 		if(automaton.getBottomOfTheStackSymbol() == symbol)
 			return true;
@@ -805,28 +1486,80 @@ public:
 		return false;
 	}
 
+	/**
+	 * Returns true as all symbols are possibly available to be elements of the pushdown store alphabet.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const PushdownStoreSymbolType & ) {
 		return true;
 	}
 
+	/**
+	 * All symbols are valid as pushdown store symbols.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const PushdownStoreSymbolType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal bottom of the stack symbol element.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class ElementConstraint< automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, PushdownStoreSymbolType, automaton::BottomOfTheStackSymbol > {
 public:
+	/**
+	 * Determines whether the bottom of the stack symbol is available in the automaton's pushdown store alphabet.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 *
+	 * \returns true if the pushdown store symbol is already in the pushdown store alphabet of the automaton
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const PushdownStoreSymbolType & symbol ) {
 		return automaton.template accessComponent < automaton::PushdownStoreAlphabet > ( ).get ( ).count ( symbol );
 	}
 
+	/**
+	 * All pushdown store symbols are valid as a bottom of the stack symbol of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param symbol the tested symbol
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const PushdownStoreSymbolType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal states component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, StateType, automaton::States > {
 public:
+	/**
+	 * Returns true if the state is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const StateType & state ) {
 		if ( automaton.getInitialStates ( ).count ( state ) )
 			return true;
@@ -864,40 +1597,114 @@ public:
 		return false;
 	}
 
+	/**
+	 * Returns true as all states are possibly available to be elements of the states.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 		return true;
 	}
 
+	/**
+	 * All states are valid as a state of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal final states component.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, StateType, automaton::FinalStates > {
 public:
+	/**
+	 * Returns true if the state is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 		return false;
 	}
 
+	/**
+	 * Determines whether the state is available in the automaton's states set.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is already in the set of states of the automaton
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const StateType & state ) {
 		return automaton.template accessComponent < automaton::States > ( ).get ( ).count ( state );
 	}
 
+	/**
+	 * All states are valid as a final state of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 	}
 };
 
+/**
+ * Helper class specifying constraints for the automaton's internal initial component element.
+ *
+ * \tparam InputSymbolType used for the terminal alphabet of the automaton.
+ * \tparam EpsilonSymbolType used for the epsilon in the automaton
+ * \tparam PushdownSymbolType used for the pushdown store alphabet of the automaton.
+ * \tparam StateType used for the terminal alphabet of the automaton.
+ */
 template < class InputSymbolType, class EpsilonType, class PushdownStoreSymbolType, class StateType >
 class SetConstraint< automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType >, StateType, automaton::InitialStates > {
 public:
+	/**
+	 * Returns true if the state is still used in some transition of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is used, false othervise
+	 */
 	static bool used ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 		return false;
 	}
 
+	/**
+	 * Determines whether the state is available in the automaton's states set.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 *
+	 * \returns true if the state is already in the set of states of the automaton
+	 */
 	static bool available ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > & automaton, const StateType & state ) {
 		return automaton.template accessComponent < automaton::States > ( ).get ( ).count ( state );
 	}
 
+	/**
+	 * All states are valid as an initial state of the automaton.
+	 *
+	 * \param automaton the tested automaton
+	 * \param state the tested state
+	 */
 	static void valid ( const automaton::RealTimeHeightDeterministicNPDA < InputSymbolType, EpsilonType, PushdownStoreSymbolType, StateType > &, const StateType & ) {
 	}
 };