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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機戶外運動監測系統Proteus仿真程序

[復制鏈接]
跳轉到指定樓層
樓主
測量溫濕度和心率脈搏測量,心率脈搏可設置,超過設置值,進行聲光告警
脈沖值不要太大,不要超過35
由于仿真中沒有紅外,手指也模擬不了,其實就是單片機的IO口檢測脈沖信號,那樣用個方波信號模擬就行了
Altium Designer畫的原理圖和PCB圖如下:(51hei附件中可下載工程文件)




單片機源程序如下:
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. #include "LCD1602.h"
  4. #include "DHT11.h"
  5. #include "Delay.h"        



  6. sbit Xintiao =P1^0 ;                                         //脈搏檢測輸入端定義
  7. sbit speaker =P2^1;                                                 //蜂鳴器引腳定義

  8. sbit LED_RED = P1^2;                   //紅燈
  9. sbit LED_GREED = P1^3;                   //綠燈

  10. uchar xiaoting_num = 0;                  //心跳值

  11. void delay5ms(void);   //誤差 0us
  12. void Tim_Init();

  13. uchar Xintiao_Change=0;           //
  14. uint  Xintiao_Jishu;
  15. uchar stop;
  16. uchar View_Change;
  17. uchar View_Data[3];
  18. uchar View_L[3];
  19. uchar View_H[3];
  20. uchar Xintiao_H=100;        //脈搏上限

  21. uchar Key_Change;
  22. uchar Key_Value;                //按鍵鍵值
  23. uchar View_Con;                        //設置的位(0正常工作,1設置上限,2設置下限)
  24. uchar View_Change;

  25. void Dispaly_Xintiao(void);




  26. void main( void )          //主函數
  27. {
  28. InitLcd();
  29. Tim_Init();
  30. ShtConnectReset();

  31. LED_RED = 0;
  32. LED_GREED = 0;

  33. TR0=1;
  34. TR1=1;                                  //打開定時器
  35. while(1)                          //進入循環
  36.   {
  37.     Display_STH11();                  //顯示溫濕度
  38.         Dispaly_Xintiao();                  //顯示心跳值

  39.         if( Key_Value == 2 )           //心跳值設置 加
  40.         {
  41.                 Xintiao_H++;
  42.                 if( Xintiao_H >= 160 )
  43.                 {
  44.                         Xintiao_H = 160;
  45.                 }
  46.                 Key_Value = 10;        
  47.         }

  48.         if( Key_Value == 3 )                 //心跳值設置 減
  49.         {
  50.                 Xintiao_H--;
  51.                 if( Xintiao_H <= 60 )
  52.                 {
  53.                         Xintiao_H = 60;
  54.                 }        
  55.                 Key_Value = 10;
  56.         }

  57.         if( Xintiao_H > xiaoting_num )
  58.         {
  59.                 LED_RED = 1;
  60.                 LED_GREED = 0;
  61.         }
  62.         else
  63.         {
  64.                 LED_RED = 0;
  65.                 LED_GREED = 1;
  66.         }
  67.   }
  68. }

  69. //心跳顯示
  70. void Dispaly_Xintiao( void )
  71. {
  72.   LCD_WriteCom( 0x80 + 0x40 );
  73.   LCD_WriteData( 'R' );
  74.   LCD_WriteData( ':' );
  75.   LCD_WriteData( View_Data[0] );
  76.   LCD_WriteData( View_Data[1] );
  77.   LCD_WriteData( View_Data[2] );
  78.   xiaoting_num = View_Data[0]*100 + View_Data[1]*10 + View_Data[3];
  79.   LCD_WriteData( ' ' );
  80.   LCD_WriteData( ' ' );
  81.   LCD_WriteData( ' ' );
  82.   LCD_WriteData( 'S' );
  83.   LCD_WriteData( ':' );
  84.   LCD_WriteData( Xintiao_H/100 + 0x30 );
  85.   LCD_WriteData( Xintiao_H%100/10 + 0x30 );
  86.   LCD_WriteData( Xintiao_H%10 + 0x30 );
  87.   LCD_WriteData( ' ' );
  88.   LCD_WriteData( ' ' );
  89. }


  90. void Time1() interrupt 3                //定時器1服務函數
  91. {
  92.         static uchar Key_Con,Xintiao_Con;
  93.         TH1=0xd8;                   //10ms
  94.         TL1=0xf0;                   //重新賦初值
  95.         switch(Key_Con)   //無按鍵按下時此值為0
  96.         {
  97.                 case 0:                   //每10ms掃描此處
  98.                 {
  99.                         if((P3&0x07)!=0x07)//掃描按鍵是否有按下
  100.                         {
  101.                                 Key_Con++;                  //有按下此值加1,值為1
  102.                         }
  103.                         break;
  104.                 }
  105.                 case 1:                                          //10ms后二次進入中斷后掃描此處(Key_Con為1)
  106.                 {
  107.                         if((P3&0x07)!=0x07)//第二次進入中斷時,按鍵仍然是按下(起到按鍵延時去抖的作用)
  108.                         {
  109.                                 Key_Con++;                  //變量加1,值為2
  110.                                 switch(P3&0x07)  //判斷是哪個按鍵按下
  111.                                 {
  112.                                         case 0x06:Key_Value=1;break;         //判斷好按鍵后將鍵值賦值給變量Key_Value
  113.                                         case 0x05:Key_Value=2;break;
  114.                                         case 0x03:Key_Value=3;break;
  115.                                 }
  116.                         }
  117.                         else                                                                 //如果10ms時沒有檢測到按鍵按下(按下時間過短)
  118.                         {
  119.                                 Key_Con=0;                                                 //變量清零,重新檢測按鍵
  120.                         }
  121.                         break;
  122.                 }
  123.                 case 2:                                                                         //20ms后檢測按鍵
  124.                 {
  125.                         if((P3&0x07)==0x07)                                 //檢測按鍵是否還是按下狀態
  126.                         {
  127.                                 Key_Change=1;                                         //有按鍵按下使能變量,(此變量為1時才會處理鍵值數據)
  128.                                 Key_Con=0;                                                //變量清零,等待下次有按鍵按下
  129.                         }
  130.                         break;
  131.                 }
  132.         }
  133.                
  134.         switch (Xintiao_Con)//此處與上面按鍵的檢測類似
  135.         {
  136.                 case 0:                         //默認Xintiao_Con是為0的
  137.                 {
  138.                         if(!Xintiao)//每10ms(上面的定時器)檢測一次脈搏是否有信號
  139.                         {
  140.                                 Xintiao_Con++;//如果有信號,變量加一,程序就會往下走了
  141.                         }
  142.                         break;
  143.                 }
  144.                 case 1:
  145.                 {
  146.                         if(!Xintiao)           //每過10ms檢測一下信號是否還存在
  147.                         {
  148.                                 Xintiao_Con++;//存在就加一
  149.                         }
  150.                         else
  151.                         {
  152.                                 Xintiao_Con=0;//如果不存在了,檢測時間很短,說明檢測到的不是脈搏信號,可能是其他干擾,將變量清零,跳出此次檢測
  153.                         }
  154.                         break;
  155.                 }
  156.                 case 2:
  157.                 {
  158.                         if(!Xintiao)
  159.                         {
  160.                                 Xintiao_Con++;//存在就加一
  161.                         }
  162.                         else
  163.                         {
  164.                                 Xintiao_Con=0;//如果不存在了,檢測時間很短,說明檢測到的不是脈搏信號,可能是其他干擾,將變量清零,跳出此次檢測
  165.                         }
  166.                         break;
  167.                 }
  168.                 case 3:
  169.                 {
  170.                         if(!Xintiao)
  171.                         {
  172.                                 Xintiao_Con++;//存在就加一
  173.                         }
  174.                         else
  175.                         {
  176.                                 Xintiao_Con=0;//如果不存在了,檢測時間很短,說明檢測到的不是脈搏信號,可能是其他干擾,將變量清零,跳出此次檢測
  177.                         }
  178.                         break;
  179.                 }
  180.                 case 4:
  181.                 {
  182.                         if(Xintiao)//超過30ms一直有信號,判定此次是脈搏信號,執行以下程序
  183.                         {
  184.                                 if(Xintiao_Change==1)//心率計原理為檢測兩次脈沖間隔時間計算心率,變量Xintiao_Change第一次脈沖時為0的,所有走下面的else,第二次走這里
  185.                                 {
  186.                                         View_Data[0]=(6000/Xintiao_Jishu)/100+0x30;
  187.                                         View_Data[1]=(6000/Xintiao_Jishu)%100/10+0x30;
  188.                                         View_Data[2]=(6000/Xintiao_Jishu)%10+0x30;
  189.                                        
  190.                         
  191.                                         View_Change=1;           //計算出心率后啟動顯示
  192.                                         Xintiao_Jishu=0;           //心跳計數清零
  193.                                         Xintiao_Change=0;   //計算出心率后該變量清零,準備下次檢測心率
  194.                                         stop=0;                           //計算出心率后stop清零
  195.                                    TR0=0;
  196.                                 //   wendu=ReadTemperature();
  197.                                 //   TR1=0;
  198.                                 }
  199.                                 else//第一次脈沖時Xintiao_Change為0
  200.                                 {
  201.                                         Xintiao_Jishu=0;        //脈沖計時變量清零,開始計時
  202.                                         Xintiao_Change=1;//Xintiao_Change置1,準備第二次檢測到脈沖時計算心率
  203.                                         TR0=1;
  204.                                 }
  205.                                 Xintiao_Con=0;        //清零,準備檢測下一次脈沖
  206.                                 break;
  207.                         }
  208.                 }
  209.         }
  210. }

  211. /**定時器T0工作函數**/
  212. void Time0() interrupt 1
  213. {
  214. TH0=0xfc;                   //1ms
  215. TL0=0x18;                   //重新賦初值
  216. Xintiao_Jishu++;  //心跳計數加
  217. if(Xintiao_Jishu==5000)//心跳計數大于5000
  218.   {
  219.    Xintiao_Jishu=0;                //數據清零
  220.    View_Change=1;                //顯示位置1
  221.    Xintiao_Change=0;        //置零,準備再次檢測
  222.    stop=1;           //心跳計數超過5000后說明心率不正常或者沒有測出,stop置1
  223.    speaker=1;  //關閉蜂鳴器
  224.   }
  225. }
  226. /**定時器初始化函數**/
  227. void Tim_Init()
  228. {
  229. EA=1;                          //打開中斷總開關
  230. ET0=1;                          //打開T0中斷允許開關
  231. ET1=1;                          //打開T1中斷允許開關
  232. TMOD=0x11;                  //設定定時器狀態
  233. TH0=0xfc;                   //1ms
  234. TL0=0x18;                   //賦初值

  235. TH1=0xd8;                   //10ms
  236. TL1=0xf0;                   //賦初值
  237. }
復制代碼

所有資料51hei提供下載:
戶外運動.zip (1.04 MB, 下載次數: 76)

評分

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

查看全部評分

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

使用道具 舉報

沙發
ID:792691 發表于 2020-7-8 22:03 | 只看該作者
如何設置心率脈搏啊
回復

使用道具 舉報

板凳
ID:759867 發表于 2020-10-23 16:40 來自手機 | 只看該作者
大佬們請收下我的膝蓋 好資料,51黑有你更精彩!!!
回復

使用道具 舉報

地板
ID:935652 發表于 2021-6-9 21:23 來自手機 | 只看該作者
用Proteus8.8打開可以仿真
回復

使用道具 舉報

5#
ID:844192 發表于 2021-6-10 13:42 | 只看該作者
大佬能問一下 用的什么傳感器嗎
回復

使用道具 舉報

6#
ID:844192 發表于 2021-6-27 16:14 | 只看該作者
黑幣不夠但是看了代碼,十分感謝!51黑有你更精彩
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产日韩视频在线 | 永久av | 免费在线观看一区二区 | 夜夜爽99久久国产综合精品女不卡 | 精品国产一区二区三区久久 | 久久九九99| 国产做爰| 亚洲国产成人在线观看 | 亚洲成人一区二区 | 一区二区三区四区视频 | 亚洲欧美自拍偷拍视频 | 天天干天天操天天看 | 欧美日韩精品区 | 成人免费视频播放 | 日韩欧美亚洲一区 | 99小视频 | 国产精品黄色 | 久久精品国产免费 | 久草视频在线看 | 国产午夜精品理论片a大结局 | 男人天堂网av | 国产激情一区二区三区 | 蜜桃在线视频 | 五月综合久久 | 国产精品成人久久久久 | 精品久久一区二区 | 欧美日韩激情 | 中文字幕在线视频一区二区三区 | 免费观看成人鲁鲁鲁鲁鲁视频 | 一区二区三区四区在线视频 | 久久新视频 | 久久久激情视频 | 成人影院在线视频 | 精品久久网 | 国产在线观看一区二区三区 | 亚洲国产一区在线 | 99视频在线免费观看 | 国产成人小视频 | 99国产精品久久久久久久 | 久久99精品久久久久久 | 一级黄色播放 |