Program Composition Notation
PCN (Program Composition Notation)はK. Mani ChandyとStephen TaylorがStrandの設計者であるIan Fosterの協力を受けて設計した、複数のプログラムを並列環境や分散環境で組み合わせるためのプログラミング言語である[1]。それまでの並行論理プログラミング言語の技術要素に、手続型言語の変数や 概要PCN (Program Composition Notation)は並行論理プログラミングでのガードや論理変数による通信と同期の仕組みをそのまま流用しながら、通常の手続型言語であるC言語などの要素を取り入れたプログラミング言語である。言語の基本的な部分はIan FosterやStephen Taylorが設計したStrandの影響を大きく受けているが、その構文はC言語風の PCNの特徴は以下の通りである[2]。
プログラム例可変変数 m の内容がリスト x の要素であれば true(1) を、そうでなければ false(0) を返すプログラムの例を以下に示す。 member(x,m,r)
int m, r;
{? x ?= [] -> r:= false,
x ?= [vlxs], v == m -> r:= true,
x ?= [vlxs], v != m -> member(xs, m, r)
}
二分木(バイナリツリー)t の高さ z を求めるプログラムの例を以下に示す。ツリーの要素は {left, val, right} か空のタプルで表現されているものとする。各枝の深さは並行して計算され、定義変数 height(t,z)
{? t ?= { } -> z = 0,
t ?= {left, val, right} -> {|| height(left, l), height(right, r),
{? l >= r -> z = 1 + l,
r >= l -> z = 1 + r
}
}
}
関連項目参考文献
|
Portal di Ensiklopedia Dunia