Coq 是一個交互式的定理證明輔助工具。它允許用戶輸入包含數學斷言的表達式、機械化地對這些斷言執行檢查、幫助構造形式化的證明、並從其形式化描述的構造性證明中提取出可驗證的(certified)程序。Coq 的理論基礎是歸納構造演算(calculus of inductive constructions)、一種構造演算(calculus of constructions)的衍生理論。Coq 並非一個自動化定理機器證明語言;然而,它提供了自動化定理證明的策略(tactics)和不同的決策過程。

Coq
編程範型函數式編程
面市時間1989年5月1日,​35年前​(1989-05-01 (版本4.10)
當前版本
  • 8.20.0(2024年9月3日;穩定版本)[1]
編輯維基數據鏈接
型態系統靜態類型強類型
實作語言OCaml
操作系統跨平台
許可證LGPL 2.1
文件擴展名.v
網站coq.inria.fr
啟發語言
ML(編程)
LCF(證明方法)
Automath(混合證明/編程)
System F直覺類型論
影響語言
AgdaIdris, Matita, Albatross
一個交互式定理證明的CoqIDE會話,左側為證明的腳本,右側顯示當前證明的狀態。

Coq 同時還是一個依賴類型函數式編程語言[4]。它由法國PPS實驗室的PI.R2團隊研究開發[5],該團隊由INRIA巴黎綜合理工學院巴黎第十一大學巴黎第七大學法國國家科學研究中心組成。此前里昂高等師範學校亦曾參與開發。Coq 項目當前由 Gérard Huet英語Gérard HuetChristine Paulin-Mohring英語Christine Paulin-Mohring 和 Hugo Herbelin領導。Coq 使用 OCaml 以及少部分 C 實現。

單詞 coq法語中意為「公雞」,此命名體現了法國在研究活動中使用動物名稱命名工具的傳統。[6] 最初,它被簡單地稱作 Coc,意即構造演算(calculus of constructions)的縮寫,同時也暗含了 Thierry Coquand(與 Gérard Huet 共同提出了前述的構造演算)的姓氏。

Coq 自身提供了一套規範語言 Gallina[7] (gallina 在西班牙語中意為「母雞」)。使用 Gallina 書寫的程序具有規範化性質——它們總是會終止。此性質使之避開了停機問題 [8]。同時,這也使得 Coq 語言本身並非圖靈完全

應用

編輯

引用

編輯
  1. ^ Release Coq 8.20.0. 2024年9月3日. 
  2. ^ Coq 8.12.2 is out. 2020-12-11 [2021-08-29]. (原始內容存檔於2022-03-23). 
  3. ^ Coq 8.13+beta1 is out. 2020-12-07 [2021-08-29]. (原始內容存檔於2022-04-07). 
  4. ^ A short introduction to Coq頁面存檔備份,存於網際網路檔案館).
  5. ^ PI.R2. [2014-01-23]. (原始內容存檔於2013-12-17). 
  6. ^ Coq Version 8.0 for the Clueless (174 Hints)頁面存檔備份,存於網際網路檔案館). Flint.cs.yale.edu. Retrieved on 2013-11-07.
  7. ^ Adam Chlipala. "Certified Programming with Dependent Types": "Library Universes"頁面存檔備份,存於網際網路檔案館).
  8. ^ Adam Chlipala. "Certified Programming with Dependent Types": "Library GeneralRec"頁面存檔備份,存於網際網路檔案館). "Library InductiveTypes"頁面存檔備份,存於網際網路檔案館).

外部連結

編輯