06:【江科大stm32】:定时器输入捕获功能

2024-09-01 13:44

本文主要是介绍06:【江科大stm32】:定时器输入捕获功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定时器输入捕获功能

  • 1、通过定时器的输入捕获功能测量PWM波的频率
  • 2、PWMI模式测量频率和占空比

1、通过定时器的输入捕获功能测量PWM波的频率

在这里插入图片描述在这里插入图片描述定时器标准库相关的编程接口:

在这里插入图片描述

①PWM.c文件的代码如下:

/*通过定时器TIM2生成一个分辨率为10us,频率为1KHz的PWM波,
*/
#include "stm32f10x.h"                  // Device header/*使用定时器TIM2,通过通道CH1(PA0)输出PWM波
*/
void PWM_Init(void)
{//1.使能时钟RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);//2.选择内部时钟TIM_InternalClockConfig(TIM2);//3.对时基单元进行配置TIM_TimeBaseInitTypeDef TIM_TimeInitStruct;TIM_TimeInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;//时钟源分频TIM_TimeInitStruct.TIM_CounterMode = TIM_CounterMode_Up;//向上计数TIM_TimeInitStruct.TIM_Period = 100 - 1;//计数器,PWM的频率 = 1KHz,T = 1msTIM_TimeInitStruct.TIM_Prescaler = 720 - 1;//预分频器,72M/720 = 100kHzTIM_TimeInitStruct.TIM_RepetitionCounter = 0;//重复计数器TIM_TimeBaseInit(TIM2,&TIM_TimeInitStruct);//4.对输出比较单元进行配置TIM_OCInitTypeDef TIM_OCInitStruct;TIM_OCStructInit(&TIM_OCInitStruct);//给结构体默认初始值TIM_OCInitStruct.TIM_OCMode = TIM_OCMode_PWM1;//选择PWM1模式TIM_OCInitStruct.TIM_OCPolarity = TIM_OCPolarity_High;//选择正极性TIM_OCInitStruct.TIM_OutputState = TIM_OutputState_Enable;//通道使能TIM_OCInitStruct.TIM_Pulse = 0;//CCR的初始值TIM_OC1Init(TIM2, &TIM_OCInitStruct);//5.配置CH1通道对应的引脚PA0RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);GPIO_InitTypeDef GPIOInitStruct;GPIOInitStruct.GPIO_Mode = GPIO_Mode_AF_PP;//复用推挽输出GPIOInitStruct.GPIO_Pin = GPIO_Pin_0;GPIOInitStruct.GPIO_Speed = GPIO_Speed_2MHz;GPIO_Init(GPIOA,&GPIOInitStruct);//6.使能定时器TIM_Cmd(TIM2,ENABLE);
}void PWM_Set(uint16_t Compare)
{TIM_SetCompare1(TIM2,Compare);//更改CCR的值,及改变占空比
}void Set_PSC(uint32_t Pres)
{TIM_PrescalerConfig(TIM2,Pres,TIM_PSCReloadMode_Immediate);//更改预分频PSC的值
}

②PWM.h文件的代码如下:

#ifndef __PWM_H
#define __PWM_H
#include "stm32f10x.h"                  // Device headervoid PWM_Init(void);
void PWM_Set(uint16_t Compare);
void Set_PSC(uint32_t Pres);#endif

③IC.c文件的代码如下:

#include "stm32f10x.h"                  // Device headervoid IC_Init(void)
{/*由于输入捕获通道和输出比较通道不能够同时的使用我们使用了TIM2的CH1产生了1KHz的PWM波形,所以我们使用TIM3的CH1(PA6)进行对PWM波形的输入进行捕获,测量其频率接线时,将输出PWM的引脚(PA0)连接到输出捕获的引脚(PA6)*/	//1. 使能TIM3的时钟RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);//2. 选择内部时钟源TIM_InternalClockConfig(TIM3);//3.配置时基单元TIM_TimeBaseInitTypeDef TIM_TimeInitStruct;TIM_TimeInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;//时钟源滤波分频TIM_TimeInitStruct.TIM_CounterMode = TIM_CounterMode_Up;//向上计数TIM_TimeInitStruct.TIM_Period = 65536 - 1;//计数器TIM_TimeInitStruct.TIM_Prescaler = 72 - 1;//预分频器,1MHz,即1us计数1次TIM_TimeInitStruct.TIM_RepetitionCounter = 0;//重复计数器TIM_TimeBaseInit(TIM3,&TIM_TimeInitStruct);//4.对输入捕获引脚进行初始化RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);GPIO_InitTypeDef GPIOInitStruct;GPIOInitStruct.GPIO_Mode = GPIO_Mode_IPU;//上拉输入GPIOInitStruct.GPIO_Pin = GPIO_Pin_6;GPIO_Init(GPIOA,&GPIOInitStruct);//5.对输入捕获单元进行初始化TIM_ICInitTypeDef TIM_ICInitStruct;TIM_ICInitStruct.TIM_Channel = TIM_Channel_1;//选择通道CH1,它不像输出比较每个通道都有一个函数TIM_OC?Init()TIM_ICInitStruct.TIM_ICFilter = 0xF;//对捕获的信号进行滤波TIM_ICInitStruct.TIM_ICPolarity = TIM_ICPolarity_Rising;//极性不反向TIM_ICInitStruct.TIM_ICPrescaler = TIM_ICPSC_DIV1;//对捕获信号进行1分频TIM_ICInitStruct.TIM_ICSelection = TIM_ICSelection_DirectTI;//选择直接连接TIM_ICInit(TIM3, &TIM_ICInitStruct);//6.对从模式进行配置TIM_SelectInputTrigger(TIM3, TIM_TS_TI1FP1);//从模式触发源选择TIM_SelectSlaveMode(TIM3,TIM_SlaveMode_Reset);//从模式的触发的模式,对计数器清零TIM_Cmd(TIM3,ENABLE);
}uint32_t Get_Freq(void)
{return 1000000 / TIM_GetCapture1(TIM3);//TIM_GetCapture1()为获取通道CH1的CCR的值
}

④IC.h文件的代码如下:

#ifndef __IC_H
#define __IC_H
#include "stm32f10x.h"                  // Device headervoid IC_Init(void);
uint32_t Get_Freq(void);#endif

⑤主程序文件的代码如下:

/*通过输入捕获功能,捕获定时器产生的PWM波形的频率,和PWM波的占空比
*/#include "stm32f10x.h" 
#include "OLED.h"
#include "PWM.h"
#include "IC.h"int main(void)
{OLED_Init();OLED_Clear();PWM_Init();IC_Init();OLED_ShowString(1,1,"Freq:00000Hz");PWM_Set(50);//设置占空比为50%的PWM波形
//	Set_PSC(720 - 1);//更改预分频的值,即分辨率的值,72M/720 = 100KHz,//则分辨率为:1/100KHz = 10us,则PWM的T = 100 * 10us = 1ms,F = 1KHzwhile(1){	OLED_ShowNum(1,6,Get_Freq(),5);}
}	

2、PWMI模式测量频率和占空比

在这里插入图片描述①IC.c文件的代码如下:

#include "stm32f10x.h"                  // Device headervoid IC_Init(void)
{/*由于输入捕获通道和输出比较通道不能够同时的使用我们使用了TIM2的CH1产生了1KHz的PWM波形,所以我们使用TIM3的CH1(PA6)进行对PWM波形的输入进行捕获,测量其频率*/	//1. 使能TIM3的时钟RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);//2. 选择内部时钟源TIM_InternalClockConfig(TIM3);//3.配置时基单元TIM_TimeBaseInitTypeDef TIM_TimeInitStruct;TIM_TimeInitStruct.TIM_ClockDivision = TIM_CKD_DIV1;//时钟源滤波分频TIM_TimeInitStruct.TIM_CounterMode = TIM_CounterMode_Up;//向上计数TIM_TimeInitStruct.TIM_Period = 65536 - 1;//计数器TIM_TimeInitStruct.TIM_Prescaler = 72 - 1;//预分频器,1MHz,即1us计数1次TIM_TimeInitStruct.TIM_RepetitionCounter = 0;//重复计数器TIM_TimeBaseInit(TIM3,&TIM_TimeInitStruct);//4.对输入捕获引脚进行初始化RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);GPIO_InitTypeDef GPIOInitStruct;GPIOInitStruct.GPIO_Mode = GPIO_Mode_IPU;//上拉输入GPIOInitStruct.GPIO_Pin = GPIO_Pin_6;GPIO_Init(GPIOA,&GPIOInitStruct);//5.对输入捕获单元进行初始化TIM_ICInitTypeDef TIM_ICInitStruct;TIM_ICInitStruct.TIM_Channel = TIM_Channel_1;//选择通道CH1,它不像输出比较每个通道都有一个函数TIM_OC?Init()TIM_ICInitStruct.TIM_ICFilter = 0xF;//对捕获的信号进行滤波TIM_ICInitStruct.TIM_ICPolarity = TIM_ICPolarity_Rising;//上升沿开始捕获TIM_ICInitStruct.TIM_ICPrescaler = TIM_ICPSC_DIV1;//对捕获信号进行1分频TIM_ICInitStruct.TIM_ICSelection = TIM_ICSelection_DirectTI;//选择直接连接TIM_ICInit(TIM3, &TIM_ICInitStruct);//	TIM_ICInitStruct.TIM_Channel = TIM_Channel_2;//选择通道CH2,它不像输出比较每个通道都有一个函数TIM_OC?Init()
//	TIM_ICInitStruct.TIM_ICFilter = 0xF;//对捕获的信号进行滤波
//	TIM_ICInitStruct.TIM_ICPolarity = TIM_ICPolarity_Rising;//下降沿开始捕获
//	TIM_ICInitStruct.TIM_ICPrescaler = TIM_ICPSC_DIV1;//对捕获信号进行1分频
//	TIM_ICInitStruct.TIM_ICSelection = TIM_ICSelection_IndirectTI;//选择间接连接
//	TIM_ICInit(TIM3, &TIM_ICInitStruct);/*如果配置了通道CH1,然后通过PWMI传入这些参数,那么PWM配置的是和CH1通道的参数相反,且这个函数只支持CH1和CH2。不能这样配置CH3和CH4
*/TIM_PWMIConfig(TIM3,&TIM_ICInitStruct);//和上面的配置相等//6.对从模式进行配置TIM_SelectInputTrigger(TIM3, TIM_TS_TI1FP1);//从模式触发源选择TIM_SelectSlaveMode(TIM3,TIM_SlaveMode_Reset);//从模式的触发的模式,对计数器清零TIM_Cmd(TIM3,ENABLE);
}uint32_t Get_Freq(void)//获取频率的函数
{return 1000000 / TIM_GetCapture1(TIM3);//获取通道CH1的CCR的值
}uint32_t IC_GetDuty(void)//获取占空比
{return (TIM_GetCapture2(TIM3) * 100/ TIM_GetCapture1(TIM3)) ;
}

②主程序文件里面的代码如下:

/*通过输入捕获功能,捕获定时器产生的PWM波形的频率,和PWM波的占空比
*/#include "stm32f10x.h" 
#include "OLED.h"
#include "PWM.h"
#include "IC.h"int main(void)
{OLED_Init();OLED_Clear();PWM_Init();IC_Init();OLED_ShowString(1,1,"Freq:00000Hz");OLED_ShowString(2,1,"Duty:000%");PWM_Set(30);//设置占空比为30%的PWM波形
//	Set_PSC(720 - 1);//更改预分频的值,即分辨率的值,72M/720 = 100KHz,//则分辨率为:1/100KHz = 10us,则PWM的T = 100 * 10us = 1ms,F = 1KHzwhile(1){	OLED_ShowNum(1,6,Get_Freq(),5);OLED_ShowNum(2,6,IC_GetDuty(),3);}
}	

这篇关于06:【江科大stm32】:定时器输入捕获功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127100

相关文章

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.