Coq
維基百科,自由的 encyclopedia
Coq 是一個交互式的定理證明輔助工具。它允許用戶輸入包含數學斷言的表達式、機械化地對這些斷言執行檢查、幫助構造形式化的證明、並從其形式化描述的構造性證明中提取出可驗證的(certified)程序。Coq 的理論基礎是歸納構造演算(calculus of inductive constructions)、一種構造演算(calculus of constructions)的衍生理論。Coq 並非一個自動化定理機器證明語言;然而,它提供了自動化定理證明的策略(tactics)和不同的決策過程。
編程範型 | 函數式編程 |
---|---|
面市時間 | 1989年5月1日,34年前(1989-05-01) (版本4.10) |
當前版本 |
|
型態系統 | 靜態類型,強類型 |
實作語言 | OCaml |
作業系統 | 跨平台 |
許可證 | LGPL 2.1 |
文件擴展名 | .v |
網站 | coq |
啟發語言 | |
ML(編程) LCF(證明方法) Automath(混合證明/編程) System F 和直覺類型論 | |
影響語言 | |
Agda,Idris, Matita, Albatross |
Coq 同時還是一個依賴類型的函數式程式語言[4]。它由法國PPS實驗室的PI.R2團隊研究開發[5],該團隊由INRIA、巴黎綜合理工學院、巴黎第十一大學、巴黎第七大學和法國國家科學研究中心組成。此前里昂高等師範學校亦曾參與開發。Coq 項目當前由 Gérard Huet(英語:Gérard Huet)、Christine 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 語言本身並非圖靈完全。