mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-17 23:38:46 +00:00
48 lines
2.9 KiB
Markdown
48 lines
2.9 KiB
Markdown
|
# Benchmarks for Prysm State Transition
|
||
|
This package contains the functionality needed for benchmarking Prysms state transitions, this includes its block processing (with and without caching) and epoch processing functions. There is also a benchmark for HashTreeRoot on a large beacon state.
|
||
|
|
||
|
## Benchmark Configuration
|
||
|
The following configs are in `config.go`:
|
||
|
* `ValidatorCount`: Sets the amount of active validators to perform the benchmarks with. Default is 16384.
|
||
|
* `AttestationsPerEpoch`: Sets the amount of attestations per epoch for the benchmarks to perform with, this affects the amount of attestations in a full block and the amount of attestations per epoch in the state for the `ProcessEpoch` and `HashTreeRoot` benchmark. Default is 128.
|
||
|
|
||
|
## Generating new SSZ files
|
||
|
Due to the sheer size of the benchmarking configurations (16384 validators), the files used for benchmarking are pregenerated so there's no wasted computations on generating a genesis state with 16384 validators. This should only be needed if there is a breaking spec change and the tests fail from SSZ issues.
|
||
|
|
||
|
To generate new files to use for benchmarking, run the below command in the root of Prysm.
|
||
|
```
|
||
|
bazel run //tools/benchmark-files-gen -- --output-dir $PRYSMPATH/shared/benchutil/benchmark_files/ --overwrite
|
||
|
```
|
||
|
|
||
|
## Running the benchmarks
|
||
|
To run the ExecuteStateTransition benchmark:
|
||
|
|
||
|
```bazel test //beacon-chain/core/state:go_default_test --test_filter=BenchmarkExecuteStateTransition_FullBlock --test_arg=-test.bench=BenchmarkExecuteStateTransition_FullBlock```
|
||
|
|
||
|
To run the ExecuteStateTransition (with cache) benchmark:
|
||
|
|
||
|
```bazel test //beacon-chain/core/state:go_default_test --test_filter=BenchmarkExecuteStateTransition_WithCache --test_arg=-test.bench=BenchmarkExecuteStateTransition_WithCache```
|
||
|
|
||
|
To run the ProcessEpoch benchmark:
|
||
|
|
||
|
```bazel test //beacon-chain/core/state:go_default_test --test_filter=BenchmarkProcessEpoch_2FullEpochs --test_arg=-test.bench=BenchmarkProcessEpoch_2FullEpochs```
|
||
|
|
||
|
To run the HashTreeRoot benchmark:
|
||
|
|
||
|
```bazel test //beacon-chain/core/state:go_default_test --test_filter=BenchmarkHashTreeRoot_FullState --test_arg=-test.bench=BenchmarkHashTreeRoot_FullState```
|
||
|
|
||
|
To run the HashTreeRootState benchmark:
|
||
|
|
||
|
```bazel test //beacon-chain/core/state:go_default_test --test_filter=BenchmarkHashTreeRootState_FullState --test_arg=-test.bench=BenchmarkHashTreeRootState_FullState```
|
||
|
|
||
|
Extra flags needed to benchmark properly:
|
||
|
|
||
|
```--nocache_test_results --test_arg=-test.v --test_timeout=2000 --test_arg=-test.cpuprofile=/tmp/cpu.profile --test_arg=-test.memprofile=/tmp/mem.profile --test_output=streamed```
|
||
|
|
||
|
## Current Results as of January 2020
|
||
|
```
|
||
|
BenchmarkExecuteStateTransition_FullBlock-4 20 2031438030 ns/op
|
||
|
BenchmarkExecuteStateTransition_WithCache-4 20 1857290454 ns/op
|
||
|
BenchmarkHashTreeRoot_FullState-4 50 297655834 ns/op
|
||
|
BenchmarkHashTreeRootState_FullState-4 50 155535883 ns/op
|
||
|
```
|