Главная страница Случайная страница КАТЕГОРИИ: АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника |
Автоматов
Граф переходов представляет собой структуру, состоящую из вершин, изображаемых в виде малых кружков, и ориентированных дуг, изображаемых в виде линий между парами вершин и снабженных стрелками, указывающими направление от одной вершины к другой. Граф переходов, описывающий автомат с состояниями, содержит вершин, причем каждая вершина соответствует одному состоянию автомата; состояние, изображаемое вершиной, снабжается обозначением, соответствующим этому состоянию. Ориентированные дуги проводятся и обозначаются по следующему правилу. Пусть представляет собой множество значений для которых и пусть Если не пустое) множество, то дуга проводится из вершины в вершину , стрелка указывает направление из и обозначение дуги записывается в виде Каждый, член вида содержащийся в обозначении дуги, называется парой вход - выход. Изложенное правило построения графа переходов автомата иллюстрируется рис. 2.1. Это правило устанавливает взаимно однозначное соответствие между графом переходов и таблицей переходов для одного и того же автомата, так что, зная одно представление, всегда можно получить другое. Для примера на рис. 2.2 изображен граф переходов автомата построенный по таблице 2.2. Рис. 2.1. Обозначение дуги. Рис. 2.2. Автомат По построению графа дуга, направленная из вершины к вершине обозначается входными символами, которые вызывают переход автомата из состояния и выходными символами, которые выдаются автоматом при этом переходе. Для детерминированного, без ограничений на входе автомата каждый входной сигнал вызывает переход из каждого состояния только в одно другое состояние; следовательно, дуги, выходящие из любой данной вершины, содержат полное число p пар вход - выход, где p — мощность входного алфавита. Непосредственное преимущество графа переходов состоит в том, что он облегчает определение реакции автомата на входную последовательность любой длины. При данном начальном состоянии автомата М и входной последовательности реакция М легко определяется прослеживанием (в направлении стрелок) непрерывной последовательности дуг, которая начинается в вершине дуга которой соответствует паре вход - выход Выходная последовательность, которую выдает автомат М при подаче на него входной последовательности тогда будет состояние, в которое при этом переходит М, определяется по обозначению вершины, в которой заканчивается последовательность из дуг. Например, реакция автомата на входную последовательность при начальном состоянии 3 легко определяется по рис. 2.2 и будет 0000001. Последовательность состояний при этом будет 1, 3, 4, 4, 4, 5 и 1. Роль графа переходов в теории конечных автоматов подобна роли, которую играет графическое изображение схемы в теории электрических цепей. Граф переходов преобразует абстрактную модель в физическое изображение, усиливающее интуицию исследователя, и дает возможность ему «отчетливо представить» различные процессы и свойства, которые без такого изображения остались бы рядом сухих математических фактов. Как и в теории цепей, граф переходов удобно рассматривать как модель саму по себе, а символы, используемые в графе, — как абстрактные компоненты модели. Поэтому часто в дальнейшем мы будем граф, представляющий автомат М, называть «автоматом Ж», вершину, представляющую состояние — «состоянием и, наоборот, отождествлять абстрактные понятия с их геометрическими представлениями, имеющимися в графе переходов. Понятие изоморфизма конечных автоматов, введенное в § 2.4, в терминах графов переходов допускает очень простую интерпретацию: автоматы изоморфны один другому, если они имеют одинаковые графы, отличающиеся, быть может, только обозначением вершин. Таким образом, для того чтобы автомат М заменить изоморфным ему автоматом, надо просто изменить обозначение одной или нескольких вершин. Аналогично, чтобы получить семейство перестановок автомата М, достаточно переставить обозначения вершин всеми возможными способами.
8. Автоматы Мура, Мили и С-автоматы. Автомат Мура (абстрактный автомат второго рода) в теории вычислений — конечный автомат, выходное значение сигнала в котором зависит лишь от текущего состояния данного автомата, и не зависит напрямую, в отличие от автомата Мили, от входных значений.
Автомат Мура может быть определён как кортеж из 6 элементов, включающий: · множество внутренних состояний S (внутренний алфавит); · начальное состояние S 0; · множество входных сигналов X (входной алфавит); · множество выходных сигналов Y (выходной алфавит); · функция переходов Φ (z, x). Для любого автомата Мура существует эквивалентный ему автомат Мили и наоборот. Любой автомат Мура путём добавления ряда внутренних состояний может быть преобразован в автомат Мили. Способы задания: · Диаграмма — изображённый на плоскости ориентированный граф, вершины которого взаимно однозначно соответствуют состояниям автомата, а дуги — входным символам. · Таблица переходов-выходов, в ячейках которой для каждой пары значений аргументов х(t), s(t) проставляются будущие внутренние состояния s(t+1). Значения выходных сигналов y(t) представляются в отдельном столбце. Автомат Мили: конечный автомат, выходная последовательность которого (в отличие от автомата Мура) зависит от состояния автомата и входных сигналов. Это означает, что в графе состояний каждому ребру соответствует некоторое значение (выходной символ). В вершины графа автомата Мили записываются выходящие сигналы, а дугам графа приписывают условие перехода из одного состояния в другое, а также входящие сигналы. Автомат Мили — совокупность , где · — конечное непустое множество состояний автомата; · — конечное непустое множество входных символов; · — конечное непустое множество выходных символов; · — функция переходов, отображающая пары состояние/входной символ на соответствующее следующее состояние; · — функция выходов, отображающая пары состояние/входной символ на соответствующий выходной символ; · — начальное состояние. Кодировка автомата Мили: Вершина (операторная или логическая), стоящая после вершины " Начало", а также вход вершины " Конец" помечается символом S1, вершины, стоящие после операторных помечаются символом Sn (n=2, 3..). С-автомат: под абстрактным С-автоматом понимают математическую модель цифрового устройства, определяемую восьмикомпонентным вектором S = {A, Z, W, U,?,? 1,? 2, a1}, где А- множество состояний, Z- входной алфавит, W-выходной алфавит автомата Мили, U- выходной алфавит автомата Мура,? -функция переходов автомата,? 1- функция выходов автомата Мили,? 2- функция выходов автомата Мура, а1 – начальное состояние. Автомат без памяти (КС): Алфавит состояний такого автомата содержит единственную букву, поэтому понятие функции переходов вырождается и становится ненужным для описания работы автомата, т.е. выходной сигнал в данном такте зависит только от входного сигнала того же такта и никак не зависит от ранее принятых сигналов.
9. Эквивалентные автоматы, преобразования автоматов. Состояния q автомата М и q' автомата М' считаются эквивалентными, если оба автомата, получив одну и ту же (любую) входную последовательность символов, перерабатывают ее в одинаковую выходную последовательность. Автоматы М и М' называются эквивалентными, если для каждого состояния автомата М существует эквивалентное ему состояние автомата М' и наоборот. Другими словами, эквивалентные автоматы реализуют одинаковые преобразования, но могут иметь различное число внутренних состояний. Понятие эквивалентности состояний применимо и к одному автомату (формально можно считать, что М и М' совпадают). Для одного автомата эквивалентными будут различные состояния, через которые одна и та же входная последовательность символов преобразуется в одинаковую выходную. В связи с синтезом схем практический интерес представляет задача построения автомата, выполняющего заданный набор преобразований при минимальном числе внутренних состояний. Автомат, эквивалентный заданному и имеющий наименьшее из всех возможных число состояний называется минимальным. Задача построения минимального автомата называется задачей минимизации автомата. Ее решение осуществляется в два этапа: сначала устанавливаются все неэквивалентные состояния исходного автомата, а затем по ним стоится минимальный автомат. В свою очередь, для определения неэквивалентных состояний необходимо выявить классы эквивалентных состояний. Переход от А Мили к А Мура Прежде чем рассмотреть трансформацию автомата-Мили в автомат Мура, наложим на автомат Мили следующее ограничение: у автомата не должно быть преходящих состояний. Под преходящим будем понимать состояние, в которое при представлении автомата в виде графа не входит ни одна дуга, но которое имеет по крайней мере одну выходящую дугу (пример - состояние a1 на рис. 1-3). Итак, пусть задан автомат Мили
SA={AA, ZA, WA, A, A, a1A},
AA = {а1,:, аm,:, aM},
SB={AB, ZB, WB, B, B, a1B}, у которого
ZB= ZA = {z1,:, zf,:, zF},
Рассомотрим пример преобразования автомата Мили, изображенного на рис. 1-2, в автомат Мура. В автомате Мили Za={Z1, Z2}, Wa={W1, W2}, Aa= {A1, A2, A3}, а1A= а1, A и A определяются графом автомата. В эквивалентном автомате Мура ZB = ZA = {Z1, Z2}, WB = WA = {W1, W2}. 1. Построим множество AB, для чего найдем множество пар, порождаемых каждым состоянием автомата SA:
A1={(a1, W1), (a1, W2)} ={b1, b 2}; 2. C каждым состоянием, представляющем собой пару, отождествим выходной сигнал, являющийся вторым элементом этой пары: B(b1) = B (b3) = B(b4) = W1 3. Рассматривая каждую пару и каждую связь, получим: так как в автомате SA из состояния а1 есть переход под действием сигнала z1 в состояние а3 с выдачей сигнала W1, то из множества A1 = {b1, b2} порождаемых состоянием а1 в автомате Мура SB должен быть переход в состояние {a3, W1}=b4 под действием сигнала z1.
Аналогично с состоянием A1 должен быть переход в состояние {a1, W1} = b1 под действием сигнала z2 и так далее. В качестве начального состояния можно выбрать любую b1, b2 А1. Если сагналы bi заменить на аi, то получим стандартное представление автомата Мура.
Рассмотрим переход от автомата Мили к автомату Мура, у которого входное состояние является переходящим. Будем составлять множество состояний следующим образом: A1U A2U A3={(a2, W1) (a2, W2) (a3, W1) (a3, W2)} = {b2, b3, b4, b5}. К этим состояниям добавим пару (а1, -) = b1. Где " - " означает, что выходной сигнал в состоянии b1 не определен. Функцию переходов SB будем определять как и раньше.
В качестве начального состояния автомата Мура можно взять порождаемое им состояние. Методы взаимной транспозиции автоматов Мили и Мура показывают, что при переходе от автомата Мили к автомату Мура число состояний принципиально не меняется. В то время как при обратном переходе в автомат Мура число состояний, как правило, увеличивается. Вследствие транзитивности отношения эквивалентности два автомата Мили, первый из которых получен из автомата Мура, так же будут эквивалентны, но у второго автомата число состояний будет больше. Таким образом эквивалентные между собой автоматы могут иметь различное число состояний. В связи с чем и возникает задача нахождения минимального автомата в классе эквивалентных между собой автоматов. Существование для любого абстрактного автомата эквивалентного ему абстрактного автомата с минимальным числом внутренних состояний впервые было доказано Муром.
10. Абстрактный автомат. Соединение двух автоматов: параллельное
|