Mercurial > hg > Papers > 2015 > atton-thesis
annotate delta.tex @ 49:ba7f0b5454ab
Add description for DeltaM definition
author | Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 15 Feb 2015 14:07:07 +0900 |
parents | df55c9df8aac |
children | 37a832dff044 |
rev | line source |
---|---|
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
1 \chapter{プログラムの変更を表現する Delta Monad} |
11
76ce5bb18092
Add Category definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
10
diff
changeset
|
2 \label{chapter:delta} |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
3 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
4 本研究では Monad によりプログラムの変更を定義する。 |
49
ba7f0b5454ab
Add description for DeltaM definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
34
diff
changeset
|
5 第\ref{chapter:delta}章ではプログラムの変更を表す Delta Monad を定義し、その使用例とメタ計算の例を示す。 |
ba7f0b5454ab
Add description for DeltaM definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
34
diff
changeset
|
6 なお、Monad についての定義と解説は第\ref{chapter:category}章と第\ref{chapter:functional_programming}章にて行なう。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
7 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
8 % {{{ Delta Monad の定義 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
9 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
10 \section{Delta Monad の定義} |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
11 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
12 まずはプログラムを定義する。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
13 プログラムは型付けされた値と、値を値へと写像する関数のみで構成されるものとする。 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
14 プログラムの実行は関数の値への適用とする。 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
15 入出力といった、値や関数で表現できない計算はメタ計算とする。 |
10 | 16 メタ計算をある性質を持つデータ構造に対応させ、メタ計算が必要な関数は値をデータ構造へと写像することで入出力といった処理を実現する。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
17 メタ計算とデータ構造の対応に用いる性質が Monad である。 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
18 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
19 例えば、失敗する可能性があるメタ計算 T は式\ref{exp:partiality}のように定義できる。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
20 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
21 \begin{equation} |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
22 T A = A_{ \bot } (i.e. A + \left\{ \bot \right\}) |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
23 \label{exp:partiality} |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
24 \end{equation} |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
25 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
26 型 A の値に対応するメタ計算 T は、A と $ \bot $ の論理和として表現できる。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
27 成功した際は A を返し、失敗した場合は $ \bot $ を返す。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
28 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
29 ここで、失敗しない前提で作成されたプログラムに対して、失敗する可能性を表現するメタ計算を対応させるとする。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
30 プログラムは型付けされた値と、関数の組み合せで構成される。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
31 例えば、型 A の値x と、型 A の値を取り型 B の値を返す関数f, 型B の値を取り型Cの値を返す関数g によって構成されるとする(式\ref{exp:non_failure_program})。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
32 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
33 \begin{equation} |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
34 g ( f ( x )) |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
35 \label{exp:non_failure_program} |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
36 \end{equation} |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
37 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
38 ここで関数f は失敗する可能性があるとする。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
39 その時、f が失敗した場合の計算を考える必要がある。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
40 計算の実現方法はいくつか存在する。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
41 計算g に失敗の判断を追加したり、例外機構により失敗を補足することで呼び出し元の関数で行なうことで実現できる。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
42 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
43 実現方法の1つとして、 Monad を用いたメタ計算がある。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
44 Monad により失敗した際の計算をメタ計算としてデータ構造に紐付ける。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
45 式\ref{exp:partiality} で定義したように、計算の成功は型 A 値を返し、失敗は $ \bot $ を返す。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
46 計算に失敗した際に対応するメタ計算を定義し、関数をそのメタ計算で拡張することで失敗に対する処理が実現できる。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
47 例えば、 A に対してはそのまま関数の適用を行ない、 $ \bot $ に対しては $ \bot $ を返すようなメタ計算を定義することで、計算が失敗した時に計算を終了することが実現できる。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
48 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
49 型A を持つx の値をメタ計算と対応して型 T A とした値を x' 、メタ計算による関数の拡張を * と記述すると、式\ref{exp:non_failure_program} の式は式\ref{exp:failure_program} のように書ける。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
50 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
51 \begin{equation} |
49
ba7f0b5454ab
Add description for DeltaM definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
34
diff
changeset
|
52 g^{*} ( f^{*} ( x' )) |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
53 \label{exp:failure_program} |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
54 \end{equation} |
14
586f3ce1effe
Add folding for section
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
12
diff
changeset
|
55 |
49
ba7f0b5454ab
Add description for DeltaM definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
34
diff
changeset
|
56 ここで重要な点は、元の関数 $ f $ と $g$ から $f^{*}$ と $g^{*}$ が導けることである。 |
ba7f0b5454ab
Add description for DeltaM definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
34
diff
changeset
|
57 メタ計算が無い関数 $ f $ とメタ計算を持つ関数 $ f^{*} $ が1対1に対応することは Monad により保証されている。 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
58 このように、値と関数で表されたプログラムにおいてメタ計算を用いることで、計算を拡張することができる。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
59 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
60 プログラムの変更をメタ計算として記述することを考える。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
61 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
62 ここで、プログラムの変更とは関数や値が変更されることであり、変更される量には単位がある。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
63 最初の変更単位をバージョン1とし、変更された後のプログラムはバージョンが1増加する。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
64 任意の型Aに対するメタ計算Tを考えた時、プログラムの変更は式\ref{exp:meta_computation_definition}のように定義する。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
65 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
66 \begin{equation} |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
67 T A = V A |
11
76ce5bb18092
Add Category definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
10
diff
changeset
|
68 \label{exp:meta_computation_definition} |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
69 \end{equation} |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
70 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
71 V はプログラムの全てバージョンの集合であり、V AとすることでAに対応する値の集合を返すものとする。 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
72 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
73 ここで、プログラムが変更される際に過去のバージョンのプログラムも保存するメタ計算を提案する。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
74 全ての変更単位で変更されたプログラムを保存し、それらを比較することでプログラムの変更を表現しようと考えた。 |
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
75 このメタ計算を表す Monad を Delta Monad と呼ぶ。 |
49
ba7f0b5454ab
Add description for DeltaM definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
34
diff
changeset
|
76 なお、この Delta Monadが Monad であることの証明は \ref{chapter:proof_delta} 章で行なう |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
77 |
14
586f3ce1effe
Add folding for section
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
12
diff
changeset
|
78 % }}} |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
79 |
14
586f3ce1effe
Add folding for section
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
12
diff
changeset
|
80 % {{{ Haskell における Delta Monad の実装例 |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
81 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
82 \section{Haskell における Delta Monad の実装例} |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
83 |
12
11015b94a5cd
Add figures category
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
11
diff
changeset
|
84 式\ref{exp:meta_computation_definition}のメタ計算をMonadで実現する。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
85 |
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
86 実装例としてプログラミング言語 Haskell を用いる。 |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
87 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
88 まずは全てのプログラムのバージョンを表わすデータ型 Delta を考える。 |
19
43d3e7b31fc0
Fix listings and page numbering
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
14
diff
changeset
|
89 Delta の定義はリスト\ref{src:delta_constructor} とする。 |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
90 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
91 \begin{table}[html] |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
92 \lstinputlisting[label=src:delta_constructor, caption=Haskellにおけるデータ型Deltaの定義]{src/delta_constructor.hs} |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
93 \end{table} |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
94 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
95 データ型 Delta はコンストラクタ Delta もしくは Mono によって構成される。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
96 バージョンが1である値は Mono によって構成される。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
97 プログラムを変更する際には、コンストラクタ Delta を用いて記述し、変更後の値と前のバージョンを持つ。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
98 なお、a とは任意の型であり、Delta が任意の型の値に対してもデータ型を構築できることを示す。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
99 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
100 Haskell においてメタ計算とデータ型の対応は Monad によって行なうため、 Monad という型クラスが用意されている。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
101 型クラスとは特定の性質を持つ型をまとめるための制約である。 |
32
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
102 ある型が型クラスに属するためには制約として型クラスによって指定された関数を定義する。 |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
103 なお、型aが型クラスCに属することを「型aは型クラスCのインスタンスである」と言う。 |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
104 型クラス Monad はリスト\ref{src:monad_class}のように定義されている。 |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
105 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
106 \begin{table}[html] |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
107 \lstinputlisting[label=src:monad_class, caption=Haskell における Monad 型クラス] |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
108 {src/monad_class.hs} |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
109 \end{table} |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
110 |
32
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
111 |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
112 型クラス Monad に属するために要請される関数は return と \verb/>>=/ である。 |
34
df55c9df8aac
Adjust monad class definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
32
diff
changeset
|
113 \verb/::/ は型注釈であり、 $ term :: type $ のように記述する。 |
df55c9df8aac
Adjust monad class definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
32
diff
changeset
|
114 なお、関数型は \verb/ a -> b / のように引数の型と返り値の型を \verb/->/で挟んで記述する。 |
df55c9df8aac
Adjust monad class definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
32
diff
changeset
|
115 引数が2つ以上の関数は \verb/ a -> b -> ... -> d / のように \verb/->/を増やすことで記述する。 |
df55c9df8aac
Adjust monad class definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
32
diff
changeset
|
116 |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
117 関数 return は任意の型aを受けとり、メタ計算と対応された型に対応させて返す。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
118 \verb/>>=/ は中置関数であり、left operand と right operand を取る。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
119 left operand であるメタ計算と対応された値と、right operand であるメタ計算と対応された値を返す関数を取り、メタ計算を行ないながら関数を適用する。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
120 |
32
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
121 データ型 Delta に対応するメタ計算を Monad を用いてリスト\ref{src:delta_instance_monad}のように定義する。 |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
122 |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
123 \begin{table}[html] |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
124 \lstinputlisting[label=src:delta_instance_monad, caption=Haskell におけるデータ型Deltaとメタ計算の関連付け] |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
125 {src/delta_instance_monad.hs} |
fc864841ab90
Update description of definition delta monad in haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
31
diff
changeset
|
126 \end{table} |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
127 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
128 \begin{itemize} |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
129 \item 関数 return |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
130 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
131 通常の値をメタ計算と対応させるため、値をバージョン1の値とする。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
132 そのためにコンストラクタ Mono を用いる。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
133 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
134 \item 中置関数 \verb/>>=/ |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
135 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
136 メタ計算を含んだ関数の適用であるため、値と関数の同じバージョンを計算して返すものとなる。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
137 もしバージョン1であった場合はコンストラクタは Mono であるため、Mono が持っている値に対して関数を適用することとなる。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
138 もしバージョンが1で無い場合のコンストラクタは Delta であるため、先頭の値を用いて計算し、残りの値と結合することとなる。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
139 その際、先頭の値を取り出すために headDelta 関数を、先頭以外の値を取り出すために tailDelta 関数を用いる。 |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
140 \end{itemize} |
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
141 |
49
ba7f0b5454ab
Add description for DeltaM definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
34
diff
changeset
|
142 なお、中置関数 \verb/>>=/ や headDelta関数などで用いたコンストラクタによる処理の分岐はパターンマッチと呼ばれる。 |
8
c4da3e667aad
Add Delta definition in Haskell
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
6
diff
changeset
|
143 Haskell ではコンストラクタごとに関数を記述することでパターンマッチを実現する。 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
144 |
14
586f3ce1effe
Add folding for section
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
12
diff
changeset
|
145 % }}} |
586f3ce1effe
Add folding for section
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
12
diff
changeset
|
146 |
31
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
147 % {{{ Delta Monad を用いたプログラムの変更の記述例 |
6
3b861ecdec9b
Add description meta computation
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
diff
changeset
|
148 |
31
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
149 \section{Delta Monad を用いたプログラムの変更の記述例} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
150 \label{section:delta_example} |
9
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
151 プログラムの変更を表現するメタ計算に対応するデータ型 Delta が記述できた。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
152 |
19
43d3e7b31fc0
Fix listings and page numbering
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
14
diff
changeset
|
153 実際に Haskell で Delta を用いたプログラムの変更例をリスト\ref{src:delta_example}に示す。 |
9
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
154 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
155 \begin{table}[html] |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
156 \lstinputlisting[label=src:delta_example, caption=Deltaを用いたプログラムの例] |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
157 {src/delta_example.hs} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
158 \end{table} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
159 |
19
43d3e7b31fc0
Fix listings and page numbering
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
14
diff
changeset
|
160 リスト\ref{src:delta_example}は1からnの間の整数に含まれる特定の数の個数を調べるプログラム numberCount である。 |
9
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
161 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
162 このプログラムは3つの関数からなり、2つのバージョンを含む。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
163 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
164 \begin{itemize} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
165 \item generator |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
166 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
167 1からnの間の整数を生成する関数である。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
168 nを渡すことにより1からnの間の整数のリストを返す。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
169 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
170 \item numberFilter |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
171 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
172 数のリストから特定の数のみを絞り込む関数である。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
173 バージョン1では素数の数のみを絞り込み、バージョン2では偶数の数のみを絞り込んでいる。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
174 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
175 \item count |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
176 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
177 数の個数を数える関数である。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
178 整数はリストで与えられるため、リストの長さが個数であるとした。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
179 \end{itemize} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
180 |
10 | 181 これらの関数3つをMonad の \verb/>>=/ によってメタ計算を含む関数呼び出しとして実行する。 |
182 3つの関数を実行する関数が numberCount 関数であり、この関数がプログラム本体である。 | |
183 numberCount を実行すると \ref{txt:delta_example_result}のような結果が得られる。 | |
9
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
184 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
185 \begin{table}[html] |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
186 \lstinputlisting[label=txt:delta_example_result, caption=numberCountプログラムの実行結果] {src/delta_example_result.txt} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
187 \end{table} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
188 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
189 これはnに1000を与えた結果である。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
190 バージョン1の時は素数の数を求めるため計算結果は168であり、バージョン2の時は偶数の数を求めるために計算結果は500となる。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
191 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
192 3つの関数で構成されたプログラムに対して1つの変更を加えたプログラムを表現することができた。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
193 つまり、Monad によってプログラムの変更をメタ計算として定義できたと言える。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
194 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
195 Haskell において実装した Delta Monad はプログラムの変更を含めた計算もメタ計算としてHaskellで実行する。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
196 これはプログラムの変更からどのような処理を導くかをメタ計算として Haskell で実行可能であることを意味する。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
197 つまり、図\ref{fig:non_delta_example}のようにプログラムにおいてバージョンが変わるごとにバージョン間の関係が存在しない状態から、図\ref{fig:delta_example}のようにプログラムの変更を含めてプログラムを実行可能となったことを意味する。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
198 例えば、プログラムの実行時にバージョン間の挙動の比較することで過去の挙動との差異を指摘することなどが可能となる。 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
199 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
200 \begin{figure}[htbp] |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
201 \begin{center} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
202 \includegraphics[scale=0.8]{fig/non_delta_example.pdf} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
203 \caption{Deltaを用いない通常のプログラムの例} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
204 \label{fig:non_delta_example} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
205 \end{center} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
206 \end{figure} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
207 |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
208 \begin{figure}[htbp] |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
209 \begin{center} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
210 \includegraphics[scale=0.8]{fig/delta_example.pdf} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
211 \caption{Deltaを用いたプログラムの例} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
212 \label{fig:delta_example} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
213 \end{center} |
324111203070
Add example used delta
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
8
diff
changeset
|
214 \end{figure} |
14
586f3ce1effe
Add folding for section
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
12
diff
changeset
|
215 |
586f3ce1effe
Add folding for section
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
12
diff
changeset
|
216 % }}} |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
217 |
31
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
218 % プログラムの変更に対するメタ計算の例 {{{ |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
219 |
30
67d79c18a276
Update description and delta definition
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
19
diff
changeset
|
220 \section{プログラムの変更に対するメタ計算の例} |
31
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
221 \label{section:delta_merit} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
222 \ref{section:delta_example}節ではプログラムの変更に対して、変更前と変更後の挙動を保存した例を述べた。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
223 \ref{section:delta_merit}節ではプログラムの変更に対するメタ計算の例を述べる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
224 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
225 まず最初に挙げられるものがプログラムの変更を保存するメタ計算である。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
226 これは Delta Monad として実際に定義できた。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
227 プログラムの変更を保存した場合、以下のような方法により信頼性の向上が見込めると考える。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
228 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
229 \begin{itemize} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
230 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
231 \item 異なるバージョンを同時に実行する |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
232 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
233 プログラムの変更列から任意のバージョン2つを取り出し、同時に実行するプログラムを構成する。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
234 プログラムを同時に実行することで以下のようなメリットがある。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
235 なお、任意の要素の組み合せは category において product として表現されるため、 product と対応があると考えている。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
236 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
237 \begin{itemize} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
238 \item 実行系とサブの実行系を実行することができる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
239 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
240 例えば、あるバージョンでリリースしたプログラムがあるとする。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
241 変更を加え、ベータ版としてリリースしたいが動作が不安定である。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
242 そこで、リリースしたプログラムからベータ版への変更から、2つのプログラムが同時に動くようなプログラムを構築する。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
243 見掛け上は安定版として動作するが、安定版の実際の入出力を用いてベータ版をテストすることが可能となる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
244 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
245 \item バージョン依存のプロトコル間で互換を持つようなプログラムが作成できる |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
246 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
247 異なるバージョン間でプロトコルに互換が無いプログラムを考える。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
248 バージョン間の互換を含めてメタ計算として定義し、全てのバージョンに対して互換を持つプログラムを構築する。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
249 そうすることによりどのバージョンのプロトコルとも互換を持つような変換器を作成できる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
250 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
251 \end{itemize} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
252 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
253 \item バージョン間の動作の比較 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
254 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
255 プログラムの各バージョンにつき、挙動を示すユニークなトレースが得られるとする。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
256 トレースの比較をすることでバージョン間の動作を比較することができる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
257 トレースの比較により以下のようなものを検出できると考えている。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
258 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
259 \begin{itemize} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
260 \item 過去のバージョンの挙動を破壊する時を検出する |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
261 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
262 プログラムの変更の際、トレースを変えてはいけない部分が存在するとする。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
263 変更の際にトレースが変更したことを検出することにより、トレースが保存される変更のみを受けつけるようにする。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
264 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
265 \item トレースが変化していないことを確認する |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
266 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
267 プログラムの変更にはいくつかの種類がある。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
268 例えば機能拡張の変更などであればトレースは変化するのが正しい。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
269 しかしリファクタリングではプログラムが変更されてもトレースが変わらないのが望ましい。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
270 トレース全体が変わらないような変更のみを受けつけることにより、リファクタリングを支援することができる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
271 \end{itemize} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
272 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
273 \item Version Control System との対応 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
274 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
275 全ての変更を保存し、任意のバージョンを生成可能であるようなメタ計算を考える。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
276 そうした時、プログラムの変更を蓄積するものは git や mercurial といった Version Control System の Repository に相当すると考えられる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
277 Delta により Repository を定義することがでるのならば、 branch や merge といった Version Control System の処理に対して形式的な定義を与えることができる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
278 また、 category における colimit と対応があると考えている。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
279 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
280 \item 変更単位を用いた処理 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
281 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
282 変更を適用する際に、特定の処理を実行することもできる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
283 例えばプログラムの変更単位に対してテストを行なうことで、変更に応じてテストの結果の変動が確認できる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
284 プログラム全体に対応するテストを定義し、変更の際にテストが通る変更のみ受け付けるようにすることでテストベースの信頼性を確保できる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
285 \end{itemize} |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
286 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
287 他にもプログラムの変更そのものを処理するプログラムを定義することもできる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
288 この機構を言語処理系に組込むことにより、プログラムの変更方法も言語の仕様に含めることができる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
289 例えば、プログラムの変更は許可されたオペレーション内で行なうといった制約を含めることが可能となる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
290 さらにユーザによりプログラムの変更に対するメタ計算を自由に定義できるような言語処理系を作るとする。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
291 その処理系ではこれまでに挙げた全てのメタ計算の例から使いたい機能を選んだり自分で追加することが可能となる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
292 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
293 このように、プログラムの変更を形式化することで多くのメタ計算が扱えるようになる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
294 さらに、メタ計算の内容によっては信頼性の向上に用いたり変更も含めた上でプログラムを作成することが可能になる。 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
295 |
d0d14c0a795b
Add examples of meta computation for program modification
Yasutaka Higa <e115763@ie.u-ryukyu.ac.jp>
parents:
30
diff
changeset
|
296 % }}} |