pub struct VAnchorCircuit<F: PrimeField, H: CRH, HG: CRHGadget<H, F>, C: MerkleConfig, LHGT: CRHGadget<C::LeafH, F>, HGT: CRHGadget<C::H, F>, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> { /* private fields */ }Implementations§
Source§impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: PrimeField,
H: CRH,
HG: CRHGadget<H, F>,
C: MerkleConfig,
LHGT: CRHGadget<C::LeafH, F>,
HGT: CRHGadget<C::H, F>,
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: PrimeField,
H: CRH,
HG: CRHGadget<H, F>,
C: MerkleConfig,
LHGT: CRHGadget<C::LeafH, F>,
HGT: CRHGadget<C::H, F>,
pub fn new( public_amount: F, ext_data_hash: ArbitraryInput<F>, leaf_private_inputs: Vec<LeafPrivateInputs<F>>, keypair_inputs: Vec<Keypair<F, H>>, leaf_public_input: LeafPublicInputs<F>, root_set: [F; M], hasher_params_w2: H::Parameters, hasher_params_w4: H::Parameters, hasher_params_w5: H::Parameters, paths: Vec<Path<C, K>>, indices: Vec<F>, nullifier_hash: Vec<H::Output>, output_commitment: Vec<H::Output>, out_leaf_private: Vec<LeafPrivateInputs<F>>, out_leaf_public: Vec<LeafPublicInputs<F>>, out_pubkey: Vec<F>, ) -> Self
pub fn verify_input_var( hasher_params_w2_var: &HG::ParametersVar, hasher_params_w4_var: &HG::ParametersVar, hasher_params_w5_var: &HG::ParametersVar, leaf_private_var: &[LeafPrivateInputsVar<F>], inkeypair_var: &[KeypairVar<F, H, HG>], leaf_public_input_var: &LeafPublicInputsVar<F>, in_path_indices_var: &[FpVar<F>], in_path_elements_var: &[PathVar<F, C, HGT, LHGT, K>], in_nullifier_var: &[HG::OutputVar], set_gadget: &SetGadget<F>, ) -> Result<FpVar<F>, SynthesisError>
pub fn verify_output_var( hasher_params_w5_var: &HG::ParametersVar, output_commitment_var: &[HG::OutputVar], leaf_private_var: &[LeafPrivateInputsVar<F>], leaf_public_var: &[LeafPublicInputsVar<F>], out_pubkey_var: &[FpVar<F>], limit_var: &FpVar<F>, ) -> Result<FpVar<F>, SynthesisError>
pub fn verify_no_same_nul( in_nullifier_var: &[HG::OutputVar], ) -> Result<(), SynthesisError>
pub fn verify_input_invariant( public_amount_var: &FpVar<F>, sum_ins_var: &FpVar<F>, sum_outs_var: &FpVar<F>, ) -> Result<(), SynthesisError>
Trait Implementations§
Source§impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> Clone for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: PrimeField,
H: CRH,
HG: CRHGadget<H, F>,
C: MerkleConfig,
LHGT: CRHGadget<C::LeafH, F>,
HGT: CRHGadget<C::H, F>,
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> Clone for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: PrimeField,
H: CRH,
HG: CRHGadget<H, F>,
C: MerkleConfig,
LHGT: CRHGadget<C::LeafH, F>,
HGT: CRHGadget<C::H, F>,
Source§impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> ConstraintSynthesizer<F> for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: PrimeField,
H: CRH,
HG: CRHGadget<H, F>,
C: MerkleConfig,
LHGT: CRHGadget<C::LeafH, F>,
HGT: CRHGadget<C::H, F>,
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> ConstraintSynthesizer<F> for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: PrimeField,
H: CRH,
HG: CRHGadget<H, F>,
C: MerkleConfig,
LHGT: CRHGadget<C::LeafH, F>,
HGT: CRHGadget<C::H, F>,
Source§fn generate_constraints(
self,
cs: ConstraintSystemRef<F>,
) -> Result<(), SynthesisError>
fn generate_constraints( self, cs: ConstraintSystemRef<F>, ) -> Result<(), SynthesisError>
Drives generation of new constraints inside
cs.Auto Trait Implementations§
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> Freeze for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> RefUnwindSafe for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: RefUnwindSafe,
<H as CRH>::Parameters: RefUnwindSafe,
H: RefUnwindSafe,
HG: RefUnwindSafe,
LHGT: RefUnwindSafe,
HGT: RefUnwindSafe,
C: RefUnwindSafe,
<H as CRH>::Output: RefUnwindSafe,
<<C as Config>::LeafH as CRH>::Parameters: RefUnwindSafe,
<<C as Config>::H as CRH>::Parameters: RefUnwindSafe,
<<C as Config>::LeafH as CRH>::Output: RefUnwindSafe,
<<C as Config>::H as CRH>::Output: RefUnwindSafe,
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> !Send for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> !Sync for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> Unpin for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>
impl<F, H, HG, C, LHGT, HGT, const K: usize, const N_INS: usize, const N_OUTS: usize, const M: usize> UnwindSafe for VAnchorCircuit<F, H, HG, C, LHGT, HGT, K, N_INS, N_OUTS, M>where
F: UnwindSafe,
<H as CRH>::Parameters: UnwindSafe,
H: UnwindSafe,
HG: UnwindSafe,
LHGT: UnwindSafe,
HGT: UnwindSafe,
C: UnwindSafe,
<H as CRH>::Output: UnwindSafe,
<<C as Config>::LeafH as CRH>::Parameters: RefUnwindSafe,
<<C as Config>::H as CRH>::Parameters: RefUnwindSafe,
<<C as Config>::LeafH as CRH>::Output: UnwindSafe,
<<C as Config>::H as CRH>::Output: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more