Проблема с остановкой

редактировать
Проблема определения, завершит ли данная программа выполнение или продолжится вечно

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

Для любой программы f, которая может определить, останавливаются ли программы, «патологическая» программа g, вызываемая с некоторым входом, может передать свой собственный источник и свой вход в f, а затем конкретно сделать противоположное тому, что f предсказывает g. Сделаю. Не может существовать f, который занимается этим делом. Ключевой частью доказательства является математическое определение компьютера и программы, которое известно как машина Тьюринга ; проблема остановки неразрешима по машинам Тьюринга. Это один из первых случаев проблем с решением, которые оказались неразрешимыми. Это доказательство важно для практических вычислений, поскольку определяет класс приложений, которые никакое изобретение в области программирования не может выполнять идеально.

Джек Коупленд (2004) связывает введение термина «проблема остановки» с работой Мартина Дэвиса в 1950-х.

Содержание
  • 1 Предпосылки
    • 1.1 Программные последствия
    • 1.2 Распространенные ошибки
  • 2 История
    • 2.1 Временная шкала
  • 3 Формализация
    • 3.1 Представление в виде набора
    • 3.2 Концепция доказательства
    • 3.3 Набросок доказательства
  • 4 Теория вычислимости
    • 4.1 Теоремы Гёделя о неполноте
  • 5 Обобщение
    • 5.1 Остановка на всех входах
    • 5.2 Распознавание частичных решений
    • 5.3 Вычисление с потерями
    • 5.4 Машины Oracle
  • 6 См. Также
  • 7 Примечания
  • 8 Ссылки
  • 9 Внешние ссылки
Предпосылки

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

Например, в псевдокоде программа

while (true) continue

не останавливается; скорее, это продолжается бесконечно в бесконечном цикле. С другой стороны, программа

print «Hello, world!»

останавливается.

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

Последствия программирования

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

Иногда эти программисты используют какой-то универсальный (полный по Тьюрингу) язык программирования, но пытаются писать в ограниченном стиле, таком как MISRA C или SPARK, что позволяет легко доказать, что итоговые подпрограммы завершаются до указанного крайнего срока.

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

Общие ловушки

Сложность проблемы остановки заключается в требовании, чтобы процедура принятия решения работала для всех программ и входных данных. Конкретная программа либо останавливается на заданном входе, либо не останавливается. Рассмотрим один алгоритм, который всегда отвечает «останавливается», а другой - «не останавливается». Для любой конкретной программы и ввода один из этих двух алгоритмов отвечает правильно, даже если никто не знает, какой именно. Однако ни один алгоритм не решает проблему остановки в целом.

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

Проблема остановки теоретически разрешима для линейных ограниченных автоматов (LBA) или детерминированных машин с конечной памятью. Машина с конечной памятью имеет конечное число конфигураций, и, следовательно, любая детерминированная программа на ней должна в конечном итоге либо остановиться, либо повторить предыдущую конфигурацию:

... любой конечный автомат, если его полностью предоставить самому себе, рано или поздно выйдет из строя. в идеально периодический повторяющийся узор. Продолжительность этого повторяющегося паттерна не может превышать количество внутренних состояний машины... (курсив в оригинале, Minsky 1967, p. 24)

Однако Мински отмечает, что компьютер с миллионом мелких деталей, каждая из которых имеет два состояния имели бы по крайней мере 2 возможных состояния:

Это единица, за которой следует около трехсот тысяч нулей... Даже если бы такая машина работала на частотах космических лучей, эоны галактической эволюции были бы как ничто по сравнению со временем прохождения такого цикла (Мински, 1967, с. 25):

Мински утверждает, что хотя машина может быть конечной, конечные автоматы «имеют ряд теоретических ограничений»:

.... вовлеченные величины должны наводить на мысль, что теоремы и аргументы, основанные главным образом на простой конечности [диаграммы] состояний, могут не иметь большого значения. (Мински стр. 25)

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

История

Проблема остановки исторически важна, потому что это была одна из первых проблем, которая была доказана неразрешимой. (Доказательство Тьюринга было опубликовано в мае 1936 года, тогда как доказательство Алонзо Черча неразрешимости проблемы в лямбда-исчислении было опубликовано уже в апреле 1936 года [Church, 1936].) Впоследствии были описаны многие другие неразрешимые проблемы.

Хронология

  • 1900: Дэвид Гилберт ставит свои «23 вопроса» (теперь известные как проблемы Гильберта ) на Втором Международном конгрессе математиков в Париже. «Из них вторым было доказательство непротиворечивости« аксиом Пеано », от которых, как он показал, зависела строгость математики». (Ходжес, стр. 83, комментарий Дэвиса у Дэвиса, 1965, стр. 108)
  • 1920–1921: Эмиль Пост исследует проблему остановки для систем тегов, рассматривая его как кандидата на неразрешимость. (Абсолютно неразрешимые проблемы и относительно неразрешимые предположения - описание предвкушения, Дэвис, 1965, стр. 340–433.) Его неразрешимость была установлена ​​намного позже Марвином Мински (1967).
  • 1928: Гильберт переработал свою «вторую проблему» на Болонском международном конгрессе. (Рейд, стр. 188–189) Ходжес утверждает, что задал три вопроса: например, №1: была ли математика завершена? №2: Была ли математика последовательной? # 3: Была ли математика разрешимой? (Ходжес стр.91). Третий вопрос известен как Entscheidungsproblem (проблема решения). (Ходжес, стр. 91, Пенроуз, стр. 34)
  • 1930: Курт Гёдель объявляет доказательство как ответ на первые два вопроса Гильберта 1928 года [ср. Рейд, стр. 198]. «Сначала он [Гильберт] был только зол и разочарован, но затем он начал пытаться конструктивно решить проблему... Сам Гёдель чувствовал - и выразил мысль в своей статье, - что его работа не противоречит формалистической точке зрения Гильберта. точка зрения "(Рейд, стр. 199)
  • 1931: Гёдель публикует" О формально неразрешимых предложениях Principia Mathematica и родственных систем I "(перепечатано в Davis, 1965, стр. 5ff)
  • 19 Апрель 1935 г.: Алонзо Черч публикует «Неразрешимую проблему элементарной теории чисел», в которой он определяет, что означает эффективное вычисление функции. Такая функция будет иметь алгоритм, и «... факт завершения работы алгоритма становится фактически известным...» (Дэвис, 1965, стр. 100)
  • 1936: Черч публикует первое доказательство того, что Проблема Entscheidungs ​​неразрешима. (Примечание к проблеме Entscheidungsproblem, перепечатано в Davis, 1965, стр. 110.)
  • 7 октября 1936 г.: получена статья Эмиля Поста «Конечные комбинаторные процессы. Формулировка I». Пост добавляет к своему «процессу» инструкцию «(C) Stop». Он назвал такой процесс «типом 1... если процесс, который он определяет, завершается для каждой конкретной проблемы». (Davis, 1965, p. 289ff)
  • 1937: Статья Алана Тьюринга «О вычислимых числах в приложении к проблеме Entscheidungs» выходит в печать в январе 1937 г. (перепечатано в Davis, 1965, стр. 115). Доказательство Тьюринга отходит от вычислений с помощью рекурсивных функций и вводит понятие машинного вычисления. Стивен Клини (1952) называет это одним из «первых примеров решения проблем, которые оказались неразрешимыми».
  • 1939: J. Баркли Россер отмечает существенную эквивалентность «эффективного метода», определенного Геделем, Черчем и Тьюрингом (Россер в Дэвисе, 1965, стр. 273, «Неформальное изложение доказательств теоремы Гёделя и теоремы Черча»)
  • 1943: В статье Стивен Клини заявляет, что «При создании полной алгоритмической теории мы описываем процедуру... которая обязательно завершается, и таким образом, чтобы исходя из результата мы может прочесть однозначный ответ «Да» или «Нет» на вопрос «Верно ли значение предиката?».
  • 1952: Kleene (1952) Глава XIII («Вычислимые функции») включает обсуждение неразрешимости проблемы остановки для машин Тьюринга и переформулировка ее в терминах машин, которые «в конечном итоге останавливаются», то есть останавливаются: «... не существует алгоритма для определения того, может ли какая-либо конкретная машина при запуске из любой данной ситуации в конечном итоге останавливается ". (Kleene (1952), стр. 382)
  • 1952: «Мартин Дэвис считает вероятным, что он впервые использовал термин« проблема остановки »в серии лекций, которые он прочитал в Контрольной Лаборатория систем в Университете Иллинойса в 1952 г. (письмо Дэвиса Коупленду, 12 декабря 2001 г.) ". (Сноска 61 в Copeland (2004), стр. 40ff)
Формализация

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

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

Представление в виде множества

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

K = {(i, x) | программа i останавливается при запуске на входе x}

представляет проблему остановки.

Этот набор рекурсивно перечислим, что означает, что существует вычислимая функция, которая перечисляет все пары (i, x), которые он содержит. Однако дополнение этого набора не является рекурсивным перечислимым.

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

  • {i | программа i в конечном итоге останавливается при запуске с вводом 0}
  • {i | есть вход x такой, что программа i в конечном итоге останавливается при запуске с входом x}.

Концепция доказательства

Доказательство того, что проблема остановки не разрешима, - это доказательство от противоречия. Чтобы проиллюстрировать концепцию доказательства, предположим, что существует вычисляемая функция total halts (f), которая возвращает true, если подпрограмма f останавливается (при запуске без входов) и возвращает false в противном случае. Теперь рассмотрим следующую подпрограмму:

def g (): if halts (g): loop_forever ()

halts (g) должен либо возвращать true, либо false, потому что предполагалось, что halts составляет total. Если halts (g) возвращает true, тогда g вызовет loop_forever и никогда не остановится, что является противоречием. Если halts (g) возвращает false, тогда g остановится, потому что он не будет вызывать loop_forever; это тоже противоречие. В целом, halts (g) не может возвращать значение истинности, которое согласуется с тем, останавливается ли g. Следовательно, исходное предположение о том, что halts - это полностью вычислимая функция, должно быть ложным.

Метод, использованный в доказательстве, называется диагонализацией - g делает противоположное тому, что, по словам останова, должно делать g. Разница между этим наброском и фактическим доказательством состоит в том, что в фактическом доказательстве вычислимая остановка функции не принимает непосредственно подпрограмму в качестве аргумента; вместо этого он берет исходный код программы. Фактическое доказательство требует дополнительной работы для решения этой проблемы. Более того, фактическое доказательство избегает прямого использования рекурсии, показанной в определении g.

Набросок доказательства

Вышеупомянутая концепция показывает общий метод доказательства; в этом разделе будут представлены дополнительные сведения. Общая цель - показать, что не существует total вычислимой функции, которая решает, останавливается ли произвольная программа i на произвольном входе x; то есть следующая функция h не вычислима (Penrose 1990, p. 57–63):

h (i, x) = {1, если программа i останавливается на входе x, 0 в противном случае. {\ displaystyle h (i, x) = {\ begin {cases} 1 {\ text {if}} {\ text {program}} i {\ text {останавливается при вводе}} x, \\ 0 {\ text { в противном случае.}} \ end {ases}}}h (i, x) = {\ begin {cases} 1 {\ text {if}} {\ text {program}} i {\ text {останавливается при вводе}} x, \\ 0 {\ text {в противном случае.}} \ end {cases}}

Здесь программа i относится к i-й программе в перечислении всех программ фиксированной полной по Тьюрингу модели вычисление.

f (i, j)i
123456
j1100101
2000100
3010101
4100100
5000111
6110010
f (i, i)100110
g (i)U00UU0

Возможные значения для общей вычислимой функции f, расположенные в двумерном массиве. Оранжевые клетки - диагональ. Значения f (i, i) и g (i) показаны внизу; U указывает, что функция g не определена для конкретного входного значения.

Доказательство продолжается путем непосредственного установления того, что никакая общая вычислимая функция с двумя аргументами не может быть требуемой функцией h. Как и в наброске концепции, для любой полной вычислимой двоичной функции f следующая частичная функция g также вычисляется некоторой программой e:

g (i) = {0 if f (i, i) = 0, иначе не определено. {\ displaystyle g (i) = {\ begin {cases} 0 {\ text {if}} f (i, i) = 0, \\ {\ text {undefined}} {\ text {в противном случае.}} \ end {cases}}}g (i) = {\ begin {case} 0 {\ text {if}} f (i, i) = 0, \\ {\ text {undefined}} {\ text {в противном случае.}} \ end {cases} }

Проверка вычислимости g основана на следующих конструкциях (или их эквивалентах):

  • вычислимые подпрограммы (программа, вычисляющая f, является подпрограммой в программе e),
  • дублирование значений (программа e вычисляет входы i, i для f из входа i для g),
  • условное ветвление (программа e выбирает между двумя результатами в зависимости от значения, которое она вычисляет для f (i, i)),
  • не дает определенного результата (например, путем бесконечного цикла),
  • возвращает значение 0.

Следующий псевдокод иллюстрирует простой способ вычисления g:

процедура compute_g (i): если f (i, i) == 0, тогда вернуть 0 цикл else навсегда

Поскольку g частично вычислим, должна быть программа e, которая вычисляет g, предположение, что модель вычислений является полной по Тьюрингу. Эта программа - одна из всех программ, в которых определена функция остановки h. Следующий шаг доказательства показывает, что h (e, e) не будет иметь того же значения, что и f (e, e).

Из определения g следует, что должен выполняться ровно один из следующих двух случаев:

  • f (e, e) = 0 и, следовательно, g (e) = 0. В этом случае h (e, e) = 1, потому что программа e останавливается на входе e.
  • f (e, e) ≠ 0 и поэтому g (e) не определено. В этом случае h (e, e) = 0, потому что программа e не останавливается на входе e.

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

Это доказательство аналогично диагональному аргументу Кантора. Можно визуализировать двумерный массив с одним столбцом и одной строкой для каждого натурального числа, как указано в таблице выше. Значение f (i, j) помещается в столбец i, строку j. Поскольку предполагается, что f является общей вычислимой функцией, любой элемент массива может быть вычислен с помощью f. Построение функции g можно визуализировать с помощью главной диагонали этого массива. Если массив имеет 0 в позиции (i, i), тогда g (i) равно 0. В противном случае g (i) не определено. Противоречие происходит из-за того, что существует некоторый столбец e массива, соответствующий самому g. Теперь предположим, что f была функцией остановки h, если g (e) определена (в данном случае g (e) = 0), g (e) останавливается, поэтому f (e, e) = 1. Но g (e) = 0 только тогда, когда f (e, e) = 0, что противоречит f (e, e) = 1. Аналогично, если g (e) не определен, то функция остановки f (e, e) = 0, что приводит к g (e) = 0 по построению g. Это противоречит предположению, что g (e) не определено. В обоих случаях возникает противоречие. Следовательно, любая вычислимая функция f не может быть функцией остановки h.

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

Типичным методом доказательства неразрешимости проблемы является метод редукции. Для этого достаточно показать, что если решение новой проблемы было найдено, его можно было бы использовать для решения неразрешимой проблемы путем преобразования экземпляров неразрешимой проблемы в экземпляры новой проблемы. Поскольку мы уже знаем, что никакой метод не может решить старую проблему, никакой метод не может решить и новую проблему. Часто новая проблема сводится к решению проблемы остановки. (Тот же метод используется для демонстрации того, что проблема NP complete, только в этом случае вместо демонстрации отсутствия решения он демонстрирует отсутствие решения за полиномиальное время, предполагая, что P ≠ NP.)

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

Теорема Райса обобщает теорему о неразрешимости проблемы остановки. В нем говорится, что для любого нетривиального свойства не существует общей процедуры принятия решения, которая для всех программ решала бы, обладает ли частичная функция, реализованная входной программой, этим свойством. (Частичная функция - это функция, которая не всегда может давать результат, и поэтому используется для моделирования программ, которые могут либо давать результаты, либо не останавливаться.) Например, свойство «остановка для входа 0» неразрешимо. Здесь «нетривиальный» означает, что набор частичных функций, удовлетворяющих этому свойству, не является ни пустым набором, ни набором всех частичных функций. Например, «останавливается или не останавливается на входе 0» явно верно для всех частичных функций, поэтому это тривиальное свойство, и его можно определить с помощью алгоритма, который просто сообщает «истина». Кроме того, эта теорема верна только для свойств частичной функции, реализованной программой; Теорема Райса не распространяется на свойства самой программы. Например, «остановка на входе 0 в пределах 100 шагов» не является свойством частичной функции, которая реализуется программой - это свойство программы, реализующей частичную функцию, и очень разрешимо.

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

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

. Поскольку отрицательный ответ на проблему остановки показывает, что существуют проблемы, которые не могут быть решены машиной Тьюринга, тезис Черча – Тьюринга ограничивает чего можно достичь на любой машине, реализующей эффективные методы. Однако не все машины, которые можно представить человеческому воображению, подчиняются тезису Чёрча – Тьюринга (например, машины-оракулы ). Остается открытым вопрос, могут ли существовать реальные детерминированные физические процессы, которые в конечном итоге ускользают от моделирования машиной Тьюринга, и, в частности, можно ли с пользой использовать какой-либо такой гипотетический процесс в форме вычислительная машина (гиперкомпьютер ), которая могла бы, среди прочего, решить проблему остановки для машины Тьюринга. Также остается открытым вопрос, участвуют ли такие неизвестные физические процессы в работе человеческого мозга и могут ли люди решить проблему остановки (Copeland 2004, p. 15).

Теоремы Гёделя о неполноте

Концепции, возникающие в теоремах Гёделя о неполноте, очень похожи на те, которые возникают в связи с проблемой остановки, и доказательства очень похожи. Фактически, более слабая форма Первой теоремы о неполноте является простым следствием неразрешимости проблемы остановки. Эта более слабая форма отличается от стандартной формулировки теоремы о неполноте тем, что утверждает, что аксиоматизация натуральных чисел, которая одновременно является полной и звуковой, невозможна. «Правильная» часть - это ослабление: это означает, что мы требуем, чтобы рассматриваемая аксиоматическая система доказывала только истинные утверждения о натуральных числах. Поскольку разумность подразумевает согласованность, эту более слабую форму можно рассматривать как следствие сильной формы. Важно отметить, что утверждение стандартной формы первой теоремы Гёделя о неполноте совершенно не связано с истинностью утверждения, а касается только вопроса о том, возможно ли его найти с помощью математического доказательства.

Более слабая форма теоремы может быть доказана из неразрешимости проблемы остановки следующим образом. Предположим, что у нас есть обоснованная (и, следовательно, непротиворечивая) и полная аксиоматизация всех истинных логических утверждений о натуральных числах. Затем мы можем построить алгоритм, который перечислит все эти утверждения. Это означает, что существует алгоритм N (n), который, учитывая натуральное число n, вычисляет истинное логическое утверждение первого порядка о натуральных числах, и что для всех истинных утверждений существует по крайней мере одно n такое, что N (n) дает это заявление. Теперь предположим, что мы хотим решить, останавливается ли алгоритм с представлением a на входе i. Мы знаем, что это утверждение может быть выражено с помощью логического оператора первого порядка, скажем, H (a, i). Поскольку аксиоматизация завершена, то либо существует n такое, что N (n) = H (a, i), либо существует n 'такое, что N (n') = ¬ H (a, i). Таким образом, если мы перебираем по всем n, пока не найдем H (a, i) или его отрицание, мы всегда остановимся, и, более того, ответ, который он нам даст, будет истинным (по разумности). Это означает, что это дает нам алгоритм для решения проблемы остановки. Поскольку мы знаем, что такого алгоритма быть не может, отсюда следует, что предположение о том, что существует непротиворечивая и полная аксиоматизация всех истинных логических утверждений первого порядка о натуральных числах, должно быть ложным.

Обобщение

Многие варианты проблемы остановки можно найти в учебниках по вычислимости (например, Sipser 2006, Davis 1958, Minsky 1967, Hopcroft and Ullman 1979, Börger 1989). Обычно их неразрешимость следует за уменьшением стандартной задачи остановки. Однако некоторые из них имеют более высокую степень неразрешимости. Следующие два примера типичны.

Остановка на всех входах

Универсальная проблема остановки, также известная (в теории рекурсии ) как совокупность, - это проблема определения, остановится ли данная компьютерная программа для каждого входа (совокупность имени происходит от эквивалентного вопроса о том, является ли вычисленная функция итого ). Эта проблема не только неразрешима, как проблема остановки, но и весьма неразрешима. С точки зрения арифметической иерархии, это Π 2 0 {\ displaystyle \ Pi _ {2} ^ {0}}\ Pi _ {2} ^ {0} -complete (Börger 1989, p. 121).

Это, в частности, означает, что проблема остановки не может быть решена даже с помощью oracle.

Распознавание частичных решений

Существует множество программ, которые для некоторых входных данных возвращают правильный ответ на проблему остановки, в то время как для других входных данных они не возвращают ответ вообще. Однако проблема «данная программа p является ли она решателем частичной остановки» (в описанном смысле) по крайней мере так же сложна, как и проблема остановки. Чтобы убедиться в этом, предположим, что для этого существует алгоритм PHSR («распознаватель решателя частичной остановки»). Затем его можно использовать для решения проблемы остановки следующим образом: чтобы проверить, останавливается ли входная программа x на y, создайте программу p, которая на входе (x, y) сообщает истину и расходится на всех других входах. Затем проверьте p с помощью PHSR.

Приведенный выше аргумент является сокращением проблемы остановки до распознавания PHS, и таким же образом могут быть уменьшены более сложные проблемы, такие как остановка всех входных данных, подразумевая, что распознавание PHS не только неразрешимый, но и более высокий в арифметической иерархии, а именно Π 2 0 {\ displaystyle \ Pi _ {2} ^ {0}}\ Pi _ {2} ^ {0} -complete.

Вычисление с потерями

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

машины Oracle

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

См. Также
Примечания
Ссылки
  • Алан Тьюринг, О вычислимых числах, с приложением к Entscheidungsproblem, Труды Лондонского математического общества, Series 2, Volume 42 (1937), pp 230–265, doi : 10.1112 / plms / s2-42.1.230. - Алан Тьюринг, О вычислимых числах, с приложением к Entscheidungsproblem. A Correction, Proceedings of the London Mathematical Society, Series 2, Volume 43 (1938), pp 544–546, doi : 10.1112 / plms / s2-43.6.544. Бесплатная онлайн-версия обеих частей Это эпохальная статья, в которой Тьюринг определяет машины Тьюринга, формулирует проблему остановки и показывает, что она (а также Entscheidungsproblem ) неразрешима.
  • Сипсер, Майкл (2006). «Раздел 4.2: Проблема остановки». Введение в теорию вычислений (второе изд.). PWS Publishing. С. 173–182. ISBN 0-534-94728-X.
  • c2: HaltingProblem
  • Черч, Алонзо (1936). «Неразрешимая проблема элементарной теории чисел». Американский журнал математики. 58 (2): 345–363. doi : 10.2307 / 2371045. JSTOR 2371045.
  • Б. Джек Коупленд изд. (2004), The Essential Turing: Seminal Writings in Computing, Logic, Philosophy, Artificial Intelligence, and Artificial Life plus The Secrets of Enigma, Clarendon Press (Oxford University Press), Oxford UK, ISBN 0-19-825079-7.
  • Дэвис, Мартин (1965). Неразрешимые, основные статьи о неразрешимых предложениях, неразрешимых проблемах и вычислимых функциях. Нью-Йорк: Raven Press.. Статья Тьюринга занимает третье место в этом томе. Работы включают работы Годеля, Черча, Россера, Клини и Поста.
  • Дэвис, Мартин (1958). Вычислимость и неразрешимость. Нью-Йорк: McGraw-Hill..
  • Альфред Норт Уайтхед и Бертран Рассел, Principia Mathematica to * 56, Cambridge at the University Press, 1962. Касательно проблемы парадоксов, авторы обсуждают проблема множества не может быть объектом ни в одной из его «определяющих функций», в частности «Введение, гл. 1 стр. 24«... трудности, возникающие в формальной логике »и гл. 2.I. Принцип порочного круга », стр. 37ff, и глава 2.VIII.« Противоречия », стр. 60ff.
  • Мартин Дэвис,« Что такое вычисления », в Mathematics Today, Lynn Arthur Steen, Vintage Books (Random House), 1980. Замечательная небольшая статья, возможно, лучшая из когда-либо написанных о машинах Тьюринга для неспециалистов. Дэвис сводит машину Тьюринга к гораздо более простой модели, основанной на модели вычислений Поста. Обсуждает Чейтин доказательство. Включает небольшие биографии Эмиля Поста, Джулии Робинсон.
  • Марвина Мински, «Вычисления: конечные и бесконечные машины», Prentice-Hall, Inc., Нью-Джерси, 1967. См. Главу тер 8, раздел 8.2 «Неразрешимость проблемы остановки».
  • Роджер Пенроуз, «Новый разум императора: о компьютерах, умах и законах физики», Oxford University Press, Oxford England, 1990 г. (с исправлениями). Ср. Глава 2, «Алгоритмы и машины Тьюринга». An over-complicated presentation (see Davis's paper for a better model), but a thorough presentation of Turing machines and the halting problem, and Church's Lambda Calculus.
  • John Hopcroft and Jeffrey Ullman, Introduction to Automata Theory, Languages and Computation, Addison-Wesley, Reading Mass, 1979. See Chapter 7 "Turing Machines." A book centered around the machine-interpretation of "languages", NP-Completeness, etc.
  • Andrew Hodges, Alan Turing: The Enigma, Simon and Schuster, New York. Ср. Chapter "The Spirit of Truth" for a history leading to, and a discussion of, his proof.
  • Constance Reid, Hilbert, Copernicus: Springer-Verlag, New York, 1996 (first published 1970). Fascinating history of German mathematics and physics from 1880s through 1930s. Hundreds of names familiar to mathematicians, physicists and engineers appear in its pages. Perhaps marred by no overt references and few footnotes: Reid states her sources were numerous interviews with those who personally knew Hilbert, and Hilbert's letters and papers.
  • , What is Random? Chance and order in mathematics and life, Copernicus: Springer-Verlag, New York, 1999. Nice, gentle read for the mathematically inclined non-specialist, puts tougher stuff at the end. Has a Turing-machine model in it. Discusses the Chaitin contributions.
  • Moore, Cristopher ; Mertens, Stephan (2011), The Nature of Computation, Oxford University Press, ISBN 9780191620805
  • Ernest Nagel and James R. Newman, Godel’s Proof, New York University Press, 1958. Wonderful writing about a very difficult subject. For the mathematically inclined non-specialist. Discusses Gentzen 's proof on pages 96–97 and footnotes. Appendices discuss the Peano Axioms briefly, gently introduce readers to formal logic.
  • Taylor Booth, Sequential Machines and Automata Theory, Wiley, New York, 1967. Cf. Chapter 9, Turing Machines. Difficult book, meant for electrical engineers and technical specialists. Discusses recursion, partial-recursion with reference to Turing Machines, halting problem. Has a Turing Machine model in it. References at end of Chapter 9 catch most of the older books (i.e. 1952 until 1967 including authors Martin Davis, F. C. Hennie, H. Hermes, S. C. Kleene, M. Minsky, T. Rado) and various technical papers. See note under Busy-Beaver Programs.
  • Busy Beaver Programs are described in Scientific American, August 1984, also March 1985 p. 23. A reference in Booth attributes them to Rado, T.(1962), On non-computable functions, Bell Systems Tech. J. 41. Booth also defines Rado's Busy Beaver Problem in problems 3, 4, 5, 6 of Chapter 9, p. 396.
  • , Turing’s Man: Western Culture in the Computer Age, The University of North Carolina Press, Chapel Hill, 1984. For the general reader. May be dated. В нем есть еще одна (очень простая) модель машины Тьюринга.
  • Эгон Бёргер. «Вычислимость, сложность, логика». North-Holland, 1989.
  • Стивен Клини, Введение в метаматематику, Северная Голландия, 1952. Глава XIII («Вычислимые функции») включает обсуждение неразрешимости проблемы остановки для машин Тьюринга. В отступление от терминологии Тьюринга о машинах без круговоротов без холостого хода, Клини вместо этого ссылается на машины, которые «останавливаются», то есть останавливаются.
  • Свен Кёлер, Кристиан Шиндельхауэр, Мартин Циглер, О приближении реальных проблем с остановкой, стр..454-466 (2005) ISBN 3540281932 Заметки к лекциям Springer в томе 3623 информатики: Неразрешимость проблемы остановки означает, что не на все случаи можно ответить правильно; но, может быть, «некоторые», «многие» или «большинство» могут? С одной стороны, постоянный ответ «да» будет правильным бесконечно часто, и неправильным также бесконечно часто. Чтобы сделать вопрос разумным, рассмотрим плотность примеров, которые могут быть решены. Оказывается, это в значительной степени зависит от рассматриваемой системы программирования.
  • Логические ограничения машинной этики с последствиями для летального автономного оружия - статья обсуждается в: Означает ли проблема остановки Никаких моральных роботов?
  • и Фемистокл М. Рассиас, Современная дискретная математика и анализ: с приложениями в криптографии, информационных системах и моделировании Springer, 2018. ISBN 978-3319743240. Глава 3 Раздел 1 содержит качественное описание проблемы остановки, доказательство от противоречия и полезное графическое представление проблемы остановки.
Внешние ссылки
Последняя правка сделана 2021-05-22 11:36:16
Содержание доступно по лицензии CC BY-SA 3.0 (если не указано иное).
Обратная связь: support@alphapedia.ru
Соглашение
О проекте