STM32中的DFSDM应用介绍

前言

STM32超低功耗系列中基于Cortex M4内核的STM32L4系列芯片内部集成了DFSDM数字滤波模块,配合Σ-Δ器件的使用,可进行高精度、高速率的AD测量。这里就DFSDM做些基本介绍,并结合STM32L4 MCU做一个实例应用演示。

应用系统框图 

系统被分为两部分:STM32外部的模拟前端Σ-Δ模块和内置的数字部分DFSDM模块。

       DFSDM是STM32产品内置的一个新的数字外设,通常搭配外部的Σ-Δ器件使用。可根据相应的应用选择外部的模拟部分,进行测量、马达控制等应用。模拟部分提供串行数据给DFSDM,DFSDM负责对数字信号进行处理。

        DFSDM数字部分集成了模拟看门狗、注入和常规转换、灵活的触发系统、中断信号生成、极值检测等。

Σ-Δ模块

  • 输入模拟信号。

  • 输出1位或2位的快速串行数字信号,可达20MHz速率。

  • 广泛的厂商支持: ST, TI,Analog Devices。

DFSDM= Digital Filter for Sigma Delta Modulators

  • 从Σ-Δ模块接收串行数据

  • 对接收到的Σ-Δ模块数据进行滤波

  • 最大24位的输出精度

典型应用

  • 电信号测量:电流、电压等。

  • 马达控制

  • 医疗应用

  • 麦克风音频

STM32 DFSDM架图如下:

收发器

  • 快速串行输入(20MHz)

  • SPI或曼切斯特编码模式

  • 时钟生成

  • 内部并行输入

  • 由CPU/DMA写入的16位寄存器数据输入

  • 收发器提供串行连接到外部Σ-Δ模块,支持SPI、曼切斯特协议。收发器也支持通过CPU或DMA写入到DFSDM数据寄存器的内部16位并行数据输入,

滤波器

  • Sinc1,Sinc2,Sinc3,Sinc4,Sinc5,FastSinc内插滤波器,过采样因子可达1024.

  • 积分器过采样因子可达1024

STM32 DFSDM应用框图如下:

整个DFSDM模块包含如下接口:

  • 8个串行收发器

  • 4个Sinc滤波器和积分器

  • 4个输出数据单元

  • 4个模拟看门狗

  • 8个短路检测器

  • 4个极值检测器

  • 8个并行数据进入寄存器

串行收发器

功能

  • 从Σ-Δ模块接收1位的串行数据,提供时钟和数据给滤波阶段,最大支持8个输入串行通道。

    支持的协议

  • 1线曼切斯特编码

  • SPI模式(时钟和数据线)

  • 上升沿、下降沿采样

  • 数据速率测量

  • 时钟缺失检测

  • 时钟速率高达20MHz

  • 串行输入(时钟和数据)通道的 DFSDM_DATINy和DFSDM_CKINy引脚可被重定向,通道重定向用于收集来自立体麦克风类型的PDM音频数据,PDM立体麦克风具有时钟和数据信号,数据通道提供左右声道信息,左声道进行时钟上升沿采样,右声道进行时钟下降沿采样。

并行收发器

功能

  • 从内部数据源接收16位的并行数据,并提供数据给滤波阶段。多达8个并行通道。

    内部并行输入数据源

  • RAM数据后期处理

  • 来自内部ADC的数据处理

  • 来自被收集数据的后期处理数据

  • CPU或者DMA提供数据到DFSDM输入寄存器

利用STM32 DFSDM进行温度测量的应用原理图如下:

STPMS2是一个双通道的二阶Σ-Δ模块,一个通道感知PT100的电压,另一个通道感知PT100的电流。使用1秒定时器来触发2个通道进行注入扫描转换。PC7(DFSDM1_DATIN3)是通道3,时钟为PC2(DFSDM1_CKOUT)。通道3测量PT100的电压,通道2测量PT100的电流。

PT100温度计算公式为:T = (PT100 – 100) / (0.385),只要通过能够测量出PT100的电压和电流,就能计算出PT100电阻值,进而得到温度值。

有时间需要仔细查阅!

  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值