pub struct ValueCommitment(/* private fields */);Expand description
A commitment to a ValueSum.
§Consensus rules
The Zcash Protocol Spec requires Sapling Spend Descriptions and Output Descriptions to
not contain a small order ValueCommitment. However, the ValueCommitment type as
specified (and implemented here) may contain a small order point. In practice, it will
not occur:
ValueCommitment::derivewill only produce a small order point if both the givenNoteValueandValueCommitTrapdoorare zero. However, the only constructor available forValueCommitTrapdoorisValueCommitTrapdoor::random, which will produce zero with negligible probability (assuming a non-broken PRNG).ValueCommitment::from_bytes_not_small_orderenforces this by definition, and is the only constructor that can be used with data received over the network.
Implementations§
Source§impl ValueCommitment
impl ValueCommitment
Sourcepub fn derive(value: NoteValue, rcv: ValueCommitTrapdoor) -> Self
pub fn derive(value: NoteValue, rcv: ValueCommitTrapdoor) -> Self
Derives a ValueCommitment by $\mathsf{ValueCommit^{Sapling}}$.
Defined in Zcash Protocol Spec § 5.4.8.3: Homomorphic Pedersen commitments (Sapling and Orchard).
Sourcepub fn as_inner(&self) -> &ExtendedPoint
pub fn as_inner(&self) -> &ExtendedPoint
Returns the inner Jubjub point representing this value commitment.
This is public for access by zcash_proofs.
Sourcepub fn from_bytes_not_small_order(bytes: &[u8; 32]) -> CtOption<ValueCommitment>
pub fn from_bytes_not_small_order(bytes: &[u8; 32]) -> CtOption<ValueCommitment>
Deserializes a value commitment from its byte representation.
Returns None if bytes is an invalid representation of a Jubjub point, or the
resulting point is of small order.
This method can be used to enforce the “not small order” consensus rules defined in Zcash Protocol Spec § 4.4: Spend Descriptions and § 4.5: Output Descriptions.
Trait Implementations§
Source§impl Add<&ValueCommitment> for CommitmentSum
impl Add<&ValueCommitment> for CommitmentSum
Source§type Output = CommitmentSum
type Output = CommitmentSum
+ operator.Source§impl Add<&ValueCommitment> for ValueCommitment
impl Add<&ValueCommitment> for ValueCommitment
Source§impl AddAssign<&ValueCommitment> for CommitmentSum
impl AddAssign<&ValueCommitment> for CommitmentSum
Source§fn add_assign(&mut self, rhs: &ValueCommitment)
fn add_assign(&mut self, rhs: &ValueCommitment)
+= operation. Read moreSource§impl Clone for ValueCommitment
impl Clone for ValueCommitment
Source§fn clone(&self) -> ValueCommitment
fn clone(&self) -> ValueCommitment
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for ValueCommitment
impl Debug for ValueCommitment
Source§impl Sub<&ValueCommitment> for ValueCommitment
impl Sub<&ValueCommitment> for ValueCommitment
Source§impl SubAssign<&ValueCommitment> for CommitmentSum
impl SubAssign<&ValueCommitment> for CommitmentSum
Source§fn sub_assign(&mut self, rhs: &ValueCommitment)
fn sub_assign(&mut self, rhs: &ValueCommitment)
-= operation. Read moreSource§impl<'a> Sum<&'a ValueCommitment> for CommitmentSum
impl<'a> Sum<&'a ValueCommitment> for CommitmentSum
Source§fn sum<I: Iterator<Item = &'a ValueCommitment>>(iter: I) -> Self
fn sum<I: Iterator<Item = &'a ValueCommitment>>(iter: I) -> Self
Self from the elements by “summing up”
the items.Source§impl Sum<ValueCommitment> for CommitmentSum
impl Sum<ValueCommitment> for CommitmentSum
Source§fn sum<I: Iterator<Item = ValueCommitment>>(iter: I) -> Self
fn sum<I: Iterator<Item = ValueCommitment>>(iter: I) -> Self
Self from the elements by “summing up”
the items.Auto Trait Implementations§
impl Freeze for ValueCommitment
impl RefUnwindSafe for ValueCommitment
impl Send for ValueCommitment
impl Sync for ValueCommitment
impl Unpin for ValueCommitment
impl UnwindSafe for ValueCommitment
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.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> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.