Struct bitcoin::consensus::Params

source ·
pub struct Params {
Show 13 fields pub network: Network, pub bip16_time: u32, pub bip34_height: u32, pub bip65_height: u32, pub bip66_height: u32, pub rule_change_activation_threshold: u32, pub miner_confirmation_window: u32, pub pow_limit: Target, pub max_attainable_target: Target, pub pow_target_spacing: u64, pub pow_target_timespan: u64, pub allow_min_difficulty_blocks: bool, pub no_pow_retargeting: bool,
}
Expand description

Parameters that influence chain consensus.

Fields§

§network: Network

Network for which parameters are valid.

§bip16_time: u32

Time when BIP16 becomes active.

§bip34_height: u32

Block height at which BIP34 becomes active.

§bip65_height: u32

Block height at which BIP65 becomes active.

§bip66_height: u32

Block height at which BIP66 becomes active.

§rule_change_activation_threshold: u32

Minimum blocks including miner confirmation of the total of 2016 blocks in a retargeting period, (nPowTargetTimespan / nPowTargetSpacing) which is also used for BIP9 deployments. Examples: 1916 for 95%, 1512 for testchains.

§miner_confirmation_window: u32

Number of blocks with the same set of rules.

§pow_limit: Target
👎Deprecated since 0.32.0: field renamed to max_attainable_target

Proof of work limit value. It contains the lowest possible difficulty.

§max_attainable_target: Target

The maximum attainable target value for these params.

Not all target values are attainable because consensus code uses the compact format to represent targets (see CompactTarget).

Note that this value differs from Bitcoin Core’s powLimit field in that this value is attainable, but Bitcoin Core’s is not. Specifically, because targets in Bitcoin are always rounded to the nearest float expressible in “compact form”, not all targets are attainable. Still, this should not affect consensus as the only place where the non-compact form of this is used in Bitcoin Core’s consensus algorithm is in comparison and there are no compact-expressible values between Bitcoin Core’s and the limit expressed here.

§pow_target_spacing: u64

Expected amount of time to mine one block.

§pow_target_timespan: u64

Difficulty recalculation interval.

§allow_min_difficulty_blocks: bool

Determines whether minimal difficulty may be used for blocks or not.

§no_pow_retargeting: bool

Determines whether retargeting is disabled for this network or not.

Implementations§

source§

impl Params

source

pub const BITCOIN: Params = Params::MAINNET

The mainnet parameters (alias for Params::MAINNET).

source

pub const MAINNET: Params = _

The mainnet parameters.

source

pub const TESTNET: Params = _

👎Deprecated since 0.32.4: Use TESTNET3 instead

The testnet3 parameters.

source

pub const TESTNET3: Params = _

The testnet3 parameters.

source

pub const TESTNET4: Params = _

The testnet4 parameters.

source

pub const SIGNET: Params = _

The signet parameters.

source

pub const REGTEST: Params = _

The regtest parameters.

source

pub const fn new(network: Network) -> Self

Creates parameters set for the given network.

source

pub fn difficulty_adjustment_interval(&self) -> u64

Calculates the number of blocks between difficulty adjustments.

Trait Implementations§

source§

impl AsRef<Params> for Network

source§

fn as_ref(&self) -> &Params

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl AsRef<Params> for Params

source§

fn as_ref(&self) -> &Params

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl Clone for Params

source§

fn clone(&self) -> Params

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Params

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl From<&Network> for &'static Params

source§

fn from(value: &Network) -> Self

Converts to this type from the input type.
source§

impl From<&Network> for Params

source§

fn from(value: &Network) -> Self

Converts to this type from the input type.
source§

impl From<Network> for &'static Params

source§

fn from(value: Network) -> Self

Converts to this type from the input type.
source§

impl From<Network> for Params

source§

fn from(value: Network) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.