D23 Improvements to Existing Provers: Difference between revisions

From Event-B
Jump to navigationJump to search
imported>Pascal
imported>Laurent
 
(4 intermediate revisions by 2 users not shown)
Line 20: Line 20:
= Motivations =
= Motivations =


Areas of improvement for provers can be summarized as follows:
The motivations for improvements to existing provers can be summarized as follows:
* Reducing proving time and effort.
* Reducing proving time and effort.
: New proof rules.
: New proof rules, both manual and automatic (e.g.., [http://www.cs.cmu.edu/afs/cs/academic/class/15671-f95/www/handouts/proof/node1.html One point rule], arithmetic rules), have been added to discharge more proof obligations more easily.
* Reflecting prover implementation corrections.
* Reflecting corrections in prover implementations.
: Reasoner versioning.
: The [http://wiki.event-b.org/index.php/Versioned_Reasoners reasoners] are versioned. A reasoner implementation may indeed evolve in time (bug fixes, modifications of the behaviour, etc), even after the old implementation has been used to prove a model. This may lead to potential issues when trying to reuse or replay proofs serialized by the old reasoner implementation. Such problems are solved through the reasoner versioning mechanism.  
* Reducing proof storage space.
* Reducing proof storage space.
: Proof purging.
: Big proof files are difficult to handle, on the one hand by the Rodin platform (slow access), and on the other hand by users (project sharing).
: Proof simplifying.
: The [http://wiki.event-b.org/index.php/Proof_Purger_Interface proof purging] and [http://wiki.event-b.org/index.php/Proof_Simplification proof simplifying] mechanisms have been implemented to address this issue.
* Facilitating manual proof review or reuse.
* Facilitating manual proof review or reuse.
: Proof skeleton view.
: The [http://wiki.event-b.org/index.php/Proof_Skeleton_View proof skeleton view] allows to quickly browse through a proof. : Moreover, the provided copy/paste feature makes it possible to reuse a stored proof into a new proof.
: Copy / paste of partial proofs.
* Improving prover API.
* Prover API evolution.
: The [http://wiki.event-b.org/index.php/New_Tactic_Providers tactic provider API] has been made more flexible to facilitate tactic contributions.
: New tactic provider API.


= Choices / Decisions =
= Choices / Decisions =
Line 79: Line 78:


In the third year of DEPLOY, most effort in the proving area will be put into:
In the third year of DEPLOY, most effort in the proving area will be put into:
: better management of well-definedness conditions,
: - Better management of well-definedness conditions.
: improvement to the rule based prover,
: - Improvement to the rule based prover.
: bridging the gap with external SMT solvers,
: - Bridging the gap with external SMT solvers.
: supporting mathematical extensions in proofs.
: - Supporting mathematical extensions in proofs.


[[Category:D23 Deliverable]]
[[Category:D23 Deliverable]]

Latest revision as of 11:41, 27 January 2010

Overview

Proving is at the core of the Rodin methodology. Therefore, it was no surprise that both industrial and academic users reported a lot of feedback on this topic. This feedback was provided either by mail or though the SourceForge trackers.

Based on this feedback, several actions were taken to improve the existing tooling for both automated and interactive proving. Some consisted in improving existing tools, while others needed a full design and development of new tools (especially for visualizing and managing proofs). Finally, an extension of the proving framework API as been realised to allow for the development of new plug-ins (such as the rule based prover).

Systerel has been in charge of existing prover improvements, with support from ETH Zurich. The evolution of the API has been designed in close collaboration with University of Southampton.


Motivations

The motivations for improvements to existing provers can be summarized as follows:

  • Reducing proving time and effort.
New proof rules, both manual and automatic (e.g.., One point rule, arithmetic rules), have been added to discharge more proof obligations more easily.
  • Reflecting corrections in prover implementations.
The reasoners are versioned. A reasoner implementation may indeed evolve in time (bug fixes, modifications of the behaviour, etc), even after the old implementation has been used to prove a model. This may lead to potential issues when trying to reuse or replay proofs serialized by the old reasoner implementation. Such problems are solved through the reasoner versioning mechanism.
  • Reducing proof storage space.
Big proof files are difficult to handle, on the one hand by the Rodin platform (slow access), and on the other hand by users (project sharing).
The proof purging and proof simplifying mechanisms have been implemented to address this issue.
  • Facilitating manual proof review or reuse.
The proof skeleton view allows to quickly browse through a proof. : Moreover, the provided copy/paste feature makes it possible to reuse a stored proof into a new proof.
  • Improving prover API.
The tactic provider API has been made more flexible to facilitate tactic contributions.

Choices / Decisions

The proving API one year ago asked that available proof commands would be completely determined statically (at application startup). This decision had to be revised to allow for dynamically contributed proof commands. This change was required not only for regular rules where several options could be considered based on available hypotheses, but also for plugging in the rule based prover, developed by University of Southampton. This API extension was fully designed and discussed through the Rodin wiki.

See New Tactic Providers.

Following to the detection of incorrect proof rules implemented in the tool, a complete review of all proof rules and their implementation has been carried out. Moreover, a review procedure has been defined to lower the risk that such glitches happen again in the future. Also, the decision to develop a rule based prover (where rules must be formally proved before being used) will provide greater confidence in the correctness of the prover.

In the current setting, proof files can grow very large (in the order of tens of megabytes). This is partly caused by the usage of the Rodin database mechanism for storing proofs in XML files. At the last DEPLOY workshop (October 2009), several other options have been discussed to reduce this memory footprint. This issue is beging further investigated.

Available Documentation

The following pages give useful information about prover improvements:

  • Prover Rules
See Inference Rules.
See All Rewrite Rules.
  • Proof Skeleton View
See Proof Skeleton View.
  • Proof Purger
See Proof Purger Interface.
  • Prover API evolution
See New Tactic Providers.
  • Versioned Reasoners
See Versioned Reasoners.

Planning

The above mentioned improvements were made available since release 1.1 of the platform:

Rodin Platform 1.1 Release Notes

In the third year of DEPLOY, most effort in the proving area will be put into:

- Better management of well-definedness conditions.
- Improvement to the rule based prover.
- Bridging the gap with external SMT solvers.
- Supporting mathematical extensions in proofs.