51单片机最快能生成多高频率的方波?

2024-08-23 22:04

本文主要是介绍51单片机最快能生成多高频率的方波?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

在嵌入式系统开发中,51 单片机作为一种非常非常非常经典,贯穿上下几十年的微控制器,被广泛应用于各种电子项目中。其中,生成特定频率的方波信号是一项常见的需求。

那么,51 单片机究竟能以多快的速度生成方波呢?这不仅涉及到硬件的性能极限,也与软件编程的技巧密切相关。

在实际应用中,我们可能需要根据不同的场景来生成不同频率的方波,例如用于驱动电机、产生时钟信号或者进行通信等。而了解 51 单片机生成方波的最高频率,是一个有趣又有实用性的探索目标

所以,最快能实现多快?

测试平台

开发工具是keil 5

51单片机是STC89C52RC(16Mhz晶振)

最新手的方式

其实硬件上最简单就是换晶振,如果你换到一个

这个代码就是最简单的,在c语言中实现一个方波输出,只要快速切换电平就可以实现,

#include <reg52.h>
#include <stdio.h>sbit LCD_RS = P1^3;
void delay(unsigned int i)
{while (i--);
}void main()
{// 设置 P1.3 为输出模式while (1){// 点亮 LED(P1.3 输出低电平)LCD_RS = 0;delay(1);// 熄灭 LED(P1.3 输出高电平)LCD_RS = 1;delay(1);}
}

在烧录上面,我们

此时生成的频率为1.425Khz,好像还行,但是不够快

那么我们修改一下烧写,改成双倍速,结果就是没有什么差别,看来烧写并不影响

所以,还是要改程序,我们先试试增加头文件#include "intrins.h"然后把while改成_nop_();

#include <reg52.h>
#include <stdio.h>
#include "intrins.h"sbit LCD_RS = P1^3;
void delay(unsigned int i)
{_nop_();
}void main()
{// 设置 P1.0 为输出模式while (1){// 点亮 LED(P1.0 输出低电平)LCD_RS = 0;delay(1);// 熄灭 LED(P1.0 输出高电平)LCD_RS = 1;delay(1);}
}

这下的波形还是方波,同时,变成了111.111kHz,非常的快速了,四舍五入有0.2Mhz

 

但是,有没有可能更快一点?

中等水平的方式

使用定时器,可以有更快的中断方式来实现,理论来说会比使用nop函数更快

这里设置的是 8 位自动重装模式,Timer0 的计数从 TL0TH0,当 Timer0 计数器达到最大值(0xFF)并溢出时,TL0 会被重装载为 TH0 的值。Timer0 的计数范围是 8 位,即从 0 到 255,总共有 256 个计数值。

#include <reg52.h>  // 包含 STC89C52RC 的头文件void Timer0_Init(void) {TMOD &= 0xF0;  // 清除 Timer0 的模式设置位TMOD |= 0x02;  // 设置 Timer0 为 8 位自动重装模式TH0 = 0xFF;    // 设置 Timer0 的重装载初值(高字节)TL0 = 0xF0;    // 设置 Timer0 的初值(低字节)ET0 = 1;       // 使能 Timer0 中断TR0 = 1;       // 启动 Timer0EA = 1;        // 使能全局中断
}void Timer0_ISR(void) interrupt 1 {// Timer0 中断服务程序P1 ^= 0x08;    // 反转 P1.3 引脚的电平(0x08 是二进制 00001000)
}void main(void) {P1 = 0x00;  // 初始化 P1 端口Timer0_Init();  // 初始化 Timer0while (1) {// 主循环可以为空,所有的工作都由 Timer0 中断处理}
}

可以看到,最终我们实现了133.333Khz,这个速度非常可以了,TH0的数值可以直接控制频率

鲜有使用的方式

除了中断之外还有一种比较少用的方法,就是直接使用汇编语言来操控单片机,这种方法可读性比较差但是确实又可以实现

这里我们直接用三部分实现

ORG 0000H          ; 程序起始地址; 主程序
MAIN_LOOP:; 初始化 P1 端口MOV P1, #0FFH  ; 将所有 P1 端口设置为高电平CLR P1.3       ; 将 P1.3 设置为低电平TOGGLE_LOOP:CPL P1.3       ; 反转 P1.3 引脚的电平; 延时循环MOV R0, #1   ; 设置延时计数器初值
DELAY:NOP            ; 空操作指令,用于延时DJNZ R0, DELAY ; 延时循环SJMP TOGGLE_LOOP ; 无限循环,反复翻转 P1.3 引脚END

SJMP是短跳转,在-127到+128字之间进行跳转

DJNZ,相当于 if(i--<=0) 这样的条件句式

在这种代码下,翻转频率直接达到了190.476khz,可以说是真的非常非常的快速了。

当然我们还可进一步的提升,我们直接去掉NOP符号,这下直接来到了222.222khz,真的是特别快速的一个频率

还能再快吗?可以,只要继续缩短就能实现

ORG 0000H          ; 程序起始地址; 主程序
MAIN_LOOP:; 初始化 P1 端口MOV P1, #0FFH  ; 将所有 P1 端口设置为高电平CLR P1.3       ; 将 P1.3 设置为低电平TOGGLE_LOOP:CPL P1.3       ; 反转 P1.3 引脚的电平; 延时循环SJMP TOGGLE_LOOP ; 无限循环,反复翻转 P1.3 引脚END

直接来到了444.444Khz

总结

实现方法方波频率
快速切换电平,使用while (i--);1.425Khz
快速切换电平,增加头文件#include "intrins.h"并把while改成_nop_();111.111kHz
使用定时器,8 位自动重装模式133.333Khz
使用汇编语言,含NOP指令190.476khz
使用汇编语言,去掉NOP指令222.222khz

这篇关于51单片机最快能生成多高频率的方波?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

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

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

poj 3723 kruscal,反边取最大生成树。

题意: 需要征募女兵N人,男兵M人。 每征募一个人需要花费10000美元,但是如果已经招募的人中有一些关系亲密的人,那么可以少花一些钱。 给出若干的男女之间的1~9999之间的亲密关系度,征募某个人的费用是10000 - (已经征募的人中和自己的亲密度的最大值)。 要求通过适当的招募顺序使得征募所有人的费用最小。 解析: 先设想无向图,在征募某个人a时,如果使用了a和b之间的关系

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机