package octez-libs
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=aa2f5bc99cc4ca2217c52a1af2a2cdfd3b383208cb859ca2e79ca0903396ca1d
sha512=d68bb3eb615e3dcccc845fddfc9901c95b3c6dc8e105e39522ce97637b1308a7fa7aa1d271351d5933febd7476b2819e1694f31198f1f0919681f1f9cc97cb3a
doc/octez-libs.mec/Mec/CurveSig/module-type-AffineWeierstrassT/index.html
Module type CurveSig.AffineWeierstrassT
Source
include WeierstrassT
include 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 : Bls12_381.Ff_sig.PRIME
module Base : Bls12_381.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
val b : Base.t
is_on_curve ~x ~y
returns true
if the coordinates (x, y)
represents a point on the curve. It does not check the point is in the prime subgroup.
is_in_prime_subgroup ~x ~y
returns true
if the coordinates (x, y)
represents a point in the prime subgroup. The coordinates must be a point on the curve
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
.
Build a point from a compressed representation. It supposes the base field leaves at least a free bit in the last byte to encode the sign. Raise Not_on_curve
if the bytes do not represent a point on the curve and in the prime subgroup.
Same than of_compressed_bytes_exn
but returns an option instead of raising an exception