annotate tex/cbc.tex @ 8:27a6616b6683

fix
author soto@cr.ie.u-ryukyu.ac.jp
date Mon, 14 Sep 2020 19:58:10 +0900
parents b124f02ea3f1
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
1 \section{Continuation based C}
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
2 CbC とはC言語からループ制御構造とサブルーチンコールを取り除き、
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
3 継続を導入したC言語の下位言語である。継続呼び出しは引数付き goto 文で表現される。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
4 また、CodeGear を処理の単位、DataGear をデータの単位として記述するプログラミング言語である。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
5 CbC のプログラミングでは DataGear を CodeGear で変更し、その変更を次の CodeGear に渡して処理を行う。
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
6
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
7 \subsection{Code Gear / Data Gear}
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
8 CbCでは、検証しやすいプログラムの単位として DataGear と CodeGear という単位を用いる。
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
9
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
10 CodeGear はプログラムの処理そのものであり、一般的なプログラム言語における関数と同じ役割である。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
11 DataGear は CodeGear で扱うデータの単位であり、処理に必要なデータである。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
12 CodeGear の入力となる DataGear を Input DataGear と呼び、出力は Output DataGear と呼ぶ。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
13
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
14 CodeGear 間の移動は継続を用いて行われる。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
15 継続は関数呼び出しとは異なり、呼び出した後に元のコードに戻れず、次の CodeGear へ継続を行う。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
16 これは、関数型プログラミングでは末尾再帰をしていることと同義である。
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
17
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
18
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
19 \subsection{Meta Code Gear / Meta Data Gear}
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
20 プログラムの記述する際は、ノーマルレベルの計算の他に、メモリ管理、スレッド管理、
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
21 資源管理等を記述しなければならない処理が存在する。これらの処理をメタ計算と呼ぶ。
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
22
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
23 メタ計算は OS の機能を通して処理することが多く、信頼性の高い記述が求められる。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
24 そのため、 CbC ではメタ計算を分離するために Meta CodeGear、 Meta DataGear を定義している。
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
25
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
26 Meta CodeGear は CbC 上でのメタ計算で、通常の CodeGear を実行する際に必要なメタ計算を分離するための単位である。
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
27 CodeGear を実行する前後やDataGear の大枠として Meta Gear が存在している。
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
28
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
29 Meta DataGear は CbC 上のメタ計算で扱われる DataGear である。例えば stub
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
30 CodeGear では Context と呼ばれる接続可能な CodeGear、DataGear のリストや、DataGear
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
31 のメモリ空間等を持った Meta DataGear を扱っている。
3
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
32
b124f02ea3f1 post agda code
soto@cr.ie.u-ryukyu.ac.jp
parents:
diff changeset
33
8
soto@cr.ie.u-ryukyu.ac.jp
parents: 3
diff changeset
34