利用GD32F470的定时器实现频率和占空比测试

2024-06-21 19:28

本文主要是介绍利用GD32F470的定时器实现频率和占空比测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1)main函数代码如下:

#include "gd32f4xx.h"
#include <stdio.h>
#include "gd32f470i_eval.h"
#include "systick.h"void TIM_PwmInit(void)
{rcu_periph_clock_enable(RCU_GPIOA);/* PWM输出管脚为复用推挽模式 */gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_NONE,GPIO_PIN_1);gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ,GPIO_PIN_1);gpio_af_set(GPIOA, GPIO_AF_1, GPIO_PIN_1);/* PWM输入管脚为浮空输入模式 */gpio_mode_set(GPIOA, GPIO_MODE_AF, GPIO_PUPD_NONE,GPIO_PIN_6);gpio_output_options_set(GPIOA, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ,GPIO_PIN_6);gpio_af_set(GPIOA, GPIO_AF_1, GPIO_PIN_6);/* TIMER1初始化 */timer_oc_parameter_struct timer_ocintpara = {0};timer_parameter_struct timer_initpara = {0};rcu_periph_clock_enable(RCU_TIMER1);timer_deinit(TIMER1);timer_initpara.prescaler         = (108 - 1);  // 预分频:108MHz / 108 = 1MHztimer_initpara.alignedmode       = TIMER_COUNTER_EDGE;  // 边沿对齐计数timer_initpara.counterdirection  = TIMER_COUNTER_UP;  // 向上计数timer_initpara.period            = (1000 - 1);  // 周期:1MHz / 1000 = 1000Hz  注: 下面设置的占空比必须小于等于period,否则错误;timer_init(TIMER1, &timer_initpara);/* 配置所有通道为PWM模式0 */timer_ocintpara.ocpolarity   = TIMER_OC_POLARITY_HIGH;  // 通道输出极性高,即高电平有效timer_ocintpara.outputstate  = TIMER_CCX_ENABLE;  // 使能输出通道timer_ocintpara.ocidlestate  = TIMER_OC_IDLE_STATE_LOW;  // 输出通道空闲低电平timer_channel_output_config(TIMER1,TIMER_CH_1, &timer_ocintpara);/* 配置通道1为25%占空比 */timer_channel_output_pulse_value_config(TIMER1, TIMER_CH_1, (250 - 1));  // 250 / 1000 = 25%timer_channel_output_mode_config(TIMER1,TIMER_CH_1, TIMER_OC_MODE_PWM0);  // 配置为PWM模式0timer_channel_output_shadow_config(TIMER1,TIMER_CH_1, TIMER_OC_SHADOW_DISABLE);  // 关闭输出影子timer_auto_reload_shadow_enable(TIMER1);  // 使能重装载影子timer_enable(TIMER1);  // 使能定时器1/* 初始化TIMER2 */timer_ic_parameter_struct timer_icinitpara = {0};rcu_periph_clock_enable(RCU_TIMER2);timer_deinit(TIMER2);timer_initpara.prescaler         = (108 - 1);  // 预分频:108MHz / 108 = 1MHztimer_initpara.alignedmode       = TIMER_COUNTER_EDGE;  // 边沿对齐计数timer_initpara.counterdirection  = TIMER_COUNTER_UP;  // 向上计数模式timer_initpara.period            = (65536 - 1);  // 周期最好设置为最高,以免计数器溢出timer_initpara.clockdivision     = TIMER_CKDIV_DIV1;  // 输入时钟1分频timer_init(TIMER2,&timer_initpara);timer_icinitpara.icpolarity  = TIMER_IC_POLARITY_RISING;  // 输入极性为上升沿,即上升沿有效timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI;  // 输入捕获通道连接至CIxtimer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1;  // 时钟1分频timer_icinitpara.icfilter    = 0x0;timer_input_pwm_capture_config(TIMER2, TIMER_CH_0, &timer_icinitpara);timer_input_trigger_source_select(TIMER2, TIMER_SMCFG_TRGSEL_CI0FE0);  // 输入触发源为通道0timer_slave_mode_select(TIMER2, TIMER_SLAVE_MODE_RESTART);  // 从模式选择为复位模式timer_master_slave_mode_config(TIMER2, TIMER_MASTER_SLAVE_MODE_ENABLE);  // 使能从模式timer_auto_reload_shadow_enable(TIMER2);  // 使能重装载影子nvic_priority_group_set(NVIC_PRIGROUP_PRE4_SUB0);  // 抢占优先级4位,响应优先级0位nvic_irq_enable(TIMER2_IRQn, 1, 0);  // 使能中断服务,抢占优先级为1timer_interrupt_flag_clear(TIMER2, TIMER_INT_CH0);  // 清除通道0中断标志位timer_interrupt_enable(TIMER2, TIMER_INT_CH0);  // 使能通道0中断timer_enable(TIMER2);  // 使能定时器2
}int fputc(int ch, FILE *f)
{usart_data_transmit(EVAL_COM0, (uint8_t)ch);while (RESET == usart_flag_get(EVAL_COM0, USART_FLAG_TBE));return ch;
}extern __IO uint16_t dutycycle;
extern __IO uint16_t frequency;
int main(void)
{systick_config();TIM_PwmInit();gd_eval_com_init(EVAL_COM0);while(1){printf("dutycycle: %d%%, frequency: %dHz\n", dutycycle, frequency);delay_1ms(1000);}
}

2)中断函数如下所示(gd32f4xx_it.c):

uint32_t ic1value = 0, ic2value = 0;
__IO uint16_t dutycycle = 0;
__IO uint16_t frequency = 0;void TIMER2_IRQHandler(void)
{if(SET == timer_interrupt_flag_get(TIMER2, TIMER_INT_CH0)){timer_interrupt_flag_clear(TIMER2, TIMER_INT_CH0);  // 清除中断标志位ic1value = timer_channel_capture_value_register_read(TIMER2, TIMER_CH_0) + 1;if(0 != ic1value){ic2value = timer_channel_capture_value_register_read(TIMER2, TIMER_CH_1) + 1;dutycycle = (ic2value * 100) / ic1value;  // 计算占空比frequency = (float)1000000 / ic1value;  // 计算频率}else{dutycycle = 0;frequency = 0;}}
}

3)测试方法:PA6与PA1用镊子短接,用示波器连接信号,串口打开,如下图所示:
在这里插入图片描述
从上图可知道,频率是927赫兹,(目标代码应该是1000HZ),有一定误差,

在这里插入图片描述
上图示波器测试的占空比是25%;
4)打开串口,查看GD32F470测试的结果,如下图所示:
在这里插入图片描述

这篇关于利用GD32F470的定时器实现频率和占空比测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py

Python利用ElementTree实现快速解析XML文件

《Python利用ElementTree实现快速解析XML文件》ElementTree是Python标准库的一部分,而且是Python标准库中用于解析和操作XML数据的模块,下面小编就来和大家详细讲讲... 目录一、XML文件解析到底有多重要二、ElementTree快速入门1. 加载XML的两种方式2.

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

Spring Security+JWT如何实现前后端分离权限控制

《SpringSecurity+JWT如何实现前后端分离权限控制》本篇将手把手教你用SpringSecurity+JWT搭建一套完整的登录认证与权限控制体系,具有很好的参考价值,希望对大家... 目录Spring Security+JWT实现前后端分离权限控制实战一、为什么要用 JWT?二、JWT 基本结构