久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 6637|回復: 0
打印 上一主題 下一主題
收起左側

基于單片機的導盲儀系統設計報告與源程序等資料下載

[復制鏈接]
跳轉到指定樓層
樓主
單片機原理及應用
項目設計報告

姓名:張*
學號:15221*
班級:校區15電氣1班
專業:電氣工程及其自動化
學院:電氣與信息工程學院


20186

目錄

基于單片機的導盲儀系統

一、緒論

1、項目研究背景及意義

二、總體設計方案及論證

1、總體方案設計

三、硬件實現及單元電路設計

1、主控制模塊

2、  電源設計

3、  超聲波測試模塊

4、 測距分析

5、 時鐘電路的設計

6、 復位電路的設計

7、  聲音報警電路的設計

8、顯示模塊

四、軟件設計

1、主程序工作流程圖

2、超聲波探測程序流程圖

五、總結

六、參考文獻

附 錄

附件1:原理圖

附件2:程序

附件3:實物圖


一、緒論
1、項目研究背景及意義
由于超聲測距是一種非接觸檢測技術,不受光線、被測對象顏色等的影響,較其它儀器更衛生,更耐潮濕、粉塵、高溫、腐蝕氣體等惡劣環境,具有少維護、不污染、高可靠、長壽命等特點。因此可廣泛應用于紙業、礦業、電廠、化工業、水處理廠、污水處理廠、農業用水、環保檢測、食品(酒業、飲料業、添加劑、食用油、奶制品)、防汛、水文、明渠、空間定位、公路限高等行業中?稍诓煌h境中進行距離準確度在線標定,可直接用于水、酒、糖、飲料等液位控制,可進行差值設定,直接顯示各種液位罐的液位、料位高度。因此,超聲在空氣中測距在特殊環境下有較廣泛的應用。利用超聲波檢測往往比較迅速、方便、計算簡單、易于實現實時控制,并且在測量精度方面能達到工業實用的指標要求,因此為了使移動機器人能夠自動躲避障礙物行走,就必須裝備測距系統,以使其及時獲取距障礙物的位置信息(距離和方向)。因此超聲波測距在移動機器人的研究上得到了廣泛的應用。同時由于超聲波測距系統具有以上的這些優點,因此在導盲儀的研制方面也得到了廣泛的應用。

二、總體設計方案及論證
1、總體方案設計
本設計包括硬件和軟件設計兩個部分。模塊劃分為數據采集、按鍵控制、四位數碼管顯示、報警等子模塊。電路結構可劃分為:超聲波傳感器、蜂鳴器、單片機控制電路。就此設計的核心模塊來說,單片機就是設計的中心單元,所以此系統也是單片機應用系統的一種應用。單片機應用系統也是有硬件和軟件組成。硬件包括單片機、輸入/輸出設備、以及外圍應用電路等組成的系統,軟件是各種工作程序的總稱。單片機應用系統的研制過程包括總體設計、硬件設計、軟件設計等幾個階段。系統采用STC89C52單片機作為核心控制單元,當測得的距離小于設定距離時,主控芯片將測得的數值與設定值進行比較處理。然后控制蜂鳴器報警。系統總體的設計方框圖如圖2-1所示。




圖2-1 系統方框圖

三、硬件實現及單元電路設計
1、主控制模塊
主控制最小系統電路如圖3-1所示。

圖3-1 最小系統

硬件電路總設計見圖3-2,從以上的分析可知在本設計中要用到如下器件: STC89C52、超聲波傳感器、按鍵、四位數碼管、蜂鳴器等一些單片機外圍應用電路。其中D1為電源工作指示燈。電路中用到3個按鍵,一個是設定鍵, 一個加鍵,一個減鍵。

圖3-2 總設計電路圖

2、  電源設計
電源部分的設計采用3節5號干電池4.5V供電。
3、  超聲波測試模塊
超聲波模塊采用現成的HC-SR04超聲波模塊,該模塊可提供 2cm-500cm 的非接觸式距離感測功能,測距精度可達高到 3mm。模塊包括超聲波發射器、接收器與控制電路;竟ぷ髟恚翰捎 IO 口 TRIG 觸發測距,給至少 10us 的高電平信號;模塊自動發送 8 個 40khz 的方波,自動檢測是否有信號返回;有信號返回,通過 IO 口 ECHO 輸出一個高電平,高電平持續的時間就是超聲波從發射到返回的時間。測試距離=(高電平時間*聲速(340M/S))/2。實物如下圖4。其中VCC 供5V 電源,GND 為地線,TRIG 觸發控制信號輸入,ECHO 回響信號輸出等四支線。

圖3-3 超聲波模塊實物圖

超聲波探測模塊HC-SR04的使用方法如下:IO口觸發,給Trig口至少10us的高電平,啟動測量;模塊自動發送8個40Khz的方波,自動檢測是否有信號返回;有信號返回,通過IO口Echo輸出一個高電平,高電平持續的時間就是超聲波從發射到返回的時間,測試距離=(高電平時間*340)/ 2,單位為m。程序中測試功能主要由兩個函數完成。
實現中采用定時器0進行定時測量,8分頻,TCNTT0預設值0XCE,當timer0溢出中斷發生2500次時為125ms,計算公式為(單位:ms):
T = (定時器0溢出次數 * (0XFF - 0XCE))/ 1000
其中定時器0初值計算依據分頻不同而有差異。
4、 測距分析
超聲波發射器向某一方向發射超聲波,在發射時刻的同時開始計時,超聲波在空氣中傳播,途中碰到障礙物就立即返回來,超聲波接收器收到反射波就立即停止計時。超聲波在空氣中的傳播速度為340m/s,根據計時器記錄的時間t,就可以計算出發射點距障礙物的距離(s),即:s=340t/2
最常用的超聲測距的方法是回聲探測法,超聲波發射器向某一方向發射超聲波,在發射時刻的同時計數器開始計時,超聲波在空氣中傳播,途中碰到障礙物面阻擋就立即反射回來,超聲波接收器收到反射回的超聲波就立即停止計時。超聲波在空氣中的傳播速度為340m/s,根據計時器記錄的時間t,就可以計算出發射點距障礙物面的距離s,即:s=340t/2。   
只要測得超聲波往返的時間,即可求得距離。這就是超聲波測距儀的基本原理。如圖12所示:

圖3-4 超聲波的測距原理


                             (3-1)
                           (3-2)
式中:L---兩探頭之間中心距離的一半.
又知道超聲波傳播的距離為:
                                ( 3-3)
式中:v—超聲波在介質中的傳播速度;
     t—超聲波從發射到接收所需要的時間.
將(3—2)、(3—3)代入(3-1)中得:
                     ( 3-4)
其中,超聲波的傳播速度v在一定的溫度下是一個常數(例如在溫度T=30度時,V=349m/s);當需要測量的距離H遠遠大于L時,則(3—4)變為:
                                           ( 3-5)               
所以,只要需要測量出超聲波傳播的時間t,就可以得出測量的距離H.
5、 時鐘電路的設計
XTAL1和XTAL2分別為反向放大器的輸入和輸出。該反向放大器可以配置為片內振蕩器。石晶振蕩和陶瓷振蕩均可采用。如采用外部時鐘源驅動器件,XTAL2應不接。
因為一個機器周期含有6個狀態周期,而每個狀態周期為2個振蕩周期,所以一個機器周期共有12個振蕩周期,如果外接石英晶體振蕩器的振蕩頻率為12MHZ,一個振蕩周期為1/12us,故而一個機器周期為1us。如圖3-5所示為時鐘電路。

圖3-5 時鐘電路圖


6、 復位電路的設計
復位方法一般有上電自動復位和外部按鍵手動復位,單片機在時鐘電路工作以后, 在RESET端持續給出2個機器周期的高電平時就可以完成復位操作。例如使用晶振頻率為12MHz時,則復位信號持續時間應不小于2us。本設計采用的是自動復位電路。如圖3-6示為復位電路。

圖3-6 復位電路圖

7、  聲音報警電路的設計
如下圖所示,用一個Speaker和三極管、電阻接到單片機的P13引腳上,構成聲音報警電路,如圖3-7示為聲音報警電路。

圖3-7 聲音報警電路圖

8、顯示模塊
顯示模塊采用數碼管顯示接口電路如圖3-8


圖3-8 數碼管電路



四、軟件設計            
1、主程序工作流程圖
按上述工作原理和硬件結構分析可知系統主程序工作流程圖如下圖4-1所示;

圖4-1主程序工作流程圖


2、超聲波探測程序流程圖

圖4-2 超聲波探測程序流程圖

五、總結
本設計研究了一種基于單片機技術的超聲波導盲儀系統。該系統通過以STC89C52單片機為工作處理器核心,超聲波傳感器,它是一種新穎的被動式超聲波探測器件,能夠以非接觸測出前方物體距離,并將其轉化為相應的電信號輸出.該報警器的最大特點就是使用戶能夠操作簡單、易懂、靈活;且安裝方便、智能性高、誤報率低。隨著現代人們安全意識的增強以及科學技術的快速發展,相信超聲波導盲儀必將在更廣闊的人群中得到更深層次的應用。
六、參考文獻
[1] 吳政江. 單片機控制紅外線防盜報警器[J]. 錦州師范學院學報, 2001.
[2] 宋文緒. 傳感器與檢測技術[M]. 北京: 高等教育出版社, 2004.
[3] 余錫存. 單片機原理及接口技術[M]. 西安: 西安電子科技大學出版社, 2000.
[4] 唐桃波, 陳玉林. 基于AT89C51的智能無線安防報警器 [J]. 電子設計應用, 2003, 5(6): 49~51.
[5] 李全利. 單片機原理及接口技術[M]. 北京: 北京航空航天大學出版社, 2004.
[6] 薛均義, 張彥斌. MCS-51系列單片微型計算機及其應用[M]. 西安: 西安交通大學出版社, 2005.
[7] 徐愛鈞, 彭秀華. 單片機高級語言C51應用程序設計[M]. 北京: 北京航空航天大學出版社, 2006.
[8] 康華光. 電子技術基礎(模擬部分)[M]. 北京: 高等教育出版社, 2004.


附件1:原理圖
附件2:程序

  1. #include <reg52.h>                       //調用單片機頭文件
  2. #define uchar unsigned char  //無符號字符型 宏定義              變量范圍0~255
  3. #define uint  unsigned int              //無符號整型 宏定義              變量范圍0~65535
  4. #include <intrins.h>

  5. //數碼管段選定義      0     1    2    3    4    5              6              7                8                 9            
  6. uchar code smg_du[]={0x28,0xee,0x32,0xa2,0xe4,0xa1,0x21,0xea,0x20,0xa0,
  7.                                                                         0x60,0x25,0x39,0x26,0x31,0x71,0xff};              //斷碼


  8. uchar dis_smg[8]   ={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8};

  9. //數碼管位選定義
  10. sbit smg_we1 = P3^4;                  //數碼管位選定義
  11. sbit smg_we2 = P3^5;
  12. sbit smg_we3 = P3^6;
  13. sbit smg_we4 = P3^7;

  14. sbit c_send   = P3^2;                            //超聲波發射
  15. sbit c_recive = P3^3;                            //超聲波接收

  16. sbit beep = P2^3;   //蜂鳴器IO口定義
  17. uchar smg_i = 3;    //顯示數碼管的個位數
  18. bit flag_300ms ;

  19. long distance;                      //距離
  20. uint set_d;                          //距離
  21. uchar flag_csb_juli;    //超聲波超出量程
  22. uint  flag_time0;       //用來保存定時器0的時候的

  23. uchar menu_1;           //菜單設計的變量


  24. /***********************1ms延時函數*****************************/
  25. void delay_1ms(uint q)
  26. {
  27.               uint i,j;
  28.               for(i=0;i<q;i++)
  29.                             for(j=0;j<120;j++);
  30. }

  31. /***********************處理距離函數****************************/
  32. void smg_display()
  33. {
  34.               dis_smg[0] = smg_du[distance % 10];
  35.               dis_smg[1] = smg_du[distance / 10 % 10];
  36.               dis_smg[2] = smg_du[distance / 100 % 10] & 0xdf; ;            
  37. }

  38. /********************獨立按鍵程序*****************/
  39. uchar key_can;              //按鍵值

  40. void key()              //獨立按鍵程序
  41. {
  42.               static uchar key_new;
  43.               key_can = 20;                   //按鍵值還原
  44.               P2 |= 0x07;
  45.               if((P2 & 0x07) != 0x07)                            //按鍵按下
  46.               {
  47.                             delay_1ms(1);                                 //按鍵消抖動
  48.                             if(((P2 & 0x07) != 0x07) && (key_new == 1))
  49.                             {                                                                                    //確認是按鍵按下
  50.                                           key_new = 0;
  51.                                           switch(P2 & 0x07)
  52.                                           {
  53.                                                         case 0x06: key_can = 3; break;                 //得到k2鍵值
  54.                                                         case 0x05: key_can = 2; break;                 //得到k3鍵值
  55.                                                         case 0x03: key_can = 1; break;                 //得到k4鍵值
  56.                                           }
  57.                             }                                         
  58.               }
  59.               else
  60.                             key_new = 1;            
  61. }

  62. /****************按鍵處理顯示函數***************/
  63. void key_with()
  64. {
  65.               if(key_can == 1)                            //設置鍵
  66.               {
  67.                             menu_1 ++;
  68.                             if(menu_1 >= 2)
  69.                             {
  70.                                           menu_1 = 0;
  71.                                           smg_i = 3;                            //只顯示3位數碼管
  72.                             }
  73.                             if(menu_1 == 1)
  74.                             {
  75.                                           smg_i = 4;                 //只顯示4位數碼管
  76.                             }
  77.               }
  78.               if(menu_1 == 1)                                          //設置報警
  79.               {
  80.                             if(key_can == 2)
  81.                             {
  82.                                           set_d ++ ;                            //加1
  83.                                           if(set_d > 400)
  84.                                                         set_d = 400;
  85.                             }
  86.                             if(key_can == 3)
  87.                             {
  88.                                           set_d -- ;                            //減1
  89.                                           if(set_d <= 1)
  90.                                                         set_d = 1;
  91.                             }
  92.                             dis_smg[0] = smg_du[set_d % 10];                         //取小數顯示
  93.                             dis_smg[1] = smg_du[set_d / 10 % 10] ;         //取個位顯示
  94.                             dis_smg[2] = smg_du[set_d / 100 % 10] & 0xdf ; //取十位顯示
  95.                             dis_smg[3] = 0x60;                      //a
  96.               }            
  97. }

  98. /****************報警函數***************/
  99. void clock_h_l()
  100. {
  101.               static uchar value;
  102.               if(distance <= set_d)
  103.               {
  104.                             value ++;  //消除實際距離在設定距離左右變化時的干擾
  105.                             if(value >= 2)
  106.                             {
  107.                                           beep = ~beep;                 //蜂鳴器報警            
  108.                             }
  109.               }
  110.               else
  111.               {
  112.                             value = 0;
  113.                             beep = 1;                            //取消報警
  114.               }            
  115. }

  116. /***********************數碼位選函數*****************************/
  117. void smg_we_switch(uchar i)
  118. {
  119.               switch(i)
  120.               {
  121.                             case 0: smg_we1 = 0;  smg_we2 = 1; smg_we3 = 1;  smg_we4 = 1; break;
  122.                             case 1: smg_we1 = 1;  smg_we2 = 0; smg_we3 = 1;  smg_we4 = 1; break;
  123.                             case 2: smg_we1 = 1;  smg_we2 = 1; smg_we3 = 0;  smg_we4 = 1; break;
  124.                             case 3: smg_we1 = 1;  smg_we2 = 1; smg_we3 = 1;  smg_we4 = 0; break;
  125.               }            
  126. }

  127. /***********************數碼顯示函數*****************************/
  128. void display()
  129. {
  130.               static uchar i;  
  131.               i++;
  132.               if(i >= smg_i)
  133.                             i = 0;            
  134.               smg_we_switch(i);                            //位選
  135.               P1 = dis_smg[i];                            //段選                     
  136. }

  137. /******************小延時函數*****************/
  138. void delay()
  139. {
  140.               _nop_();                                        //執行一條_nop_()指令就是1us
  141.               _nop_();
  142.               _nop_();
  143.               _nop_();
  144.               _nop_();
  145.               _nop_();
  146.               _nop_();
  147.               _nop_();
  148.               _nop_();
  149.               _nop_();
  150. }


  151. /*********************超聲波測距程序*****************************/
  152. void send_wave()
  153. {
  154.               c_send = 1;                                       //10us的高電平觸發
  155.               delay();
  156.               c_send = 0;            
  157.               TH0 = 0;                                      //給定時器0清零
  158.               TL0 = 0;
  159.               TR0 = 0;                                                          //關定時器0定時
  160.               while(!c_recive);                              //當c_recive為零時等待
  161.               TR0=1;
  162.               while(c_recive)                                  //當c_recive為1計數并等待
  163.               {
  164.                             flag_time0 = TH0 * 256 + TL0;
  165.                             if((flag_time0 > 40000))      //當超聲波超過測量范圍時,顯示3個888
  166.                             {
  167.                                           TR0 = 0;
  168.                                           flag_csb_juli = 2;
  169.                                           distance = 888;
  170.                                           break ;                           
  171.                             }
  172.                             else
  173.                             {
  174.                                           flag_csb_juli = 1;            
  175.                             }
  176.               }
  177.               if(flag_csb_juli == 1)
  178.               {            
  179.                             TR0=0;                                                                                                  //關定時器0定時
  180.                             distance =flag_time0;                                          //讀出定時器0的時間
  181.                             distance *= 0.017;               // 0.017 = 340M / 2 = 170M = 0.017M 算出來是米
  182.                             if((distance > 500))                                                        //距離 = 速度 * 時間
  183.                             {            
  184.                                           distance = 888;                                                        //如果大于3.8m就超出超聲波的量程
  185.                             }
  186.               }
  187. }


  188. /*********************定時器0、定時器1初始化******************/
  189. void time_init()               
  190. {
  191.               EA  = 1;                              //開總中斷
  192.               TMOD = 0X11;                //定時器0、定時器1工作方式1
  193.               ET0 = 0;                              //關定時器0中斷
  194.               TR0 = 1;                              //允許定時器0定時
  195.               ET1 = 1;                              //開定時器1中斷
  196.               TR1 = 1;                              //允許定時器1定時            
  197. }



  198. /***************主函數*****************/
  199. void main()
  200. {
  201.               beep = 0;                            //開機叫一聲  
  202.               delay_1ms(150);
  203.               P0 = P1 = P2 = P3 = 0xff;                 //初始化單片機IO口為高電平
  204.               time_init();              //定時器初始化程序
  205.               send_wave();              //測距離函數
  206.               while(1)
  207.               {                             
  208.                             if(flag_300ms == 1)
  209.                             {                           
  210. ……………………

  211. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼



全部資料51hei下載地址:

152219702125張俊巖.zip (8.66 MB, 下載次數: 69)


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂1 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 精品国产一区二区三区四区在线 | 久久免费视频2 | 日韩和的一区二在线 | 国产成人精品一区二区三区四区 | 国产精品1区2区 | 99一区二区 | 久久亚洲91 | 亚洲一区二区三区四区五区中文 | 欧美在线视频观看 | 亚洲视频一区二区三区 | 日韩福利 | 狠狠操狠狠干 | 日本免费一区二区三区 | 日韩精品一区二区三区 | 一区二区三区小视频 | 亚洲一区二区免费 | 精国产品一区二区三区四季综 | 国产精品一区2区 | 毛片日韩| 日韩中文字幕第一页 | 免费av观看| 日韩一区二区三区四区五区六区 | 一区二区小视频 | 日本中文字幕在线观看 | 一区二区三区四区五区在线视频 | 久久久久国产精品免费免费搜索 | 久久久久久久久中文字幕 | 欧美激情综合网 | 日韩一区二区三区四区五区 | 羞羞视频免费观看入口 | 欧美日韩成人网 | 欧美精品一区在线发布 | 欧美国产精品一区二区三区 | 免费观看毛片 | 欧美一区在线视频 | 日韩性在线| 欧美日韩在线一区二区 | 视频一区二区在线观看 | 午夜天堂精品久久久久 | 久久久久久久一区 | 色婷婷久久久久swag精品 |