1*6fa2df46SAndroid Build Coastguard Worker // Copyright (C) 2021 The Android Open Source Project 2*6fa2df46SAndroid Build Coastguard Worker // 3*6fa2df46SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License"); 4*6fa2df46SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License. 5*6fa2df46SAndroid Build Coastguard Worker // You may obtain a copy of the License at 6*6fa2df46SAndroid Build Coastguard Worker // 7*6fa2df46SAndroid Build Coastguard Worker // http://www.apache.org/licenses/LICENSE-2.0 8*6fa2df46SAndroid Build Coastguard Worker // 9*6fa2df46SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software 10*6fa2df46SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS, 11*6fa2df46SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*6fa2df46SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and 13*6fa2df46SAndroid Build Coastguard Worker // limitations under the License. 14*6fa2df46SAndroid Build Coastguard Worker 15*6fa2df46SAndroid Build Coastguard Worker #include <ditto/sampler.h> 16*6fa2df46SAndroid Build Coastguard Worker 17*6fa2df46SAndroid Build Coastguard Worker #include <cmath> 18*6fa2df46SAndroid Build Coastguard Worker #include <ctime> 19*6fa2df46SAndroid Build Coastguard Worker 20*6fa2df46SAndroid Build Coastguard Worker #include <ditto/logger.h> 21*6fa2df46SAndroid Build Coastguard Worker 22*6fa2df46SAndroid Build Coastguard Worker namespace dittosuite { 23*6fa2df46SAndroid Build Coastguard Worker MeasureStart()24*6fa2df46SAndroid Build Coastguard Workervoid TimeSampler::MeasureStart() { 25*6fa2df46SAndroid Build Coastguard Worker clock_gettime(CLOCK_MONOTONIC, &start_); 26*6fa2df46SAndroid Build Coastguard Worker } 27*6fa2df46SAndroid Build Coastguard Worker MeasureEnd()28*6fa2df46SAndroid Build Coastguard Workervoid TimeSampler::MeasureEnd() { 29*6fa2df46SAndroid Build Coastguard Worker clock_gettime(CLOCK_MONOTONIC, &end_); 30*6fa2df46SAndroid Build Coastguard Worker samples_.push_back(end_ - start_); 31*6fa2df46SAndroid Build Coastguard Worker } 32*6fa2df46SAndroid Build Coastguard Worker Measure(const size_t file_size,const timespec & duration)33*6fa2df46SAndroid Build Coastguard Workervoid BandwidthSampler::Measure(const size_t file_size, const timespec& duration) { 34*6fa2df46SAndroid Build Coastguard Worker double bandwidth = file_size * 1e6 / TimespecToNanos(duration); // currently bytes/milliseconds 35*6fa2df46SAndroid Build Coastguard Worker bandwidth = bandwidth * 1e3 / (1 << 10); // Kb / s 36*6fa2df46SAndroid Build Coastguard Worker samples_.push_back(bandwidth); 37*6fa2df46SAndroid Build Coastguard Worker } 38*6fa2df46SAndroid Build Coastguard Worker 39*6fa2df46SAndroid Build Coastguard Worker } // namespace dittosuite 40