package mec
Install
Dune Dependency
Authors
Maintainers
Sources
md5=7c68b531c8011b5d032f0a0d8523e8c5
sha512=f428751c5f2b7c7fc07548551bea0277c9c8c32c1052aecf22787188e7678939dbb091844e29178b2819d724cf843c65774d9211c0a0ede5bf71caff3f2dd1bc
doc/mec_curve_utils/Mec_curve_utils/Ec/MakeAffineEdwardsToAffineMontgomery/argument-1-E/index.html
Parameter MakeAffineEdwardsToAffineMontgomery.E
au^2 + v^2 = 1 + du^2v^2
include Mec_curve_sig.Ec_sig.BASE
exception Not_on_curve of Bytes.t
Represents an element on the curve. In the case of a curve with a cofactor, the element is not necessarily in the prime subgroup.
module Scalar : Ff_sig.PRIME
module Base : Ff_sig.PRIME
val check_bytes : Bytes.t -> bool
Check if a point, represented as a byte array, is on the curve *
Attempt to construct a point from a byte array. Raise Not_on_curve
if the point is not on the curve
val zero : t
Zero of the elliptic curve
val one : t
A fixed generator of the elliptic curve
val is_zero : t -> bool
Return true
if the given element is zero
val random : ?state:Random.State.t -> unit -> t
Generate a random element
val a : Base.t
The parameter a
of the curve, from the equation a * u^2 + v^2 = 1 + d * u^2 * v^2
val d : Base.t
The parameter d
of the curve, from the equation a * u^2 + v^2 = 1 + d * u^2 * v^2
The cofactor of the curve. The parameter is used in is_small_order
and in the random point generator.
is_on_curve ~u ~v
returns true
if the coordinates (u, v)
represents a point on the curve. It does not check the point is in the prime subgroup.
is_in_prime_subgroup ~u ~v
returns true
if the coordinates (u, v)
represents a point in the prime subgroup. The coordinates must be a point on the curve
Return the affine coordinate u (such that au^2 + v^2 = 1 + d u^2 v^2
Return the affine coordinate u (such that au^2 + v^2 = 1 + d u^2 v^2
Build a point from the affine coordinates. If the point is not on the curve and in the subgroup, returns None
Build a point from the affine coordinates. If the point is not on the curve and in the subgroup, raise Not_on_curve
.