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