LINEスタンプ制作代行サービス・LINEスタンプの作り方!

お電話でのお問い合わせ:03-6869-8600

stampfactory大百科事典

Miranda

Mirandaは、遅延評価方式の純粋関数型プログラミング言語である。作者デビッド・ターナー(David Turner)による以前の言語SASLやKRCの後継でもあり、またMLやHopeの影響も受けている。イギリスのリサーチ・ソフトウェア社(Research Software Ltd.)が販売しており、同社の商標でもある。研究目的ではない商用を目指した最初の純粋関数型言語であった。よくある例題を解くプログラムに関して言えば、Mirandaのコードは(APLなどを別とすれば)ほとんどの主流のプログラミング言語よりも簡単で短く表現でき、他の関数型言語と同様、信頼性の高いプログラムの開発が命令型言語に比べて短期間で可能になったという報告がある。1985年に登場した。処理系の実装としてはUnix系向けのC言語で実装されたもののみがある。後発のHaskellは多くの面でMirandaの影響を受けている。Miranda は遅延評価の純粋関数型言語であり、副作用がなく、命令型プログラミング機能は存在しない。具象構文の最も大きい特徴としては、オフサイドルールを採用している。codice_1 からその行の終わりまでがコメントとして扱われる。別のコメント記法は「文芸的プログラミング」的なもので、行の先頭に codice_2 がない行は全てコメントとして扱われる。Miranda の基本データ型は codice_3、codice_4、codice_5 である。文字列は codice_3 のリストであり、codice_4 は内部的には2種類の形式があって、自動的に変換される(多倍長整数がデフォルトで使われ、必要に応じて浮動小数点数が使われる)。タプルは様々な型のデータの羅列であり、抽象的な観点からは直積型である。リストもある。角括弧で表され、各要素はカンマで区切られる。全要素は同じ型でなければならない。リストの連結は codice_8、差分は codice_9、要素追加は codice_10、サイズ(要素数)は codice_11、インデックス指定は codice_12 である。以下に使用例を挙げる。その他にもリスト構築のショートカットがある。codice_13 は要素が数列の場合に利用可能で、1 ずつ増加する数列以外も指定可能である。さらに強力なリスト構築機能として「リスト内包表記」(ZF記法とも呼ばれていた)があり、2種類の形式がある。式を項の列に適用する形式は以下のようになる。この意味は、n の自乗のリストで、n は全ての正の整数のリストから取られる。また、ある項がその1つ前の項の関数から得られる形式は以下のようになる。これは、2のべき乗のリストである。これらの例から分かるように、Miranda では無限のリストを表現可能である。たとえばごく単純な無限のリストの例として、全ての正の整数のリスト codice_14 がある。さらに(これはHaskellには無い機能のため、Mirandaの特色と言えるが)、codice_15 という記号を使う diagonalising list comprehensions(対角化リスト内包表記)により、codice_14 というような無限のリスト2つから、codice_17 というようなそれらを合成したリストを作ることができる(普通の内包表記で普通に作ろうとすると、片方のリストを辿り続けてしまい、もう片方のリストを辿ることをしないため、うまくできない)。codice_18 というように書く。関数への実引数の適用は codice_19 のように、単に関数に実引数を続ける。Miranda は他の純粋関数型言語と同様、関数を引数として他の関数に渡したり、関数の結果として関数を返したり、データ構造に要素として関数を含むといったことが可能である。また、関数は全て1引数にカリー化されているものと見ることもでき、実引数の数が足りていない適用は部分適用となる(注意: しばしば混同されるが、「カリー化」と「部分適用」は違うものである)。例えば次のようになる。この場合、codice_20 は自身の引数に 1 を加算する。実際、codice_21 は2つの引数をとる関数 codice_22 だが、これも実際には単一引数 codice_23 に 4 を加算する関数とも解釈できる。2つの引数をとる関数を中置演算子にすることができる。例えば、上記の codice_22 関数では、codice_25 という項を codice_26 演算子と同じように使うことができる。逆に2つの引数に作用する中置演算子を関数に変換することもできる。従って、次のようになる。これは、引数に 1 を足す関数を記述する一番単純な方法である。同様にといった単一引数関数を作成できる。この場合、インタプリタは除算のどちらの引数が関数の引数として供給されるのかを理解しており、引数を 2 で割る関数や 1 を引数で割る関数が得られる。Miranda は強い型付けをする言語だが、記述上は明確な型の宣言を必ずしも要しない。関数の型が明示されない場合、インタプリタは引数の型や引数の使われ方から型推論を行う。例えばリスト逆転関数などでは、基本データ型(codice_3, codice_4, codice_5)に加えて、引数の型を問題としない codice_30 型がある。これは、任意のデータ型のリストに適用可能である。これを明示的に関数型を宣言するなら、次のようになる。モジュール機構による名前空間の分離機構もある。モジュール外から内部の名前が見えないようにできる。以下の のスクリプトは、数の集合について、全ての部分集合を求める関数である。以下は文芸的な記法で、全ての素数のリストを与える関数 codice_31 を定義している。[[Category:関数型言語]][[Category:プログラミング言語]]

出典:wikipedia

LINEスタンプ制作に興味がある場合は、
下記よりスタンプファクトリーのホームページをご覧ください。