Модели вычислений
Лектор - профессор Захаров Владимир Анатольевич.
Содержание
Программа курса
Конечные автоматы и регулярные выражения
- Формальные языки. Операции над языками. Проблемы принадлежности слова языку, пустоты, тотальности, равенства, включения.
- Недетерминированные конечные автоматы. Вычисления автоматов. Автоматные языки.
- Детерминированные конечные автоматы. Эквивалентные состояния и эквивалентные автоматы. Алгоритм проверки эквивалентности детерминированных конечных автоматов.
- Минимальные детерминированные конечные автоматы. Теорема о существовании и единственности минимального детерминированного конечного автомата. Алгоритм минимизации детерминированных конечных автоматов.
- Алгоритм преобразования конечного автомата к детерминированному виду. Замкнутость класса автоматных языков относительно операций над языками.
- Теорема о разрастании для автоматных языков. Примеры неавтоматных языков.
- Регулярные выражения. Алгебра регулярных выражений. Уравнения в регулярных выражениях. Теорема Клини о соответствии между регулярными выражениями и конечными автоматами.
- Задача проверки соответствия текста шаблону и теоретико-автоматный подход к ее решению. Задача поиска подстроки в строке. Алгоритм Ахо-Карасик.
- Двусторонние конечные автоматы. Теорема о соответствии между односторонними и двусторонними конечными автоматами.
Машины Тьюринга и рекурсивно перечислимые языки
- Одноленточные машины Тьюринга. Вычисления машин Тьюринга. Рекурсивные и рекурсивно-перечислимые языки.
- Моделирование односторонних и многоленточных машин Тьюринга одноленточными машинами Тьюринга.
- Арифметические функции, вычислимые по Тьюрингу. Характеристические теоремы для рекурсивных и рекурсивно-перечислимых языки.
- Массовые алгоритмические проблемы и их связь с рекурсивными языками
- Универсальные машины Тьюринга. Неразрешимость проблемы останова для машин Тьюринга.
- Сводимость алгоритмических проблем. Примеры алгоритмически неразрешимых проблем программирования.
- Функциональные (семантические) свойства программ. Теорема Райса.
- Замкнутость классов рекурсивных и рекурсивно перечислимых языков относительно теоретико-множественных операций.
- Проблема соответствий Поста. Алгоритмическая неразрешимость проблемы соответствий Поста.
- Многоголовочные конечные автоматы. Алгоритмическая неразрешимость проблемы останова для многоголовочных конечных автоматов.
- Ассоциативные исчисления. Алгоритмическая неразрешимость проблемы достижимости для полусистем Туэ.
- Примеры алгоритмически неразрешимых проблем математики: проблема разрешимости диофантовых уравнений, проблема мозаики. Машины Минского. Универсальность модели вычислений машин Минского.
Контекстно-свободные языки и автоматы с магазинной памятью
- Формальные грамматики. Классификация формальных грамматик. Иерархия Хомского формальных языков.
- Праволинейные грамматики. Совпадение класса автоматных языков и класса праволинейных языков.
- Неограниченные грамматики и рекурсивно перечислимые языки.
- Контекстно-свободные грамматики. Устранение недостижимых и -правил. Нормальная форма Хомского контекстно-свободных грамматик. Приведение контекстно-свободных грамматик к нормальной форме Хомского.
- Деревья синтаксического разбора. Теорема о разрастании для контекстно-свободных языков. Примеры языков, не являющихся контекстно-свободными.
- Автоматы с магазинной памятью и их свойства. Взаимосвязь контекстно-свободных языков и автоматов с магазинной памятью.
- Теоремы о замкнутости и незамкнутости класса контекстно-свободных языков относительно операций над формальными языками. Алгоритм проверки пустоты для контекстно-свободных грамматик.
- Алгоритмическая неразрешимость проблем эквивалентности и тотальности для контекстно-свободных грамматик.
- Задача синтаксического анализа. Алгоритм Кока-Касами-Янгера проверки принадлежности слова контекстно-свободному языку. Детерминированные автоматы с магазинной памятью и LL(1) грамматики.
- Контекстно-зависимые грамматики. Взаимосвязь контекстно-зависимых грамматик и машин Тьюринга с линейно-ограниченной памятью.
Автоматы над бесконечными словами и темпоральные логики
- Конечные автоматы-преобразователи (трансдьюсеры) и рациональные отношения. Детерминированные трансдьюсеры. Алгоритм проверки эквивалентности детерминированных трансдьюсеров.
- Алгоритмическая неразрешимость проблемы эквивалентности недетерминированных трансдьюсеров.
- Конечные автоматы над бесконечными словами (автоматы Бюхи, Рабина, Мюллера) и их свойства. Омега-регулярные языки. Алгоритм проверки пустоты конечных автоматов над бесконечными словами.
- Детерминизация автоматов над бесконечными словами.
- Замкнутость класса омега-регулярных языков относительно теоретико-множественных операций.
- Монадическая логика 2-го порядка S1S и ее взаимосвязь с конечными автоматами над бесконечными словами.
- Темпоральная логика PLTL: синтаксис и семантика. Применение PLTL для спецификации вычислений и взаимосвязь с автоматами над бесконечными словами.
- Задача проверки выполнимости формул PLTL и ее сведение к задаче проверки пустоты конечных автоматов над бесконечными словами.
- Алгоритм двойного поиска в глубину проверки пустоты конечных автоматов над бесконечными словами. Система верификации SPIN: ее устройство и применение.
Литература
- Ахо А., Ульман Дж. Теория синтаксического анализа, перевода и компиляции. Т. 1: Синтаксический анализ. - М.: Мир, 1978. - 612 с.
- Ахо А., Сети Р., Ульман Дж. Компиляторы: принципы, технологии и инструменты. - М.: Вильямс, 2001. - 768 с.
- Верещагин Н.К., Шень А. Лекции по математической логике и теории алгоритмов. Часть 3. Вычислимые функции. - М.: МЦНМО, 1999. - 176 с.
- Катленд Н. Вычислимость. Введение в теорию рекурсивных функций. - М.: Мир, 1983.
- Льюис Ф., Розенкранц Д, Стирнз Р. Теоретические основы проектирования компиляторов. - М.: Мир, 1979.. - 656 с.
- Матрос Д.Ш., Поднебесова Г.Б. Теория алгоритмов. - М.: Бином, 2008. - 200 с.
- Пентус А.Е., Пентус М.Р. Математическая теория формальных языков. Серия "Основы информатики и математики" - М: Бином, 2006. - 247 с.
- Роджерс Х. Теория рекурсивных функций и эффективная вычислимость. - М.: Мир, 1972.
- Хопкрофт Дж., Мотвани Р., Ульман Дж. Введение в теорию автоматов, языков и вычислений. - М.: Вильямс, 2002. - 528 с.
Правила проведения экзамена
Экзамен проводится в форме письменной контрольной работы. Время, отведенное на решение задач, составляет 120 мин. Письменная контрольная работа состоит из 10 заданий.
Задания 1-4 - это задачи требующие применения стандартных алгоритмов и методов решения. Правильное решение каждой такой задачи оценивается 2 баллами.
В заданиях 5-8 требуется сформулировать определения основных понятий, введенных в лекционном курсе. Правильное решение каждой такой задачи оценивается 1 баллом.
В задании 9 требуется сформулировать и доказать одну из теорем, рассмотренных в лекционном курсе. Правильное решение каждой такой задачи оценивается 2 баллами.
В задании 10 требуется решить теоретическую задачу, опираясь на сведения, представленные в лекционном курсе. Правильное решение каждой такой задачи оценивается 3 баллами.
Оценка контрольной работы проводится по следующим критериям:
14-17 баллов - отлично,
10-15 баллов - отлично,
7-9 баллов - удовлетворительно.