Эквивалентность состояний ДКА — различия между версиями
(→См. также) |
|||
Строка 1: | Строка 1: | ||
+ | == Основные определения == | ||
+ | |||
{{Определение | {{Определение | ||
|definition = Два автомата <tex> \mathcal{A}_1 = \langle Q_1,\Sigma,\delta_1,s_{1}, T_1\subseteq Q_1 \rangle </tex> и <tex>\mathcal{A}_2 = \langle Q_2,\Sigma,\delta_2,s_{2}, T_2\subseteq Q_2 \rangle </tex> называются '''эквивалентными''', если они распознают один и тот же язык над алфавитом <tex>\Sigma</tex>, то есть <tex>\mathcal{L}(\mathcal{A}_1) = \mathcal{L}(\mathcal{A}_2)</tex>. | |definition = Два автомата <tex> \mathcal{A}_1 = \langle Q_1,\Sigma,\delta_1,s_{1}, T_1\subseteq Q_1 \rangle </tex> и <tex>\mathcal{A}_2 = \langle Q_2,\Sigma,\delta_2,s_{2}, T_2\subseteq Q_2 \rangle </tex> называются '''эквивалентными''', если они распознают один и тот же язык над алфавитом <tex>\Sigma</tex>, то есть <tex>\mathcal{L}(\mathcal{A}_1) = \mathcal{L}(\mathcal{A}_2)</tex>. | ||
Строка 42: | Строка 44: | ||
Псевдокод: | Псевдокод: | ||
− | bfs_equivalence_check() | + | bfs_equivalence_check(aut1, aut2) |
− | + | '''insert''' <tex>\{0, 0\}</tex> in <tex>Q </tex> | |
− | used1[0] | + | used1[0] <tex> \leftarrow </tex> true; |
− | while | + | used2[0] <tex> \leftarrow </tex> true; |
− | u | + | '''while''' <tex>Q \ne \varnothing </tex> |
− | v | + | u <tex> \leftarrow </tex> Q.front.first; |
− | + | v <tex> \leftarrow </tex> Q.front.second; | |
− | if(isTerminal1[u] != isTerminal2[v]) | + | pop(Q); |
− | return false; | + | '''if'''(isTerminal1[u] != isTerminal2[v]) |
− | for | + | '''return''' false; |
− | if(!used1[ | + | '''for''' <tex>i \in \Sigma</tex> |
− | + | '''if'''(!used1[aut1[u][i]] || !used2[aut2[v][i]]) | |
− | used1[ | + | '''insert''' <tex>\{</tex>aut1[u][i], aut2[v][i]<tex>\}</tex> in <tex>Q</tex> |
− | return true; | + | used1[aut1[u][i]] <tex> \leftarrow </tex> true; |
+ | used2[aut2[v][i]] <tex> \leftarrow </tex> true; | ||
+ | '''return''' true; | ||
Замечание: в данной реализации оба автомата обязательно должны иметь [[Детерминированные_конечные_автоматы#допускает|дьявольские состояния]]. | Замечание: в данной реализации оба автомата обязательно должны иметь [[Детерминированные_конечные_автоматы#допускает|дьявольские состояния]]. |
Версия 13:42, 18 октября 2014
Содержание
Основные определения
Определение: |
Два автомата | и называются эквивалентными, если они распознают один и тот же язык над алфавитом , то есть .
Определение: |
Слово различает два состояния и , если
|
Определение: |
Два состояния строки, которая их различает, то есть верно, что
| и называются эквивалентными , если не существует
Заметим, что эквивалентность состояний действительно является отношением эквивалентности. Так как (равносильность) является отношением эквивалентности и в детерминированном автомате всегда существует путь по любому слову, описанное нами отношение является отношением эквивалентности.
Лемма: |
, , , различает и . Тогда различает и . |
Доказательство: |
А значит, по условию различимости для и , |
Пример
Эти два автомата принимают слова из языка слов длины не меньше одного, состоящих из символов алфавита
. Стартовые и все допускающие состояния автоматов эквивалентны между собой.Проверка ДКА на эквивалентность
Заданы два автомата:
со стартовым состоянием и со стартовым состоянием соответственно. Нужно проверить их на эквивалентность.Проверка через минимизацию
Для этого построим автомат
Осталось лишь проверить на эквивалентность состояния и в полученном автомате. Их эквивалентность совпадает с эквивалентностью автоматов и . Для этого можно применить алгоритм минимизации ДКА, который разбивает все состояния на классы эквивалентности. Если состояния и нового автомата в одном классе эквивалентности - исходные автоматы эквивалентны.
Проверка через BFS
Алгоритм заключается в синхронном обходе автоматов в ширину, проверяя, что по пути сохраняются терминальные состояния.
Псевдокод:
bfs_equivalence_check(aut1, aut2) insertin used1[0] true; used2[0] true; while u Q.front.first; v Q.front.second; pop(Q); if(isTerminal1[u] != isTerminal2[v]) return false; for if(!used1[aut1[u][i]] || !used2[aut2[v][i]]) insert aut1[u][i], aut2[v][i] in used1[aut1[u][i]] true; used2[aut2[v][i]] true; return true;
Замечание: в данной реализации оба автомата обязательно должны иметь дьявольские состояния.
Источники информации
equivalence between two automata
См. также
Минимизация_ДКА,_алгоритм_за_O(n^2)_с_построением_пар_различимых_состояний