2024-07-10 09:19:00 +00:00
|
|
|
|
#include "hp203b.h"
|
2024-07-18 10:15:50 +00:00
|
|
|
|
#include "i2c.h"
|
2024-11-09 01:25:43 +00:00
|
|
|
|
#include "filter.h"
|
2024-07-18 08:31:44 +00:00
|
|
|
|
#include "anemometer_dev.h"
|
|
|
|
|
|
2024-07-10 09:19:00 +00:00
|
|
|
|
/****************************
|
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>
|
2024-07-10 09:19:00 +00:00
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2024-07-18 08:31:44 +00:00
|
|
|
|
*
|
|
|
|
|
*
|
2024-07-10 09:19:00 +00:00
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
*****************************/
|
2024-07-18 08:31:44 +00:00
|
|
|
|
void hp203_set_mode()
|
2024-07-10 09:19:00 +00:00
|
|
|
|
{
|
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-10 09:19:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/****************************
|
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>
|
2024-11-23 04:05:21 +00:00
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2024-07-18 08:31:44 +00:00
|
|
|
|
*
|
|
|
|
|
*
|
2024-11-23 04:05:21 +00:00
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD><EFBFBD>ѹ
|
2024-07-10 09:19:00 +00:00
|
|
|
|
*****************************/
|
2024-12-05 08:10:01 +00:00
|
|
|
|
BOOL Hp203bReadPressure(float *press)
|
2024-07-10 09:19:00 +00:00
|
|
|
|
{
|
2024-11-09 01:25:43 +00:00
|
|
|
|
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;
|
2024-12-05 08:10:01 +00:00
|
|
|
|
return FALSE;
|
2024-12-14 02:36:44 +00:00
|
|
|
|
}
|
2024-12-05 08:10:01 +00:00
|
|
|
|
return TRUE;
|
2024-07-10 09:19:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-11-09 01:25:43 +00:00
|
|
|
|
/****************************
|
2024-11-23 04:05:21 +00:00
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD>ƣ<EFBFBD>Hp203bReadTempture
|
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD>ܣ<EFBFBD><EFBFBD><EFBFBD>ȡ<EFBFBD>¶<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2024-11-09 01:25:43 +00:00
|
|
|
|
*
|
|
|
|
|
*
|
2024-11-23 04:05:21 +00:00
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD>¶<EFBFBD>
|
|
|
|
|
*****************************/
|
2024-12-05 08:10:01 +00:00
|
|
|
|
BOOL Hp203bReadTempture(float *press)
|
2024-11-23 04:05:21 +00:00
|
|
|
|
{
|
2024-12-14 02:36:44 +00:00
|
|
|
|
uint32_t Hp203b_tempture = 0;
|
2024-11-23 04:05:21 +00:00
|
|
|
|
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;
|
2024-11-23 04:05:21 +00:00
|
|
|
|
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;
|
|
|
|
|
}
|
2024-12-05 08:10:01 +00:00
|
|
|
|
return TRUE;
|
2024-11-23 04:05:21 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/****************************
|
|
|
|
|
*<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>ѹֵ
|
|
|
|
|
*
|
|
|
|
|
*
|
2024-11-09 01:25:43 +00:00
|
|
|
|
*<EFBFBD><EFBFBD><EFBFBD>أ<EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
*****************************/
|
2024-11-23 04:05:21 +00:00
|
|
|
|
#define COLLECT_HB203_DATA_NUM 10
|
|
|
|
|
BOOL get_HP203_data(float* tempdata, float* press)
|
2024-12-14 02:36:44 +00:00
|
|
|
|
{
|
2024-12-28 09:00:34 +00:00
|
|
|
|
uint8_t ret;
|
|
|
|
|
uint8_t temp_falt = 0;
|
|
|
|
|
uint8_t press_falt = 0;
|
2024-11-23 04:05:21 +00:00
|
|
|
|
// ѹǿ
|
|
|
|
|
U_DataType collect_pressure[COLLECT_HB203_DATA_NUM]={0x00};
|
2024-11-09 01:25:43 +00:00
|
|
|
|
|
2024-11-23 04:05:21 +00:00
|
|
|
|
for(int i=0; i<COLLECT_HB203_DATA_NUM; i++){
|
2024-12-14 02:36:44 +00:00
|
|
|
|
hp203_set_mode();
|
2024-12-28 09:28:37 +00:00
|
|
|
|
osDelay(5);
|
2024-12-05 08:10:01 +00:00
|
|
|
|
ret = Hp203bReadPressure(&collect_pressure[i].fValue);
|
|
|
|
|
if(ret == FALSE)
|
|
|
|
|
{
|
2024-12-28 09:00:34 +00:00
|
|
|
|
press_falt++;
|
|
|
|
|
continue;
|
|
|
|
|
//goto error_return;
|
2024-12-05 08:10:01 +00:00
|
|
|
|
}
|
2024-12-28 09:28:37 +00:00
|
|
|
|
osDelay(5);
|
2024-11-09 01:25:43 +00:00
|
|
|
|
}
|
2024-12-28 09:00:34 +00:00
|
|
|
|
if(press_falt >= COLLECT_HB203_DATA_NUM)
|
|
|
|
|
{
|
|
|
|
|
goto error_return;
|
|
|
|
|
}
|
2024-12-14 02:36:44 +00:00
|
|
|
|
|
2024-12-28 09:00:34 +00:00
|
|
|
|
U_DataType tmp_press = filter_middle(collect_pressure, COLLECT_HB203_DATA_NUM - press_falt, FILTER_DATA_TYPE_FLOAT);
|
2024-11-09 01:25:43 +00:00
|
|
|
|
if(tmp_press.fValue < 300)
|
|
|
|
|
{
|
2024-11-23 04:05:21 +00:00
|
|
|
|
// return FALSE;
|
|
|
|
|
goto error_return;
|
2024-11-09 01:25:43 +00:00
|
|
|
|
}
|
|
|
|
|
if(tmp_press.fValue > 1200)
|
|
|
|
|
{
|
2024-11-23 04:05:21 +00:00
|
|
|
|
// return FALSE;
|
|
|
|
|
goto error_return;
|
|
|
|
|
}
|
|
|
|
|
// <20>¶<EFBFBD>
|
|
|
|
|
U_DataType 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();
|
2024-12-28 09:28:37 +00:00
|
|
|
|
osDelay(5);
|
2024-12-05 08:10:01 +00:00
|
|
|
|
ret = Hp203bReadTempture(&collect_tempture[i].fValue);
|
|
|
|
|
if(ret == FALSE)
|
|
|
|
|
{
|
2024-12-28 09:00:34 +00:00
|
|
|
|
temp_falt++;
|
|
|
|
|
continue;
|
|
|
|
|
//goto error_return;
|
2024-12-05 08:10:01 +00:00
|
|
|
|
}
|
2024-12-28 09:28:37 +00:00
|
|
|
|
osDelay(5);
|
2024-11-23 04:05:21 +00:00
|
|
|
|
}
|
2024-12-28 09:00:34 +00:00
|
|
|
|
if(temp_falt >= COLLECT_HB203_DATA_NUM)
|
|
|
|
|
{
|
|
|
|
|
goto error_return;
|
|
|
|
|
}
|
2024-12-14 02:36:44 +00:00
|
|
|
|
|
2024-12-28 09:00:34 +00:00
|
|
|
|
U_DataType tmp_tempture = filter_middle(collect_tempture, COLLECT_HB203_DATA_NUM - temp_falt, FILTER_DATA_TYPE_FLOAT);
|
2024-12-14 02:36:44 +00:00
|
|
|
|
if(tmp_tempture.fValue < -50)
|
2024-11-23 04:05:21 +00:00
|
|
|
|
{
|
|
|
|
|
// return FALSE;
|
|
|
|
|
goto error_return;
|
|
|
|
|
}
|
2024-12-14 02:36:44 +00:00
|
|
|
|
if(tmp_tempture.fValue > 95)
|
2024-11-23 04:05:21 +00:00
|
|
|
|
{
|
|
|
|
|
// return FALSE;
|
|
|
|
|
goto error_return;
|
2024-11-09 01:25:43 +00:00
|
|
|
|
}
|
|
|
|
|
|
2024-11-23 04:05:21 +00:00
|
|
|
|
*tempdata = tmp_tempture.fValue;
|
|
|
|
|
*press = tmp_press.fValue;
|
2024-11-09 01:25:43 +00:00
|
|
|
|
return TRUE;
|
2024-11-23 04:05:21 +00:00
|
|
|
|
|
|
|
|
|
error_return:
|
|
|
|
|
*tempdata = 0;
|
|
|
|
|
*press = 0;
|
|
|
|
|
return FALSE;
|
2024-11-09 01:25:43 +00:00
|
|
|
|
}
|