pub struct ExpandedDifficulty(/* private fields */);Expand description
A 256-bit unsigned “expanded difficulty” value.
Used as a target threshold for the difficulty of a block::Hash.
§Consensus
The precise bit pattern of an ExpandedDifficulty value is
consensus-critical, because it is compared with the block::Hash.
Note that each CompactDifficulty value can be converted from a
range of ExpandedDifficulty values, because the precision of
the floating-point format requires rounding on conversion.
Therefore, consensus-critical code must perform the specified
conversions to CompactDifficulty, even if the original
ExpandedDifficulty values are known.
Callers should avoid constructing ExpandedDifficulty zero
values, because they are rejected by the consensus rules,
and cause some conversion functions to panic.
The difficulty filter is unchanged from Bitcoin, and is calculated using SHA-256d on the whole block header (including solutionSize and solution). The result is interpreted as a 256-bit integer represented in little-endian byte order, which MUST be less than or equal to the target threshold given by ToTarget(nBits).
Zcash Specification section 7.7.2.
Implementations§
Source§impl ExpandedDifficulty
impl ExpandedDifficulty
Sourcepub fn to_compact(self) -> CompactDifficulty
pub fn to_compact(self) -> CompactDifficulty
Calculate the CompactDifficulty for an expanded difficulty.
§Consensus
See ToCompact() in the Zcash Specification, and GetCompact()
in zcashd:
https://zips.z.cash/protocol/protocol.pdf#nbits
§Panics
If self is zero.
ExpandedDifficulty values are generated in two ways:
- conversion from
CompactDifficultyvalues, which rejects zeroes, and - difficulty adjustment calculations, which impose a non-zero minimum
target_difficulty_limit.
Neither of these methods yield zero values.
Trait Implementations§
Source§impl BytesInDisplayOrder for ExpandedDifficulty
impl BytesInDisplayOrder for ExpandedDifficulty
Source§fn bytes_in_serialized_order(&self) -> [u8; 32]
fn bytes_in_serialized_order(&self) -> [u8; 32]
Source§fn from_bytes_in_serialized_order(bytes: [u8; 32]) -> Self
fn from_bytes_in_serialized_order(bytes: [u8; 32]) -> Self
Source§fn bytes_in_display_order(&self) -> [u8; BYTE_LEN]
fn bytes_in_display_order(&self) -> [u8; BYTE_LEN]
Source§fn from_bytes_in_display_order(bytes_in_display_order: &[u8; BYTE_LEN]) -> Self
fn from_bytes_in_display_order(bytes_in_display_order: &[u8; BYTE_LEN]) -> Self
Source§impl Clone for ExpandedDifficulty
impl Clone for ExpandedDifficulty
Source§fn clone(&self) -> ExpandedDifficulty
fn clone(&self) -> ExpandedDifficulty
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for ExpandedDifficulty
impl Debug for ExpandedDifficulty
Source§impl Display for ExpandedDifficulty
impl Display for ExpandedDifficulty
Source§impl<T> Div<T> for ExpandedDifficulty
impl<T> Div<T> for ExpandedDifficulty
Source§impl From<ExpandedDifficulty> for CompactDifficulty
impl From<ExpandedDifficulty> for CompactDifficulty
Source§fn from(value: ExpandedDifficulty) -> Self
fn from(value: ExpandedDifficulty) -> Self
Source§impl From<ExpandedDifficulty> for U256
impl From<ExpandedDifficulty> for U256
Source§fn from(value: ExpandedDifficulty) -> Self
fn from(value: ExpandedDifficulty) -> Self
Source§impl From<U256> for ExpandedDifficulty
impl From<U256> for ExpandedDifficulty
Source§impl FromHex for ExpandedDifficulty
impl FromHex for ExpandedDifficulty
Source§impl Hash for ExpandedDifficulty
impl Hash for ExpandedDifficulty
Source§impl<T> Mul<T> for ExpandedDifficulty
impl<T> Mul<T> for ExpandedDifficulty
Source§type Output = ExpandedDifficulty
type Output = ExpandedDifficulty
* operator.Source§fn mul(self, rhs: T) -> ExpandedDifficulty
fn mul(self, rhs: T) -> ExpandedDifficulty
* operation. Read moreSource§impl Ord for ExpandedDifficulty
impl Ord for ExpandedDifficulty
Source§fn cmp(&self, other: &ExpandedDifficulty) -> Ordering
fn cmp(&self, other: &ExpandedDifficulty) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Source§impl PartialEq<ExpandedDifficulty> for Hash
impl PartialEq<ExpandedDifficulty> for Hash
Source§fn eq(&self, other: &ExpandedDifficulty) -> bool
fn eq(&self, other: &ExpandedDifficulty) -> bool
Is self equal to other?
See <ExpandedDifficulty as PartialOrd<block::Hash>::partial_cmp
for details.
Source§impl PartialEq<Hash> for ExpandedDifficulty
impl PartialEq<Hash> for ExpandedDifficulty
Source§impl PartialEq for ExpandedDifficulty
impl PartialEq for ExpandedDifficulty
Source§impl PartialOrd<ExpandedDifficulty> for Hash
impl PartialOrd<ExpandedDifficulty> for Hash
Source§fn partial_cmp(&self, other: &ExpandedDifficulty) -> Option<Ordering>
fn partial_cmp(&self, other: &ExpandedDifficulty) -> Option<Ordering>
How does self compare to other?
§Consensus
See <ExpandedDifficulty as PartialOrd<block::Hash>::partial_cmp
for details.
Source§impl PartialOrd<Hash> for ExpandedDifficulty
impl PartialOrd<Hash> for ExpandedDifficulty
Source§fn partial_cmp(&self, other: &Hash) -> Option<Ordering>
fn partial_cmp(&self, other: &Hash) -> Option<Ordering>
§Consensus
block::Hashes are compared with ExpandedDifficulty thresholds by
converting the hash to a 256-bit integer in little-endian order.
Greater values represent less work. This matches the convention in zcashd and bitcoin.
Source§impl PartialOrd for ExpandedDifficulty
impl PartialOrd for ExpandedDifficulty
Source§impl Sum for ExpandedDifficulty
impl Sum for ExpandedDifficulty
Source§fn sum<I: Iterator<Item = ExpandedDifficulty>>(iter: I) -> Self
fn sum<I: Iterator<Item = ExpandedDifficulty>>(iter: I) -> Self
Self from the elements by “summing up”
the items.Source§impl ToHex for &ExpandedDifficulty
impl ToHex for &ExpandedDifficulty
Source§fn encode_hex<T: FromIterator<char>>(&self) -> T
fn encode_hex<T: FromIterator<char>>(&self) -> T
self into the result. Lower case
letters are used (e.g. f9b4ca)Source§fn encode_hex_upper<T: FromIterator<char>>(&self) -> T
fn encode_hex_upper<T: FromIterator<char>>(&self) -> T
self into the result. Upper case
letters are used (e.g. F9B4CA)Source§impl ToHex for ExpandedDifficulty
impl ToHex for ExpandedDifficulty
Source§fn encode_hex<T: FromIterator<char>>(&self) -> T
fn encode_hex<T: FromIterator<char>>(&self) -> T
self into the result. Lower case
letters are used (e.g. f9b4ca)Source§fn encode_hex_upper<T: FromIterator<char>>(&self) -> T
fn encode_hex_upper<T: FromIterator<char>>(&self) -> T
self into the result. Upper case
letters are used (e.g. F9B4CA)Source§impl TryFrom<ExpandedDifficulty> for Work
impl TryFrom<ExpandedDifficulty> for Work
impl Copy for ExpandedDifficulty
impl Eq for ExpandedDifficulty
impl StructuralPartialEq for ExpandedDifficulty
Auto Trait Implementations§
impl Freeze for ExpandedDifficulty
impl RefUnwindSafe for ExpandedDifficulty
impl Send for ExpandedDifficulty
impl Sync for ExpandedDifficulty
impl Unpin for ExpandedDifficulty
impl UnwindSafe for ExpandedDifficulty
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<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<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
key and return true if they are equal.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
key and return true if they are equal.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> 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>
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>
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 moreSource§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.