华大HC32L13x系列定时器的正交编码功能笔记

2024-01-27 23:40

本文主要是介绍华大HC32L13x系列定时器的正交编码功能笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MCU:HC32L130
引脚:PB06,PB07,端口复用af4,af5;定时器:TIM0
实现功能:正确识别旋钮编码器步进,实现挡位调节

官方例程对这个的描述很少,一步一步踩出来的!!

1.编码器认识
1.1结构

1.2接线

编码器规格书额定电压5V,实际可以当作普通按键来用,3V也能正常使用。

DE端相当于普通按键,

AB端接上拉电阻到VCC,C端接GND,

A,B端建议加滤波电容,实测10nf效果挺好,太大会影响波形

1.3波形

正向旋扭时波形

反向旋钮时波形

2.程序实现
2.1定时器配置:

1.基本功能配置:时钟使能,计数方式,周期设置,计数值设置,重载值,定时器功能等

2.正交编码器功能配置,此项配置完成会记录编码器波形边沿个数

3.通道配置:输入捕获,触发方式,滤波设置

4.触发中断使能

/*******************************************************************************
* Function Name  : encoder_Capture_Init();
* Description    : 编码器正交编码计数
* Input          : PB6 PB7
*								 
* Output         : None
* Return         : None
* Attention		 	 : None
*******************************************************************************/
void encoder_Capture_Init(void)
{uint16_t                   u16ArrValue;uint16_t                   u16CntValue;stc_bt_mode23_cfg_t        stcBtBaseCfg;stc_bt_m23_master_slave_cfg_t     stcBtmasterslaveCfg;stc_bt_m23_input_cfg_t     stcBtPortCapCfg;//结构体初始化清零DDL_ZERO_STRUCT(stcBtBaseCfg);DDL_ZERO_STRUCT(stcBtPortCapCfg);Sysctrl_SetPeripheralGate(SysctrlPeripheralBaseTim, TRUE); //Base Timer外设时钟使能stcBtBaseCfg.enWorkMode    = BtWorkMode2;              //锯齿波模式stcBtBaseCfg.enCT          = BtTimer;                  //定时器功能,计数时钟为内部PCLKstcBtBaseCfg.enPRS         = BtPCLKDiv64;              //PCLK/64stcBtBaseCfg.enCntDir      = BtCntUp;                  //向上计数,在三角波模式时只读Bt_Mode23_Init(TIM0, &stcBtBaseCfg);                   //TIM0 的模式2功能初始化u16ArrValue = 0XFFFF;Bt_M23_ARRSet(TIM0, u16ArrValue, TRUE);                //设置重载值,并使能缓存u16CntValue = 0;Bt_M23_Cnt16Set(TIM0, u16CntValue);                    //设置计数初值stcBtmasterslaveCfg.enMasterSlaveSel = BtSlaveMode;					///< 从模式   此项不配置对功能不影响stcBtmasterslaveCfg.enSlaveModeSel = BtSlaveCodeCnt3;				///< 正交编码计数模式3stcBtmasterslaveCfg.enTsSel = BtTs0ETR;										///<  外部输输入滤波后的相位选择信号
//		stcBtmasterslaveCfg.enMasterSrc	= BtMasterOCA0Ref;Bt_M23_MasterSlave_Set(TIM0,&stcBtmasterslaveCfg);stcBtPortCapCfg.enCH0ACapSel   = BtCHxCapFallRise;     //CHA通道上升沿下降沿捕获都使能stcBtPortCapCfg.enCh0ACmpCap   = BtCHxCapMode;         //CHA通道设置为捕获模式stcBtPortCapCfg.enCH0AInFlt    = BtFltPCLKDiv64Cnt3;   //PCLK/16 3个连续有效stcBtPortCapCfg.enCH0APolarity = BtPortPositive;       //正常输入输出 stcBtPortCapCfg.enCH0BCapSel   = BtCHxCapFallRise;     //CHB通道上升沿下降沿捕获都使能stcBtPortCapCfg.enCh0BCmpCap   = BtCHxCapMode;         //CHB通道设置为捕获模式stcBtPortCapCfg.enCH0BInFlt    = BtFltPCLKDiv64Cnt3;   //PCLK/16 3个连续有效		//滤波设置 16usstcBtPortCapCfg.enCH0BPolarity = BtPortPositive;       //正常输入输出 Bt_M23_PortInput_Cfg(TIM0, &stcBtPortCapCfg);          //端口输入初始化配置Bt_M23_EnSwTrigCapCmpA(TIM0);											//捕获比较A软件触发  使能Bt_M23_EnSwTrigCapCmpB(TIM0);											//捕获比较B软件触发	 使能Bt_ClearAllIntFlag(TIM0);                              //清中断标志Bt_Mode23_EnableIrq(TIM0,BtCA0Irq);                    //使能TIM0 CB0比较/捕获中断		Bt_Mode23_EnableIrq(TIM0,BtCB0Irq);                    //使能TIM0 CB0比较/捕获中断EnableNvic(TIM0_IRQn, IrqLevel3, TRUE);                //TIM0中断使能Bt_M23_Run(TIM0);
}

5.中断处理

注意:清中断方式要AB通道分别清除,如果直接清楚定时器中断,会同时清两个通道,会出现问题的

最后获得,TIM0_COUNT会是边沿的个数,编码器一个步进,AB端会分别产生一个下降沿和上升沿,共计4个

正向旋转1步,A通道的值:BtCCR0A_VAL会比TIM0_COUNT  多 1,BtCCR0A_VAL会比BtCCR0B_VAL 多 1;TIM0_COUNT + 4;

反向向旋转1步,B通道的值:BtCCR0B_VAL会比TIM0_COUNT 多 1,BtCCR0A_VAL会比BtCCR0B_VAL 少 1;TIM0_COUNT + 4;

/******************************************************************************** TIM0中断服务函数******************************************************************************/
uint8_t  ENCODER_CNT;
void Tim0_IRQHandler(void)
{static uint16_t BtCCR0A_VAL,BtCCR0B_VAL,TIM0_COUNT;
//Timer0 模式23 捕获中断Aif(TRUE == Bt_GetIntFlag(TIM0, BtCA0Irq)){Bt_ClearIntFlag(TIM0,BtCA0Irq); //清除中断标志}
//    //Timer0 模式23 捕获中断Bif(TRUE == Bt_GetIntFlag(TIM0, BtCB0Irq)){Bt_ClearIntFlag(TIM0,BtCB0Irq); //清除中断标志}TIM0_COUNT = Bt_M23_Cnt16Get(TIM0);BtCCR0B_VAL = Bt_M23_CCR_Get(TIM0,BtCCR0B);BtCCR0A_VAL = Bt_M23_CCR_Get(TIM0,BtCCR0A);		if(TIM0_COUNT%4 == 0){if((BtCCR0B_VAL+1 == TIM0_COUNT)&&(BtCCR0A_VAL + 1 == BtCCR0B_VAL)){if(ENCODER_CNT < 10)ENCODER_CNT++;}if((BtCCR0A_VAL - 1 == TIM0_COUNT)&&(BtCCR0B_VAL - 1 == BtCCR0A_VAL)){if(ENCODER_CNT > 0)ENCODER_CNT--;	}}
}
3.个人理解,有问题恳请指正!

这篇关于华大HC32L13x系列定时器的正交编码功能笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0