Skyward boardcore
Loading...
Searching...
No Matches
LoggerStats.h
Go to the documentation of this file.
1/* Copyright (c) 2018 Skyward Experimental Rocketry
2 * Author: Federico Terraneo
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a copy
5 * of this software and associated documentation files (the "Software"), to deal
6 * in the Software without restriction, including without limitation the rights
7 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8 * copies of the Software, and to permit persons to whom the Software is
9 * furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice shall be included in
12 * all copies or substantial portions of the Software.
13 *
14 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20 * THE SOFTWARE.
21 */
22
23#pragma once
24
25#include <ostream>
26#include <string>
27
28namespace Boardcore
29{
30
35{
36 uint64_t timestamp = 0;
37
38 int logNumber = 0;
39
42
44 int queuedSamples = 0;
45 int buffersFilled = 0;
47 int writesFailed = 0;
50 int maxWriteTime = 0;
51
52 static std::string header()
53 {
54 return "timestamp,logNumber,tooLargeSamples,droppedSamples,"
55 "queuedSamples,buffersFilled,buffersWritten,writesFailed,"
56 "lastWriteError,averageWriteTime,maxWriteTime\n";
57 }
58
59 void print(std::ostream& os) const
60 {
61 os << timestamp << "," << logNumber << "," << tooLargeSamples << ","
62 << droppedSamples << "," << queuedSamples << "," << buffersFilled
63 << "," << buffersWritten << "," << writesFailed << ","
64 << lastWriteError << "," << averageWriteTime << "," << maxWriteTime
65 << "\n";
66 }
67};
68
69} // namespace Boardcore
This file includes all the types the logdecoder script will decode.
Statistics for the logger.
Definition LoggerStats.h:35
int droppedSamples
Number of dropped samples due to fifo full.
Definition LoggerStats.h:43
int logNumber
Number of dropped samples because they where too large.
Definition LoggerStats.h:38
int averageWriteTime
Average time for an fwrite() of a buffer.
Definition LoggerStats.h:49
int maxWriteTime
Max time for an fwrite() of a buffer.
Definition LoggerStats.h:50
int lastWriteError
Error of the last fwrite() that failed.
Definition LoggerStats.h:48
int buffersWritten
Number of buffers written to disk.
Definition LoggerStats.h:46
int buffersFilled
Number of buffers filled.
Definition LoggerStats.h:45
static std::string header()
Definition LoggerStats.h:52
int writesFailed
Number of fwrite() that failed.
Definition LoggerStats.h:47
int queuedSamples
Number of samples written to buffer.
Definition LoggerStats.h:44
void print(std::ostream &os) const
Definition LoggerStats.h:59