Download presentation
1
第14回 プログラムの意味論と検証(3) 不動点意味論 担当:犬塚
プログラミング言語論 第14回 プログラムの意味論と検証(3) 不動点意味論 担当:犬塚
2
今日の講義 これまでに簡単なプログラミング言語について、表示的意味論を与えた。
本講義では、再帰呼び出しで定義される関数についての表示的意味を与える。 この理論は不動点意味論と呼ばれる。 この意味論のために導入する領域理論と合わせて、D.Scottが与えた。
3
再帰 再帰は、基本的な制御構造である。 チューリング機械と同様によく用いられる計算の原理である、帰納的関数論(recursive function theory)では、再帰が基本的制御構造。 他のループも再帰に還元できる。 再帰は、内側の呼出しでサイズの小さなパラメータで呼び出すように書けば確実に停止するので、扱いの容易な制御構造である。
4
この講義で導入するアイデア 再帰定義を汎関数を用いて再定義する。 再帰的プログラムの意味を、汎関数の不動点として捉える。
再帰的関数の表示的意味としてふさわしい、関数の領域を用意する。 連続関数 領域の上で、汎関数の不動点が存在することを示す =不動点定理
5
再帰 f (x, y) = (if x=0 then y else f (x-1, 2*y))
f (3,3)=f (2,6)=f (1,12)=f (0,24)=24 g(x,y) = (if x=y then y+1 else g(x, g(x-1, y+1))) g(4,2)=g(4,g(3,3))=g(4,4)=5 g(5,1)=g(5,g(4,2))=g(5,g(4,g(3,3)))=g(5,g(4,4))=g(5,5)=6 g(2,3)=g(2,g(1,4))=g(2,g(1,g(0,5)))=g(2,g(1,g(0,g(-1,6))))=…
6
再帰と汎関数 再帰的関数定義 f (x,y) = (if x=0 then y else f (x - 1, 2 * y))
この再帰的な関数定義は、汎関数 G=lj x y. (if x=0 then y else j (x - 1, 2 * y)) を用いると、次の方程式として書くことができる。 f = G( f )
7
練習 次の再帰的関数定義を、汎関数を用いて書き直せ。 g(x,y) = (if x=y then y+1 else g(x-1, y+1))
Γ=λψxy. (if x=y then y+1 else ψ(x-1, y+1)) としたとき、 g=Γ(g)
8
Gの不動点 は次の関数を不動点として持つ。 f = lxy. 2xy = lxy.(if x=0 then y else 2x-12*y)
G1=lj xy.(if x=0 then y else j(x-1, 2*y)) は次の関数を不動点として持つ。 f = lxy. 2xy G1 ( f ) = lxy.(if x=0 then y else f (x-1, 2*y)) = lxy.(if x=0 then y else 2x-12*y) = lxy.(if x=0 then 2xy else 2xy) = lxy. 2xy =f
9
2つの不動点 G2=ljxy. (if x=y then y+1 else j(x, j(x-1, y+1)))
次の汎関数は少なくとも2つの不動点をもつ。 G2=ljxy. (if x=y then y+1 else j(x, j(x-1, y+1))) f1 = lxy. x+1 G2 (f1) = lxy.(if x=y then y+1 else f1(x, f1 (x-1, y+1))) = lxy.(if x=y then x+1 else x+1) =f1 f2 = lxy.(if x≧y then x+1 else y-1) G2 (f2) = lxy.(if x=y then y+1 else f2(x, f2 (x-1, y+1))) = lxy.(if x=y then y+1 else f2(x, {if x-1≧y+1 then x else y})) = lxy.(if x=y then y+1 else f2(x, {if x≧y+2 then x else y})) = lxy.(if x=y then y+1 else {if x≧y+2 then x+1 else if x≧y then x+1 else y-1})) = lxy.(if x≧y then x+1 else y-1)=f2
10
汎関数によって定義される関数 関数hについて x = h(x)の解 を、不動点(fixed point)という。
再帰的に定義される関数は、汎関数Gの方程式 f = G( f ) の解と考えられる。つまり、 Gの不動点である。 疑問点: どんなGは不動点をもつことが保証できるのか? 2つ以上の不動点を持つことはないのか?2つ以上不動点をもつ場合、どれが定義される関数なのか?
11
無限個の不動点をもつ汎関数の例 G3=lj x. (if x=0 then 1 else j(x+1))
この汎関数は、以下のものすべてを不動点として持つ。 f0= lx.(if x=0 then 1 else 0) f1= lx.(if x=0 then 1 else 1) f2= lx.(if x=0 then 1 else 2) f3= lx.(if x=0 then 1 else 3) … さらに、次の部分関数も不動点と見なせる。 fu = lx.(if x=0 then 1 else 未定義) 実際には、上のG3 に対応する次のプログラムではfuがまさに、このプログラムの意味にふさわしい。 f(x) = (if x=0 then 1 else f (x+1))
12
部分関数 A B プログラムとしての関数は、その計算が停止しない場合、 未定義(undefined)であると考えられる。
即ち、プログラムの意味は、未定義の部分を含んだ関数 =部分関数(partial function)として与えなければならない。 未定義の箇所のない関数は全域関数(total function)。 A B × × × 未定義
13
定義域、値域の拡張 D D+ 関数の定義域、値域には未定義要素も含めて考えるのが便利である。
そこで、集合Dに対して次の集合を定義することにする。 D+=D∪{wD} こうした集合を領域(domain)という。 D D+ wD
14
自然な拡張 未定義を明示的に扱うため、部分関数の扱いを再構成する。 定義域A、値域Bの部分関数 f : A→B
f (x) ; f (x) が定義されているとき f+(x) = wB ; x= wA か、または f (x)が未定義のとき f+ は f の自然な拡大(natural extension)という。 A B A+ B+ × × × × × × 未定義 wA wB
15
領域の上の半順序関係 T F wBool 領域D+上で、未定義の値から定義の値への順序 を考える。 すなわち、x, y ∈D+について、
領域D+上で、未定義の値から定義の値への順序 を考える。 すなわち、x, y ∈D+について、 x=wD,またはx=y のときそのときに限りx y 例 Bool={T, F}としたとき、Bool+={T, F, wBool}で、次のハッセ図で表される順序をもつ。 T F wBool
16
2引数の関数 f(x,y)=x+yのような2引数関数の定義域に対する領域を与える。 D1×D2に対応する領域は次のとおり。
(D1×D2)+=D1+×D2+ (A×B)+上の半順序を次のとおり定義する。 (x, y), (x’, y’) ∈(D1×D2)+について、 x x’ かつ y y’ のとき、そのときに限り(x, y) (x’, y’) 例 Bool={T, F}のとき、 (Bool×Bool)+ ={(T,T),(T,F),(T,wBool), (F,T),(F,F),(F,wBool), (wBool,T),(wBool,F),(wBool,wBool)} これは右のハッセ図で表される順序をもつ。 (T,T) (T,F) (F,T) (F,F) (T,wBool) (wBool,T) (F,wBool) (wBool,F) (wBool,wBool)}
17
関数の単調性 通常通り定義された関数は領域上の順序に関して単調性をもつ。 単調性(monotonic): x yのとき、f(x) f(y)
例 通常、関数の引数が未定義なら関数の返り値は未定義。 f : N×N → N, f(x, y)= x+y f+:(N×N)+ →N+, f+(x, y)= x+y f+は について単調である。 (∵) (x, y) (x’, y’)とする。 x, yがどちらもwNでなければ(x, y)=(x’, y’)。よってf+(x, y) f+(x’, y’) x, yのどちらかがwNなら f+(x, y)=wNなのでやはりf+(x, y) f+(x’, y’)
18
練習 g : N×N → N, g(x, y)= if x=0 then x else x+y も単調性を持つことを確認せよ。
この場合は、もう少し場合わけが必要。 (x, y) (x’, y’)とする。 1) x= wNのとき 2) x= 0 のとき 3) xが0, wNのどちらでもなく、y = wN のとき 4) xが0, wNのどちらでもなく、 y もwN 以外の値のとき
19
計算される関数の候補 我々の表示的意味論として考えるべき関数は、単調な関数だけでよい。
単調でない関数は不自然である: ある引数が未定義であるかどうかで、答えが変わるのはおかしい。 そこで、 (D1→D2)+={ f + | f + : D1 + →D2 + は単調}
20
関数の間の順序 汎関数も同様の議論で扱うには、汎関数の定義域=関数の集合にも順序を導入する必要がある。
f1, f2 ∈(D1→D2)+について、 任意の x∈D1+で f1(x) f2(x)であるときそのときに限り、 f1 f2 つまり、f1 f2 であるとは、 f1が未定義でない限り f1(x)=f2(x)であるということ。 ( f1(x)が未定義の場合は、 f2(x)はどんな値を持ってもよい)
21
鎖、一意な極限 D+の要素の(無限)列 x0, x1, x2,…が x0 x1 x ・・・ となるとき、この列をD+の鎖 (chain) という。 D+の鎖 x0, x1, x2,… に対し、つぎの x をこの鎖の 一意な極限(unique limit) という。 xi x , i=0, 1, … y が xi y , i = 0, 1,… をみたすなら x y (xは鎖のどの要素より大きく、そういうものの中で一番小さい) 鎖 x0, x1, x2,… の一意な極限を lim xi と書く。 i →∞
22
領域の性質 これまで検討してきた関数の領域は次の性質D+を持つ。 ここで改めて、上の性質を持つとき 領域 ということにする。
D+は に関して半順序集合である。 D+は最小の要素を持つ。 D+のすべての鎖が、一意な極限をもつ。 こうしたことは、(D1×D2)+、(D1→D2)+にも言える。 ここで改めて、上の性質を持つとき 領域 ということにする。
23
連続 D1+、D2+を領域、 f :D1+→D2+を単調な関数とする。 このとき、D1+の任意の鎖、 x0, x1, x2,…を考えると、
f は単調であるので、 f (x0), f (x1), f (x2),…も鎖である。 D2+は領域なので、任意の鎖は一意な極限をもつ。 このとき次が成立つ場合、 f は 連続(continuous) であるという。 f ( lim xi) = lim f (xi) i →∞ i →∞
24
解析での連続と、ここでの連続 ここで用いた連続の概念は、特別のものでない。 普通に用いる連続の概念は、実はここで述べた連続の特別なケース。
通常連続は次のように定義される。 R(実数)の点列a0, a1, a2,…は次のとき極限aを持つ。 任意のe >0に対して、あるNがあり、すべての i>N で |a-ai|<e。 関数 f : R→Rが連続であるとは、極限をもつ任意のRの点列a0, a1, a2,…に対し、f (lim ai) = lim f (ai)。 i →∞ i →∞
25
不動点定理 D+を領域、f : D+→D+を連続関数とする。 このとき f は、 x = lim f n(wD)
ただし、wDはD+の最小要素。 さらに、この x は最小の不動点である。 n →∞
26
不動点定理の証明(1) まず f i(wD) f i+1(wD)を i に関する数学的帰納法で示す。
i =0 の場合、wDは最小要素なので wD f (wD)。 f i (wD) f i+1(wD)ならば f の単調性から f i+1(wD) f i+2(wD) したがって、 wD f (wD) f 2(wD) ・・・ 示された。 したがってこれらは鎖となり、一意な極限 x =lim f i(wD)がある。 すると、 f の連続性から、 f (lim f i(wD))=lim f i+1(wD)= lim f i(wD) つまり、xは不動点である。 i →∞ i →∞ i →∞ i →∞
27
不動点定理の証明(2) つぎに x が最小の不動点であることを示す。 y を f のある不動点とする。
するとwDは最小要素なので wD y。 f の単調性から f (wD) f (y)=y 同様に任意の i についてf i (wD) yである。 したがって、極限の性質より x =lim f i (wD) y (以上) i →∞
28
まとめ 再帰的プログラムの意味を与える不動点意味論を紹介した。 再帰的プログラムは汎関数の不動点として定義できる。
関数が不動点を持つための定理=不動点定理を利用して、再帰定義が定義するものを明らかにすることができる。 不動点定理が述べる最小不動点は確かに、プログラムの動きと一致する。
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.