В теории вычислимости функция Аккермана , названная в честь Вильгельма Аккермана , является одним из простейших [1] и самых ранних открытых примеров полностью вычислимой функции, которая не является примитивно рекурсивной . Все примитивно рекурсивные функции являются тотальными и вычислимыми, но функция Аккермана иллюстрирует, что не все полностью вычислимые функции являются примитивно рекурсивными.
После публикации [2] функции Аккермана (которая имела три неотрицательных целых аргумента) многие авторы модифицировали ее для различных целей, так что сегодня «функция Аккермана» может относиться к любому из многочисленных вариантов исходной функции. Одной из распространенных версий является двухаргументная функция Аккермана–Петера, разработанная Рожей Петер и Рафаэлем Робинсоном . Ее значение растет очень быстро; например, результатом является , целое число из 19 729 десятичных цифр. [3]
История
В конце 1920-х годов математики Габриэль Судан и Вильгельм Акерман , ученики Давида Гильберта , изучали основы вычислений. И Судану, и Акерману приписывают [4] открытие полных вычислимых функций (в некоторых источниках называемых просто «рекурсивными»), которые не являются примитивно рекурсивными . Судан опубликовал менее известную функцию Судана , а вскоре после этого и независимо, в 1928 году, Акерман опубликовал свою функцию (от греческой буквы фи ). Трехаргументная функция Акермана, , определена таким образом, что для , она воспроизводит основные операции сложения , умножения и возведения в степень как
а для p > 2 он расширяет эти базовые операции таким образом, что их можно сравнить с гипероперациями :
(Помимо своей исторической роли как полностью вычислимой, но не примитивно рекурсивной функции, исходная функция Аккермана расширяет основные арифметические операции за пределы возведения в степень, хотя и не так гладко, как это делают варианты функции Аккермана, специально разработанные для этой цели, например, последовательность гиперопераций Гудстейна .)
В работе «О бесконечности » [5] Дэвид Гильберт выдвинул гипотезу, что функция Аккермана не является примитивно рекурсивной, но именно Аккерман, личный секретарь Гильберта и его бывший студент, фактически доказал эту гипотезу в своей статье « О конструкции действительных чисел по Гильберту» . [2] [6]
Позднее Рожа Петер [7] и Рафаэль Робинсон [8] разработали версию функции Аккермана с двумя переменными, которая стала предпочтительнее почти всех авторов.
По сравнению с большинством других версий, функция Бака не имеет несущественных смещений:
Было исследовано много других версий функции Аккермана. [12] [13]
Определение
Определение: как m-арная функция
Оригинальная функция Аккермана с тремя аргументами определяется рекурсивно следующим образом для неотрицательных целых чисел и :
Из различных версий с двумя аргументами версия, разработанная Петером и Робинсоном (называемая большинством авторов «функцией Аккермана»), определена для неотрицательных целых чисел следующим образом :
Для вычисления можно использовать стек , который изначально содержит элементы .
Затем повторно два верхних элемента заменяются в соответствии с правилами [n 4]
Схематически, начиная с :
WHILE длина стека <> 1{ ВСТАВИТЬ 2 элемента; ВСТАВИТЬ 1 или 2 или 3 элемента, применяя правила r1, r2, r3}
Псевдокод опубликован в работе Гроссмана и Цейтмана (1988).
Например, при вводе ,
конфигурации стека
отражают сокращение [n 5]
Замечания
Стратегия «самый левый-самый внутренний» реализована в 225 языках программирования на Rosetta Code .
Для всех вычислений требуется не более шагов. [18]
Гроссман и Зейтман (1988) указали, что при вычислении максимальной длины стека , при условии .
Их собственный алгоритм, по сути своей итеративный, производит вычисления во времени и пространстве.
TRS, основанный на итерированной 1-арной функции
Определение итерированных 1-арных функций Аккермана приводит к различным правилам редукции
Так как композиция функций ассоциативна, то вместо правила r6 можно определить
Как и в предыдущем разделе, вычисление можно реализовать с помощью стека.
Первоначально стек содержит три элемента .
Затем три верхних элемента многократно заменяются в соответствии с правилами [n 4]
Схематически, начиная с :
WHILE длина стека <> 1{ ВСТАВИТЬ 3 элемента; ВЫТЯНУТЬ 1 или 3 или 5 элементов, применяя правила r4, r5, r6;}
Пример
На входе последовательные конфигурации стека
Соответствующие равенства имеют вид
При использовании правила редукции r7 вместо правила r6 замены в стеке будут следующими
Последовательные конфигурации стека будут тогда
Соответствующие равенства имеют вид
Замечания
На любом заданном входе представленные до сих пор TRS сходятся за одинаковое количество шагов. Они также используют одни и те же правила редукции (в этом сравнении правила r1, r2, r3 считаются «такими же, как» правила r4, r5, r6/r7 соответственно). Например, редукция сходится за 14 шагов: 6 × r1, 3 × r2, 5 × r3. Редукция сходится за те же 14 шагов: 6 × r4, 3 × r5, 5 × r6/r7. TRS различаются порядком применения правил редукции.
Когда вычисляется по правилам {r4, r5, r6}, максимальная длина стека остается ниже . Когда вместо правила r6 используется правило редукции r7, максимальная длина стека составляет всего . Длина стека отражает глубину рекурсии. Поскольку редукции по правилам {r4, r5, r7} подразумевает меньшую максимальную глубину рекурсии, [n 6] это вычисление более эффективно в этом отношении.
TRS, на основе гипероператоров
Как ясно показали Сундблад (1971) или Порто и Матос (1980), функция Аккермана может быть выражена через последовательность гиперопераций :
или, после удаления константы 2 из списка параметров, в терминах функции Бака
Функция Бака [10] , которая сама по себе является вариантом функции Аккермана, может быть вычислена с помощью следующих правил редукции:
Вместо правила b6 можно определить правило
Для вычисления функции Аккермана достаточно добавить три правила редукции
Эти правила учитывают базовый случай A(0,n), выравнивание (n+3) и подстановку (-3).
Пример
Вычислить
используя правило сокращения : [n 5]
используя правило сокращения : [n 5]
Соответствующие равенства имеют вид
когда применяется TRS с правилом сокращения :
когда применяется TRS с правилом сокращения :
Замечания
Вычисление по правилам {b1 - b5, b6, r8 - r10} является глубоко рекурсивным. Максимальная глубина вложенности s составляет . Виновником является порядок выполнения итерации: . Первая исчезает только после того, как вся последовательность развернута.
Вычисление по правилам {b1 - b5, b7, r8 - r10} более эффективно в этом отношении. Итерация имитирует повторяющийся цикл по блоку кода. [n 7] Вложенность ограничена одним уровнем рекурсии на итеративную функцию. Мейер и Ритчи (1967) показали это соответствие.
Эти соображения касаются только глубины рекурсии. Любой способ итерации приводит к одинаковому числу шагов редукции, включающих одни и те же правила (когда правила b6 и b7 считаются «одними и теми же»). Редукция, например, сходится за 35 шагов: 12 × b1, 4 × b2, 1 × b3, 4 × b5, 12 × b6/b7, 1 × r9, 1 × r10. Modus iterandi влияет только на порядок, в котором применяются правила редукции.
Реального выигрыша во времени выполнения можно добиться только не пересчитывая подрезультаты снова и снова. Мемоизация — это метод оптимизации, при котором результаты вызовов функций кэшируются и возвращаются, когда те же самые входные данные появляются снова. См., например, Ward (1993). Grossman & Zeitman (1988) опубликовали хитрый алгоритм, который вычисляет во времени и в пространстве.
Огромные цифры
Чтобы продемонстрировать, как вычисление результатов происходит за много шагов и в большом количестве: [n 5]
Таблица значений
Вычисление функции Аккермана можно переформулировать в терминах бесконечной таблицы. Сначала разместите натуральные числа вдоль верхней строки. Чтобы определить число в таблице, возьмите число сразу слева. Затем используйте это число, чтобы найти требуемое число в столбце, заданном этим числом, и на одну строку выше. Если слева нет числа, просто посмотрите на столбец под заголовком «1» в предыдущей строке. Вот небольшая верхняя левая часть таблицы:
Значения A ( m , n )
н
м
0
1
2
3
4
н
0
1
2
3
4
5
1
2
3
4
5
6
2
3
5
7
9
11
3
5
13
29
61
125
4
13
65533
2 65536 − 3
5
65533
6
м
Числа, представленные здесь только с помощью рекурсивного возведения в степень или стрелок Кнута, очень велики и заняли бы слишком много места, если бы их записывать простыми десятичными цифрами.
Несмотря на большие значения, встречающиеся в этой ранней части таблицы, были определены некоторые даже большие числа, такие как число Грэма , которое не может быть записано с помощью любого малого количества стрелок Кнута. Это число построено с помощью техники, похожей на рекурсивное применение функции Аккермана к самой себе.
Это повторение приведенной выше таблицы, но значения заменены соответствующим выражением из определения функции, чтобы наглядно показать закономерность:
Значения A ( m , n )
н
м
0
1
2
3
4
н
0
0+1
1+1
2+1
3+1
4+1
н + 1
1
А (0, 1)
А (0, А (1, 0)) = А (0, 2)
А (0, А (1, 1)) = А (0, 3)
А (0, А (1, 2)) = А (0, 4)
А (0, А (1, 3)) = А (0, 5)
А (0, А (1, n −1))
2
А (1, 1)
А (1, А (2, 0)) = А (1, 3)
А (1, А (2, 1)) = А (1, 5)
А (1, А (2, 2)) = А (1, 7)
А (1, А (2, 3)) = А (1, 9)
А (1, А (2, n −1))
3
А (2, 1)
А (2, А (3, 0)) = А (2, 5)
А (2, А (3, 1)) = А (2, 13)
А (2, А (3, 2)) = А (2, 29)
А (2, А (3, 3)) = А (2, 61)
А (2, А (3, n −1))
4
А (3, 1)
А (3, А (4, 0)) = А (3, 13)
А (3, А (4, 1)) = А (3, 65533)
А (3, А (4, 2))
А (3, А (4, 3))
А (3, А (4, n −1))
5
А (4, 1)
А (4, А (5, 0))
А (4, А (5, 1))
А (4, А (5, 2))
А (4, А (5, 3))
А (4, А (5, n −1))
6
А (5, 1)
А (5, А (6, 0))
А (5, А (6, 1))
А (5, А (6, 2))
А (5, А (6, 3))
А (5, А (6, n −1))
Характеристики
Общие замечания
Может быть не сразу очевидно, что оценка всегда завершается. Однако рекурсия ограничена, поскольку в каждом рекурсивном применении либо уменьшается, либо остается прежним и уменьшается. Каждый раз, когда достигает нуля, уменьшается, поэтому в конечном итоге также достигает нуля. (Выражаясь более технически, в каждом случае пара уменьшается в лексикографическом порядке пар, что является хорошим упорядочением , как и упорядочение отдельных неотрицательных целых чисел; это означает, что нельзя опускаться в порядке бесконечно много раз подряд.) Однако, когда уменьшается, нет верхней границы того, насколько может увеличиться — и часто это увеличение будет значительным.
Для малых значений m, таких как 1, 2 или 3, функция Аккермана растет относительно медленно по отношению к n (максимум экспоненциально ). Для , однако, она растет гораздо быстрее; даже составляет около 2,00353 × 1019 728 , а десятичное расширениеочень велико по любым типичным меркам, около 2,12004 × 10 6,03123 × 1019 727 .
Интересный аспект заключается в том, что единственная арифметическая операция, которую он когда-либо использует, — это сложение 1. Его быстрорастущая мощность основана исключительно на вложенной рекурсии. Это также подразумевает, что время его работы по крайней мере пропорционально его выходу, и поэтому также чрезвычайно велико. На самом деле, в большинстве случаев время работы намного больше, чем выход; см. выше.
Одноаргументная версия , которая увеличивает и то , и другое одновременно, затмевает все примитивные рекурсивные функции, включая очень быстрорастущие функции, такие как экспоненциальная функция , факториальная функция, мульти- и суперфакториальные функции и даже функции, определенные с использованием нотации Кнута со стрелкой вверх (за исключением случаев, когда используется индексированная стрелка вверх). Можно увидеть, что примерно сопоставимо с в быстрорастущей иерархии . Этот экстремальный рост можно использовать, чтобы показать, что то, что, очевидно, вычислимо на машине с бесконечной памятью, такой как машина Тьюринга , и поэтому является вычислимой функцией , растет быстрее, чем любая примитивная рекурсивная функция, и, следовательно, не является примитивно рекурсивным.
Не примитивно рекурсивный
Функция Аккермана растет быстрее, чем любая примитивно-рекурсивная функция , и поэтому сама по себе не является примитивно-рекурсивной. Набросок доказательства таков: примитивно-рекурсивная функция, определенная с использованием до k рекурсий, должна расти медленнее, чем , (k+1)-я функция в быстрорастущей иерархии, но функция Аккермана растет по крайней мере так же быстро, как .
В частности, показано, что для каждой примитивной рекурсивной функции существует неотрицательное целое число, такое что для всех неотрицательных целых чисел ,
Как только это установлено, следует, что само по себе не является примитивно рекурсивным, поскольку в противном случае подстановка привела бы к противоречию
Доказательство проводится следующим образом: определяется класс всех функций, которые растут медленнее функции Аккермана
и показать, что содержит все примитивные рекурсивные функции. Последнее достигается путем показа того, что содержит константные функции, функцию-последователя, функции проекции и что она замкнута относительно операций композиции функций и примитивной рекурсии.
Использование в вычислительной сложности
Функция Аккермана появляется во временной сложности некоторых алгоритмов [19], таких как системы сложения векторов [20] и достижимость сетей Петри [21] , таким образом показывая, что они вычислительно невыполнимы для больших примеров. Обратная функция Аккермана появляется в некоторых результатах временной сложности.
Обратный
Поскольку рассмотренная выше функция f ( n ) = A ( n , n ) растет очень быстро, ее обратная функция , f −1 , растет очень медленно. Эта обратная функция Аккермана f −1 обычно обозначается как α . Фактически, α ( n ) меньше 5 для любого практического размера входных данных n , поскольку A (4, 4) имеет порядок .
Эта обратная функция появляется во временной сложности некоторых алгоритмов, таких как структура данных непересекающихся множеств и алгоритм Шазелла для минимальных остовных деревьев . Иногда в этих настройках используется исходная функция Аккермана или другие вариации, но все они растут с одинаково высокой скоростью. В частности, некоторые модифицированные функции упрощают выражение, исключая −3 и подобные члены.
Двухпараметрическую вариацию обратной функции Аккермана можно определить следующим образом, где — функция пола :
Эта функция возникает при более точном анализе алгоритмов, упомянутых выше, и дает более точную временную границу. В структуре данных непересекающихся множеств m представляет собой количество операций, а n представляет собой количество элементов; в алгоритме минимального остовного дерева m представляет собой количество ребер, а n представляет собой количество вершин. Существует несколько немного отличающихся определений α ( m , n ) ; например, log 2 n иногда заменяется на n , а функция floor иногда заменяется на ceiling .
Другие исследования могут определить обратную функцию единицы, где m установлено равным константе, так что обратная функция применяется к конкретной строке. [22]
Обратная функция Аккермана является примитивно рекурсивной. [23]
Использовать как эталон
Функция Аккермана, благодаря своему определению в терминах чрезвычайно глубокой рекурсии, может использоваться в качестве эталона способности компилятора оптимизировать рекурсию. Первое опубликованное использование функции Аккермана таким образом было в 1970 году Драгошем Вайдой [24] и, почти одновременно, в 1971 году, Ингве Сундбладом. [14]
Основополагающая работа Сундблада была продолжена Брайаном Вихманном (соавтором эталонного теста Whetstone ) в трилогии статей, написанных между 1975 и 1982 годами. [25] [26] [27]
^ На каждом шаге подчеркнутый редекс переписывается.
^ ab здесь: стратегия «самая левая-самая внутренняя»!
^ abcd Для лучшей читаемости S(0) обозначается как 1, S(S(0)) обозначается как 2, S(S(S(0))) обозначается как 3 и т. д.
^ Максимальная глубина рекурсии относится к числу уровней активации процедуры, которые существуют во время самого глубокого вызова процедуры. Корнелиус и Кирби (1975)
^ ЦИКЛ n+1 РАЗ ДЕЛИТЬ F
Ссылки
^ Монин и Хинчи 2003, с. 61.
^ ab Аккерманн 1928.
^ "Десятичное разложение A(4,2)". kosara.net . 27 августа 2000 г. Архивировано из оригинала 20 января 2010 г.
^ Калуде, Маркус и Теви 1979.
↑ Гильберт 1926, стр. 185.
^ ван Хейеноорт 1977.
↑ Питер 1935.
↑ Робинсон 1948.
↑ Ричи 1965, стр. 1028.
^ abc Бак 1963.
^ Меуссен и Зантема 1992, стр. 6.
^ Мунафо 1999a.
↑ Ричи 1965.
^ ab Sundblad 1971.
↑ Порто и Матос 1980.
^ Гроссман и Цейтман 1988.
^ Полсон 2021.
↑ Коэн 1987, стр. 56, Предложение 3.16 (см. в корректуре).
Calude, Cristian ; Marcus, Solomon ; Tevy, Ionel (ноябрь 1979 г.). «Первый пример рекурсивной функции, которая не является примитивно рекурсивной». Historia Math . 6 (4): 380–84. doi : 10.1016/0315-0860(79)90024-7 .
Коэн, Дэниел Э. (январь 1987). Вычислимость и логика . Halsted Press. ISBN9780745800349.
Корнелиус, Б. Дж.; Кирби, Г. Х. (1975). «Глубина рекурсии и функция Акермана». BIT Numerical Mathematics . 15 (2): 144–150. doi :10.1007/BF01932687. S2CID 120532578.
Czerwiński, Wojciech; Orlikowski, Łukasz (7 февраля 2022 г.). Достижимость в системах сложения векторов является полной по Аккерману. Труды 62-го ежегодного симпозиума IEEE 2021 года по основам компьютерной науки. arXiv : 2104.13866 . doi :10.1109/FOCS52979.2021.00120.
Grossman, Jerrold W.; Zeitman, R.Suzanne (май 1988). "По сути итеративное вычисление функции Аккермана". Теоретическая информатика . 57 (2–3): 327–330. doi :10.1016/0304-3975(88)90046-1.
ван Хейеноорт, Жан (1977) [перепечатано с исправлениями, впервые опубликовано в 1967]. От Фреге до Гёделя: Учебник по математической логике, 1879–1931 . Издательство Гарвардского университета.
Leroux, Jérôme (7 февраля 2022 г.). Проблема достижимости сетей Петри не является примитивно рекурсивной. Труды 62-го ежегодного симпозиума IEEE 2021 года по основам компьютерной науки. arXiv : 2104.12695 . doi : 10.1109/FOCS52979.2021.00121.
Матос, Армандо Б. (7 мая 2014 г.). "Обратная функция Аккермана примитивно рекурсивна" (PDF) . Архивировано (PDF) из оригинала 9 октября 2022 г.
Meeussen, VCS; Zantema, H. (1992). Derivation lengths in term rewriting from interpretations in the naturals (PDF) (Report). Universiteit Utrecht. UU-CS, Department of Computer Science. ISSN 0924-3275. Архивировано (PDF) из оригинала 9 октября 2022 г.
Мейер, Альберт Р.; Ритчи , Деннис МакАлистер (1967). «Сложность циклических программ». Труды 22-й национальной конференции 1967 г. . ACM '67: Труды 22-й национальной конференции 1967 г. Стр. 465–469. doi : 10.1145/800196.806014 .
Pettie, S. (2002). "Нижняя граница в стиле обратного Аккермана для проблемы проверки минимального остовного дерева в режиме онлайн". 43-й ежегодный симпозиум IEEE по основам компьютерной науки, 2002. Труды . С. 155–163. doi :10.1109/SFCS.2002.1181892. ISBN0-7695-1822-2. S2CID 8636108.
Порту, Антонио; Матос, Армандо Б. (1 сентября 1980 г.). «Акерман и сверхдержавы» (PDF) . Новости ACM SIGACT . 12 (3): Оригинальная версия 1980 г., опубликована в «Новости ACM SIGACT», Изменено 20 октября 2012 г., Изменено 23 января 2016 г. (рабочий документ). doi : 10.1145/1008861.1008872. S2CID 29780652. Архивировано (PDF) из оригинала 9 октября 2022 г.
Ритчи, Роберт Уэллс (ноябрь 1965 г.). «Классы рекурсивных функций, основанные на функции Аккермана». Pacific Journal of Mathematics . 15 (3): 1027–1044. doi : 10.2140/pjm.1965.15.1027 .
Сундблад, Ингве (март 1971 г.). «Функция Аккермана. Теоретическое, вычислительное и формульное исследование». BIT Numerical Mathematics . 11 (1): 107–119. doi :10.1007/BF01935330. S2CID 123416408.
Вайда, Драгош (1970). «Проверка компилятора для алголоподобного языка». Бюллетень Математического общества Математических наук Республики Социалистическая Румыния . Новая серия. 14 (62) (4): 487–502. JSTOR 43679758.
Уорд, Мартин П. (16 июля 1993 г.). Итеративные процедуры вычисления функции Аккермана . CiteSeerX 10.1.1.35.9907 .
Wichmann, Brian A. (март 1976 г.). «Функция Аккермана: исследование эффективности вызовов процедур». BIT Numerical Mathematics . 16 : 103–110. CiteSeerX 10.1.1.108.4125 . doi :10.1007/BF01940783. S2CID 16993343.
Вихманн, Брайан А. (июль 1977 г.). «Как вызывать процедуры, или вторые мысли о функции Аккермана». BIT Numerical Mathematics . 16 (3): 103–110. doi :10.1002/spe.4380070303. S2CID 206507320.
Вихманн, Брайан А. (июль 1982 г.). "Последние результаты теста вызова процедур, функция Аккермана" (PDF) . Архивировано (PDF) из оригинала 9 октября 2022 г.