Verification of Concurrent Programs Using the Coq Proof Assistant: A Case Study
-
- Affeldt Reynald
- Department of Computer Science, The University of Tokyo
-
- Kobayashi Naoki
- Department of Computer Science, Tokyo Institute of Technology
-
- Yonezawa Akinori
- Department of Computer Science, The University of Tokyo
書誌事項
- 公開日
- 2005
- DOI
-
- 10.2197/ipsjdc.1.117
- 公開者
- 一般社団法人 情報処理学会
この論文をさがす
説明
We show how to model and verify a concurrent program using the Coq proof assistant. The program in question is an existing mail server written in Java. The approach we take is to use an original library that provides a language for modeling, a logic, and lemmas for verification of concurrent programs. First, we report on the modeling of the mail server. Using the language provided by the library, we build a model by (1) translating the original program and (2) building appropriate abstractions to model its environment. Second, we report on the verification of a property of the mail server. We compare this library-based approach with an alternative approach that directly appeals to the Coq language and logic for modeling and specification. We show that the library-based approach has many advantages. In particular, non-functional aspects (communications, non-determinism, multi-threading) are handled directly by the library and therefore do not require complicated modeling. Also, the model can be directly run using existing compilers or virtual machines, thus providing us with a certified implementation of the mail server.
収録刊行物
-
- IPSJ Digital Courier
-
IPSJ Digital Courier 1 117-127, 2005
一般社団法人 情報処理学会
- Tweet
詳細情報 詳細情報について
-
- CRID
- 1390001205222792320
-
- NII論文ID
- 130000022400
-
- ISSN
- 13497456
-
- 本文言語コード
- en
-
- データソース種別
-
- JaLC
- Crossref
- CiNii Articles
- OpenAIRE
-
- 抄録ライセンスフラグ
- 使用不可
