diff options
| author | Pierre Letouzey | 2015-06-22 14:53:31 +0200 |
|---|---|---|
| committer | Pierre Letouzey | 2015-06-22 14:53:31 +0200 |
| commit | 29fcfc4f8bc1bfbdfbae0c07850aed65f6c3eb04 (patch) | |
| tree | 1e2edfae22c9f90ae4eceb8cf081df88a98b981e /plugins/extraction/ExtrHaskellZInt.v | |
| parent | 6bec099f8487b9d3ec5c44079cf69d3474c73b91 (diff) | |
| parent | 4b6b4d8cdd12902d166504ec3d96ca94705d81f6 (diff) | |
Merge branch 'v8.5' into trunk
Diffstat (limited to 'plugins/extraction/ExtrHaskellZInt.v')
| -rw-r--r-- | plugins/extraction/ExtrHaskellZInt.v | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/plugins/extraction/ExtrHaskellZInt.v b/plugins/extraction/ExtrHaskellZInt.v new file mode 100644 index 0000000000..66690851a7 --- /dev/null +++ b/plugins/extraction/ExtrHaskellZInt.v @@ -0,0 +1,24 @@ +(** Extraction of [Z] into Haskell's [Int] *) + +Require Import ZArith. +Require Import ExtrHaskellZNum. + +(** + * Disclaimer: trying to obtain efficient certified programs + * by extracting [Z] into [Int] is definitively *not* a good idea. + * See comments in [ExtrOcamlNatInt.v]. + *) + +Extract Inductive positive => "Prelude.Int" [ + "(\x -> 2 Prelude.* x Prelude.+ 1)" + "(\x -> 2 Prelude.* x)" + "1" ] + "(\fI fO fH n -> if n Prelude.== 1 then fH () else + if Prelude.odd n + then fI (n `Prelude.div` 2) + else fO (n `Prelude.div` 2))". + +Extract Inductive Z => "Prelude.Int" [ "0" "(\x -> x)" "Prelude.negate" ] + "(\fO fP fN n -> if n Prelude.== 0 then fO () else + if n Prelude.> 0 then fP n else + fN (Prelude.negate n))". |
