Clearmatics Libsnark  0.1
C++ library for zkSNARK proofs
Public Types | Public Member Functions | Public Attributes | List of all members
libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT > Class Template Reference

#include <bls12_377_miller_loop.hpp>

Inheritance diagram for libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >:
Inheritance graph
[legend]
Collaboration diagram for libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >:
Collaboration graph
[legend]

Public Types

using FieldT = libff::Fr< ppT >
 
using FqkT = libff::Fqk< other_curve< ppT > >
 

Public Member Functions

 bls12_377_e_over_e_miller_loop_gadget (protoboard< libff::Fr< ppT >> &pb, const bls12_377_G1_precomputation< ppT > &P1_prec, const bls12_377_G2_precomputation< ppT > &Q1_prec, const bls12_377_G1_precomputation< ppT > &P2_prec, const bls12_377_G2_precomputation< ppT > &Q2_prec, const Fp12_2over3over2_variable< FqkT > &result, const std::string &annotation_prefix)
 
void generate_r1cs_constraints ()
 
void generate_r1cs_witness ()
 
- Public Member Functions inherited from libsnark::gadget< libff::Fr< ppT > >
 gadget (protoboard< libff::Fr< ppT > > &pb, const std::string &annotation_prefix)
 

Public Attributes

Fp12_2over3over2_variable< FqkT_f0
 
pb_linear_combination< FieldT_minus_P2_Y
 
std::vector< std::shared_ptr< Fp12_2over3over2_square_gadget< FqkT > > > _f_squared
 
std::vector< std::shared_ptr< bls12_377_ate_compute_f_ell_P< ppT > > > _f_ell_P
 

Additional Inherited Members

- Protected Attributes inherited from libsnark::gadget< libff::Fr< ppT > >
protoboard< libff::Fr< ppT > > & pb
 
const std::string annotation_prefix
 

Detailed Description

template<typename ppT>
class libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >

Definition at line 86 of file bls12_377_miller_loop.hpp.

Member Typedef Documentation

◆ FieldT

template<typename ppT >
using libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >::FieldT = libff::Fr<ppT>

Definition at line 89 of file bls12_377_miller_loop.hpp.

◆ FqkT

template<typename ppT >
using libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >::FqkT = libff::Fqk<other_curve<ppT> >

Definition at line 90 of file bls12_377_miller_loop.hpp.

Constructor & Destructor Documentation

◆ bls12_377_e_over_e_miller_loop_gadget()

template<typename ppT >
libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >::bls12_377_e_over_e_miller_loop_gadget ( protoboard< libff::Fr< ppT >> &  pb,
const bls12_377_G1_precomputation< ppT > &  P1_prec,
const bls12_377_G2_precomputation< ppT > &  Q1_prec,
const bls12_377_G1_precomputation< ppT > &  P2_prec,
const bls12_377_G2_precomputation< ppT > &  Q2_prec,
const Fp12_2over3over2_variable< FqkT > &  result,
const std::string &  annotation_prefix 
)

Member Function Documentation

◆ generate_r1cs_constraints()

template<typename ppT >
void libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >::generate_r1cs_constraints ( )

◆ generate_r1cs_witness()

template<typename ppT >
void libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >::generate_r1cs_witness ( )

Member Data Documentation

◆ _f0

Definition at line 92 of file bls12_377_miller_loop.hpp.

◆ _f_ell_P

template<typename ppT >
std::vector<std::shared_ptr<bls12_377_ate_compute_f_ell_P<ppT> > > libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >::_f_ell_P

Definition at line 100 of file bls12_377_miller_loop.hpp.

◆ _f_squared

template<typename ppT >
std::vector<std::shared_ptr<Fp12_2over3over2_square_gadget<FqkT> > > libsnark::bls12_377_e_over_e_miller_loop_gadget< ppT >::_f_squared

Definition at line 97 of file bls12_377_miller_loop.hpp.

◆ _minus_P2_Y

Definition at line 93 of file bls12_377_miller_loop.hpp.


The documentation for this class was generated from the following file: