AD电压采集
一、AD电压采集功能介绍
ShineBlink Core 单片机提供 4 个 AD 通道 A0-A3。AD 精度为 12 位,即 0-4096 对应电压 0 - 3.6V。
注意:A0-A3 的输入电压必须在 3.3V 以内。
Core 提供的 AD 功能函数包含:LIB_ADConfig() 和 LIB_ADCheckBufFull()。
其中 LIB_ADConfig 用来配置存储AD采样结果的Buffer容量Num(最大可配置为64),以及Buffer中每个采样结果的时间间隔Time(单位:us)。当配置完成后我们就可以通过调用LIB_ADCheckBufFull()函数来查询Buffer中的采样结果是否已装满,装满后我们就可以一次性从Buffer中读出所有的采样结果了。
这样做的意义在于,当我们配置好AD后,底层驱动会严格按照Time时间间隔来采样,而我们只需要保证在每Num * Time这段时间内调用LIB_ADCheckBufFull来查询并取出结果即可。
注意一旦调用LIB_ADConfig函数后,A0-A3这四个通道会同时以相同参数开始工作,开发者如果不需要同时用4个通道,可以只关心自己用的通道,其他的置之不顾即可。
二、本例程演示功能
通过A0通道采集外部电压值,每个采样点时间间隔10毫秒,每当采样点达到50个时,可以通过LIB_ADCheckBufFull函数读出50个采样点,求出这50个点的平均值,并通过 print() 函数打印输出。
A1,A2,A3通道此时其实也和A0一样工作着,因为这里我们只关心A0上的电压,所以A1,A2,A3在此例程中就不体现出来了。
三、接线图
四、完整代码
--配置A0-A3这四个通道同时开始工作,当每个通道采集满50个点时缓存满,每个点的采集时间间隔为10ms
LIB_ADConfig(50,10000)
--开始大循环
while(GC(1) == true)
do
A0_full_flag, A0_tab = LIB_ADCheckBufFull("A0")
--每当A0通道的缓存满以后,计算缓存内的50个元素的平均值,并换算成电压值print输出
--由LIB_ADConfig(50,10000)可以算出,此处大概是50X10000us=0.5秒执行一次
if A0_full_flag == 1 then
SUM = 0
for i = 1, #A0_tab do --此处#A0_tab的值是50,表示A0_tab表内的元素个数
SUM = SUM + A0_tab[i]
end
AVER = SUM / #A0_tab
--将A0通道的AD值转换成实际电压打印出来
print(string.format("A0=%.2fv\r\n", AVER*3.6/4096.0))
end
--这里只演示A0通道,如果想看A1,A2,A3通道的结果,复制上面的代码修改一下编号即可
end
如果感兴趣,上面代码中出现的LIB开头的库函数可以在 API文档 中通过Ctrl+F查询。
五、演示结果
最后在TF卡中的LOG.TXT文件中我们可以看到如上图所示的print打印内容。从时间戳可以看到确实是按照LIB_ADConfig(50,10000)设置,即每0.5秒输出一次50点的平均值。需要注意的是,我们从日志上计算每次输出的时间戳的差值可能不是精确的0.5秒,这是因为print打印输出是上层应用代码,实时性不是太精确。但底层AD采样驱动代码是严格按照10000us这个时间间隔来采集点,这点请不要担心。
六、结语
本文基于 FlexLua 低代码单片机技术,无需复杂单片机C语言开发。即使新手也可很容易用FlexLua零门槛开发各种功能丰富稳定可靠的 IoT 硬件,更多学习教程可参考 FlexLua 官网。
领取专属 10元无门槛券
私享最新 技术干货