lean4-htt/src/Init/Data/Float.lean
2020-04-03 17:19:48 -07:00

73 lines
2.6 KiB
Text

/-
Copyright (c) 2020 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Authors: Leonardo de Moura
-/
prelude
import Init.Core
import Init.Data.ToString
structure FloatSpec :=
(float : Type)
(val : float)
(lt : float → float → Prop)
(le : float → float → Prop)
(decEq : DecidableEq float)
(decLt : DecidableRel lt)
(decLe : DecidableRel le)
-- Just show FloatSpec is inhabited.
constant floatSpec : FloatSpec := {
float := Unit,
val := (),
lt := fun _ _ => True,
le := fun _ _ => True,
decEq := inferInstanceAs (DecidableEq Unit),
decLt := fun _ _ => inferInstanceAs (Decidable True),
decLe := fun _ _ => inferInstanceAs (Decidable True)
}
structure Float :=
(val : floatSpec.float)
instance : Inhabited Float := ⟨{ val := floatSpec.val }⟩
@[extern "lean_float_of_nat"] constant Float.ofNat : (@& Nat) → Float := arbitrary _
@[extern c inline "#1 + #2"] constant Float.add : Float → Float → Float := arbitrary _
@[extern c inline "#1 - #2"] constant Float.sub : Float → Float → Float := arbitrary _
@[extern c inline "#1 * #2"] constant Float.mul : Float → Float → Float := arbitrary _
@[extern c inline "#1 / #2"] constant Float.div : Float → Float → Float := arbitrary _
def Float.lt : Float → Float → Prop :=
fun a b => match a, b with
| ⟨a⟩, ⟨b⟩ => floatSpec.lt a b
def Float.le : Float → Float → Prop := fun a b => floatSpec.le a.val b.val
instance : HasZero Float := ⟨Float.ofNat 0⟩
instance : HasOne Float := ⟨Float.ofNat 1⟩
instance : HasOfNat Float := ⟨Float.ofNat⟩
instance : HasAdd Float := ⟨Float.add⟩
instance : HasSub Float := ⟨Float.sub⟩
instance : HasMul Float := ⟨Float.mul⟩
instance : HasDiv Float := ⟨Float.div⟩
instance : HasLess Float := ⟨Float.lt⟩
instance : HasLessEq Float := ⟨Float.le⟩
@[extern c inline "#1 == #2"] constant Float.decEq (a b : Float) : Decidable (a = b) :=
match a, b with
| ⟨a⟩, ⟨b⟩ => match floatSpec.decEq a b with
| isTrue h => isTrue (congrArg Float.mk h)
| isFalse h => isFalse (fun h₁ => Float.noConfusion h₁ (fun h₁ => absurd h₁ h))
@[extern c inline "#1 < #2"] constant Float.decLt (a b : Float) : Decidable (a < b) :=
match a, b with
| ⟨a⟩, ⟨b⟩ => floatSpec.decLt a b
@[extern c inline "#1 <= #2"] constant Float.decLe (a b : Float) : Decidable (a ≤ b) :=
match a, b with
| ⟨a⟩, ⟨b⟩ => floatSpec.decLe a b
@[extern "lean_float_to_string"] constant Float.toString : Float → String := arbitrary _
instance : HasToString Float := ⟨Float.toString⟩