Текст книги "Тени разума. В поисках науки о сознании"
Автор книги: Роджер Пенроуз
Жанр:
Философия
сообщить о нарушении
Текущая страница: 9 (всего у книги 49 страниц)
В этом разделе мы поговорим о вычислениях. Под вычислением (или алгоритмом) я подразумеваю действие некоторой машины Тьюринга, или, иными словами, действие компьютера, задаваемое той или иной компьютерной программой. Не следует забывать и о том, что понятие вычисления включает в себя не только выполнение обычных арифметических действий – таких, например, как сложение или умножение чисел, – но и некоторые другие процессы. Так, частью вычислительной процедуры могут стать и вполне определенные логические операции. В качестве примера вычисления можно рассмотреть следующую задачу:
(А)Найти число, не являющееся суммой квадратов трех чисел.
Под «числом» в данном случае я подразумеваю «натуральное число», т.е. число из ряда
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, ….
Под квадратомчисла понимается результат умножения натурального числа на само себя, т.е. число из ряда
0, 1, 4, 9, 16, 25, 36, …;
представленные в этом ряду числа получены следующим образом:
0 × 0 = 0 2, 1 × 1 = 1 2, 2 × 2 = 2 2, 3 × 3 = 3 2, 4 × 4 = 4 2, 5 × 5 = 5 2, 6 × 6 = 6 2, ….
Такие числа называются «квадратами», поскольку их можно представить в виде квадратных матриц (пустой матрицей в начале строки обозначен 0):
С учетом вышесказанного решение задачи (А)может происходить следующим образом. Мы поочередно проверяем каждое натуральное число, начиная с 0, на предмет того, не является ли оно суммой трех квадратов. При этом, разумеется, рассматриваются только те квадраты, величина которых не превышает самого числа. Таким образом, для каждого натурального числа необходимо проверить некоторое конечное количество квадратов. Отыскав тройку квадратов, составляющих в сумме данное число, переходим к следующему натуральному числу и снова ищем среди квадратов (не превышающих по величине рассматриваемое число) такие три, которые дают в сумме это самое число. Вычисление завершается лишь тогда, когда мы находим натуральное число, которое невозможно получить путем сложения любых трех квадратов. Попробуем применить описанную процедуру на практике и начнем наше вычисление с нуля. Нуль равен 0 2+ 0 2+ 0 2, что, безусловно, является суммой трех квадратов. Далее рассматриваем единицу и находим, что она не равна 0 2 + 0 2+ 0 2, однако равна 0 2 + 0 2+ 1 2. Переходим к числу 2 и выясняем, что оно не равно ни 0 2 + 0 2+ 0 2, ни 0 2 + 0 2+ 1 2, но равно 0 2 + 1 2+ 1 2. Затем следует число 3 и сумма 3 = 1 2 + 1 2+ 1 2; далее – число 4 и сумма 4 = 0 2 + 0 2+ 2 2; после 5 = 0 2 + 1 2+ 2 2и 6 = 1 2 + 1 2+ 2 2переходим к 7, и тут обнаруживается, что ни одна из троек квадратов (всех возможных троек квадратов, каждый из которых не превышает 7)
0 2 + 0 2+ 0 2 0 2 + 0 2+ 1 2 0 2 + 0 2+ 2 2 0 2 + 1 2+ 1 2 0 2 + 1 2+ 2 2
0 2 + 2 2+ 2 2 1 2 + 1 2+ 1 2 1 2 + 1 2+ 2 2 1 2 + 2 2+ 1 2 2 2 + 2 2+ 2 2
не дает в сумме 7. На этом этапе вычисление завершается, а мы делаем вывод: 7 есть одно из искомых чисел, так как оно неявляется суммой квадратов трех чисел.
2.3. Незавершающиеся вычисленияБудем считать, что с задачей (А)нам просто повезло. Попробуем решить еще одну:
(B)Найти число, не являющееся суммой квадратов четырех чисел.
На этот раз, добравшись до числа 7, мы находим, что в виде суммы квадратов четырехчисел его представить вполне возможно: 7 = 1 2+ 1 2+ 1 2+ 2 2, поэтому мы переходим к числу 8 (сумма 8 = 0 2+ 0 2+ 2 2+ 2 2), далее – 9 (сумма 9 = 0 2+ 0 2+ 0 2+ 3 2) и 10 (10 = 0 2+ 0 2+ 1 2+ 3 2) и т.д. Вычисления все продолжаются и продолжаются (… 23 = 1 2+ 2 2+ 3 2+ 3 2, 24 = 0 2+ 2 2+ 2 2+ 4 2, …, 359 = 1 2+ 3 2+ 5 2+ 18 2, …) и завершаться, похоже, не собираются. Мы предполагаем, что искомое число, должно быть, невообразимо велико, и для его вычисления нашему компьютеру потребуется чрезвычайно большой промежуток времени и огромный объем памяти. Более того, мы уже начинаем сомневаться, существует ли оно вообще, это самое число. Вычисления все продолжаются и продолжаются, и конца им не видно. Вообще говоря, так оно и есть: описанная вычислительная процедура завершиться в принципе не может. Известна теорема, впервые доказанная в 1770 году великим французским (и отчасти итальянским) математиком Жозефом Луи Лагранжем, согласно которой в виде суммы квадратов четырех чисел можно представить любое число. Теорема эта, кстати, весьма непроста (доказать ее как-то пытался великий современник Лагранжа, швейцарский математик Леонард Эйлер, человек, отличавшийся удивительной математической интуицией, оригинальностью и продуктивностью, однако его постигла неудача).
Я, разумеется, не собираюсь докучать читателю подробностями доказательства Лагранжа, вместо этого рассмотрим одну не в пример более простую задачу:
(C)Найти нечетное число, являющееся суммой двух четных чисел.
Нисколько не сомневаюсь, что все и так уже все поняли, однако все же поясню. Очевидно, что вычисление, необходимое для решения этой задачи, раз начавшись, не завершится никогда. При сложении четных чисел, т.е. чисел, кратных двум,
0, 2, 4, 6, 8, 10, 12, 14, 16, …,
всегда получаются четные же числа; иными словами, никакая пара четных чисел не может дать в сумме нечетное число, т.е. число вида
1, 3, 5, 7, 9, 11, 13, 15, 17, ….
Я привел два примера ( (B)и (C)) вычислений, которые невозможно выполнить до конца. Несмотря на то, что в первом случае вычисление и в самом деле никогда не завершается, доказать это довольно непросто, во втором же случае, напротив, бесконечность вычисления более чем очевидна. Позволю себе привести еще один пример:
(D)Найти четное число, большее 2, не являющееся суммой двух простых чисел.
Вспомним, что простым называется натуральное число (отличное от 0 и 1), которое делится без остатка лишь само на себя и на единицу; иными словами, простые числа составляют следующий ряд:
2, 3, 5, 7, 11, 13, 17, 19, 23, ….
Существует довольно высокая вероятность того, что отыскание решения задачи (D)также потребует незавершающейся вычислительной процедуры, однако полной уверенности пока нет. Для получения такой уверенности необходимо прежде доказать истинность знаменитой «гипотезы Гольдбаха», выдвинутой Гольдбахом в письме к Эйлеру еще в 1742 году и до сих пор недоказанной.
2.4. Как убедиться в невозможности завершить вычисление?Мы установили, что вычисления могут как успешно завершаться, так и вообще не иметь конца. Более того, в тех случаях, когда вычисление завершиться в принципе не может, это его свойство иногда оказывается очевидным, иногда не совсем очевидным, а иногда настолько неочевидным, что ни у кого до сих пор не достало сообразительности однозначно такую невозможность доказать. С помощью каких методов математики убеждают самих себя и всех остальных в том, что такое-то вычисление не может завершиться? Применяют ли они при решении подобных задач какие-либо вычислительные (или алгоритмические) процедуры? Прежде чем мы приступим к поиску ответа на этот вопрос, рассмотрим еще один пример. Он несколько менее очевиден, чем (C), но все же гораздо проще (B). Возможно, нам удастся попутно получить некоторое представление о том, с помощью каких средств и методов математики приходят к своим выводам.
В предлагаемом примере участвуют числа, называемые шестиугольными:
1, 7, 19, 37, 61, 91, 127, …,
иными словами, числа, из которых можно строить шестиугольные матрицы (пустую матрицу на этот раз мы невключаем):
Каждое такое число, за исключением начальной единицы, получается добавлением к предыдущему числу соответствующего числа из ряда кратных 6:
6, 12, 18, 24, 30, 36, ….
Это легко объяснимо, если обратить внимание на то, что каждое новое шестиугольное число получается путем окружения предыдущего числа шестиугольным кольцом
причем число горошин в этом кольце обязательно будет кратно 6, а множитель при каждом увеличении шестиугольника на одно кольцо будет возрастать ровно на единицу.
Вычислим последовательные суммы шестиугольных чисел, увеличивая каждый раз количество слагаемых на единицу, и посмотрим, что из этого получится.
1 = 1, 1 + 7 = 8, 1 + 7 + 19 = 27, 1 + 7 + 19 + 37 = 64, 1 + 7 + 19 + 37 + 61 = 125.
Что же особенного в числах 1, 8, 27, 64, 125? Все они являются кубами. Кубом называют число, умноженное само на себя трижды:
1 = 1 3=1 × 1 × 1, 8 = 2 3= 2 × 2 × 2, 27 = 3 3= 3 × 3 × 3, 64 = 4 3= 4 × 4 × 4, 125 = 5 3= 5 × 5 × 5, ….
Присуще ли это свойство всем шестиугольным числам? Попробуем следующее число. В самом деле,
1 + 7 + 19 + 37 + 61 + 91 = 216 = 6 × 6 × 6 = 6 3.
Всегда ли выполняется это правило? Если да, то никогда не завершится вычисление, необходимое для решения следующей задачи:
(E)Найти последовательную сумму шестиугольных чисел, начиная с единицы, не являющуюся кубом.
Думается, я сумею убедить вас в том, что это вычисление и в самом деле можно выполнять вечно, но так и не получить искомого ответа.
Прежде всего отметим, что число называется кубом не просто так: из соответствующего количества точек можно сложить трехмерный массив в форме куба (такой, например, как на рис. 2.1). Попробуем представить себе построение такого массива в виде последовательности шагов: вначале разместим где-нибудь угловую точку, а затем будем добавлять к ней, одну за другой, особые конфигурации точек, составленные из трех «плоскостей» – задней стенки, боковой стенки и потолка, как показано на рис. 2.2.
Рис. 2.1. Сферы, уложенные в кубический массив.
Рис. 2.2. Разберем куб на части – каждая со своей задней стенкой, боковой стенкой и потолком.
Посмотрим теперь на одну из наших трехгранных конфигураций со стороны, т. е. вдоль прямой, соединяющей начальную точку построения и точку, общую для всех трех граней. Мы увидим шестиугольник, подобный тому, что изображен на рис. 2.3. Точки, из которых складываются эти увеличивающиеся в размере шестиугольники, представляют собой, в сущности, те же точки, что образуют полный куб. То есть получается, что последовательное сложение шестиугольных чисел, начиная с единицы, всегда будет давать число кубическое. Следовательно, можно считать доказанным, что вычисление, требуемое для решения задачи (E), никогда не завершится.
Рис. 2.3. Каждую часть построения можно рассматривать как шестиугольник.
Кто-то, быть может, уже готов упрекнуть меня в том, что представленные выше рассуждения можно счесть в лучшем случае интуитивным умозаключением, но не формальным и строгим математическим доказательством. На самом же деле, перед вами именно доказательство, и доказательство вполне здравое, а пишу все это я отчасти и для того, чтобы показать, что осмысленность того или иного метода математического обоснования никак не связана с его «формализованностью» в соответствии с какой-либо заранее заданной и общепринятой системой правил. Напомню, кстати, о еще более элементарном примере геометрического обоснования, применяемого для получения одного общего свойства натуральных чисел, – речь идет о доказательстве истинности равенства a × b = b × a, приведенном в §1.19. Тоже вполне достойное «доказательство», хотя формальным его назвать нельзя.
Представленное выше рассуждение о суммировании последовательных шестиугольных чисел можно при желании заменить более формальным математическим доказательством. В основу такого формального доказательства можно положить принцип математической индукции, т.е. процедуру установления истинности утверждения в отношении всех натуральных чисел на основании одного-единственного вычисления. По существу, этот принцип позволяет заключить, что некое положение P( n), зависящее от конкретного натурального числа n(например, такое: «сумма первых nшестиугольных чисел равна n 3»), справедливо для всех n, если мы можем показать, во-первых, что оно справедливо для n= 0 (или, в нашем случае, для n= 1), и, во-вторых, что из истинности P( n) следуетистинность и P( n+1). Думаю, нет необходимости описывать здесь в деталях, как можно с помощью математической индукции доказать невозможность завершить вычисление (E); тем же, кого данная тема заинтересовала, рекомендую попытаться в качестве упражнения выполнить такое доказательство самостоятельно.
Всегда ли для установления факта действительной незавершаемости вычисления достаточно применить некие четко определенные правила – такие, например, как принцип математической индукции? Как ни странно, нет. Это утверждение, как мы вскоре увидим, является одним из следствий теоремы Гёделя, и для нас крайне важно попытаться его правильно понять. Причем недостаточной оказывается не только математическая индукция. Недостаточным будет какой угоднонабор правил, если под «набором правил» подразумевать некую систему формализованных процедур, в рамках которой возможно исключительно вычислительным путем проверить корректность применения этих правил в каждом конкретном случае. Такой вывод может показаться чересчур пессимистичным, ибо он, по-видимому, означает, что, несмотря на то, что вычисления, которые нельзя завершить, существуют, сам факт их незавершаемости строго математически установить невозможно. Однако смысл упомянутого следствия из теоремы Гёделя заключается вовсе не в этом. На самом деле, все не так уж и плохо: способность понимать и делать выводы, присущая математикам – как, впрочем, и всем остальным людям, наделенным логическим мышлением и воображением, – просто-напросто не поддается формализации в виде того или иного набора правил. Иногда правила могут стать частичной заменой пониманию, однако в полной мере такая замена не представляется возможной.
2.5. Семейства вычислений; следствие Гёделя—Тьюринга GДля того, чтобы понять, каким образом из теоремы Гёделя (в моей упрощенной формулировке, навеянной отчасти идеями Тьюринга) следует все вышесказанное, нам необходимо будет сделать небольшое обобщение для типов утверждений, относящихся к рассмотренным в предыдущем разделе вычислениям. Вместо того чтобы решать проблему завершаемости для каждого отдельного вычисления ( (A), (B), (C), (D)или (E)), нам следует рассмотреть некоторое общее вычисление, которое зависит от натурального числа n(либо как-то воздействуетна него). Таким образом, обозначив такое вычисление через C( n), мы можем рассматривать его как целое семействовычислений, где для каждого натурального числа (0, 1, 2, 3, 4, …) выполняется отдельное вычисление (соответственно, C(0), C(1), C(2), C(3), C(4), …), а сам принцип, в соответствии с которым вычисление зависит от n, является целиком и полностью вычислительным.
В терминах машин Тьюринга это всего лишь означает, что C( n) есть действие, производимое некоей машиной Тьюринга над числом n. Иными словами, число п наносится на ленту и подается на вход машины, после чего машина самостоятельно выполняет вычисления. Если вас почему-либо не устраивает концепция «машины Тьюринга», вообразите себе самый обыкновенный универсальный компьютер и считайте n«данными», необходимыми для работы какой-нибудь программы. Нас в данном случае интересует лишь одно: при любом ли значении nможет завершиться работа такого компьютера.
Для того чтобы пояснить, что именно понимается под вычислением, зависящим от натурального числа n, рассмотрим два примера:
(F)найти число, не являющееся суммой квадратов nчисел,
и
(G)найти нечетное число, являющееся суммой nчетных чисел.
Припомнив, о чем говорилось выше, мы без особого труда убедимся, что вычисление (F)завершается толькопри n= 0, 1, 2 и 3 (давая в результате, соответственно, 1, 2, 3 и 7), тогда как вычисление (G)вообще не завершается ни при каком значении n. Вздумай мы действительно доказать, что вычисление (F)не завершается при n, равном или большем 4, нам понадобилась бы более или менее серьезная математическая подготовка (по крайней мере, знакомство с доказательством Лагранжа); с другой стороны, тот факт, что ни при каком nне завершается вычисление (G), вполне очевиден. Какими же процедурами располагают математики для установления незавершаемой природы таких вычислений в общем случае? Можно ли сами эти процедуры представить в вычислительной форме?
Предположим, что у нас имеется некая вычислительная процедура А, которая по завершении [9]9
Здесь я предполагаю, что если процедура Авообще завершается, то это свидетельствует об успешном установлении факта незавершаемости C( n). Если же А«застревает» по какой-либо иной, нежели достижение «успеха», причине, то это означает, что в данном случае процедура Aкорректно завершиться не может. См. далее по тексту возражения Q3и Q4, а также Приложение А.
[Закрыть]дает нам исчерпывающее доказательство того, что вычисление C( n) действительно никогда не заканчивается. Ниже мы попробуем вообразить, что A включает в себя всеизвестные математикам процедуры, посредством которых можно убедительно доказать, что то или иное вычисление никогда не завершается. Соответственно, если в каком-то конкретном случае завершается процедура A, то мы получаем, в рамках доступного человеку знания, доказательство того, что рассматриваемое конкретное вычисление никогда не заканчивается. Большая часть последующих рассуждений не потребует участия процедуры Aименно в такой роли, так как они посвящены, в основном, математическим умопостроениям. Однако для получения окончательного заключения Gнам придется-таки придать процедуре Aсоответствующий статус.
Я, разумеется, не требую, чтобы посредством процедуры Aвсегда можно было однозначно установить, что вычисление C( n) нельзя завершить (в случае, если это действительно так); однако я настаиваю на том, что неверных ответов Aне дает, т.е. если мы с ее помощью пришли к выводу, что вычисление C( n) не завершается, значит, так оно и есть. Процедуру A, которая и в самом деле всегда дает верный ответ, мы будем называть обоснованной.
Следует отметить, что если процедура Aоказывается в действительности необоснованной, то этот факт, в принципе, можно установить с помощью прямого вычисления – иными словами, необоснованную процедуру Aможно опровергнуть вычислительными методами: если А ошибочно утверждает, что вычисление C( n) нельзя завершить, тогда как в действительности это не так, то выполнение самого вычисления C( n) в конечном счете приведет к опровержению А. (Возможность практического выполнения такого вычисления представляет собой отдельный вопрос, его мы рассмотрим в ответе на возражение Q8.)
Для того чтобы процедуру Aможно было применять к вычислениям в общем случае, нам потребуется какой-нибудь способ маркировки различных вычислений C( n), допускаемый A. Все возможные вычисления Cможно, вообще говоря, представить в виде простой последовательности
C 0, C 1, C 2, C 3, C 4, C 5, …,
т.е. q-e вычисление при этом получит обозначение C q. В случае применения такого вычисления к конкретному числу n будем записывать
C 0( n), C 1( n), C 2( n), C 3( n), C 4( n), C 5( n), ….
Можно представить, что эта последовательность задается, скажем, как некий пронумерованный ряд компьютерных программ. (Для большей ясности мы могли бы, при желании, рассматривать такую последовательность как ряд пронумерованных машин Тьюринга, описанных в НРК; в этом случае вычисление C q( n) представляет собой процедуру, выполняемую q-й машиной Тьюринга T qнад числом n.) Здесь важно учитывать следующий технический момент: рассматриваемая последовательность является вычислимой– иными словами, существует одно-единственное [10]10
Собственно, точно такой же результат достигается посредством процедуры, выполняемой универсальной машиной Тьюринга над парой чисел q, n; см. Приложение Аи НРК, с. 51-57.
[Закрыть]вычисление C •, которое, будучи выполнено над числом q, дает в результате C q, или, если точнее, выполнение вычисления C •над паройчисел q, n(именно в таком порядке) дает в результате C q( n).
Можно полагать, что процедура Aпредставляет собой некое особое вычисление, выполняя которое над парой чисел q, n, можно однозначно установить, что вычисление C q( n), в конечном итоге, никогда не завершится. Таким образом, когда завершаетсявычисление A, мы имеем достаточное доказательство того, что вычисление C q( n) завершить невозможно. Хотя, как уже говорилось, мы и попытаемся вскоре представить себе такую процедуру A, которая формализует всеизвестные современной математике процедуры, способные достоверно установить невозможность завершения вычисления, нет никакой необходимости придавать Aтакой смысл прямо сейчас. Пока же процедурой Aмы будем называть любой обоснованныйнабор вычислительных правил, с помощью которого можно установить, что то или иное вычисление C q( n) никогда не завершается. Поскольку выполняемое процедурой А вычисление зависит от двух чисел qи n, его можно обозначить как A( q, n) и записать следующее утверждение:
(H)Если завершается A( q, n), то C q( n) не завершается.
Рассмотрим частный случай утверждения (H), положив q равным n. Такой шаг может показаться странным, однако он вполне допустим. (Он представляет собой первый этап мощного «диагонального доказательства» – процедуры, открытой в высшей степени оригинальным и влиятельным датско-русско-немецким математиком девятнадцатого века Георгом Кантором; эта процедура лежит в основе рассуждений и Гёделя, и Тьюринга.) При q, равном n, наше утверждение принимает следующий вид:
(I)Если завершается A( n, n), то C n( n) не завершается.
Отметим, что A( n, n) зависит только от одногочисла ( n), а не от двух, так что данное вычисление должно принадлежать ряду C 0, C 1, C 2, C 3, C 4, C 5, … (по n), поскольку предполагается, что этот ряд содержит все вычисления, которые можно выполнить над одним натуральным числом n. Обозначив это вычисление через C k, запишем:
(J) A( n, n) = C k( n).
Рассмотрим теперь частный случай n= k. (Второй этап диагонального доказательства Кантора.) Из равенства (J) получаем:
(K) A( k, k) = C k( k),
утверждение же (I)при n= kпринимает вид:
(L)Если завершается A( k, k), то C k( k) не завершается.
Подставляя (K)в (L), находим:
(M)Если завершается C k( k), то C k( k) не завершается.
Из этого следует заключить, что вычисление C k( k) в действительности незавершается. (Ибо, согласно (M), если оно завершается, то оно не завершается!) Невозможно завершить и вычисление A( k, k), поскольку, согласно (K), оно совпадаетс C k( k). То есть наша процедура Aоказывается не в состоянии показать, что данное конкретное вычисление C k( k) не завершается, даже если оно и в самом деле не завершается.
Более того, если нам известно, что процедура А обоснованна, то, значит, нам известнои то, что вычисление C k( k) не завершается. Иными словами, нам известно нечто, о чем посредством процедуры Aмы узнать не могли. Следовательно, сама процедура Aс нашим пониманием никакне связана.
В этом месте осторожный читатель, возможно, пожелает перечесть все вышеприведенное доказательство заново, дабы убедиться в том, что он не пропустил какой-нибудь «ловкости рук» с моей стороны. Надо признать, что, на первый взгляд, это доказательство и в самом деле смахивает на фокус, и все же оно полностью допустимо, а при более тщательном изучении лишь выигрывает в убедительности. Мы обнаружили некое вычисление C k( k), которое, насколько нам известно, не завершается; однако установить этот факт с помощью имеющейся в нашем распоряжении вычислительной процедуры А мы не в состоянии. Это, собственно, и есть теорема Гёделя(—Тьюринга) в необходимом мне виде. Она применима к любой вычислительной процедуре A, предназначенной для установления невозможности завершить вычисление, – коль скоро нам известно, что упомянутая процедура обоснованна. Можно заключить, что для однозначного установления факта незавершаемости вычисления не будет вполне достаточным ни один из заведомо обоснованных наборов вычислительных правил (такой, например, как процедура A), поскольку существуют незавершающиеся вычисления (например, C k( k)), на которые эти правила не распространяются. Более того, поскольку на основании того, что нам известно о процедуре Aи об ее обоснованности, мы действительно можем составить вычисление C k( k), которое, очевидно, никогда не завершается, мы вправе заключить, что процедуру Aникоим образом нельзясчитать формализацией процедур, которыми располагают математики для установления факта незавершаемости вычисления, вне зависимости от конкретной природы A. Вывод:
G Для установления математической истины математики не применяют заведомо обоснованные алгоритмы.
Мне представляется, что к такому выводу неизбежно должен прийти всякий логически рассуждающий человек. Однако многие до сих пор предпринимают попытки этот вывод опровергнуть (выдвигая возражения, обобщенные мною под номерами Q1– Q20в §2.6и §2.10), и, разумеется, найдется ничуть не меньше желающих оспорить вывод более строгий, суть которого сводится к тому, что мыслительная деятельность непременно оказывается связана с некими феноменами, носящими фундаментально невычислительный характер. Вы, возможно, уже спрашиваете себя, каким же это образом подобные математические рассуждения об абстрактной природе вычислений могут способствовать объяснению принципов функционирования человеческого мозга. Какое такое отношение имеет все вышесказанное к проблеме осмысленного осознания? Дело в том, что, благодаря этим математическим рассуждениям, мы и впрямь можем прояснить для себя некие весьма важные аспекты такого свойства мышления, как понимание– в терминах общей вычислимости, – а как было показано в §1.12, свойство понимания связано с осмысленным осознанием самым непосредственным образом. Предшествующее рассуждение действительно носит в основном математический характер, и связано это с необходимостью подчеркнуть одно очень существенное обстоятельство: алгоритм Aучаствует здесь на двух совершенно различных уровнях. С одной стороны, это просто некий алгоритм, обладающий определенными свойствами; с другой стороны, получается, что на самом-то деле Aможно рассматривать как «алгоритм, которым пользуемся мы сами» в процессе установления факта незавершаемости того или иного вычисления. Так что в вышеприведенном рассуждении речь идет не только и не столько о вычислениях. Речь идет также и о том, каким образом мы используем нашу способность к осмысленному пониманию для составления заключения об истинности какого-либо математического утверждения – в данном случае утверждения о незавершаемости вычисления C k( k). Именно взаимодействие между двумя различными уровнями рассмотрения алгоритма A– в качестве гипотетического способа функционирования сознания и собственно вычисления – позволяет нам сделать вывод, выражающий фундаментальное противоречие между такой сознательной деятельностью и простым вычислением.
Существуют, однако, всевозможные лазейки и контраргументы, на которые необходимо обратить самое пристальное внимание. Для начала, в оставшейся части этой главы, я тщательно разберу все важные контраргументы против вывода G, которые когда-либо попадались мне на глаза – см. возражения Q1– Q20и комментарии к ним в §§2.6и 2.10; там, кроме того, можно найти и несколько дополнительных возражений моего собственного изобретения. Каждое из возражений будет разобрано со всей обстоятельностью, на какую я только способен. Пройдя через это испытание, вывод G, как мы убедимся, существенно не пострадает. Далее, в главе 3, я рассмотрю следствия уже из утверждения G. Мы обнаружим, что оно и в самом деле способно послужить прочным фундаментом для построения весьма убедительного доказательства абсолютнойневозможности точного моделирования сознательного математического понимания посредством вычислительных процедур, будь то восходящие, нисходящие или любые их сочетания. Многие сочтут такой вывод весьма неприятным, поскольку если он справедлив, то нам, получается, просто некуда двигаться дальше. Во второй части книги я выберу более позитивный курс. Я приведу правдоподобные, на мой взгляд, научные доводы в пользу справедливости результатов моих размышлений о физических процессах, которые могут, предположительно, лежать в основе деятельности мозга – вроде той, что осуществляется при нашем восприятии приведенных выше рассуждений, – и о причинах недоступности этой деятельности для какого бы то ни было вычислительного описания.