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

#include <ssp.hpp>

Public Member Functions

 ssp_instance (const std::shared_ptr< libfqfft::evaluation_domain< FieldT >> &domain, const size_t num_variables, const size_t degree, const size_t num_inputs, const std::vector< std::map< size_t, FieldT >> &V_in_Lagrange_basis)
 
 ssp_instance (const std::shared_ptr< libfqfft::evaluation_domain< FieldT >> &domain, const size_t num_variables, const size_t degree, const size_t num_inputs, std::vector< std::map< size_t, FieldT >> &&V_in_Lagrange_basis)
 
 ssp_instance (const ssp_instance< FieldT > &other)=default
 
 ssp_instance (ssp_instance< FieldT > &&other)=default
 
ssp_instanceoperator= (const ssp_instance< FieldT > &other)=default
 
ssp_instanceoperator= (ssp_instance< FieldT > &&other)=default
 
size_t num_variables () const
 
size_t degree () const
 
size_t num_inputs () const
 
bool is_satisfied (const ssp_witness< FieldT > &witness) const
 

Public Attributes

std::shared_ptr< libfqfft::evaluation_domain< FieldT > > domain
 
std::vector< std::map< size_t, FieldT > > V_in_Lagrange_basis
 

Detailed Description

template<typename FieldT>
class libsnark::ssp_instance< FieldT >

A SSP instance.

Specifically, the datastructure stores:

There is no need to store the Z polynomial because it is uniquely determined by the domain (as Z is its vanishing polynomial).

Definition at line 46 of file ssp.hpp.

Constructor & Destructor Documentation

◆ ssp_instance() [1/4]

template<typename FieldT >
libsnark::ssp_instance< FieldT >::ssp_instance ( const std::shared_ptr< libfqfft::evaluation_domain< FieldT >> &  domain,
const size_t  num_variables,
const size_t  degree,
const size_t  num_inputs,
const std::vector< std::map< size_t, FieldT >> &  V_in_Lagrange_basis 
)

◆ ssp_instance() [2/4]

template<typename FieldT >
libsnark::ssp_instance< FieldT >::ssp_instance ( const std::shared_ptr< libfqfft::evaluation_domain< FieldT >> &  domain,
const size_t  num_variables,
const size_t  degree,
const size_t  num_inputs,
std::vector< std::map< size_t, FieldT >> &&  V_in_Lagrange_basis 
)

◆ ssp_instance() [3/4]

template<typename FieldT >
libsnark::ssp_instance< FieldT >::ssp_instance ( const ssp_instance< FieldT > &  other)
default

◆ ssp_instance() [4/4]

template<typename FieldT >
libsnark::ssp_instance< FieldT >::ssp_instance ( ssp_instance< FieldT > &&  other)
default

Member Function Documentation

◆ degree()

template<typename FieldT >
size_t libsnark::ssp_instance< FieldT >::degree ( ) const

◆ is_satisfied()

template<typename FieldT >
bool libsnark::ssp_instance< FieldT >::is_satisfied ( const ssp_witness< FieldT > &  witness) const

◆ num_inputs()

template<typename FieldT >
size_t libsnark::ssp_instance< FieldT >::num_inputs ( ) const

◆ num_variables()

template<typename FieldT >
size_t libsnark::ssp_instance< FieldT >::num_variables ( ) const

◆ operator=() [1/2]

template<typename FieldT >
ssp_instance& libsnark::ssp_instance< FieldT >::operator= ( const ssp_instance< FieldT > &  other)
default

◆ operator=() [2/2]

template<typename FieldT >
ssp_instance& libsnark::ssp_instance< FieldT >::operator= ( ssp_instance< FieldT > &&  other)
default

Member Data Documentation

◆ domain

template<typename FieldT >
std::shared_ptr<libfqfft::evaluation_domain<FieldT> > libsnark::ssp_instance< FieldT >::domain

Definition at line 54 of file ssp.hpp.

◆ V_in_Lagrange_basis

template<typename FieldT >
std::vector<std::map<size_t, FieldT> > libsnark::ssp_instance< FieldT >::V_in_Lagrange_basis

Definition at line 56 of file ssp.hpp.


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