PX4 Firmware
PX4 Autopilot Software http://px4.io
tests_common.h
Go to the documentation of this file.
1 /****************************************************************************
2  *
3  * Copyright (c) 2019 Todd Stellanova. All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * 1. Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in
13  * the documentation and/or other materials provided with the
14  * distribution.
15  * 3. Neither the name of the copyright holder nor the names of its
16  * contributors may be used to endorse or promote products derived
17  * from this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
26  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  *
32  ****************************************************************************/
33 
34 #ifndef ECL_TESTS_COMMON_H
35 #define ECL_TESTS_COMMON_H
36 
38 
39 /**
40  * Insert a series of samples around a mean value
41  * @param validator The validator under test
42  * @param mean The mean value
43  * @param count The number of samples to insert in the validator
44  * @param rms_err (out) calculated rms error of the inserted samples
45  * @param timestamp_io (in/out) in: start timestamp, out: last timestamp
46  */
47 void insert_values_around_mean(DataValidator *validator, const float mean, uint32_t count, float *rms_err,
48  uint64_t *timestamp_io);
49 
50 /**
51  * Print out the state of a DataValidator
52  * @param validator
53  */
54 void dump_validator_state(DataValidator *validator);
55 
56 /**
57  * Insert a time series of samples into the validator
58  * @param validator
59  * @param incr_value The amount to increment the value by on each iteration
60  * @param value_io (in/out) in: initial value, out: final value
61  * @param timestamp_io (in/out) in: initial timestamp, out: final timestamp
62  */
64  const float incr_value,
65  float *value_io,
66  uint64_t *timestamp_io);
67 
68 #endif //ECL_TESTS_COMMON_H
void dump_validator_state(DataValidator *validator)
Print out the state of a DataValidator.
void insert_values_around_mean(DataValidator *validator, const float mean, uint32_t count, float *rms_err, uint64_t *timestamp_io)
Insert a series of samples around a mean value.
void fill_validator_with_samples(DataValidator *validator, const float incr_value, float *value_io, uint64_t *timestamp_io)
Insert a time series of samples into the validator.
A data validation class to identify anomalies in data streams.