Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
38_Skinchenni_avtomati.doc
Скачиваний:
12
Добавлен:
03.09.2018
Размер:
189.95 Кб
Скачать

236

Дискретна Математика :: Скінченні автомати

Тема 38. Скінченні автомати

38.1. Скінченні автомати з виходом

Означення 38.1. Скінченним автоматом називають систему M = (S, I, O, f, g, s0), у якій S – скінченна множина станів, I – скінченна множина, яку називають вхідним алфавітом, O – скінченна множина, яку називають вихідним алфавітом, f: SISфункція переходів, gSI  Oфункція виходів, s0  S – виділений елемент, який називають початковим станом.

Елементи вхідного алфавіту називають вхідними символами, або входами, а вихідного – вихідними символами, або виходами. Рівність f(six) = sj означає, що в разі входу x автомат, який перебуває в стані si, переходить у стан sj, а рівність g(six) = y – що в цьому разі на виході з’являється y; тут si, sjS, xI, yO.

Оскільки функції f і g означено на скінченних множинах, то їх можна задавати таблицями. Зазвичай дві таблиці зводять у таблицю станів. Вона містить значення функції переходів f і функції виходів g для всіх пар (s, x), де sS, xI.

Наприклад, у табл. 38.1 задано функції переходів і виходів для автомата з множиною станів S = {s0, s1, s2, s3} та вхідним і вихідним алфавітами I = {0, 1}, O = {0, 1}.

Стан

f

g

Вхід

Вхід

0

1

0

1

s0

s1

s0

1

0

s1

s3

s0

1

1

s2

s1

s2

0

1

s3

s2

s1

0

0

Табл. 38.1.

Ще один поширений і наочний спосіб подання автомата  за допомогою орієнтованого мультиграфа, який називають діаграмою станів. Вершини графа відповідають станам; якщо f(si, xj) = sk та g(si, xj) = yr, то з вершини si у вершину sk веде дуга з позначкою xj, yr. Тут xj I, yr  O.Діаграму станів для автомата, заданого табл. 38.1, показано на рис. 38.1.

Рис. 38.1.

Для автомата M його функцію виходів g можна означити не тільки на множині I всіх вхідних символів (букв), а й на множині I* всіх вхідних ланцюжків (слів). Розглянемо вхідний ланцюжок  = x1x2xk. Під час його обробки автомат спочатку переходить зі стану s0 в стан s1, де s1f(s0x1), потім у стан s2, де s2 = f(s1, x2), і цей процес триває до досягнення стану sk = f(sk–1, xk). Тут xk – останній символ вхідного ланцюжка. Ця послідовність переходів у нові стани формує вихідний ланцюжок  = y1y2yk, де y1 = g(s0x1) – вихідний символ, який відповідає переходу з s0 в s1, y2 = g(s1x2) – вихідний символ, що відповідає переходу з s1 в s2, і так до отримання вихідного символу yk = g(sk–1xk). Загалом yj = g(sj–1xj) для j = 1, 2, ..., k. Отже, ми можемо розширити означення функції виходів на вхідні ланцюжки так, що g(a) = , де вихідний ланцюжок відповідає вхідному ланцюжку .

Знайдемо вихідний ланцюжок, який видає скінченний автомат, зображений на рис. 38.1, якщо вхідний ланцюжок — 101001. Автомат видає на виході ланцюжок 011110. Послідовність його станів і вихідних символів наведено в табл. 38.2.

Вхід

1

0

1

0

0

1

Стан

s0

s0

s1

s0

s1

s3

Вихід

0

1

1

1

1

0

Новий стан

s0

s1

s0

s1

s3

s1

Табл. 38.2.

Означення 38.2. Відповідність, яка відображає вхідні ланцюжки автомата M у вихідні ланцюжки описаним вище способом, називають автоматним відображенням, а також автоматним оператором M.

Якщо результат застосування цього оператора до ланцюжка  вихідний ланцюжок , то це позначають M() = . Кількість символів у ланцюжку , як завжди, називають довжиною ланцюжка та позначають ||чи l().

Автоматне відображення має дві властивості.

  1. Ланцюжки та = M() мають однакову довжину: || = || (збереження довжини).

  2. Якщо = 12 й M(12) = 12, де |1| = |1|, то M(1) = 1, тобто образ відрізка довжиною l дорівнює відрізку образу з такою самою довжиною.

Властивість 2 означає, що автоматні оператори  це оператори без випередження, тобто такі, котрі, обробляючи ланцюжок зліва направо, “не підглядають уперед”: i-та буква вихідного ланцюжка залежить тільки від перших i букв вхідного ланцюжка. Приклад оператора з випередженням  той, який ланцюжку  = x1x2xk ставить у відповідність ланцюжок xkx1x2, перша буква вихідного ланцюжка тут дорівнює останній букві вхідного ланцюжка. Зазначимо, що ці дві властивості  це не достатні умови автоматності відображення: існують відображення, які задовольняють умови 1 і 2, але не реалізовані в скінченному автоматі.

Розглянемо деякі корисні приклади скінченних автоматів, які свідчать, що стани скінченного автомата дають змогу застосовувати їх як скінченну пам'ять. Стани можна використовувати для запам'ятовування ситуацій або символів, які читає автомат. Проте через скінченну множину станів скінченні автомати не можна використовувати в деяких важливих застосуваннях.

Побудуємо скінченний автомат для додавання двох цілих додатних чисел у двійковій системі. Візьмемо числа (xnx1x0)2 та (yny1y0)2. Додавши розряди x0 та y0, отримаємо розряд суми z0 та біт перенесення c0, який дорівнює 0 чи 1. Потім додамо розряди x1та y1 і біт перенесення c0. Одержимо розряд суми z1 та біт перенесення c1. Процедуру продовжуємо до стадії підсумування розрядів xn та yn і попереднього біта перенесення cn-1; отримаємо розряд суми zn і біт перенесення cn, який дорівнює розряду суми zn+1.

Вхідний алфавіт автомата складається з чотирьох символів: I= {00, 01, 10, 11}. Вони потрібні для подання можливих значень xi й yi i-го розряду обох доданків. Вихідний алфавіт O = {0, 1}, множина станів S = {s0s1}. Стан s0 відповідає ситуації, коли немає одиниці перенесення з попереднього розряду; цей стан початковий. Стан s1 відповідає наявності одиниці перенесення з попереднього розряду. Розв’язок наведено у вигляді таблиці станів (табл. 38.3) та діаграми станів (рис. 38.2).

Стан

f

g

Вхід

Вхід

00

01

10

11

00

01

10

11

s0

s0

s0

s0

s1

0

1

1

0

s1

s0

s1

s1

s1

1

0

0

1

Табл. 38.3.

Рис. 38.2.

Розглянуті автомати називають автоматами Мілі. Уперше їх уведено 1955 р. Є також інший тип автоматів із виходом – так звані автомати Мура, запроваджені 1956 р. У цих автоматах вихід залежить лише від стану, а не від вхідного сигналу.

Автомати Мілі можна використовувати для розпізнавання мови. Проте для цього зазвичай використовують інший тип автоматів – скінченні автомати без виходу.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]