Skip to main content

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.7.0-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 .[all]

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% │
└────────┴────────────┴────────┴─────────┴────────────┴────────────┴───────────┴────────────┴────────────┴─────────────┴────────────┴────────┘

Authors and acknowledgments

  • Jerilyn Franz

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

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

simplebench-0.7.0.tar.gz (276.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

simplebench-0.7.0-py3-none-any.whl (247.7 kB view details)

Uploaded Python 3

File details

Details for the file simplebench-0.7.0.tar.gz.

File metadata

  • Download URL: simplebench-0.7.0.tar.gz
  • Upload date:
  • Size: 276.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for simplebench-0.7.0.tar.gz
Algorithm Hash digest
SHA256 41bd8f2ae08c27bb42fe676a58dd92781e69fd5708b29c6916f1e41146d43b39
MD5 e764881dd3e4f6a0ffcf31ed8a24190d
BLAKE2b-256 8ee44e74404ea3e39c29adcfdc6c09e02c004c2a86fdc3ffcaab0d4897baa504

See more details on using hashes here.

File details

Details for the file simplebench-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: simplebench-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 247.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for simplebench-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6d91d2bb2978e92d9124787e58aaf45a654ff0a4539b5d2e1eaa3e5c43ee8f62
MD5 826c47addd07460311ad78d0f422b58a
BLAKE2b-256 53590262973ae526f62f454b1091c8e3b5d078be7f59478bb1275ea842852054

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page