1 /*
2  * Copyright (C) 2019 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef __STATS_H__
18 #define __STATS_H__
19 
20 #include <android/log.h>
21 #include <inttypes.h>
22 
23 #ifndef ALOG
24 #define ALOG(priority, tag, ...) ((void)__android_log_print(ANDROID_##priority, tag, __VA_ARGS__))
25 
26 #define ALOGI(...) ALOG(LOG_INFO, LOG_TAG, __VA_ARGS__)
27 #define ALOGE(...) ALOG(LOG_ERROR, LOG_TAG, __VA_ARGS__)
28 #define ALOGD(...) ALOG(LOG_DEBUG, LOG_TAG, __VA_ARGS__)
29 #define ALOGW(...) ALOG(LOG_WARN, LOG_TAG, __VA_ARGS__)
30 
31 #ifndef LOG_NDEBUG
32 #define LOG_NDEBUG 1
33 #endif
34 
35 #if LOG_NDEBUG
36 #define ALOGV(cond, ...)   ((void)0)
37 #else
38 #define ALOGV(...) ALOG(LOG_VERBOSE, LOG_TAG, __VA_ARGS__)
39 #endif
40 #endif  // ALOG
41 
42 #include <sys/time.h>
43 #include <algorithm>
44 #include <numeric>
45 #include <vector>
46 
47 // Include local copy of Timers taken from system/core/libutils
48 #include "utils/Timers.h"
49 
50 using namespace std;
51 
52 class Stats {
53   public:
Stats()54     Stats() {
55         mInitTimeNs = 0;
56         mDeInitTimeNs = 0;
57     }
58 
~Stats()59     ~Stats() {
60         reset();
61     }
62 
63   private:
64     nsecs_t mInitTimeNs;
65     nsecs_t mDeInitTimeNs;
66     nsecs_t mStartTimeNs;
67     std::vector<int32_t> mFrameSizes;
68     std::vector<nsecs_t> mInputTimer;
69     std::vector<nsecs_t> mOutputTimer;
70 
71   public:
getCurTime()72     nsecs_t getCurTime() { return systemTime(CLOCK_MONOTONIC); }
73 
setInitTime(nsecs_t initTime)74     void setInitTime(nsecs_t initTime) { mInitTimeNs = initTime; }
75 
setDeInitTime(nsecs_t deInitTime)76     void setDeInitTime(nsecs_t deInitTime) { mDeInitTimeNs = deInitTime; }
77 
setStartTime()78     void setStartTime() { mStartTimeNs = systemTime(CLOCK_MONOTONIC); }
79 
addFrameSize(int32_t size)80     void addFrameSize(int32_t size) { mFrameSizes.push_back(size); }
81 
addInputTime()82     void addInputTime() { mInputTimer.push_back(systemTime(CLOCK_MONOTONIC)); }
83 
addOutputTime()84     void addOutputTime() { mOutputTimer.push_back(systemTime(CLOCK_MONOTONIC)); }
85 
reset()86     void reset() {
87         if (!mFrameSizes.empty()) mFrameSizes.clear();
88         if (!mInputTimer.empty()) mInputTimer.clear();
89         if (!mOutputTimer.empty()) mOutputTimer.clear();
90     }
91 
getOutputTimer()92     std::vector<nsecs_t> getOutputTimer() { return mOutputTimer; }
93 
getInitTime()94     nsecs_t getInitTime() { return mInitTimeNs; }
95 
getDeInitTime()96     nsecs_t getDeInitTime() { return mDeInitTimeNs; }
97 
getTimeDiff(nsecs_t sTime,nsecs_t eTime)98     nsecs_t getTimeDiff(nsecs_t sTime, nsecs_t eTime) { return (eTime - sTime); }
99 
getTotalTime()100     nsecs_t getTotalTime() {
101         if (mOutputTimer.empty()) return -1;
102         return (*(mOutputTimer.end() - 1) - mStartTimeNs);
103     }
104 
105     void dumpStatistics(const string& operation, const string& inputReference,
106                         int64_t duarationUs, const string& componentName = "",
107                         const string& mode = "", const string& statsFile = "");
108 
109     void uploadMetrics(const string& operation, const string& inputReference,
110                       const int64_t& durationUs, const string& componentName = "",
111                       const string& mode = "");
112 };
113 #endif  // __STATS_H__
114