1.背景

        此实验建立在STM32F429核心板基础上,对于深刻了解STM32Cube使用具有深刻意义。利用DMA进行ADC采样,具有速度快,极大减少CPU消耗的优势,对于数据采集系统具有很大的优势,特别是其单路2.4MSPS采样速度,三路组合可以达到惊人的7.2MSPS采样速度,对于一般应用均可满足。
2.STM32Cube配置
     2.1 工程建立在前面均与简述,这里不做赘述,系统时钟180MHz。
       2.2 ADC参数配置
      
      Scan Conversion Mode 扫描模式,当使用多通道需要使能。
      Continuous Conversion Mode 连续转化模式,当一路转化完成立马开始新一轮转化。
      ADC的时钟触发有两种方式,一种是通过定时器等外部中断源触发,另一种是ADC自身的时钟触发。
      这里选择Timer 3 Caputure Cpmpare 1 event 触发。
         
       ADC通过DMA来实现数据采集,DMA Setting参数如上图所示。这里需要注意的是Memory需要自加    1,并且使用FIFO,采用半满阈值设置,为了做“乒乓”调度算法。因为ADC是12bit的,故采用Half Word。
      
     开启DMA中断。
    2.3  采样定时脉冲设置
      因为ADC使用了Timer 3,所以需要对Timer 3 进行配置。如果ADC采用内部ADC时钟触发,则无需配    置。
               
            
        这里采用频率设置为500KHz,定时器时钟为180/2=90MHz,9分频之后是10MHz,然后counter period 是20,采样周期10M/20=500KHz。
    
       2.4 通过STM32Cube产生源码,使用MDK打开工程。
       在大循环之前加入语句
       uint16_t Samples_In[512]={0};
       HAL_TIM_PWM_Start(&htim3,TIM_CHANNEL_1);
  HAL_ADC_Start_DMA(&hadc1,(uint32_t *)&Samples_In[0],512);

3. ADC效果验证
     3.1 利用前述章节配置串口波特率115200,DMA发送使能。
     3.2 在ADC的FIFO结束中断上,关闭ADC的DMA,使其不再工作,通过串口将ADC采集到的512组16进制数据发送到PC机上,利用串口调试助手将其保存到名为“test_sina.txt”的文件中;
    3.3 打开matlab软件,新建.m文件,命名为“test_getdata.m”。
          写入语句:
clc;clear;
sina =textread('test_sina.txt','%s')';%以字符形式打开文件 
alpha = hex2dec(sina)'; %16进制转化为10进制数,存入alpha矩阵 
len = (length(alpha(1,:))+1)/2;
%len = 511;
for i=1:1:len
    s(1,i) = alpha(1,2*i-1)+alpha(1,2*i)*256;
end
x = 1:len;
plot(x,s);

信号发生器发生1KHz的正弦信号,通过MATLAB将ADC采集的数据还原如上图所示,是一个周期多一点点的正弦波。
理论计算:500KHz的采样率,采集1KHz的正弦信号,能够采集1个周期多一点点,跟MATLAB显示的一样。


为了更加形象显示图像,下节会使用DAC利用“乒乓”调度算法将ADC的数据实时输出。



附件列表

基于STM32Cube的ADC模数采样设计的更多相关文章

  1. STM32中基于DMA的ADC采样实例之MQ-2烟雾传感器

    最近学习了一下STM32中的ADC采样,由于手头正好有一个MQ-2的烟雾传感器,所以正好可以测试一把.体验ADC采样的过程.下面介绍一下这个MQ-2烟雾传感器. 1.MQ-2烟雾传感器简介 MQ-2气 ...

  2. DSP基础学习-ADC同步采样

    DSP基础学习-ADC同步采样 彭会锋 2015-04-28 20:31:06 在DSP28027 LauchPad学习过程中,关于ADC同步采样和顺序采样的区别稍加研究了一下,发现里面还真有些门道, ...

  3. 基于FPGA的XPT2046触摸控制器设计

    基于FPGA的XPT2046触摸控制器设计 小梅哥编写,未经许可,文章内容和所涉及代码不得用于其他商业销售的板卡 本实例所涉及代码均可通过向 xiaomeige_fpga@foxmail.com  发 ...

  4. 基于Linux的智能家居的设计(3)

    2  硬件设计 本课题的硬件设计包含主控制器.传输数据设计.数据採集设计.控制驱动设计.显示设计.门禁设计. 2.1  主控制器 依据方案三选择S3C6410主控芯片,S3C6410是由Samsung ...

  5. 基于AHB总线的master读写设计(Verilog)

    一.AHB总线学习 1. AHB总线结构 如图所示,AHB总线系统利用中央多路选择机制实现主机与从机的互联问题.从图中可以看出,AHB总线结构主要可分为三部分:主机.从机.控制部分.控制部分由仲裁器. ...

  6. 基于ZigBee的家居控制系统的设计与应用

    基于ZigBee的家居控制系统的设计与应用 PPT简介:http://pan.baidu.com/s/1i38PC6D 摘  要 智能家居是未来家居的发展方向,其利用先进的网络技术.计算机技术和无线通 ...

  7. 基于Verilog HDL 的数字时钟设计

    基于Verilog HDL的数字时钟设计 一.实验内容:     利用FPGA实现数字时钟设计,附带秒表功能及时间设置功能.时间设置由开关S1和S2控制,分别是增和减.开关S3是模式选择:0是正常时钟 ...

  8. Hi3518EV200平台ADC多通道采样

    Hi3518EV200平台ADC多通道采样流程 Hi3518EV200 ADC 本文针对Hi3518EV200平台处理器,通过ADC单次采样方式,实现对多通道(1~4通道)ADC进行采样控制.本文仅仅 ...

  9. 基于Web在线考试系统的设计与实现

    这是一个课程设计的文档,源码及文档数据库我都修改过了,貌似这里复制过来的时候图片不能贴出,下载地址:http://download.csdn.net/detail/sdksdk0/9361973   ...

随机推荐

  1. 在Linux上编译dotnet cli的源代码生成.NET Core SDK的安装包

    .NET 的开源,有了更多的DIY乐趣.这篇博文记录一下在新安装的 Linux Ubuntu 14.04 上通过自己动手编译 dotnet cli 的源代码生成 .net core sdk 的 deb ...

  2. ENode框架Conference案例分析系列之 - 事件溯源如何处理重构问题

    前言 本文可能对大多数不太了解ENode的朋友来说,理解起来比较费劲,这篇文章主要讲思路,而不是一上来就讲结果.我写文章,总是希望能把自己的思考过程尽量能表达出来,能让大家知道每一个设计背后的思考的东 ...

  3. Java NIO6:选择器2---代码篇

    选择器服务器端代码 上一篇文章毫无条理地讲了很多和选择器相关的知识点,下面进入实战,看一下如何写和使用选择器实现服务端Socket数据接收的程序,这也是NIO中最核心.最精华的部分. 看一下代码: p ...

  4. 作业二:个人编程项目——编写一个能自动生成小学四则运算题目的程序

    1. 编写一个能自动生成小学四则运算题目的程序.(10分)   基本要求: 除了整数以外,还能支持真分数的四则运算. 对实现的功能进行描述,并且对实现结果要求截图.   本题发一篇随笔,内容包括: 题 ...

  5. Linux的tree命令

    发现Linux下有个很好的命令,tree,能把目录以树的形式列出来,还支持很强大的参数. 但默认情况下是不带的,得自己去安装,先到这里下载它的代码:http://mama.indstate.edu/u ...

  6. Meteor + node-imap(nodejs) + mailparser(nodejs) 实现完整收发邮件

    版本信息: Meteor:windows MIS安装  0.6.4 node-imap:npm指定的0.8.0版,不是默认的0.7.x版. mailparser:npm安装0.3.6 以下是记录踩到的 ...

  7. C/C++ makefile自动生成工具(comake2,autotools,linux),希望能为开源做点微薄的贡献!

      序     在linux下C或C++项目开发,Makefile是必备的力气,但是发现手写很麻烦. 在百度有个comake2工具,用于自动生成Makefile工具,而在外边本想找一个同类工具,但发现 ...

  8. Unsupported major.minor version 51.0

    org/jboss/as/domain/management/security/adduser/AddUser : Unsupported major.minor version 51. 0 已编译好 ...

  9. Atitit 设计模式与算法,与流程的关系

    Atitit 设计模式与算法,与流程的关系 1.1. 设计模式就是算法 就是流程,不同的方面看法不同,抽象方法不同而造成的假象. 软件就是由设计模式累积成的.也可以说算法累计成的.. ,而可以用Vis ...

  10. Entity Framework Code First实体关联数据加载

    在项目过程中,两个实体数据之间在往往并非完全独立的,而是存在一定的关联关系,如一对一.一对多及多对多等关联.存在关联关系的实体,经常根据一个实体的实例来查询获取与之关联的另外实体的实例. Entity ...