FP (プログラミング言語)
FP(Function Programming の略)は、ジョン・バッカスが関数型プログラミングパラダイムを支持するために創り出したプログラミング言語の1つである。名前が付けられた変数を排除することができる。本言語は、バッカスによる1977年チューリング賞受賞講演「プログラミングはフォン・ノイマン・スタイルから解放されうるか?: 関数型プログラミング・スタイルとそのプログラム代数」において発表された。同講演の内容に基づいて発表された論文[2]は、関数型プログラミングの研究への関心をかき立て[3]、結局はバッカスが期待していた関数レベルパラダイムではなく、モダンな関数型言語につながった。FPそれ自身は学術目的以外では決して使われなかった[4]。バッカスは1980年代に後継のプログラミング言語FLを創り出したが、それも研究プロジェクトの域を出なかった。 概要FPで書かれたプログラムがある別の値へと写像する値(value)は、列形式化(sequence formation)の下閉じている1個の集合(set)から構成される。 もし、x1, ..., xn が値であれば、列(sequence) 〈x1, ..., xn〉も値である。 これらの値は、真偽値、整数、実数、文字など任意のアトムの集合から組み立てることができる。
⊥は未定義/不定(undefined)の値であることを表し、ボトム(bottom)という。列はボトムの性質を保存する(bottom-preserving)。 〈x1, ..., ⊥, ..., xn〉 = ⊥ FPで書かれたプログラムは、ある単一の値xそれぞれを別の値に写像する関数 (function) fである。関数fを値xに作用させた結果を f:x と表現する。 関数は、原始的、すなわち、FP 環境において提供されるか、またはプログラム形式化演算(program-forming operation(関数形式functional formとも呼ばれる))から構築されたか、である。 原始的関数の一例に定数関数(constant)があり、これはある値xをに変換する。関数は正格である。 f:⊥ = ⊥ 別の例にセレクタ(selector)関数ファミリがある。ここで、1, 2, ... は、
を意味する。 関数形式原始的関数とは対照的に、関数形式は他の関数に基づいて演算を行う。たとえば、加算 として0を、乗算 として1をとるような単元(unit value)を持つ関数もある。関数形式unitは次のいずれかである関数 fに適用される際にそのような値を生成する。
以下はFPの中核となる関数形式である。
方程式型関数関数形式により原始的関数から構築されているものに加え、関数はある方程式により再帰的に定義されることもできる。もっとも単純なものは次のものである。 f ≡ Ef ここで Ef は、関数形式を用いて、原始的関数、他の定義済関数および関数記号 f それ自身から構築された1個の式である。 脚注
外部リンク |
Portal di Ensiklopedia Dunia