A public repository for BMS algorithms for a NUCLEO BOARD.
Hi Everyone!
Welcome to this repository from Howey's Research Group at the University of Oxford.
The code published here incorporates BMS algorithms for diagnosis functions such as SOC, SOH and Power estimation on a Kokam 53Ah Li-ion battery. This code was designed to work with a NUCLEO F401-RE board and to be tested with a dSPACE HIL Simulator. A short guide on how the set up works is available at https://bitbucket.org/ff95/bms .
The code is made up of three key parts. "Headers" and "Source" folders and the "main.cpp" file. As the code was generated by converting a Simulink model ( available on the BitBucket page), the headers and source code files generated by the conversion are in the corresponding "Headers" and "Source" folders. The "main.cpp" file sets up the ADC, the USB data transmission and starts the estimation (once a character "y" has been received by the computer it is connected to). It also transmits the data from the estimation via USB. Explanation on how to set up the communication with the board is available at BitBucket webpage, from where a MATLAB file can be downloaded which allows real time communication.
For any questions you can contact the author at federicomariaferrari@gmail.com .
The Simulink and Matlab files, together with a short guide, are all available at: https://bitbucket.org/ff95/bms.
Thanks for trying this out!
Federico
headers/Simulink/rt_nonfinite.h
- Committer:
- fmferrari
- Date:
- 2017-07-13
- Revision:
- 23:447ef1071e49
- Parent:
- 13:831eab218c33
File content as of revision 23:447ef1071e49:
// // Academic License - for use in teaching, academic research, and meeting // course requirements at degree granting institutions only. Not for // government, commercial, or other organizational use. // // File: rt_nonfinite.h // // Code generated for Simulink model 'EKF'. // // Model version : 1.113 // Simulink Coder version : 8.11 (R2016b) 25-Aug-2016 // C/C++ source code generated on : Mon Jan 16 11:49:59 2017 // // Target selection: ert.tlc // Embedded hardware selection: STMicroelectronics->ST10/Super10 // Code generation objectives: Unspecified // Validation result: Not run // #ifndef RTW_HEADER_rt_nonfinite_h_ #define RTW_HEADER_rt_nonfinite_h_ #include <stddef.h> #include "rtwtypes.h" #ifdef __cplusplus extern "C" { #endif extern real_T rtInf; extern real_T rtMinusInf; extern real_T rtNaN; extern real32_T rtInfF; extern real32_T rtMinusInfF; extern real32_T rtNaNF; extern void rt_InitInfAndNaN(size_t realSize); extern boolean_T rtIsInf(real_T value); extern boolean_T rtIsInfF(real32_T value); extern boolean_T rtIsNaN(real_T value); extern boolean_T rtIsNaNF(real32_T value); typedef struct { struct { uint32_T wordH; uint32_T wordL; } words; } BigEndianIEEEDouble; typedef struct { struct { uint32_T wordL; uint32_T wordH; } words; } LittleEndianIEEEDouble; typedef struct { union { real32_T wordLreal; uint32_T wordLuint; } wordL; } IEEESingle; #ifdef __cplusplus } // extern "C" #endif #endif // RTW_HEADER_rt_nonfinite_h_ // // File trailer for generated code. // // [EOF] //