-
Notifications
You must be signed in to change notification settings - Fork 5.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
EIP-649: Byzantium Difficulty Bomb Delay and Block Reward Reduction #669
Merged
+113
−38
Merged
Changes from 16 commits
Commits
Show all changes
27 commits
Select commit
Hold shift + click to select a range
fc748cc
Add template for EIP #649
5chdn 6aa9951
Update EIP #649
5chdn 33fc59d
EIP Number for #649
5chdn 0b12843
Replace #186 with eip-649
5chdn 5fd71ef
Wording and formatting.
5chdn ee262a3
Consider 649 instead of #186.
5chdn 9c29817
Fix EIP link
5chdn b48d836
Use the byzantium fork block number.
5chdn a37720f
Move eip-649 to accepted as per CDM-22
5chdn ca7cdac
Merge branch 'master' into a5-eip-649
5chdn e9f741a
Clarify motivation behind block reward structure, ref #186
5chdn cab7b1f
Ensure fake block number is not negative
5chdn 7a946e0
Avoid negative block numbers, ref #649.
5chdn 2708d37
Merge upstream master
5chdn 3eaf90c
Add EIP #649 to Byzantium Meta EIP #609
5chdn ce61f00
Change EIP #649 status to accepted, ref #688
5chdn c82890e
Improve wording for exact block number targeted, ref #649.
5chdn 46368ac
Merge myself.
5chdn 03deb55
Update existing implementations
5chdn 5cd7381
Improve title to make sure the issuance is not reduced, ref #186
5chdn 619b19c
Add yellow paper and parity implementations.
5chdn b587225
Change status to Final
5chdn d46dd25
Add other notable implementations
5chdn 6a7aa9f
Add tests
5chdn c5b49c6
Add missing core dev meeting links
5chdn d89b6d1
Merge README.md
5chdn 0ea86f8
Clean up formatting of README.md
5chdn File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
## Preamble | ||
|
||
EIP: 649 | ||
Title: Metropolis Difficulty Bomb Delay and Issuance Reduction | ||
Authors: Afri Schoedon, Vitalik Buterin | ||
Type: Standard Track | ||
Category: Core | ||
Status: Accepted | ||
Created: 2017-06-21 | ||
Replaces: 186 | ||
|
||
## Simple Summary | ||
The average block times are increasing due to the difficulty bomb (also known as the "_ice age_") slowly accelerating. This EIP proposes to delay the difficulty bomb for approximately one and a half year and to reduce the block rewards with the Byzantium fork, the first part of the Metropolis fork. | ||
|
||
## Abstract | ||
After `BYZANTIUM_FORK_BLKNUM` the client will calculate the difficulty based on a fake block number suggesting the client that the difficulty bomb is adjusting around 3 million blocks later than previously specified with the Homestead fork. Furthermore, block rewards will be adjusted to a base of 3 ETH, uncle and nephew rewards will be adjusted accordingly. | ||
|
||
## Motivation | ||
The Casper development and switch to proof-of-stake is delayed, the Ethash proof-of-work should be feasible for miners and allow sealing new blocks every 15 seconds on average for another one and a half years. With the delay of the ice age, there is a desire to not suddenly also increase miner rewards. The difficulty bomb has been known about for a long time and now it's going to stop from happening. In order to maintain stability of the system, a block reward reduction that offsets the ice age delay would leave the system in the same general state as before. Reducing the reward also decreases the likelihood of a miner driven chain split as Ethereum approaches proof-of-stake. | ||
|
||
## Specification | ||
#### Relax Difficulty with Fake Block Number | ||
For the purposes of `calc_difficulty`, simply replace the use of `block.number`, as used in the exponential ice age component, with the formula: | ||
|
||
fake_block_number = max(0, block.number - 3_000_000) if block.number >= BYZANTIUM_FORK_BLKNUM else block.number | ||
|
||
#### Adjust Block, Uncle, and Nephew rewards | ||
To add an issuance reduction, adjust the block reward to `new_block_reward`, where | ||
|
||
new_block_reward = 3_000_000_000_000_000_000 if block.number >= BYZANTIUM_FORK_BLKNUM else block.reward | ||
|
||
(3E18 wei, or 3,000,000,000,000,000,000 wei, or 3 ETH). | ||
|
||
Analogue, if an uncle is included in a block for `block.number >= BYZANTIUM_FORK_BLKNUM` such that `block.number - uncle.number = k`, the uncle reward is | ||
|
||
new_uncle_reward = (8 - k) * new_block_reward / 8 | ||
|
||
This is the existing pre-Metropolis formula for uncle rewards, simply adjusted with `new_block_reward`. | ||
|
||
The nephew reward for `block.number >= BYZANTIUM_FORK_BLKNUM` is | ||
|
||
new_nephew_reward = new_block_reward / 32 | ||
|
||
This is the existing pre-Metropolis formula for nephew rewards, simply adjusted with `new_block_reward`. | ||
|
||
## Rationale | ||
This will delay the ice age by 42 million seconds (approximately 1.4 years), so the chain would be back at 30 second block times at the end of 2018. An alternate proposal was to add special rules to the difficulty calculation to effectively _pause_ the difficulty between different blocks. This would lead to similar results. | ||
|
||
This was previously discussed at All Core Devs Meeting [#09](https://github.com/ethereum/pm/blob/master/All%20Core%20Devs%20Meetings/Meeting%209.md#metropolis-timing-and-roadmap-discussion), [#12](https://github.com/ethereum/pm/blob/master/All%20Core%20Devs%20Meetings/Meeting%2012.md#5-metropolis-update), [#13](https://github.com/ethereum/pm/blob/master/All%20Core%20Devs%20Meetings/Meeting%2013.md#3-eip-186-reduce-eth-issuance-before-proof-of-stake-hudson), and [#14](https://github.com/ethereum/pm/blob/master/All%20Core%20Devs%20Meetings/Meeting%2014.md#1-eip-186-reduce-eth-issuance-before-proof-of-stake-core-devs). Consensus on the specification was achieved in All Core Devs Meeting [#19](https://github.com/ethereum/pm/blob/master/All%20Core%20Devs%20Meetings/Meeting%2019.md) and specification drafted in EIP issue [#649](https://github.com/ethereum/EIPs/issues/649). It was decided to replace EIP [#186](https://github.com/ethereum/EIPs/issues/186) and include the issuance reduction along with the difficulty bomb delay in All Core Devs Meeting [#20](#) and [#21](#); accepted in [#22](#). | ||
|
||
## Backwards Compatibility | ||
This EIP is not forward compatible and introduces backwards incompatibilities in the difficulty calculation, as well as the block, uncle and nephew reward structure. Therefore, it should be included in a scheduled hardfork at a certain block number. It's suggested to include this EIP in the first of the two Metropolis hard-forks, the _Byzantium_ fork. | ||
|
||
## Test Cases | ||
No test cases exist yet. But will be easy to set up based on the rules specified above. | ||
|
||
## Implementation | ||
None existing client implementation exists yet. | ||
|
||
## Copyright | ||
Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/). |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This should be "Starting with".
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks.