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

Initial implementation of Poisson Sortition #2084

Merged
merged 16 commits into from
Jun 26, 2020
Merged

Conversation

Kubuxu
Copy link
Contributor

@Kubuxu Kubuxu commented Jun 21, 2020

TODO:

  • Fix debug_advance
  • Propagate wincount to actors
  • Fix TestDealMining

Copy link
Member

@davidad davidad left a comment

Choose a reason for hiding this comment

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

Try as I might, and despite several potential pitfalls, I cannot spot a single bug in this implementation. Couldn't have done it better myself 💯🙏☺️

chain/types/electionproof.go Outdated Show resolved Hide resolved
chain/types/electionproof_test.go Outdated Show resolved Hide resolved
chain/types/electionproof.go Outdated Show resolved Hide resolved
@Kubuxu Kubuxu force-pushed the feat/poiss-sortition branch from 8df2e78 to dea60d8 Compare June 22, 2020 01:09
Copy link
Member

@davidad davidad left a comment

Choose a reason for hiding this comment

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

refactored structure still looks correct to me 👍

chain/types/electionproof.go Outdated Show resolved Hide resolved
chain/types/electionproof.go Outdated Show resolved Hide resolved
chain/types/electionproof.go Outdated Show resolved Hide resolved
chain/types/electionproof.go Outdated Show resolved Hide resolved
Jakub Sztandera added 8 commits June 23, 2020 16:24
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
As it turns out `big.Int#Mul` doesn't like it when you reuse input as
output.

```
name         old time/op    new time/op    delta
WinCounts-8    4.56µs ± 1%    3.90µs ± 2%  -14.44%  (p=0.000 n=9+10)

name         old alloc/op   new alloc/op   delta
WinCounts-8    3.50kB ± 0%    1.15kB ± 0%  -67.23%  (p=0.000 n=10+10)

name         old allocs/op  new allocs/op  delta
WinCounts-8      45.0 ± 0%      24.0 ± 0%  -46.67%  (p=0.000 n=10+10)
```

Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
@Kubuxu Kubuxu force-pushed the feat/poiss-sortition branch from 69ac1dc to 2b597fb Compare June 23, 2020 14:24
Jakub Sztandera added 2 commits June 23, 2020 16:33
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
@Kubuxu Kubuxu force-pushed the feat/poiss-sortition branch from 29bfd8a to 30135f9 Compare June 23, 2020 18:08
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
@Kubuxu Kubuxu force-pushed the feat/poiss-sortition branch from 30135f9 to 2165728 Compare June 23, 2020 18:10
Jakub Sztandera added 2 commits June 23, 2020 20:37
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
@Kubuxu Kubuxu force-pushed the feat/poiss-sortition branch from 726755d to 19ed695 Compare June 23, 2020 18:37
@Kubuxu Kubuxu marked this pull request as ready for review June 23, 2020 18:43
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Copy link
Contributor

@magik6k magik6k left a comment

Choose a reason for hiding this comment

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

Couple of nitpicks. I didn't go very deep into the math, it feels like it does the correct thing, but I'm mostly putting my trust in @davidad saying it's correct

Probably want @whyrusleeping to have a look at this before merging

chain/store/weight.go Outdated Show resolved Hide resolved
chain/store/weight.go Outdated Show resolved Hide resolved
chain/store/weight.go Outdated Show resolved Hide resolved
chain/types/bigint_test.go Outdated Show resolved Hide resolved
chain/gen/gen.go Outdated Show resolved Hide resolved
Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
Copy link
Contributor

@arajasek arajasek left a comment

Choose a reason for hiding this comment

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

Math seems good, though I'm guessing the big Mults and Divs will be slow...probably not the critical path, though

Signed-off-by: Jakub Sztandera <kubuxu@protocol.ai>
@Kubuxu Kubuxu force-pushed the feat/poiss-sortition branch from 91831f4 to 4895c89 Compare June 24, 2020 17:51
@Kubuxu
Copy link
Contributor Author

Kubuxu commented Jun 24, 2020

The whole sortition for 100% miner (the most expensive) take 3.8μs.

@magik6k magik6k merged commit 2db8611 into next Jun 26, 2020
@magik6k magik6k deleted the feat/poiss-sortition branch June 26, 2020 10:26
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