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

MSM optimization #40

Closed
wants to merge 5 commits into from
Closed

Conversation

Brechtpd
Copy link

@Brechtpd Brechtpd commented Mar 8, 2022

Depends on privacy-scaling-explorations/pairing#7, which should be merged first so this doesn't need to depend on any external repo's.

Credit for the core ideas behind these optimizations to Zac Williamson/Barretenberg. The implementation in this PR is based on barretenberg (and I think most other implementations doing similar things are as well) which contains comments that largely explain things pretty well, other references mainly used to complement those comments:

More info inside arithmetic_msm.rs, but the main speedups are from:

  • Using affine point addition for the bucket additions
  • Use of endomorphism to reduce half number of rounds
  • Use of WNAF represenation of the coefficients to half the number of buckets

On my computer it's around twice as fast as best_multiexp but haven't done a lot of testing yet on other computers with more cores.

The new implementation is used inside the prover, although for the best performance a shared cache object needs to be shared:

  • Ideally can be shared between different proof generations.
  • Needs to be mutable because the data is used as a scratch buffer so allocations aren't necessary.

Because the bases were already stored in Params I just made that object mutable everywhere where needed but I'm not sure if that's the best idea. Perhaps a separate object may make more sense.

@Brechtpd Brechtpd marked this pull request as ready for review March 10, 2022 01:41
@Brechtpd Brechtpd changed the title [WIP] MSM optimization MSM optimization Mar 10, 2022
@barryWhiteHat barryWhiteHat added the benchmarks Triggers a long running prover benchmark label Mar 11, 2022
@barryWhiteHat barryWhiteHat added benchmarks Triggers a long running prover benchmark and removed benchmarks Triggers a long running prover benchmark labels Mar 14, 2022
@Brechtpd
Copy link
Author

The code coverage currently fails. Because everything else seems to run fine I think it's because the code coverage runs with --all-features and so also enables the x86 specific assembly (I don't think anything else enables those features). I enabled those features (disabled by default) here because they weren't yet for testing (and I added a new prefetch feature that also depends on some x86 assembly).

Does anyone know if the ci machine supports x86 instructions?

@barryWhiteHat
Copy link

Does anyone know if the ci machine supports x86 instructions?

@AronisAt79

Could you also chekc why the bench i snot running here :)

@AronisAt79 AronisAt79 added benchmarks Triggers a long running prover benchmark and removed benchmarks Triggers a long running prover benchmark labels Mar 16, 2022
@AronisAt79
Copy link

@Brechtpd, @barryWhiteHat

during halo2 automated benches implementation, we had agreed that the tests will be triggered from kzg-rebase branch. Therefore, the pr that introduced the workflow code was only merged with kzg-rebase. Now this branch is obsolete? I thought that halo2 optimizations would be submitted via branches sourcing from kzg-rebase. Was that not the case? Regardless of that, there is still a needed fix on the workflow. Where should it be directed?

@barryWhiteHat
Copy link

thought that halo2 optimizations would be submitted via branches sourcing from kzg-rebase. Was that not the case?

Nah we switched to schplonk you can get that by just removing the flag as its default.

Regardless of that, there is still a needed fix on the workflow. Where should it be directed?

Not sure probably just good to remove the kzg-rebase branch from benchmarks and just use master.

@AronisAt79
Copy link

thought that halo2 optimizations would be submitted via branches sourcing from kzg-rebase. Was that not the case?

Nah we switched to schplonk you can get that by just removing the flag as its default.

Regardless of that, there is still a needed fix on the workflow. Where should it be directed?

Not sure probably just good to remove the kzg-rebase branch from benchmarks and just use master.
@barryWhiteHat
Thanks! It is clear. I will merge the proper workflow to master

@AronisAt79
Copy link

@Brechtpd @barryWhiteHat
necessary adaptations of the workflow yml file have been merged to main branch via #48.

@barryWhiteHat barryWhiteHat added benchmarks Triggers a long running prover benchmark and removed benchmarks Triggers a long running prover benchmark labels Mar 17, 2022
@therealyingtong therealyingtong requested review from han0110 and therealyingtong and removed request for han0110 March 18, 2022 11:06
@jonathanpwang
Copy link

What's the status of this PR? It doesn't seem like there's any blockers, and a faster MSM would certainly be very nice. @Brechtpd

@Brechtpd
Copy link
Author

Ready for review but yeah it's been a while. :)

However, I believe the fastest approach will very likely exploit the fact that in plonk many MSMs are done over the same bases (zcash#641), instead of just optimizing a single MSM as much as possible as in this PR. I think it's probably best to analyze the combined MSM approach and check its performance before continuing with this PR, and see if the approach in this PR still makes sense/is compatible with the combined approach.

@jonathanpwang
Copy link

Ah thanks for pointing out that other issue. That is very interesting. I can't guess one way or the other which would end up being faster for the halo2 particular use case. Something to investigate in the future...

@CPerezz
Copy link
Member

CPerezz commented Dec 12, 2022

Should we tske a look @Brechtpd ????

@Brechtpd
Copy link
Author

I believe some people (kilic if I remember correctly) already started looking into this but it is a bit complex and pretty low priority so I guess the review never got finished.

In any case, at this point would definitely first look into the combined MSM approach and then potentially integrate that into this PR as that will require a different set of changes which are potentially simpler.

@CPerezz
Copy link
Member

CPerezz commented Dec 22, 2022

@kilic any input on that???

@kilic
Copy link

kilic commented Feb 3, 2023

@kilic any input on that???

@CPerezz @jonathanpwang

This PR is a bit old and using pse/pairing as backend the one we used before we move to pse/halo2curves. Now trying to rebase it or possibly move it to pse/halo2curves with recent endomorhism features that covers both pasta and bn and is about to be added with privacy-scaling-explorations/halo2curves#24.

@kilic
Copy link

kilic commented Feb 13, 2023

@Brechtpd Can you confirm msm tests are passing at your side? I cannot hit expected results. I'm trying to debugging but maybe you can spot the issue much faster

@Brechtpd
Copy link
Author

I'm having some trouble getting things building again because of old packages for some reason. I still had an old checkout and for some reason that does have test_commit_lagrange and test_roundtrip failing, but I don't remember there being any issues (but yeah, it's been a while so don't know for sure). The tests were working here on github as can still be seen, though the details have been purged because too old presumably. Not sure what's going on unfortunately.

@kilic
Copy link

kilic commented Feb 14, 2023

trouble getting things building again because of old packages for some reason. I still had an old checkout and for some reason that does have test_commit_lagrange and test_roundtrip failing, but I don't remember there being any issues (but yeah, it's been a while so don't know for sure). The tests were working here on github as can still be seen, though the details have been purged because too old presumably. Not sure what's going on unfortunately.

I see. No worries. I think I'm getting closer

@CPerezz
Copy link
Member

CPerezz commented Mar 7, 2023

Closing in favour of privacy-scaling-explorations/halo2curves#29

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
benchmarks Triggers a long running prover benchmark
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

7 participants