- Sep 09, 2013
-
-
Robbert Krebbers authored
-
- Aug 27, 2013
-
-
Robbert Krebbers authored
-
- Aug 21, 2013
-
-
Robbert Krebbers authored
-
Robbert Krebbers authored
-
Robbert Krebbers authored
-
Robbert Krebbers authored
-
- Aug 15, 2013
-
-
Robbert Krebbers authored
-
- Aug 14, 2013
-
-
Robbert Krebbers authored
-
- Aug 12, 2013
-
-
Robbert Krebbers authored
This commit includes the following changes: * More theorems about pre-, partial and total orders. * Define the lexicographic order on various commonly used data types. * Mergesort and its correctness proof. * Implement finite maps and sets using ordered association lists.
-
- Jun 24, 2013
-
-
Robbert Krebbers authored
-
Robbert Krebbers authored
-
- Jun 17, 2013
-
-
Robbert Krebbers authored
-
Robbert Krebbers authored
-
- May 21, 2013
-
-
Robbert Krebbers authored
-
- May 15, 2013
-
-
Robbert Krebbers authored
-
- May 12, 2013
-
-
Robbert Krebbers authored
-
- May 11, 2013
-
-
Robbert Krebbers authored
-
Robbert Krebbers authored
-
- May 07, 2013
-
-
Robbert Krebbers authored
The refactoring includes: * Use infix notations for the various list relations * More consistent naming * Put lemmas on one line whenever possible * Change proofs into one-liners when possible * Make better use of the "Implicit Types" command * Improve the order of the list module by placing all definitions at the start, then the proofs, and finally the tactics. Besides, there is some new machinery for proofs by reflection on lists. It is used for a decision procedure for permutations and list containment.
-
- Apr 02, 2013
-
-
Robbert Krebbers authored
-
- Mar 25, 2013
-
-
Robbert Krebbers authored
-
- Mar 14, 2013
-
-
Robbert Krebbers authored
-
- Feb 24, 2013
-
-
Robbert Krebbers authored
-
- Feb 22, 2013
-
-
Robbert Krebbers authored
-
- Feb 19, 2013
-
-
Robbert Krebbers authored
Both the operational and axiomatic semantics are extended with sequence points and a permission system based on fractional permissions. In order to achieve this, the memory model has been completely revised, and is now built on top of an abstract interface for permissions. Apart from these changed, the library on lists and sets has been heavily extended, and minor changed have been made to other parts of the prelude.
-
- Feb 01, 2013
-
-
Robbert Krebbers authored
-
- Jan 09, 2013
-
-
Robbert Krebbers authored
Conflicts: ars.v assertions.v axiomatic.v base.v doc/index.html expressions.v fin_maps.v memory.v smallstep.v state.v statements.v tactics.v
-
Robbert Krebbers authored
-
Robbert Krebbers authored
The development now corresponds exactly to the FoSSaCS 2013 paper. Also, the prelude is updated to the one of the master branch.
-
- Jan 05, 2013
-
-
Robbert Krebbers authored
-
Robbert Krebbers authored
-
Robbert Krebbers authored
* Define the standard strict order on pre orders. * Prove that this strict order is well founded for finite sets and finite maps. We also provide some utilities to compute with well founded recursion. * Improve the "simplify_option_equality" tactic to handle more cases. * Axiomatize finiteness of finite maps by translation to lists, instead of by them having a finite domain. * Prove many additional properties of finite maps. * Add many functions and theorems on lists, including: permutations, resize, filter, ...
-
- Nov 12, 2012
-
-
Robbert Krebbers authored
Most interestingly: * Use [lia] instead of [omega] everywhere * More many generic lemmas on the memory to the theory on finite maps. * Many additional list lemmas. * A new interface for a monad for collections, which is now also used by the collection tactics. * Provide an additional finite collection implementation using unordered lists without duplicates removed. This implementation forms a monad (just the list monad in disguise).
-
- Oct 19, 2012
-
-
Robbert Krebbers authored
The following things have been changed in this revision: * We now give a small step semantics for expressions. The denotational semantics only works for side-effect free expressions. * Dynamically allocated memory through alloc and free is now supported. * The following expressions are added: assignment, function call, unary operators, conditional, alloc, and free. * Some customary induction schemes for expressions are proven. * The axiomatic semantics (and its interpretation) have been changed in order to deal with non-deterministic expressions. * We have added inversion schemes based on small inversions for the operational semantics. Inversions using these schemes are much faster. * We improved the statement preservation proof of the operational semantics. * We now use a variant of SsReflect's [by] and [done], instead of Coq's [now] and [easy]. The [done] tactic is much faster as it does not perform inversions. * Add theory, definitions and notations on vectors. * Separate theory on contexts. * Change [Arguments] declarations to ensure better unfolding.
-
- Oct 10, 2012
-
-
Robbert Krebbers authored
* Introduce a type class and notation for disjointness. * Define unions of finite maps (a lot of theory has still to be moved from memory to fin_maps). * Prove the Hoare rule for function calls with arguments. * Prove the Hoare rule to add sets of functions. * Some additional theory on lifting of assertions.
-
- Sep 04, 2012
-
-
Robbert Krebbers authored
-
- Aug 30, 2012
-
-
Robbert Krebbers authored
-
- Aug 29, 2012
-
-
Robbert Krebbers authored
improve some definitions, simplify some proofs.
-
- Aug 23, 2012
-
-
Robbert Krebbers authored
-
- Aug 21, 2012
-
-
Robbert Krebbers authored
The main changes are: * Function calls in the operational semantics * Mutually recursive function calls in the axiomatic semantics * A general definition of the interpretation of the axiomatic semantics so as to improve reusability (useful for function calls, and also for expressions in future versions) * Type classes for stack independent, memory independent, and memory extensible assertions, and a lot of instances to automatically derive these properties. * Many additional lemmas on the memory and more robust tactics to simplify goals involving is_free and mem_disjoint * Proof of preservation of statements in the smallstep semantics * Some new tactics: feed, feed destruct, feed inversion, etc... * More robust tactic scripts using bullets and structured scripts * Truncate most lines at 80 characters
-