Library Coq.Numbers.AltBinNotations


Alternative Binary Numeral Notations

Faster but less safe parsers and printers of positive, N, Z.
By default, literals in types positive, N, Z are parsed and printed via the Numeral Notation command, by conversion from/to the Decimal.int representation. When working with numbers with thousands of digits and more, conversion from/to Decimal.int can become significantly slow. If that becomes a problem for your development, this file provides some alternative Numeral Notation commands that use Z as bridge type. To enable these commands, just be sure to Require this file after other files defining numeral notations.
Note: up to Coq 8.8, literals in types positive, N, Z were parsed and printed using a native ML library of arbitrary precision integers named bigint.ml. From 8.9, the default is to parse and print using a Coq library converting sequences of digits, hence reducing the amount of ML code to trust. But this method is slower. This file then gives access to the legacy method, trading efficiency against a larger ML trust base relying on bigint.ml.

Require Import BinNums.

positive

Definition pos_of_z z :=
  match z with
    | Zpos p => Some p
    | _ => None
  end.

Definition pos_to_z p := Zpos p.


N

Definition n_of_z z :=
  match z with
    | Z0 => Some N0
    | Zpos p => Some (Npos p)
    | Zneg _ => None
  end.

Definition n_to_z n :=
  match n with
    | N0 => Z0
    | Npos p => Zpos p
  end.


Z

Definition z_of_z (z:Z) := z.