Skip to content

Latest commit

 

History

History
 
 

MicrobenchmarkSample

Microbenchmark Sample

This sample project shows how to use the Jetpack Microbenchmark library.

It includes multiple simple benchmark samples:

  • AutoBoxingBenchmark measures the cost of allocating Integer() objects.

  • BitmapBenchmark measures the cost of accessing Bitmap pixels, showing the overhead of many JNI calls versus one in the underlying Android platform code.

  • SortingBenchmarks measures different sorting algorithms, showing how to work with random data and runWithTimingDisabled sections.

As well as one more complex UI benchmark:

  • RecyclerViewBenchmark measures the cost of scrolling a RecyclerView UI defined in another UI library module.

Project Structure

Microbenchmarks require specific setup to produce consistent results. As a consequence of this, the project has to be split into several modules:

  • :microbenchmark- contains only the Microbenchmarks tests.
  • :benchmarkable - contains the code callable from Microbenchmarks
  • :app - code within this module can't be called from Microbenchmarks

No Gradle module has dependency on :microbenchmark module and therefore it's not merged into the built application. It serves as an entrypoint to run the benchmark tests from.

App structure with :app, :microbenchmark and :benchmarkable Gradle modules which allows Microbenchmarks to benchmark code in the :benchmarkable module.

Running

Open the project in Android Studio Arctic Fox 2020.3.1 or later, and run benchmarks as you usually would run tests: Ctrl-Shift-F10 (Mac: Ctrl-Shift-R).

Alternatively, run from command line with:

./gradlew benchmark:cC

Locking Clocks

If you have a rooted device you can benchmark on, use ./gradlew lockClocks to lock the CPU clocks of the device to stable values. To unlock clocks, use ./gradlew unlockClocks, or reboot your device. This feature is provided by the androidx.benchmark gradle plugin.

Reporting Issues

You can report an Issue with the sample using this repository. If you find an issue with the Microbenchmark library, report it using the Issue Tracker.

License

Copyright 2022 The Android Open Source Project, Inc.

Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to you 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.