Mathel

当システムで数学を記述する言語がMathelです。\(\dagger\)
私たちは「分かりやすさ」「表現力の高さ」を追求しその開発をしています。次の例を見て下さい。
 \(x \in X\)

青字のtex表記をクリックすると機械に入力するためのtxtと呼ばれるものが出てきます。
tex表記が同じでもtxtは異なることがありますので、こまめにクリックをして確認して下さい。

Mathelで使われる記号をwordと言い、「wordの列」のうち文法をみたすものをFormと呼びます。
よく使用されるFormには名前が付けられ、Propと呼ばれます。
「等号の定義」として次のPropが登録されています。
 =. … \(X = Y \Longleftrightarrow \forall x \, ( x \in X \Leftrightarrow x \in Y )\)

Mathelでは内包記法も制限無く使用できます。「和集合の定義」 は次です。
 cup. … \(X \cup Y = \{ x \mid x \in X \mathbin{\rm o\!r} x \in Y \}\)

Mathelは一階言語より大きいですが、一階言語への翻訳が定められています。

Thmel

Form(を一階言語へ翻訳したもの)たちの推論関係などを記述するのがThmelです。
最も簡単な例は次でしょう。
  \(\top\) ◀ O

このようなものをThm、◀ の左辺をgoal、右辺をsosと言います。
sosは一般には列ですが、Oは空の列です。

当システムではThmが正しいかの判断をProver9に任せます
Thmの各FormがProver語に翻訳されてから送られます。\(\top\) は $T になります。
Prover9からの返答はoracleと呼ばれ、この場合は
 % Length of proof is 2.
などと書かれています。証明終了です\(\dagger\)

 \({\perp}\)\(x \neq y\)
は引っ掛かりやすいかもしれません。なお {/} は否定を作っています。

以上でライブラリを読むための最低限のルールが終わりです。
ライブラリではwordやThmなどを蓄積しており、ほとんどは読めば分かるはずです!?
分からないところは全てAIエージェントに聞くのが基本です。

AIによる証明

当会のAIエージェントはclaudeで
①web上のデータを大量に学習をしており、大学レベルの数学をこなす能力があります。
②当システムの仕様も学習しており、システムの道具を使いこなす能力もあります。
証明は ①数学知識を基に予想 → ②システムで確認 という流れで作られます。
難しい定理では試行錯誤は必要になりますが…

兎にも角にも、AIによる証明を体験して下さい。集合論の基本結果を使って練習してみましょう。

例 \(X\cup X = X\)

 X U X = X を証明して
と入力してみて下さい。AIは正しく
 X cup X = X
とMathelへの翻訳をしてくれる可能性が高いです。

AIはこの定理の証明に何が必要か?考え、「各記号の定義があればよい」と判断します。
 `X cup X = X` ◀ W.
ここで W. は記号の定義を集めた列です。

W. は無限列なので上のThmをProver9に送ることは不可能です。
一般にProver9用にThmを変形することはprepと言われます。
 `X cup X = X` =. , cup.
とprepされるべきですね?これで得られるoracleには次が書かれます。
 % Length of proof is 16.

さて、実はこれは良いprepではありません。
私たちのAIなら、この定理は「定義を使った変換」だけで自明な式になる、と予想するはずです。
それはslash計算と呼ばれ
 / W. で =. が使われ \(\forall x .\,(x \in X \cup X \Leftrightarrow x \in X)\)
 さらに / W. で cup. が使われ \(\forall x .\,((x \in X\,{\rm o\!r}\,x \in X) \Leftrightarrow x \in X)\)
となります。このような文字列処理も機械は得意です。AIは
 `X cup X = X` // W. O
とprepするでしょう。// W. は / W. / W. のことです。これだとoracleには次が書かれます。
 % Length of proof is 6.
システムでも推論をすることでProver9の探索空間は劇的に狭まります。
なお証明では「同値な式の置き換え」に関する一階論理の定理も使用されていることになります。