Skip to content
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

SWIP-21: Reserve doubling #56

Open
wants to merge 15 commits into
base: master
Choose a base branch
from
Open

Conversation

ct-ctrl
Copy link
Collaborator

@ct-ctrl ct-ctrl commented Sep 16, 2024

this is to merge the swip-21 final draft into the SWIP repo to open it up for official review and comments.

Copy link
Member

@zelig zelig left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we need:

  • one or two diagrams
  • discussion about push/retrieve protocols and the non-effect of reserve doubling on their correctness

@0xCardinalError 0xCardinalError changed the title swip-21.md Add EIP: Reserve doubling #56 Sep 17, 2024
@0xCardinalError 0xCardinalError changed the title Add EIP: Reserve doubling #56 Add SWIP: Reserve doubling #56 Sep 17, 2024
wrong func name
@0xCardinalError
Copy link
Collaborator

We should probably mention that inclusion proofs will be checked "differently", as they are also dependent on "inProximity" function that checks bits of chunks. Or to be more precise they will get different depth than originally

for example

        if (!inProximity(entryProof2.proveSegment, _currentRevealRoundAnchor, winnerSelected.depth)) {
            revert OutOfDepthClaim(1);
        }

Winner is checked for depth, which actually is a revel struct, which has in it depth fetched from reported reveal.
So I suppose that we will also be checking sampling from increased reserve in this new feature.

@zelig
Copy link
Member

zelig commented Sep 18, 2024

We should probably mention that inclusion proofs will be checked "differently", as they are also dependent on "inProximity" function that checks bits of chunks. Or to be more precise they will get different depth than originally

for example

        if (!inProximity(entryProof2.proveSegment, _currentRevealRoundAnchor, winnerSelected.depth)) {
            revert OutOfDepthClaim(1);
        }

Winner is checked for depth, which actually is a revel struct, which has in it depth fetched from reported reveal. So I suppose that we will also be checking sampling from increased reserve in this new feature.

No, this does not change. the depth commited and revealed represents the depth of the playing reserve. The original address of the sampled chunk (coming from the proof) is correctly checked to match the anchor up to at least this depth. This is the retrievability validation proving that the chunk is located in the anchor's proximity within the committed depth.

Doubling the reserve means a node can play also when the sister neighbourhood is selected. It still must play with a sample of the chunks within the proximity of the anchor within the committed depth d. However, its own overlay is allowed to match the anchor up to only d-1 bits.

In general, operating with increased reserve means that registering a height m in the staking contract entitles your node to play if the difference between its proximity to the anchor and its committed depth is not greater than m. This is responsibility validation that is done as part of the reveal transaction.

@ldeffenb
Copy link

ldeffenb commented Sep 18, 2024

I see multiple (and necessary) mentions about "connecting to all peers in the sister neighborhood", but I suspect this will be problematic. The current kademlia attempts to connect to all nodes in the current neighborhood. This is good because the other nodes in the neighborhood are also trying to connect to us, and it "just works".

But consider a node that has doubled its reserve, it is now trying to connect to all immediate neighbors (as before), but now is also trying to connect to the nodes in the sister neighborhood as well. But the gotcha is that those nodes (at least, any that have not doubled) are NOT trying to connect to this node. So, all connections to the sister neighborhood nodes will be incoming connections to those peers which are purposely restricted so as not to overSaturate a node's connections. Without some kademlia changes, it may not be possible to achieve connections to "all" sister neighborhood nodes, and even less likely to be able to achieve (and maintain across peer connection periodic purges) this level of connections to cousin neighborhood nodes in a quadrupled (or more) configuration.

@zelig
Copy link
Member

zelig commented Sep 18, 2024

thanks for your feedback @ldeffenb

But consider a node that has doubled its reserve, it is now trying to connect to all immediate neighbors (as before), but now is also trying to connect to the nodes in the sister neighborhood as well. But the gotcha is that those nodes (at least, any that have not doubled) are NOT trying to connect to this node. So, all connections to the sister neighborhood nodes will be incoming connections to those peers which are purposely restricted so as not to overSaturate a node's connections.

like the jewish joke works:
1 this is not much more of a problem than in a nondoubled neighbourhoods, if 2 nodes are oversaturated then no connection is possible
2. neighbours can be checked for their height on the blockchain and can be made exempt
3. its only meant to be a few doubled nodes for each non-doubled one
4. there is no big harm in not being connected to all sister peers

Without some kademlia changes, it may not be possible to achieve connections to "all" sister neighborhood nodes, and even less likely to be able to achieve (and maintain across peer connection periodic purges) this level of connections to cousin neighborhood nodes in a quadrupled (or more) configuration.

This is kind of addressed in the text concluding that nodes are unlikely to go much farther ahead in doubling than the typical node. in other words the reserve size is expecyed to grow in a piecemeal fashion and uniformly

@zelig zelig changed the title Add SWIP: Reserve doubling #56 Add SWIP-21: Reserve doubling Sep 18, 2024
@0xCardinalError
Copy link
Collaborator

0xCardinalError commented Sep 20, 2024

No, this does not change. the depth commited and revealed represents the depth of the playing reserve.

thnx, I reread SWIP and comment and I got what was meant.

@0xCardinalError
Copy link
Collaborator

We should add some lists of needed Tests for this SWIP

@0xCardinalError 0xCardinalError changed the title Add SWIP-21: Reserve doubling Add SWIP-21: Reserve doubling #56 Sep 24, 2024
@0xCardinalError 0xCardinalError changed the title Add SWIP-21: Reserve doubling #56 Add SWIP-21: Reserve doubling Sep 24, 2024
Add clarity of how height must be factored in the calculation of effective stake.
@tamas6 tamas6 changed the title Add SWIP-21: Reserve doubling SWIP-21: Reserve doubling Oct 22, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants