▲ このウインドウを閉じる |
When the cause is lost, there is enough of words. |
百足 ちつとは足でも歩いて見ろ。 さて、前回、僕は、「モデルと自然言語」について綴りましたが、いわゆる「基幹系システム」を対象にして、以下の2つの前提を置いています。
(1) 事業のなかで使われる文章情報を対象とする。
もし、この2つの前提を外せば、ほかの考えかたを前提にした公理系・技術が成立します。
どういう目的のために、どういう公理を前提にして、どのような体系 (あるいは、体系まで至らないけれど、いくつかの やりかた) を組んでいるか、という点を確認しなければ、2つの体系 (あるいは、やりかた) を対比するとき、(それぞれの体系が整合的であれば、) 対比は、「水掛け論 (talk past)」として終わってしまいます。
形式主義的公理主義が、自然の現象 (事態) に対して、すべからく適用できるかどうか、という点について、僕は、意見を提示するほどの数学的な知識はないのですが、少なくとも、モデル (あるいは、理論) は、いくつかの命題を前提にして、それらの命題のみを用いて作られるという前提に立てば、モデル (公理系) を検討するなら、目的と選ばれた公理を確認するのは当然でしょうね。モデルも1つの言語ゲームです。
(1) 目的関数 (公理系) 以上のような考え方ができる、というのは、論理的に考えることができるエンジニアの態度だと思うのですが、SQL のプログラムや Java のプログラムを作成できれば、関係モデルやオブジェクト主導を知っていると勘違いしている人たちが多いし、目的や公理を提示しないで、単なる作図技法をモデルと勘違いしている人たちも多いようです。 公理 (前提) と目的 (制約条件) を提示しなければ、モデル (公理系) の対比は、シロートの喧嘩のような「水掛け論」になるのは当然でしょうね。 「科学的である」ということが、対象の構成とか法則を探ることであり、エンジニアリングということが、(対象に対する) 機械仕掛けの構造を設計・作成する技術である、とすれば、モデル (公理系) を検討するなら、目的 (制約条件) を確認することは、エンジニアの態度として、当然のことでしょう。
かって、小生の「論理データベース論考」に対して、「詐欺である」という言い掛かりの読者カードが送られてきたことがあります。そして、「SQL などという醜悪な言語しか扱っていない」という非難が綴られていました。 なお、T字形 ER手法を使って作図したスキーマが、SQL 以外の言語に対して--あるいは、手続き型言語と表操作言語のほかの言語に対して--、有効かどうか、という点を、僕は検証していないので、なんとも、コメントができない (ただし、セット・アット・ア・タイム法とレコード・アット・ア・タイム法を前提にしている言語に対しては、T字形 ER手法のスキーマを使うことができるはずです)。T字形 ER手法は、関係モデルが前提にした公理 (関数従属性と包含従属性) に関して、「べつの定義を使えば--関数従属性に対して「null値」を認めないで、包含従属性に対して「並び (順序系列)」を考慮すれば--、べつの公理系を作ることができる」ことを示しただけです。 リレーショナル代数演算 (セット・アット・ア・タイム法) を前提にした SQL が「醜悪」かどうか、という点は僕には判断できないけれど、少なくとも、関係代数は、第1階述語論理を使った「関係完備 (relational complete)」が証明されているので、1つの公理系として、整合的です。整合的な公理系は「美しい」、と僕は思うのですが、SQL は、関係代数のほかの操作句 (group-by、average、countなど) も用意しているので、件の人は、それらを「醜悪」と言ったのかなあ、、、それとも、モデルの目的・前提・制約条件を考えることができなかったのかな(笑)。 「反コンピュータ的断章 (2004年1月7日付)」のなかで、「コンピュータ ソフトウェア事典を読む」ことを、お薦めしました。コンピュータ ソフトウェア事典を読めば、自らが専門にしている技術など、広大なコンピュータ・ソフトウェアの領域のなかでは、微々たる対象にすぎないことを理解できるでしょう。そうすれば、自らの技術が「最高」などと思う自惚れもなくなるでしょう。そして、自らは「一介のエンジニア」にすぎない、と思うのが正しい。ただし、技術 (人工的な言語ゲーム) の適用目的・前提・制約条件を考慮して、技術体系を、1つの言語ゲームとして、「科学的に考える」ことができるエンジニアである、と。
|
▼ このウインドウを閉じる |