如何使用TPYBoard读取芯片上的温度传感器
这篇文章主要介绍了如何使用TPYBoard读取芯片上的温度传感器,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
一、STM32内部温度传感器概要
STM32芯片内部一项独特的功能就是内部集成了一个温度传感器,因为是内置,所以测试的是芯片内部的温度,如果芯片外接负载一定的情况下,那么芯片的发热也基本稳定,相对于外界的温度而言,这个偏差值也是基本稳定的.也就是说用STM32内部传感器来测量外界环境的温度。
在一些恶劣的应用环境下面,可以通过检测芯片内部而感知设备的工作环境温度,如果温度过高或者过低了则马上睡眠或者停止运转.可以保证您的设备工作的可靠性。
目前我国的北斗导航定位系统已经比较成熟,北斗导航应用的范围越来越广,正是基于这个时代大背景下做出一块利用北斗系统定位的开发板,可以方便演示定位系统,提高北斗智慧的技术技能,让更多的人了解北斗智慧以及北斗导航相关知识和开发北斗相关产品方向。
二、STM32内部温度传感器参数
1.STM32内部温度传感器与ADC的通道16相连,与ADC配合使用实现温度测量;
2.测量范围-40~125℃,精度±1.5℃。
3.温度传感器产生一个随温度线性变化的电压,转换范围在2V 手册中对于公式中的参数说明: 三、读取温度的实现原理 写代码的时候,在测量要求不怎么高的情况下,公式可以简化。简化的公式: Temperature=(1.42-ADC_Value*3.3/4096)*1000/4.35+25 程序编写: 1.初始化ADC,初始化DMA 注意:内部温度传感器是使用了ADC1的第16通道哦. 2.ADC_TempSensorVrefintCmd(ENABLE); 使能温度传感器和内部参考电压通道 3.按照刚才列出的公式计算 Temperature=(1.42-ADC_Value*3.3/4096)*1000/4.35+25; 四、TPYBoard读取温度例程 感谢你能够认真阅读完这篇文章,希望小编分享的"如何使用TPYBoard读取芯片上的温度传感器"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!# main.py -- put your code here!import pybimport timeimport stmfrom pyb import Pindef adcread(chan): # 16 temp 17 vbat 18 vref assert chan >= 16 and chan <= 18, 'Invalid ADC channel' start = pyb.millis() timeout = 100 stm.mem32[stm.RCC + stm.RCC_APB2ENR] |= 0x100 # enable ADC1 clock.0x4100 stm.mem32[stm.ADC1 + stm.ADC_CR2] = 1 # Turn on ADC stm.mem32[stm.ADC1 + stm.ADC_CR1] = 0 # 12 bit if chan == 17: stm.mem32[stm.ADC1 + stm.ADC_SMPR1] = 0x200000 # 15 cycles stm.mem32[stm.ADC + 4] = 1 << 23 elif chan == 18: stm.mem32[stm.ADC1 + stm.ADC_SMPR1] = 0x1000000 stm.mem32[stm.ADC + 4] = 0xc00000 else: stm.mem32[stm.ADC1 + stm.ADC_SMPR1] = 0x40000 stm.mem32[stm.ADC + 4] = 1 << 23 stm.mem32[stm.ADC1 + stm.ADC_SQR3] = chan stm.mem32[stm.ADC1 + stm.ADC_CR2] = 1 | (1 << 30) | (1 << 10) # start conversion while not stm.mem32[stm.ADC1 + stm.ADC_SR] & 2: # wait for EOC if pyb.elapsed_millis(start) > timeout: raise OSError('ADC timout') data = stm.mem32[stm.ADC1 + stm.ADC_DR] # clear down EOC stm.mem32[stm.ADC1 + stm.ADC_CR2] = 0 # Turn off ADC return datadef v33(): return 4096 * 1.21 / adcread(17)def vbat(): return 1.21 * 2 * adcread(18) / adcread(17) # 2:1 divider on Vbat channeldef vref(): return 3.3 * adcread(17) / 4096def temperature(): return 25 + 400 * (3.3 * adcread(16) / 4096 - 0.76)adc = pyb.ADCAll(12)leds = [pyb.LED(i) for i in range(1,5)]sw=pyb.Switch()def test(): pyb.LED(1).on() pyb.LED(2).on() pyb.LED(3).on() pyb.LED(4).on() pyb.delay(2000)sw.callback(test)for l in leds: l.off()n = 0try: while True: n = (n + 1) % 4 leds[n].toggle() pyb.delay(50) print('v33:',v33()) print('vbat:',vbat()) print('vref:',vref()) print('temperature:',temperature())finally: for l in leds: l.off()