Машины Мура и Мили

Конечные автоматы могут иметь выходы, соответствующие каждому переходу. Есть два типа конечных автоматов, которые генерируют выходные данные:

  • Машина Мили
  • Машина Мура

Машина Мили

Машина Мили - это конечный автомат, выход которого зависит как от текущего состояния, так и от текущего входа.

Его можно описать набором из 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