Машины Мура и Мили
Конечные автоматы могут иметь выходы, соответствующие каждому переходу. Есть два типа конечных автоматов, которые генерируют выходные данные:
- Машина Мили
- Машина Мура
Машина Мили
Машина Мили - это конечный автомат, выход которого зависит как от текущего состояния, так и от текущего входа.
Его можно описать набором из 6 (Q, ∑, O, δ, X, q 0 ), где -
Q - конечный набор состояний.
∑ конечный набор символов, называемый входным алфавитом.
O конечный набор символов, называемый выходным алфавитом.
δ - входная переходная функция, где δ: Q × ∑ → Q
X - функция перехода выхода, где X: Q × ∑ → O
q0- начальное состояние, из которого обрабатывается любой ввод (q 0 ∈ Q).
Таблица состояний машины Mealy показана ниже -
Настоящее состояние | Следующее состояние | |||
---|---|---|---|---|
вход = 0 | input = 1 | |||
состояние | Вывод | состояние | Вывод | |
→ а | б | х 1 | c | х 1 |
б | б | х 2 | d | х 3 |
c | d | х 3 | c | х 1 |
d | d | х 3 | d | х 2 |
Диаграмма состояний вышеупомянутой машины Мили -
Машина Мура
Машина Мура - это конечный автомат, выходы которого зависят только от текущего состояния.
Машину Мура можно описать набором из 6 (Q, ∑, O, δ, X, q 0 ), где -
Q - конечный набор состояний.
∑ конечный набор символов, называемый входным алфавитом.
O конечный набор символов, называемый выходным алфавитом.
δ - входная переходная функция, где δ: Q × ∑ → Q
X - функция перехода выхода, где X: Q → O
q0- начальное состояние, из которого обрабатывается любой ввод (q 0 ∈ Q).
Таблица состояний машины Мура показана ниже -
Настоящее состояние | Следующее состояние | Вывод | |
---|---|---|---|
Вход = 0 | Вход = 1 | ||
→ а | б | c | х 2 |
б | б | d | х 1 |
c | c | d | х 2 |
d | d | d | х 3 |
Диаграмма состояний вышеупомянутой машины Мура -
Машина Мили против машины Мура
В следующей таблице выделены моменты, которые отличают машину Мили от машины Мура.
Машина Мили | Машина Мура |
---|---|
Выход зависит как от текущего состояния, так и от текущего входа. | Выход зависит только от текущего состояния. |
Как правило, у нее меньше состояний, чем у машины Мура. | Как правило, у него больше состояний, чем у Mealy Machine. |
Значение выходной функции является функцией переходов и изменений, когда выполняется входная логика для текущего состояния. | Значение выходной функции является функцией текущего состояния и изменений тактовых импульсов всякий раз, когда происходят изменения состояния. |
Аппараты Мили быстрее реагируют на вводимые данные. Обычно они реагируют в одном такте. | В машинах Мура для декодирования выходных сигналов требуется больше логики, что приводит к большим задержкам в цепи. Обычно они реагируют на один такт позже. |
Машина Мура в машину Мили
Алгоритм 4
Input - Машина Мура
Output - Мучная машина
Step 1 - Возьмите пустой формат таблицы переходов машины Мили.
Step 2 - Скопируйте все переходные состояния машины Мура в этот формат таблицы.
Step 3- Проверить текущие состояния и соответствующие им выходы в таблице состояний машины Мура; если для состояния Q i выходной сигнал равен m, скопируйте его в выходные столбцы таблицы состояний машины Мили, где бы Q i ни появлялся в следующем состоянии.
пример
Давайте рассмотрим следующую машину Мура -
Настоящее состояние | Следующее состояние | Вывод | |
---|---|---|---|
а = 0 | а = 1 | ||
→ а | d | б | 1 |
б | а | d | 0 |
c | c | c | 0 |
d | б | а | 1 |
Теперь применим алгоритм 4, чтобы преобразовать его в машину Мили.
Step 1 & 2 -
Настоящее состояние | Следующее состояние | |||
---|---|---|---|---|
а = 0 | а = 1 | |||
состояние | Вывод | состояние | Вывод | |
→ а | d | б | ||
б | а | d | ||
c | c | c | ||
d | б | а |
Step 3 -
Настоящее состояние | Следующее состояние | |||
---|---|---|---|---|
а = 0 | а = 1 | |||
состояние | Вывод | состояние | Вывод | |
=> а | d | 1 | б | 0 |
б | а | 1 | d | 1 |
c | c | 0 | c | 0 |
d | б | 0 | а | 1 |
Машина Мили к машине Мура
Алгоритм 5
Input - Мучная машина
Output - Машина Мура
Step 1- Рассчитайте количество различных выходов для каждого состояния (Q i ), которые доступны в таблице состояний машины Мили.
Step 2- Если все выходы Qi одинаковы, скопируйте состояние Q i . Если он имеет п различных выходов, ломают Q I в п состояний как Q в которомn = 0, 1, 2 .......
Step 3 - Если выход начального состояния равен 1, вставьте новое начальное состояние в начало, которое дает 0 выход.
пример
Давайте рассмотрим следующую машину Мили -
Настоящее состояние | Следующее состояние | |||
---|---|---|---|---|
а = 0 | а = 1 | |||
Следующее состояние | Вывод | Следующее состояние | Вывод | |
→ а | d | 0 | б | 1 |
б | а | 1 | d | 0 |
c | c | 1 | c | 0 |
d | б | 0 | а | 1 |
Здесь состояния «a» и «d» дают только 1 и 0 выходов соответственно, поэтому мы сохраняем состояния «a» и «d». Но состояния «b» и «c» производят разные выходные данные (1 и 0). Итак, делимb в b0, b1 и c в c0, c1.
Настоящее состояние | Следующее состояние | Вывод | |
---|---|---|---|
а = 0 | а = 1 | ||
→ а | d | б 1 | 1 |
б 0 | а | d | 0 |
б 1 | а | d | 1 |
c 0 | c 1 | С 0 | 0 |
c 1 | c 1 | С 0 | 1 |
d | б 0 | а | 0 |