stringtranslate.com

машина Тьюринга

Физическая машина Тьюринга, созданная Майком Дэйви
Физическая модель машины Тьюринга. Настоящая машина Тьюринга имела бы неограниченное количество ленты с обеих сторон; однако физические модели могут иметь только конечное количество ленты.
Combinational logicFinite-state machinePushdown automatonTuring machineAutomata theory
Классы автоматов

Машина Тьюринга — это математическая модель вычислений, описывающая абстрактную машину [1] , которая манипулирует символами на полосе ленты в соответствии с таблицей правил. [2] Несмотря на простоту модели, она способна реализовать любой компьютерный алгоритм . [3]

Машина работает на бесконечной [4] ленте памяти, разделенной на дискретные ячейки, [5] каждая из которых может содержать один символ, взятый из конечного набора символов, называемого алфавитом машины. У нее есть «головка», которая в любой момент работы машины располагается над одной из этих ячеек, и «состояние», выбранное из конечного набора состояний. На каждом шаге своей работы головка считывает символ в своей ячейке. Затем, основываясь на символе и собственном текущем состоянии машины, машина записывает символ в ту же ячейку и перемещает головку на один шаг влево или вправо [6] или останавливает вычисление. Выбор того, какой заменяющий символ записать, в каком направлении переместить головку и следует ли останавливать, основан на конечной таблице, которая определяет, что делать для каждой комбинации текущего состояния и считываемого символа. Как и настоящая компьютерная программа, машина Тьюринга может войти в бесконечный цикл , который никогда не остановится.

Машина Тьюринга была изобретена в 1936 году Аланом Тьюрингом , [7] [8] который назвал ее «a-machine» (автоматическая машина). [9] Именно научный руководитель Тьюринга, Алонзо Чёрч , позже ввел термин «машина Тьюринга» в своем обзоре. [10] С помощью этой модели Тьюринг смог ответить на два вопроса отрицательно:

Таким образом , предоставив математическое описание очень простого устройства, способного производить произвольные вычисления, он смог доказать свойства вычислений в целом — и, в частности, невычислимость Entscheidungsproblem ( «проблемы принятия решений»). [13]

Машины Тьюринга доказали существование фундаментальных ограничений мощности механических вычислений. [14] Хотя они могут выполнять произвольные вычисления, их минималистский дизайн делает их слишком медленными для вычислений на практике: реальные компьютеры основаны на других конструкциях, которые, в отличие от машин Тьюринга, используют память с произвольным доступом .

Полнота по Тьюрингу — это способность вычислительной модели или системы инструкций имитировать машину Тьюринга. Язык программирования, полный по Тьюрингу, теоретически способен выражать все задачи, выполнимые компьютерами; почти все языки программирования являются полными по Тьюрингу, если игнорировать ограничения конечной памяти.

Обзор

Машина Тьюринга — это идеализированная модель центрального процессора (ЦП), который управляет всеми манипуляциями с данными, выполняемыми компьютером, при этом каноническая машина использует последовательную память для хранения данных. Обычно последовательная память представляется в виде ленты бесконечной длины, на которой машина может выполнять операции чтения и записи.

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

При наличии машины Тьюринга M и произвольной строки s , как правило, невозможно решить, произведет ли M в конечном итоге s . Это связано с тем, что проблема остановки неразрешима, что имеет серьезные последствия для теоретических пределов вычислений.

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

Машина Тьюринга, способная имитировать любую другую машину Тьюринга, называется универсальной машиной Тьюринга (UTM или просто универсальной машиной). Другой математический формализм, лямбда-исчисление , с похожей «универсальной» природой был введен Алонзо Чёрчем . Работы Чёрча переплелись с работами Тьюринга, чтобы сформировать основу тезиса Чёрча–Тьюринга . Этот тезис утверждает, что машины Тьюринга, лямбда-исчисление и другие подобные формализмы вычислений действительно охватывают неформальное понятие эффективных методов в логике и математике и, таким образом, предоставляют модель, с помощью которой можно рассуждать об алгоритме или «механической процедуре» математически точным способом, не привязываясь к какому-либо конкретному формализму. Изучение абстрактных свойств машин Тьюринга дало много идей в области компьютерной науки , теории вычислимости и теории сложности .

Физическое описание

В своем эссе 1948 года «Интеллектуальные машины» Тьюринг писал, что его машина состоит из:

...неограниченная емкость памяти, полученная в виде бесконечной ленты, размеченной на квадраты, на каждом из которых может быть напечатан символ. В любой момент в машине есть один символ; он называется сканированным символом. Машина может изменять сканированный символ, и ее поведение частично определяется этим символом, но символы на ленте в других местах не влияют на поведение машины. Однако ленту можно перемещать вперед и назад через машину, что является одной из элементарных операций машины. Поэтому любой символ на ленте может в конечном итоге иметь иннингс. [15]

—  Тьюринг 1948, стр. 3 [16]

Описание

Машина Тьюринга математически моделирует машину, которая механически работает на ленте. На этой ленте находятся символы, которые машина может считывать и записывать по одному за раз с помощью головки ленты. Работа полностью определяется конечным набором элементарных инструкций, таких как «в состоянии 42, если видимый символ равен 0, записать 1; если видимый символ равен 1, перейти в состояние 17; в состоянии 17, если видимый символ равен 0, записать 1 и перейти в состояние 6» и т. д. В оригинальной статье (« О вычислимых числах, с приложением к Entscheidungsproblem », см. также ссылки ниже) Тьюринг представляет себе не механизм, а человека, которого он называет «компьютером», который рабски выполняет эти детерминированные механические правила (или, как говорит Тьюринг, «бессистемно»).

Головка всегда находится над определенным квадратом ленты; показан только конечный отрезок квадратов. Состояние машины (q 4 ) показано над квадратом, который должен быть обработан. (Рисунок по Клини (1952) стр. 375.)
Здесь внутреннее состояние (q 1 ) показано внутри головки, а иллюстрация описывает ленту как бесконечную и предварительно заполненную "0", символом, служащим пробелом. Полное состояние системы (ее "полная конфигурация") состоит из внутреннего состояния, любых непустых символов на ленте (на этой иллюстрации "11B") и положения головки относительно этих символов, включая пробелы, т. е. "011B". (Рисунок по Мински (1967) стр. 121.)

Более конкретно, машина Тьюринга состоит из:

  1. Либо сотрите, либо напишите символ (заменив j на j1 ).
  2. Перемещение головы (которое описывается d k и может иметь значения: «L» для одного шага влево или «R» для одного шага вправо или «N» для того, чтобы оставаться на том же месте).
  3. Предположим то же самое или новое состояние , как предписано (перейти в состояние q i1 ).

В моделях 4-кортежа стирание или запись символа (a j1 ) и перемещение головки влево или вправо (d k ) задаются как отдельные инструкции. Таблица сообщает машине (ia) стереть или записать символ или (ib) переместить головку влево или вправо, а затем (ii) принять то же самое или новое состояние, как предписано, но не оба действия (ia) и (ib) в одной инструкции. В некоторых моделях, если в таблице нет записи для текущей комбинации символа и состояния, то машина остановится; другие модели требуют заполнения всех записей.

Каждая часть машины (то есть ее состояние, наборы символов и используемая лента в любой момент времени) и ее действия (такие как печать, стирание и движение ленты) являются конечными , дискретными и различимыми ; именно неограниченный объем ленты и времени выполнения дает ей неограниченный объем дискового пространства .

Формальное определение

Следуя Хопкрофту и Ульману (1979, стр. 148), (одноленточную) машину Тьюринга можно формально определить как 7- кортеж , где

3-х ступенчатый занятой бобер. Черные значки представляют местоположение и состояние головы; квадратные цвета представляют 1 (оранжевый) и 0 (белый); время идет вертикально сверху до состояния HALT внизу.

Сравнительно редкий вариант допускает «отсутствие сдвига», скажем, N, в качестве третьего элемента набора направлений .

Семикортежник для занятого бобра с тремя состояниями выглядит следующим образом (подробнее об этом занятом бобре см. в разделе Примеры машин Тьюринга ):

Изначально все ячейки ленты помечены значком .

Дополнительные сведения, необходимые для визуализации или реализации машин Тьюринга

По словам ван Эмде Боаса (1990), стр. 6: «Теоретико-множественный объект [его формальное описание из семи кортежей, похожее на приведенное выше] дает лишь частичную информацию о том, как будет вести себя машина и как будут выглядеть ее вычисления».

Например,

Альтернативные определения

Определения в литературе иногда немного различаются, чтобы сделать аргументы или доказательства проще или понятнее, но это всегда делается таким образом, чтобы полученная машина имела ту же вычислительную мощность. Например, набор можно изменить с на , где N («None» или «No-operation») позволит машине оставаться на той же ячейке ленты вместо того, чтобы двигаться влево или вправо. Это не увеличит вычислительную мощность машины.

Наиболее распространенное соглашение представляет каждую «инструкцию Тьюринга» в «таблице Тьюринга» одним из девяти кортежей по 5, согласно соглашению Тьюринга/Дэвиса (Тьюринг (1936) в «Неразрешимом» , стр. 126–127 и Дэвис (2000) стр. 152):

(определение 1): (q i , S j , Sk / E/N, L/R/N, q m )
( текущее состояние q i , отсканированный символ S j , печать символа Sk / стирание E / нет N , перемещение_ленты_на_один_квадрат влево L / вправо R / нет N , новое состояние q m )

Другие авторы (Минский (1967) стр. 119, Хопкрофт и Ульман (1979) стр. 158, Стоун (1972) стр. 9) принимают иное соглашение, при котором новое состояние q m указывается сразу после сканированного символа S j :

(определение 2): (q i , S j , q m , Sk / E/N, L/R/N)
( текущее состояние q i , отсканированный символ S j , новое состояние q m , печать символа Sk / стереть E / нет N , переместить_ленту_на_один_квадрат влево L / вправо R / нет N )

В оставшейся части статьи будет использоваться «определение 1» (конвенция Тьюринга/Дэвиса).

В следующей таблице исходная модель Тьюринга допускала только первые три строки, которые он называл N1, N2, N3 (ср. Тьюринг в The Undecidable , стр. 126). Он допускал стирание «сканируемого квадрата», называя нулевой символ S 0 = «стирание» или «пустой» и т. д. Однако он не допускал непечатаемость, поэтому каждая строка инструкции включает «печатный символ S k » или «стирание» (ср. сноску 12 в Post (1947), The Undecidable , стр. 300). Сокращения принадлежат Тьюрингу ( The Undecidable , стр. 119). После оригинальной статьи Тьюринга в 1936–1937 годах машинные модели допускали все девять возможных типов пятикортежей:

Любая таблица Тьюринга (список инструкций) может быть составлена ​​из девяти вышеуказанных 5-кортежей. По техническим причинам три непечатаемые или "N" инструкции (4, 5, 6) обычно можно опустить. Примеры см. в разделе Примеры машин Тьюринга .

Реже встречается использование 4-кортежей: они представляют собой дальнейшее раздробление инструкций Тьюринга (ср. Post (1947), Boolos & Jeffrey (1974, 1999), Davis-Sigal-Weyuker (1994)); также см. больше на Post–Turing machine .

«Государство»

Слово «состояние», используемое в контексте машин Тьюринга, может быть источником путаницы, поскольку оно может означать две вещи. Большинство комментаторов после Тьюринга использовали «состояние» для обозначения имени/обозначения текущей инструкции, которая должна быть выполнена, т. е. содержимого регистра состояния. Но Тьюринг (1936) провел четкое различие между записью того, что он назвал «m-конфигурацией» машины, и «состоянием прогресса» машины (или человека) через вычисление — текущим состоянием всей системы. То, что Тьюринг называл «формулой состояния», включает как текущую инструкцию, так и все символы на ленте:

Таким образом, состояние хода вычислений на любой стадии полностью определяется записью инструкций и символами на ленте. То есть, состояние системы может быть описано одним выражением (последовательностью символов), состоящим из символов на ленте, за которыми следует Δ (которая, как предполагается, не должна появляться в другом месте), а затем записью инструкций. Это выражение называется «формулой состояния».

—  Неразрешимое , стр. 139–140, выделено автором

Ранее в своей статье Тьюринг пошел еще дальше: он приводит пример, в котором он поместил символ текущей «m-конфигурации» — метку инструкции — под сканируемым квадратом вместе со всеми символами на ленте ( The Undecidable , стр. 121); это он называет « полной конфигурацией » ( The Undecidable , стр. 118). Чтобы напечатать «полную конфигурацию» на одной строке, он помещает метку состояния/m-конфигурацию слева от сканируемого символа.

Вариант этого можно увидеть у Клини (1952), где Клини показывает, как записать число Гёделя «ситуации» машины: он помещает символ «m-конфигурации» q 4 над сканированным квадратом примерно в центре 6 непустых квадратов на ленте (см. рисунок ленты Тьюринга в этой статье) и помещает его справа от сканированного квадрата. Но Клини называет само «q 4 » «состоянием машины» (Клини, стр. 374–375). Хопкрофт и Ульман называют эту композицию «мгновенным описанием» и следуют соглашению Тьюринга о размещении «текущего состояния» (метка инструкции, m-конфигурация) слева от сканируемого символа (стр. 149), то есть мгновенное описание представляет собой композицию непустых символов слева, состояния машины, текущего символа, сканируемого головкой, и непустых символов справа.

Пример: общее состояние 3-х состояний 2-х символьного занятого бобра после 3-х «ходов» (взято из примера «бег» на рисунке ниже):

1 А 1

Это означает: после трех ходов на ленте ... 000110000 ..., головка сканирует самую правую 1, и состояние равно A. Пробелы (в данном случае представленные «0») могут быть частью общего состояния, как показано здесь: B 01; на ленте есть одна 1, но головка сканирует 0 («пробел») слева от нее, и состояние равно B.

«Состояние» в контексте машин Тьюринга следует уточнить, что именно описывается: текущая инструкция, или список символов на ленте вместе с текущей инструкцией, или список символов на ленте вместе с текущей инструкцией, размещенной слева от сканируемого символа или справа от сканируемого символа.

Биограф Тьюринга Эндрю Ходжес (1983: 107) отметил и проанализировал эту путаницу.

Диаграммы «состояний»

Машина Тьюринга «3-state busy beaver» в представлении с конечным числом состояний . Каждый круг представляет «состояние» таблицы — «m-конфигурацию» или «инструкцию». «Направление» перехода состояний показано стрелкой. Метка (например, 0/P,R ) рядом с исходящим состоянием (в «хвосте» стрелки) указывает сканируемый символ, который вызывает определенный переход (например, 0 ), за которым следует косая черта / , за которой следуют последующие «поведения» машины, например, « P print », затем переместить ленту « R right ». Общепринятого формата не существует. Показанное соглашение соответствует McClusky (1965), Booth (1967), Hill и Peterson (1974).

Справа: приведенная выше таблица, представленная в виде диаграммы «переходов состояний».

Обычно большие таблицы лучше оставить таблицами (Booth, стр. 74). Их легче моделировать на компьютере в табличной форме (Booth, стр. 74). Однако некоторые концепции — например, машины с «сбросом» состояний и машины с повторяющимися шаблонами (ср. Hill and Peterson, стр. 244ff) — легче увидеть, если рассматривать их как рисунок.

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

Эволюция вычислений трудолюбивого бобра начинается сверху и продолжается снизу.

Читателю следует снова предупредить, что такие диаграммы представляют собой моментальный снимок их таблицы, замороженной во времени, а не ход («траекторию») вычисления во времени и пространстве. В то время как каждый раз, когда занятая машина-бобёр «работает», она всегда будет следовать одной и той же траектории состояния, это не относится к «копирующей» машине, которой можно предоставить переменные входные «параметры».

Диаграмма «прогресс вычисления» показывает прогресс «состояния» (инструкции) трехступенчатого занятого бобра через его вычисление от начала до конца. Справа находится «полная конфигурация» Тьюринга («ситуация» Клини, «мгновенное описание» Хопкрофта–Ульмана) на каждом шаге. Если бы машину остановили и очистили, чтобы очистить как «регистр состояния», так и всю ленту, эти «конфигурации» можно было бы использовать для возобновления вычисления в любом месте его хода (ср. Turing (1936) The Undecidable , стр. 139–140).

Эквивалентные модели

Многие машины, которые, как можно было бы подумать, обладают большей вычислительной мощностью, чем простая универсальная машина Тьюринга, могут оказаться не более мощными (Хопкрофт и Ульман, стр. 159, ср. Мински (1967)). Они могут вычислять быстрее, возможно, или использовать меньше памяти, или их набор инструкций может быть меньше, но они не могут вычислять более мощно (т. е. больше математических функций). ( Тезис Чёрча-Тьюринга предполагает, что это верно для любого типа машины: что всё, что может быть «вычислено», может быть вычислено некоторой машиной Тьюринга.)

Машина Тьюринга эквивалентна автомату с одним стеком ( PDA), который стал более гибким и лаконичным за счет ослабления требования LIFO ( last-in-first-out ) к его стеку. Кроме того, машина Тьюринга также эквивалентна PDA с двумя стеками со стандартной семантикой LIFO, используя один стек для моделирования ленты слева от головки, а другой стек — для ленты справа.

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

Распространенными эквивалентными моделями являются многоленточная машина Тьюринга , многодорожечная машина Тьюринга , машины с входом и выходом и недетерминированная машина Тьюринга (NDTM) в отличие от детерминированной машины Тьюринга (DTM), для которой таблица действий имеет не более одной записи для каждой комбинации символа и состояния.

Машины Тьюринга, предназначенные только для чтения и движущиеся вправо, эквивалентны DFA (а также NFA путем преобразования с использованием алгоритма преобразования NFA в DFA ).

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

Актуальным вопросом является то, является ли модель вычислений, представленная конкретными языками программирования, эквивалентной Тьюрингу. В то время как вычисления реального компьютера основаны на конечных состояниях и, таким образом, не способны имитировать машину Тьюринга, сами языки программирования не обязательно имеют это ограничение. Кирнер и др., 2009 показали, что среди языков программирования общего назначения некоторые являются полными по Тьюрингу, а другие — нет. Например, ANSI C не является полным по Тьюрингу, поскольку все экземпляры ANSI C (возможны различные экземпляры, поскольку стандарт намеренно оставляет определенное поведение неопределенным по причинам наследия) подразумевают память с конечным пространством. Это связано с тем, что размер типов данных ссылок на память, называемых указателями , доступен внутри языка. Однако другие языки программирования, такие как Pascal , не имеют этой функции, которая позволяет им быть полными по Тьюрингу в принципе. Он просто полон по Тьюрингу в принципе, поскольку выделение памяти в языке программирования может быть неудачным, что означает, что язык программирования может быть полным по Тьюрингу при игнорировании неудачных выделений памяти, но скомпилированные программы, исполняемые на реальном компьютере, не могут.

Выбор c-машин, оракул o-машин

В начале своей статьи (1936) Тьюринг проводит различие между «автоматической машиной» — ее «движением... полностью определяемым конфигурацией» — и «машиной выбора»:

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

—  Неразрешимое , стр. 118

Тьюринг (1936) не развивает эту тему более подробно, за исключением сноски, в которой он описывает, как использовать a-машину для «нахождения всех доказуемых формул исчисления [Гильберта]», а не использовать машину выбора. Он «предполагает, что выбор всегда находится между двумя возможностями 0 и 1. Каждое доказательство будет тогда определяться последовательностью выборов i 1 , i 2 , ..., i n (i 1 = 0 или 1, i 2 = 0 или 1, ..., i n = 0 или 1), и, следовательно, число 2 n + i 1 2 n-1 + i 2 2 n-2 + ... +i n полностью определяет доказательство. Автоматическая машина последовательно выполняет доказательство 1, доказательство 2, доказательство 3, ...» (сноска ‡, The Undecidable , стр. 138)

Это действительно метод, с помощью которого детерминированная (т. е. а-) машина Тьюринга может быть использована для имитации действия недетерминированной машины Тьюринга ; Тьюринг решил этот вопрос в сноске и, по-видимому, исключил его из дальнейшего рассмотрения.

Машина -оракул или о-машина — это а-машина Тьюринга, которая приостанавливает свои вычисления в состоянии « о », пока для завершения своих вычислений она «ждет решения» «оракула» — сущности, не указанной Тьюрингом, «за исключением того, что она не может быть машиной» (Тьюринг (1939), Неразрешимое , стр. 166–168).

Универсальные машины Тьюринга

Реализация машины Тьюринга

Как писал Тьюринг в «Неразрешимом» , стр. 128 (курсив добавлен):

Можно изобрести одну машину , которую можно использовать для вычисления любой вычислимой последовательности. Если эта машина U снабжена лентой, в начале которой записана строка из пятерок, разделенных точками с запятой некоторой вычислительной машины M , то U вычислит ту же последовательность, что и M.

Это открытие сейчас воспринимается как должное, но в то время (1936) оно считалось поразительным. [ необходима ссылка ] Модель вычислений, которую Тьюринг назвал своей «универсальной машиной» — « U » для краткости — некоторые считают (ср. Дэвис (2000)) фундаментальным теоретическим прорывом, который привел к идее компьютера с хранимой программой .

Статья Тьюринга... по сути содержит изобретение современного компьютера и некоторых сопровождавших его методов программирования.

—  Минский (1967), стр. 104

С точки зрения вычислительной сложности , многоленточная универсальная машина Тьюринга должна быть медленнее только на логарифмический множитель по сравнению с машинами, которые она моделирует. Этот результат был получен в 1966 году FC Hennie и RE Stearns . (Arora и Barak, 2009, теорема 1.9)

Сравнение с реальными машинами

Реализация машины Тьюринга с использованием деталей Lego

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

Есть несколько способов объяснить, почему машины Тьюринга являются полезными моделями реальных компьютеров:

Еще одна реализация машины Тьюринга

Ограничения

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

Ограничением машин Тьюринга является то, что они не моделируют сильные стороны конкретной компоновки. Например, современные компьютеры с хранимой программой на самом деле являются примерами более конкретной формы абстрактной машины, известной как машина с произвольной выборкой или модель машины RASP. Как и универсальная машина Тьюринга, RASP хранит свою «программу» в «памяти», внешней по отношению к «инструкциям» ее конечной машины. В отличие от универсальной машины Тьюринга, RASP имеет бесконечное количество различимых, пронумерованных, но неограниченных «регистров» — «ячеек» памяти, которые могут содержать любое целое число (ср. Elgot and Robinson (1964), Hartmanis (1971) и, в частности, Cook-Rechow (1973); ссылки на машину с произвольной выборкой ). Конечная машина RASP оснащена возможностью косвенной адресации (например, содержимое одного регистра может использоваться в качестве адреса для указания другого регистра); Таким образом, «программа» RASP может адресовать любой регистр в последовательности регистров. Результатом этого различия является то, что существуют вычислительные оптимизации, которые могут быть выполнены на основе индексов памяти, что невозможно в обычной машине Тьюринга; таким образом, когда машины Тьюринга используются в качестве основы для ограничения времени выполнения, может быть доказана «ложная нижняя граница» для времени выполнения определенных алгоритмов (из-за ложного упрощающего предположения машины Тьюринга). Примером этого является двоичный поиск , алгоритм, который, как можно показать, выполняется быстрее при использовании модели вычислений RASP, а не модели машины Тьюринга.

Взаимодействие

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

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

Сравнение с арифметической моделью вычисления

Арифметическая модель вычислений отличается от модели Тьюринга в двух аспектах: [20] : 32 

Некоторые алгоритмы работают за полиномиальное время в одной модели, но не в другой. Например:

Однако, если алгоритм работает за полиномиальное время в арифметической модели, и, кроме того, двоичная длина всех задействованных чисел является полиномиальной по длине входных данных, то он всегда является полиномиальным по времени в модели Тьюринга. Говорят, что такой алгоритм работает за строго полиномиальное время .

История

Исторический обзор: вычислительная техника

Робин Ганди (1919–1995) — ученик Алана Тьюринга (1912–1954) и его друг на всю жизнь — прослеживает происхождение понятия «вычислительная машина» до Чарльза Бэббиджа (около 1834 года) и фактически выдвигает «Тезис Бэббиджа»:

Что все разработки и операции анализа теперь могут быть выполнены машинами .

—  (курсив в Бэббидже, цитируемом Ганди, стр. 54)

Анализ Ганди аналитической машины Бэббиджа описывает следующие пять операций (ср. стр. 52–53):

  1. Арифметические функции +, −, ×, где − обозначает «правильное» вычитание: xy = 0, если yx .
  2. Любая последовательность операций является операцией.
  3. Итерация операции (повторение n раз операции P).
  4. Условная итерация (повторение n раз операции P при условии «успешности» теста T).
  5. Условный перенос (т.е. условный « goto »).

Ганди утверждает, что «функции, которые могут быть вычислены с помощью (1), (2) и (4), являются именно теми, которые являются вычислимыми по Тьюрингу ». (стр. 53). Он цитирует другие предложения относительно «универсальных вычислительных машин», включая предложения Перси Ладгейта (1909), Леонардо Торреса Кеведо (1914), [21] [22] Мориса д'Оканя (1922), Луи Куффиньяля (1933), Ванневара Буша (1936), Говарда Эйкена (1937). Однако:

… акцент делается на программировании фиксированной итерируемой последовательности арифметических операций. Фундаментальная важность условной итерации и условного переноса для общей теории вычислительных машин не осознается…

—  Ганди стр. 55

Entscheidungsproblem («проблема принятия решения»): десятый вопрос Гильберта 1900 года

Что касается проблем Гильберта, поставленных известным математиком Дэвидом Гильбертом в 1900 году, аспект проблемы № 10 витал в воздухе почти 30 лет, прежде чем был сформулирован точно. Первоначальное выражение Гильберта для № 10 выглядит следующим образом:

10. Определение разрешимости диофантова уравнения . Дано диофантово уравнение с любым числом неизвестных величин и с рациональными целыми коэффициентами: Разработать процесс, согласно которому можно определить за конечное число операций, разрешимо ли уравнение в рациональных целых числах. Entscheidungsproblem [задача принятия решений для логики первого порядка ] решена, когда мы знаем процедуру, которая позволяет для любого заданного логического выражения решить за конечное число операций его действительность или выполнимость... Entscheidungsproblem следует считать основной проблемой математической логики.

—  цитируется с этим переводом и оригинальным немецким текстом в Dershowitz and Gurevich, 2008

К 1922 году это понятие « Entscheidungsproblem » несколько развилось, и Х. Бехманн заявил, что

... наиболее общая форма Entscheidungsproblem [является] следующей:

Требуется совершенно определенное общеприменимое предписание, которое позволит за конечное число шагов решить истинность или ложность данного чисто логического утверждения...

—  Ганди, стр. 57, цитируя Бехмана

Бехман замечает, что... общая проблема эквивалентна проблеме определения того, какие математические предложения истинны.

—  там же.

Если бы удалось решить Entscheidungsproblem, то появилась бы «процедура решения многих (или даже всех) математических задач».

—  там же , стр. 92

К международному конгрессу математиков 1928 года Гильберт «сформулировал свои вопросы достаточно точно. Во-первых, была ли математика полной ... Во-вторых, была ли математика последовательной ... И, в-третьих, была ли математика разрешимой ?» (Ходжес, стр. 91, Хокинг, стр. 1121). На первые два вопроса ответил в 1930 году Курт Гёдель на том же самом собрании, где Гильберт произнес свою речь об уходе на пенсию (к большому огорчению Гильберта); третий — Entscheidungsproblem — пришлось ждать до середины 1930-х годов.

Проблема заключалась в том, что ответ сначала требовал точного определения «определенного общего применимого предписания», которое профессор Принстона Алонзо Чёрч назовёт « эффективной вычислимостью », а в 1928 году такого определения не существовало. Но в течение следующих 6–7 лет Эмиль Пост разработал своё определение рабочего, перемещающегося из комнаты в комнату, пишущего и стирающего отметки по списку инструкций (Post 1936), как и Чёрч и его два студента Стивен Клини и Дж. Б. Россер , используя лямбда-исчисление Чёрча и теорию рекурсии Гёделя (1934). Статья Чёрча (опубликованная 15 апреля 1936 года) показала, что Entscheidungsproblem действительно «неразрешима» [23] и опередила Тьюринга почти на год (статья Тьюринга была представлена ​​28 мая 1936 года, опубликована в январе 1937 года). Тем временем Эмиль Пост представил краткую статью осенью 1936 года, так что Тьюринг, по крайней мере, имел приоритет над Постом. Пока Чёрч рецензировал статью Тьюринга, Тьюринг успел изучить статью Чёрча и добавить Приложение, в котором он набросал доказательство того, что лямбда-исчисление Чёрча и его машины будут вычислять одни и те же функции.

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

—  Ходжес, стр. 112

А Пост лишь предложил определение исчисляемости и раскритиковал «определение» Черча, но ничего не доказал.

Машина Алана Тьюринга

Весной 1935 года Тьюринг, будучи молодым студентом магистратуры в Королевском колледже в Кембридже , принял вызов; его вдохновили лекции логика М. Х. А. Ньюмена «и он узнал из них о работах Гёделя и Entscheidungsproblem... Ньюмен использовал слово «механический»... В некрологе Тьюринга 1955 года Ньюмен пишет:

На вопрос «что такое «механический» процесс?» Тьюринг дал характерный ответ: «Нечто, что может быть сделано машиной», и приступил к весьма близкой ему по духу задаче анализа общего понятия вычислительной машины.

—  Ганди, стр. 74

Ганди утверждает, что:

Я предполагаю, но не знаю, что Тьюринг с самого начала своей работы ставил своей целью доказательство неразрешимости Entscheidungsproblem. Он сказал мне, что «главная идея» статьи пришла к нему, когда он лежал на лугах Гранчестера летом 1935 года. «Главной идеей» мог быть либо его анализ вычислений, либо его понимание того, что существует универсальная машина, и, следовательно, диагональный аргумент для доказательства неразрешимости.

—  там же , стр. 76

Хотя Ганди считал, что приведенное выше утверждение Ньюмана «вводит в заблуждение», это мнение разделяют не все. Тьюринг всю жизнь интересовался машинами: «Алан мечтал изобрести пишущие машинки, когда был мальчиком; у [его матери] миссис Тьюринг была пишущая машинка; и он вполне мог начать с того, чтобы спросить себя, что имелось в виду, когда называл пишущую машинку «механической»» (Ходжес, стр. 96). Во время работы в Принстоне, работая над докторской диссертацией, Тьюринг построил булев-логический множитель (см. ниже). Его докторская диссертация под названием « Системы логики, основанные на ординалах », содержит следующее определение «вычислимой функции»:

Выше было сказано, что «функция эффективно вычислима, если ее значения могут быть найдены некоторым чисто механическим процессом». Мы можем понимать это утверждение буквально, понимая под чисто механическим процессом тот, который может быть выполнен машиной. Можно дать математическое описание в определенной нормальной форме структур этих машин. Развитие этих идей приводит к авторскому определению вычислимой функции и к отождествлению вычислимости с эффективной вычислимостью. Несложно, хотя и несколько трудоемко, доказать, что эти три определения [третье — λ-исчисление] эквивалентны.

—  Тьюринг (1939) в «Неразрешимом» , стр. 160

Алан Тьюринг изобрел «a-машину» (автоматическую машину) в 1936 году. [7] Тьюринг представил свою статью 31 мая 1936 года в Лондонское математическое общество для его трудов (ср. Hodges 1983:112), но она была опубликована в начале 1937 года, а оттиски стали доступны в феврале 1937 года (ср. Hodges 1983:129). Именно научный руководитель Тьюринга, Алонзо Чёрч , позже ввёл термин «машина Тьюринга» в обзоре. [10] С помощью этой модели Тьюринг смог ответить на два вопроса отрицательно:

Таким образом , предоставив математическое описание очень простого устройства, способного производить произвольные вычисления, он смог доказать свойства вычислений в целом — и, в частности, невычислимость Entscheidungsproblem ( «проблемы принятия решений»). [13]

Когда Тьюринг вернулся в Великобританию, он в конечном итоге стал соавтором взлома немецких секретных кодов, созданных шифровальными машинами под названием «Энигма»; он также принял участие в разработке ACE ( автоматической вычислительной машины ), «[Тьюринг] предложение ACE было фактически самодостаточным, и его корни лежали не в EDVAC [инициативе США], а в его собственной универсальной машине» (Ходжес, стр. 318). Все еще продолжаются споры относительно происхождения и природы того, что было названо Клини (1952) « тезисом Тьюринга» . Но то, что Тьюринг доказал с помощью своей модели вычислительной машины, отражено в его статье « О вычислимых числах с приложением к проблеме Entscheidungsproblem » (1937):

[что] проблема Гильберта Entscheidungsproblem не может иметь решения... Поэтому я предлагаю показать, что не может быть общего процесса для определения того, доказуема ли данная формула U функционального исчисления K, т. е. что не может быть машины, которая, имея любую одну из этих формул U, в конечном итоге скажет, доказуема ли U.

—  из статьи Тьюринга, перепечатанной в The Undecidable , стр. 145

Пример Тьюринга (его второе доказательство): Если кто-то попросит общую процедуру, которая скажет нам: «Печатает ли эта машина когда-нибудь 0», то вопрос «неразрешим».

1937–1970: «Цифровой компьютер», рождение «компьютерной науки»

В 1937 году, работая в Принстоне над своей докторской диссертацией, Тьюринг построил цифровой (булево-логический) умножитель с нуля, создав собственные электромеханические реле (Ходжес, стр. 138). «Задачей Алана было воплотить логическую конструкцию машины Тьюринга в сети переключателей, управляемых реле...» (Ходжес, стр. 138). Хотя Тьюринг, возможно, изначально был просто любопытным и экспериментировал, вполне серьезная работа в том же направлении велась в Германии ( Конрад Цузе (1938)), а также в Соединенных Штатах ( Говард Эйкен ) и Джордж Штибиц (1937); плоды их трудов использовались как армиями стран Оси, так и союзниками во Второй мировой войне (ср. Ходжес, стр. 298–299). В начале-середине 1950-х годов Хао Ван и Марвин Мински свели машину Тьюринга к более простой форме (предшественнику пост-Тьюринговой машины Мартина Дэвиса ); одновременно европейские исследователи сводили новомодный электронный компьютер к похожему на компьютер теоретическому объекту, эквивалентному тому, что теперь называлось «машиной Тьюринга». В конце 1950-х и начале 1960-х годов параллельно идущие разработки Мелзака и Ламбека (1961), Мински (1961) и Шепердсона и Стерджиса (1961) продвинули европейскую работу дальше и свели машину Тьюринга к более удобной, похожей на компьютер абстрактной модели, называемой счетной машиной ; Элгот и Робинсон (1964), Хартманис (1971), Кук и Рекхов (1973) продвинули эту работу еще дальше с моделями регистровой машины и машины с произвольным доступом — но в основном все они представляют собой просто многоленточные машины Тьюринга с набором инструкций, подобным арифметике.

1970–настоящее время: как модель вычислений

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

В зависимости от объектов, которыми мы хотим манипулировать в вычислениях (такие числа, как неотрицательные целые числа или буквенно-цифровые строки), в теории сложности машин доминирующее положение заняли две модели:

автономная многоленточная машина Тьюринга ..., представляющая собой стандартную модель для строковых вычислений, и машина с произвольным доступом (RAM) , представленная Куком и Рекховом..., которая моделирует идеализированный компьютер в стиле фон Неймана.

—  ван Эмде Боас 1990:4

Лишь в смежной области анализа алгоритмов эту роль берет на себя модель RAM.

—  ван Эмде Боас 1990:16

Смотрите также

Примечания

  1. ^ Минский 1967:107 «В своей статье 1936 года А. М. Тьюринг определил класс абстрактных машин, которые теперь носят его имя. Машина Тьюринга — это конечный автомат, связанный с особым видом среды — ее лентой, — в которой она может хранить (и позднее восстанавливать) последовательности символов», также Стоун 1972:8, где слово «машина» заключено в кавычки.
  2. Stone 1972:8 утверждает: «Эта «машина» является абстрактной математической моделью», также см. Sipser 2006:137ff, который описывает «модель машины Тьюринга». Rogers 1987 (1967):13 ссылается на «характеристику Тьюринга», Boolos Burgess and Jeffrey 2002:25 ссылается на «определенный вид идеализированной машины».
  3. Sipser 2006:137 «Машина Тьюринга может делать все, что может делать настоящий компьютер».
  4. ^ Cf. Sipser 2002:137. Также, Rogers 1987 (1967):13 описывает «бумажную ленту бесконечной длины в обоих направлениях». Minsky 1967:118 утверждает: «Лента считается бесконечной в обоих направлениях». Boolos Burgess и Jeffrey 2002:25 включают возможность того, что «на каждом конце находится кто-то, кто добавляет дополнительные пустые квадраты по мере необходимости».
  5. ^ См. Rogers 1987 (1967): 13. Другие авторы используют слово «квадрат», например Boolos Burgess Jeffrey 2002: 35, Minsky 1967: 117, Penrose 1989: 37.
  6. ^ Boolos Burgess Jeffry 2002:25 иллюстрирует машину, движущуюся по ленте. Penrose 1989:36-37 описывает себя как «чувствующего себя некомфортно» с бесконечной лентой, отмечая, что «ее может быть трудно сдвинуть!»; он «предпочитает думать о ленте как о представлении некоторой внешней среды, через которую может двигаться наше конечное устройство», и после замечания, что «„движение“ — это удобный способ изображения вещей», а затем предполагает, что «устройство получает все свои входные данные из этой среды. Некоторые вариации модели машины Тьюринга также позволяют головке оставаться в том же положении, а не двигаться или останавливаться.
  7. ^ ab Hodges, Andrew (2012). Алан Тьюринг: Энигма (ред. The Centenary). Princeton University Press . ISBN 978-0-691-15564-7.
  8. ^ Идея пришла к нему в середине 1935 года (возможно, см. больше в разделе «История») после вопроса, заданного М. Х. А. Ньюманом в его лекциях: «Существовал ли определенный метод или, как выразился Ньюман, «механический процесс», который можно было бы применить к математическому утверждению и который дал бы ответ на вопрос, доказуемо ли оно» (Hodges 1983:93). Тьюринг представил свою статью 31 мая 1936 года в Лондонское математическое общество для его трудов (ср. Hodges 1983:112), но она была опубликована в начале 1937 года, а оттиски были доступны в феврале 1937 года (ср. Hodges 1983:129).
  9. См. сноску в Davis 2000:151.
  10. ^ см. примечание в предисловии к «Собранию сочинений Алонзо Чёрча» (ред. Бердж, Тайлер; Эндертон, Герберт (2019-04-23)). «Собрание сочинений Алонзо Чёрча». Кембридж, Массачусетс, США: MIT Press. ISBN 978-0-262-02564-5.)
  11. ^ ab Turing 1936 в The Undecidable 1965:132-134; Определение Тьюринга «кругового» можно найти на странице 119.
  12. ^ ab Turing, Alan Mathison (1937). «О вычислимых числах с приложением к Entscheidungsproblem ». Труды Лондонского математического общества . Серия 2. 42 (1): 230–265. doi :10.1112/plms/s2-42.1.230. S2CID  73712.
  13. ^ ab Turing 1936 в The Undecidable 1965:145
  14. ^ Sipser 2006:137 отмечает, что «Машина Тьюринга может делать все, что может делать настоящий компьютер. Тем не менее, даже машина Тьюринга не может решить некоторые проблемы. В самом реальном смысле эти проблемы находятся за пределами теоретических пределов вычислений».
  15. См. определение термина «иннингс» в Викисловаре.
  16. ^ AM Turing (июль 1948 г.). Интеллектуальные машины (отчет). Национальная физическая лаборатория.Здесь: стр.3-4
  17. ^ Иногда называется таблицей действий или функцией перехода .
  18. ^ Обычно пятерки [кортежи по 5]: q i a j →q i1 a j1 d k , но иногда четверки [кортежи по 4].
  19. ^ стр.149; в частности, Хопкрофт и Ульман предполагают, что не определено во всех состояниях из
  20. ^ Гретшель, Мартин ; Ловас, Ласло ; Шрийвер, Александр (1993), Геометрические алгоритмы и комбинаторная оптимизация, Алгоритмы и комбинаторика, том. 2 (2-е изд.), Springer-Verlag, Берлин, номер документа : 10.1007/978-3-642-78240-4, ISBN 978-3-642-78242-8, г-н  1261419
  21. ^ Л. Торрес Кеведо. Ensayos sobre Automática – Ваше определение. Extension teórica de sus aplicaciones, Revista de la Academia de Ciencias Exacta, Revista 12, стр. 391–418, 1914.
  22. ^ Торрес Кеведо. Л. (1915). «Essais sur l'Automatique - Sa définition. Etendue theorique de ses application», Revue Génerale des Sciences Pures et Appliquées , vol. 2, стр. 601–611.
  23. ^ Более узкий вопрос, поставленный в десятой проблеме Гильберта , о диофантовых уравнениях , оставался нерешенным до 1970 года, когда связь между рекурсивно перечислимыми множествами и диофантовыми множествами была окончательно раскрыта.

Ссылки

Первичная литература, переиздания и компиляции

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

Тезис Чёрча

Малые машины Тьюринга

Другой

Внешние ссылки