foxBMS
1.2.1
The foxBMS Battery Management System API Documentation
|
Header fileS for handling redundancy between redundant cell voltage and cell temperature measurements. More...
Go to the source code of this file.
Data Structures | |
struct | MRC_STATE |
Macros | |
#define | MRC_CURRENT_MEASUREMENT_PERIOD_TIMEOUT_ms (250u) |
#define | MRC_AFE_MEASUREMENT_PERIOD_TIMEOUT_ms (250u) |
#define | MRC_CURRENT_SENSOR_MEASUREMENT_TIMEOUT_ms (300u) |
#define | MRC_ALLOWED_NUMBER_OF_INVALID_CELL_VOLTAGES (5u) |
Typedefs | |
typedef struct MRC_STATE | MRC_STATE_s |
Functions | |
STD_RETURN_TYPE_e | MRC_Initialize (void) |
Function to initalize redundancy module. More... | |
STD_RETURN_TYPE_e | MRC_ValidateAfeMeasurement (void) |
Function to validate the measurement between redundant measurement values for cell voltage and cell temperature. More... | |
STD_RETURN_TYPE_e | MRC_ValidatePackMeasurement (void) |
Function to validate the measurements of pack values (string values, pack values) More... | |
Header fileS for handling redundancy between redundant cell voltage and cell temperature measurements.
SPDX-License-Identifier: BSD-3-Clause
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
We kindly request you to use one or more of the following phrases to refer to foxBMS in your hardware, software, documentation or advertising materials:
Definition in file redundancy.h.
#define MRC_AFE_MEASUREMENT_PERIOD_TIMEOUT_ms (250u) |
Maximum time between AFE measurements before the redundancy module raises an error because a measurement is not updated anymore.
The redundancy module will wait a maximum of this time for new values from the base AFE measurement and AFE redundant measurements. If no new values are updated from both measurement sources within this timeframe it will validate the measurement values it has up to this point if possible.
Definition at line 87 of file redundancy.h.
#define MRC_ALLOWED_NUMBER_OF_INVALID_CELL_VOLTAGES (5u) |
If both, the current sensor and the AFE measurement have no valid values we try to construct the string voltage by replacing invalid cell voltage measurements with the average cell voltage in this string. The result of this estimation will be flagged as invalid if more than the number of allowed invalid cell voltages are detected. The result will be markes as valid if less then this number of cells are detected as invalid.
Definition at line 110 of file redundancy.h.
#define MRC_CURRENT_MEASUREMENT_PERIOD_TIMEOUT_ms (250u) |
Maximum time between measurements before the redundancy module raises an error because a measurement is not updated anymore.
The redundancy module will wait a maximum of this time for new current values. If no new values are updated within this timeframe it will invalidate the measurement values.
Definition at line 73 of file redundancy.h.
#define MRC_CURRENT_SENSOR_MEASUREMENT_TIMEOUT_ms (300u) |
Maximum time between current sensor high voltage, current and power measurements before the redundancy module raises an error because a measurement is not updated anymore.
The redundancy module will wait a maximum of this time for new values from the current sensor. If no new values are updated within this timeframe it will validate the measurement values it has up to this point if possible.
Definition at line 100 of file redundancy.h.
typedef struct MRC_STATE MRC_STATE_s |
This structure contains all the variables relevant for the redundancy state machine.
STD_RETURN_TYPE_e MRC_Initialize | ( | void | ) |
Function to initalize redundancy module.
< bitmask if current is valid. 0->valid, 1->invalid
< bitmask if voltage is valid. 0->valid, 1->invalid
< bitmask if voltage is valid. 0->valid, 1->invalid
< bitmask if power is valid. 0->valid, 1->invalid
Definition at line 1092 of file redundancy.c.
STD_RETURN_TYPE_e MRC_ValidateAfeMeasurement | ( | void | ) |
Function to validate the measurement between redundant measurement values for cell voltage and cell temperature.
Definition at line 1117 of file redundancy.c.
STD_RETURN_TYPE_e MRC_ValidatePackMeasurement | ( | void | ) |
Function to validate the measurements of pack values (string values, pack values)
Definition at line 1158 of file redundancy.c.