foxBMS  1.0.1
The foxBMS Battery Management System API Documentation
plausibility.h
Go to the documentation of this file.
1 /**
2  *
3  * @copyright © 2010 - 2021, Fraunhofer-Gesellschaft zur Foerderung der angewandten Forschung e.V.
4  * All rights reserved.
5  *
6  * SPDX-License-Identifier: BSD-3-Clause
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions are met:
10  *
11  * 1. Redistributions of source code must retain the above copyright notice, this
12  * list of conditions and the following disclaimer.
13  *
14  * 2. Redistributions in binary form must reproduce the above copyright notice,
15  * this list of conditions and the following disclaimer in the documentation
16  * and/or other materials provided with the distribution.
17  *
18  * 3. Neither the name of the copyright holder nor the names of its
19  * contributors may be used to endorse or promote products derived from
20  * this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
23  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
26  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
28  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
30  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  * We kindly request you to use one or more of the following phrases to refer to
34  * foxBMS in your hardware, software, documentation or advertising materials:
35  *
36  * - ″This product uses parts of foxBMS®″
37  * - ″This product includes parts of foxBMS®″
38  * - ″This product is derived from foxBMS®″
39  *
40  */
41 
42 /**
43  * @file plausibility.h
44  * @author foxBMS Team
45  * @date 2020-02-24 (date of creation)
46  * @updated 2020-02-24 (date of last update)
47  * @ingroup APPLICATION
48  * @prefix PL
49  *
50  * @brief plausibility checks for cell voltage and cell temperatures
51  *
52  */
53 
54 #ifndef FOXBMS__PLAUSIBILITY_H_
55 #define FOXBMS__PLAUSIBILITY_H_
56 
57 /*========== Includes =======================================================*/
58 #include "plausibility_cfg.h"
59 
60 #include "database.h"
61 
62 /*========== Macros and Definitions =========================================*/
63 
64 /*========== Extern Constant and Variable Declarations ======================*/
65 
66 /*========== Extern Function Prototypes =====================================*/
67 /**
68  * @brief Pack voltage plausibility check between LTC and current sensor values
69  *
70  * @param voltageMic_mV pack voltage measured by MIC
71  * @param voltageCurrentSensor_mV pack voltage measured by current sensor
72  *
73  * @return #STD_OK if pack voltage valid, otherwise #STD_NOT_OK
74  */
75 extern STD_RETURN_TYPE_e PL_CheckStringVoltage(int32_t voltageMic_mV, int32_t voltageCurrentSensor_mV);
76 
77 /*========== Externalized Static Functions Prototypes (Unit Test) ===========*/
78 
79 /**
80  * @brief Cell voltage plausibility check between two redundant cell voltage measurement values
81  *
82  * @param[in] baseCellVoltage cell voltage from base measurement
83  * @param[in] redundancy0CellVoltage cell voltage from redundant measurement
84  * @param[out] pCellVoltage output cell voltage after plausibility check
85  *
86  * @return #STD_OK if cell voltage valid, otherwise #STD_NOT_OK
87  */
89  int16_t baseCellVoltage,
90  int16_t redundancy0CellVoltage,
91  int16_t *pCellVoltage);
92 
93 /**
94  * @brief Cell temperature plausibility check between two redundant cell temperature measurement values
95  *
96  * @param[in] baseCelltemperature cell temperature from base measurement
97  * @param[in] redundancy0Celltemperature cell temperature from redundant measurement
98  * @param[out] pCelltemperature output cell temperature after plausibility check
99  *
100  * @return #STD_OK if cell voltage valid, otherwise #STD_NOT_OK
101  */
103  int16_t baseCelltemperature,
104  int16_t redundancy0Celltemperature,
105  int16_t *pCelltemperature);
106 
107 /**
108  * @brief Cell voltage spread plausibility check
109  *
110  * @param[in,out] pCellvoltages pointer to cell voltage database entry
111  * @param[in] pMinMaxAverageValues pointer to minimum/maximum/average database entry
112  *
113  * @return #STD_OK if no issue detected, otherwise #STD_NOT_OK
114  */
116  DATA_BLOCK_CELL_VOLTAGE_s *pCellvoltages,
117  DATA_BLOCK_MIN_MAX_s *pMinMaxAverageValues);
118 
119 /**
120  * @brief Cell temperature spread plausibility check
121  *
122  * @param[in,out] pCellTemperatures pointer to cell temperature database entry
123  * @param[in] pMinMaxAverageValues pointer to minimum/maximum/average database entry
124  *
125  * @return #STD_OK if no issue detected, otherwise #STD_NOT_OK
126  */
128  DATA_BLOCK_CELL_TEMPERATURE_s *pCellTemperatures,
129  DATA_BLOCK_MIN_MAX_s *pMinMaxAverageValues);
130 
131 #endif /* FOXBMS__PLAUSIBILITY_H_ */
PL_CheckTemperatureSpread
STD_RETURN_TYPE_e PL_CheckTemperatureSpread(DATA_BLOCK_CELL_TEMPERATURE_s *pCellTemperatures, DATA_BLOCK_MIN_MAX_s *pMinMaxAverageValues)
Cell temperature spread plausibility check.
Definition: plausibility.c:151
PL_CheckCelltemperature
STD_RETURN_TYPE_e PL_CheckCelltemperature(int16_t baseCelltemperature, int16_t redundancy0Celltemperature, int16_t *pCelltemperature)
Cell temperature plausibility check between two redundant cell temperature measurement values.
Definition: plausibility.c:102
STD_RETURN_TYPE_e
enum STD_RETURN_TYPE STD_RETURN_TYPE_e
PL_CheckVoltageSpread
STD_RETURN_TYPE_e PL_CheckVoltageSpread(DATA_BLOCK_CELL_VOLTAGE_s *pCellvoltages, DATA_BLOCK_MIN_MAX_s *pMinMaxAverageValues)
Cell voltage spread plausibility check.
Definition: plausibility.c:119
PL_CheckStringVoltage
STD_RETURN_TYPE_e PL_CheckStringVoltage(int32_t voltageMic_mV, int32_t voltageCurrentSensor_mV)
Pack voltage plausibility check between LTC and current sensor values.
Definition: plausibility.c:73
DATA_BLOCK_CELL_TEMPERATURE
Definition: database_cfg.h:131
DATA_BLOCK_CELL_VOLTAGE
Definition: database_cfg.h:115
plausibility_cfg.h
plausibility checks for cell voltage and cell temperatures
DATA_BLOCK_MIN_MAX
Definition: database_cfg.h:158
database.h
Database module header.
PL_CheckCellvoltage
STD_RETURN_TYPE_e PL_CheckCellvoltage(int16_t baseCellVoltage, int16_t redundancy0CellVoltage, int16_t *pCellVoltage)
Cell voltage plausibility check between two redundant cell voltage measurement values.
Definition: plausibility.c:85