找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4202|回复: 5
打印 上一主题 下一主题
收起左侧

实现等精度频率测量 频率计+温度计 带仿真和单片机源码及PPT教程

  [复制链接]
跳转到指定楼层
楼主
ID:159270 发表于 2017-2-23 23:46 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
等精度频率测量,有源代码,值得学习

PPT教程:


等精度频率测量51单片机源码:
  1. #include"temp.h"
  2. /*******************************************************************************
  3. * 函数名         : Delay1ms
  4. * 函数功能                   : 延时函数
  5. * 输入           : 无
  6. * 输出                  : 无
  7. *******************************************************************************/

  8. void Delay1ms(unsigned int y)
  9. {
  10.         unsigned int x;
  11.         for(y;y>0;y--)
  12.                 for(x=110;x>0;x--);
  13. }
  14. /*******************************************************************************
  15. * 函数名         : Ds18b20Init
  16. * 函数功能                   : 初始化
  17. * 输入           : 无
  18. * 输出                  : 初始化成功返回1,失败返回0
  19. *******************************************************************************/

  20. unsigned char Ds18b20Init()
  21. {
  22.         unsigned int i;
  23.         DSPORT=0;                         //将总线拉低480us~960us
  24.         i=70;        
  25.         while(i--);//延时642us
  26.         DSPORT=1;                        //然后拉高总线,如果DS18B20做出反应会将在15us~60us后总线拉低
  27.         i=0;
  28.         while(DSPORT)        //等待DS18B20拉低总线
  29.         {
  30.                 i++;
  31.                 if(i>5000)//等待>5MS
  32.                         return 0;//初始化失败        
  33.         }
  34.         return 1;//初始化成功
  35. }

  36. /*******************************************************************************
  37. * 函数名         : Ds18b20WriteByte
  38. * 函数功能                   : 向18B20写入一个字节
  39. * 输入           : com
  40. * 输出                  : 无
  41. *******************************************************************************/

  42. void Ds18b20WriteByte(unsigned char dat)
  43. {
  44.         unsigned int i,j;
  45.         for(j=0;j<8;j++)
  46.         {
  47.                 DSPORT=0;                        //每写入一位数据之前先把总线拉低1us
  48.                 i++;
  49.                 DSPORT=dat&0x01; //然后写入一个数据,从最低位开始
  50.                 i=6;
  51.                 while(i--); //延时68us,持续时间最少60us
  52.                 DSPORT=1;        //然后释放总线,至少1us给总线恢复时间才能接着写入第二个数值
  53.                 dat>>=1;
  54.         }
  55. }
  56. /*******************************************************************************
  57. * 函数名         : Ds18b20ReadByte
  58. * 函数功能                   : 读取一个字节
  59. * 输入           : com
  60. * 输出                  : 无
  61. *******************************************************************************/


  62. unsigned char Ds18b20ReadByte()
  63. {
  64.         unsigned char byte,bi;
  65.         unsigned int i,j;        
  66.         for(j=8;j>0;j--)
  67.         {
  68.                 DSPORT=0;//先将总线拉低1us
  69.                 i++;
  70.                 DSPORT=1;//然后释放总线
  71.                 i++;
  72.                 i++;//延时6us等待数据稳定
  73.                 bi=DSPORT;         //读取数据,从最低位开始读取
  74.                 /*将byte左移一位,然后与上右移7位后的bi,注意移动之后移掉那位补0。*/
  75.                 byte=(byte>>1)|(bi<<7);                                                  
  76.                 i=4;                //读取完之后等待48us再接着读取下一个数
  77.                 while(i--);
  78.         }                                
  79.         return byte;
  80. }
  81. /*******************************************************************************
  82. * 函数名         : Ds18b20ChangTemp
  83. * 函数功能                   : 让18b20开始转换温度
  84. * 输入           : com
  85. * 输出                  : 无
  86. *******************************************************************************/

  87. void  Ds18b20ChangTemp()
  88. {
  89.         Ds18b20Init();
  90.         Delay1ms(1);
  91.         Ds18b20WriteByte(0xcc);                //跳过ROM操作命令                 
  92.         Ds18b20WriteByte(0x44);          //温度转换命令
  93.         Delay1ms(100);
  94. }
  95. /*******************************************************************************
  96. * 函数名         : Ds18b20ReadTempCom
  97. * 函数功能                   : 发送读取温度命令
  98. * 输入           : com
  99. * 输出                  : 无
  100. *******************************************************************************/

  101. void  Ds18b20ReadTempCom()
  102. {        

  103.         Ds18b20Init();
  104.         Delay1ms(1);
  105.         Ds18b20WriteByte(0xcc);         //跳过ROM操作命令
  106.         Ds18b20WriteByte(0xbe);         //发送读取温度命令
  107. }
  108. /*******************************************************************************
  109. * 函数名         : Ds18b20ReadTemp
  110. * 函数功能                   : 读取温度
  111. * 输入           : com
  112. * 输出                  : 无
  113. *******************************************************************************/

  114. int Ds18b20ReadTemp()
  115. {
  116.         int temp=0;
  117.         unsigned char tmh,tml;
  118.         Ds18b20ChangTemp();                                 //先写入转换命令
  119.         Ds18b20ReadTempCom();                        //然后等待转换完后发送读取温度命令
  120.         tml=Ds18b20ReadByte();                //读取温度值共16位,先读低字节
  121.         tmh=Ds18b20ReadByte();                //再读高字节
  122.         temp=tmh;
  123.         temp<<=8;
  124.         temp|=tml;
  125.         return temp;
  126. }
复制代码


等精度频率计全部资料下载:
频率计 温度计.rar (1018.46 KB, 下载次数: 125)

评分

参与人数 2黑币 +105 收起 理由
348652560 + 5 很给力!
admin + 100 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏5 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:1 发表于 2017-3-8 02:30 | 只看该作者
好资料,51黑有你更精彩。
回复

使用道具 举报

板凳
ID:159514 发表于 2017-3-8 14:47 | 只看该作者
输入测试频率的信号是不是需要分频处理?我在做频率测量的时候先除以40后再测的
回复

使用道具 举报

地板
ID:211164 发表于 2017-6-14 17:06 | 只看该作者
看看,借鉴学习学习
回复

使用道具 举报

5#
ID:211258 发表于 2017-6-15 17:01 | 只看该作者
谢谢分享!收藏了!
回复

使用道具 举报

6#
ID:366539 发表于 2019-7-25 13:34 | 只看该作者
谢谢分享!认真学习
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表