Теория вычислений - Theory of computation

Художественное представление Машина Тьюринга. Машины Тьюринга часто используются в качестве теоретических моделей вычислений.

В теоретическая информатика и математика, то теория вычислений это ветка, которая занимается тем, какие проблемы могут быть решены на модель вычисления, используя алгоритм, как эффективно они могут быть решены или в какой степени (например, приблизительные решения против точных). Поле делится на три основные ветви: теория автоматов и формальные языки, теория вычислимости, и теория сложности вычислений, которые связаны вопросом: «Каковы фундаментальные возможности и ограничения компьютеров?».[1]

Чтобы выполнить строгое исследование вычислений, компьютерные ученые работают с математической абстракцией компьютеров, называемой модель вычисления. Используется несколько моделей, но наиболее часто исследуемой является Машина Тьюринга.[2] Ученые-информатики изучают машину Тьюринга, потому что ее легко сформулировать, можно анализировать и использовать для доказательства результатов, а также потому, что она представляет собой то, что многие считают самой мощной из возможных «разумных» моделей вычислений (см. Тезис Черча – Тьюринга ).[3] Может показаться, что потенциально бесконечный объем памяти - это неосуществимый атрибут, но любой разрешимый проблема[4] решаемая машиной Тьюринга всегда требует ограниченного количества памяти. Итак, в принципе, любая проблема, которую может решить (решить) машина Тьюринга, может быть решена компьютером с ограниченным объемом памяти.

История

Теорию вычислений можно рассматривать как создание всевозможных моделей в области информатики. Следовательно, математика и логика используются. В прошлом веке она стала самостоятельной академической дисциплиной и была отделена от математики.

Некоторые пионеры теории вычислений были Рамон Лулль, Церковь Алонсо, Курт Гёдель, Алан Тьюринг, Стивен Клини, Рожа Петер, Джон фон Нейман и Клод Шеннон.

ветви

Теория автоматов

ГрамматикаЯзыкиАвтоматПравила производства (ограничения)
Тип-0Рекурсивно перечислимыйМашина Тьюринга (нет ограничений)
Тип 1Контекстно-зависимыйЛинейно-ограниченная недетерминированная машина Тьюринга
Тип-2Без контекстаНедетерминированный выталкивающий автомат
Тип-3ОбычныйКонечный автомат
и

Теория автоматов - это изучение абстрактных машин (или, точнее, абстрактных «математических» машин или систем) и вычислительных задач, которые могут быть решены с помощью этих машин. Эти абстрактные машины называются автоматами. Автоматы происходят от греческого слова (Αυτόματα), что означает, что что-то делает что-то само по себе. Теория автоматов также тесно связана с формальный язык теория[5] поскольку автоматы часто классифицируются по классу формальных языков, которые они могут распознать. Автомат может быть конечным представлением формального языка, который может быть бесконечным множеством. Автоматы используются в качестве теоретических моделей для вычислительных машин и используются для доказательства вычислимости.

Теория формального языка

Иерархия Хомского
Набор включений, описываемых иерархией Хомского

Теория языка - это раздел математики, связанный с описанием языков как набора операций над алфавит. Он тесно связан с теорией автоматов, поскольку автоматы используются для создания и распознавания формальных языков. Существует несколько классов формальных языков, каждый из которых допускает более сложную спецификацию языка, чем предыдущий, т.е. Иерархия Хомского,[6] и каждый соответствует классу автоматов, который его распознает. Поскольку автоматы используются в качестве моделей для вычислений, формальные языки являются предпочтительным способом спецификации для любой проблемы, которая должна быть вычислена.

Теория вычислимости

Теория вычислимости в первую очередь занимается вопросом о том, в какой степени проблема решаема на компьютере. Заявление о том, что проблема остановки не может быть решена машиной Тьюринга[7] является одним из наиболее важных результатов в теории вычислимости, поскольку это пример конкретной проблемы, которую легко сформулировать и которую невозможно решить с помощью машины Тьюринга. Большая часть теории вычислимости основывается на результате проблемы остановки.

Еще одним важным шагом в теории вычислимости был Теорема Райса, который утверждает, что для всех нетривиальных свойств частичных функций, это неразрешимый вычисляет ли машина Тьюринга частичную функцию с этим свойством.[8]

Теория вычислимости тесно связана с разделом математическая логика называется теория рекурсии, что снимает ограничение на изучение только моделей вычислений, которые сводятся к модели Тьюринга.[9] Многие математики и теоретики вычислений, изучающие теорию рекурсии, будут называть ее теорией вычислимости.

Теория вычислительной сложности

Представление отношения между классами сложности

Теория сложности учитывает не только то, можно ли вообще решить проблему на компьютере, но и то, насколько эффективно проблема может быть решена. Рассмотрены два основных аспекта: временная сложность и пространственная сложность, которые представляют собой, соответственно, количество шагов, необходимых для выполнения вычисления, и сколько памяти требуется для выполнения этого вычисления.

Чтобы проанализировать, сколько времени и места алгоритм требует, компьютерщики выражают время или пространство, необходимое для решения проблемы, как функцию размера входной задачи. Например, найти конкретное число в длинном списке чисел становится труднее, когда список чисел становится больше. Если мы скажем, что есть п числа в списке, то, если список не отсортирован и не проиндексирован каким-либо образом, нам, возможно, придется просмотреть каждое число, чтобы найти число, которое мы ищем. Таким образом, мы говорим, что для решения этой проблемы компьютер должен выполнить ряд шагов, которые линейно растут по размеру проблемы.

Чтобы упростить эту задачу, компьютерные ученые приняли Обозначение Big O, что позволяет сравнивать функции таким образом, чтобы не учитывать отдельные аспекты конструкции машины, а учитывать только асимптотическое поведение поскольку проблемы становятся большими. Итак, в нашем предыдущем примере мы могли бы сказать, что проблема требует шаги для решения.

Пожалуй, самая важная открытая проблема во всем Информатика вопрос о том, обозначен ли определенный широкий класс проблем НП можно решить эффективно. Это обсуждается далее на Классы сложности P и NP, и P против проблемы NP один из семи Задачи Премии тысячелетия заявлено Институт математики Клэя в 2000 году. Официальное описание проблемы был дан Премия Тьюринга победитель Стивен Кук.

Модели вычислений

Помимо Машина Тьюринга, другой аналог (см .: Тезис Черча – Тьюринга ) модели вычислений используются.

Лямбда-исчисление
Вычисление состоит из исходного лямбда-выражения (или двух, если вы хотите разделить функцию и ее ввод) плюс конечная последовательность лямбда-членов, каждый из которых выводится из предыдущего члена одним применением Бета-редукция.
Комбинаторная логика
концепция, во многом похожая на -calculus, но также существуют важные различия (например, комбинатор с фиксированной точкой Y имеет нормальную форму в комбинаторной логике, но не в -исчисление). Комбинаторная логика была разработана с большими амбициями: понять природу парадоксов, сделать основы математики более экономичными (концептуально), исключить понятие переменных (таким образом прояснить их роль в математике).
μ-рекурсивные функции
вычисление состоит из мю-рекурсивной функции, т.е. его определяющая последовательность, любое входное значение (я) и последовательность рекурсивных функций, появляющихся в определяющей последовательности с входами и выходами. Таким образом, если в определяющей последовательности рекурсивной функции функции и могут появиться члены вида 'g (5) = 7' или 'h (3,2) = 10'. Каждая запись в этой последовательности должна быть приложением базовой функции или следовать из записей выше, используя сочинение, примитивная рекурсия или же μ рекурсия. Например, если , то для появления 'f (5) = 3' выше должны встречаться такие термины, как 'g (5) = 6' и 'h (5,6) = 3'. Вычисление завершается только в том случае, если последний член дает значение рекурсивной функции, применяемой к входам.
Алгоритм Маркова
а система перезаписи строк который использует грамматика -подобные правила для работы струны символов.
Зарегистрировать машину
теоретически интересная идеализация компьютера. Есть несколько вариантов. В большинстве из них каждый регистр может содержать натуральное число (неограниченного размера), а инструкции просты (и немногочисленны), например существуют только уменьшение (в сочетании с условным переходом) и инкремент (и остановка). Отсутствие бесконечного (или динамически растущего) внешнего хранилища (наблюдаемого на машинах Тьюринга) можно понять, заменив его роль на Гёделевская нумерация методы: тот факт, что каждый регистр содержит натуральное число, дает возможность представить сложную вещь (например, последовательность, матрицу и т. д.) соответствующим огромным натуральным числом - однозначность как представления, так и интерпретации может быть установлена теоретическое число основы этих методов.

Помимо общих вычислительных моделей, некоторые более простые вычислительные модели полезны для специальных, ограниченных приложений. Обычные выражения, например, укажите шаблоны строк во многих контекстах, от офисного программного обеспечения до языки программирования. Другой формализм, математически эквивалентный регулярным выражениям, Конечные автоматы используются в схемотехнике и при решении некоторых проблем. Бесконтекстные грамматики указать синтаксис языка программирования. Недетерминированный выталкивающие автоматы - еще один формализм, эквивалентный контекстно-свободным грамматикам. Примитивные рекурсивные функции являются определенным подклассом рекурсивных функций.

Различные модели вычислений могут выполнять разные задачи. Один из способов измерить мощность вычислительной модели - изучить класс формальные языки что модель может создать; таким образом Иерархия Хомского языков получается.

Рекомендации

  1. ^ Майкл Сипсер (2013). Введение в теорию вычислений 3-й. Cengage Learning. ISBN  978-1-133-18779-0. центральные области теории вычислений: автоматы, вычислимость и сложность. (Страница 1)
  2. ^ Ходжес, Эндрю (2012). Алан Тьюринг: Загадка (Столетие изд.). Princeton University Press. ISBN  978-0-691-15564-7.
  3. ^ Рабин, Майкл О. (Июнь 2012 г.). Тьюринг, Чёрч, Гёдель, вычислимость, сложность и рандомизация: личное мнение.
  4. ^ Дональд Монк (1976). Математическая логика. Springer-Verlag. ISBN  9780387901701.
  5. ^ Хопкрофт, Джон Э. и Джеффри Д. Уллман (2006). Введение в теорию автоматов, языки и вычисления. 3-е изд. Ридинг, Массачусетс: Эддисон-Уэсли. ISBN  978-0-321-45536-9.
  6. ^ Иерархия Хомского (1956). «Три модели для описания языка». Теория информации, Сделки IRE на. IEEE. 2 (3): 113–124. Дои:10.1109 / TIT.1956.1056813.
  7. ^ Алан Тьюринг (1937). «О вычислимых числах в приложении к Entscheidungsproblem». Труды Лондонского математического общества. IEEE. 2 (42): 230–265. Дои:10.1112 / плмс / с2-42.1.230. Получено 6 января 2015.
  8. ^ Генри Гордон Райс (1953). «Классы рекурсивно перечислимых множеств и проблемы их решения». Труды Американского математического общества. Американское математическое общество. 74 (2): 358–366. Дои:10.2307/1990888. JSTOR  1990888.
  9. ^ Мартин Дэвис (2004). Неразрешимое: основные статьи о неразрешимых предложениях, неразрешимых проблемах и вычислимых функциях (Dover Ed). Dover Publications. ISBN  978-0486432281.

дальнейшее чтение

Учебники для информатиков

(В этой области есть много учебников; этот список по необходимости неполный.)

Книги по теории вычислимости с (более широкой) математической точки зрения
  • Хартли Роджерс младший (1987). Теория рекурсивных функций и эффективной вычислимости, MIT Press. ISBN  0-262-68052-1
  • С. Барри Купер (2004). Теория вычислимости. Чепмен и Холл / CRC. ISBN  1-58488-237-9..
  • Карл Х. Смит, Рекурсивное введение в теорию вычислений, Springer, 1994, ISBN  0-387-94332-3. Более короткий учебник, подходящий для аспирантов по информатике.
Историческая перспектива

внешняя ссылка