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

chore: Single-shot benchmarking + continuous benchmarking #183

Merged
merged 5 commits into from
Feb 3, 2025

Conversation

aborgna-q
Copy link
Collaborator

@aborgna-q aborgna-q commented Feb 2, 2025

Setups iai-callgrind-based benchmarks for single-shot benchmarking (by using callgrind internally).

Cleans up the benchmark cases and adds some structure so they can be executed both with iai-callgrind and criterion, depending on whether we want to measure instruction count or time.

They can be called separatedly,

# Single-shot, requires some extra setup
cargo bench --bench iai_benches
# Time-based, takes longer to run
cargo bench --bench criterion_benches

See DEVELOPMENT.md for instructions.


The instruction count benchmarks are now uploaded to bencher.dev, so we get an historical comparison of the performance and a CI check can alert about regressions.
I believe the "No thresholds found" error in this PR will go away once this gets run in main.

The service choice was mainly between bencher.dev and codspeed.io . I choose the former since it supports single-shot benchmarks natively.
See this issue in ratatui where the Bencher maintainer discusses some differences, ratatui/ratatui#1092.

@aborgna-q aborgna-q changed the title chore: Single-shot benchmarking + Continuous benchmarking chore: Single-shot benchmarking + continuous benchmarking Feb 2, 2025
Copy link

codecov bot commented Feb 2, 2025

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 83.27%. Comparing base (97fa7b8) to head (0748032).
Report is 2 commits behind head on main.

Additional details and impacted files
@@           Coverage Diff           @@
##             main     #183   +/-   ##
=======================================
  Coverage   83.27%   83.27%           
=======================================
  Files          24       24           
  Lines        6117     6117           
  Branches     6117     6117           
=======================================
  Hits         5094     5094           
  Misses        947      947           
  Partials       76       76           

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@aborgna-q aborgna-q force-pushed the ab/iai-benches branch 8 times, most recently from f0fbe46 to 4a85932 Compare February 2, 2025 23:18
@aborgna-q aborgna-q added the perf Performance issue label Feb 2, 2025
@CQCL CQCL deleted a comment from hugrbot Feb 3, 2025
@CQCL CQCL deleted a comment from hugrbot Feb 3, 2025
@hugrbot
Copy link
Collaborator

hugrbot commented Feb 3, 2025

🐰 Bencher Report

Branchab/iai-benches
Testbedubuntu-latest

⚠️ WARNING: No Threshold found!

Without a Threshold, no Alerts will ever be generated.

Click here to create a new Threshold
For more information, see the Threshold documentation.
To only post results if a Threshold exists, set the --ci-only-thresholds flag.

Click to view all benchmark results
BenchmarkEstimated Cycles1e3 x cyclesInstructionsBenchmark Result
1e3 x instructions
(Result Δ%)
Upper Boundary
1e3 x instructions
(Limit %)
L1 Hits1e3 x hitsL2 HitshitsRAM HitshitsTotal read+write1e3 x reads/writes
iai_benches::convex::callgrind_convex_construction big:ConvexConstruction :: big()📈 view plot
⚠️ NO THRESHOLD
35,960.92📈 view plot
🚷 view threshold
25,493.12📈 view plot
⚠️ NO THRESHOLD
35,647.39📈 view plot
⚠️ NO THRESHOLD
25,523.00📈 view plot
⚠️ NO THRESHOLD
5,312.00📈 view plot
⚠️ NO THRESHOLD
35,678.22
iai_benches::convex::callgrind_convex_construction small:ConvexConstruction :: small()📈 view plot
⚠️ NO THRESHOLD
367.76📈 view plot
🚷 view threshold
258.69📈 view plot
⚠️ NO THRESHOLD
360.35📈 view plot
⚠️ NO THRESHOLD
19.00📈 view plot
⚠️ NO THRESHOLD
209.00📈 view plot
⚠️ NO THRESHOLD
360.58
iai_benches::convex::callgrind_convex_full big:ConvexFull :: big()📈 view plot
⚠️ NO THRESHOLD
20,322.72📈 view plot
🚷 view threshold
15,776.01📈 view plot
⚠️ NO THRESHOLD
19,772.57📈 view plot
⚠️ NO THRESHOLD
69,486.00📈 view plot
⚠️ NO THRESHOLD
5,792.00📈 view plot
⚠️ NO THRESHOLD
19,847.85
iai_benches::convex::callgrind_convex_full small:ConvexFull :: small()📈 view plot
⚠️ NO THRESHOLD
138.65📈 view plot
🚷 view threshold
106.24📈 view plot
⚠️ NO THRESHOLD
133.29📈 view plot
⚠️ NO THRESHOLD
50.00📈 view plot
⚠️ NO THRESHOLD
146.00📈 view plot
⚠️ NO THRESHOLD
133.49
iai_benches::convex::callgrind_convex_sparse big:ConvexSparse :: big()📈 view plot
⚠️ NO THRESHOLD
93.19📈 view plot
🚷 view threshold
62.58📈 view plot
⚠️ NO THRESHOLD
84.64📈 view plot
⚠️ NO THRESHOLD
325.00📈 view plot
⚠️ NO THRESHOLD
198.00📈 view plot
⚠️ NO THRESHOLD
85.16
iai_benches::convex::callgrind_convex_sparse small:ConvexSparse :: small()📈 view plot
⚠️ NO THRESHOLD
12.07📈 view plot
🚷 view threshold
6.11📈 view plot
⚠️ NO THRESHOLD
8.34📈 view plot
⚠️ NO THRESHOLD
4.00📈 view plot
⚠️ NO THRESHOLD
106.00📈 view plot
⚠️ NO THRESHOLD
8.45
iai_benches::hierarchy::callgrind_create_hierarchy big:CreateHierarchy :: big()📈 view plot
⚠️ NO THRESHOLD
3,870.42📈 view plot
🚷 view threshold
2,470.62📈 view plot
⚠️ NO THRESHOLD
3,589.92📈 view plot
⚠️ NO THRESHOLD
3,410.00📈 view plot
⚠️ NO THRESHOLD
7,527.00📈 view plot
⚠️ NO THRESHOLD
3,600.86
iai_benches::hierarchy::callgrind_create_hierarchy small:CreateHierarchy :: small()📈 view plot
⚠️ NO THRESHOLD
41.32📈 view plot
🚷 view threshold
25.68📈 view plot
⚠️ NO THRESHOLD
37.28📈 view plot
⚠️ NO THRESHOLD
3.00📈 view plot
⚠️ NO THRESHOLD
115.00📈 view plot
⚠️ NO THRESHOLD
37.40
iai_benches::hierarchy::callgrind_traverse_hierarchy big:TraverseHierarchy :: big()📈 view plot
⚠️ NO THRESHOLD
1,932.60📈 view plot
🚷 view threshold
1,311.11📈 view plot
⚠️ NO THRESHOLD
1,893.93📈 view plot
⚠️ NO THRESHOLD
7,580.00📈 view plot
⚠️ NO THRESHOLD
22.00📈 view plot
⚠️ NO THRESHOLD
1,901.54
iai_benches::hierarchy::callgrind_traverse_hierarchy small:TraverseHierarchy :: small()📈 view plot
⚠️ NO THRESHOLD
22.08📈 view plot
🚷 view threshold
14.31📈 view plot
⚠️ NO THRESHOLD
20.63📈 view plot
⚠️ NO THRESHOLD
10.00📈 view plot
⚠️ NO THRESHOLD
40.00📈 view plot
⚠️ NO THRESHOLD
20.68
iai_benches::portgraph::callgrind_clone_portgraph big:ClonePortgraph :: big()📈 view plot
⚠️ NO THRESHOLD
54,346.95📈 view plot
🚷 view threshold
4,841.33📈 view plot
⚠️ NO THRESHOLD
6,216.84📈 view plot
⚠️ NO THRESHOLD
0.00📈 view plot
⚠️ NO THRESHOLD
1,375,146.00📈 view plot
⚠️ NO THRESHOLD
7,591.99
iai_benches::portgraph::callgrind_clone_portgraph small:ClonePortgraph :: small()📈 view plot
⚠️ NO THRESHOLD
7.01📈 view plot
🚷 view threshold
2.41📈 view plot
⚠️ NO THRESHOLD
3.40📈 view plot
⚠️ NO THRESHOLD
0.00📈 view plot
⚠️ NO THRESHOLD
103.00📈 view plot
⚠️ NO THRESHOLD
3.50
iai_benches::portgraph::callgrind_make_portgraph big:MakePortgraph :: big()📈 view plot
⚠️ NO THRESHOLD
709,381.19📈 view plot
🚷 view threshold
525,001.64📈 view plot
⚠️ NO THRESHOLD
685,314.65📈 view plot
⚠️ NO THRESHOLD
4.00📈 view plot
⚠️ NO THRESHOLD
687,615.00📈 view plot
⚠️ NO THRESHOLD
686,002.27
iai_benches::portgraph::callgrind_make_portgraph small:MakePortgraph :: small()📈 view plot
⚠️ NO THRESHOLD
76.64📈 view plot
🚷 view threshold
54.31📈 view plot
⚠️ NO THRESHOLD
70.97📈 view plot
⚠️ NO THRESHOLD
8.00📈 view plot
⚠️ NO THRESHOLD
161.00📈 view plot
⚠️ NO THRESHOLD
71.13
iai_benches::portgraph::callgrind_remove_unordered big:RemoveUnordered :: big()📈 view plot
⚠️ NO THRESHOLD
2,803.96📈 view plot
🚷 view threshold
2,068.41📈 view plot
⚠️ NO THRESHOLD
2,560.65📈 view plot
⚠️ NO THRESHOLD
47,541.00📈 view plot
⚠️ NO THRESHOLD
160.00📈 view plot
⚠️ NO THRESHOLD
2,608.35
iai_benches::portgraph::callgrind_remove_unordered small:RemoveUnordered :: small()📈 view plot
⚠️ NO THRESHOLD
26.90📈 view plot
🚷 view threshold
18.94📈 view plot
⚠️ NO THRESHOLD
25.06📈 view plot
⚠️ NO THRESHOLD
11.00📈 view plot
⚠️ NO THRESHOLD
51.00📈 view plot
⚠️ NO THRESHOLD
25.12
iai_benches::portgraph::callgrind_resize_ports big:ResizePorts :: big()📈 view plot
⚠️ NO THRESHOLD
9,306.67📈 view plot
🚷 view threshold
6,546.11📈 view plot
⚠️ NO THRESHOLD
9,028.62📈 view plot
⚠️ NO THRESHOLD
13,708.00📈 view plot
⚠️ NO THRESHOLD
5,986.00📈 view plot
⚠️ NO THRESHOLD
9,048.32
iai_benches::portgraph::callgrind_resize_ports small:ResizePorts :: small()📈 view plot
⚠️ NO THRESHOLD
98.31📈 view plot
🚷 view threshold
67.21📈 view plot
⚠️ NO THRESHOLD
89.85📈 view plot
⚠️ NO THRESHOLD
18.00📈 view plot
⚠️ NO THRESHOLD
239.00📈 view plot
⚠️ NO THRESHOLD
90.11
iai_benches::render::callgrind_render_dot big:RenderDot :: big()📈 view plot
⚠️ NO THRESHOLD
613,689.16📈 view plot
🚷 view threshold
421,056.93📈 view plot
⚠️ NO THRESHOLD
608,261.33📈 view plot
⚠️ NO THRESHOLD
38,835.00📈 view plot
⚠️ NO THRESHOLD
149,533.00📈 view plot
⚠️ NO THRESHOLD
608,449.69
iai_benches::render::callgrind_render_dot small:RenderDot :: small()📈 view plot
⚠️ NO THRESHOLD
6,159.32📈 view plot
🚷 view threshold
4,085.79📈 view plot
⚠️ NO THRESHOLD
6,034.55📈 view plot
⚠️ NO THRESHOLD
2,057.00📈 view plot
⚠️ NO THRESHOLD
3,271.00📈 view plot
⚠️ NO THRESHOLD
6,039.88
iai_benches::render::callgrind_render_mermaid big:RenderMermaid :: big()📈 view plot
⚠️ NO THRESHOLD
191,851.39📈 view plot
🚷 view threshold
134,004.07
(+0.00%)
134,004.24
(100.00%)
📈 view plot
⚠️ NO THRESHOLD
187,836.32📈 view plot
⚠️ NO THRESHOLD
186,818.00📈 view plot
⚠️ NO THRESHOLD
88,028.00📈 view plot
⚠️ NO THRESHOLD
188,111.17
iai_benches::render::callgrind_render_mermaid small:RenderMermaid :: small()📈 view plot
⚠️ NO THRESHOLD
1,908.38📈 view plot
🚷 view threshold
1,306.77
(+0.00%)
1,307.68
(99.93%)
📈 view plot
⚠️ NO THRESHOLD
1,858.95📈 view plot
⚠️ NO THRESHOLD
1,023.00📈 view plot
⚠️ NO THRESHOLD
1,266.00📈 view plot
⚠️ NO THRESHOLD
1,861.24
iai_benches::toposort::callgrind_toposort small:Toposort :: small()📈 view plot
⚠️ NO THRESHOLD
312.77📈 view plot
🚷 view threshold
220.69📈 view plot
⚠️ NO THRESHOLD
308.61📈 view plot
⚠️ NO THRESHOLD
12.00📈 view plot
⚠️ NO THRESHOLD
117.00📈 view plot
⚠️ NO THRESHOLD
308.74
🐰 View full continuous benchmarking report in Bencher

@CQCL CQCL deleted a comment from hugrbot Feb 3, 2025
@aborgna-q aborgna-q force-pushed the ab/iai-benches branch 2 times, most recently from ebb8365 to ac2480a Compare February 3, 2025 18:22
@aborgna-q aborgna-q requested a review from lmondada February 3, 2025 18:23
@aborgna-q aborgna-q marked this pull request as ready for review February 3, 2025 18:23
Copy link
Contributor

@lmondada lmondada left a comment

Choose a reason for hiding this comment

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

Super cool!

@aborgna-q aborgna-q added this pull request to the merge queue Feb 3, 2025
Merged via the queue into main with commit 03368af Feb 3, 2025
13 checks passed
@aborgna-q aborgna-q deleted the ab/iai-benches branch February 3, 2025 19:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
perf Performance issue
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants