stm32内部温度传感器

一、系统架构

主要实现的功能是串口打印输出以及ADC1通道1将模拟量转化成为数字量并将这个数字量

通过一次关系得到温度值,并将得到的温度值打印到出去 

 

二、环境配置 

采用cubemx进行配置

主要配置串口1 temsenor 以及我们的PA8h和PD2使小灯进行闪烁 

 

 

 

 

这里我们可以看到有一个温度传感器选项,其实也就是我们的ADC1的通道16

我们也可以下下面HAL库中宏定义得到验证 

三、编码 

这里我为了方便演示,所以我就只写出.c文件的函数实现  .h文件由渎者来进行自行添加 

1.在mian.c中添加我们的printf端口重定向 

	#if 1
#pragma import(__use_no_semihosting)             
//标准库需要的支持函数                 
struct __FILE 
{ 
	int handle; 

}; 

FILE __stdout;       
//定义_sys_exit()以避免使用半主机模式    
void _sys_exit(int x) 
{ 
	x = x; 
} 
//重定义fputc函数 
int fputc(int ch, FILE *f)
{      
	while((USART1->SR&0X40)==0);//循环发送,直到发送完毕   
    USART1->DR = (uint8_t) ch;      
	return ch;
}
#endif 

 2.在adc.c中编写测试函数以及将模拟量转化成为数字量的方法,最后还有将数字量如何转化成为温度值的代码 

/* USER CODE BEGIN 1 */

//这个是一个adc温度传感的通道代码
void adctenor_test(void){
	
	
	//我们知道温度传感器的通道是16,所以我们这里只需要对通道16进行采样
	//通过采样的电压值通过线性变换能够得到温度的值
	
	HAL_GPIO_TogglePin(GPIOA,GPIO_PIN_8);
	HAL_GPIO_TogglePin(GPIOD,GPIO_PIN_2);

    printf("\n\r准备进行温度转换.......................\r\n");	
	
	
	double tem = ADC_GET_TEM(); //得到温度值
	
	printf("\n\r温度值为%f\r\n",tem);	
	
	HAL_Delay(1000);
	
	
}



//获得ADC值
//ch: 通道值 0~16,取值范围为:ADC_CHANNEL_0~ADC_CHANNEL_16
//返回值:转换结果
uint16_t Get_Adc(uint32_t ch)   
{
    ADC_ChannelConfTypeDef ADC1_ChanConf;
    
    ADC1_ChanConf.Channel=ch;                                   //通道
    ADC1_ChanConf.Rank=1;                                       //第1个序列,序列1
    ADC1_ChanConf.SamplingTime=ADC_SAMPLETIME_239CYCLES_5;      //采样时间               
    HAL_ADC_ConfigChannel(&hadc1,&ADC1_ChanConf);        //通道配置
	
    HAL_ADC_Start(&hadc1);                               //开启ADC
	
    HAL_ADC_PollForConversion(&hadc1,10);                //轮询转换
 
	return (uint16_t)HAL_ADC_GetValue(&hadc1);	        	//返回最近一次ADC1规则组的转换结果
}


//编写一个方法,通过取平均值得到准确值

//获取指定通道的转换值,取times次,然后平均 
//times:获取次数
//返回值:通道ch的times次转换结果平均值
uint16_t Get_Adc_Average(uint32_t ch,uint8_t times)
{
	uint32_t temp_val=0;
	uint8_t t;
	for(t=0;t<times;t++)
	{
		temp_val+=Get_Adc(ch);
		HAL_Delay(5);
	}
	return temp_val/times;
} 



//这个方法是返回ADC通道转化后的温度的
double ADC_GET_TEM(){
	
	//首先我们得到20次采样的通道的数字量  也就是我们通道16的值
	int adcx = Get_Adc_Average(ADC_CHANNEL_TEMPSENSOR,20);
	double temperate=(float)adcx*(3.3/4096); //电压值
	temperate = (temperate - 0.76) / 0.0025 + 25;
	double result= temperate * 100; //扩大 100 倍.
	return result;
}


/* USER CODE END 1 */

 3.在mian.c添加我们的测试代码

/* USER CODE BEGIN WHILE */
  while (1)
  {
	  adctenor_test();
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }

 四、实验现象

 

 

通过串口打印发现出了点问题..............

应该是在这个    temperate = (temperate - 0.76) / 0.0025 + 25; 转化出现了点问题

如果读者有更好的回归分析请赐教。             作者是摆烂哥!!!先撤了 

  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值