找回密码
 立即注册

QQ登录

只需一步,快速开始

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

超声波仿真加单片机源程序 需8.6版本的proteus

[复制链接]
跳转到指定楼层
楼主
仿真需要8.6版本的仿真proteus
超声波仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


51单片机源程序:
  1. #include <REGX52.H>
  2. #include <intrins.h>
  3. #define uchar unsigned char
  4. #define uint  unsigned int
  5. #define smgport P0
  6. uchar code smg_du[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
  7. uchar code smg_we[]={0xfe,0xfd,0xfb,0xf7};
  8. uchar dis_smg[4]   ={0x40,0x40,0x40,0x40};
  9. sbit smg_w=P2^1;
  10. sbit smg_d=P2^0;
  11. sbit ECHO=P3^2;
  12. sbit TR=P3^3; //触发信号
  13. uchar Flag;//测量标志位0.5秒触发一次
  14. /**************************************************
  15. 10us延时
  16. **************************************************/
  17. void Delay10Us(void)
  18. {
  19.     _nop_();_nop_();
  20.     _nop_();_nop_();
  21.     _nop_();_nop_();
  22.     _nop_();_nop_();
  23. }
  24. /**************************************************
  25. 数码位选函数
  26. **************************************************/
  27. void smg_we_switch(uchar i)
  28. {
  29.     smgport=smg_we[i];
  30.     smg_w=1;
  31.     //smgport=smg_we[i];
  32.     smg_w=0;        
  33. }
  34. void smg_d_switch(uchar dat)
  35. {
  36.     smgport=dat;
  37.     smg_d=1;
  38.     smg_d=0;//所存           
  39. }
  40. /**************************************************
  41. 关闭显示用于消隐
  42. **************************************************/
  43. void smgalloff(void)
  44. {
  45.     smgport=0;
  46.     smg_d=1;
  47.     smg_d=0;

  48.     smgport=0xff;
  49.     smg_w=1;
  50.     smg_w=0;      
  51. }
  52. /**************************************************
  53. 数码管显示
  54. **************************************************/
  55. void smgDis(void)
  56. {
  57.     static uchar i=0;
  58.     smgalloff();
  59.     smg_d_switch(dis_smg[i]);
  60.     smg_we_switch(i);
  61.     if(++i==4)i=0;
  62. }
  63. /**************************************************
  64. 距离测量
  65. **************************************************/
  66. void Measure(void)
  67. {
  68.     uchar Err; //错误标记
  69.     unsigned long distance,pTime;//距离,时间变量
  70.     Err=0;
  71.     TR=1;     //TR保持10us高电平触发模块测距
  72.     Delay10Us();
  73.     TR=0;
  74.     TH0=0;
  75.     TL0=0;
  76.     while(ECHO==0);//等待ECHO变为高
  77.     TR0=1;       //启动定时器,外部高电平触发
  78.     while(ECHO==1)//等待超声波回应获超时
  79.     {
  80.         pTime=TH0*256+TL0;
  81.         if(pTime>40000)//时间超时
  82.         {
  83.             Err=1;
  84.             break;
  85.         }
  86.     }
  87.     TR0=0;//关闭定时器
  88.     pTime=TH0*256+TL0; //获取时间
  89.     if(pTime<59)//测量距离小于2cm
  90.     {
  91.         Err=1;
  92.     }
  93.     if(Err==0)
  94.     {
  95.         distance=(pTime*173)/10000;//;pTime*346/1000000/2=pTime*0.0173 仿真的环境温度为25度346m/s
  96.         if(distance>400)//仿真有效值只到331CM
  97.         {
  98.             Err=1;           
  99.         }
  100.         else
  101.         {
  102.             dis_smg[0]=0;
  103.             dis_smg[1]=smg_du[distance/100]; //分离千位
  104.             dis_smg[2]=smg_du[(distance/10)%10];//分离百位
  105.             dis_smg[3]=smg_du[distance%10];     //分离个位
  106.             return;
  107.         }
  108.     }
  109.     dis_smg[0]=0;    //错误时数码管显示Err
  110.     dis_smg[1]=0x79;
  111.     dis_smg[2]=0x50;
  112.     dis_smg[3]=0x50;              
  113. }
  114. /**************************************************
  115. 定时器0初始化
  116. **************************************************/
  117. void Timer0Init(void)
  118. {
  119.     TMOD|=0x09;//工作于16位模式,只有P32和TR0同时为1时开始计数
  120. }
  121. /**************************************************
  122. 定时器1初始化
  123. **************************************************/
  124. void Timer1Init(void)
  125. {
  126.     TMOD|=0x10;//定时器1工作在方式1
  127.         TH1 = (65536-2000)/256;
  128.         TL1 = (65536-2000)%256;     //2ms
  129.     TR1=1;
  130.     ET1=1;
  131.     EA=1;        
  132. }
  133. void main(void)
  134. {
  135.     TR=0;       //关闭触发
  136.     smgalloff();
  137.     Timer0Init();//定时器0初始化
  138.     Timer1Init();//定时器1初始化
  139.     while(1)
  140.     {
  141.         if(Flag)//每500ms测量一次
  142.         {
  143.             Flag=0;
  144.             Measure();//测量
  145.         }
  146. …………
  147. …………
  148. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

全部资料51hei下载地址:
单片机超声波仿真.zip (106.37 KB, 下载次数: 222)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

沙发
ID:1 发表于 2017-12-3 00:43 | 只看该作者
好资料,51黑有你更精彩!!!
回复

使用道具 举报

板凳
ID:212177 发表于 2018-1-30 09:41 来自手机 | 只看该作者
哈哈,我终于找到这个超声波模块了
回复

使用道具 举报

地板
ID:310648 发表于 2018-5-22 10:11 | 只看该作者
怎么下载不了
回复

使用道具 举报

5#
ID:523759 发表于 2019-6-10 09:35 | 只看该作者
那个圈是怎么放置的
回复

使用道具 举报

6#
ID:655329 发表于 2019-12-3 17:59 | 只看该作者
厉害
回复

使用道具 举报

7#
ID:826192 发表于 2020-10-8 20:22 | 只看该作者
仿真中为什么显示不了距离
回复

使用道具 举报

8#
ID:208271 发表于 2023-2-25 13:00 | 只看该作者
用8.9运行,可以运行,程序也没有问题,感谢
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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