mirror of
https://github.com/bitcoin/bips.git
synced 2025-01-19 05:45:07 +01:00
bip141: Change 'block cost' to 'block weight'
The term 'block cost' led to confusion about the unit that it is expressed in, in that it expressed monetary cost. Change it to a more general term 'block weight'. This was discussed in the [2016-07-14 Bitcoin Core developer meeting](http://www.erisian.com.au/meetbot/bitcoin-core-dev/2016/bitcoin-core-dev.2016-07-14-19.00.html).
This commit is contained in:
parent
ab32c2a845
commit
83596de8ca
@ -108,13 +108,13 @@ If the version byte is 1 to 16, no further interpretation of the witness program
|
|||||||
|
|
||||||
Blocks are currently limited to 1,000,000 bytes (1MB) total size. We change this restriction as follows:
|
Blocks are currently limited to 1,000,000 bytes (1MB) total size. We change this restriction as follows:
|
||||||
|
|
||||||
''Block cost'' is defined as ''Base size'' * 3 + ''Total size''. (rationale<ref>Rationale of using a single composite constraint, instead of two separate limits such as 1MB base data and 3MB witness data: Using two separate limits would make mining and fee estimation nearly impossible. Miners would need to solve a complex non-linear optimization problem to find the set of transactions that maximize fees given both constraints, and wallets would not be able to know what to pay as it depends on which of the two conditions is most constrained by the time miners try to produce blocks with their transactions in. Another problem with such an approach is freeloading. Once a set of transactions hit the base data 1MB constraint, up to 3MB extra data could be added to the witness by just minimally increasing the fee. The marginal cost for extra witness space effectively becomes zero in that case.</ref>)
|
''Block weight'' is defined as ''Base size'' * 3 + ''Total size''. (rationale<ref>Rationale of using a single composite constraint, instead of two separate limits such as 1MB base data and 3MB witness data: Using two separate limits would make mining and fee estimation nearly impossible. Miners would need to solve a complex non-linear optimization problem to find the set of transactions that maximize fees given both constraints, and wallets would not be able to know what to pay as it depends on which of the two conditions is most constrained by the time miners try to produce blocks with their transactions in. Another problem with such an approach is freeloading. Once a set of transactions hit the base data 1MB constraint, up to 3MB extra data could be added to the witness by just minimally increasing the fee. The marginal cost for extra witness space effectively becomes zero in that case.</ref>)
|
||||||
|
|
||||||
''Base size'' is the block size in bytes with the original transaction serialization without any witness-related data, as seen by a non-upgraded node.
|
''Base size'' is the block size in bytes with the original transaction serialization without any witness-related data, as seen by a non-upgraded node.
|
||||||
|
|
||||||
''Total size'' is the block size in bytes with transactions serialized as described in [[bip-0144.mediawiki|BIP144]], including base data and witness data.
|
''Total size'' is the block size in bytes with transactions serialized as described in [[bip-0144.mediawiki|BIP144]], including base data and witness data.
|
||||||
|
|
||||||
The new rule is ''block cost'' ≤ 4,000,000.
|
The new rule is ''block weight'' ≤ 4,000,000.
|
||||||
|
|
||||||
==== Sigops ====
|
==== Sigops ====
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user