annotate presen/slide.md @ 16:11058e51adb7

update
author mir3636
date Wed, 15 Feb 2017 23:00:11 +0900
parents 1ba7fa1773d9
children 981020cb97ae
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10
mir3636
parents:
diff changeset
1 title: CbC 言語による OS 記述
mir3636
parents:
diff changeset
2 author: Mitsuki Miyagi
mir3636
parents:
diff changeset
3 profile:
mir3636
parents:
diff changeset
4 lang: Japanese
mir3636
parents:
diff changeset
5 code-engine: coderay
mir3636
parents:
diff changeset
6
mir3636
parents:
diff changeset
7 # メタ計算の重要性
15
mir3636
parents: 10
diff changeset
8 - プログラムを記述する際、通常の処理の他に、メモリ管理やスレッド管理、CPU や GPU の資源管理等、記述しなければならない処理が存在する。これらの計算を Meta Computation と呼ぶ。
mir3636
parents: 10
diff changeset
9 - Meta Computation を通常の計算から切り離して記述す るためには処理を細かく分割する必要がある。しかし、関 数やクラスなどの単位は容易に分割できない。
mir3636
parents: 10
diff changeset
10 - そこで当研究室では Meta Computation を柔軟に記述 するためのプログラミング言語の単位として Code Gear、 Data Gear という単位を提案している。
10
mir3636
parents:
diff changeset
11
15
mir3636
parents: 10
diff changeset
12 # Code Gear と Data Gear
mir3636
parents: 10
diff changeset
13 - Code Gear は関数に比べて細かく分割されているので Meta Computation をより柔軟に記述できる。
mir3636
parents: 10
diff changeset
14 - Data Gear はデータの単位であり、Code Gear は 任意の数の Input Data Gear を参照して処理を行い、Output Data Gear を出力し処理を終える。
10
mir3636
parents:
diff changeset
15
15
mir3636
parents: 10
diff changeset
16 # Continuation based C (CbC)
mir3636
parents: 10
diff changeset
17 - Continuation based C (CbC) はこの Code Gear 単位を 用いたプログラミング言語として開発している。
mir3636
parents: 10
diff changeset
18 - Code Gear から 次の Code Gear へと goto による継続で遷移で処理を行い、引数として出力を与える。
10
mir3636
parents:
diff changeset
19
16
mir3636
parents: 15
diff changeset
20 # Gears OS
mir3636
parents: 15
diff changeset
21 - Gears OS では並列実行するための Task を、実行する Code Gear 、実行に必要な Input Data Gear 、Output Data Gear の組で表現する。
mir3636
parents: 15
diff changeset
22 - またGears OS では Meta Computation を Meta Code Gear、Meta Data Gear で表現する。
mir3636
parents: 15
diff changeset
23 - Meta Code Gear は通常の Code Gear の直後に遷移され、Meta Computation を実行する。
mir3636
parents: 15
diff changeset
24 - Meta Code Gear で OS の 機能であるメモリ管理やスレッド管理を行う。
10
mir3636
parents:
diff changeset
25
16
mir3636
parents: 15
diff changeset
26 # Context
mir3636
parents: 15
diff changeset
27 - Gears OS では Context と呼ばれる接続可能な Code/Data Gear のリスト、Temporal Data Gear のためのメモリ空間等を持っている Meta Data Gear がある。
mir3636
parents: 15
diff changeset
28 - Gears OSは必要なCode/DataGearに参照したい場合、このContext を通す必要がある。
10
mir3636
parents:
diff changeset
29
16
mir3636
parents: 15
diff changeset
30 # stub Code Gear
mir3636
parents: 15
diff changeset
31 - しかし、Context を直接扱うのはセキュリティ上好ましくない。
mir3636
parents: 15
diff changeset
32 - そこで Context から必要なデータを取り出して Code Gear に接続する stub Code Gear を定義し、これを介して間接的に必要な Data Gear にアクセスする。
10
mir3636
parents:
diff changeset
33
16
mir3636
parents: 15
diff changeset
34 # Gearef、GearImpl
mir3636
parents: 15
diff changeset
35 - Context には Allocation 等で生成した Data Gear へのポインタが格納されている。
mir3636
parents: 15
diff changeset
36 -