Студопедия

Главная страница Случайная страница

КАТЕГОРИИ:

АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника






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






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

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

Скінченним автоматом називають системуM =( S, I, O, f, g, s 0), у якійS, І, О - скінченні множини, af: S × I→ Sтаg: S × I→ O- функції, визначені на декартовому добуткуS × l.МножинуSназивають множиною станів, І- вхідним алфавітом, О-вихідним алфавітом, f- функцією переходів, g-функцією виходів, виділений елементs 0 S- початковим станом.

Елементи вхідного алфавіту називають вхідними символами ( входами ), а вихідного - вихідними символами ( виходами ).

Рівністьf(si, x)=s.означає, що у разі входу х автомат, який перебуває в станіsi, переходить у стан sj, а рівністьg(si, х)= y, - щов цьому разі на виході з'являється y; тутssssi, sj∈ S, х∈ I, y∈ О.

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

Таблиця 9.2

Стан F G
Вхід Вхід
0 1    
s 0 s 1 s 2 s 3 s 1 s 0 s 3 s 0 s 1 s 2 s 2 s 1 1 0 1 1 0 1 0 0

 

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

Ще один поширений і наочний спосіб задання автоматам орієнтований мультиграф, який називають діаграмою станів. Вершини графа відповідають станам; якщо f (si, xj)= sk та g (si, xj)= yr, та то із вершини si. у вершину sk веде дуга, на якій записані через кому хj та yr. Тут xjI, yr∈ О. Кратні дуги не обов'язкові; якщо є дві кратні дуги, то їх можна замінити однією, на якій написати обидві пари вхідний символ-вихідний символ.

Приклад 9.19. Діаграму станів для автомата, заданого табл. 9.2, зображено на рис. 9.6. ▲

Рис. 9.6

Для заданого скінченного автомата М його функція виходів g може бути визначена не тільки на множині I всіх вхідних символів (букв), а й на множині I * всіх вхідних ланцюжків (слів). Нехай вхідний ланцюжокα = x 1 x 2…хk. Тоді під час читання цього ланцюжкаавтомат спочатку переходить зі стану s 0 у стан s 1 де s 1= f (s 0, x 1)після цього у стан s 2 де s 2= f (s 1, x 2), і цей процес триває до досягнен­ня стану sk = f (sk- 1, xk). Звернемо увагу, що тут xk -останній символ вхід­ного ланцюжка. Ця послідовність переходів у нові стани формує вихід­ний ланцюжок ω = y 1 y 2yk де y 1= g (s 0, x 1) вихідним символом, який відповідає переходуз s 1 в s 2, y 2= g (s 1, x 2) - вихідним символом, який відпо­відає переходу з s 1 в s 2і цей процес триває до отримання вихідного символу yk = g (sk -1, xk). У загальному yj = g (sj -1, xj)для j =1, 2,.., k.. Отже, ми можемо розширити означення функції виходів на вхідні ланцюжки так, що g (α)=ω, де вихідний ланцюжок со відповідає вхідному ланцюжку α.

Приклад 9.20. Знайдемо вихідний ланцюжок, який видасть скінченний автомат з рис. 9.6, якщо вхідний ланцюжок 101001.

Автомат на виході видасть ланцюжок 011110. Послідовність станів і вихідних символів наведено у табл. 9.3. ▲

Таблиця 9.3

Вхід 101001 -
Стан Вихід s 0 s 0 s 1 s 0 s 1 s 3 s 1 0 1 1 1 1 0 -

Нехай М- скінченний автомат. Кожному вхідному ланцюжку α поставимо описаним вище способом у відповідність вихідний ланцюжок ω. Цю відповідність, яка відображає вхідні ланцюжки у вихідні ланцюжки, називаютьавтоматним відображенням, а такожавтоматним (абообмежено детермінованим) оператором, який реалізується автоматом М. Іноді говорять коротко - оператор М; якщо результатом застосування цього оператора до ланцюжка α є вихідний ланцюжок ω, то це позначають М (α)=ω. Кількість символів у ланцюжку α, як завжди, називають довжиною α і позначають |α | або l (α).

Автоматне відображення має дві властивості: 1) ланцюжки α та ω = М (α)мають однакову довжину: |α |=|ω | (властивість збере­ження довжини); 2) якщо α =α 1α 2 і M1 α 2)=ω 1ω 2 де |α 1|=|ω 1|, то М1)=ω 1, тобто образ відрізка довжини l дорівнює відрізку образу такої ж довжини. Властивість 2 відображає той факт, що автоматні оператори - це оператори без випередження, тобто оператори, які, переробляючи ланцюжок зліва направо, " не підглядають вперед": i -та буква вихідного ланцюжка залежить тільки від перших і букв вхідного ланцюжка. Приклад оператора з випередженням - опе­ратор, який ланцюжку α =х1х2..хk ставить у відповідність ланцюжок хk…х2х1; перша буква вихідного ланцюжка тут дорівнює останній букві вхідного ланцюжка. Зазначимо, що ці дві властивості не є достатніми умовами автоматності відображення: існують відобра­ження, які задовольняють умови 1та 2, але не реалізуються в скінченному автоматі.

Рис. 9.7

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

Приклад 9.21. Важливим елементом у багатьох пристроях є авто­мат одиничної затримки. Він видає на виході вхідний ланцюжок, затриманий на одиницю часу. Отже, якщо на вхід подано двійковий ланцюжок x 1 x 2.. xk, то на виході буде ланцюжок0 x 1 x 2.. xk -1

Такий автомат повинен мати два вхідні символи (нехай це будуть 0 та 1), початковий стан s 0 і пам'ятати, який з двох символів 0 або 1 був на вході у попередній момент. Отже, потрібно ще два стани: нехай автомат буде в стані s 1, якщо попереднім вхідним символом була 1, і в стані s 2, - якщо 0. На виході за початкового стану завжди буде 0 незалежно від входу. Кожний перехід зі стану s 1дає на виході 1, а зі стану s 2- 0. Діаграма станів цього автомата зображена на рис. 9.7. ▲

Приклад 9.22. Побудуємо скінченний автомат для додавання двох цілих додатних чисел у двійковій системі.

Нехай додаємо числа(хпх 1 х 0)2 та(упy 1 y 0)2. Спочатку додаємо розряди х0 та у0, у результаті отримуємо розряд сумиz0 та біт пере­несення с 0. Цей біт дорівнює 0 або 1. Далі розряди х1 та у1 додаємо разом з бітом перенесення c 0. Це дає розряд суми z 1 і біт перене­сення с1. Процедуру продовжуємо до стадії підсумовування розря­дів xn, yn та попереднього біта перенесеннясп-1; отримаємо розряд сумиzп і біт перенесеннясп, який дорівнює розряду сумиzп+1.

Таблиця 9.4

Стан F g
Вхід Вихід
               
s 0 s 0 s 0 s 0 s 1        
s 1 s 0 s 1 s 1 s 1        

 

 

Рис. 9.8

Вхідний алфавіт автомата складається з чотирьох символів: I ={00, 01, 10, 11}. Це необхідно для зображення можливих значень хi та уi - значень i -го розряду обох доданків. Вихідний алфавіт: O ={0, 1}. Множина станівS={s0, s1}. Станs0відповідає відсутності 1 перенесення з попереднього розряду, цей же стан початковий. Стан Sjвідповідає наявності 1 перенесення з попереднього роз­ряду. Розв'язок наведено у вигляді таблиці станів (табл. 9.4) і діаграми станів (рис. 9.8). ▲

Приклад 9.23. Побудуємо скінченний автомат, який видає на виході 1 тоді й лише тоді, коли на вході останніми трьома симво­лами були 1.

Цей автомат повинен мати три стани. Початковий стан s 0, цей же стан використовують для запам'ятовування випадку, коли попе­редній вхідний символ 0. Стан s 1відповідає випадку, коли попе­редній символ на вході 1, але символ перед ним - 0. Станs2запам'ятовує випадок двох поспіль вхідних 1. Отже, якщо автомат перейшов зі стануs1у станs2, то на вхід подано дві 1 поспіль. Вхід 1 у стані s 2 означає, що це була третя поспіль 1, і на виході видається 1. У всіх інших випадках на виході видається 0. Діаграма станів цього автомата зображена на рис. 9.9. ▲

Автомат з прикладу 9.23 подає мову, оскільки він видає на виході 1 тоді й лише тоді, коли вхідний ланцюжок (слово) має спеціальні властивості (в цьому прикладі мова складається з ланцюжків нулів та одиниць, які закінчуються трьома 1 поспіль).

Подання мов є одним з найважливіших застосувань скінченних автоматів.

 

Рис. 9.9

Автомати, які ми розглянули, називають автоматами Мілі (G. Mealy).Вперше їх уведено 1955 р. Є також інший тип авто­матів з виходом, так звані автомати Мура (Е. Moore), запроваджені 1956 р. У цих автоматах вихід визначається лише станом, тобто не залежить від вхідного сигналу.

У прикладі 9.23 описано, як автомат Мілі можна використати для задання мови. Проте з цією метою звичайно застосовують інший тип автоматів - скінченні автомати без виходу. Такі автомати мають множину заключних (або приймаючих) станів і допускають ланцю­жок тоді й лише тоді, коли цей ланцюжок переводить автомат без виходу із початкового стану у заключний стан.


Поделиться с друзьями:

mylektsii.su - Мои Лекции - 2015-2025 год. (0.007 сек.)Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав Пожаловаться на материал