STM32CubeMX实现DMA模式下AD转换.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
如何使用STM32CubeMX实现DMA模式下的AD转换 山西大学电子信息工程系,王晓峰 wangxiaofeng@sxu.edu.cn 1、在Pinout界面配置ADC输入通道(引脚) 在左边栏中勾选要选用为AD通道的引脚,每个ADC对应一组引脚,单击勾选即可。红色为冲突引脚。 2、时钟配置 图中的PCLK2 即为AD模块输入时钟。但不是最终转换速率,且最大转换速率不能超过器件上限(2.4MSPS)。 3、参数配置 进入configuration界面。点选ADC按钮。 模式为独立模式。 ClockPrescale 是对PCLK2进行分频。需要注意,完成一次AD 需要15个周期。所以最终的转换频率是 PCLK2 除2再除15。 Resolution:分辨率:12位二进制数 Dataalignment数据对齐:右对齐 ScanConversionMode:扫描转换模式,如果使用了一个ADC下的多个采集通道,需要选择Enable模式, 否则只会转换设置的第一个通道。 ContinuousConversionMode连续转换模式 DiscontinuousConversionMode:不连续转换模式 DMAContinuousrequests :DMA连续请求 EndofConversionSelection转换结束方式选择:可选择单通道转换完成后EOC标志置位或所有转换完成后 EOC置位。 ADC_Regular_ConversionMode:在此项下,需要手动将每一个AD通道添加到Rank里。 WatchDog:模拟看门狗 NVIC部分添加DMA流并开启中断(第二行),关闭中断模式的中断使能(第一行)。 Priority 优先级:可根据具体情况设定。但一定保持SysTick的优先级最高。 Memory :勾选此项,转换数据将存在Memory 中,并且地址自加连续存放。此功能对某个通道连续多次 采样很好用,采样数据会自动填满一个数组,方便软件滤波。 Mode :选循环模式,填满数组后自动从头刷新。 DataWidth 数据长度:如果是 12位AD转换,此处选半字。 在这个页面可以添加引脚标签。建议保持高阻(不上拉不下拉)。 4 程序实现 在STM32CubeMX生成好的程序基础上。 在main设置一个uhADCxConvertedValue2 的全局变量数组。类型为Uint16_t。 在main 函数的初始化区后,while(1)区前,添加: if(HAL_ADC_Start_DMA(hadc1,(uint32_t*)uhADCxConvertedValue2,100)!=HAL_OK)E or_Handler(); ADC1启动,并开始连续转换,转换结果会放在uhADCxConvertedValue2数组中,大小是 100。因为是连续转换, 所以数组中存放的是最近100次转换结果。 5 软件滤波 滤波子函数:可以计算 100个点的滤波结果。 此函数为中值平均滑动滤波,当然,滑动是ADC 的DMA 自动实现的。 uint16_tADC_Average(__IOuint16_t*buff,uint16_tnum,uint16_tthreshold) { uint32_t sigma=0; uint16_ti=0,j=0,temp=0; uint16_ttemp_buff[num]; for(i=0;inum;i++)temp_buff[i]=buff[i]; for(i=0;i(num-1);i++) { for(j=0;j(num-1);j++) { if(temp_buff[j]temp_buff[j+1]) { temp=temp_buff[j]; temp_buff[j]=temp_buff[j+1];

文档评论(0)

kehan123 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档