Module Fields.Make_fp6

Parameters

module N : Nat_intf.S
module Fp : Intf
module Fp2 : Degree_2_extension_intf with type base = Fp.t
module Fp3 : sig ... end
module Info : sig ... end

Signature

include Degree_2_extension_intf with type base = Fp3.t and module Nat = Fp.Nat
type base = Fp3.t
include Extension_intf with type base := base and type t = base * base with module Nat = Fp.Nat
include Extended_intf with type t = base * base with module Nat = Fp.Nat
include Sqrt_field_intf with type t = base * base with module Nat = Fp.Nat
include Intf with type t = base * base with module Nat = Fp.Nat
type t = base * base
val to_yojson : t -> Yojson.Safe.t
val of_yojson : Yojson.Safe.t -> t Ppx_deriving_yojson_runtime.error_or
include Core_kernel.Bin_prot.Binable.S with type t := t
val bin_size_t : t Bin_prot.Size.sizer
val bin_write_t : t Bin_prot.Write.writer
val bin_read_t : t Bin_prot.Read.reader
val __bin_read_t__ : ( int -> t ) Bin_prot.Read.reader
val bin_shape_t : Bin_prot.Shape.t
val bin_writer_t : t Bin_prot.Type_class.writer
val bin_reader_t : t Bin_prot.Type_class.reader
val bin_t : t Bin_prot.Type_class.t
include Ppx_sexp_conv_lib.Sexpable.S with type t := t
val t_of_sexp : Sexplib0__.Sexp.t -> t
val sexp_of_t : t -> Sexplib0__.Sexp.t
val compare : t -> t -> int
val hash_fold_t : Ppx_hash_lib.Std.Hash.state -> t -> Ppx_hash_lib.Std.Hash.state
val hash : t -> Ppx_hash_lib.Std.Hash.hash_value
include Basic_intf with type t := t with module Nat = Fp.Nat
module Nat = Fp.Nat
val equal : t -> t -> Ppx_deriving_runtime.bool
val order : Nat.t
val one : t
val zero : t
val (+) : t -> t -> t
val (*) : t -> t -> t
val (-) : t -> t -> t
val (/) : t -> t -> t
val square : t -> t
val gen : t Core_kernel.Quickcheck.Generator.t
val gen_incl : t -> t -> t Core_kernel.Quickcheck.Generator.t
val gen_uniform : t Core_kernel.Quickcheck.Generator.t
val gen_uniform_incl : t -> t -> t Core_kernel.Quickcheck.Generator.t
val random : unit -> t
val negate : t -> t
val inv : t -> t
val parity : t -> bool
val is_square : t -> bool
val sqrt : t -> t
val (**) : t -> Nat.t -> t
val scale : t -> base -> t
val of_base : base -> t
val project_to_base : t -> base
val to_list : t -> base list
val mul_by_2345 : t -> t -> t
val frobenius : t -> int -> t
val cyclotomic_exp : t -> N.t -> t
val unitary_inverse : t -> t