This library implements arithmetic and logical operations over arbitrary-precision integers.
The module is simply named Z
. Its interface is similar to that of the Int32
, Int64
and Nativeint
modules from the OCaml standard library, with some additional functions. See the file z.mli
for documentation.
The implementation uses GMP (the GNU Multiple Precision arithmetic library) to compute over big integers. However, small integers are represented as unboxed Caml integers, to save space and improve performance. Big integers are allocated in the Caml heap, bypassing GMP's memory management and achieving better GC behavior than e.g. the MLGMP library. Computations on small integers use a special, faster path (in C or OCaml) eschewing calls to GMP, while computations on large integers use the low-level MPN functions from GMP.
Arbitrary-precision integers can be compared correctly using OCaml's polymorphic comparison operators (=
, <
, >
, etc.).
Additional features include:
Q
for rationals, built on top of Z
(see q.mli
)Big_int_Z
that implements the same API as Big_int from the legacy Num
library, but uses Z
internallySupport for js_of_ocaml is provided by Zarith_stubs_js.
The configure
script has a few options. Use the -help
option to get a list and short description of each option.
This builds native and bytecode versions of the library.
or, if you install to a system location but are not an administrator
If Findlib is detected, it is used to install files. Otherwise, the files are copied to a zarith/
subdirectory of the directory given by ocamlc -where
.
The libraries are named zarith.cmxa
and zarith.cma
, and the Findlib module is named zarith
.
Compiling and linking with the library requires passing the -I +zarith
option to ocamlc
/ ocamlopt
, or the -package zarith
option to ocamlfind
.
(but these are not installed).
ocamldoc
) by the additional commandThe documentation for the latest release is hosted on GitHub Pages.
This Library is distributed under the terms of the GNU Library General Public License version 2, with a special exception allowing unconstrained static linking. See LICENSE file for details.
Copyright (c) 2010-2011 Antoine Miné, Abstraction project. Abstraction is part of the LIENS (Laboratoire d'Informatique de l'ENS), a joint laboratory by: CNRS (Centre national de la recherche scientifique, France), ENS (École normale supérieure, Paris, France), INRIA Rocquencourt (Institut national de recherche en informatique, France).
Source files Description configure configuration script z.ml[i] Z module and implementation for small integers caml_z.c C implementation big_int_z.ml[i] wrapper to provide a Big_int compatible API to Z q.ml[i] rational library, pure OCaml on top of Z zarith_top.ml toplevel module to provide pretty-printing projet.mak builds Z, Q and the tests zarith.opam package description for opam z_mlgmpidl.ml[i] conversion between Zarith and MLGMPIDL tests/ simple regression tests and benchmarksRetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4