micro_climate/Drivers/HP203B/hp203b.c

184 lines
4.3 KiB
C
Raw Permalink Normal View History

#include "hp203b.h"
2024-07-18 10:15:50 +00:00
#include "i2c.h"
#include "filter.h"
2024-07-18 08:31:44 +00:00
#include "anemometer_dev.h"
/****************************
2024-07-18 08:31:44 +00:00
*<EFBFBD><EFBFBD><EFBFBD>ƣ<EFBFBD>set_mode
*<EFBFBD><EFBFBD><EFBFBD>ܣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ôӻ<EFBFBD>ģʽ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͨ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2024-07-18 08:31:44 +00:00
*
*
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD><EFBFBD>
*****************************/
2024-07-18 08:31:44 +00:00
void hp203_set_mode()
{
2024-07-18 10:15:50 +00:00
uint8_t cmd[1] = {HP20X_CONVERT_OSR1024};
HAL_I2C_Master_Transmit(&hi2c3, HP20X_ADDRESSCMD, cmd, 1, 0xff);
}
/****************************
2024-07-18 08:31:44 +00:00
*<EFBFBD><EFBFBD><EFBFBD>ƣ<EFBFBD>Hp203bReadPressure
2024-07-18 10:15:50 +00:00
*<EFBFBD><EFBFBD><EFBFBD>ܣ<EFBFBD><EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD>ѹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2024-07-18 08:31:44 +00:00
*
*
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD><EFBFBD>ѹ
*****************************/
BOOL Hp203bReadPressure(float *press)
{
long Hp203b_Pressure = 0;
uint8_t Hp203bPressure_Temp[3] = {0};
2024-07-18 10:15:50 +00:00
uint8_t read_command[1] = {HP20X_READ_P};
HAL_I2C_Master_Transmit(&hi2c3, HP20X_ADDRESSCMD, read_command, 1, 0xff);
HAL_I2C_Master_Receive(&hi2c3, HP20X_ADDRESSCMD, Hp203bPressure_Temp, 3, 0xff);
2024-07-18 08:31:44 +00:00
Hp203b_Pressure = Hp203bPressure_Temp[0];
Hp203b_Pressure <<= 8;
Hp203b_Pressure |= Hp203bPressure_Temp[1];
Hp203b_Pressure <<= 8;
Hp203b_Pressure |= Hp203bPressure_Temp[2];
2024-12-14 02:36:44 +00:00
*press = (float)Hp203b_Pressure / 100.0f;
if(*press < 300 || *press > 1200)
{
*press = 0;
return FALSE;
2024-12-14 02:36:44 +00:00
}
return TRUE;
}
/****************************
*<EFBFBD><EFBFBD><EFBFBD>ƣ<EFBFBD>Hp203bReadTempture
*<EFBFBD><EFBFBD><EFBFBD>ܣ<EFBFBD><EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*
*
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD><EFBFBD>
*****************************/
BOOL Hp203bReadTempture(float *press)
{
2024-12-14 02:36:44 +00:00
uint32_t Hp203b_tempture = 0;
uint8_t Hp203bPressure_Temp[3] = {0};
uint8_t read_command[1] = {0x32};
HAL_I2C_Master_Transmit(&hi2c3, HP20X_ADDRESSCMD, read_command, 1, 0xff);
HAL_I2C_Master_Receive(&hi2c3, HP20X_ADDRESSCMD, Hp203bPressure_Temp, 3, 0xff);
2024-12-14 02:36:44 +00:00
Hp203b_tempture = (Hp203bPressure_Temp[0] & 0x0F)<<16;
Hp203b_tempture |= Hp203bPressure_Temp[1]<<8;
Hp203b_tempture |= Hp203bPressure_Temp[2];
2024-12-14 02:36:44 +00:00
if((Hp203b_tempture>>19) & 1){
Hp203b_tempture = (((~Hp203b_tempture) + 1) & 0xFFFFF);
*press = -(float)Hp203b_tempture / 100.0f;
}
else{
*press = (float)Hp203b_tempture / 100.0f;
}
if(*press<-50||*press>95){
*press = 0;
return FALSE;
}
return TRUE;
}
static float calculateAverage(float arr[], int avgLength) {
float sum = 0;
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><E9A3A8><EFBFBD><EFBFBD>10<31><30>Ԫ<EFBFBD>أ<EFBFBD><D8A3><EFBFBD><EFBFBD>ռ<EFBFBD><D5BC><EFBFBD><EFBFBD><EFBFBD>ֱֵ<D6B5><D6B1><EFBFBD>ﵽָ<EFB5BD><D6B8><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
for (int i = 0; i < 10; ++i) {
sum += arr[i];
}
// <20><><EFBFBD><EFBFBD>ƽ<EFBFBD><C6BD>ֵ<EFBFBD><D6B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ
float average = sum / avgLength;
return average;
}
/****************************
*<EFBFBD><EFBFBD><EFBFBD>ƣ<EFBFBD>get_press_data
*<EFBFBD><EFBFBD><EFBFBD>ܣ<EFBFBD><EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD>ѹ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Press--<EFBFBD><EFBFBD>ѹֵ
*
*
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD><EFBFBD>
*****************************/
#define COLLECT_HB203_DATA_NUM 10
BOOL get_HP203_data(float* tempdata, float* press)
2024-12-14 02:36:44 +00:00
{
uint8_t ret;
uint8_t temp_falt = 0;
uint8_t press_falt = 0;
// ѹǿ
float collect_pressure[COLLECT_HB203_DATA_NUM]={0x00};
for(int i=0; i<COLLECT_HB203_DATA_NUM; i++){
2024-12-14 02:36:44 +00:00
hp203_set_mode();
osDelay(5);
ret = Hp203bReadPressure(&collect_pressure[i]);
if(ret == FALSE)
{
press_falt++;
continue;
//goto error_return;
}
osDelay(5);
}
if(press_falt >= COLLECT_HB203_DATA_NUM)
{
goto error_return;
}
//<2F><>ƽ<EFBFBD><C6BD>
float tmp_press = calculateAverage(collect_pressure, COLLECT_HB203_DATA_NUM - press_falt);
if(tmp_press < 300)
{
// return FALSE;
goto error_return;
}
if(tmp_press > 1200)
{
// return FALSE;
goto error_return;
}
// <20><EFBFBD>
float collect_tempture[COLLECT_HB203_DATA_NUM]={0x00};
for(int i=0; i<COLLECT_HB203_DATA_NUM; i++){
2024-12-14 02:36:44 +00:00
hp203_set_mode();
osDelay(5);
ret = Hp203bReadTempture(&collect_tempture[i]);
if(ret == FALSE)
{
temp_falt++;
continue;
//goto error_return;
}
osDelay(5);
}
if(temp_falt >= COLLECT_HB203_DATA_NUM)
{
goto error_return;
}
//<2F><>ƽ<EFBFBD><C6BD>
float tmp_tempture = calculateAverage(collect_tempture, COLLECT_HB203_DATA_NUM - temp_falt);
if(tmp_tempture < -50)
{
// return FALSE;
goto error_return;
}
if(tmp_tempture > 95)
{
// return FALSE;
goto error_return;
}
*tempdata = tmp_tempture;
*press = tmp_press;
return TRUE;
error_return:
*tempdata = 0;
*press = 0;
return FALSE;
}