|  | 
| template<class SymbolType , class StateType1 , class StateType2 > | 
| static automaton::NFA< SymbolType, ext::pair< StateType1, StateType2 > > | intersection (const automaton::NFA< SymbolType, StateType1 > &first, const automaton::NFA< SymbolType, StateType2 > &second) | 
|  | 
| template<class SymbolType , class StateType1 , class StateType2 > | 
| static automaton::DFA< SymbolType, ext::pair< StateType1, StateType2 > > | intersection (const automaton::DFA< SymbolType, StateType1 > &first, const automaton::DFA< SymbolType, StateType2 > &second) | 
|  | 
| template<class SymbolType , class StateType1 , class StateType2 > | 
| static automaton::DFTA< SymbolType, ext::pair< StateType1, StateType2 > > | intersection (const automaton::DFTA< SymbolType, StateType1 > &first, const automaton::DFTA< SymbolType, StateType2 > &second) | 
|  | 
Intersection of two finite automata. For finite automata A1, A2, we create a finite automaton A such that L(A) = L(A1) \cap L(A2). This method utilizes epsilon transitions in finite automata (Melichar: Jazyky a překlady, 2.75).