pub struct ProverSolution<N>where
N: Network,{ /* private fields */ }Expand description
The prover solution for the coinbase puzzle from a prover.
Implementations§
Source§impl<N> ProverSolution<N>where
N: Network,
impl<N> ProverSolution<N>where
N: Network,
Sourcepub const fn new(
partial_solution: PartialSolution<N>,
proof: KZGProof<<N as Environment>::PairingCurve>,
) -> ProverSolution<N>
pub const fn new( partial_solution: PartialSolution<N>, proof: KZGProof<<N as Environment>::PairingCurve>, ) -> ProverSolution<N>
Initializes a new instance of the prover solution.
Sourcepub fn verify(
&self,
verifying_key: &VerifierKey<<N as Environment>::PairingCurve>,
epoch_challenge: &EpochChallenge<N>,
proof_target: u64,
) -> Result<bool, Error>
pub fn verify( &self, verifying_key: &VerifierKey<<N as Environment>::PairingCurve>, epoch_challenge: &EpochChallenge<N>, proof_target: u64, ) -> Result<bool, Error>
Returns true if the prover solution is valid.
Sourcepub const fn commitment(&self) -> PuzzleCommitment<N>
pub const fn commitment(&self) -> PuzzleCommitment<N>
Returns the commitment for the solution.
Sourcepub const fn proof(&self) -> &KZGProof<<N as Environment>::PairingCurve>
pub const fn proof(&self) -> &KZGProof<<N as Environment>::PairingCurve>
Returns the proof for the solution.
Sourcepub fn to_prover_polynomial(
&self,
epoch_challenge: &EpochChallenge<N>,
) -> Result<DensePolynomial<<<N as Environment>::PairingCurve as PairingEngine>::Fr>, Error>
pub fn to_prover_polynomial( &self, epoch_challenge: &EpochChallenge<N>, ) -> Result<DensePolynomial<<<N as Environment>::PairingCurve as PairingEngine>::Fr>, Error>
Returns the prover polynomial.
Trait Implementations§
Source§impl<N> Clone for ProverSolution<N>
impl<N> Clone for ProverSolution<N>
Source§fn clone(&self) -> ProverSolution<N>
fn clone(&self) -> ProverSolution<N>
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 moreSource§impl<N> Debug for ProverSolution<N>where
N: Network,
impl<N> Debug for ProverSolution<N>where
N: Network,
Source§impl<'de, N> Deserialize<'de> for ProverSolution<N>where
N: Network,
impl<'de, N> Deserialize<'de> for ProverSolution<N>where
N: Network,
Source§fn deserialize<D>(
deserializer: D,
) -> Result<ProverSolution<N>, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize<D>(
deserializer: D,
) -> Result<ProverSolution<N>, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
Deserializes the prover solution from a JSON-string or buffer.
Source§impl<N> Display for ProverSolution<N>where
N: Network,
impl<N> Display for ProverSolution<N>where
N: Network,
Source§impl<N> From<ProverSolution<N>> for Transmission<N>where
N: Network,
impl<N> From<ProverSolution<N>> for Transmission<N>where
N: Network,
Source§fn from(solution: ProverSolution<N>) -> Transmission<N>
fn from(solution: ProverSolution<N>) -> Transmission<N>
Converts the prover solution into a transmission.
Source§impl<N> FromBytes for ProverSolution<N>where
N: Network,
impl<N> FromBytes for ProverSolution<N>where
N: Network,
Source§impl<N> FromStr for ProverSolution<N>where
N: Network,
impl<N> FromStr for ProverSolution<N>where
N: Network,
Source§impl<N> Hash for ProverSolution<N>
impl<N> Hash for ProverSolution<N>
Source§impl<N> PartialEq for ProverSolution<N>
impl<N> PartialEq for ProverSolution<N>
Source§impl<N> Serialize for ProverSolution<N>where
N: Network,
impl<N> Serialize for ProverSolution<N>where
N: Network,
Source§fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
Serializes the prover solution to a JSON-string or buffer.
Source§impl<N> ToBytes for ProverSolution<N>where
N: Network,
impl<N> ToBytes for ProverSolution<N>where
N: Network,
impl<N> Copy for ProverSolution<N>
impl<N> Eq for ProverSolution<N>
impl<N> StructuralPartialEq for ProverSolution<N>where
N: Network,
Auto Trait Implementations§
impl<N> Freeze for ProverSolution<N>where
<<N as Environment>::PairingCurve as PairingEngine>::G1Affine: Freeze,
<N as Environment>::Field: Freeze,
<N as Environment>::Projective: Freeze,
impl<N> RefUnwindSafe for ProverSolution<N>where
<<N as Environment>::PairingCurve as PairingEngine>::G1Affine: RefUnwindSafe,
<N as Environment>::Field: RefUnwindSafe,
<N as Environment>::Projective: RefUnwindSafe,
impl<N> Send for ProverSolution<N>
impl<N> Sync for ProverSolution<N>
impl<N> Unpin for ProverSolution<N>where
<<N as Environment>::PairingCurve as PairingEngine>::G1Affine: Unpin,
<N as Environment>::Field: Unpin,
<N as Environment>::Projective: Unpin,
impl<N> UnwindSafe for ProverSolution<N>where
<<N as Environment>::PairingCurve as PairingEngine>::G1Affine: UnwindSafe,
<N as Environment>::Field: UnwindSafe,
<N as Environment>::Projective: 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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<'de, T> DeserializeExt<'de> for Twhere
T: DeserializeOwned,
impl<'de, T> DeserializeExt<'de> for Twhere
T: DeserializeOwned,
fn take_from_value<D>(
value: &mut Value,
field: &str,
) -> Result<T, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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> 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