Семантика исчисления предикатов


 

Для уяснения смысла аксиом и правил вывода введем понятие интерпретации языка и исчисления α.

Определение 9.25. Под интерпретацией языка исчисления α понимают любое множество М с зафиксированным отображением u сигнатуры σ во множество операций и предикатов, определенных на М, при котором символу n-арной операции f из σ соответствует n-арная операция fu, определенная на множестве М, а символу n-арного предиката р из σ n-арный предикат рu на М. Образ множества σ при отображении u обозначим через σu. В частности, образом констант из σ при u будут нуль-арные операции на М, т. е. некоторые элементы из М.

Если (М, u) — интерпретация языка α, то, заменив в любой формуле языка α константы, символы операций и символы предикатов их образами при u и условившись переменным из Х придавать значения из множества М, мы получим формулу Аu алгебры предикатов на алгебраической системе Мu), и можно говорить о выполнимости, истинности или ложности этой формулы на системе Мu).

Определение 9.26. Формула А исчисления предикатов называется выполнимой, истинной, ложной в интерпретации (М, u), если соответственно выполнима, истинна, ложна формула Аu на алгебраической системе Мu).

Определение 9.27. Формула А исчисления предикатов α называется тождественно истинной, если она истинна во всех интерпретациях исчисления α.

Естественно возникает вопрос о соотношении между классами доказуемых и истинных формул исчисления предикатов. Ответ на этот вопрос можно получить из следующих теорем.

Теорема 9.28. Если каждая формула множества формул Т истинна в некоторой интерпретации (М, u) исчисления α и T├─ A, то А — истинна в (М, u).

Доказательство. Для простоты записей условимся считать, что операции и предикаты на М обозначены теми же буквами, что и соответствующие им символы операций из σ. Тогда u — тождественное отображение и в записи Аu индекс u можно опускать.

Из определения доказуемой формулы следует, что достаточно доказать два утверждения:

а) все аксиомы истинны;

б) формула, являющаяся непосредственным следствием по любому правилу вывода из истинных формул, является истинной.

Истинность аксиом первых четырех групп аксиом доказывается одним методом. Проиллюстрируем его на аксиоме I1: A ® (B ® A).

Заменив в А, В свободные вхождения переменных элементами из М, получим высказывания, имеющие вполне определенные значения £ и ß (каждое из £, ß есть «и» или «л»). Перебирая всевозможные наборы значений «и» и «л» для £, ß мы непосредственной проверкой (пользуясь определением операции ®) убедимся в том, что при любых £, ß £ ® (ß ® £) º и.

Отсюда следует, что аксиома I1 истинна в интерпретации (М, u).

Докажем теперь истинность аксиомы

V1 : "x A(x) ® A(t),

где t — терм, свободный для х в А(х). Пусть х, х1, …, хn суть все переменные, имеющие свободные вхождения в А(х) и xi1, …, xim — все переменные, участвующие в образовании терма t. Так как t свободен для х в А(х), то все вхождения переменных xi1, …, xim в терм t останутся свободными при подстановке t вместо х в формулу А(х). В связи с этим запишем:

A(t) = A(t(xi1, …, xim), х1, …, хn).

Допустим, что формула V1 не истинна в интерпретации (М, u). Это означает, что при некотором наборе значений переменных х1 = a1, …, хn = an, xi1 = ai1, …, xim = aim формула "x A(x) принимает значение «и», а формула A(t) — значение «л». Если обозначить через b значение терма t при xi1 = ai1, …, xim = aim, то будем иметь: с одной стороны, A(х0, a1, …, an) является истинным высказыванием при любом значении х0 Î М, а с другой стороны, высказывание A(b, a1, …, an) — ложно. Полученное противоречие и доказывает наше утверждение.

Аналогично доказывается, что правила вывода позволяют из истинных формул в интерпретации (М, u) получать снова истинные формулы, т.е.:

1) если истинны формулы А и А ® В, то истинна и формула В;

2) если истинна формула В ® А(х) и х не имеет свободных вхождений в В, то истинна формула В ® "х А(х);

3) если истинна формула А(х) ® В и х не имеет свободных вхождений в В, то истинна и формула $х А(х) ® В.

Теорема доказана.

Следствие 9.29. Всякая доказуемая формула исчисления предикатов α является истинной в любой интерпретации (М, u) исчисления α.

Замечание. Теорема и следствие теряют силу, если в аксиомах V1 и V2 не накладывать ограничений на терм t или в правилах "-введения и $-удаления разрешить свободные вхождения х в В. Приведем соответствующие примеры.

1. Пусть множество натуральных чисел N, A(x) = $y (x < y) и t = x + y — терм, не свободный для х в А(х), поскольку свободное вхождение буквы х в А(х) находится в области действия квантора $ по букве у, входящий в терм t. Нетрудно видеть, что формула "x A(x) ® A(t), или подробнее, "x($y(x < y)) ® $y(x + y < y) ложна в арифметике.

2. В той же интерпретации, положим B = (x £ y), A = (x £ y + 1). Тогда имеем: формула В ® А истинна на N, а формула В ® " ложна, поскольку, например, при х = 2, у = 3 имеем (2 £ 3) º и, "x (x £ 4) º л.

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

Следствие 9.30. Исчисление предикатов непротиворечиво, т.е. в нем не может быть доказуемой никакая формула А вместе с ее отрицанием, или никакая формула вида .

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

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

Теорема 9.31. Если формула исчисления предикатов истинна во всех его интерпретациях, то она доказуема в исчислении предикатов.

Для доказательства этой теоремы введем сначала некоторые понятия и докажем одно общее утверждение (см. теорему 9.7.11).

Определение 9.32. Множество формул Т исчисления α называется противоречивым, если существует такая формула А языка α, что Т├─ . В противном случае Т называется непротиворечивым.

Определение 9.33. Множество формул Т исчисления α называется выполнимым, если существует интерпретация, в которой все формулы из Т принимают истинное значение хотя бы при одной (общей для всех формул из Т) замене переменных.

Определение 9.34. Множество формул Т исчисления α называется полным, если для каждой замкнутой формулы языка α имеет место Т├─ А или Т ├─ .

Теорема 9.35. Всякое непротиворечивое множество S замкнутых формул исчисления α выполнимо.

Доказательство. Добавим к множеству символов языка α еще счетное множество констант (символов нуль-арных операций) ß = {b0, b1, b2, …}.

Получим новый язык α1 в сигнатуре σ1 = σ È ß. Заменяя в аксиомах и правилах вывода исчисления α формулы языка α1, мы получим новое логическое исчисление, которое обозначим той же буквой α1. Из определения языка α1 видно, что все доказанные факты об исчислении α (в частности, все доказанные формулы и дополнительные правила вывода) сохраняются и в α1. Так как язык α1 включает в себя α, то S можно рассматривать как множество предложений языка α1. Легко видеть, что S будет непротиворечивым и в исчислении α1. Действительно, если в α1 из S выводима формула , то, заменив в формулах вывода из S все константы из ß переменными, не участвующими в этом выводе, мы получим вывод в α из S формулы , где В получается из А указанной заменой констант. Чтобы убедиться в этом, достаточно заметить, что указанная замена аксиомы переводит в аксиомы и сохраняет свойство формулы быть непосредственным следствием предыдущих формул. Таким образом, S непротиворечиво в α1.

Теперь расширим определенным образом множество S. Для этого занумеруем все замкнутые формулы исчисления α1: А0, А1, А2, …

По формуле А0 и системе S построим множество формул S0, положив:

где bi0 — символ с наименьшим номером из ß, не встречающийся в А0. Из определения S0 имеем: S Î S0 и S0 ├─ А0 или S0 ├─ .

Покажем, что S0 непротиворечиво. Допустим, что в α1 S0 ├─ . В соответствии с определением S0 рассмотрим три случая.

1. S ├─ `А0. Тогда S0 = S È { } и из (9.5) имеем: S, `А0 ├─ . Отсюда по следствию из теоремы дедукции получаем S ├─ , что невозможно в силу непротиворечивости S.

2. невыводима из S и А0 не имеет вида $х В0(х). Тогда S0 = S È {А0} и мы точно так же, как и в случае «а», получим S ├─ , что противоречит условию.

3. невыводима из S и А0 = $х В0(х). Тогда S0 = = S È {А0, B0, (bi0)}, и потому S, А0, B0, (bi0) ├─ . Так как формула B0 (bi0) замкнута, то тем же приемом, что и выше, получим S, А0 ├─ . Так как bi0 не входит в А0 и в формулы из S, то, повторив весь вывод с заменой bi0 на переменную xJ, не входящую в участвующие в выводе формулы, мы получим S, А0 ├─ , или S ├─ А0 ® . Дополним вывод А0 ® из S формулами:

А0 ® "xj (правило "-введения)
"xj ® (аксиома)
А0 ® (правило силлогизма)
А0 ® "x (правило "-введения)
"x ® (правило $-отрицания)
А0 ® (правило силлогизма)

Поскольку $xB0(x) = А0, то мы получили вывод из S формулы А0 ® , т.е. S, А0├─ `А0. А так как S, А0 ├─ А0, то по правилу умножения формул S, А0├─ А0 . Отсюда следует: S├─ А0, и мы снова пришли к противоречию с условием. Тем самым мы закончили доказывать непротиворечивость множества формул S0.

Далее, по А1 и S0 мы аналогично построим непротиворечивое множество S1 такое, что: S0 Ì S1, S1├─ А1 или S1├─ .

Продолжая этот процесс, мы получим последовательность непротиворечивых множеств формул S0 Ì S1 Ì S2 Ì … таких, что Si├─ Аi и Si├─ . Следовательно, есть непротиворечивое и полное множество формул.

Теперь построим интерпретацию исчисления предикатов α, в которой истинны все формулы из α. В качестве основного множества возьмем множество М термов языка α1, в которых нет предметных переменных — это так называемые замкнутые термы языка α1. Определим на М операции fu и предикаты рu, соответствующие символам операций f и предикатов р из α.

Если а — символ 0-арной операции из σ, то положим аu = а. Если f — символ n-арной операции из σ, p — символ n-арного предиката и t1, …, tn — термы из М, то положим fu (t1, …, tn) = f(t1, …, tn):

Тем самым определена интерпретация (М, σ) исчисления α1, а потому и α.

Теперь индукцией по рангу формулы А докажем, что для любой замкнутой формулы языка α1:

Т├─ А в α1 Û Аu º и в (М, σ). (9.7)

Для упрощения записи верхний индекс u у формул будем опускать. Если А = р(t1, …, tn) — элементарная формула, то (9.7) верно по определению предиката р.

Пусть А — замкнутая формула ранга r > 0. В зависимости от последней операции в А возможны шесть случаев.

1. А = А1А2. Используя определение конъюнкции, предположение индукции и правила умножения и разделения формул, получим: А º и Û А1 = и, А2 = и Û Т├─ А1, Т├─ А2 Û Т├─ А1А2.

2. А = А1 Ú А2. Если А1 Ú А2 º и, то А1 = и или А2 = и. Тогда по предположению индукции Т├─ А1 или Т├─ А2, а поэтому и Т├─ А1 Ú А2. Обратно, пусть Т├─ А1 Ú А2. Если Т├─ А1 или Т├─ А2, то по предположению индукции А1 º и или А2 º и, а потому и А º и. В противном случае, в силу полноты системы Т имеем: Т├─ , Т├─ . Тогда по правилам умножения формул и де Моргана получим: Т├─ ` , Т├─ . Итак, имеем: Т├─ А1 Ú А2, Т├─ , что невозможно в силу непротиворечивости Т.

3. А =`А1. Учитывая предположение индукции и полноту системы формул Т, получим: А º и Û А º л Û Т├─ `А1 Û Т├─ А.

4. А = А1 ® А2. В этом случае, используя предположение индукции и правила введения посылки, контрапозиции и двойного отрицания, получим: А º и Û А1 º л или А2 º и Û Т├─ `А1, или Т├─ `А2 Û Т├─ `А2 ®`А1 или Т├─ А2 ® А1 Û Т├─ А.

5. А = "хА1(х). Если А º и, то А1(t) º и при любом t Î M. Тогда по предположению индукции Т├─ А1(t) для всех t Î M. Допустим, что T ├─ . Тогда по правилу "-отрицания T ├─ и по построению множества Т в Т существует формула при некоторой константе b Î M. В итоге мы получили: Т├─ А1(t) при любом t Î M и Т├─ А1(b) при b Î M, что невозможно в силу непротиворечивости Т. Следовательно, T ├─ "хА1(х). Обратно, пусть T ├─ "хА1(х). Если "хА1(х) ¹ и, то А1(t) º л при некотором t Î M. Тогда по предположению индукции Т├─ . Отсюда по аксиоме V2 и по правилу "-отрицания получим T ├─ и T ├─ , что невозможно в силу непротиворечивости Т.

6. А = $хА1(х). Если А º и, то А1(t) º и при некотором t Î M и по предположению индукции Т├─ А1(t). Отсюда, используя аксиому V2, получим T ├─ $хА1(х), т.е. Т├─ А. Обратно, если Т├─ А, то в силу непротиворечивости Т получим, что не выводима из Т. Тогда, по построению Т, в Т содержится формула А1(b) при некотором b Î M. По предположению индукции А1(b) º и, а потому и $хА1(х) = и.

Таким образом, все замкнутые формулы языка α, выводимые из Т, истинны в интерпретации (М, u). А так как S Ì T, то и все формулы из S истинны в (М, u), т.е. множество S выполнимо и теорема доказана.

Теперь можно доказать и теорему Гёделя о полноте исчисления α. Пусть А — формула исчисления предикатов α и А º и в любой интерпретации исчисления α. Если х1, …, хn суть все переменные, имеющие свободные вождения в А, то формула В = "х1, …, хnА также истинна в любой интерпретации α, а потому формула`В ложна в любой интерпретации α. Отсюда следует, что множество формул невыполнимо.

Тогда по теореме о выполнимости множество противоречиво, т.е. существует формула С языка α, такая, что ├─ .

Но тогда по следствию из теоремы дедукции ├─ B. Теперь, применяя n раз аксиому V1 и правило заключения, получим ├─ A, что и доказывает теорему Гёделя.

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

Теорема 9.36 (о совместной выполнимости). Если замкнутая формула А исчисления α истинна в любой интерпретации α, в которой истинны формулы некоторого Т замкнутых формул, то Т├─ А.

Доказательство. Из условия видно, что множество формул Т U невыполнимо. Значит, по теореме о выполнимости множество противоречиво, т.е. T, ├─ для некоторой формулы В. Отсюда по следствию из теоремы дедукции Т├─ А.

Теорема Мальцева (9.37). Множество замкнутых формул S исчисления α выполнимо тогда и только тогда, когда выполнимо любое его конечное подмножество.

Доказательство. Выполнимость конечных подмножеств выполнимого множества формул очевидна. Докажем обратное утверждение. Допустим, что выполнимо любое конечное подмножество формул множества S, а само S невыполнимо. Тогда по теореме о выполнимости оно противоречиво, т.е. найдется такая формула А, что S├─ .

Но тогда выводима лишь из конечного подмножества S1 Ì S формул, участвующих в выводе формулы из S. Следовательно, нашлось противоречивое конечное множество формул из S. Если бы S было выполнимым, то по теореме 9.28 нашлась бы интерпретация α, в которой была бы истинной формула , что невозможно. Полученное противоречие и доказывает теорему.

 


 

 

Л е к ц и я 10

 



Дата добавления: 2022-05-27; просмотров: 91;


Поиск по сайту:

Воспользовавшись поиском можно найти нужную информацию на сайте.

Поделитесь с друзьями:

Считаете данную информацию полезной, тогда расскажите друзьям в соц. сетях.
Poznayka.org - Познайка.Орг - 2016-2024 год. Материал предоставляется для ознакомительных и учебных целей.
Генерация страницы за: 0.078 сек.