diff options
author | Chris Jones <cjfj@google.com> | 2020-07-09 09:23:06 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-07-09 09:23:06 +0100 |
commit | 39c8d58a76ce7c3398786ee96a452668e8392af7 (patch) | |
tree | cea466374d099566994d7011427228e6467e53a3 /bindings/python/google_benchmark/example.py | |
parent | 7f27afe83b82f3a98baf58ef595814b9d42a5b2b (diff) | |
download | google-benchmark-39c8d58a76ce7c3398786ee96a452668e8392af7.tar.gz google-benchmark-39c8d58a76ce7c3398786ee96a452668e8392af7.zip |
Rename python bindings package to `google_benchmark`. (#999)
A few people have complained that `benchmark` is too generic. Also, add
Python 3.8.
Diffstat (limited to 'bindings/python/google_benchmark/example.py')
-rw-r--r-- | bindings/python/google_benchmark/example.py | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/bindings/python/google_benchmark/example.py b/bindings/python/google_benchmark/example.py new file mode 100644 index 0000000..e968462 --- /dev/null +++ b/bindings/python/google_benchmark/example.py @@ -0,0 +1,48 @@ +# Copyright 2020 Google Inc. All rights reserved. +# +# 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. +"""Example of Python using C++ benchmark framework. + +To run this example, you must first install the `google_benchmark` Python package. + +To install using `setup.py`, download and extract the `google_benchmark` source. +In the extracted directory, execute: + python setup.py install +""" + +import google_benchmark as benchmark + + +@benchmark.register +def empty(state): + while state: + pass + + +@benchmark.register +def sum_million(state): + while state: + sum(range(1_000_000)) + + +@benchmark.register +def skipped(state): + if True: # Test some predicate here. + state.skip_with_error('some error') + return # NOTE: You must explicitly return, or benchmark will continue. + + ... # Benchmark code would be here. + + +if __name__ == '__main__': + benchmark.main() |