0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

工程师笔记 | 使用 TIMER 输出比较模式输出相移信号

jf_pJlTbmA9 来源:STM32单片机 作者:STM32单片机 2023-09-18 10:58 次阅读

1、前言

客户想要使用 STM32L031 产生两个特定的 PWM 波,这两个波形频率相同,占空比相同,但相位不同。经过验证,使用定时器的输出比较模式可以产生这种带相移的 PWM 波形。

下面以 STM32L031 的 TIM2 为例来介绍使用产生相移信号的方法。

2、概述

在未使能预装载寄存器时(OCxPE=0),使用输出比较模式,可以随时通过软件更新

TIM_CCRx 寄存器的值,以控制输出波形。

DMA 的循环模式,可以在最后一次数据传输完成后,自动重新加载初始编程值,内部地址寄存器会重新加载基址值,进入下一个循环。

使用输出比较模式配合 DMA 的循环模式可以不断更新 TIMx_CCR 寄存器的值,从而输出可控的波形。

下面以 NUCLEO-L031 为例介绍产生相移信号的方法。

3、目标波形

为了便于观察,令 PWM 波的周期为 100ms,占空比为 20%。以 TIM2_CH1 输出的波形的为基准,其为 0 度相移。

➢ TIM2_CH1: 相移 0 度,占空比为 20%

➢ TIM2_CH2: 相移 90 度,占空比为 20%

➢ TIM2_CH3: 相移 180 度,占空比为 20%

➢ TIM2_CH4: 相移 270 度,占空比为 20%

4. 使用 STM32CubeMX 进行配置

使用 STM32CubeMX 进行基础参数的配置。

这里配置时钟为 32MHz,如图 1 所示。

wKgaomUD3vWAduTwAAJYZw8L61I475.png

配置时钟源为内部时钟,因为 TIM2_CH1 为基准信号,直接配置为 PWM 输出即可。

TIM2_CH2、TIM2_CH3 和 TIM2_CH4 配置为输出比较模式,如图 2 所示。

wKgZomUD3vaAQJImAACa2i7L31w082.png

配置 TIM2 的预分频值与计数周期,配置计数周期为 100,计数模式配置为"Up"。配置channel1 的模式为"PWM mode 1",因为占空比为 20%,计数周期为 100,所以 CCR1 寄存器配置为 20(也即 Channel1 的 Pulse 配置为"20"),极性配置为"High"。Channel2、Channel3 和 Channel4 的模式都配置为"Toggle on match"(匹配时翻转电平),极性配置为"low",CCR 不需要配置,因为会通过 DMA 自动写入。具体配置如图 3 所示。

wKgaomUD3vqAYqVPAAI56OYLxrk948.png

添加 TIM2_CH2、TIM2_CH3 和 TIM2_CH4 的 DMA,并进行配置,配置的内容都相同,配置如下:

➢ Direction: Memory To Peripheral

➢ Mode: Circular

➢ Data Width: Word

具体配置如图 4 所示

wKgZomUD3vuAWmh_AAFMbn5Ltr4081.png

5. 修改代码

由 STM32CubeMX 生成代码之后,需要在生成的代码中添加一些处理。

首先需要计算 channel2、channel3 和 channel4 的 CCR 值。以 channel2 为例:配置的计数周期为 100,初始极性为 low,当 CNT 计数值与 CCR 寄存器匹配的时候,输出电平发生翻转,所以为了实现与 channel1 占空比相同的波形,需要翻转两次电平。

第一次翻转的 CCR 可以通过相位差进行计算,第二次翻转的 CCR 值可以通过占空比和第一次翻转的 CCR 值这两个条件进行计算。Channel2 第一次翻转的 CCR 值为: "100 x (90°/360°) = 25";第二次翻转的 CCR 值为:"25 + (20% x 100) = 45"

表 1 由上面计算方式同理可得:

wKgZomUD3v2AQoQIAABcapiq70M129.png

在 main.c 文件中需要建立三个数组,将 channel2~4 的两次 CCR 值存入这三个数组中,具体如下所示:

wKgaomUD3v6AEGUcAAA-5VaifZk887.png


wKgaomUD3v-AMqKnAAAPmnjWj8U237.png

然后在 mian 函数中添加如下代码。使 channel1 输出 PWM 波,配置 channel2~4 在 DMA 模式下使用输出比较模式进行输出。

wKgZomUD3wGAWvphAAB5aYLz3E0901.png

6. 测试结果

测试结果如下图所示,4 个 channel 产生的 PWM 波的周期都为 100ms,占空比都为20%,测试出来的 channel2~4 的相移与设计目标波形一致。

wKgZomUD3wKAbsBuAACxpYAjSYc554.png

7、小结

使用定时器的输出比较模式与 DMA 进行搭配,可以比较灵活的生成波形。

来源:STM32单片机
免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理


审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5377

    浏览量

    121398
  • PWM
    PWM
    +关注

    关注

    114

    文章

    5203

    浏览量

    215110
  • 定时器
    +关注

    关注

    23

    文章

    3256

    浏览量

    115526
收藏 人收藏

    评论

    相关推荐

    TFP401APZP为什么没有HSYNC输出

    笔记本电脑作为HDMI信号源时,TFP401APZP没有HSYNC信号输出,VSYNC,ODCK输出正常。 将
    发表于 12-23 07:57

    ADS1299内部测试信号调试OK,正常测试信号信号输出全为7FFFFF,为什么?

    错,但内部测试信号可正常显示,而正常输入不行? 4、寄存器配置方面比较EVM与自己配置的寄存器表,配置相一致,因此排除以上因素,还是未能解决问题,希望TI的工程师与论坛的各位朋友们能够帮忙解答,万分感谢!
    发表于 12-19 06:12

    FPGA算法工程师、逻辑工程师、原型验证工程师有什么区别?

    ,如数字信号处理、图像处理、人工智能等,并将其转化为适合 FPGA 实现的硬件逻辑。重点在于算法的性能提升、资源利用效率以及与系统的集成。 FPGA 逻辑工程师: 侧重于 FPGA 内部逻辑电路
    发表于 09-23 18:26

    红石比较器两种模式的作用

    红石比较器是Minecraft中的一种非常重要的红石元件,它用于比较两个红石信号的强度,并根据比较结果输出不同的
    的头像 发表于 09-05 09:17 760次阅读

    过零比较器的输出电压由什么决定

    输出电压是由输入信号的幅度和相位决定的。 过零比较器的工作原理 过零比较器的基本工作原理是将输入信号与一个参考电压进行
    的头像 发表于 08-06 15:16 1326次阅读

    正是拼的年纪|65岁电子工程师上班VLOG #65岁退休 #电子工程师 #搞笑 #上班vlog

    电子工程师
    安泰小课堂
    发布于 :2024年07月25日 11:31:02

    什么是推挽输出模式,什么是开漏输出模式?

    (一个NPN型和一个PNP型)来实现输出。当输入信号为高电平时,NPN型晶体管导通,PNP型晶体管截止,输出端呈现低阻抗的高电平;当输入信号为低电平时,NPN型晶体管截止,PNP型晶体
    的头像 发表于 07-09 14:22 3174次阅读

    大厂电子工程师常见面试题#电子工程师 #硬件工程师 #电路知识 #面试题

    电子工程师电路
    安泰小课堂
    发布于 :2024年04月30日 17:33:15

    stm32比较输出timer_etr没有计数是为什么?

    请教有人搞过STM32L比较输出内部配到到timer_etr的计数吗。比较器的比较输出已经搞通
    发表于 04-23 06:39

    利用TIMER测量信号周期及占空比的精度

    有人使用STM32G4系列的通用型TIMER基于捕获功能对外来信号进行周期及占空比的测量。他用TIM3产生频率、占空比可调的PWM输出做为被测信号。TIM4用来进行频率测量,工作在复位
    的头像 发表于 02-25 10:11 1668次阅读
    利用<b class='flag-5'>TIMER</b>测量<b class='flag-5'>信号</b>周期及占空比的精度