stm32定时器输入捕获模式

频率测量

频率测量有两种方法

  • 测频法:在闸门时间T内,对上升沿或下降沿计次,得到N,则评率fx=N/T
  • 测周法:两个上升沿内,以标准频率fc计次得到N,则频率fx= fc/N
  • 中界频率:测频法和测周法误差相等的点fm=√(fc/T),fx大于fm选用测频法更准确。

定时器输入捕获测频原理

在说原理前需要先讲一下定时器的主从模式
主模式则是设置定时器输出时上升沿/下降沿触发自动执行的操作
从模式则是设置定时器输入时上升沿/下降沿触发自动执行的操作
下面我们用到的从模式是复位模式,进入中断定时器的计数器会自动复位清零

在这里插入图片描述
这是定时器运行框图,输入捕获只有看红色框出来的部分就可以了。可能有点抽象,接下来我来翻译一下。

首先是第一框中的TI1代表的是定时器x的通道1GPIO引脚输入的波频,TI2、3、4同理

然后看到是第二个框中第一条通道的TI1FP1和TI1FP2,分别代表的是,TI1这个波频输入哪一个通道处理,TI1FP1则使用定时器通道1的资源对TI1这个波频进行捕获上升沿/下降沿,TI1FP2则使用的是定时器通道2的资源,TI2FP1则代表TI2这个波频使用定时器通道1的资源。

然后就到了处理波频的步骤了,在我们第一个上升沿到来时,定时器的CNT寄存器开始计时,然后下一个上升沿到来,CNT里的值传入CCR输入/比较寄存器,接下来从模式将CNT寄存器自动清零。我们将CCR里的值取出就可以知道一个周期计时值,通过该值大小知道该波频的频率高低。

整个流程如下图
在这里插入图片描述

定时器输入捕获测量占空比(PWMI模式)

上文提到,定时器通道1的引脚输入的波频可以分为TI1FP1和TI2FP2到两个通道的计时器处理,那么我们将一段波频分别给两个定时器通道处理,一个捕获上升沿,一个捕获下降沿,在第二次捕获上升沿的中断进入时,用捕获上升沿的CCR1获取的值减去捕获下降沿的CCR2的值就可以得到高电平的时间,计算即可得到占空比。

如下图所示
在这里插入图片描述
具体步骤:
第一次捕获到上升沿:CNT开始计时
第一次捕获到下降沿:CCR2获取CNT的值,得到高电平时间
第二次捕获到上升沿:CCR1获取CNT的值,进入从模式清除CNT的值,得到周期

那么就可以计算出占空比了。

定时器编码器模式

stm32的定时器拥有编码器模式,使我们可以使用编码器,计算电机转速

AB相编码器

这种编码器可以理解为编码器会输出两个相差90°相位差的波频,而通过A相在前还是B相在前,判断电机正转反转。
在这里插入图片描述
该模式的操作原理比较简单
两波频进入编码器接口后,判断相位差是哪个在前,如果为A相在前就将计数器加1,负责计数器减1。

使用定时器编码模式的软件代码

#include "stm32f10x.h"
#include "hal_TIM.h"/****************************************************************************
*@*名称 : hal_TIM_Encoder_Config
*@*功能 : 初始化定时器2的编码器模式
*@*形参 : 无
*@*返回值 : 无
****************************************************************************/
static void hal_TIM_Encoder_Config(void)
{RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIMx, ENABLE);RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);GPIO_InitTypeDef GPIO_InitStructure;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;									//上拉输入GPIO_InitStructure.GPIO_Pin = TIM_ENCODER_A_PIN | TIM_ENCODER_B_PIN;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &GPIO_InitStructure);TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;TIM_TimeBaseInitStructure.TIM_ClockDivision = TIM_CKD_DIV1;		//时钟分频因子TIM_TimeBaseInitStructure.TIM_CounterMode = TIM_CounterMode_Up;TIM_TimeBaseInitStructure.TIM_Period = 65536 - 1;		//ARRTIM_TimeBaseInitStructure.TIM_Prescaler = 1 - 1;		//PSC	预分频器		//使用系统时钟作为定时器的编码器模式的时钟,实现 1 至 65536 分频TIM_TimeBaseInitStructure.TIM_RepetitionCounter = 0;TIM_TimeBaseInit(TIMx, &TIM_TimeBaseInitStructure);TIM_ICInitTypeDef TIM_ICInitStructure;TIM_ICStructInit(&TIM_ICInitStructure);												//因为结构体没有定义完整,但担心有不知名错误,先初始化结构体TIM_ICInitStructure.TIM_Channel = TIM_Channel_1;TIM_ICInitStructure.TIM_ICFilter = 0xF;												//滤波次数7次TIM_ICInit(TIMx, &TIM_ICInitStructure);TIM_ICInitStructure.TIM_Channel = TIM_Channel_2;TIM_ICInitStructure.TIM_ICFilter = 0xF;TIM_ICInit(TIMx, &TIM_ICInitStructure);TIM_EncoderInterfaceConfig(TIMx, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Rising);TIM_Cmd(TIMx, ENABLE);
}/****************************************************************************
*@*名称 : hal_TIM_Encoder_Init
*@*功能 : 初始化定时器2的编码器模式
*@*形参 : 无
*@*返回值 : 无
****************************************************************************/
void hal_TIM_Encoder_Init(void)
{hal_TIM_Encoder_Config();
}/****************************************************************************
*@*名称 : hal_TIM_Encoder_Get
*@*功能 : 获取定时器编码器模式计数的CNT(TIM_EncoderMode_TI12通道12都计数,一个周期记4次)
*@*形参 : 无
*@*返回值 : CNT计数值
****************************************************************************/
int16_t hal_TIM_Encoder_Get(void)
{int16_t Temp;Temp = TIM_GetCounter(TIMx);return Temp;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/208172.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python Pyvis库详解:创建交互式网络图

更多Python学习内容:ipengtao.com 大家好,我是涛哥,今天为大家分享 Python Pyvis库详解:创建交互式网络图,文章4000字,阅读大约15分钟,大家enjoy~~ Pyvis是一个基于JavaScript库NetworkX的Pytho…

git-2

1.分离头指针情况下的注意事项 分离头指针指的是变更没有基于某个branch去做,所以当进行分支切换的时候,在分离头指针上产生的commit,很可能会被git当作垃圾清理掉,如果你认为是重要的内容,切记需要绑定分支 2.进一步…

【11月比赛合集】48场可报名的数据挖掘大奖赛,任君挑选!

CompHub[1] 实时聚合多平台的数据类(Kaggle、天池…)和OJ类(Leetcode、牛客…)比赛。本账号会推送最新的比赛消息,欢迎关注! 以下信息仅供参考,以比赛官网为准 目录 Kaggle(9场比赛)阿里天池(…

基于蛇优化算法优化概率神经网络PNN的分类预测 - 附代码

基于蛇优化算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于蛇优化算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于蛇优化优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要:针对PNN神经网络…

ubuntu借助overlay方案实现重启自动还原

配置重启还原OS 首先:sudo apt install overlayroot 安装一下软件 然后编辑配置文件:/etc/overlayroot.conf * overlayroottmpfs or overlayroottmpfs:PARAMETERS write all changes to a temporary (ram only) backing device A tmpfs mount will …

中职组网络安全B模块-渗透提权2

任务五:渗透提权2 任务环境说明: 仅能获取xxx的IP地址 用户名:test,密码:123456 访问服务器主机,找到主机中管理员名称,将管理员名称作为Flag值提交; Flag:doyoudoyoudo 访问服…

srs的webrtc信令分析

关于webrtc的流信令只有四个 /rtc/v1/publish/,这是推流接口,是推流客户端跟SRS交换SDP的接口 /rtc/v1/play/,这是拉流接口,是拉流客户端跟SRS交换SDP的接口 /rtc/v1/whip/,这也是推流接口,作用是也是交换…

汇编-PUSHFD和POPFD标志寄存器值压栈和出栈

PUSHFD指令将32位EFLAGS寄存器内容压入堆栈, 而POPFD指令则将栈顶单元内容弹出到EFLAGS寄存器 格式:

Rust语言特性探秘:宏的魔力

大家好!我是lincyang。 今天我们继续深入探讨Rust语言中的一个有趣而强大的特性——宏(Macros)。 宏在Rust中扮演着特殊的角色,不仅提高了代码的灵活性,还增强了代码的可重用性。接下来,我们会通过具体的…

c语言——俄罗斯方块

一、游戏效果 俄罗斯方块 二. 游戏背景 俄罗斯方块是久负盛名的游戏,它也和贪吃蛇,扫雷等游戏位列经典游戏的⾏列。 《俄罗斯方块》(Tetris,俄文:Тетрис)是一款由俄罗斯人阿列克谢帕基特诺夫于1984…

数学建模之拟合及其代码

发现新天地,欢迎访问Cr不是铬的个人网站 引言 与插值问题不同,在拟合问题中不需要曲线一定经过给定的点。拟合问题的目标是寻求一个函数(曲线),使得该曲线在某种准则下与所有的数据点最为接近,即曲线拟合…

SpringBoot_websocket实战

SpringBoot_websocket实战 前言1.websocket入门1.1 websocket最小化配置1.1.1 后端配置1.1.2 前端配置 1.2 websocket使用sockjs1.2.1 后端配置1.2.2 前端配置 1.3 websocket使用stomp协议1.3.1 后端配置1.3.2 前端配置 2.websocket进阶2.1 websocket与stomp有什么区别2.2 webs…