pub enum GkrError<F> {
MalformedProof,
InvalidMask {
instance: usize,
instance_layer: LayerIndex,
},
NumInstancesMismatch {
given: usize,
proof: usize,
},
InvalidSumcheck {
layer: LayerIndex,
source: SumcheckError<F>,
},
CircuitCheckFailure {
claim: F,
output: F,
layer: LayerIndex,
},
}
Expand description
Error encountered during GKR protocol verification.
Variants§
MalformedProof
The proof is malformed.
InvalidMask
Mask has an invalid number of columns.
Fields
§
instance_layer: LayerIndex
Layer of the instance (but not necessarily the batch).
NumInstancesMismatch
There is a mismatch between the number of instances in the proof and the number of instances passed for verification.
InvalidSumcheck
There was an error with one of the sumcheck proofs.
CircuitCheckFailure
The circuit polynomial the verifier evaluated doesn’t match claim from sumcheck.
Trait Implementations§
Source§impl<F> Error for GkrError<F>
impl<F> Error for GkrError<F>
Source§fn source(&self) -> Option<&(dyn Error + 'static)>
fn source(&self) -> Option<&(dyn Error + 'static)>
Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§fn description(&self) -> &str
fn description(&self) -> &str
👎Deprecated since 1.42.0: use the Display impl or to_string()
Auto Trait Implementations§
impl<F> Freeze for GkrError<F>where
F: Freeze,
impl<F> RefUnwindSafe for GkrError<F>where
F: RefUnwindSafe,
impl<F> Send for GkrError<F>where
F: Send,
impl<F> Sync for GkrError<F>where
F: Sync,
impl<F> Unpin for GkrError<F>where
F: Unpin,
impl<F> UnwindSafe for GkrError<F>where
F: 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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more