include Core.Float
Floating-point numbers.
include sig ... end
val typerep_of_t : t Typerep_lib.Std.Typerep.t
val typename_of_t : t Typerep_lib.Std.Typename.t
module Robust_compare = Core_kernel.Float.Robust_compare
The results of robust comparisons on nan
should be considered undefined.
include Robust_compare.S
val robust_comparison_tolerance : Core_kernel__.Import.float
intended to be a tolerance on human-entered floats
module O = Core_kernel.Float.O
module Terse = Core_kernel.Float.Terse
include Core_kernel.Identifiable.S with type t := t and type comparator_witness := Base.Float.comparator_witness
include sig ... end
val bin_t : t Bin_prot.Type_class.t
val bin_read_t : t Bin_prot.Read.reader
val __bin_read_t__ : (Core_kernel__.Import.int ‑> t) Bin_prot.Read.reader
val bin_reader_t : t Bin_prot.Type_class.reader
val bin_size_t : t Bin_prot.Size.sizer
val bin_write_t : t Bin_prot.Write.writer
val bin_writer_t : t Bin_prot.Type_class.writer
val bin_shape_t : Bin_prot.Shape.t
val hash_fold_t : Base.Hash.state ‑> t ‑> Base.Hash.state
val hash : t ‑> Base.Hash.hash_value
val t_of_sexp : Base.Sexp.t ‑> t
val sexp_of_t : t ‑> Base.Sexp.t
include Core_kernel.Identifiable.S_common with type t := t
include sig ... end
val compare : t ‑> t ‑> Core_kernel__.Import.int
val hash_fold_t : Base.Hash.state ‑> t ‑> Base.Hash.state
val hash : t ‑> Base.Hash.hash_value
val sexp_of_t : t ‑> Base.Sexp.t
include Core_kernel__.Import.Stringable.S with type t := t
val of_string : string ‑> t
val to_string : t ‑> string
include Core_kernel__.Import.Pretty_printer.S with type t := t
val pp : Base.Formatter.t ‑> t ‑> unit
include Core_kernel.Comparable.S_binable with type t := t
include Core_kernel__.Comparable_intf.S_common
include Base.Comparable.S
include Base__.Comparable_intf.Polymorphic_compare
ascending
is identical to compare
. descending x y = ascending y x
. These are
intended to be mnemonic when used like List.sort ~compare:ascending
and List.sort
~cmp:descending
, since they cause the list to be sorted in ascending or descending
order, respectively.
clamp_exn t ~min ~max
returns t'
, the closest value to t
such that
between t' ~low:min ~high:max
is true.
Raises if not (min <= max)
.
val clamp : t ‑> min:t ‑> max:t ‑> t Base.Or_error.t
include Base.Comparator.S with type t := t
val comparator : (t, comparator_witness) Base.Comparator.comparator
include Base__.Comparable_intf.Validate with type t := t
val validate_lbound : min:t Base.Maybe_bound.t ‑> t Base.Validate.check
val validate_ubound : max:t Base.Maybe_bound.t ‑> t Base.Validate.check
val validate_bound : min:t Base.Maybe_bound.t ‑> max:t Base.Maybe_bound.t ‑> t Base.Validate.check
module Replace_polymorphic_compare : Core_kernel__.Comparable_intf.Polymorphic_compare with type t := t
include Core_kernel__.Comparable_intf.Map_and_set_binable with type t := t with type comparator_witness := comparator_witness
include Core_kernel.Comparator.S with type t := t
val comparator : (t, comparator_witness) Core_kernel.Comparator.comparator
module Map : Core_kernel.Map.S_binable with type Key.t = t with type Key.comparator_witness = comparator_witness
module Set : Core_kernel.Set.S_binable with type Elt.t = t with type Elt.comparator_witness = comparator_witness
include Core_kernel.Hashable.S_binable with type t := t
include sig ... end
val hash_fold_t : Base.Hash.state ‑> t ‑> Base.Hash.state
val hash : t ‑> Base.Hash.hash_value
val hashable : t Core_kernel.Hashtbl.Hashable.t
module Table : Core_kernel.Hashtbl.S_binable with type key = t
module Hash_set : Core_kernel.Hash_set.S_binable with type elt = t
module Hash_queue : Core_kernel.Hash_queue.S with type Key.t = t
include module type of sig ... end with type t := t with module O := Base.Float.O with module Terse := Base.Float.Terse
val of_float : float ‑> t
val to_float : t ‑> float
val hash_fold_t : Base.Hash.state ‑> t ‑> Base.Hash.state
val hash : t ‑> Base.Hash.hash_value
val t_of_sexp : Base.Sexp.t ‑> t
val sexp_of_t : t ‑> Base.Sexp.t
val of_string : string ‑> t
val clamp : t ‑> min:t ‑> max:t ‑> t Base.Or_error.t
val comparator : (t, comparator_witness) Base.Comparator.comparator
val validate_lbound : min:t Base.Maybe_bound.t ‑> t Base.Validate.check
val validate_ubound : max:t Base.Maybe_bound.t ‑> t Base.Validate.check
val validate_bound : min:t Base.Maybe_bound.t ‑> max:t Base.Maybe_bound.t ‑> t Base.Validate.check
val pp : Base.Formatter.t ‑> t ‑> unit
val validate_positive : t Base.Validate.check
val validate_non_negative : t Base.Validate.check
val validate_negative : t Base.Validate.check
val validate_non_positive : t Base.Validate.check
val is_positive : t ‑> bool
val is_non_negative : t ‑> bool
val is_negative : t ‑> bool
val is_non_positive : t ‑> bool
val validate_ordinary : t Base.Validate.check
val nan : t
val infinity : t
val neg_infinity : t
val max_value : t
val min_value : t
val zero : t
val one : t
val minus_one : t
val pi : t
val sqrt_pi : t
val sqrt_2pi : t
val euler : t
val epsilon_float : t
val max_finite_value : t
val min_positive_subnormal_value : t
val min_positive_normal_value : t
val to_int64_preserve_order : t ‑> int64 option
val to_int64_preserve_order_exn : t ‑> int64
val of_int64_preserve_order : int64 ‑> t
val of_int : int ‑> t
val to_int : t ‑> int
val of_int63 : Base.Int63.t ‑> t
val of_int64 : int64 ‑> t
val to_int64 : t ‑> int64
val iround : ?dir:[ `Down | `Nearest | `Up | `Zero ] ‑> t ‑> int option
val iround_exn : ?dir:[ `Down | `Nearest | `Up | `Zero ] ‑> t ‑> int
val iround_towards_zero : t ‑> int option
val iround_down : t ‑> int option
val iround_up : t ‑> int option
val iround_nearest : t ‑> int option
val iround_towards_zero_exn : t ‑> int
val iround_down_exn : t ‑> int
val iround_up_exn : t ‑> int
val iround_nearest_exn : t ‑> int
val int63_round_down_exn : t ‑> Base.Int63.t
val int63_round_up_exn : t ‑> Base.Int63.t
val int63_round_nearest_exn : t ‑> Base.Int63.t
val iround_lbound : t
val iround_ubound : t
val is_nan : t ‑> bool
val is_inf : t ‑> bool
module Parts = Base__Float.Parts
module O = Base__Float.O
module O_dot = Base__Float.O_dot
val to_string : t ‑> string
val to_string_hum : ?delimiter:char ‑> ?decimals:int ‑> ?strip_zero:bool ‑> t ‑> string
val to_padded_compact_string : t ‑> string
module Class = Base__Float.Class
val is_finite : t ‑> bool
val sign : t ‑> Base.Sign.t
val sign_exn : t ‑> Base.Sign.t
module Sign_or_nan = Base__Float.Sign_or_nan
val sign_or_nan : t ‑> Sign_or_nan.t
val create_ieee : negative:bool ‑> exponent:int ‑> mantissa:Base.Int63.t ‑> t Base.Or_error.t
val create_ieee_exn : negative:bool ‑> exponent:int ‑> mantissa:Base.Int63.t ‑> t
val ieee_negative : t ‑> bool
val ieee_exponent : t ‑> int
val ieee_mantissa : t ‑> Base.Int63.t
module Terse = Base__Float.Terse
module Private = Base__Float.Private
val to_string_12 : t ‑> Core_kernel__.Import.string
to_string_12 x
builds a string representing x
using up to 12 significant digits.
It loses precision. You can use "%{Float#12}"
in formats, but consider "%.12g"
,
"%{Float#hum}"
, or "%{Float}"
as alternatives.
val to_string : t ‑> Core_kernel__.Import.string
to_string x
builds a string s
representing the float x
that guarantees the round
trip, i.e., Float.equal x (Float.of_string s)
.
It usually yields as few significant digits as possible. That is, it won't print
3.14
as 3.1400000000000001243
. The only exception is that occasionally it will
output 17 significant digits when the number can be represented with just 16 (but
not 15 or fewer) of them.
val to_string_round_trippable : t ‑> Core_kernel__.Import.string
val sign : t ‑> Core_kernel.Sign.t
val robust_sign : t ‑> Core_kernel.Sign.t
(Formerly sign
) Uses robust comparison (so sufficiently small numbers are mapped
to Zero
). Also maps NaN to Zero
. Using this function is weakly discouraged.
val gen_uniform_excl : t ‑> t ‑> t Core_kernel.Quickcheck.Generator.t
gen_uniform_excl lo hi
creates a Quickcheck generator producing finite t
values
between lo
and hi
, exclusive. The generator approximates a uniform distribution
over the interval (lo, hi). Raises an exception if lo
is not finite, hi
is not
finite, or the requested range is empty.
The implementation chooses values uniformly distributed between 0 (inclusive) and 1
(exclusive) up to 52 bits of precision, then scales that interval to the requested
range. Due to rounding errors and non-uniform floating point precision, the resulting
distribution may not be precisely uniform and may not include all values between lo
and hi
.
val gen_incl : t ‑> t ‑> t Core_kernel.Quickcheck.Generator.t
gen_incl lo hi
creates a Quickcheck generator that produces values between lo
and
hi
, inclusive, approximately uniformly distributed, with extra weight given to
generating the endpoints lo
and hi
. Raises an exception if lo
is not finite,
hi
is not finite, or the requested range is empty.
val gen_finite : t Core_kernel.Quickcheck.Generator.t
gen_finite
produces all finite t
values, excluding infinities and all NaN
values.
val gen_positive : t Core_kernel.Quickcheck.Generator.t
gen_positive
produces all (strictly) positive finite t
values.
val gen_negative : t Core_kernel.Quickcheck.Generator.t
gen_negative
produces all (strictly) negative finite t
values.
val gen_without_nan : t Core_kernel.Quickcheck.Generator.t
gen_without_nan
produces all finite and infinite t
values, excluding all NaN
values.
include Extended_float
Extensions to Core.Float
.
val pretty : ?on_negative:[ `Blow_up | `Normal | `Print_dir ] ‑> float ‑> string
pretty-print a float using no more than five characters, using abberviations k, m, g, t.
if on_negative
is not set to `Normal
then the resulting is never over four
chars but upon negative number we either:
"<0"
val order_of_magnitude_difference : float ‑> float ‑> int
order_of_magnitude_difference a b
by how many orders of magnitude do a
and b
differ?
The return value is non-negative.
examples:
include Number.Verified_std with type repr = Core.Float.t
module Make_bounded : functor (Spec : Bounded_spec) -> Bounded with type t = private repr
Functor of creating bounded numbers
Unsafe modules and functors that still fully expose the representation for extensibility.
module Pos_unsafe : S with type t = repr
module Pos0_unsafe : S0 with type t = repr
module Neg_unsafe : S with type t = repr
module Neg0_unsafe : S0 with type t = repr
module Make_bounded_unsafe : functor (Spec : Bounded_spec) -> Bounded with type t = repr
module type Fraction : sig ... end
module Fraction = Extended_float.Fraction
module Fraction_unsafe = Extended_float.Fraction_unsafe