调试备忘录-NTC电阻的使用(教程 + 代码)

软件环境:CodeWarrior 11.1

硬件环境:NXP S9KEAZ64A

传感器参数:NTC热敏电阻(R25 = 50k,B25-50 3950) 

写在前面

  最近做小项目需要用到NTC电阻,因此写一个调试备忘录记录下。

什么是NTC电阻?

  NTC热敏电阻就是负温度系数的电阻,当温度升高时,电阻降低(反之则为PTC电阻)。NTC电阻灵敏度高,温度分辨率高,但

是测量温度范围较窄,通常低于100摄氏度。

NTC电阻与温度之间的关系

  NTC热敏电阻温度和电阻关系最常见的公式就是如下图基于参数“β”的指数公式,公式比较简单,也是非常常用的公式。(其中的

β,有些资料也称为B) 

  其中,

  

  因此,如果知道了RT2 、T2和B的值,就可以计算出任意温度下NTC热敏电阻的阻值,或者计算出任意NTC热敏电阻阻值对应的温

度值。常规应用中,厂家一般会给出T=298.15k下的阻值和B值,不同型号的NTC热敏电阻其参数也是不同。

NTC电阻的实际应用

  在购买使用NTC电阻之前,我们需要先确认NTC电阻在25℃的阻值,然后设计温度采样电路。可以先和商家确认热敏电阻的阻值表。

例如:下表部分阻值表的截图,其中的R25=15KΩ就是热敏电阻在25℃时候的阻值,B25/50就是25℃-50℃时候的B值。

  因此如果我想检测温度的话,直接将检测到的电阻值带入上面的公式,就可以得到当前的温度了。

  当然,如果你检测区间不在25℃-50℃,你也可以自己将阻值表里面的数据,带入公式中,得出你目标区间的B值,进而在一定区间内比较精准的检测温度。

  对于NTC热敏电阻的检测电路,直接使用最简单的分压电路就可以了。如下图:

                                                                                

RT1阻值的计算方法为:R = (adc_value * 20 * 1.0 /  (adc_all - adc_value))  ;

  其中,adc_all 为你的ADC采样精度,例如8位精度就是0xFF,adc_value为你的ADC实际采样值,20为电路中的分压电阻,20K。1.0是为了确保有小数结果。

所以最终的温度为:

1

2

3

4

ADC_Channel_Vlaue = ADC_Read(ch);                   //Read ADC value from channel n

R = (20 * ADC_Channel_Vlaue * 1.0 /(255 - ADC_Channel_Vlaue));      //8位精度

Temperature1_Value = 1/ (log( R / R25 )  / B + 1 / (273.15 + 25));

Temperature1_Value = Temperature1_Value - 273.15;

1

Temperature1_Value 为最终的温度。

附上函数的全部代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

float Temperature_Measurement(UINT8 ch)

{

    UINT8 Temperature_Counter = 0;

    UINT8 ADC_Channel_Vlaue = 0;

    float Temperature1_Value;  

    float Temperature1_Sum_Value = 0;

    float Temperature1_Average_Value = 0;

    float R25 = 50;

    float R = 0;

    float B = 3950;

     

    while(Temperature_Counter<100)

    {

        Temperature_Counter++;

        ADC_Channel_Vlaue = ADC_Read(ch);                 //Read ADC value from channel n

        R = (20 * ADC_Channel_Vlaue * 1.0 /(255 - ADC_Channel_Vlaue));   //

        Temperature1_Value = 1/ (log( R / R25 )  / B + 1 / (273.15 + 25));

        Temperature1_Value = Temperature1_Value - 273.15;

        Temperature1_Sum_Value = Temperature1_Sum_Value + Temperature1_Value;  

        ADC_SC1 = 0 ;                      

    }      

     

    Temperature1_Average_Value = Temperature1_Sum_Value / Temperature_Counter; 

     

    return (Temperature1_Average_Value);   

}

  

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
下面是使用NUCLEO-U575ZI-Q开发板读取NTC电阻温度的ADC代码(假设NTC电阻与ADC引脚PA0相连): ```c #include "stm32u5xx_hal.h" ADC_HandleTypeDef hadc; void SystemClock_Config(void); static void MX_GPIO_Init(void); static void MX_ADC1_Init(void); int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); MX_ADC1_Init(); while (1) { // 开始ADC转换 HAL_ADC_Start(&hadc); // 等待转换完成 HAL_ADC_PollForConversion(&hadc, HAL_MAX_DELAY); // 读取ADC值并计算温度(假设NTC电阻分压电阻为10kΩ,B值为3950K) uint16_t adc_value = HAL_ADC_GetValue(&hadc); float voltage = adc_value * 3.3 / 4096; // ADC参考电压为3.3V,分辨率为12位(4096个量化级别) float resistance = 10000 * voltage / (3.3 - voltage); float temperature = 1 / (1 / 298.15 + 1 / 3950 * log(resistance / 10000)) - 273.15; // 输出温度 printf("Temperature: %.2f\n", temperature); // 延时一段时间 HAL_Delay(1000); } } void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** Supply configuration update enable */ HAL_PWREx_ConfigSupply(PWR_LDO_SUPPLY); /** Configure the main internal regulator output voltage */ __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1); while (!__HAL_PWR_GET_FLAG(PWR_FLAG_VOSRDY)) { } /** Initializes the RCC Oscillators according to the specified parameters * in the RCC_OscInitTypeDef structure. */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI48 | RCC_OSCILLATORTYPE_HSI | RCC_OSCILLATORTYPE_LSE; RCC_OscInitStruct.HSIState = RCC_HSI_ON; RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT; RCC_OscInitStruct.LSEState = RCC_LSE_ON; RCC_OscInitStruct.HSI48State = RCC_HSI48_ON; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /** Initializes the CPU, AHB and APB buses clocks */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK | RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_PCLK1 | RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK) { Error_Handler(); } } static void MX_ADC1_Init(void) { ADC_MultiModeTypeDef multimode = {0}; ADC_ChannelConfTypeDef sConfig = {0}; hadc.Instance = ADC1; hadc.Init.ClockPrescaler = ADC_CLOCK_ASYNC_DIV1; hadc.Init.Resolution = ADC_RESOLUTION_12B; hadc.Init.ScanConvMode = ADC_SCAN_DISABLE; hadc.Init.ContinuousConvMode = DISABLE; hadc.Init.DiscontinuousConvMode = DISABLE; hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START; hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE; hadc.Init.DMAContinuousRequests = DISABLE; hadc.Init.Overrun = ADC_OVR_DATA_OVERWRITTEN; hadc.Init.SamplingTimeCommon1 = ADC_SAMPLETIME_640CYCLES_5; hadc.Init.SamplingTimeCommon2 = ADC_SAMPLETIME_640CYCLES_5; hadc.Init.OversamplingMode = DISABLE; hadc.Init.TriggerFrequencyMode = ADC_TRIGGER_FREQ_HIGH; hadc.Init.LowPowerAutoWait = DISABLE; hadc.Init.LowPowerFrequencyMode = DISABLE; hadc.Init.LowPowerAutoPowerOff = DISABLE; hadc.Init.ChannelsBank = ADC_CHANNELS_BANK_A; hadc.Init.VREF = ADC_VREF_INTERNAL; if (HAL_ADC_Init(&hadc) != HAL_OK) { Error_Handler(); } multimode.Mode = ADC_MODE_INDEPENDENT; if (HAL_ADCEx_MultiModeConfigChannel(&hadc, &multimode) != HAL_OK) { Error_Handler(); } sConfig.Channel = ADC_CHANNEL_0; sConfig.Rank = ADC_RANK_CHANNEL_NUMBER; sConfig.SamplingTime = ADC_SAMPLETIME_640CYCLES_5; sConfig.SingleDiff = ADC_SINGLE_ENDED; sConfig.OffsetNumber = ADC_OFFSET_NONE; sConfig.Offset = 0; if (HAL_ADC_ConfigChannel(&hadc, &sConfig) != HAL_OK) { Error_Handler(); } } static void MX_GPIO_Init(void) { GPIO_InitTypeDef GPIO_InitStruct = {0}; /* GPIO Ports Clock Enable */ __HAL_RCC_GPIOA_CLK_ENABLE(); /*Configure GPIO pin : PA0 */ GPIO_InitStruct.Pin = GPIO_PIN_0; GPIO_InitStruct.Mode = GPIO_MODE_ANALOG; GPIO_InitStruct.Pull = GPIO_NOPULL; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Snow_2018

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值