Skip to main content
Version: Next

Performance and Benchmarks

Circom

In summary:
Both native witness generation and proof generation are generally faster than snarkjs in the browser, with potential speed improvements of up to 20 times.
However, performance varies across different circuits. We recommend developers benchmark their custom circuits before selecting tools for app development.

warning

iOS

Benchmarks on an iPhone 16 Pro (2024).

Witness generationwitnesscalccircom-witnesscalcwasmerw2csnarkjs
Keccak256142.1 ms (~1x)75.4 ms (~2x)287.7 ms (slower)140 ms (~1x)147.1 ms
SHA25641 ms (~2x)51.3 ms (~1.7x)171.3 ms (slower)93.9 ms (~1x)91.8 ms
RSA153 ms (~19x)-2937.5 ms (~1x)2312.3 ms (~1.2x)2979.5 ms
Semaphore22 ms (~3.5x)14.6 ms (~5.3x)266.5 ms (slower)38.9 ms (~2x)77.6 ms
Anon Aadhaar285.1 ms-3284.7 ms1490.8 ms-
Proof generationrapidsnarkark-workssnarkjs
Keccak256630.3 ms (~8.2x)956.9 ms (~5.4x)5182.1 ms
SHA256186.7 ms (~8.2x)498.6 ms (~3x)1487 ms
RSA749.1 ms (~8.8x)2250.8 ms (~3x)6604.5 ms
Semaphore143.3 ms (~6.9x)151.4 ms (~6.6x)1001.6 ms
Anon Aadhaar3131.7 ms10681.6 ms-

Android

Benchmarks on an Samsung S23 Ultra (2023).

Witness generationwitnesscalccircom-witnesscalcwasmerw2csnarkjs
Keccak256101.4 ms (~3x)71 ms (~4x)507.3 ms (slower)210.5 ms (~1.3x)292.3 ms
SHA25629 ms (~5x)44 ms (~3.5x)271.6 ms (slower)106.9 ms (~1.4x)157.9 ms
RSA155 ms (~25x)-4723 ms (slower)3751 ms (~1x)3958 ms
Semaphore10.3 ms (~7x)14.7 ms (~5x)416.9 ms (slower)32.8 ms (~2x)74.1 ms
Anon Aadhaar365.1 ms (~8.7x)-5359.6 ms (slower)2716.4 ms (~1.1x)3207.5 ms
Proof generationrapidsnarkark-workssnarkjs
Keccak256743.7 ms (~14x)2330.4 ms (~4.7x)11096.4 ms
SHA256228.4 ms (~15x) 1575.2 ms (~2x)3514.8 ms
RSA950 ms (~14x)5839 ms (~2.3x)13442 ms
Semaphore165.8 ms (~13x)276.9 ms (~7.7x)2146 ms
Anon Aadhaar3394.5 ms (~15x)33239.2 ms (~1.5x)51546.3 ms

macOS

Benchmarks on an Macbook Pro M1 Max (2021).

Witness generationwitnesscalccircom-witnesscalcwasmerw2csnarkjs
Keccak25663.9 ms (~5x)69.6 ms (~5x)507.7 ms (slower)214.6 ms (~1.6x)348.7 ms
SHA25622 ms (~10x)32 ms (~7x)272 ms (slower)112 ms (~2x)225 ms
RSA164 ms (~29x)-5326 ms (slower)4796 ms (slower)4777 ms
Semaphore7.1 ms (~18x)5 ms (~26x)287 ms (slower)34.9 ms (~3.7x)130 ms
Anon Aadhaar324 ms (~10x)-5369 ms (slower)2902 ms (~1.2x)3437 ms
Proof generationrapidsnarkark-workssnarkjs
Keccak256528 ms (~7x)1161 ms (~3.3x)3873 ms
SHA256158 ms (~9x) 779 ms (~2x)1462 ms
RSA676 ms (~8x)3005 ms (~1.8x)5553 ms
Semaphore112 ms (~7.8x)84 ms (~10x)877 ms
Anon Aadhaar2421 ms (~8x)14142 ms (~1.3x)19794 ms

Halo2

In summary:
The performance of the Mopro build is comparable to the native Halo2 build.

The bellow tests were run on a Macbook Pro M1 Pro (2021) as well as an iPhone 15 Pro (2023).

Keccak256Prove Time (s)Verify Time (s)
Native (M1 Pro)10.3 s0.15 s
Emulator (M1 Pro)10.1 s0.13 s
iPhone 15 Pro11.0 s0.12 s
RSAProve Time (s)Verify Time (s)
Native (M1 Pro)76.5 s11.1 s
Emulator (M1 Pro)64.5 s9.0 s
iPhone 15 Procrashescrashes

Note that the iPhone 15 Pro crashes when running the RSA circuit due to the large memory requirements. The circuit needs around 5GB of memory to run, while the iPhone 15 Pro usually limits the application memory usage to 3GB.