pub enum SubProtocol<'a, E: Pairing> {
Show 30 variants
PoKBBSSignatureG1(PoKBBSSigG1SubProtocol<'a, E>),
VBAccumulatorMembership(VBAccumulatorMembershipSubProtocol<'a, E>),
VBAccumulatorNonMembership(VBAccumulatorNonMembershipSubProtocol<'a, E>),
PoKDiscreteLogs(SchnorrProtocol<'a, E::G1Affine>),
Saver(SaverProtocol<'a, E>),
BoundCheckLegoGroth16(BoundCheckLegoGrothProtocol<'a, E>),
R1CSLegogroth16Protocol(R1CSLegogroth16Protocol<'a, E>),
PSSignaturePoK(PSSignaturePoK<'a, E>),
PoKBBSSignature23G1(PoKBBSSigG1SubProtocol<'a, E>),
PoKBBSSignature23IETFG1(PoKBBSSigIETFG1SubProtocol<'a, E>),
BoundCheckBpp(BoundCheckBppProtocol<'a, E::G1Affine>),
BoundCheckSmc(BoundCheckSmcProtocol<'a, E>),
BoundCheckSmcWithKV(BoundCheckSmcWithKVProtocol<'a, E::G1Affine>),
Inequality(InequalityProtocol<'a, E::G1Affine>),
DetachedAccumulatorMembership(DetachedAccumulatorMembershipSubProtocol<'a, E>),
DetachedAccumulatorNonMembership(DetachedAccumulatorNonMembershipSubProtocol<'a, E>),
KBUniversalAccumulatorMembership(KBUniversalAccumulatorMembershipSubProtocol<'a, E>),
KBUniversalAccumulatorNonMembership(KBUniversalAccumulatorNonMembershipSubProtocol<'a, E>),
VBAccumulatorMembershipCDH(VBAccumulatorMembershipCDHSubProtocol<'a, E>),
VBAccumulatorNonMembershipCDH(VBAccumulatorNonMembershipCDHSubProtocol<'a, E>),
KBUniversalAccumulatorMembershipCDH(KBUniversalAccumulatorMembershipCDHSubProtocol<'a, E>),
KBUniversalAccumulatorNonMembershipCDH(KBUniversalAccumulatorNonMembershipCDHSubProtocol<'a, E>),
KBPositiveAccumulatorMembership(KBPositiveAccumulatorMembershipSubProtocol<'a, E>),
KBPositiveAccumulatorMembershipCDH(KBPositiveAccumulatorMembershipCDHSubProtocol<'a, E>),
PoKOfBBDT16MAC(PoKOfMACSubProtocol<'a, E::G1Affine>),
PoKDiscreteLogsG2(SchnorrProtocol<'a, E::G2Affine>),
VBAccumulatorMembershipKV(VBAccumulatorMembershipKVSubProtocol<E::G1Affine>),
KBUniversalAccumulatorMembershipKV(KBUniversalAccumulatorMembershipKVSubProtocol<E::G1Affine>),
KBUniversalAccumulatorNonMembershipKV(KBUniversalAccumulatorNonMembershipKVSubProtocol<E::G1Affine>),
VeTZ21(VeTZ21Protocol<'a, E::G1Affine>),
}Expand description
Various sub-protocols that are executed to create a StatementProof which are then combined to
form a Proof
Variants§
PoKBBSSignatureG1(PoKBBSSigG1SubProtocol<'a, E>)
For BBS+ signature in group G1
VBAccumulatorMembership(VBAccumulatorMembershipSubProtocol<'a, E>)
VBAccumulatorNonMembership(VBAccumulatorNonMembershipSubProtocol<'a, E>)
PoKDiscreteLogs(SchnorrProtocol<'a, E::G1Affine>)
Saver(SaverProtocol<'a, E>)
For verifiable encryption using SAVER
BoundCheckLegoGroth16(BoundCheckLegoGrothProtocol<'a, E>)
For range proof using LegoGroth16
R1CSLegogroth16Protocol(R1CSLegogroth16Protocol<'a, E>)
PSSignaturePoK(PSSignaturePoK<'a, E>)
PoKBBSSignature23G1(PoKBBSSigG1SubProtocol<'a, E>)
For BBS signature in group G1
PoKBBSSignature23IETFG1(PoKBBSSigIETFG1SubProtocol<'a, E>)
BoundCheckBpp(BoundCheckBppProtocol<'a, E::G1Affine>)
For range proof using Bulletproofs++
BoundCheckSmc(BoundCheckSmcProtocol<'a, E>)
For range proof using set-membership check
BoundCheckSmcWithKV(BoundCheckSmcWithKVProtocol<'a, E::G1Affine>)
For range proof using set-membership check with keyed verification
Inequality(InequalityProtocol<'a, E::G1Affine>)
To prove inequality of a signed message with a public value
DetachedAccumulatorMembership(DetachedAccumulatorMembershipSubProtocol<'a, E>)
DetachedAccumulatorNonMembership(DetachedAccumulatorNonMembershipSubProtocol<'a, E>)
KBUniversalAccumulatorMembership(KBUniversalAccumulatorMembershipSubProtocol<'a, E>)
KBUniversalAccumulatorNonMembership(KBUniversalAccumulatorNonMembershipSubProtocol<'a, E>)
VBAccumulatorMembershipCDH(VBAccumulatorMembershipCDHSubProtocol<'a, E>)
VBAccumulatorNonMembershipCDH(VBAccumulatorNonMembershipCDHSubProtocol<'a, E>)
KBUniversalAccumulatorMembershipCDH(KBUniversalAccumulatorMembershipCDHSubProtocol<'a, E>)
KBUniversalAccumulatorNonMembershipCDH(KBUniversalAccumulatorNonMembershipCDHSubProtocol<'a, E>)
KBPositiveAccumulatorMembership(KBPositiveAccumulatorMembershipSubProtocol<'a, E>)
KBPositiveAccumulatorMembershipCDH(KBPositiveAccumulatorMembershipCDHSubProtocol<'a, E>)
PoKOfBBDT16MAC(PoKOfMACSubProtocol<'a, E::G1Affine>)
PoKDiscreteLogsG2(SchnorrProtocol<'a, E::G2Affine>)
VBAccumulatorMembershipKV(VBAccumulatorMembershipKVSubProtocol<E::G1Affine>)
KBUniversalAccumulatorMembershipKV(KBUniversalAccumulatorMembershipKVSubProtocol<E::G1Affine>)
KBUniversalAccumulatorNonMembershipKV(KBUniversalAccumulatorNonMembershipKVSubProtocol<E::G1Affine>)
VeTZ21(VeTZ21Protocol<'a, E::G1Affine>)
Implementations§
Source§impl<'a, E: Pairing> SubProtocol<'a, E>
impl<'a, E: Pairing> SubProtocol<'a, E>
pub fn challenge_contribution<W: Write>( &self, writer: W, ) -> Result<(), ProofSystemError>
Trait Implementations§
Source§impl<'a, E: Clone + Pairing> Clone for SubProtocol<'a, E>
impl<'a, E: Clone + Pairing> Clone for SubProtocol<'a, E>
Source§fn clone(&self) -> SubProtocol<'a, E>
fn clone(&self) -> SubProtocol<'a, E>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreimpl<'a, E: Pairing> StructuralPartialEq for SubProtocol<'a, E>
Auto Trait Implementations§
impl<'a, E> Freeze for SubProtocol<'a, E>
impl<'a, E> RefUnwindSafe for SubProtocol<'a, E>where
<E as Pairing>::G1Affine: RefUnwindSafe,
<E as Pairing>::ScalarField: RefUnwindSafe,
<E as Pairing>::G2Affine: RefUnwindSafe,
<E as Pairing>::TargetField: RefUnwindSafe,
impl<'a, E> Send for SubProtocol<'a, E>
impl<'a, E> Sync for SubProtocol<'a, E>
impl<'a, E> Unpin for SubProtocol<'a, E>
impl<'a, E> UnwindSafe for SubProtocol<'a, E>where
<E as Pairing>::G1Affine: UnwindSafe + RefUnwindSafe,
<E as Pairing>::ScalarField: UnwindSafe + RefUnwindSafe,
<E as Pairing>::G2Affine: UnwindSafe + RefUnwindSafe,
<E as Pairing>::TargetField: UnwindSafe,
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> Upcastable for T
impl<T> Upcastable for T
Source§fn upcast_any_ref(&self) -> &(dyn Any + 'static)
fn upcast_any_ref(&self) -> &(dyn Any + 'static)
upcast ref
Source§fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
upcast mut ref