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

feat(icicle): Add icicle MSM support #503

Merged
merged 5 commits into from
Jan 7, 2025
Merged

feat(icicle): Add icicle MSM support #503

merged 5 commits into from
Jan 7, 2025

Conversation

sagar-a16z
Copy link
Contributor

@sagar-a16z sagar-a16z commented Nov 15, 2024

  • Rebased feat(icicle): Add icicle msm support #322
  • Updated to latest icicle release
  • Fixed it to use the GPU correctly
  • Fall back to JOLT's CPU implementations when GPU is unavailable - much faster than the default CPU impl.
  • Added msm benchmarks
  • Overall Perf is up ~20%.

@wiz-a16z
Copy link

wiz-a16z bot commented Nov 15, 2024

Wiz Scan Summary

Scanner Findings
Vulnerability Finding Vulnerabilities
Data Finding Sensitive Data
Secret Finding Secrets
IaC Misconfiguration IaC Misconfigurations
Total

View scan details in Wiz

To detect these findings earlier in the dev lifecycle, try using Wiz Code VS Code Extension.

@sagar-a16z
Copy link
Contributor Author

sagar-a16z commented Nov 15, 2024

With the newest benchmark I added, the GPU perf is actually really good. (This is a WSL machine on a 5800X3D + 3080TI)

CPU

VariableBaseMSM::msm() [mode:JOLT CPU]
                        time:   [807.29 ms 810.86 ms 814.58 ms]

GPU

VariableBaseMSM::msm() [mode:Icicle]
                        time:   [153.71 ms 156.67 ms 159.43 ms]

It’s WAY faster. For some reason it's much slower when running the examples. Maybe because my CPU usage was low while this benchmark ran where as the CPU is pinned when running the examples or maybe because I have plenty of left over memory.

@sagar-a16z sagar-a16z force-pushed the sagar/icicle_msms branch 2 times, most recently from 8bc1af1 to 705070a Compare November 19, 2024 00:11
@sagar-a16z sagar-a16z changed the title WIP feat(icicle): Add icicle MSM support feat(icicle): Add icicle MSM support Dec 2, 2024
@sagar-a16z sagar-a16z marked this pull request as ready for review December 2, 2024 21:21
Copy link
Collaborator

@moodlezoup moodlezoup left a comment

Choose a reason for hiding this comment

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

great work! main question is: I think we need to move the icicle init into prove; otherwise if someone is e.g. loading the preprocessing from disk and running prove by itself, icicle won't be initialized. wdyt?

jolt-core/benches/msm.rs Outdated Show resolved Hide resolved
jolt-core/benches/msm.rs Outdated Show resolved Hide resolved
jolt-core/benches/msm_batch.rs Outdated Show resolved Hide resolved
Comment on lines 318 to 321
//TODO(sagar): This should be moved to a more appropriate place - icicle makes a network request
// which impacts prover time.
icicle::icicle_init();

Copy link
Collaborator

Choose a reason for hiding this comment

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

Should this be moved to prove?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I had moved this to preprocessing to keep off the critical path in my tests but you're right, it needs to be inside of prove but it can also remain inside of preprocessing. Calling it multiple times does nothing so should be safe to do.

@moodlezoup moodlezoup merged commit 1145ec4 into main Jan 7, 2025
10 checks passed
@sagar-a16z sagar-a16z deleted the sagar/icicle_msms branch January 7, 2025 22:17
@mratsim
Copy link

mratsim commented Jan 13, 2025

FYI, you might want to add modularity in terms of backend following ZAL:

This would allow you to switch the backend even for CPU (Constantine is 2x faster than Rust impls of BN254 and BLS12-381 for example):

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.

3 participants