BenchmarkCmp 2.1.0
dotnet tool install --global BenchmarkCmp --version 2.1.0
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local BenchmarkCmp --version 2.1.0
#tool dotnet:?package=BenchmarkCmp&version=2.1.0
nuke :add-package BenchmarkCmp --version 2.1.0
dotnet-benchmarkcmp
Inspired by go-benchcmp
, dotnet-benchmarkcmp
displays performance changes between benchmarks.
benchmarkcmp
parses the output of two BenchmarkDotNet
benchmark runs, correlates the results per benchmark (based on name), and displays the deltas.
Getting started
Installation
To install the tool, use dotnet tool install
command:
dotnet tool install -g BenchmarkCmp
Use
To measure the performance impact of a change, use BenchmarkDotNet
to run benchmarks before / after the change and save artifacts. Then feed the benchmark artifacts (check Supported exporters section to see supported artifacts) to benchmarkcmp
:
dotnet benchmarkcmp old.json new.json
benchmarkcmp
will summarize and display the performance changes, in a format like this:
benchmark | old time/op | new time/op | delta
-------------------------------+-------------+-------------+--------
SimpleBenchmark.A: DefaultJob | 1,210 s | 1,108 s | -8,44%
benchmark | old allocs | new allocs | delta
-------------------------------+------------+------------+-------
SimpleBenchmark.A: DefaultJob | 0 | 0 | ~
benchmark | old G0 collects | new G0 collects | delta
| per 1k ops | per 1k ops |
-------------------------------+-----------------+-----------------+-------
SimpleBenchmark.A: DefaultJob | 0 | 0 | ~
benchmark | old G1 collects | new G1 collects | delta
| per 1k ops | per 1k ops |
-------------------------------+-----------------+-----------------+-------
SimpleBenchmark.A: DefaultJob | 0 | 0 | ~
benchmark | old G2 collects | new G2 collects | delta
| per 1k ops | per 1k ops |
-------------------------------+-----------------+-----------------+-------
SimpleBenchmark.A: DefaultJob | 0 | 0 | ~
Supported data
- Base Statistics
- Min / median / mean / max run time
- Memory Diagnoser
- Allocated memory
- Gen 0, 1, 2 allocation
- Threading Diagnoser
- Completed work items
- Lock contentions
- Native Memory Profiler
- Allocated native memory
- Native memory leak
- Hardware Counter Diagnoser
- Branch instructions
- Branch mispredictions
- Cache misses
- Exception Diagnoser
- Exception frequency
- JIT Stats Diagnoser
- Amount of JITted methods
- Amount of tiered methods
- JIT allocated memory
Supported exporters
- JsonExporter.Brief
- JsonExporter.Full
- XmlExporter.Brief
- XmlExporter.Full
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
This package has no dependencies.
- Added min / median / max statistics support.
- Added XML exporter support (Brief and Full).