Clearmatics Libsnark
0.1
C++ library for zkSNARK proofs
|
#include <uscs.hpp>
Public Member Functions | |
uscs_constraint_system () | |
size_t | num_inputs () const |
size_t | num_variables () const |
size_t | num_constraints () const |
bool | is_valid () const |
bool | is_satisfied (const uscs_primary_input< FieldT > &primary_input, const uscs_auxiliary_input< FieldT > &auxiliary_input) const |
void | add_constraint (const uscs_constraint< FieldT > &constraint) |
void | add_constraint (const uscs_constraint< FieldT > &constraint, const std::string &annotation) |
bool | operator== (const uscs_constraint_system< FieldT > &other) const |
void | report_linear_constraint_statistics () const |
Public Attributes | |
size_t | primary_input_size |
size_t | auxiliary_input_size |
std::vector< uscs_constraint< FieldT > > | constraints |
Friends | |
std::ostream & | operator (std::ostream &out, const uscs_constraint_system< FieldT > &cs) |
std::istream & | operator>> (std::istream &in, uscs_constraint_system< FieldT > &cs) |
A system of USCS constraints looks like
{ ( \sum_{i=1}^{m_k} a_{k,i} * x_{k,i} )^2 = 1 }_{k=1}^{n} .
In other words, the system is satisfied if and only if there exist a USCS variable assignment for which each USCS constraint evaluates to -1 or 1.
NOTE: The 0-th variable (i.e., "x_{0}") always represents the constant 1. Thus, the 0-th variable is not included in num_variables.
|
inline |
void libsnark::uscs_constraint_system< FieldT >::add_constraint | ( | const uscs_constraint< FieldT > & | constraint | ) |
void libsnark::uscs_constraint_system< FieldT >::add_constraint | ( | const uscs_constraint< FieldT > & | constraint, |
const std::string & | annotation | ||
) |
bool libsnark::uscs_constraint_system< FieldT >::is_satisfied | ( | const uscs_primary_input< FieldT > & | primary_input, |
const uscs_auxiliary_input< FieldT > & | auxiliary_input | ||
) | const |
bool libsnark::uscs_constraint_system< FieldT >::is_valid | ( | ) | const |
size_t libsnark::uscs_constraint_system< FieldT >::num_constraints | ( | ) | const |
size_t libsnark::uscs_constraint_system< FieldT >::num_inputs | ( | ) | const |
size_t libsnark::uscs_constraint_system< FieldT >::num_variables | ( | ) | const |
bool libsnark::uscs_constraint_system< FieldT >::operator== | ( | const uscs_constraint_system< FieldT > & | other | ) | const |
void libsnark::uscs_constraint_system< FieldT >::report_linear_constraint_statistics | ( | ) | const |
|
friend |
|
friend |
size_t libsnark::uscs_constraint_system< FieldT >::auxiliary_input_size |
std::vector<uscs_constraint<FieldT> > libsnark::uscs_constraint_system< FieldT >::constraints |
size_t libsnark::uscs_constraint_system< FieldT >::primary_input_size |