スライド 1

述語論理と∀(全称)∃(存在)
3回の講義の概観:
1
命題論理
(真理値)
命題論理
(公理と推論規則)
3
2
述語論理
(モデルと解釈)
意味論 semantics
述語論理
(公理と推論規則)
syntax 構文論
1
preview
述語論理は命題論理よりも複雑
例題: 次の文は真か偽か? (曖昧な文です)
「すべての自然数 x に対して x < y を満たすよう
な自然数 y が存在する」
(小野先生の例題)
1. 解釈(その一)
すべての x に対して「 x < y を満たすような y
が存在する」 :∀x ∃y (x < y)
2. 解釈(その二)
「すべての x に対して x < y を満たす」ような y
が存在する :∃y ∀x (x < y)
曖昧
2
復習
述語と対象変数
• 命題とは真理値(真偽)が確定している文のこと
真偽のいずれかの値 { t, f } をとる:命題変数
• 対象変数を含む文の真理値は確定しない
例: x ≦ 200
y は素数である
このような文を扱うために 命題関数 P を考える
P : D  T, ここに T = { t, f }
例: 対象領域 D として自然数の集合を考える
P : D×D  T, 2変数(引数)の述語
• 対象変数 individual variable, object variable
• 命題関数 propositional function
3
述語 predicate
• 述語: 命題関数の具体的な表現 例: Le, Prime
Le (x, 200) : (x ≦ 200 ), 2変数(引数) 述語記号
Prime (y) : 「 y は素数である」
• 対象領域 D の要素を対象 object, individual という
対象領域 D の上を動く変数を対象変数、D の定数を
対象定数 object (individual) constant という
• 全称記号∀, と存在記号∃
∀x P(x): すべての x∈D に対して P(x) が真になる
∃y Q(y): ある y ∈D が存在して Q(y) が真になる
↑
正確な記法を次に述べる。∀と∃が多重になるときに注意
4
述語論理の項
term
• 今までに登場したもの: 対象変数、対象定数
• さらに必要なもの: 対象領域の上の関数記号
関数記号の例: 自然数の上の +, ×
項 term の定義:
1. 個々の対象定数、対象変数は項である
2. f が n 変数(引数)の関数記号で, t1, t2, …, tn が
項であるならば f (t1, t2,…, tn) は項である
項の例: 200, x, y, (3+x), 6×(x+y).
+(3,x), ×(6, +(x, y)) とも書く
5
論理式 formula, wff
述語記号: 述語を表す記号
1. P が n 変数(引数)の述語記号で t1, t2, …, tn が
項ならば 、P(t1, t2, …, tn) は論理式である
2. A, B が論理式ならば、 A∧B, A∨B, A⇒B, ¬Aは、い
復習:⇔は省略してよい
ずれも論理式である
3. A が論理式で x が対象変数ならば 、
(∀x A), (∃x A) は論理式である
注:「1」の形の論理式を原子(atomic)論理式 という
例: ∀x(∀y(∃q(∃r(x=q×y+r)))), = は述語記号
6
∀, ∃ quantifier
限定記号, 量化記号, 限量子
「すべての x に対して R(x, y) を満たす y が存在
する」 という文は曖昧である
前出
1. ∀x ∃y (x < y)
すべての自然数 x に対して,x よりも大きな
自然数 y (例えば x+1 )が存在する (真)
2. ∃y ∀x (x < y)
ある自然数 y が存在して,y は如何なる
(すべての)自然数 x よりも大きい (偽)
7
自由変数と束縛変数
free and bound variables
• ∀x ∃y (x < y) の変数 x, y は、変数と呼ばれてい
るが、代入の対象にならない
∀z ∃y (z < y) と書いても意味が変わらない
• 変数には2種類ある。自由変数と束縛変数
• ここで注意するべき事は、同じ変数が自由であり、
同時に束縛されることがある
例: ∃y (x = y+y )∧ ∃z ( y = z+z+1 )
x は偶数である
y は奇数である
• 自由変数と束縛変数を出現 occurrenceという単位
で区別しなければならない
8
出現 occurrence
1. A が原子論理式であるとき、A に含まれる変数 x の出現
は、すべて自由な出現である
2. A が B∧C, B∨C, B⇒C, ¬B のいずれかであるとする。もし
x が B または C における自由な出現であるならば、その
x は A において自由である。もし x が B または C におけ
る束縛された出現であるならば、その x は A において束
縛されている
3. A が (∀z B) または (∃z B) であるとする。もし z が x である
ときは、Aにおける x の出現は束縛されている。
z が x と異なる場合には、もし x が B における自由な出
現であるならば、その x の出現は A において自由であ
る。もし x が B における束縛された出現であるならば、
その x の出現は A において束縛されている
9
自由変数と束縛変数(例)
• 例: ∃y (x = y+y )∧ ∃z ( y = z+z+1 )
• 論理式が自由変数を一つも含まない時
閉論理式 closed formula という
• 論理式 A に含まれる自由変数 x に項 t を代入し
て得られる論理式を A[t/x] と表す
• 代入をめぐる珍現象: (小野先生の例題)
∃z(x=y×z) : x は y の倍数である
∃z(x=100×z) : x は 100 の倍数である
∃z(x=z×z) : x は平方数である
• これを避けるために自由変数と束縛変数の記号
の種類を分ける流儀の教科書もある
10
代入の方法
• A は ∀zB または ∃zB の形の論理式とする
• A[t/x]は
z が x のとき A[t/x] は A 自身(束縛変数に代入不可)
z が x とは異なる変数のとき、
t に z が出現しなければ、
A[t/x] は ∀zA[t/x] または ∃zA[t/x]
t に z が出現する場合は、
A[t/x] は ∀w((A[w/z])[t/x])
または ∃w((A[w/z])[t/x] )
ただし w は A にも t にも現れない新しい対象変数
i.e. 項 t に変数 w が現れることがない
11
代入に関する補足説明
• 前のスライドの変数 w は新しい変数である。
これは対象変数の集合が無限集合であるこ
とを意味する。つまり必要があれば、いつでも
「新しい変数」を選ぶことができる。
• 前のスライドの面倒な操作を一言で表現すれ
ば「束縛変数が項 t に出現する場合には、束
縛変数を新しい変数に、あらかじめ書き換え
ておく」ということである。
12
論理式の意味
• 述語論理の論理式の意味を考えるには、対象領域
domain を定める必要がある
(解釈 interpretation, モデル model, 構造 structure)
• 空でない集合 D を定める
• 対象定数に D の要素(元)を対応づける
対象変数は D の上を動く
関数記号に D の上の関数を対応づける
述語記号に D の上の述語を対応づける ※
単なる記号 に 具体的な要素、関数、述語 を対応
※ ただし述語記号 = (等号)の解釈は通常の等号とする
13
解釈 ⊨ 閉論理式
⊭⊨
• M ⊨ A 解釈 M において論理式 A が真
• M ⊭ A 解釈 M において論理式 A が偽
1. A が原子論理式のとき M ⊨ P(t1, t2, …, tn) とな
るのは、Pの解釈が項 t1, t2, …, tn の解釈にお
いて真になる場合である.
2. M ⊨ A∧B となるのは (M ⊨ A かつ M ⊨ B ),
3. M ⊨ A∨B となるのは(M ⊨ A または M ⊨ B),
4. M ⊨ A⇒B となるのは (M ⊨ A ならば M ⊨ B),
5. M ⊨ ¬A となるのは M ⊭ A の時である .
M: Lucida Calligraph
⊭⊨ : MSゴシック(UTF)
14
(続) 解釈 ⊨ 閉論理式
⊭⊨
6. M ⊨ ∀x A となるのは、すべての D の要素 u に
対して M ⊨ A[u/x] となるとき,
7. M ⊨ ∃x A となるのは、D のある要素 u が存在
して M ⊨ A[u/x] となるときである.
論理式 B に対して、B に含まれる自由変数 が
x1, x2, …, xm であるとき、 ∀x1∀x2…∀xm Bを
B の閉包 universal closureという. BC と書く
8. M ⊨ B となるのは M ⊨ BC となるときである.
M: Lucida Calligraph
⊭⊨ : MSゴシック(UTF)
15
恒真な(valid)論理式
• いかなる解釈(モデル)に対しても真になる論理式
を恒真な valid 論理式という
「述語論理におけるトートロジー」ということもある
• どのような解釈をしても真になるということは、個別
の対象要素、関数記号、述語記号の解釈に依存し
ないという意味である
すなわち論理式の形(構造)により、恒真であるか
否かが定まる
16
恒真な論理式の例(その一)
A は x を自由変数として含まない
1. ∀x A ⇔ A, ∃x A ⇔ A
2. ∀x B ⇔ ∀y(B[y/x]), ∃x B ⇔ ∃y (B[y/x])
ここに y は B に含まれていない新しい変数
3. A ∧ ∀x B ⇔ ∀x (A∧B),
A ∨ ∃x B ⇔ ∃x (A∨B)
4. A ∨ ∀x B ⇔ ∀x (A∨B),
A ∧ ∃x B ⇔ ∃x (A∧B)
5. ∀x B ∧ ∀x C ⇔ ∀x (B∧C),
∃x B ∨ ∃x C ⇔ ∃x (B∨C)
6. (∀x B ∨ ∀x C) ⇒ ∀x (B∨C),
∃x(B ∧ C) ⇒ (∃x B∧∃x C)
17
恒真な論理式の例(その二)
7. ∀x∀y B ⇔ ∀y∀x B , ∃x∃y B ⇔ ∃y∃x B
(関連の話題が前出)
8. ∃x∀y B ⇒ ∀y∃x B
9. ∀x B ⇒ ∃x B
10. ¬∀x B ⇔ ∃x¬B, ¬∃x B ⇔ ∀x¬B
11. (A ⇒∀x B) ⇔ ∀x(A ⇒ B),
(A ⇒∃x B) ⇔ ∃x(A ⇒ B)
12. (∀x B ⇒ A) ⇔ ∃x(B ⇒ A),
(∃x B ⇒ A) ⇔ ∀x(B ⇒ A)
13. ∃x(B ⇒ C) ⇔ (∀x B ⇒ ∃x C)
14. ∀x(B ⇒ C) ⇒ (∀x B ⇒ ∀x C)
15. ∀x(B ⇒ C) ⇒ (∃x B ⇒ ∃x C)
ド・モルガンの法則
18
恒真な論理式の説明
• (∃x B ⇒ A) ⇔ ∀x(B ⇒ A) 12の下
• この論理式に含まれる自由変数が y1, …, ym の
とき、任意の解釈 M について次をいえばよい
M ⊨∀y1…∀ym{(∃x B ⇒ A) ⇔ ∀x(B ⇒ A)}
• 上は閉論理式であるから次をいう(解釈 4, 6)
すべての u1, …,um ∈ D に対して
M ⊨(∃x B ⇒ A)[u1/y1,…,um/ym]
⇔ M ⊨ ∀x(B ⇒ A) [u1/y1,…,um/ym]
• 以下の説明では、既に上のような項の代入が済
んでいると仮定する
19
恒真な論理式の説明(2)
M ⊨ (∃x B ⇒ A) ⇔ M ⊨ ∀x(B ⇒ A)
• M ⊨(∃x B ⇒ A) であると仮定する. 解釈4から「
(M ⊨ ∃x B ) ならば(M ⊨ A)である 」 ということ
になる
• 解釈7から「(ある v∈D が存在して M ⊨ B[v/x])
ならば(M ⊨ A)である 」 ということになる
• 上は「(M ⊨ B[v/x] を満たすような v∈D は存在し
ない)または(M ⊨ A)である 」となる
• さらに「(すべての v∈D に対して M ⊭ B[v/x] )ま
たは(M ⊨ A)である 」となる
20
恒真な論理式の説明(3)
M ⊨ (∃x B ⇒ A) ⇔ M ⊨ ∀x(B ⇒ A)
• 論理式 A は x を自由変数として含まない
「すべての v∈D に対して (M ⊭ B[v/x] または
M ⊨ A[v/x])である 」
• 「すべての v∈D に対して (M ⊨ ¬ B[v/x] または
M ⊨ A[v/x])である 」
• 「(すべての v∈D に対して
(M ⊨ ¬ B[v/x] ∨A[v/x])である 」
• 「(すべての v∈D に対して
(M ⊨ B[v/x] ⇒ A[v/x])である 」
• M ⊨ ∀x(B ⇒ A)
半分終り
21
恒真な論理式の説明(4)
M ⊨ (∃x B ⇒ A) ⇔ M ⊨ ∀x(B ⇒ A)
• M ⊨∀x(B ⇒ A) であると仮定する. 解釈6と4から
「すべての v∈D に対して(M ⊨ B[v/x] ならば
M ⊨ A[v/x])である 」 になる
• 論理式 A は x を自由変数として含まない「すべて
の v∈D に対して(M ⊭ B[v/x] または M ⊨ A )」
• 「(すべての v∈D に対してM ⊭ B[v/x])または
(M ⊨ A)である )」,さらに「(M ⊨ B[v/x] を満たす
v∈D は存在しない) または(M ⊨ A)である 」
• 「(M ⊨ B[v/x] を満たすv∈D が存在する) ならば
(M ⊨ A)である 」
終
22
充足可能な論理式
• ある解釈(モデル)に対して真になる論理式を充足
可能な satisfiable 論理式という
• 充足可能でない論理式を充足不可能 unsatisfiable
という
• 論理式 A が充足不可能であることは、¬A が恒真で
あることの必要十分条件である
23
冠頭標準形 prenex normal form
• 全称記号∀と存在記号∃が、他の論理記号の外
側にあるとき、冠頭論理式という
QxQyQz…A, Qは∀あるいは∃記号
A は全称記号も存在記号も含まない論理式
• 論理式 A と同値な冠頭論理式が存在する
これを冠頭標準形という
• (小野先生の説明) 恒真な論理式の 3, 4, 10, 11,
12 を使って同値変形する。ただし A が自由変数
x を含むときは、まず 2. により x を新しい変数で
置き換えておく
24
冠頭標準形への同値変形
¬∃yP(x,y)∧∀y{∃zQ(x,y,z)⇒R(x,y)}
¬∃yP(x,y)∧∀w{∃zQ(x,w,z)⇒R(x,w)}
∀y¬P(x,y)∧∀w{∃zQ(x,w,z)⇒R(x,w)}
∀y∀w{¬P(x,y)∧(∃zQ(x,w,z)⇒R(x,w))}
∀y∀w{¬P(x,y)∧∀z(Q(x,w,z)⇒R(x,w))}
∀y∀w∀z{¬P(x,y)∧(Q(x,w,z)⇒R(x,w))}
訂正: 廣瀬先生のp.24, ∃zは∀zです
さらに
∀y∀w∀z{¬P(x,y)∧(¬Q(x,w,z)∨R(x,w))}
∀y∀w∀z{(¬P(x,y)∧¬Q(x,w,z))
分配法則
∨( ¬P(x,y)∧R(x,w))}
25
冠頭標準形
• (廣瀬先生の説明) 与えられた述語の中の別の変
数が同じ変数の記号で表されているとき、すべて異
なる変数に書き換える
例: ∀x P(x,y)∨∃y Q(y,z)は∀x P(x,y)∨∃w Q(w,z)
∃x P(x)∧∀x Q(x, y)は∃x P(x)∧∀z Q(z, y)
• ド・モルガンの法則を用いて否定記号¬を内側に移
動する(10)
• 全称記号∀と存在記号∃を外側に移動する
(3, 4, 11, 12)
• さらに、冠頭標準形と論理和標準形、冠頭標準形と
論理積標準形を組合せることができる
26