Минимизация автоматов
С утилитарной точки зрения интерес представляет только зависимость между входами и выходами автомата, а роль его состояний сводится исключительно к участию в формировании этих зависимостей в качестве промежуточных переменных. Следовательно, любая совокупность состояний, обеспвчивающая требуемые зависимости между входом и выходом, может быть выбрана в качестве множества состояний автомата. В то же время этот выбор естественно подчинить определенным целям: минимизации числа состояний или оптимизации автомата в каком-либо смысле. Следует иметь в виду, что с уменьшением состояний сокращается и количество требуемых элементов памяти, но это может привести к усложнению комбинационного автомата. Поэтому синтез наиболее экономичного автомата требует поиска удачного компромисса между сложностью комбинационной и запоминающих частей.
Минимизация числа состояний полных автоматов связана с отношением эквивалентности. Пусть автоматы М1 и М2 находящиеся в начальных состояниях si и sj (обозначения М1 и М2 могут относиться к одному и тому же автомату), под воздействием любой входной последовательности выдают одинаковые выходные последовательности, т. е. автоматы М1 и М2 в данных состояниях si и sj неразличимы по внешним выходам. Такое отношение между состояниями одного и того жеили двух различных автоматов обладает свойствами рефлексивности, симметричности и транзитивности, следовательно, оно является отношением эквивалентности состояний. Если состояния не эквивалентны, то их называют различимыми. Легко доказать справедливость следующих положений:
1) состояния si и sj автомата явно различимы, если различаются соответствующие им строки в таблице выходов;
2) состояния si и sj автомата явно эквивалентны, если соответствующие им строки в таблице переходов и таблице выходов одинаковы или становятся одинаковыми при замене каждого номера si на номер sj (или наоборот).
Например, рассмотрим автомат, заданный таблицей переходов.
Таблица 7
x(n) s(n) | |||
1/1 | 4/0 | 4/1 | |
5/0 | 1/1 | 4/1 | |
1/0 | 1/1 | 6/1 | |
3/1 | 2/0 | 0/1 | |
1/1 | 4/0 | 4/1 | |
1/0 | 5/1 | 4/1 | |
5/0 | 5/1 | 2/1 |
Из этой таблицы следует, что состояния из множества {0, 3, 4} являются явно различимыми с любым состоянием из множества {1, 2, 5, 6}. Поэтому следует искать эквивалентные состояния только среди элементов, принадлежащих одному из этих множеств. Так как строки 0 и 4 одинаковы, а строки 1 и 5 становятся одинаковыми при замене в числителе цифры 1 на 5 (или 5 на 1), то явно эквивалентными являются пары состояний {0, 4} и {1, 5}.
Объединяя эквивалентные состояния в автомате М1, получаем эквивалентный автомат М2 с меньшим числом состояний, который в любом состоянии нельзя отличить от исходного, наблюдая сигналы на выходах. Очевидно, что автоматы М1 и М2 являются эквивалентными, если каждому состоянию si автомата М1 соответствует, по крайней мере, одно эквивалентное ему состояние автомата М2 и если каждому состоянию sj автомата М2 соответствует хотя бы одно эквивалентное ему состояние автомата М1.
Эквивалентные состояния, например, si и sj удобно объединять по общей таблице переходов, вычеркивая строку sj и заменяя везде в числителе числа sj на si. После объединения пар явно эквивалентных состояний может оказаться возможным снова обнаружить такие состояния, которые также объединяются с помощью аналогичной процедуры. В результате последовательного объединения приходим к сокращенной таблице переходов, которой, соответствует сокращенный автомат, эквивалентный исходному, но имеющий меньшее число состояний. Так, для рассматриваемого примера получаем последовательно автомат М2, эквивалентный автомату М1 и автомат М3, эквивалентный автомату М2.
Таблица 8
x(n) s(n) | |||
0(4) | 1/1 | 0/0 | 0/1 |
1(5) | 1/0 | 1/1 | 0/1 |
1/0 | 1/1 | 6/1 | |
3/1 | 2/0 | 0/1 | |
1/0 | 1/1 | 2/1 |
Таблица 9
x(n) s(n) | |||
0(4) | 1/1 | 0/0 | 0/1 |
1(5) | 1/0 | 1/1 | 0/1 |
2(6) | 1/0 | 1/1 | 2/1 |
3/1 | 2/0 | 0/1 |
Табл. 8 соответствует объединению пар эквивалентных состояний {0,4} и {1, 5}, а табл. 9 – объединению пары {2, 6}. Сокращенный автомат содержит только четыре состояния.