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

perf: PairingCheck for BN254, BLS12-381, BLS12-377 and BW6-761 #1365

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

Conversation

yelhousni
Copy link
Contributor

@yelhousni yelhousni commented Dec 20, 2024

Description

This PR saves the squarings previously needed in AssertFinalExpIsOne for PairingCheck for BN254, BLS12-381, BLS12-377 and BW6-761 elliptic curves.

See discussion #1347.

Type of change

  • New feature (non-breaking change which adds functionality)

How has this been tested?

TestPairingCheckTestSolve tests pass.

How has this been benchmarked?

The PR saves:

  • 371,175 scs for BLS12-381,
  • 238,793 scs for BN254,
  • 4,272 scs for BLS12-377 and
  • 1,195,718 scs for BW6-761.

Checklist:

  • I have performed a self-review of my code
  • I have commented my code, particularly in hard-to-understand areas
  • I have made corresponding changes to the documentation
  • I have added tests that prove my fix is effective or that my feature works
  • I did not modify files generated from templates
  • golangci-lint does not output errors locally
  • New and existing unit tests pass locally with my changes
  • Any dependent changes have been merged and published in downstream modules

@yelhousni yelhousni added the perf label Dec 20, 2024
@yelhousni yelhousni added this to the v0.11.N milestone Dec 20, 2024
@yelhousni yelhousni requested a review from ivokub December 20, 2024 22:00
@yelhousni yelhousni self-assigned this Dec 20, 2024
Copy link
Contributor

@shramee shramee left a comment

Choose a reason for hiding this comment

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

Look great to me!
Thanks for the great work! ❤️

@yelhousni yelhousni changed the title perf: PairingCheck for BN254 and BLS12-381 perf: PairingCheck for BN254, BLS12-381 and BLS12-377 Jan 9, 2025
@yelhousni yelhousni changed the title perf: PairingCheck for BN254, BLS12-381 and BLS12-377 perf: PairingCheck for BN254, BLS12-381, BLS12-377 and BW6-761 Jan 16, 2025
Copy link
Collaborator

@ivokub ivokub left a comment

Choose a reason for hiding this comment

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

Looks good to me. However I think currently there is too much copied implementation. It works, but in the future when we want to target more optimizations/refactors then I'm afraid we could have mismatch between different code paths.

I would try to refactor common parts into separate functions and then use function calls instead. I can have a try at it.

std/algebra/emulated/sw_bls12381/hints.go Outdated Show resolved Hide resolved
std/algebra/emulated/sw_bn254/hints.go Show resolved Hide resolved
std/algebra/emulated/sw_bw6761/hints.go Show resolved Hide resolved
std/algebra/emulated/sw_bls12381/pairing.go Show resolved Hide resolved
std/algebra/native/sw_bls12377/pairing2.go Outdated Show resolved Hide resolved
@yelhousni
Copy link
Contributor Author

Looks good to me. However I think currently there is too much copied implementation. It works, but in the future when we want to target more optimizations/refactors then I'm afraid we could have mismatch between different code paths.

I would try to refactor common parts into separate functions and then use function calls instead. I can have a try at it.

Right, I'll try to refactor some bits.

@yelhousni yelhousni requested a review from ivokub January 17, 2025 18:25
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants