Теория вычислительных процессов
Программа как формализованное описание процесса обработки данных. Интерпретация стандартных схем программ. Синтаксические и семантические свойства программ. Функции и графы. Свойства и виды стандартных схем программ. Языки формальной спецификации.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | курс лекций |
Язык | русский |
Дата добавления | 03.03.2012 |
Размер файла | 574,0 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Введение
Следуя А. П. Ершову, мы употребляем термин «теоретическое программирование» в качестве названия математической дисциплины, изучающей синтаксические и семантические свойства программ, их структуру, преобразования, процесс их составления и исполнения. Это словосочетание построено по аналогии с названиями таких наук, как теоретическая физика, теоретическая механика и т. д. В такой аналогии есть глубокий смысл: во всех случаях теоретическая научная дисциплина изучает фундаментальные понятия и законы основной науки и на основании обнаруженных закономерностей строит более частные математические модели исследуемых объектов, на которых ставит и решает прикладные задачи. В нашем случае ситуация усложняется еще тем, что объект моделирования - программа - уже представляет собой абстрактный объект.
В настоящее время сложились следующие основные направления исследований теоретического программирования.
Математические основы программирования. Основная цель исследований - развитие математического аппарата, ориентированного на теоретическое программирование, разработка общей теории машинных вычислений. Эта теория тесно соприкасается с теорией алгоритмов и вычислимых функций, теорией автоматов и формальных языков, логикой, алгеброй, с теорией сложности вычислений.
Теория схем программ. В этих работах внимание концентрируется на изучении структурных свойств и преобразований программ, а именно тех, которые отличают программы от других способов задания алгоритмов. Главным объектом исследования становится схема программы - математическая модель программы, в которой с той или иной степенью детализации отражено строение программы, взаимодействие составляющих ее компонентов.
Семантическая теория программ. Семантика программы или отдельных конструкций языков программирования - это их смысл, математический смысл для программиста и описание функционирования для машины. Этот раздел теоретического программирования изучает методы формального описания семантики программ, семантические методы преобразования и доказательства утверждений о программах. В частности, работы по методам проверки семантической правильности программ нацелены на автоматизацию их отладки и автоматический синтез программ.
Теория вычислительных процессов и структур (теория параллельных вычислений). Исследования в этой области направлены на разработку и обоснование новых методов программирования, прежде всего методов программирования параллельных процессов. В частности, изучаются модели, структуры и функционирование операционных систем, методы распараллеливания алгоритмов и программ, ведется поиск новых архитектурных принципов конструирования вычислительных машин и систем на основе результатов и рекомендаций теоретического программирования и вычислительной математики.
Прикладные задачи теоретического программирования. Сюда в первую очередь относятся разработка и обоснование алгоритмов трансляции и алгоритмов автоматической оптимизации программ.
Две дисциплины государственного стандарта специальности 220400 - Программное обеспечение вычислительной техники и автоматизированных систем - «Теория языков программирования и методы трансляции» и «Теория вычислительных процессов» рассматривают основы теоретического программирования. Первая дисциплина охватывает первый и последний пункты нашей, не претендующей на классификационную строгость и полноту, рубрикации. Вторая дисциплина, составляющая предмет настоящего курса, раскрывает пункты 2 - 4.
0.1 Программа как формализованное описание процесса обработки данных
Целью программирования является описание процессов обработки данных (в дальнейшем - просто процессов). Данные - это представление фактов и идей в формализованном виде, пригодном для передачи и переработке в некоем процессе, а информация - это смысл, который придается данным при их представлении. Обработка данных - это выполнение систематической последовательности действий с данными. Данные представляются и хранятся на носителях данных. Совокупность носителей данных, используемых при какой-либо обработке данных, будем называть информационной средой. Набор данных, содержащихся в какой-либо момент в информационной среде, будем называть состоянием этой информационной среды. Процесс можно определить как последовательность сменяющих друг друга состояний некоторой информационной среды.
Описать процесс - значит определить последовательность состояний заданной информационной среды. Если мы хотим, чтобы по заданному описанию требуемый процесс порождался автоматически на компьютере, необходимо, чтобы это описание было формализованным. Такое описание называется программой. С другой стороны, программа должна быть понятной и человеку, так как и при разработке программ, и при их использовании часто приходится выяснять, какой именно процесс она порождает. Поэтому программа составляется на понятном человеку формализованном языке программирования, с которого она автоматически переводится на язык соответствующего компьютера с помощью другой программы, называемой транслятором. Программисту, прежде чем составить программу, приходится проделывать большую подготовительную работу по уточнению постановки задачи, выбору метода ее решения, выяснению специфики применения требуемой программы, прояснению общей организации разрабатываемой программы и многое другое.
0.2 Правильная программа и надежная программа
Под «программой» часто понимают правильную программу, т.е. программу, не содержащую ошибок, соответствующую спецификации и дающую возможность формального вывода программы из формального набора предпосылок. Однако понятие ошибки в программе трактуется программистами неоднозначно. Будем считать, что в программе имеется ошибка, если она не выполняет того, что разумно ожидать от нее на основании документации по применению программы. Следовательно, правильнее говорить о несогласованности между программами и документацией по их применению.
В связи с тем, что задание на программу обычно формулируется не формально, а также из-за неформализованности понятия ошибки в программе, нельзя доказать формальными методами (математически) правильность программы. Нельзя доказать правильность программы и тестированием: как указал Дейкстра, тестирование может лишь продемонстрировать наличие в программе ошибки.
Альтернативой правильной программы является надежная программа. Надежность программы - это ее способность безотказно выполнять определенные функции при заданных условиях в течение заданного периода времени с достаточно большой вероятностью. При этом под отказом в программе понимают проявление в нем ошибки. Таким образом, надежная программа не исключает наличия в ней ошибок - важно лишь, чтобы эти ошибки при практическом применении этой программы в заданных условиях проявлялись достаточно редко. Убедиться, что программа обладает таким свойством можно при его испытании путем тестирования, а также при практическом применении. Таким образом, фактически мы можем разрабатывать лишь надежные, а не правильные программы.
Разрабатываемая программа может обладать различной степенью надежности. Как измерять эту степень? Так же как в технике, степень надежности можно характеризовать вероятностью работы программы без отказа в течение определенного периода времени. Однако в силу специфических особенностей программ определение этой вероятности наталкивается на ряд трудностей по сравнению с решением этой задачи в технике.
При оценке степени надежности программ следует также учитывать последствия каждого отказа. Некоторые ошибки в программах могут вызывать лишь некоторые неудобства при его применении, тогда как другие ошибки могут иметь катастрофические последствия, например, угрожать человеческой жизни. Поэтому для оценки надежности программных средств иногда используют дополнительные показатели, учитывающие стоимость (вред) для пользователя каждого отказа.
1. Схемы программ
1.1 Краткое математическое предисловие
1.1.1 Функции и графы
Ведем некоторые соглашения об обозначениях элементов теории множеств и логики.
Множество - есть набор несовпадающих объектов, которые мы будем задавать явным перечислением, и заключать в фигурные скобки. Например: D - множество дней недели:
D = { Пн, Вт, Ср, Чт, Пт, Сб, Вс }, D1 = { Вт, Ср, Чт, Пн, Сб, Пт, Вс }.
D и D1 эквивалентны, т.е. порядок элементов не важен.
Будем использовать обозначения:
x О A - x есть элемент и принадлежит множеству A; x О ?A - x не является элементом множества А.
Для бесконечных множеств метод перечисления элементов множества не применим, для этого используется характеристическое свойство А = {x | p(x)}, где х - переменная, значениями которой являются некоторые объекты, а р - свойство тех и только тех значений х, которые являются элементами задаваемого множества.
Пустое множество - множество, которое не содержит ни одного элемента, обозначается O ?или {}.
Если каждый элемент множества А является элементом множества В, то множество А является подмножеством множества В, будем писать A О B.
Если хотя бы один элемент множества А не является элементом множества В, то множество А не является подмножеством множества В и это записывается А О В.
Декартовым произведением А1 О А2 О … О Аn множеств А1, А2 … и Аn называется множество {(a1, a2, …, an) | a1 О A1, a2 О A2, , an О An}, а An обозначает А О А О … О А (n раз).
Функцией, отображающей множество Х во множество Y (обозначение F: X > Y), называется множество F Н X хY такое, что для любых пар (x, y)?F и (x' y') F из x = x' следует, что y = y'.
Множество {x | (x, y) Н F} - область определения функции F (или множество значений ее аргумента); множество {y | (x, y) Н F} - область значений функции F.
Функцию F: X > Y называют n-местной функцией над множеством А, если Y = A и X = An.
Предикатом называют функцию, областью значений которой является множество символов-цифр {0, 1}. При этом говорят, что предикат P: X > {0, 1} истинен для x Н X, если P(x) = 1, и ложен, если P(x) = 0. Отношение на множестве Х - это двухместный предикат P: X2 > {0, 1}.
Алфавитом называют непустое конечное множество символов. Например, V1 = {a, b}, V2 = {0, 1}, V3 = {a, +, 1, =} - алфавиты. Словом в алфавите V называется конечный объект, получаемый выписыванием одного за другим символов V, например, а + 1 = 1 + а - слово в алфавите V3, 101011 - слово в алфавите V2, abaab - слово в алфавите V1. Длина слова - число символов в нем, пустое слово не содержит ни одного символа.
Множество всех слов в алфавите V обозначается V*.
n-местной словарной функцией над алфавитом V называют n-местную функцию над V*, т. е. функцию из V* О V* О … О V* (n раз) в V*.
Направленным графом называется тройка G = (V, E, Ф), где V - множество вершин, Е - множество дуг, а Ф - функция из Е в (VО{?})2 , ? О V. Дуга е называется входом графа, если Ф(е) = (w, u), для u О VИ{?}; внутренней, если Ф(е) = (u1, u2) для u1,--u2 О V; выходом, если Ф(е) = (w, ?), для u u Vu{?}. Дуга е, являющаяся одновременно и входом и выходом графа, называется висячей; для нее Ф(е) = (u, ?). Дуги, не являющиеся внутренними, называются также свободными.
Рисунок 1.1.
Говорят, что дуга е инцидентна вершине u, если е выходит из u или ведет в u. Две дуги смежны, если существует хотя бы одна инцидентная им обеим вершина. Вершина u называется наследником вершины u', если в графе имеется хотя бы одна такая дуга, что Ф(е) = (u, ? ).
Изображенный на рисунке 1.1 граф G1 содержит 4 вершины, 8 дуг. Дуга е1 - входная, дуга е6 - выходная, дуга е8 - висячая, остальные дуги внутренние; вершины ? 1 и ? 3 наследники вершины ? 1.
Путем в графе G называется последовательность …?iei?i+1… дуг и вершин, такая, что для всех i Ф(еi) = (ui,--ui+1). Образом пути называется слово, составленное из пометок проходимых дуг и вершин.
Две вершины u1,--u2 графа G называются связанными, если u1 = u2 или существует маршрут е1, …,еn графа G такой, что дуга е1 инцидентна вершине u1, а дуга еn - вершине u2.
1.1.2 Вычислимость и разрешимость
Данное в п. 1.1.1. определение функции не содержит указаний о том, как для заданных значений аргументов получить соответствующие значения функции. Было бы практичнее переформулировать это определение таким образом, чтобы оно содержало конструктивную процедуру, или алгоритм, нахождения значений функции. Однако такое определение уже приведенного выше, т. е. определяет лишь некоторый подкласс функций, которые называют вычислимыми функциями.
Тьюринг в середине 30-х годов формализовал способ получения значений вычислимой функции с помощью абстрактной «математической машины», вычисляющей значения функции по значениям ее аргументов. Конкретная машина Тьюринга задает конкретную вычислимую функцию и его гипотеза (тезис) состояла в том, что каждая функция, для которой существует алгоритм нахождения ее значений, представима некоторой машиной Тьюринга, т. е. является вычислимой. Тезис Тьюринга не может быть доказан, так как наряду с формальным понятием вычислимой функции он содержит эмпирическое понятие алгоритма. Однако интуиция, отсутствие опровергающих примеров и равносильность различных формализаций вычислимости убеждают в справедливости этого тезиса.
Машина Тьюринга Т задает словарную функцию над некоторым алфавитом V и представляет собой описание машины -- набор (F, Q, q0, #, I) - и правило функционирования, общее для всех машин, где
V -- алфавит машины;
Q -- конечное непустое множество символов, называемых состояниями машины
(Q З V =Ж);
q0 -- выделенный элемент множества Q, называемый начальным состоянием;
# -- специальный «пустой» символ, не принадлежащий ни V, ни Q;
I -- программа машины.
Программа машины -- это конечное множество слов вида qa ® q'a'd, называемых командами, где q, q' О Q, a, a' О V И {#}; ® -- вспомогательный символ-разделитель; d -- элемент множества {l, r, р}, содержащего три специальных символа, которых нет ни в V, ни в Q. Предполагается также, что в программе I никакие две команды не могут иметь одинаковую пару первых двух символов.
Правило функционирования поясним неформально на распространенной «физической» модели машины Тьюринга. Машина состоит из потенциально бесконечной (в обе стороны) ленты, управления и головки, перемещаемой вдоль ленты (см. рисунок). Лента разбита на клетки, которые могут содержать символы из алфавита V или быть пустыми, т. е. содержать символ #. Управление на каждом шаге работы машины находится в одном из состояний из Q, расшифровывает программу, которая однозначно определяет поведение машины и управляет головкой. Головка в каждый момент расположена против некоторой клетки ленты и может считывать символы с ленты, записывать их на ленту и перемещаться в обе стороны вдоль ленты. Машина функционирует следующим образом. В начальный момент на ленте записано некоторое слово из V, а управление находится в начальном состоянии q0. Начальное слово, равно как и слова, появляющиеся в процессе работы машины, ограничено с двух сторон пустыми символами #. Головка обозревает крайний слева символ заданного слова.
Работа машины состоит в повторении следующего цикла элементарных действий:
1) считывание символа, находящегося против головки;
2) поиск применимой команды, а именно той команды qa ® q'a'd, в которой q -- текущее состояние управления, а -- считанный символ;
3) выполнение найденной команды, состоящее в переводе управления в новое состояние q', записи в обозреваемую головкой клетку символа а' (вместо стираемого символа а) и последующем перемещении головки вправо, если d = r, влево, если d = I, или сохранении ее в том же положении, если d = р.
Машина останавливается в том и только в том случае, если на очередном шаге ни одна из команд не применима. Результат работы остановившейся машины -- заключительное слово на ленте.
Машина Тьюринга, перерабатывая начальные слова на ленте в заключительные, задает словарную функцию, для которой начальные слова - значения аргумента, заключительные - значения функции. (Для представления n-местной функции начальное слово на ленте имеет вид #a1 #a2 # … #an #, где подслова a1, a2,…, an не содержат символа #. При интерпретации заключительного слова на ленте как значения функции символ # игнорируется). Если машина не останавливается, начав работу с некоторым словом на ленте, то функция, задаваемая машиной, считается неопределенной для этого слова. Таким образом, машина Тьюринга Т задает частичную функцию FT и способ вычисления ее значений. Хотя машины Тьюринга оперируют со словами, они могут задавать и числовые функции в силу установленной выше связи между словами и числами.
По определению, функция F является (частично) вычислимой, если существует машина Тьюринга Т такая, что FT = F. Говорят также, что для функции F существует (частичный) алгоритм вычисления ее значений, задаваемый машиной Т.
Для машины Тьюринга, как и для всех других формальных способов задания алгоритмов, включая программы для ЭВМ, характерны следующие свойства:
1) конструктивность -- машина Тьюринга представляет собой конечный объект, построенный по определенным правилам из базовых объектов;
2) конечность -- процесс нахождения значений функции для тех значений аргументов, для которых она определена, состоит из конечного числа шагов;
3) однозначность -- результат работы машины единственным образом определяется начальным словом;
4) массовость -- машина работает с любым начальным словом на ленте, составленным из символов ее алфавита.
Машина Тьюринга однозначно задается своей программой. Если упорядочить ее команды и закодировать последовательность команд словом в алфавите машины Тьюринга, то можно получить ее описание в собственном алфавите. Заметим, что одной и той же машине Тьюринга соответствуют различные словарные представления в ее алфавите в зависимости от выбора упорядочений множеств Q, V, I, но по любому из этих представлений программа машины восстанавливается однозначно.
Изучая свойства программ и их математических абстракций - схем программ, мы ставим целью автоматизацию программирования, в том числе автоматический анализ свойств программ и их преобразования, осуществляемые с помощью других, специальных программ. Поэтому нас интересуют алгоритмы, которые могли бы по любой предъявленной программе установить, завершит ли она работу или будет «циклить», дают ли две программы, исходная и оптимизированная, один и тот же результат, является ли программа синтаксически правильной и т. д.
Массовые алгоритмические проблемы формулируются следующим образом. Необходимо указать алгоритм, который бы определял, обладает ли предъявленный объект из некоторого класса объектов интересующим нас свойством, принадлежит ли он множеству М всех объектов, обладающих этим свойством. Если существует такой частичный алгоритм, то говорят, что множество перечислимо, а поставленная массовая алгоритмическая проблема частично разрешима. Если этот алгоритм к тому же всюду определен, то множество М разрешимо и поставленная проблема также разрешима. Существуют неразрешимые проблемы и даже проблемы, которые не являются частично разрешимыми, что свидетельствует о существовании невычислимых функций.
Пусть V - алфавит, М Н V - множество слов в V.
Характеристической функцией множества М называется предикат FM: V* > {0, 1}, всюду определенный на V*: FM (а) = 1, если а Н М, и FM (а) = 0, если а Н М.
Частичная характеристическая функция множества М - это функция НМ: V* > {1}, определенная только для слов из М и имеющая вид НM (а) = 1 для всех а Н М.
Множество М называется разрешимым, если его характеристическая функция вычислима. Множество М перечислимо, если его частичная характеристическая функция вычислима. Разрешимость множества М означает, что существует всегда останавливающаяся (оканчивающая работу за конечное время) машина Тьюринга, позволяющая для любого слова в алфавите V через конечное число шагов установить, принадлежит ли это слово множеству М или нет. Перечислимость множества М означает, что существует машина Тьюринга, которая останавливается в том и только том случае, если предъявленное слово принадлежит множеству М.
Приведем без доказательства несколько важных теорем.
Теорема (Пост). Множество М Н V* разрешимо тогда и только тогда, когда М и его дополнение М' = V*\M перечислимы.
Машина Тьюринга, начав работу, или останавливается, или работает бесконечно. Проблема остановки формулируется так. Пусть М - множество всех пар слов в алфавите V, в каждой паре первое слово - словарное представление некоторой машины Тьюринга, второе - такое слово, что эта машина останавливается, начав работу над ним. Является ли множество М неразрешимым.
Теорема (Тьюринг). Проблема остановки машины Тьюринга неразрешима.
Последняя теорема демонстрирует существование невычислимых функций. Из тезиса Тьюринга следует, что для неразрешимых проблем нельзя построить алгоритм, который решал бы их, например, с помощью ЭВМ.
Проблема зацикливания состоит в следующем: существует ли алгоритм, хотя бы частный, который выясняет заранее для произвольной машины Тьюринга будет ли она работать бесконечно.
Теорема. Проблема зацикливания машины Тьюринга не является частично разрешимой.
1.1.3 Программы и схемы программ
Схемы программ - это математические модели программ, описывающие строение программы, или точнее строение множества программ, где конкретные операции и функции заменены абстрактными функциональными и предикатными символами. Следующий пример программ вычисления факториала n! и переворачивания слов поясняет различие между программами и их схемой S1.
begin integer x, y; begin integer x, y; begin
ввод(x); ввод(x); ввод(x);
y:=1; y:=?; y:=a;
L: if x=0 then goto L1; L: if x=0 then goto L1; L: if p(x) then goto L1;
y:=x*y; y:=CONSCAR(x, y); y:=g(x, y);
x:=x-1; x:=CDR(x); x:=h(x);
goto L; goto L; goto L;
L1: вывод(y); L1: вывод(y); L1: вывод(y);
end end end
Функция CONSCAR (суперпозиция функций CONS и CAR из языка Лисп) приписывает первую букву первого слова ко второму слову (т. е. CONSCAR(аб, в) = ав), а функция CAR стирает первую букву слова (т. е. CAR(аб) = б).
1.2 Стандартные схемы программ
1.2.1 Базис класса стандартных схем программ
Стандартные схемы программ (ССП) характеризуются базисом и структурой схемы.
Базис класса фиксирует символы, из которых строятся схемы, указывает их роль (переменные, функциональные символы и др.), задает вид выражений и операторов схем.
Полный базис В класса стандартных схем состоит из 4-х непересекающихся, счетных множеств символов и множества операторов - слов, построенных из этих символов.
Множества символов полного базиса:
1. Х = {x, х1, х2..., у, у1 у2..., z, z1, z2...} - множество символов, называемых переменными;
2. F = {f(0), f(1), f(2)..., g(0), g(1), g(2)..., h(0), h(1), h(2)...} - множество функциональных символов; верхний символ задает местность символа; нульместные символы называют константами и обозначают начальными буквами латинского алфавита a, b, c...;
3. Р = {р(0), р(1), р(2)...; q(0), q(1), q(2)...; } - множество предикатных символов; р(0), q(0) - ; нульместные символы называют логическими константами;
4. {start, stop, ...,:= и т. д.} - множество специальных символов.
Термами (функциональными выражениями) называются слова, построенные из переменных, функциональных и специальных символов по следующим правилам:
односимвольные слова, состоящие из переменных или констант, являются термами;
слово ? вида f(n)(?1, ?2...?n), где ?1, ?2...?n - термы, является термом;
те и только те слова, о которых говорится в п.п. 1,2, являются термами.
Примеры термов: х, f(0), а, f(1)(х), g(2)(x, h(3)(y, a)).
Тестами (логическими выражениями) называются логические константы и слова вида р(n)(?1, ?2,...,?n). Примеры: p(0), p(0)(х), g(3)(x, y, z), p(2) (f(2(x, y)). Допускается в функциональных и логических выражениях опускать индексы местности, если это не приводит к двусмысленности или противоречию.
Множество операторов включает пять типов:
начальный оператор - слово вида start(х1, х2...хк), где k ?0, а х1, х2...хк - переменные, называемые результатом этого оператора;
заключительный оператор - слово вида stop(?1, ?2...?n), где n ?0, а ?1, ?2...?n - термы; вхождения переменных в термы ? называются аргументами этого оператора;
оператор присваивания - слово вида х := ?, где х - переменная (результат оператора), а ? - терм; вхождения переменных в термы называются аргументами этого оператора;
условный оператор (тест) - логическое выражение; вхождения переменных в логическое выражение называются аргументами этого оператора;
оператор петли - односимвольное слово loop.
Среди операторов присваивания выделим случаи: когда ? - переменная, то оператор называется пересылкой (х:=у) и когда ? -константа, то оператор называется засылкой (х:=а).
Подклассы используют ограниченные базисы. Так, например, подкласс У1 имеет базис:
{х1, х2}, {а, f(1)}, {p(1)}, {start, stop, (,),:=, ,}
и множество операторов
{start(х1, х2); х1:= f(x1), x2=f(x2), x1:=а, х2:= а, р(х1), р(х2), stop(х1,х2)},
т. е. схемы из этого подкласса используют две переменные, константу а, один одноместный функциональный символ, один предикатный символ и операторы указанного вида.
1.2.2 Графовая форма стандартной схемы
Представим стандартную схему программ как размеченный граф, вершинам которого приписаны операторы из некоторого базиса В.
Стандартной схемой в базисе В называется конечный (размеченный ориентированный) граф без свободных дуг и с вершинами следующих пяти видов:
Начальная вершина (ровно одна) помечена начальным о1ператором. Из нее выходит ровно одна дуга. Нет дуг, ведущих к начальной вершине.
Заключительная вершина (может быть несколько). Помечена заключительным оператором. Из нее не выходит ни одной дуги.
Вершина-преобразователь. Помечена оператором присваивания. Из нее выходит ровно одна дуга.
Вершина-распознаватель. Помечена условным оператором (называемым условием данной вершины). Из нее выходит ровно две дуги, помеченные 1 (левая) и 0 (правая).
Вершина-петля. Помечена оператором петли. Из нее не выходит ни одной дуги.
Конечное множество переменных схемы S составляют ее память ХS.
Из определения следует, что один и тот же оператор может помечать несколько вершин схемы.
Вершины именуются (метки вершины) целым неотрицательным числом (0, 1, 2...). Начальная вершина всегда помечается меткой 0.
Схема S называется правильной, если на каждой дуге заданы все переменные.
Пример правильной ССП S1 в графовой форме приведен на рисунке 1.2, а.
Вершины изображены прямоугольниками, а вершина-распознаватель - овалом. Операторы записаны внутри вершины.
1.2.3 Линейная форма стандартной схемы
Для использования линейной формы СПП множество специальных символов расширим дополнительными символами ?:, goto, if, then, else?. СПП в линейной форме представляет собой последовательность инструкций, которая строится следующим образом:
если выходная дуга начальной вершины с оператором start(х1,..., хn) ведет к вершине с меткой L, то начальной вершине соответствует инструкция:
0: start(х1,..., хn) goto L;
если вершина схемы S с меткой L - преобразователь с оператором присваивания х:=?, выходная дуга которого ведет к вершине с меткой L1, то этому преобразователю соответствует инструкция:
L: x: =? goto L1;
если вершина с меткой L - заключительная вершина с оператором stop(?1,...?m), то ей соответствует инструкция
L: stop(?1,..., ?m);
если вершина с меткой L - распознаватель с условием р(?1,...?k), причем 1-дуга ведет к вершине с меткой L1, а 0-дуга - к вершине с меткой L0, то этому распознавателю соответствует инструкция
L: if р(?1,...?k) then L1 else L0;
если вершина с меткой L - петля, то ей соответствует инструкция
L: loop.
Обычно используется сокращенная запись (опускание меток). Полная и сокращенная линейные формы ССП (рисунок 1.2, а) приведены ниже
0: start(х) goto 1, start(х),
1: у: = а goto 2, у: = а,
2: if р(х) then 5 else 3, 2: if р(х) then 5 else 3,
3: у: = g(x,y) goto 4, 3: у: = g(x,y),
4: х: = h(x) goto 2, х: = h (x) goto 2,
5: stop(у). 5: stop(у).
1.2.4 Интерпретация стандартных схем программ
ССП не является записью алгоритма, поэтому позволяет исследовать только структурные свойства программ, но не семантику вычислений. При построении «семантической» теории схем программ вводится понятие интерпретация ССП. Определим это понятие.
Пусть в некотором базисе В определен класс ССП. Интерпретацией базиса В в области интерпретации D называется функция I, которая сопоставляет:
каждой переменной х из базиса В - некоторый элемент d = I(x) из области интерпретации D;
каждой константе а из базиса В - некоторый элемент d = I(а) из области интерпретации D;
каждому функциональному символу f(n) - всюду определенную функцию F(n)=I(f(n));
каждой логической константе р(0) - один символ множества { 0,1 };
каждому предикатному символу р(n) - всюду определенный предикат P(n) = I(p(n)).
Пара (S,I) называется интерпретированной стандартной схемой (ИСС), или стандартной программой (СП).
Определим понятие выполнения программы.
Состоянием памяти программы (S,I) называют функцию W: XS ? D, которая каждой переменной x из памяти схемы S сопоставляет элемент W(x) из области интерпретации D.
Значение терма ? при интерпретации I и состоянии памяти W (обозначим ?I(W)) определяется следующим образом:
1) если ?=х, x - переменная, то ?I(W) = W(x);
2) если ?=a, a - константа, то ?I(W) = I(a);
3) если ?=f(n)(?1, ?2..., ?n), то ?I(W)= I(f(n))(?1I(W), ?2I(W),..., ?nI(W)).
Аналогично определяется значение теста при интерпретации I и состоянии памяти W или I(W):
если ? =р(n)(?1, ?2..., ?n), то I(W)= I(p(n))(?1I(W), ?2I(W),... ?nI(W)), n ?0.
Конфигурацией программы называют пару
U=(L,W),
где L - метка вершины схемы S, а W - состояние ее памяти. Выполнение программы описывается конечной или бесконечной последовательностей конфигураций, которую называют протоколом выполнения программы (ПВП).
Протокол (U0, U1,..., Ui, Ui+1,...) выполнения программы (S,I) определяем следующим образом (ниже ki означает метку вершины, а Wi - состояние памяти в i-й конфигурации протокола,
Ui=(ki,Wi)):
U0=(0, W0), W0 - начальное состояние памяти схемы S при интерпретации I.
Пусть Ui=(ki, Wi) - i-я конфигурация ПВП, а О - оператор схемы S в вершине с меткой ki. Если О - заключительный оператор stop(?1, ?2... ?n), то Ui - последняя конфигурация, так что протокол конечен. В этом случае считают, что, программа (S,I) останавливается, а последовательность значений ?1I(W), ?2I(W),..., ?nI(W) объявляют результатом val(S,I) выполнения программы (S,I). В противном случае, т. е. когда О - не заключительный оператор, в протоколе имеется следующая, (i+1)-я конфигурация Ui+1 = (ki+1, Wi+1), причем
а) если О - начальный оператор, а выходящая из него дуга ведет к вершине с меткой L, то ki+1 = L и Wi+1 = Wi;
б) если О - оператор присваивания х:=?, а выходящая из него дуга ведет к вершине с меткой L, то ki+1 = L, Wi+1 = Wi, Wi+1(х) = ?1(Wi);
в) если О - условный оператор и I(Wi) = ?, где ? ,1 а выходящая из него дуга ведет к вершине с меткой L, то ki+1 = L и Wi+1 = Wi;
г) если О - оператор петли, то ki+1 = L и Wi+1 = Wi, так что протокол бесконечен.
Таким образом, программа останавливается тогда и только тогда, когда протокол ее выполнения конечен. В противном случае программа зацикливается и результат ее выполнения не определен.
Рассмотрим две интерпретации СПП S1 (рисунок 1.2, а). Интерпретация (S1, I1) задана так:
область интерпретации D1 Nat - подмножество множества Nat целых неотрицательных чисел;
I1(x)=4; I1(y)=0; I1(a)=1;
I1(g)=G, где G - функция умножения чисел, т. е. G(d1,d2)= d1*d2;
I1(h)=H, где H - функция вычитания единицы, т. е. H(d)= d-1;
I1(p)=P1, где P1 - предикат «равно 0», т.е. P1(d)=1, если d=0.
Программа (S1, I1) вычисляет 4! (рисунок 1.2,б).
Интерпретация (S1, I2) задана следующим образом:
область интерпретации D2=V*, где V* - множество всех возможных слов в алфавите V.
I2(x)=abc;
I2(y)=--e, где e - пустое слово;
I2(a)= e;
I2(g)=CONSTAR;
I2(h)=CDR;
I2(p)=P2, где P2 - предикат «равное ?», т.е. P2(?)=1, если ?=?.
Программа (S1, I2) преобразует слово abc в слово cba (рисунок 1.2, в).
ПВП (S1, I1) и (S1, I2) конечен, результат - 24 и - cba (таблица 1.1 и 1.2).
Таблица 1.1
Конфигурация |
U0 |
U1 |
U2 |
U3 |
U4 |
U5 |
U6 |
U7 |
U8 |
U9 |
U10 |
U11 |
U12 |
U13 |
||
Метка |
0 |
1 |
2 |
3 |
4 |
2 |
3 |
4 |
2 |
3 |
4 |
2 |
3 |
|||
Значения |
х |
4 |
4 |
4 |
4 |
3 |
3 |
3 |
2 |
2 |
2 |
1 |
1 |
1 |
0 |
|
у |
0 |
1 |
1 |
4 |
4 |
4 |
12 |
12 |
12 |
24 |
24 |
24 |
24 |
24 |
Таблица 1.2
Конфигурация |
U0 |
U1 |
U2 |
U3 |
U4 |
U5 |
U6 |
U7 |
U8 |
U9 |
U10 |
U11 |
U12 |
||
Метка |
0 |
1 |
2 |
3 |
4 |
2 |
3 |
4 |
2 |
3 |
4 |
2 |
5 |
||
Значения |
x |
abc |
abc |
abc |
abc |
bc |
bc |
bc |
c |
c |
c |
? |
? |
? |
|
у |
? |
? |
? |
a |
a |
a |
ba |
ba |
ba |
cba |
cba |
cba |
cba |
1.3 Свойства и виды стандартных схем программ
1.3.1 Эквивалентность, тотальность, пустота, свобода
ССП S в базисе В тотальна (пуста), если для любой интерпретации I базиса В программа (S, I) останавливается (зацикливается).
Стандартные схемы S1 и S2 в базисе В функционально эквивалентны (S1 ? S2), если либо обе зацикливаются, либо обе останавливаются с одинаковым результатом, т. е. val (S1, I) ? val (S2, I).
Примеры тотальных, пустых и эквивалентных схем S2, S3, S4, S5 приведены на рисунке 1.3.
Рисунок 1.3
Цепочкой стандартной схемы (ЦСС) называют:
1. конечный путь по вершинам схемы, ведущий от начальной вершины к заключительной;
2. бесконечный путь по вершинам, начинающийся начальной вершиной схемы.
В случае, когда вершина-распознаватель (v), то дополнительно указывается верхний индекс (1 или 0), определяющий 1-дугу или 0-дугу, исходящую из вершины.
Примеры цепочек схемы S1 (рисунок 1.2,а):
(0, 1, 21, 5); (0, 1, 20, 3, 4, 20,3,4,21,5) и т. д.
Цепочкой операторов (ЦО) называется последовательность операторов, метящих вершины некоторой цепочки схемы.
Например для S1: (start(х), у:=a, р1(x), stop(у)) или (start(х), у:=a, р0(x), y:=g(x, y), x:=h(x), р0(x), y:=g(x, y), x:=h(x), р0(x), y:=g(x, y), x:=h(x), …)) и т. д.
Предикатные символы ЦО обозначаются так же, как вершины распознавателей в ЦСС.
Пусть S - ССП в базисе В, I - некоторая его интерпретация, (0, 1, к2, к3,…) - последовательность меток инструкций S, выписанных в том порядке, в котором эти метки входят в конфигурации протокола выполнения программы (S, I). Ясно, что эта последовательность - цепочка схемы S. Считают, что интерпретация I подтверждает (порождает) эту цепочку.
ЦСС в базисе В называют допустимой, если она подтверждается хотя бы одной интерпретацией этого базиса.
Не всякая ЦСС является допустимой. В схеме S2 (рисунок 1.3,а) цепочки (0, 1, 20, 5, 61, 7), (0, 1, 21, 3, 40, 7) и все другие конечные цепочки не подтверждаются ни одной интерпретацией.
Свойство допустимости цепочек играет чрезвычайно важную роль в анализе ССП. В частности оно определяет те случаи, когда стандартная схема свободна.
ССП свободна, если все ее цепочки допустимы.
Допустимая цепочка операторов - это цепочка операторов, соответствующая допустимой цепочке схемы. В тотальной схеме все допустимые цепочки (и допустимые цепочки операторов) конечны. В пустой схеме - бесконечны.
Рассмотренные свойства распространяются на все другие классы стандартных схем и образуют опорные пункты схематологии программирования.
1.3.2 Свободные интерпретации
Множество всех интерпретаций очень велико и поэтому вводится класс свободных интерпретаций (СИ), который образует ядро класса всех интерпретаций в том смысле, что справедливость высказываний о семантических свойствах ССП достаточно продемонстрировать для программ, получаемых только с помощью СИ.
Все СИ базиса В имеют одну и ту же область интерпретации, которая совпадает со множеством Т всех термов базиса В. Все СИ одинаково интерпретируют переменные и функциональные символы, а именно:
а) для любой переменной х из базиса В и для любой СИ Ih этого базиса Ih(x)=x;
б) для любой константы a из базиса В Ih(a)=a;
в) для любого функционального символа f(n) из базиса В, где nі1, Ih(f(n))=F(n): Tn®T, где F(n) - словарная функция такая, что
F(n)(t1, t2, ..., tn)= f(n) (t1, t2, ... tn),
т. е. функция F(n) по термам t1, t2, ...tn из Т строит новый терм, используя функциональный смысл символа f(n).
Что касается интерпретации предикатных символов, то она полностью свободна, т.е. разные СИ различаются лишь интерпретаций предикатных символов.
Таким образом, после введения СИ термы используются в двух разных качествах, как функциональные выражения в схемах и как значения переменных и выражений. В дальнейшем термы-значения будем заключать в апострофы. Например, если где t1=`f(x,a)`` - терм-значение переменной x, а где t2 = `g(y)`` - терм-значение переменной y, то значение свободно интерпретированного терма t3=f(x, h(y) равно терму-значению `f(f(x,a), h(g(y)))`.
Пример 1.1. Пусть Ih -СИ базиса, в котором определена схема S1 (рисунок 1.2, а), и в этой интерпретации предикат Р=Ih(р) задан так: P(t) = 1, если число функциональных символов в t больше двух; P(t) = 0, в противном случае.
Тогда ПВП (S1,Ih) можно представить таблицей 1.3.
Таблица 1.3
Конфигурация |
Метка |
Значения |
||
X |
у |
|||
U0 |
0 |
`x` |
`y` |
|
U1 |
1 |
`x` |
`a` |
|
U2 |
2 |
`x` |
`a` |
|
U3 |
3 |
`x` |
`g(x,a)` |
|
U4 |
4 |
`h(x)` |
`g(x,a)` |
|
U5 |
2 |
`h(x)` |
`g(x,a)` |
|
U6 |
3 |
`h(x)` |
`g(h(x),g(x,a))` |
|
U7 |
4 |
`h(h(x))` |
`g(h(x),g(x,a))` |
|
U8 |
2 |
`h(h(x))` |
`g(h(x),g(x,a))` |
|
U9 |
3 |
`h(h(x))` |
`g(h(h(x)),g(h(x),g(x,a)))` |
|
U10 |
4 |
`h(h(h(x)))` |
`g(h(h(x)),g(h(x),g(x,a)))` |
|
U11 |
2 |
`h(h(h(x)))` |
`g(h(h(x)),g(h(x),g(x,a)))` |
|
U12 |
5 |
`h(h(h(x)))` |
`g(h(h(x)),g(h(x),g(x,a)))` |
Обратим внимание на следующую особенность термов. Если из терма удалить все скобки и запятые, то получим слово (назовем его бесскобочным термом), по которому можно однозначно восстановить первоначальный вид терма (при условии, что отмечена или известна местность функциональных символов). Например, терму g(2)(h(1)(x), g(2)(x,y)) соответствует бесскобочный терм ghxgxy. Правила восстановления терма по бесскобочной записи аналогичны правилам восстановления арифметических по их прямой польской записи, которая просто и точно указывает порядок выполнения операций.
В этой записи, впервые примененной польским логиком Я. Лукашевичем, операторы следуют непосредственно за операндами. Поэтому ее иногда называют постфиксной записью. Классическая форма записи, как мы обычно пишем, называется инфиксной. Например:
A*B => AB* A*B+C =>AB*C+ A*(B+C/D) =>ABCD/+* A*B+C*D =>AB*CD*+
Правила представления в польской записи:
1) Идентификаторы следуют в том же порядке, что и в инфиксной записи
2) Операторы следуют в том же порядке, в каком они должны вычисляться (слева направо)
3) 3) Операторы располагаются непосредственно за своими операндами.
Бесскобочная запись термов короче и она будет использоваться далее наряду с обычной записью.
1.3.3 Согласованные свободные интерпретации
Полагают, что интерпретация I и СИ Ih (того же базиса В) согласованы, если для любого логического выражения p справедливо Ih(p)=I(p).
Пусть, например, t=`g(h(h(x)), g(h(x), g(x,a)))`, а интерпретация I3 совпадает с интерпретацией I1 из п. 1.2.4 за исключением лишь того, что I(x)=3. Так как I3(a) = 1; I3(g) - функция умножения; I3(h) - функция вычитания 1; получаем I3(p) = ((3-1)-1)*((3-1)*(3*1)) = 6.
В этом случае Ih примера из п. 1.3.2. согласована с только что рассмотренной интерпретацией I3, а так же с I2 (рисунок 1.2, в), но не согласована с I1 (рисунок 1.2, б).
Справедливы прямое и обратное утверждения, что для каждой интерпретации I базиса В существует согласованная с ней СИ этого базиса.
Так, например, выше было сказано, что Ih рассмотренного примера не согласована с I1. Что бы сделать Ih согласованной, необходимо условие Р(?) видоизменить: P(t) = 1, если число функциональных символов в ? больше трех; P(t) = 0, в противном случае.
Можно поступить и по другому. Оставить Ih без изменения и согласовать с ней I1. Для этого необходимо будет заменить I1(x) = 4, на I1(x) = 3.
Введем важное вспомогательное понятие подстановки термов, используемое в дальнейшем. Если x1, …, xn (n ? 0) - попарно различные переменные, t1, ..., tn - термы из Т, а t - функциональное или логическое выражение, то через t [t1/x1, ..., мn/xn] будем обозначать выражение, получающееся из выражения t одновременной заменой каждого из вхождений переменной xi на терм tI (i = 1, …, n). Например:
a[y/x]=a, f(x, y)[y/x, x/y]=f(y, x), g(x)[g(x)/x]=g(g(x)), p(x)[a/x]=p(a).
Приведем без доказательства несколько важных утверждений:
Если интерпретация I и свободная интерпретация Ih согласованы, то программы (S, I) и (S, Ih) либо зацикливаются, либо обе останавливаются и I(val(S,Ih))= val(S,I), т.е. каждой конкретной программе можно поставить во взаимно-однозначное соответствие свободно интерпретированную (стандартную) согласованную программу.
Если интерпретация и свободная интерпретация согласованы, они порождают одну и ту же цепочку операторов схемы.
Теорема Лакхэма - Парка - Паттерсона. Стандартные схемы S1 и S2 в базисе В функционально эквивалентны тогда и только тогда, когда они функционально эквивалентны на множестве всех свободных интерпретаций базиса В, т.е. когда для любой свободной интерпретации Ih программы (S1,Ih) и (S2,Ih) либо обе зацикливаются, либо обе останавливаются и
val(S1,I) = {I(val(S1 Ih)) = I(val(S2 Ih))} = val(S2,I).
Стандартная схема S в базисе В пуста (тотальна, свободна) тогда и только тогда, когда она пуста (тотальна, свободна) на множестве всех свободных интерпретаций этого базиса, т.е. если для любой свободной интерпретации Ih программа (S, Ih) зацикливается (останавливается).
Стандартная схема S в базисе В свободна тогда и только тогда, когда она свободна на множестве всех свободных интерпретаций этого базиса, т. е. когда каждая цепочка схемы подтверждается хотя бы одной свободной интерпретацией.
1.3.4 Логико-термальная эквивалентность
Отношение эквивалентности Е, заданное на парах стандартных схем, называют корректным, если для любой пары схем S1 и S2 из S1 S2 следует, что S1~ S2, т. е. S1 и S2 функционально эквивалентны.
Поиск разрешимых корректных отношений эквивалентности представляет значительный интерес с точки зрения практической оптимизации преобразования программ, поскольку в общем виде функциональная эквивалентность стандартных схем алгоритмически неразрешима.
Идея построения таких (корректных и разрешимых) отношений связанна с введением понятия истории цепочки схем. В истории с той или иной степенью детальности фиксируются промежуточные результаты выполнения операторов рассматриваемой цепочки. Эквивалентными объявляются схемы, у которых совпадают множества историй всех конечных цепочек.
Одним из отношений эквивалентности является логико-термальная эквивалентность (ЛТЭ).
Определим термальное значение переменной х для конечного пути ? схемы S как терм t(?, x), который строится следующим образом.
Если путь ? содержит только один оператор А, то: t(?, x) , если А - оператор присваивания, t(?, x) = х, в остальных случаях.
Если ? = ?'Ае, где А - оператор, е - выходящая из него дуга, ?' - непустой путь, ведущий к А, а x1, …, xn - все переменные терма
t(Ае, x), то t(?, x) = t(Ае, x)[ t(?', x1)/x1, …, t(?', xn)/xn].
Понятие термального значения распространим на произвольные термы
S: t(?, x) = t [ t(?, x1)/x1, …, t(?, xn)/xn].
Например, пути
start(х); y:=x; p1(x); x:=f(x); p0(y); y:=x; p1(x); x:=f(x) в схеме на рисунке 1.4, а соответствует термальное значение f(f(x)) переменной х.
Размещено на http://www.allbest.ru/
Рисунок 1.4.
Для пути ? в стандартной схеме S определим ее логико-термальную историю (ЛТИ) lt(S, ?) как слово, которое строится следующим образом.
Если путь ? не содержит распознавателей и заключительной вершины, то lt(S, ?) - пустое слово.
Если ? = ?'vе, где v - распознаватель с тестом p(t1, ..., tk), а е - выходящая из него ?-дуга, ? О{0,1}, то lt(S, ?) = lt(S, ?') p?(t(?', t1), …, t(?', tk)).
Если ? = ?'v, где v - заключительная вершина с оператором stop((t1, ..., tk), то
lt(S, ?) = lt(S, ?') t(?', t1) … t(?', tk).
Например, логико-термальной историей пути, упомянутого в приведенном выше примере, будет p1(x) p0(x) p1(f(x)).
Детерминантом (обозначение: det(S)) стандартной схемы S называют множество ЛТИ всех ее цепочек, завершающихся заключительным оператором.
Схемы S1 и S2 называют ЛТЭ (лт - эквивалентными) S1 ?ЛТ? S2, если их детерминанты совпадают.
Приведем без доказательства следующие утверждение:
Логико-терминальная эквивалентность корректна, т. е. из ЛТЭ следует функциональная эквивалентность (S1 ~ЛТ~ S2 Ю S1 ~ S2). Обратное утверждение как видно из рисунка 1.4 не верно.
ЛТ-эквивалентность допускает меньше сохраняющих ее преобразований, чем функциональная эквивалентность.
1.4 Моделирование стандартных схем программ
1.4.1 Одноленточные автоматы
Конечный одноленточный (детерминированный, односторонний) автомат обнаруживают ряд полезных качеств, используемых в теории схем программ для установления разрешимости свойств ССП.
Одноленточный конечный автомат (ОКА) над алфавитом V задается набором
A = { V, Q, R, q0, #, I }
и правилом функционирования, общим для всех таких автоматов. В наборе А
V - алфавит;
Q - конечное непустое множество состояний (QЗV=Ж);
R - множество выделенных заключительных состояний (RНQ);
q0 - выделенное начальное состояние;
I - программа автомата;
# - «пустой» символ.
Программа автомата I представляет собой множество команд вида qа®q', в которой q,q'ОQ, aОV и для любой пары (q, a) существует единственная команда, начинающаяся этими символами.
Неформально ОКА можно представить как абстрактную машину, похожую на машину Тьюринга, но имеющую следующие особенности:
1) выделены заключительные состояния;
2) машина считывает символы с ленты, ничего не записывая на нее;
3) на каждом шаге головка автомата, считав символ с ленты и перейдя согласно программе в новое состояние, обязательно передвигается вправо на одну клетку;
4) автомат останавливается в том и только в том случае, когда головка достигнет конца слова, т.е. символа ?.
Размещено на http://www.allbest.ru/
Говорят, что автомат допускает слово a в алфавите V, если, начав работать с лентой, содержащей это слово, он останавливается в заключительном состоянии. Автомат A задает характеристическую функцию множества MA допускаемых им слов в алфавите V, т. е. он распознает, принадлежит ли заданное слово множеству MA если связать с остановкой в заключительном состоянии символ 1, а с остановкой в незаключительном состоянии - 0.
Наглядным способом задания ОКА служат графы автоматов. Автомат А представляется графом, множество вершин которого - множество состояний Q, и из вершины q в вершину q' ведет дуга, помеченная символом а, тогда и только тогда, когда программа автомата содержит команду qа®q'. Работе автомата над заданным словом соответствует путь из начальной вершины q. Последовательность проходимых вершин этого пути - это последовательность принимаемых автоматом состояний, образ пути по дугам - читаемое слово. Любой путь в графе автомата, начинающийся в вершине q0 и заканчивающийся в вершине q,--ОR, порождает слово, допустимое автоматом.
Пример 1.2. ОКА A = ({a, b}, {q0, q1, q2, q3}, {q2}, q0, ?, I), допускающего слова {an bm | n=1,2, ...; m=1,2, ...}, задается графом (рисунок 1.5). Программа I содержит команды:
q0a®q1; q0b®q3; q1a®q1; q1b®q2; q2a®q3; q2b®q2; q3a®q3; q3b®q3.
Автомат называется пустым, если МА = ?, Автоматы А1 и А2 эквивалентны, если МА1 = МА2. Для машины Тьюринга проблемы пустоты и эквивалентности неразрешимы, более того, они не являются частично разрешимыми. Ситуация меняется для конечных автоматов.
Для ОКА доказано:
1) Проблема пустоты ОКА разрешима.
Доказательство основано на проверке допустимости конечного множества всех слов, длина которых не превышает числа состояний ОКА - n. Если ни одно слово из этого множества не допускается, то ОКА «пуст».
2) Предположение о том, что минимальная длина допускаемого слова больше n отвергается на том основании, что оно может быть сведено к слову меньшей длины, путем выбрасывания участков между двумя повторяющимися в пути узлами.
3) Проблема эквивалентности ОКА разрешима.
Доказательство основано на использовании отношения эквивалентности двух состояний q и q': если состояния q и q' эквивалентны, то для всех a?A состояния d(q, a) и d'(q', a) также эквивалентны. Формируемые пары не должны входить одновременно заключительное и незаключительное состояния.
1.4.2 Многоленточные автоматы
Многоленточный (детерминированный, односторонний) конечный автомат (МКА) задается так же, как ОКА. Отличие состоит в том, что множество состояний Q разбивается на n ? 2 подмножеств (непересекающихся) Q1, ..., Qn. «Физическая» интерпретация n - ленточного автомата отличается тем, что он имеет n лент и n головок, по головке на ленту. Если автомат находится в состоянии qОQi, то i-я головка читает i-ю ленту так же, как это делает ОКА. При переходе МКА в состояние q'ОQj (i№j) i-я головка останавливается, а j-я начинает читать свою ленту. МКА останавливается, когда головка на одной из лент прочитает символ ?.
Размещено на http://www.allbest.ru/
Рассмотрим функционирование МКА с n=2 (рисунок 1.6) на примере сравнения пар слов в алфавите {1, 0} и допуске только совпадающих слов.
Здесь Q=Q1UQ2, где Q1={q01}; Q2={q12, q22, q32}; R={q01}; V={0, 1},
начальное состояние - q01. МКА обрабатывает наборы слов (U1, U2), где слово U1 записано на первой ленте, а U2 - на второй. Допустимое множество наборов MA -это все возможные пары одинаковых слов, т.е. наборы, где U1 = U2. Например, набор может быть (1101, 1101) и т.п.
Подобные документы
Аналитический обзор существующих программ-редакторов схем (Microsoft Office Visio 2007, FCEditor, редактор блок-схем). Математическое описание программы и её интерпретатора. Описание системы и руководство пользователя, XML и текст редактора схем.
дипломная работа [2,1 M], добавлен 07.07.2012Рассмотрение основ разработки программ с четкой структуризацией с применением технологии нисходящего программирования. Постановка задачи, применение процедуры и функции из стандартных модулей при создании проекта. Создание пользовательского интерфейса.
курсовая работа [936,7 K], добавлен 22.01.2015Обзор известных программ, которые выполняют аналогичные функции. Выбор инструментальных средств разработки. Проектирование пользовательского интерфейса и структур данных (во внешней и оперативной памяти). Выбор стандартных визуальных компонентов.
курсовая работа [1,1 M], добавлен 13.10.2015Вирусы - самовоспроизводящиеся программы, их свойства и классификация. Примеры схем их функционирования. Пути проникновения в компьютер и механизм распределения вирусных программ, признаки их проявления. Способы защиты от них, антивирусные средства.
контрольная работа [36,1 K], добавлен 13.01.2011Операционная система MS-DOS: история и характеристика. Обзор стандартных программ операционной системы Windows. Способы запуска программ. Служебные приложения Windows и их назначение: диспетчер задач, проверка, очистка, дефрагментация и архивация диска.
реферат [221,4 K], добавлен 06.01.2015Разработка простейших линейных алгоритмов (составление логических выражений), программ с ветвлениями, циклических программ и составление их блок-схем. Практическое выполнение обработки массивов на примере вычисления элементов квадратной матрицы.
контрольная работа [173,3 K], добавлен 01.03.2010Первый прототип вируса. Идея создания самовоспроизводящихся программ. Разработка вирусоподобных программ. Основные признаки проявления вирусов. Классификация компьютерных вирусов. Рынок антивирусных программ. Основные виды антивирусных программ.
презентация [1,8 M], добавлен 25.10.2012Приемы работы с инструментальной средой программирования С++. Кодирование арифметических и логических выражений с использованием стандартных библиотечных функций ввода, вывода в С++. Описание переменной вещественного типа в языке программирования С++.
лабораторная работа [137,9 K], добавлен 13.06.2014Особенности антивирусных программ (антивирусов) - компьютерных программ, предназначенных для обезвреживания вирусов и различного рода вредоносного ПО, с целью сохранности данных и оптимальной работы ПК. Классификация и примеры антивирусных программ.
реферат [22,4 K], добавлен 26.03.2010Понятие и свойства алгоритмов: рекурсивного, сортировки и поиска. Простая программа и структурный подход к разработке алгоритмов. Язык блок-схем и проектирования программ (псевдокод). Рассмотрение принципов объектно-ориентированного программирования.
презентация [53,1 K], добавлен 13.10.2013