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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機心率計 電子脈搏計設計(原理圖Protues仿真和C程序)

  [復制鏈接]
跳轉到指定樓層
樓主
51單片機做的心率計設計,能實時測量脈搏,并通過led燈閃爍代表脈搏跳動,有報警功能,下面是仿真原理圖,protues仿真工程文件請到附件里面下載

下面是壓縮包里面的心率計原理圖:

為大家轉換成了幾種格式方便查看.

這是所有資料:

單片機電子脈搏計的原理圖 仿真 和程序全部設計資料下載: 電子脈搏計.zip (466.3 KB, 下載次數: 778)

部分程序預覽:
  1. #include <reg52.h>
  2. #include <intrins.h>         //                         包含頭文件

  3. #define uint            unsigned int
  4. #define uchar           unsigned char
  5. #define ulong           unsigned long         //宏定義
  6. #define LCD_DATA        P0                                 //定義P0口為LCD_DATA

  7. sbit LCD_RS =P2^5;
  8. sbit LCD_RW =P2^6;
  9. sbit LCD_E  =P2^7;                                                 //定義LCD控制引腳

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

  12. void delay5ms(void);   //誤差 0us
  13. void LCD_WriteData(uchar LCD_1602_DATA);         /********LCD1602數據寫入***********/
  14. void LCD_WriteCom(uchar LCD_1602_COM);                 /********LCD1602命令寫入***********/
  15. void lcd_1602_word(uchar Adress_Com,uchar Num_Adat,uchar *Adress_Data); /*1602字符顯示函數,變量依次為字符顯示首地址,顯示字符長度,所顯示的字符*/
  16. void InitLcd();//液晶初始化函數

  17. void Tim_Init();

  18. uchar Xintiao_Change=0;           //
  19. uint  Xintiao_Jishu;
  20. uchar stop;
  21. uchar View_Data[3];
  22. uchar View_L[3];
  23. uchar View_H[3];
  24. uchar Xintiao_H=100;        //脈搏上限
  25. uchar Xintiao_L=40;                //脈搏下限


  26. uchar Key_Change;
  27. uchar Key_Value;                //按鍵鍵值
  28. uchar View_Con;                        //設置的位(0正常工作,1設置上限,2設置下限)
  29. uchar View_Change;

  30. void main()          //主函數
  31. {
  32. InitLcd();
  33. Tim_Init();
  34. lcd_1602_word(0x80,16,"Heart Rate:     ");          //初始化顯示
  35. TR0=1;
  36. TR1=1;                                  //打開定時器
  37. while(1)                          //進入循環
  38.   {
  39.    if(Key_Change)          //有按鍵按下并已經得出鍵值
  40.     {
  41.          Key_Change=0;          //將按鍵使能變量清零,等待下次按鍵按下
  42.          View_Change=1;
  43.          switch(Key_Value)                                //判斷鍵值
  44.           {
  45.            case 1:                                                //設置鍵按下
  46.                  {
  47.                           View_Con++;                        //設置的位加
  48.                           if(View_Con==3)                //都設置好后將此變量清零
  49.                            View_Con=0;
  50.                           break;                                //跳出,下同
  51.                          }
  52.            case 2:                                                //加鍵按下
  53.                  {
  54.                           if(View_Con==2)                //判斷是設置上限
  55.                            {
  56.                                    if(Xintiao_H<150)        //上限數值小于150
  57.                                  Xintiao_H++;                //上限+
  58.                            }
  59.                           if(View_Con==1)                //如果是設置下限
  60.                            {
  61.                                    if(Xintiao_L<Xintiao_H-1)//下限值小于上限-1(下限值不能超過上限)
  62.                                  Xintiao_L++;                //下限值加
  63.                            }
  64.                           break;
  65.                          }
  66.            case 3:                                                //減鍵按下
  67.                  {
  68.                           if(View_Con==2)                //設置上限
  69.                            {
  70.                                    if(Xintiao_H>Xintiao_L+1)//上限數據大于下限+1(同樣上限值不能小于下限)
  71.                                  Xintiao_H--;                //上限數據減
  72.                            }
  73.                           if(View_Con==1)                //設置下限
  74.                            {
  75.                                    if(Xintiao_L>30)        //下限數據大于30時
  76.                                  Xintiao_L--;                //下限數據減
  77.                            }
  78.                           break;
  79.                          }
  80.          }
  81.         }
  82.    if(View_Change)//開始顯示變量
  83.     {
  84.          View_Change=0;//變量清零
  85.          if(stop==0)                          //心率正常時
  86.           {
  87.            if(View_Data[0]==0x30) //最高位為0時不顯示
  88.             View_Data[0]=' ';
  89.           }
  90.          else                                          //心率不正常(計數超過5000,也就是兩次信號時間超過5s)不顯示數據
  91.           {
  92.            View_Data[0]=' ';
  93.            View_Data[1]=' ';
  94.            View_Data[2]=' ';
  95.           }

  96.          switch(View_Con)
  97.           {
  98.            case 0: //正常顯示
  99.                   {
  100.                            lcd_1602_word(0x80,16,"Heart Rate:     ");//顯示一行數據
  101.                            lcd_1602_word(0xc0,16,"                ");//顯示第二行數據
  102.                            lcd_1602_word(0xcd,3,View_Data);                         //第二行顯示心率
  103.                            break;
  104.                           }
  105.            case 1: //設置下限時顯示
  106.                   {
  107.                            lcd_1602_word(0x80,16,"Heart Rate:     ");//第一行顯示心率
  108.                            lcd_1602_word(0x8d,3,View_Data);
  109.                            
  110.                            View_L[0]=Xintiao_L/100+0x30;                //將下限數據拆字
  111.                            View_L[1]=Xintiao_L%100/10+0x30;
  112.                            View_L[2]=Xintiao_L%10+0x30;

  113.                            if(View_L[0]==0x30)                                        //最高位為0時,不顯示
  114.                             View_L[0]=' ';
  115.                            
  116.                            lcd_1602_word(0xC0,16,"Warning L :     ");//第二行顯示下限數據
  117.                            lcd_1602_word(0xCd,3,View_L);
  118.                            break;
  119.                           }
  120.            case 2: //設置上限時顯示(同上)
  121.                   {
  122.                            lcd_1602_word(0x80,16,"Heart Rate:     ");
  123.                            lcd_1602_word(0x8d,3,View_Data);
  124.                            
  125.                            View_H[0]=Xintiao_H/100+0x30;
  126.                            View_H[1]=Xintiao_H%100/10+0x30;
  127.                            View_H[2]=Xintiao_H%10+0x30;

  128.                            if(View_H[0]==0x30)
  129.                             View_H[0]=' ';
  130.                            
  131.                            lcd_1602_word(0xC0,16,"Warning H :     ");
  132.                            lcd_1602_word(0xCd,3,View_H);
  133.                            break;
  134.                           }
  135.           }
  136.         }
  137.   }
  138. }

  139. void Time1() interrupt 3                //定時器1服務函數
  140. {
  141. static uchar Key_Con,Xintiao_Con;
  142. TH1=0xd8;                   //10ms
  143. TL1=0xf0;                   //重新賦初值
  144. switch(Key_Con)   //無按鍵按下時此值為0
  145.   {
  146.    case 0:                   //每10ms掃描此處
  147.           {
  148.                    if((P3&0x07)!=0x07)//掃描按鍵是否有按下
  149.                     {
  150.                          Key_Con++;                  //有按下此值加1,值為1
  151.                         }
  152.                    break;
  153.                   }
  154.    case 1:                                          //10ms后二次進入中斷后掃描此處(Key_Con為1)
  155.           {
  156.                    if((P3&0x07)!=0x07)//第二次進入中斷時,按鍵仍然是按下(起到按鍵延時去抖的作用)
  157.                     {
  158.                          Key_Con++;                  //變量加1,值為2
  159.                          switch(P3&0x07)  //判斷是哪個按鍵按下
  160.                           {
  161.                            case 0x06:Key_Value=1;break;         //判斷好按鍵后將鍵值賦值給變量Key_Value
  162.                            case 0x05:Key_Value=2;break;
  163.                            case 0x03:Key_Value=3;break;
  164.                           }
  165.                         }
  166.                    else                                                                 //如果10ms時沒有檢測到按鍵按下(按下時間過短)
  167.                            {
  168.                          Key_Con=0;                                                 //變量清零,重新檢測按鍵
  169.                         }
  170.                    break;
  171.                   }
  172.    case 2:                                                                         //20ms后檢測按鍵
  173.           {
  174.                    if((P3&0x07)==0x07)                                 //檢測按鍵是否還是按下狀態
  175.                     {
  176.                          Key_Change=1;                                         //有按鍵按下使能變量,(此變量為1時才會處理鍵值數據)
  177.                          Key_Con=0;                                                //變量清零,等待下次有按鍵按下
  178.                         }
  179.                    break;
  180.                   }
  181.   }

  182. switch (Xintiao_Con)//此處與上面按鍵的檢測類似
  183.   {
  184.    case 0:                         //默認Xintiao_Con是為0的
  185.           {
  186.                    if(!Xintiao)//每10ms(上面的定時器)檢測一次脈搏是否有信號
  187.                     {
  188.                          Xintiao_Con++;//如果有信號,變量加一,程序就會往下走了
  189.                         }
  190.                    break;
  191.                   }
  192.    case 1:
  193.           {
  194.                    if(!Xintiao)           //每過10ms檢測一下信號是否還存在
  195.                     {
  196.                          Xintiao_Con++;//存在就加一
  197.                         }
  198.                    else
  199.                     {
  200.                          Xintiao_Con=0;//如果不存在了,檢測時間很短,說明檢測到的不是脈搏信號,可能是其他干擾,將變量清零,跳出此次檢測
  201.                         }
  202.                    break;
  203.                   }
  204.   case 2:
  205.           {
  206.                    if(!Xintiao)
  207.                     {
  208.                          Xintiao_Con++;//存在就加一
  209.                         }
  210.                    else
  211.                     {
  212.                          Xintiao_Con=0;//如果不存在了,檢測時間很短,說明檢測到的不是脈搏信號,可能是其他干擾,將變量清零,跳出此次檢測
  213.                         }
  214.                    break;
  215.                   }
  216.   case 3:
  217.           {
  218.                    if(!Xintiao)
  219.                     {
  220.                          Xintiao_Con++;//存在就加一
  221.                         }
  222.                    else
  223.                     {
  224.                          Xintiao_Con=0;//如果不存在了,檢測時間很短,說明檢測到的不是脈搏信號,可能是其他干擾,將變量清零,跳出此次檢測
  225.                         }
  226.                    break;
  227.                   }
  228.   case 4:
  229.           {
  230.                    if(Xintiao)//超過30ms一直有信號,判定此次是脈搏信號,執行以下程序
  231.                     {
  232.                          if(Xintiao_Change==1)//心率計原理為檢測兩次脈沖間隔時間計算心率,變量Xintiao_Change第一次脈沖時為0的,所有走下面的else,第二次走這里
  233.                           {
  234.                            View_Data[0]=(60000/Xintiao_Jishu)/100+0x30;
  235.                    View_Data[1]=(60000/Xintiao_Jishu)%100/10+0x30;
  236.                    View_Data[2]=(60000/Xintiao_Jishu)%10+0x30;

  237.                            if(((60000/Xintiao_Jishu)>=Xintiao_H)||((60000/Xintiao_Jishu)<=Xintiao_L))//心率不在范圍內報警
  238.                             speaker=0;                        //蜂鳴器響
  239.                            else
  240.                             speaker=1;                        //不響

  241.                            View_Change=1;           //計算出心率后啟動顯示
  242.                            Xintiao_Jishu=0;           //心跳計數清零
  243.                            Xintiao_Change=0;   //計算出心率后該變量清零,準備下次檢測心率
  244.                            stop=0;                           //計算出心率后stop清零
  245.                           }
  246.                          else//第一次脈沖時Xintiao_Change為0
  247.                           {
  248.                            Xintiao_Jishu=0;        //脈沖計時變量清零,開始計時
  249.                            Xintiao_Change=1;//Xintiao_Change置1,準備第二次檢測到脈沖時計算心率
  250.                           }
  251.                          Xintiao_Con=0;        //清零,準備檢測下一次脈沖
  252.                          break;
  253.                         }
  254.                   }
  255.   }
  256. }
  257. /**定時器T0工作函數**/
  258. void Time0() interrupt 1
  259. {
  260. TH0=0xfc;                   //1ms
  261. TL0=0x18;                   //重新賦初值
  262. Xintiao_Jishu++;  //心跳計數加
  263. if(Xintiao_Jishu==5000)//心跳計數大于5000
  264.   {
  265.    Xintiao_Jishu=0;                //數據清零
  266.    View_Change=1;                //顯示位置1
  267.    Xintiao_Change=0;        //置零,準備再次檢測
  268.    stop=1;           //心跳計數超過5000后說明心率不正常或者沒有測出,stop置1
  269.    speaker=1;  //關閉蜂鳴器
  270.   }
  271. }
  272. /**定時器初始化函數**/
  273. void Tim_Init()
  274. {
  275. EA=1;                          //打開中斷總開關
  276. ET0=1;                          //打開T0中斷允許開關
  277. ET1=1;                          //打開T1中斷允許開關
  278. TMOD=0x11;                  //設定定時器狀態
  279. TH0=0xfc;                   //1ms
  280. TL0=0x18;                   //賦初值

  281. TH1=0xd8;                   //10ms
  282. TL1=0xf0;                   //賦初值
  283. }
  284. /**在指定地址顯示指定數量的指定字符**/
  285. /**Adress_Com顯示地址,Num_Adat顯示字符數量,Adress_Data顯示字符串內容**/
  286. void lcd_1602_word(uchar Adress_Com,uchar Num_Adat,uchar *Adress_Data)
  287. {
  288. uchar a=0;
  289. uchar Data_Word;
  290. LCD_WriteCom(Adress_Com); //選中地址
  291. for(a=0;a<Num_Adat;a++)   //for循環決定顯示字符個數
  292.   {
  293.    Data_Word=*Adress_Data;          //讀取字符串數據
  294.    LCD_WriteData(Data_Word);  //顯示字符串
  295.    Adress_Data++;                          //顯示地址加一
  296.   }
  297. }

  298. /***************1602函數*******************/
  299. void LCD_WriteData(uchar LCD_1602_DATA)         /********LCD1602數據寫入***********/
  300. {
  301. delay5ms();  //操作前短暫延時,保證信號穩定
  302. LCD_E=0;
  303. LCD_RS=1;
  304. LCD_RW=0;
  305. _nop_();
  306. LCD_E=1;
  307. LCD_DATA=LCD_1602_DATA;
  308. LCD_E=0;
  309. LCD_RS=0;
  310. }

  311. /********LCD1602命令寫入***********/
  312. void LCD_WriteCom(uchar LCD_1602_COM)
  313. {
  314. delay5ms();//操作前短暫延時,保證信號穩定
  315. LCD_E=0;
  316. LCD_RS=0;
  317. LCD_RW=0;
  318. _nop_();
  319. LCD_E=1;
  320. LCD_DATA=LCD_1602_COM;
  321. LCD_E=0;
  322. LCD_RS=0;
  323. }


  324. void InitLcd()                   //初始化液晶函數
  325. {
  326. delay5ms();
  327. delay5ms();
  328. LCD_WriteCom(0x38); //display mode
  329. LCD_WriteCom(0x38); //display mode
  330. LCD_WriteCom(0x38); //display mode
  331. LCD_WriteCom(0x06); //顯示光標移動位置
  332. LCD_WriteCom(0x0c); //顯示開及光標設置
  333. LCD_WriteCom(0x01); //顯示清屏
  334. delay5ms();
  335. delay5ms();
  336. }

  337. void delay5ms(void)   //5ms延時函數
  338. {
  339.     unsigned char a,b;
  340.     for(b=185;b>0;b--)
  341.         for(a=12;a>0;a--);
  342. }
復制代碼


評分

參與人數 4黑幣 +71 收起 理由
依然是你 + 8 很給力!
yznn + 5 很給力!
fsdch + 8 共享資料的黑幣獎勵!
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

沙發
ID:111164 發表于 2016-3-28 17:38 | 只看該作者
求資料啊!
回復

使用道具 舉報

板凳
ID:111844 發表于 2016-4-1 21:12 | 只看該作者
感覺不錯
回復

使用道具 舉報

地板
ID:112749 發表于 2016-4-7 17:26 | 只看該作者
不知道資料齊全不。先看看
回復

使用道具 舉報

5#
ID:112693 發表于 2016-4-8 12:48 | 只看該作者
好東西呀,學習學習
回復

使用道具 舉報

6#
ID:116894 發表于 2016-4-26 20:34 | 只看該作者
還聯錯,贊一個
回復

使用道具 舉報

7#
ID:122134 發表于 2016-5-20 11:33 | 只看該作者
好棒~在研究~~~厲害呢!
回復

使用道具 舉報

8#
ID:122134 發表于 2016-5-20 11:44 | 只看該作者
請問兩次信號之間為什么是5秒呢,5秒會不會太長啊?
回復

使用道具 舉報

9#
ID:92231 發表于 2016-5-29 10:15 來自手機 | 只看該作者
這項目好強大,下來學習
回復

使用道具 舉報

10#
ID:110502 發表于 2016-8-22 15:48 | 只看該作者
謝謝樓主分享!!!
回復

使用道具 舉報

11#
ID:137545 發表于 2016-8-25 10:01 | 只看該作者
好帖子,多謝分享
回復

使用道具 舉報

12#
ID:137789 發表于 2016-8-28 21:45 | 只看該作者
不錯4545
回復

使用道具 舉報

13#
ID:139380 發表于 2016-9-14 10:27 | 只看該作者
很好,但是下不了,。。。。。。
回復

使用道具 舉報

14#
ID:136054 發表于 2016-9-15 20:36 | 只看該作者
共享是一種美德
回復

使用道具 舉報

15#
ID:140152 發表于 2016-9-23 10:55 | 只看該作者
棒棒的  頂
回復

使用道具 舉報

16#
ID:140769 發表于 2016-9-29 22:15 | 只看該作者
感謝分享,贊你!
回復

使用道具 舉報

17#
ID:145061 發表于 2016-10-29 14:05 | 只看該作者
謝謝樓主分享,好好學習一下。
回復

使用道具 舉報

18#
ID:145585 發表于 2016-11-1 21:12 | 只看該作者
謝謝分享,剛好可以參考一下
回復

使用道具 舉報

19#
ID:79626 發表于 2017-4-17 07:43 | 只看該作者
非常不錯  解決了我的畢業設計問題
回復

使用道具 舉報

20#
ID:190939 發表于 2017-4-18 19:11 | 只看該作者
很棒解決了我的畢業設計問題
回復

使用道具 舉報

21#
ID:21545 發表于 2017-5-10 16:31 | 只看該作者
謝謝!!!
回復

使用道具 舉報

22#
ID:121496 發表于 2017-5-12 15:47 | 只看該作者
努力學習中.很好的資料~
回復

使用道具 舉報

23#
ID:200071 發表于 2017-5-12 20:00 | 只看該作者
努力學習中
回復

使用道具 舉報

24#
ID:237529 發表于 2017-10-13 12:40 | 只看該作者
樓主,我想問一下你的這個能不能做成實物,因為我看你原理圖里面沒有心率傳感器,你要是知道怎么改的話和我說說,謝謝了
回復

使用道具 舉報

25#
ID:231246 發表于 2017-11-10 18:34 | 只看該作者
那接收信號是用st188嗎?
回復

使用道具 舉報

26#
ID:247623 發表于 2017-11-11 23:57 | 只看該作者
為什么我下載不了,點鏈接,跳出危險網址,是怎么回事?白白扣掉10分,無語
回復

使用道具 舉報

27#
ID:241598 發表于 2017-11-12 15:18 | 只看該作者
求資料
回復

使用道具 舉報

28#
ID:76133 發表于 2017-11-17 11:33 | 只看該作者

好東西呀,學習學習
回復

使用道具 舉報

29#
ID:243973 發表于 2017-11-22 01:32 | 只看該作者
是個好東西 學完要動手做一個
回復

使用道具 舉報

30#
ID:170498 發表于 2017-12-26 18:17 | 只看該作者
學習了
回復

使用道具 舉報

31#
ID:122053 發表于 2017-12-26 21:27 | 只看該作者
很好,學習了
回復

使用道具 舉報

32#
ID:252657 發表于 2018-3-6 19:54 | 只看該作者
程序看不了

評分

參與人數 1黑幣 +5 收起 理由
阿亮666 + 5 很給力!

查看全部評分

回復

使用道具 舉報

33#
ID:265684 發表于 2018-3-14 15:35 | 只看該作者
穩得不行啊,很有參考價值
回復

使用道具 舉報

34#
ID:255407 發表于 2018-5-5 10:23 | 只看該作者
樓主給力
回復

使用道具 舉報

35#
ID:255407 發表于 2018-5-5 10:23 | 只看該作者
樓主棒棒的
回復

使用道具 舉報

36#
ID:329690 發表于 2018-5-17 07:13 來自手機 | 只看該作者
很好啊!謝謝樓主
回復

使用道具 舉報

37#
ID:414560 發表于 2018-10-24 12:41 | 只看該作者
很棒很棒
回復

使用道具 舉報

38#
ID:427851 發表于 2018-11-22 20:20 | 只看該作者
很好!剛好做課設需要參考,謝謝了
回復

使用道具 舉報

39#
ID:438357 發表于 2018-12-4 21:33 | 只看該作者
很強  參考參考 謝謝樓主!
回復

使用道具 舉報

40#
ID:434173 發表于 2018-12-6 20:07 | 只看該作者
這項目好強大,下來學習
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 免费一区二区在线观看 | 精品国产一区二区三区久久影院 | 在线国产一区二区 | 亚州无限乱码 | 欧美一级在线视频 | 亚洲三区在线观看 | 国产亚洲欧美另类一区二区三区 | 伦理一区二区 | 欧美自拍一区 | 91精品国产综合久久久久久漫画 | 欧产日产国产精品99 | 欧美精品久久久 | 成人免费久久 | 久久精品欧美一区二区三区不卡 | 国产一区免费 | 一区二区三区不卡视频 | 精品久久久久久亚洲精品 | 九九精品在线 | 久久精品国产免费一区二区三区 | 欧美性久久久 | 亚洲一区二区中文字幕 | 精品免费国产一区二区三区四区 | 国产成人免费 | av大片在线观看 | 午夜影院在线视频 | 人人澡人人射 | 亚洲精品一区二区三区 | 日韩免费一区二区 | 欧美一页| av一区二区三区四区 | 亚洲毛片在线观看 | 欧美综合一区二区三区 | www.国产| 国产精久久久久久久妇剪断 | 国产二区视频 | 久久久片| 亚洲精品v日韩精品 | 日美女逼逼 | 国产视频日韩 | 精品一区二区三区在线视频 | 亚洲一区视频在线 |