(PWM呼吸灯)合泰开发板HT66F2390-----点灯大师

前言

上一篇文章相信大家已经成为了点灯高手了,那么进阶就是成为点灯大师 实现PWM呼吸灯
接下来就是直接的代码讲解了,不再讲PWM原理的
这里部分内容参考了另一个博主的文章
合泰杯——合泰单片机工程7之PWM输出

如果有小伙伴不理解引脚设置和delay函数生成或者环境配置的可以浏览上一章内容
合泰杯开发板HT66F2390入门教程(点亮LED灯)——获得成就:点灯大师
本文中会讲解代码为什么要这样配置寄存器和引脚才可以制作呼吸灯(内容可能不完整,持续更新)

代码

#include "HT66F2390.h" 
const int Period = 4095;        // 定义PWM周期为4095
void setLED_PWM(unsigned long Duty);
void delay(unsigned long count); // 声明延时函数
void PWM_Init(void);
void main()
{_wdtc=0b10101011;  //关闭看门狗int i=0;PWM_Init();while(1){	for(i=0;i<Period;i++){delay(50);setLED_PWM(i);}for(i=Period;i>0;i--){delay(50);setLED_PWM(i);  }			}
}void delay(unsigned long count)  //延时10us级别
{volatile unsigned long i;for(i=0;i<count;i++)asm("nop");
}void setLED_PWM(unsigned long Duty)
{_ptm3ah =Duty/256;      //占空比设置_ptm3al =Duty%256;
}void PWM_Init(void){_ptm3c0=0b00001000;	   //时钟选择为8MHz/4_ptm3c1=0b10101000;    //功能选择寄存器,选择PWM输出且低有效_ptm3rph=Period/256;    //周期设置,写入CCRP的两个寄存器之中这个是把16位的数据划分成高8位和低8位_ptm3rpl=Period%256;_pds1=0b00000010;       //PTP3引脚选择,接的是D4_emi=1;                //开启总中断
}

代码讲解

学过PWM的同学都能理解呼吸灯的原理,同样,本文中的呼吸灯原理就是通过配置HT66F2390中周期型TM寄存器实现PWM控制,这里就不对PWM原理进行讲解了

可以打开该芯片的数据手册
合泰官方HT66F2390数据手册

我们要使用PWM的话,想一想肯定和定时器有关,那么我们能就翻开数据手册找到定时器有关的内容
在旁边的目录就能找到
在这里插入图片描述

如图,我们发现了PWM的身影,那么就接着往下看看
在这里插入图片描述

这里我们看到了PTM的输出引脚,其中的数字代表的不同引脚类型,后面有说(本文章使用的PTM,如果你要使用STM也是差不多的思路)那这个时候我们就又要跳到PTM相关的内容了

在这里插入图片描述

这个时候我们发现上面的数字PTPn很有可能就是代表下面的n,然后又可以发现n=0~1是10-bit,n=2和3是16-bit的,我们选择16位所以选择n为2或者3
接着往下看这些寄存器代表什么意思

在这里插入图片描述

那我们就可以发现这些寄存器是配置计数器,周期和占空比之类的
最重要的是下面这两个寄存器
PTMnC0和PTMnC1,n的数值代表多少位的计数器

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
那么看到这里,我想用n = 3(16位计数器),PWM输出高有效,那么是不是就把这两个寄存器配置为,如果是你要10位n=1的话就是_ptm1c0 = 0bxxxxxxxx;

    _ptm3c0=0b00001000;	   //时钟选择为8MHz/4_ptm3c1=0b10101000;    //功能选择寄存器,选择PWM输出且高有效

然后周期和占空比也知道怎么配置了,也是同理配置寄存器

    _ptm3rph=Period/256;    //周期设置,写入CCRP的两个寄存器之中这个是把16位的数据划分成高8位和低8位_ptm3rpl=Period%256;    _ptm3ah =Duty/256;      //占空比设置_ptm3al =Duty%256;

然后我配置了寄存器但是我要知道怎如何使用他,他是哪个引脚呢,那么就需要回到前面这个图了
在这里插入图片描述
我们选择的n = 3,那么就是输出引脚为PTP3,我们接下来看看这个HT66F2390芯片的引脚图

在这里插入图片描述

我们发现他有两个引脚的复用都是PTP3,那么说明这两个引脚都可以使用PWM功能,接下来就是需要知道怎么配置复用功能引脚了
例如我要用PD4就去设置复用功能

在这里插入图片描述
这里如果你想用PB2也是一样的意思,找到PBS1或这PBS0看看

最终我们的初始化PWM代码就可以有下面的部分,我这里是n=3,PD4引脚

void PWM_Init(void){_ptm3c0=0b00001000;	   //时钟选择为8MHz/4_ptm3c1=0b10101000;    //功能选择寄存器,选择PWM输出且低有效_ptm3rph=Period/256;    //周期设置,写入CCRP的两个寄存器之中这个是把16位的数据划分成高8位和低8位_ptm3rpl=Period%256;_pds1=0b00000010;       //PTP3引脚选择,接的是D4_emi=1;                //开启总中断
}

设置占空比

void setLED_PWM(unsigned long Duty)
{_ptm3ah =Duty/256;      //占空比设置_ptm3al =Duty%256;
}

最后一个也是关键的内容
在这里插入图片描述
这里就可以说明为什么我们的代码是这样的了,这里的delay参数是10us

const int Period = 4095;        // 定义PWM周期为4095while(1){	for(i=0;i<Period;i++){delay(50);setLED_PWM(i);}for(i=Period;i>0;i--){delay(50);setLED_PWM(i);  }			}

结果演示

PWM呼吸灯演示视频

总结

这个也是最近学习的内容,网上的详细教程也比较少,最后也是自己看着别人的例程对着数据手册写出来的,所以打算自己写一个完整的阅读数据手册配置寄存器完成指定目的的思路,这也大大提升了我阅读数据手册的能力,加下来学习其他的功能我也会继续更新我自己的学习的内容和教程

如果有错误的地方或者需要改进的地方欢迎大家指出!

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

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

相关文章

华为数通方向HCIP-DataCom H12-821题库(单选题:501-520)

第501题 三台交换机运行RSTP协议,拓扑和配置情况如图所示。那么以下关于根桥的描述,正确的是哪一项? A、根桥是SWA B、根桥是SWB C、根桥是SWC D、根桥无法确定 参考答案:A 第502题 在华为设备中,以下哪一个命令可以实现BFD与静态默认路由联动? A、ip route-static 0.…

mysql数据库优化及sql调优,Java后端社招面试经历

Redis 什么是Redis?Redis的数据类型?使用Redis有哪些好处?Redis相比Memcached有哪些优势?Memcache与Redis的区别都有哪些?Redis是单进程单线程的?一个字符串类型的值能存储最大容量是多少?Redis的持久化机制是什么?各自的优缺点?Redis常见性能问题和解决方案:redis过…

docker容器配置mysql5.7主从复制

介绍 本文将通过docker创建3个mysql数据库容器&#xff0c;实现数据库主从复制功能&#xff0c;三个数据库容器分别为主库mysql-master:3307&#xff0c;从库mysql-slave-01:3308&#xff0c;mysql-slave-02:3309。使用的是mysql5.7版本 1. 拉取mongo镜像 docker pull mysql…

【网络那些事】

【云计算】 云计算&#xff1a;把计算资源放在某个地方&#xff0c;并通过互联网暴露出来&#xff0c;让用户可以按需使用计算资源的方式&#xff0c;就是所谓的云计算 云计算的三种服务&#xff1a; 云平台专业名词 日常叫法 亚马逊云叫法 云服务器 ECS &#xff08;Elas…

循环结构:for循环,while循环,do-while,死循环

文章目录 for循环for案例&#xff1a;累加for循环在开发中的常见应用场景 whilewhile循环案例&#xff1a; for和while的区别&#xff1a;do-while三种循环的区别小结死循环 快捷键 ctrlaltt for循环 看循环执行多少次&#xff0c;就看有效数字有几个 快捷键 fori 示例代码&am…

Vuepress的使用

介绍 将markdown静态资源转换成html。 动态资源的转换还有很多&#xff0c;为什么要使用Vuepress&#xff1f; 目录分析 项目配置 详情 具体配置请看文档 插件配置 vuepress-theme-vdoing 主题插件 npm install vuepress-theme-vdoing -D先安装依赖配置主题 使用vuep…

论文设计任务书学习文档|基于智能搜索引擎的图书管理系统的设计与实现

文章目录 论文(设计)题目:基于智能搜索引擎的图书管理系统的设计与实现1、论文(设计)的主要任务及目标2、论文(设计)的主要内容3、论文(设计)的基本要求4、进度安排论文(设计)题目:基于智能搜索引擎的图书管理系统的设计与实现 1、论文(设计)的主要任务及目标 …

报错:板端IP与PC的IP相同

报错&#xff1a; 配置 实际上我配置并没有错。 服务器IP&#xff08;就是本机&#xff09;、板端IP、网关。 解决 我网卡配置了多个IP。一番删除添加还是报错。 于是点击服务器IP&#xff0c;换成别的&#xff0c;再换回来&#xff0c;可以了&#xff1a;

【大数据架构(3)】Lambda vs. Kappa Architecture-选择你需要的架构

文章目录 一. Data Processing Architectures1. Lambda Architecture1.1. 架构说明a. Data Ingestion Layerb. Batch Layer (Batch processing)c. Speed Layer (Real-Time Data Processing)d. Serving Layer 1.2. Lambda Architecture的优缺点1.3. 使用案例 2. Kappa Architect…

HTML+CSS+JS:花瓣登录组件

效果演示 实现了一个具有动态花朵背景和简洁登录框的登录页面效果。 Code <section><img src"./img/background.jpeg" class"background"><div class"login"><h2>Sign In</h2><div class"inputBox"…

重拾前端基础知识:CSS3

重拾前端基础知识&#xff1a;CSS3 前言边框圆角阴影图片 背景渐变文本字体多列动画与过渡2D 转换3D 转换过渡动画 网格布局弹性盒子&#xff08;重点&#xff09;父元素设置子元素设置 响应式设计设置 Viewport构建响应式网格视图12栅格媒体查询 案例讲解图片按钮分页 浏览器支…

【MATLAB】SVMD_ MFE_SVM_LSTM 神经网络时序预测算法

有意向获取代码&#xff0c;请转文末观看代码获取方式~也可转原文链接获取~ 1 基本定义 SVMD_MFE_SVM_LSTM神经网络时序预测算法结合了单变量分解&#xff08;SVMD&#xff09;、多尺度特征提取&#xff08;MFE&#xff09;、聚类后展开支持向量机&#xff08;SVM&#xff09;…

rhcsa(rh134)

shell 查看用户shell a、如下查看/etc/shells文件列出了系统上所有可用的 shell&#xff08;具体的可用的 shell 列表可能会因不同的红帽版本和配置而有所不同&#xff09; &#xff08;如下图/etc/shells文件包含/bin/tmux并不意味着tmux是一个shell。实际上&#xff0c;/etc/…

CSS:弹性盒子Flexible Box布局

CSS:Flexible Box弹性盒子布局 一、flex布局原理 ​ flex是flexible Box的缩写,意为 ”弹性布局“&#xff0c;用来为盒状模型提供最大的灵活性&#xff0c;任何一个容器都可以指定为flex布局。 当我们的父盒子设置为flex布局之后&#xff0c;子元素的 float 、clear 和 vert…

4核8G服务器并发数多少?性能如何?

腾讯云4核8G服务器支持多少人在线访问&#xff1f;支持25人同时访问。实际上程序效率不同支持人数在线人数不同&#xff0c;公网带宽也是影响4核8G服务器并发数的一大因素&#xff0c;假设公网带宽太小&#xff0c;流量直接卡在入口&#xff0c;4核8G配置的CPU内存也会造成计算…

WPF应用程序使用MVVM模式

文章目录 一、前言二、正文&#xff1a;模式 - WPF应用程序使用MVVM设计模式2.0 一些术语2.1 秩序与混乱2.2 MVVM模式的演变2.3 为何WPF开发者喜爱MVVM2.4 Demo应用程序2.5 路由命令逻辑2.6 ViewModel类层次结构2.7 ViewModelBase类2.8 CommandViewModel类2.9 MainWindowViewMo…

Vueuse:打造高效的 Vue.js 开发利器

Vueuse&#xff1a;打造高效的 Vue.js 开发利器 Vueuse 是一个功能强大的 Vue.js 生态系统工具库&#xff0c;它提供了一系列的可重用的 Vue 组件和函数&#xff0c;帮助开发者更轻松地构建复杂的应用程序。本文将介绍 Vueuse 的主要特点和用法&#xff0c;以及它在 Vue.js 开发…

【Vue的单选按钮不选中已解决亲测】

伙计&#xff0c;你是否因为后台给vue前端已经传入了对应的单选按钮的数据&#xff0c;为啥还是不选中呢&#xff01;&#xff1f; 这个问题实话我百度乐很多都不能解决我的问题&#xff0c;最后机智如我的发现乐vue的自身的问题&#xff0c;后端返回的数据类型如果是数字int类…

Git 指令深入浅出【1】—— 文件管理

Git 指令深入浅出【1】—— 文件管理 一、新建仓库二、配置1. 基本指令2. 免密配置3. 简化指令 三、管理文件1. 常用文件管理指令&#xff08;1&#xff09;基本指令工作区暂存区版本库 &#xff08;2&#xff09;日志&#xff08;3&#xff09;查看修改 2. 版本回退&#xff0…

MySQL基础--10.1--sql查询各科成绩前三名

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 sql查询各科成绩前三名建表造数 方法一&#xff1a;使用加行号的方式查询方法二&#xff1a;使用子查询嵌套查询原理解析考虑并列情况 方法三&#xff1a;窗口函数1…