xref: /aosp_15_r20/frameworks/rs/toolkit/test/TimingTracker.kt (revision e1eccf28f96817838ad6867f7f39d2351ec11f56)
1*e1eccf28SAndroid Build Coastguard Worker /*
<lambda>null2*e1eccf28SAndroid Build Coastguard Worker  * Copyright (C) 2021 The Android Open Source Project
3*e1eccf28SAndroid Build Coastguard Worker  *
4*e1eccf28SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*e1eccf28SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*e1eccf28SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*e1eccf28SAndroid Build Coastguard Worker  *
8*e1eccf28SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*e1eccf28SAndroid Build Coastguard Worker  *
10*e1eccf28SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*e1eccf28SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*e1eccf28SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*e1eccf28SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*e1eccf28SAndroid Build Coastguard Worker  * limitations under the License.
15*e1eccf28SAndroid Build Coastguard Worker  */
16*e1eccf28SAndroid Build Coastguard Worker 
17*e1eccf28SAndroid Build Coastguard Worker package com.example.testapp
18*e1eccf28SAndroid Build Coastguard Worker 
19*e1eccf28SAndroid Build Coastguard Worker class TimingTracker(
20*e1eccf28SAndroid Build Coastguard Worker     private val numberOfIterations: Int = 1,
21*e1eccf28SAndroid Build Coastguard Worker     private var numberOfIterationsToIgnore: Int = 0
22*e1eccf28SAndroid Build Coastguard Worker ) {
23*e1eccf28SAndroid Build Coastguard Worker     init {
24*e1eccf28SAndroid Build Coastguard Worker         require(numberOfIterations > numberOfIterationsToIgnore)
25*e1eccf28SAndroid Build Coastguard Worker     }
26*e1eccf28SAndroid Build Coastguard Worker     private val timings = mutableMapOf<String, IntArray>()
27*e1eccf28SAndroid Build Coastguard Worker     private var currentIteration: Int = 0
28*e1eccf28SAndroid Build Coastguard Worker     fun nextIteration() {
29*e1eccf28SAndroid Build Coastguard Worker         currentIteration++
30*e1eccf28SAndroid Build Coastguard Worker     }
31*e1eccf28SAndroid Build Coastguard Worker     fun <T> measure(name: String, workToTime: () -> T): T {
32*e1eccf28SAndroid Build Coastguard Worker         val start = System.nanoTime()
33*e1eccf28SAndroid Build Coastguard Worker         val t = workToTime()
34*e1eccf28SAndroid Build Coastguard Worker         if (currentIteration >= numberOfIterationsToIgnore) {
35*e1eccf28SAndroid Build Coastguard Worker             val end = System.nanoTime()
36*e1eccf28SAndroid Build Coastguard Worker             val deltaInMicroseconds: Int = ((end - start) / 1000).toInt()
37*e1eccf28SAndroid Build Coastguard Worker             val timing = timings.getOrPut(name) {
38*e1eccf28SAndroid Build Coastguard Worker                 IntArray(numberOfIterations - numberOfIterationsToIgnore)
39*e1eccf28SAndroid Build Coastguard Worker             }
40*e1eccf28SAndroid Build Coastguard Worker             timing[currentIteration - numberOfIterationsToIgnore] += deltaInMicroseconds
41*e1eccf28SAndroid Build Coastguard Worker         }
42*e1eccf28SAndroid Build Coastguard Worker         return t
43*e1eccf28SAndroid Build Coastguard Worker     }
44*e1eccf28SAndroid Build Coastguard Worker     fun report(): String {
45*e1eccf28SAndroid Build Coastguard Worker         var minimum: Int = Int.MAX_VALUE
46*e1eccf28SAndroid Build Coastguard Worker         for (timing in timings.values) {
47*e1eccf28SAndroid Build Coastguard Worker             val m = timing.minOrNull()
48*e1eccf28SAndroid Build Coastguard Worker             if (m != null && m < minimum) minimum = m
49*e1eccf28SAndroid Build Coastguard Worker         }
50*e1eccf28SAndroid Build Coastguard Worker 
51*e1eccf28SAndroid Build Coastguard Worker         println(timings.map { (name, timing) -> name + ": " + timing.minOrNull() }.joinToString(separator = "\n"))
52*e1eccf28SAndroid Build Coastguard Worker 
53*e1eccf28SAndroid Build Coastguard Worker         return (timings.map { (name, timing) -> name + ": " + timing.joinToString() }.joinToString() + "\n\n" +
54*e1eccf28SAndroid Build Coastguard Worker                 timings.map { (name, timing) -> name + ": " + timing.joinToString { "%.2f".format(it.toFloat() / minimum) } }.joinToString() + "\n\n" +
55*e1eccf28SAndroid Build Coastguard Worker                 timings.map { (name, timing) -> name + ": " + timing.minOrNull() }.joinToString())
56*e1eccf28SAndroid Build Coastguard Worker     }
57*e1eccf28SAndroid Build Coastguard Worker }
58*e1eccf28SAndroid Build Coastguard Worker 
59