xref: /aosp_15_r20/test/dittosuite/src/sampler.cpp (revision 6fa2df46f119dce7527f5beb2814eca0e6f886ac)
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 Worker void 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 Worker void 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 Worker void 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