diff options
| author | coqbot-app[bot] | 2020-10-14 08:42:14 +0000 |
|---|---|---|
| committer | GitHub | 2020-10-14 08:42:14 +0000 |
| commit | 411025844a4c005ce03d77c6c640807c28269d4a (patch) | |
| tree | e949e2d259253020368d0ea4b4d45d8ceeecaafa /kernel/float64_31.ml | |
| parent | 9fa5174bac92de63bceae2c4e9ef70fab93198fd (diff) | |
| parent | 6fe8c44ff828ef4ec89b49ada634ce87639f384f (diff) | |
Merge PR #13147: Use OCaml floating-point operations on 64 bits arch
Reviewed-by: erikmd
Reviewed-by: silene
Diffstat (limited to 'kernel/float64_31.ml')
| -rw-r--r-- | kernel/float64_31.ml | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/kernel/float64_31.ml b/kernel/float64_31.ml new file mode 100644 index 0000000000..09b28e6cf0 --- /dev/null +++ b/kernel/float64_31.ml @@ -0,0 +1,35 @@ +(************************************************************************) +(* * The Coq Proof Assistant / The Coq Development Team *) +(* v * Copyright INRIA, CNRS and contributors *) +(* <O___,, * (see version control and CREDITS file for authors & dates) *) +(* \VV/ **************************************************************) +(* // * This file is distributed under the terms of the *) +(* * GNU Lesser General Public License Version 2.1 *) +(* * (see LICENSE file for the text of the license) *) +(************************************************************************) + +include Float64_common + +external mul : float -> float -> float = "coq_fmul_byte" "coq_fmul" +[@@unboxed] [@@noalloc] + +external add : float -> float -> float = "coq_fadd_byte" "coq_fadd" +[@@unboxed] [@@noalloc] + +external sub : float -> float -> float = "coq_fsub_byte" "coq_fsub" +[@@unboxed] [@@noalloc] + +external div : float -> float -> float = "coq_fdiv_byte" "coq_fdiv" +[@@unboxed] [@@noalloc] + +external sqrt : float -> float = "coq_fsqrt_byte" "coq_fsqrt" +[@@unboxed] [@@noalloc] + +(*** Test at runtime that no harmful double rounding seems to + be performed with an intermediate 80 bits representation (x87). *) +let () = + let b = ldexp 1. 53 in + let s = add 1. (ldexp 1. (-52)) in + if add b s <= b || add b 1. <> b || ldexp 1. (-1074) <= 0. then + failwith "Detected non IEEE-754 compliant architecture (or wrong \ + rounding mode). Use of Float is thus unsafe." |
