-
Notifications
You must be signed in to change notification settings - Fork 170
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
Fip0081 gradual activation #967
Fip0081 gradual activation #967
Conversation
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.
I might be missing something obvious but introducing a state machine here seems like unnecessary complexity and state, e.g.
- Do we really need a pre-activation state given it's... erm... pre-activation?
- Why not compute a gamma directly from activation, length, and date, thereby avoiding not just the state but the numerical considerations you mention? Something like
$\gamma=0.7+\min(\max(0.3*\frac{(FIP \textunderscore activation \textunderscore date+activation \textunderscore len \textunderscore days) -datettime.today().days}{activation \textunderscore len \textunderscore days},0),0.3)$
Also, the while loop is underspecified as it could run with any frequency, but that's a bit pedantic esp. given your note on needing to choose a period. Regardless of the granularity, this should likely all be defined in epochs (i.e. activation epoch, activation_len_epochs, ...) to not be sensitive to clocks.
I don't disagree with anything you've stated, but this is just pseudocode. It likely has no correlation to how this would actually be implemented in Lotus, since things such as absolute dates are not available. I wrote it as a state machine because I thought it would be easy to understand. |
FIPS/fip-0081.md
Outdated
@@ -79,10 +79,28 @@ a reasonable lower bound on network collateral. | |||
|
|||
## Specification | |||
Factor the per-sector initial consensus pledge into two parts: a 70% share which divides by the baseline function like today, | |||
and a smaller 30% "simple" share which does not divide by the baseline function. | |||
and a smaller 30% "simple" share which does not divide by the baseline function. Gradually activate the change from the current | |||
to the target. |
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.
Small ask, but can we also describe the activation period? It's helpful to have the qualitative description as well as the pseudocode.
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.
yep, added, but if unclear or could use further revision lmk and I can update!
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. This is helpful in communicating the high level intention of a phase-in to humans. However the pseudocode as written can't function as a specification for implementers due to assuming a context for computation that doesn't match the chain's (which the PR description acknowledges). As such, I don't think we should merge this.
If we do want to merge something as a stepping stone to a full specification, I'd suggest avoiding pseudocode and just writing prose, with a TODO to actually specify how to implement that intent.
I've updated the description and removed the pseudocode. Is it clearer now? |
@@ -236,9 +281,5 @@ so the supply of storage is more than adequate to demand. | |||
|
|||
To be provided. | |||
|
|||
## TODO | |||
|
|||
- Implementation |
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 is still TODO. The description of intent is clear enough, but this currently lacks specification of how to achieve it.
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.
I tried to view the attached PDF, but could only see 9 blank pages. Can someone else check this? @kkarrancsu do you want to try sending me the file by another channel too?
Hmm, not sure what happened there but I pushed a new pdf that is hopefully uncorrupted. Will also share directly with you. |
The new one works for me. |
New PDF 👍 |
I've added a link to the draft implementation in the builtin-actors repository. Is it OK to move this FIP forward for consideration, while we continue to refine the draft implementation? |
Hi @jennijuju - gentle ping on this post Eth-CC! |
What do you mean by move this FIP forward? My original objection here still stands. The FIP does not specify how to achieve its outcome. From the draft implementation, I know that it has now been worked out how this can be achieved, but it's not represented in this document. This needs to be specified in the FIP. Linking to the code doesn't suffice for this. This document must specify:
I can lift my objection and allow this to merge as a draft, but the FIP will still not be ready for last call, so I don't want to mislead by doing that. |
@kkarrancsu - i agree with anorth, lmk if you want to do a pass tgt sometime this week! |
Hi @jennijuju - I've updated the Specification section to include a description of the necessary changes. Can you review and also help me understand how to think about Migration? |
FIPS/fip-0081.md
Outdated
The practical effect of this is that the sector initial pledge calculation will not tend to zero as the network baseline grows, but toward the `SectorInitialConsensusPledge` (30% of the pre-baseline-crossing total). When/if the baseline function exceeds network QAP, the per-sector initial pledge value will still decrease exponentially, but to this floor rather than toward zero. | ||
|
||
### Built-in Actors Change Specification | ||
In this section, we describe the changes required to the `builtin-actors` necessary to implement this update. The high level changes that need to occur is that the ramp configuration needs to be passed to the function which computes the consensus pledge. |
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.
Nit: first sentence is redundant.
FIPS/fip-0081.md
Outdated
|
||
### State Data Structures | ||
**Market Actor** | ||
1. `CurrentTotalPowerReturnParams` - Add ramp configuration parameters defined above to the `CurrentTotalPowerReturnParams` structure. |
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 is just a copy of the parameter/return shape defined by the power actor. I think it's sufficient to define the change for the power actor only. Clearly the actors that call into it need to use the right schema. The existence of this copy of the structure is just a code artefact.
FIPS/fip-0081.md
Outdated
but to this floor rather than toward zero. | ||
**Miner Actor** | ||
1. `NetworkPledgeInputs` - Add ramp configuration parameters defined above to the `NetworkPledgeInputs` structure. | ||
2. `CurrentTotalPowerReturn` - Add ramp configuration parameters defined above to the `CurrentTotalPowerReturn` structure. |
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.
Ditto
FIPS/fip-0081.md
Outdated
|
||
Under the updated formula for `SectorInitialConsensusPledge`, the network's current setting is `gamma=1.0`, which results in all of the `SectorInitialConsensusPledge` coming from `BaselineConsensusPledge`. | ||
|
||
We recommend updating gamma from its current value of 1.0 to the target value of 0.7 over an period of 1Y. The technical reason for this recommendation is that gamma has a direct effect on pledge - changing this gradually will prevent pledge from sharply increasing, which will negatively affect SPs. There are additional economic considerations which support this recommendation and are discussed [here](../resources/fip-0081/gradual_activation_rationale.pdf). |
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.
No "we recommend" in a FIP. Just clearly define what the specification is. The fact that the FIP authors recommend it is implied.
Hi @anorth @jennijuju - I think that the remaining changes are completed, can you take a look to see if it's ready to move to the next step? |
This pull request updates FIP0081 to include a ramped activation.
Pseudocode is provided for how a ramped activation could be realized. The pseudocode is written from the perspective of how to set the Gamma value (
gamma_day
) for each day of the network. This implies that there is a controller that is setting the Gamma value for each day and that controller would be active forever. It is possible tobreak
out of the loop after Gamma reaches the target value of 0.7.This pseudocode omits several realities that need to be taken into account when implementing in the network, including: