A simple suite for benchmarking
Project description
SimpleBench is a modern Python framework for benchmarking and performance testing of code.
As such it has the following goals:
Simple to use for simple benchmarks
Powerful enough to handle sophisticated benchmarking needs out-of-the-box
Flexible enough to handle complex custom benchmarking scenarios
Extensible to allow users to add their own functionality as needed
Full API and command-line interface support
Current Status
Alpha release 0.5.1-alpha.0
Functionally complete but not yet 100% tested or documented. There may be breaking changes before reaching version 1.0.
Additional report formats and benchmark options are planned.
Installing
Minimum Python Version: 3.10
From PyPI
python -m pip install simplebench
python -m pip install simplebench[graphs]
python -m pip install simplebench[all]
From Source
git clone https://github.com/JerilynFranz/python-simplebench
cd python-simplebench
python3 -m pip install .
Documentation
Basic Example
This is a basic example of creating and running a benchmark using SimpleBench. It demonstrates how to define a benchmark function, run it, and view an output report on the console. There are more detailed examples and tutorials in the documentation.
SimpleBench supports numerous benchmark options, report formats, command-line options, and customization points - this example focuses on the simplest case.
Defining a Benchmark
import simplebench
@simplebench.benchmark
def addition_benchmark():
"""A simple addition benchmark of Python's built-in sum function."""
sum(range(1000))
if __name__ == "__main__":
simplebench.main()
Running a Benchmark
python my_benchmark_script.py --rich-table.ops --progress
Benchmark Output
This will run the addition_benchmark function and generate a rich table report of its performance.
addition_benchmark
operations per second
A simple addition benchmark of Python's built-in sum function.
┏━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━┳━━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━━━━━━┳━━━━━━━━━━━━┳━━━━━━━━┓
┃ ┃ ┃ ┃ Elapsed ┃ mean ┃ median ┃ ┃ ┃ ┃ ┃ std dev ┃ ┃
┃ N ┃ Iterations ┃ Rounds ┃ Seconds ┃ kOps/s ┃ kOps/s ┃ min Ops/s ┃ max kOps/s ┃ 5th kOps/s ┃ 95th kOps/s ┃ kOps/s ┃ rsd% ┃
┡━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━╇━━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━━━━━━╇━━━━━━━━━━━━╇━━━━━━━━┩
│ 1 │ 46701 │ 1 │ 0.32 │ 148.00 │ 149.00 │ 876.00 │ 153.00 │ 143.00 │ 151.00 │ 8.99 │ 6.08% │
└────────┴────────────┴────────┴─────────┴────────────┴────────────┴───────────┴────────────┴────────────┴─────────────┴────────────┴────────┘
Inspiration
“Simple things should be simple and complex things should be possible.” Alan Kay
“… with proper design, the features come cheaply. This approach is arduous, but continues to succeed.” Dennis Ritchie
Copyright
Copyright 2025 by Jerilyn Franz
License
Licensed under the Apache License, Version 2.0 (the “License”); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file simplebench-0.6.0.tar.gz.
File metadata
- Download URL: simplebench-0.6.0.tar.gz
- Upload date:
- Size: 272.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
081c25fc428dd2eeba0d648e082e60a6603e83f956f7e666c15483e45ea9933c
|
|
| MD5 |
a4176136ccf77ab76382a78371a42170
|
|
| BLAKE2b-256 |
4fa689da79287b50a8ef8537c35da48f247c4d392e9aa93ef000153be147bfdf
|
File details
Details for the file simplebench-0.6.0-py3-none-any.whl.
File metadata
- Download URL: simplebench-0.6.0-py3-none-any.whl
- Upload date:
- Size: 246.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
166af27330b742a1b55bdf67b88a593b64090c4bdc633c6acffa2673b2e53fbe
|
|
| MD5 |
db50db89ca26623351d267899d6e5b25
|
|
| BLAKE2b-256 |
0fac259a262775f1195e165430674e4e6bae1e8fad94ca3fed56e5eeb74a4db9
|