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);}
}	

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

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

相关文章

RabbitMQ中的死信交换机?(RabbitMQ延迟队列有了解过吗)

延迟队列 延迟队列:进入队列的消息会被延迟消费的队列。 延迟队列死信交换机 TTL(过期时间) 延迟队列的使用场景:超时订单、限时优惠、定时发布 死信交换机 当一个队列中的消息满足下列情况之一时,可以成为死信(dead letter): 消费者使…

iOS工程:获取手机相册权限,iOS原生系统弹窗, Privacy隐私政策选择,如何添加系统弹出并修改描述文字

【iOS工程】获取手机相册权限,iOS原生系统弹窗, Privacy隐私政策选择,如何添加系统弹出并修改描述文字 设备/引擎:Mac(11.6)/Mac Mini 开发工具:Xcode(15.0.1) 开发需求&#xff…

【Java设计模式】Builder模式:在Java中清晰构建自定义对象

文章目录 【Java设计模式】Builder模式:在Java中清晰构建自定义对象一、概述二、Builder设计模式的意图三、Builder模式的详细解释及实际示例四、Java中Builder模式的编程示例五、Builder模式类图六、Java中何时使用Builder模式七、Builder模式的优点和权衡八、源码…

YOLO-World: Real-Time Open-Vocabulary Object Detection:实时开放词汇对象检测

YOLO系列探测器已成为高效实用的工具。然而,它们对预定义和训练的对象类别的依赖限制了它们在开放场景中的适用性。针对这一限制,我们引入了YOLO-World,这是一种创新方法,通过视觉语言建模和大规模数据集的预训练,增强…

.NET8 Web 利用BAT命令 一键部署 IIS - CI-CD基础

1. Windows Server 前置准备 1.1 IIS安装好 1.2 .NET8 Sdk 运行时 安装 官方下载地址:https://dotnet.microsoft.com/zh-cn/download/dotnet/8.0 1.3 创建一个.NET8 WebMvc项目 生成发布包 微软MVC这个项目模板直接创建,发布 2. 利用 BAT 来一键部署…

Aigtek功率放大器应用领域分享:无处不在的MEMS传感器

微机电系统(MEMS,Micro-Electro-MechanicalSystem),也叫做微电子机械系统、微系统、微机械等,指尺寸在几毫米乃至更小的高科技装置。微机电系统其内部结构一般在微米甚至纳米量级。微机电系统是在微电子技术(半导体制造…

分布式基础理论——CAP理论和BASE理论

文章目录 CAP 理论BASE 理论参考资料 CAP 理论 CAP定理(CAP theorem)指出,在分布式系统中,设计读写操作时只能同时满足以下三个特性中的两个: 一致性(Consistency) : 所有节点访问同一份最新的…

ssm基于微信小程序的食堂窗口自助点餐系统源码调试讲解

1. 环境搭建 JDK 1.8:确保您的系统已安装JDK 1.8,并配置好环境变量。JDK 1.8 是目前很多Java项目仍在使用的稳定版本,适用于SSM框架。Tomcat 7:安装并配置Tomcat 7作为您的Web服务器。Tomcat 7 支持Servlet 3.0和JSP 2.2&#xf…

杰发科技AC7801——Flash模拟EEP内存(2)

1. 默认配置在1000个地址存储1000个数据 配置如下 计算地址 查看地址内容,等到打印完成 计算符合,从0-999共计1000 2. 修改配置在65536地址存储65536个数据 配置还是这个 因为传进去的地址是uint16_t,因此最大值是65536,写65536…

基于Pytorch框架的深度学习PSPnet网络动物马语义分割系统源码

第一步:准备数据 动物马分割数据,总共有328张图片,里面的像素值为0和1,所以看起来全部是黑的,不影响使用 第二步:搭建模型 psp模块的样式如下,其psp的核心重点是采用了步长不同,po…

前端:html+css:伪类画箭头(实心)

一、效果图 二、代码 html <div class"rectangle">AC/DC</div> css /* 图形 */ .rectangle {position: relative;width: 50px;height: 20px;background-color: #3498db;color: white; } .rectangle:before {content: ;position: absolute;top: 0;l…

Spring Boot Web开发实践:请求与响应参数的使用方法

主要介绍了请求响应的简单参数、实体参数、数组集合参数、日期参数、路径参数等各自的使用方法&#xff01;&#xff01;&#xff01; 文章目录 前言 Postman 简单参数 原始方式 SpringBoot方式 实体参数 数组集合参数 日期参数 路径参数 总结 前言 主要介绍了请求响应的简单参…

Tkinter Checkbutton设置了一个多选,为什么初始值都是勾选的:

代码如下&#xff1a; from tkinter import *master Tk()renyuan ["唐僧", "沙僧", "悟空", "八戒"]def r_change():rec ""ci 0for el in vars:rec el.get() "、"ci 1rec "九点" rec "离…

PHP概述-特点-应用领域-如何学习

老师建议注册使用百度文心一言&#xff1b;讯飞星火大模型-AI大语言模型-星火大模型-科大讯飞&#xff1b;Kimi.ai - 帮你看更大的世界 等人工智能工具软件的一个到两个&#xff0c;也可下载文心一言、讯飞星火、kimi等APP软件使用&#xff0c;对于我们在读的大二学生来说有什么…

GPT-6曝光!阉割版「草莓」秋季兑现

夕小瑶科技说 原创 作者 | 海野 OpenAI的Q* 项目&#xff0c;也就是后来在网上沸沸扬扬的Strawberry草莓&#xff0c;终于定档于秋季上线。 据The Information爆料&#xff0c;作为GPT-4的下一代&#xff0c;Strawberry很惊艳&#xff1a; 拥有极强的推理和数学能力&#xf…

【人工智能 | 机器学习 | 理论篇】决策树(decision tree)

文章目录 1. 基本流程2. 划分选择2.1 信息增益2.2 增益率2.3 基尼系数 3. 剪枝处理3.1 预剪枝3.2 后剪枝 4. 连续与缺失值4.1 连续值处理4.2 缺失值处理 5. 多变量决策树 1. 基本流程 二分类任务决策树流程&#xff1a; 决策树&#xff1a;包含 1个根结点、若干个内部结点、若…

vue.js3+element-plus+typescript add,edit,del,search

vite.config.ts server: {cors: true, // 默认启用并允许任何源host: 0.0.0.0, // 这个用于启动port: 5110, // 指定启动端口open: true, //启动后是否自动打开浏览器 proxy: {/api: {target: http://localhost:8081/, //实际请求地址&#xff0c;数据库的rest APIschangeOr…

Maven Wrapper深入实战

概述 官网&#xff0c;GitHub。 Maven Wrapper&#xff0c;缩写为mvnw&#xff0c;是一个受Gradle Wrapper和Takari Wrapper启发而产生的Maven子项目&#xff0c;主要有以下三个用途&#xff1a; 让开发者电脑上无需安装Maven&#xff0c;也不用配置环境变量&#xff0c;即可…

【案例63】SSL RC4 加密套件支持检测 (Bar Mitzvah)修复方案

漏洞详情信息 漏洞名称 SSL RC4 加密套件支持检测 (Bar Mitzvah) 漏洞等级 高 漏洞描述 远程主机支持在一个或多个密码组中使用 RC4。 RC4 密码在伪随机字节流的生成中存在缺陷&#xff0c;导致引入了各种各样的小偏差&#xff0c;降低了其随机 性。 如果反复加密明文&am…

Linux下qt程序缺少中文字库,中文显示为框框

现象 Linux下qt5.9编译程序&#xff0c;运行时候界面上的中文显示一个一个的框框。 如图 原因 开发板里缺少中文字库或者qt字库环境未正常配置导致的。 解决方法一&#xff1a; 如果系统中存在中文字库&#xff0c;一般是在/usr/share/下有一个fonts文件夹 配置qt中文字库路…