[BACK]Return to communication-model.tex CVS log [TXT][DIR] Up to [local] / OpenXM / doc / OpenXM-specs

Diff for /OpenXM/doc/OpenXM-specs/communication-model.tex between version 1.5 and 1.6

version 1.5, 2000/01/21 08:44:54 version 1.6, 2000/01/24 02:48:24
Line 1 
Line 1 
 %% $OpenXM: OpenXM/doc/OpenXM-specs/communication-model.tex,v 1.4 2000/01/21 06:24:49 noro Exp $  %% $OpenXM: OpenXM/doc/OpenXM-specs/communication-model.tex,v 1.5 2000/01/21 08:44:54 noro Exp $
 //&jp \section{ Open XM の通信モデル}  //&jp \section{ OpenXM の通信モデル}
 //&eg \section{ Communication model of Open XM}  (This part has not yet been translated)  //&eg \section{ Communication model of OpenXM}
   
 /*&jp  /*&jp
 われわれは, 数学プロセスがメッセージを  われわれは, 数学プロセスがメッセージを
Line 22 
Line 22 
 メッセージは論理的に次のような構造をもつ:  メッセージは論理的に次のような構造をもつ:
 */  */
 /*&eg  /*&eg
 In our model of comutation, mathematical processes proceed  In our model of computation, mathematical processes proceed
 a computation by exchanging messages. Each process is a stack machine,  a computation by exchanging messages. Each process is a stack machine,
 which is called an OX stack machine.  which is called an OX stack machine.
 The following methods are possible to realize communications between  The following methods are possible to realize communications between
Line 32  mathematical processes.
Line 32  mathematical processes.
 \item Linking as a subroutine library.  \item Linking as a subroutine library.
 \item TCP/IP streams.  \item TCP/IP streams.
 \item Remote Procedure call.  \item Remote Procedure call.
 \item Muitithread.  \item Multi-thread.
 \item PVM library.  \item PVM library.
 \item MPI library.  \item MPI library.
 \end{enumerate}  \end{enumerate}
   
 In OpenXM Communication is exechange of messages between processes.  In OpenXM communication means exchange of messages between processes.
 A message has the following structure:  A message has the following structure:
 */  */
 /*&C  /*&C
Line 51  A message has the following structure:
Line 51  A message has the following structure:
 \end{center}  \end{center}
 */  */
 /*&jp  /*&jp
 このメッセージを, OX Message (Open XM message object) とよぶ.  このメッセージを, OX message (OpenXM message object) とよぶ.
 OX Message はトップレベルのメッセージ object であり,  OX Message はトップレベルのメッセージ object であり,
 仕様書では, さまざまなグループに属する object が登場する.  仕様書では, さまざまなグループに属する object が登場する.
 グループ名は, たとえば, OX Message/TCPIP/Basic0 などと書く.  グループ名は, たとえば, OX Message/TCPIP/Primitive などと書く.
 {\tt message\_body} の部分の仕様は, OX Message  {\tt message\_body} の部分の仕様は, OX Message
 の上位に位置する部分であり,  SMobject または CMObject がくる.  の上位に位置する部分であり,  SMobject または CMObject がくる.
 これらの object はタグをもち, そのタグ定数は {\tt SM\_} または  これらの object はタグをもち, そのタグ定数は {\tt SM\_} または
Line 62  OX Message はトップレベルのメッセージ object であり,
Line 62  OX Message はトップレベルのメッセージ object であり,
 SMobject は, スタックマシンコマンドメッセージ object であり,  SMobject は, スタックマシンコマンドメッセージ object であり,
 やはり, グループ分けされている.  やはり, グループ分けされている.
 各グループ名は,  各グループ名は,
 SMobject/Basic0,  SMobject/Basic1 などと書く.  SMobject/Primitive,  SMobject/Basic などと書く.
 SMobject の構造は  SMobject の構造は
 サーバスタックマシンの節で詳しく説明する.  サーバスタックマシンの節で詳しく説明する.
 CMObject についてはすでに Basic0 の CMObject の説明をしたが,  CMObject についてはすでに Primitive の CMObject の説明をしたが,
 あとで CMObject レベル 1の説明をする.  あとで CMObject レベル 1の説明をする.
 OX Message の  OX Message の
 {\tt ox message\_tag} の定数は {\tt OX\_} で始まる.  {\tt ox message\_tag} の定数は {\tt OX\_} で始まる.
 */  */
 /*&eg  /*&eg
 We call it an OX message (OpenXM message object).  We call it an OX message (OpenXM message object).
 OX Message is the top level message object.  OX message is the top level message object.
 The OX messages are classified into three types: DATA, COMMAND,  The OX messages are classified into three types: DATA, COMMAND,
 and SPECIAL. They are distinguished by {\tt ox message\_tag}.  and SPECIAL. They are distinguished by {\tt ox message\_tag}.
 The name of an ox message tag begins with  {\tt OX\_}.  The name of an ox message tag begins with  {\tt OX\_}.
 Typical OX message tags are {\tt OX\_COMMAND} followed by  Typical OX message tags are {\tt OX\_COMMAND} followed by
 SMobject and {\tt OX\_DATA} followed by CMOobject.  SMobject and {\tt OX\_DATA} followed by CMObject.
 Each message object also has its tag. For SMobject, the name  Each message object also has its tag. For SMobject, the name
 of a tag begins with {\tt SM\_}. For CMOobject, the name of  of a tag begins with {\tt SM\_}. For CMObject, the name of
 a tag begins with {\tt CMO\_}.  a tag begins with {\tt CMO\_}.
 An SMobject represents a stack machine command and categorized  An SMobject represents a stack machine command and categorized
 into several groups such as SMobject/Basic0, SMobject/Basic1.  into several groups such as SMobject/Primitive, SMobject/Basic.
 The details of SMobjects will be explained in Section \ref{sec:stackmachine}.  The details of SMobjects will be explained in Section \ref{sec:stackmachine}.
 We have already explained the Basic0 CMOobjects.  We have already explained the Primitive CMObjects.
 We will describe the Basic1 CMOobjects later.  We will describe the Basic CMObjects in Section \ref{sec:basic1}.
 */  */
 //&jp \subsection{  OX Message の 表現方法 }  //&jp \subsection{  OX Message の 表現方法 }
 //&eg \subsection{  OX Messages }  //&eg \subsection{  OX Messages }
   
 /*&jp  /*&jp
 Open XM で各プロセスは  OpenXM で各プロセスは
 \begin{center}  \begin{center}
 (OXexpression を理解するスタックマシン) $+$ (xxx 言語で動くエンジン)  (OXexpression を理解するスタックマシン) $+$ (xxx 言語で動くエンジン)
 \end{center}  \end{center}
Line 106  SMobject を スタックマシンオペレータともよぶ.
Line 106  SMobject を スタックマシンオペレータともよぶ.
 */  */
   
 /*&eg  /*&eg
 In Open XM, each process may have a hybrid interface;  In OpenXM, each process may have a hybrid interface;
 it may accept and execute not only stack machine commands,  it may accept and execute not only stack machine commands,
 but also its original command sequences.  but also its original command sequences.
 We call such a process an OX stack machine.  We call such a process an OX stack machine.
Line 141  From AAA, To BBB, を OXexpression の前に書く.
Line 141  From AAA, To BBB, を OXexpression の前に書く.
 */  */
   
 /*&eg  /*&eg
 A comman `{\tt ,}' may be used to separate elements in an expression.  A comma `{\tt ,}' may be used to separate elements in an expression.
 {\tt OX\_tag} is a constant which denotes an OX message tag.  {\tt OX\_tag} is a constant which denotes an OX message tag.
 {\tt SM\_tag} is a constant which denotes an SM command tag.  {\tt SM\_tag} is a constant which denotes an SM command tag.
 If a sender AAA or a receiver BBB has to be specified,  If a sender AAA or a receiver BBB has to be specified,
Line 157  push a CMO string ``Hello''.
Line 157  push a CMO string ``Hello''.
 */  */
   
   
 /*&jp  /*&eg
 The following expression means a request to execute  The following expression means a request to execute
 a local function ``hoge''.  a local function ``hoge''.
 */  */
Line 177  a 32 bit (4 byte) integer with the network byte order.
Line 177  a 32 bit (4 byte) integer with the network byte order.
 */  */
   
 //&jp \subsection{OXexpression の 標準 encoding と TCP/IP ソケットによる実装法}  //&jp \subsection{OXexpression の 標準 encoding と TCP/IP ソケットによる実装法}
 //&eg \subsection{Standard enconding of OXexpressions and an implementation by TCP/IP sockets}  //&eg \subsection{Standard encoding of OXexpressions and an implementation by TCP/IP sockets}
 /*&jp  /*&jp
 通信の実現方法は通信路のとりかたによりかわるが,  通信の実現方法は通信路のとりかたによりかわるが,
 論理構造は統一的にあつかわないといけない.  論理構造は統一的にあつかわないといけない.
Line 231  Thus OX messages are represented as follows.
Line 231  Thus OX messages are represented as follows.
 \end{tabular}  \end{tabular}
 \end{center}  \end{center}
 */  */
 //&jp が, もっとこまかく見ると,  //&jp \noindent が, もっとこまかく見ると,
 //&eg More precisely it has the following representation.  //&eg \noindent More precisely it has the following representation.
 /*&C  /*&C
 \begin{center}  \begin{center}
 \begin{tabular}{|c|c|}  \begin{tabular}{|c|c|}
 \hline  \hline
 {\tt ox message\_tag}, \ {\tt packet number}&{\tt message\_body} \\  {\tt ox message\_tag}, \ {\tt serial number}&{\tt message\_body} \\
 \hline  \hline
 \end{tabular}  \end{tabular}
 \end{center}  \end{center}
 */  */
 /*&jp  /*&jp
   \noindent
 となっている.  となっている.
   
 グループ OX Message/TCPIP/Basic0 の  グループ OX Message/TCPIP/Primitive の
 {\tt ox message\_tag} としては次のものが用意されている.  {\tt ox message\_tag} としては次のものが用意されている.
 */  */
 //&eg As {\tt ox message\_tag} the following are provided.  //&eg \noindent As {\tt ox message\_tag} the following are provided.
   
 /*&C  /*&C
 @plugin/oxMessageTag.h  @plugin/oxMessageTag.h
Line 287  Thus OX messages are represented as follows.
Line 288  Thus OX messages are represented as follows.
 \verb+ OX_COMMAND + メッセージは次の形のパケットで表現される: \\  \verb+ OX_COMMAND + メッセージは次の形のパケットで表現される: \\
 */  */
 /*&eg  /*&eg
 Two streams are used for communication between a client and a server.  Two streams are provided for communication between a client and a server.
 One is the stream to exchange data and to send stack machine commands.  One is the stream to exchange data and to send stack machine commands.
 The other is the stream to control stack machines.  The other is the stream to control stack machines.
 Messages on the latter stream are called control messages and  Messages on the latter stream are called control messages and
Line 297  the above two streams by using two ports on TCP/IP.
Line 298  the above two streams by using two ports on TCP/IP.
 The stack machine command message has the following forms: \\  The stack machine command message has the following forms: \\
 */  */
 /*&C  /*&C
   \noindent
 \begin{tabular}{|c|c|}  \begin{tabular}{|c|c|}
 \hline  \hline
 {\tt OX\_COMMAND} & {\tt int32 function\_id} \\  \hline  {\tt OX\_COMMAND} & {\tt int32 function\_id} \\  \hline
Line 338  debugging threads, or to exit form the debugging mode.
Line 340  debugging threads, or to exit form the debugging mode.
 */  */
   
 //&jp コントロールメッセージの結果メッセージは次の形のパケットで表現される: \\  //&jp コントロールメッセージの結果メッセージは次の形のパケットで表現される: \\
 //&eg The result of a cotrol message has the following form:\\  //&eg The result of a control message has the following form:\\
 /*&C  /*&C
 \begin{tabular}{|c|c|l|}  \begin{tabular}{|c|c|l|}
 \hline  \hline
Line 352  debugging threads, or to exit form the debugging mode.
Line 354  debugging threads, or to exit form the debugging mode.
 /*&jp  /*&jp
 {\tt int32 function\_id}  {\tt int32 function\_id}
 の部分に, サーバスタックマシン の operator に対応する番号がはいる.  の部分に, サーバスタックマシン の operator に対応する番号がはいる.
 グループ SMobject/Basic0 および SMobject/Basic1 に属する  グループ SMobject/Primitive および SMobject/Basic に属する
 タグとして以下のものがある.  タグとして以下のものがある.
 */  */
 /*&eg  /*&eg
 {\tt int32 function\_id} is the value of a stack machine command.  {\tt int32 function\_id} is the value of a stack machine command.
 SM tags in SMobject/Basic0 and SMobject/Basic1 and corresponding  SM tags in SMobject/Primitive and SMobject/Basic and corresponding
 values are as follows.  values are as follows.
 */  */
 /*&C  /*&C
Line 387  values are as follows.
Line 389  values are as follows.
 \end{verbatim}  \end{verbatim}
 */  */
   
 //&jp たとえば,  //&jp \noindent たとえば,
 //&eg For example  //&eg \noindent For example
 /*&C  /*&C
 \begin{center}  \begin{center}
 (OX\_COMMAND, SM\_pops)  (OX\_COMMAND, SM\_pops)
 \end{center}  \end{center}
 */  */
 //&jp は  //&jp \noindent は
 //&eg is encoded as follows.  //&eg \noindent is encoded as follows.
 /*&C  /*&C
 \begin{center}  \begin{center}
 \begin{tabular}{|c|c|}  \begin{tabular}{|c|c|}
Line 412  operator の詳細は次の節で説明する.
Line 414  operator の詳細は次の節で説明する.
 これらの定数の名前はインプリメントのとき短縮形で表現してもよい.  これらの定数の名前はインプリメントのとき短縮形で表現してもよい.
 */  */
 /*&eg  /*&eg
 The details of the operators are described in Section \ref{sec:stackmanine}.  The details of the operators are described in Section \ref{sec:stackmachine}.
 Names of these constants may be represented by abbreviated forms.  Names of these constants may be represented by abbreviated forms.
 */  */
   

Legend:
Removed from v.1.5  
changed lines
  Added in v.1.6

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>