Coq
Coqは証明支援システムの一つ。Coqの核はプログラミング言語Gallinaを用いる。フランス国立情報学自動制御研究所のPI.R2チーム(PPS研究所内にある)が、エコール・ポリテクニーク、フランス国立工芸院、パリ第7大学、パリ第11大学と(かつてリヨン高等師範学校とも)共同して開発している。Hugo Herbelinが事実上の開発代表者である。
Contents
特徴
CoqはCalculus of constructionsという高階型システム(Thierry CoquandとGérard Huetが1984年に創始したもので、英語ではCoCと略せてシステム名Coqに至る)に基づく。正しい証明は正しく型がつくラムダ式であるというカリー=ハワード同型対応を利用しているので、Coqの証明言語は型付きラムダ計算の一種である。1991年以降Coqが用いているCalculus of Constructionsの変種は、Christine Paulin-Mohringによるもので、帰納的構成を直接含み、Calculus of Inductive Constructions (CIC)という名前がついている。
Coqには
- 主張を操作する機能
- 主張の証明を機械的に検査する機能
- 形式的証明の探索を支援する機能
- 依存型を用いたプログラムを記述する機能
- 実行可能な検証済みプログラムを抽出する機能
がある。
加えてCoqには証明の自動化機能が増えている。中にはomegaタクティクというものがあり、プレスバーガー算術の大部分を決定できる。
Coqの最大の達成の中には、
- 四色定理: Georges GonthierとBenjamin Wernerによって、完全に機械化された証明が2004年に完了した。[1]
- CompCert: C言語のコンパイラで、Coqによって開発され証明がつき、2006年にリリースされた。[2]
- Feit-Thompson定理: Georges Gonthierと彼のグループによって、2012年9月に証明が完了した。[3]
がある。
CoqはGNU LGPLライセンスで配布されているフリーソフトウェアである。
Ssreflect拡張
Georges GonthierのチームがSsreflect(small scale reflectionの略)というCoqの拡張を開発している。拡張はreflection用の機能にとどまらず、Coqの多くのタクティクの改良版を提供する上に、証明の保守性を高めるコーディング慣習も含んでいる。 Ssreflectの機能には下のようなものがある。
- 保守性を高めるための機能
- Coqが自動生成した識別子をユーザが指定できなくなって、Coqのバージョンアップによって証明が通らなくなることを防止する機能
- 証明の枝を完結させることを明示して、軽微な証明を自動で行わせられる上に、証明が通らなくなったときに修正するべき範囲がわかりやすくなる機能
- 主張を直接証明する代わりに、Coq内で検証済みの判定機を実行するreflectionという技法に特化した証明タクティク
- 有限集合上の和や積などの大きな演算子を扱う機能
- 代数のライブラリ
SsreflectはCeCill-BとCecill-2.0でデュアルライセンスされていて、自由に利用できる。Ssreflectの最新版はCoq 8.4上で動く。[4]
脚注
関連項目
Coqの利用上の参考になりうる図書や文献
- 萩原 学、アフェルト・レナルド:「Coq/SSReflect/MathCompによる定理証明:フリーソフトではじめる数学]、 森北出版、ISBN 978-4627062412(2018年4月18日)。
外部リンク
- Coqプロジェクトのページ (英語)
- CoqのReference Manual (英語)