annotate Paper/sugi-prosym.tex @ 6:5a5db338e71c

add mind map
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 19 Nov 2012 15:22:05 +0900
parents a48e22ceed00
children b04de6f70085 25a3002cb1e6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
1 \documentclass[private]{ipsjpapers}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
2 \usepackage{listings}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
3 % 巻数,号数などの設定
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
4 %\setcounter{巻数}{41}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
5 %\setcounter{号数}{6}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
6 %\setcounter{volpageoffset}{1234}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
7 %\受付{12}{2}{4}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
8 %\採録{12}{5}{11}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
9
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
10 % ユーザが定義したマクロなど.
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
11 \makeatletter
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
12 \let\@ARRAY\@array \def\@array{\def\<{\inhibitglue}\@ARRAY}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
13 \def\<{\(\langle\)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
14 \def\>{\(\rangle\)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
15 %\def\|{\verb|}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
16 \def\Underline{\setbox0\hbox\bgroup\let\\\endUnderline}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
17 \def\endUnderline{\vphantom{y}\egroup\smash{\underline{\box0}}\\}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
18 \def\LATEX{\iLATEX\Large}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
19 \def\LATEx{\iLATEX\normalsize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
20 \def\LATex{\iLATEX\small}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
21 \def\iLATEX#1{L\kern-.36em\raise.3ex\hbox{#1\bf A}\kern-.15em
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
22 T\kern-.1667em\lower.7ex\hbox{E}\kern-.125emX}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
23 \def\LATEXe{\ifx\LaTeXe\undefined \LaTeX 2e\else\LaTeXe\fi}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
24 \def\LATExe{\ifx\LaTeXe\undefined \iLATEX\scriptsize 2e\else\LaTeXe\fi}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
25 \def\Quote{\list{}{}\item[]}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
26 \let\endQuote\endlist
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
27 \def\TT{\if@LaTeX@e\tt\fi}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
28 \def\CS#1{\if@LaTeX@e\tt\expandafter\string\csname#1\endcsname\else
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
29 $\backslash$#1\fi}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
30
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
31 %\checklines % 行送りを確認する時に使用
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
32 \begin{document}%{
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
33 % 和文表題
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
34 \title[Code Segment と Data Segment によるプログラミング手法]%
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
35 {Code Segment と Data Segment によるプログラミング手法 }
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
36 % 英文表題
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
37 \etitle{How to Programming with Code Segment and Data Segment}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
38 % 所属ラベルの定義
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
39 \affilabel{URYUKYU}{琉球大学\\University of the Ryukyu}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
40 % 和文著者名
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
41 \author{河野 真治\affiref{URYUKYU}\member{19841765}\and
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
42 杉本 優\affiref{URYUKYU}\nomember}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
43
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
44
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
45 % 英文著者名
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
46 \eauthor{Shinji Kono\affiref{URYUKYU}\and
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
47 Yu Sugimoto\affiref{URYUKYU}}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
48
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
49
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
50 % 連絡先(投稿時に必要.製版用では無視される.)
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
51 \contact{杉本 優\\
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
52 〒903-0213 沖縄県中頭郡西原町字千原1番地\\
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
53 琉球大学 情報工学科\\
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
54 TEL: (098)895-8723\qquad FAX: (098)895-8727\\
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
55 email: sugi@cr.ie.u-ryukyu.ac.jp}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
56
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
57 % 和文概要
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
58 \begin{abstract}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
59 本研究室では分散プログラミングにおいて、データをData Segment、タスクをCode Segmentという単位に分割して記述する方法を提唱している。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
60 しかし、前述した方法をプログラマーが一から記述することは大変である。そこで、本研究室で分散ネットフレームワーク Alice を作成した。本論文では実際にAliceを用いてCode Segment と Data Segment によるプログラミング手法の例を示す。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
61 \end{abstract}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
62 % 英文概要
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
63 \begin{eabstract}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
64 \end{eabstract}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
65
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
66 % 表題などの出力
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
67 \maketitle
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
68
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
69 % }{
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
70
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
71 % 本文はここから始まる
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
72 \section{歴史的経緯}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
73 本研究室では、並列タスク管理フレームワークCeriumの管理を行なっているが、その設計と実装を行うにあたり、並列プログラミングと分散プログラミング
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
74 は本質的には同じことを行なっていることが分かった。特にヘテロジーニアスマルチコアであり、ローカルストアをそれぞれのコアが持っているというCell の特異な環境は、分散プログラミング環境と告示している。それらを踏まえて、Ceriumのタスク管理手法を分散に応用できないかと考えた。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
75
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
76
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
77 Ceriumに置いても、タスクとそれの入出力データの取り扱いは難しい課題である。データを操作するAPIを考えて、タスクを自然に記述し、効率良く実行する方法を考えてきた。そこで考えられた手法が、データをDataSegment、タスクをCodeSegmentという単位に分割して記述する方法である。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
78 % }{
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
79
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
80 \section{分散ネットフレームワークAlice}\label{sec:ITEM}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
81 \subsection{Aliceとは}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
82 Aliceは本研究室の卒業生である赤嶺一樹氏が、本研究室で開発を行なっている並列タスク管理フレームワーク Cerium と先行研究である Federated Linda の開発を通して得られた知見を生かされている。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
83 Federated Linda の設計はシングルスレッドで行われている。しかし、近年ではマルチコアのマシンが主流となっている。将来的にはメニーコアのマシンが主流になってくると考えられるそのような背景を踏まえてAliceはマルチスレッド向けに設計されている。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
84
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
85 AliceはData SegmentとCode Segmentという単位でデータと処理を細かく分割し、それぞれの依存関係を記述して分散プログラムを作成する。また、他のマシンとの接続トポロジーの構成の機能も有しているのでユーザーはトポロジー構成後の処理を記述するだけでよい。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
86 % }{
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
87 \subsection{Data Segment}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
88 AliceではData Semgnetをデータベースとして利用している。KeyValueStoreで実装されており、キーごとにリストを持っている。Data Segment APIを用いることで、リストにデータを追加、削除を適宜行うことができる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
89
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
90 \subsubsection{Data Segment Manager}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
91 大量のData Segmentを管理するのがData Segment Managerである。Data Segment Managerは文字列のキーでData Segmentを整理する。各キーごとにキュー構造を持っている。それらをData Segment APIを用いて操作する。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
92 データの読み出し("peek" または "take")時に、希望のデータがなかった場合、ブロッキングを行う機能を持つ。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
93 しかし、ブロッキングといってもそこで同期するわけではない。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
94 非同期でデータを通信する。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
95 そのため、 "peek" と "take" は他の API とは違い、レスポンスが発生する。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
96 \subsubsection{Data Segment API}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
97 表番号)が用意されているData Segment APIである。これらを用いてデータの送受信を行う。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
98 \begin{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
99 \item {\ttfamily void put(String key, Value val)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
100 \item {\ttfamily void update(String key, Value val)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
101 \item {\ttfamily void peek(Receiver receiver, String key, int id)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
102 \item {\ttfamily void take(Receiver receiver, String key, int id)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
103 \end{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
104
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
105 \subsubsection*{"put"}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
106 "put" はデータを追加するための API である。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
107
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
108 "put" は受け取ったデータ val を Data Segment 内のキューに対してエンキューする。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
109 この時、キーごとに重複しない連番の ID を受け取った順に振る。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
110
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
111 %(図 \ref{fig:put})
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
112 \subsubsection*{"update"}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
113 "update" はデータを置き換えるための API である。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
114
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
115 "update" はキューの先頭にあるデータをひとつだけ削除する。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
116 その後は "put" と同じく、 受け取ったデータ val を Data Segment 内のキューに対してエンキューする。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
117 この時、キーごとに重複しない連番の ID を受け取った順に振る。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
118 %(図 \ref{fig:update})
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
119 \subsubsection*{"peek"}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
120 "peek" はデータを読み込むための API である。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
121
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
122 "peek" は前回読み込んだデータの id を引数で指定する。省略した場合は、 0 が id として渡される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
123 id よりも値の大きい id のデータがキューに含まれていれば、そのデータを receiver に返す。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
124 もし id 以下のデータしか無いならば、データの更新が前回の "peek" 発行時から更新が無いものと考え、リストに格納されて保留される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
125 %(図 \ref{fig:peek})
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
126
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
127 "take" や "update" によりデータの更新があれば、 "peek" が直ちに実行される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
128 \subsubsection*{"take"}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
129 "take" もデータを読み込むための API である。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
130 基本的な id に関する部分は "peek" と同じである。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
131
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
132 "peek" との決定的な違いは、読み込まれたデータは Data Segment 内のキューから取り除かれるということである。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
133 %(図 \ref{fig:take})
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
134
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
135 %after
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
136 \lstset{
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
137 language={java},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
138 basicstyle={\small},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
139 identifierstyle={\small},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
140 commentstyle={\small\itshape},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
141 keywordstyle={\small\bfseries},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
142 ndkeywordstyle={\small},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
143 stringstyle={\small\ttfamily},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
144 frame={tb},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
145 breaklines=true,
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
146 columns=[l]{fullflexible},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
147 numbers=left,
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
148 xrightmargin=0zw,
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
149 xleftmargin=3zw,
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
150 numberstyle={\scriptsize},
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
151 stepnumber=1,
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
152 numbersep=1zw,
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
153 lineskip=-0.5ex
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
154 }
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
155
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
156
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
157
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
158 \subsection{Code Segment}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
159 Code Segmentはタスクのことである。Code Segmentをユーザーが記述するときに、Code Segment 内で使用するData Segment を記述し、依存関係を作る。依存関係により、実行される順番が一意に決まる。実際に使用するData Segment はCode Segmentの入出力に相当する。それぞれ、Input Data Segment、Output Data Segmentとする。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
160 \subsubsection{Code Segmentの実行方法}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
161 Code Semgnetを実行するためにはStart Code SegmentというCode Segmentを実行させる必要がある。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
162 Start Code SegmentはどのData Segmentにも依存しない。つまりInput Data Segmentを持たない。このCode Segmentをmainメソッド内でnewし、executeメソッドを呼ぶことで実行を開始させることができる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
163 \begin{table}[tb]
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
164 \lstinputlisting[label=StartCodeSegment, caption=StartCodeSegment]{source/StartCodeSegment.java}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
165 \end{table}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
166
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
167 \subsubsection{Code Segmentの記述方法}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
168 Code Segmentをユーザーが記述する際にはCodeSegmentを継承して記述する。そのCodeSegmentはInputDataSegmentManagerとOutputDataSegmentManagerを利用することができる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
169 \subsubsection*{InputDataSegmentManager}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
170 InputDataSegmentManagerはCode Segmentのidsというフィールドを用いてアクセスする。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
171 \begin{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
172 \item {\ttfamily Receiver create(CommandType type)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
173 \end{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
174 createでコマンドが実行された際に取得されるData Segmentが格納される受け皿を作る。引数にはCommandTypeが取られ、指定できるCommandTypeはPEEKまたはTAKEである。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
175 \begin{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
176 \item {\ttfamily void setKey(String managerKey, String key, int id)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
177 \end{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
178 setKeyメソッドにより、どこのData Segmentのあるkeyに対してpeekまたはtakeコマンドを実行させるかを指定することができる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
179 コマンドの結果がレスポンスとして届き次第Code Segmentは実行される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
180 \subsubsection*{OutputDataSegmentManager}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
181 OutputDataSegmentManagerはCode Segmentのodsというフィールドを用いてアクセスする。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
182 OutPutDataSegmentManagerは"put"または"update"を実行することができる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
183 \begin{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
184 \item {\ttfamily void put(String managerKey, String key, \\ Value val)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
185 \item {\ttfamily void update(String managerKey, String key, Value val)}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
186 \end{itemize}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
187
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
188 \subsection{Topology Manager}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
189 TopologyManagerはAlice同士の接続トポロジーを管理する。TopologyManager関連の通信処理はCode Segmentで実装してある。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
190 TopologyManagerはトポロジーファイルを読み込み、参加を表明したクライアント(以下、Topology Node)に接続するべきクライアントのIPアドレスやポート番号、接続名を送り、トポロジーファイルに記述された通りにトポロジーを作成する。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
191
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
192 \subsection{Topology Managerの設定ファイル}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
193 Topology Managerはトポロジーファイルを読み込むが、トポロジーファイル自体はDOT Languageという言語で記述される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
194 DOT Languageとはプレーンテキストを用いて、データ構造としてのグラフを表現するための、データ記述言語の一種である。このDOT Languageのグラフを利用して、クライアント間の接続を表現する。DOT Languageファイルはdotコマンドを用いて、グラフの画像ファイルを出力することができるので、記述したトポロジーが正しいことを可視化して確認することができる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
195
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
196 クライアント間の接続にはlabelを用いて名前が割り振られており、この接続名を用いてユーザーはData Segment Managerにアクセスすることができる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
197 前述したReceiver にsetKeyを行う際、odsでputまたはupdateする際の引数のmanagerKeyがこれにあたる。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
198
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
199 \subsection{Topology Managerの使用方法}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
200 Topology Nodeを起動する際にコマンドライン引数としてTopology ManagerのIPアドレスとポート番号を指定をする。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
201 そしてmain関数内でTopologyNodeをnewを行えば良い。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
202 TopologyNodeの第一引数は Alice デーモンの設定オブジェクト、第二引数はStart Code Segmentである。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
203 ここで指定した、Start Code Segmentがトポロジーが完成した後実行される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
204
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
205 % }{
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
206 \section{ゲームの例題}\label{sec:Enum}\label{sec:item}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
207 \subsection{水族館}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
208 今回作成した例題は水族館である。複数のクライアントのディスプレイを複数の魚が移動していくものである。魚は画面の端まで移動すると自分の画面上からは消え、別のクライアントの画面の端から魚が出てくる。また、魚のうち一匹はクライアントが直接操作することができる。トポロジーはTopologyManagerによりツリー状に構成してある。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
209 \subsection{データの伝搬}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
210
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
211 \begin{enumerate}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
212 \item ユーザーが魚を操作するまたはCode Segmentにより魚の座標が更新される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
213 \item 画面に表示させるためのSetLocation (Code Segment)が実行され実際に魚のオブジェクトにセットされ画面に反映される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
214 \item Update(Code Segment)にFishPosition(魚の座標データ)が渡される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
215 \item Updateにlist(送信者リスト)が渡される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
216 \item Updateが実行され、listを元にデータが送信される。ただし、この時にFishPositionには送信元情報が付加されているので、送信元には送信されない。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
217 \item 各clientで2 - 4が実行される。
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
218 \end{enumerate}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
219
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
220 \section{評価}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
221
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
222
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
223 \section{まとめと今後の課題}
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
224
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
225
5a5db338e71c add mind map
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 5
diff changeset
226 \end{document}