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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

51單片機和MPX4115發動機機油壓力檢測Proteus仿真程序、載重檢測等

[復制鏈接]
跳轉到指定樓層
樓主
51單片機和MPX4115壓力測量器壓力檢測系統--發動機機油壓力檢測、載重檢測等
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機代碼:
  1. //線性區間標度變換公式:    y=(115-15)/(243-13)*X+15kpa   


  2. #include <AT89X52.h>
  3. #include <intrins.h>
  4. #include <stdio.h>


  5. #define R24C04ADD 0xA1
  6. #define W24C04ADD 0xA0

  7. //ADC0832的引腳
  8. sbit ADCS =P2^2;  //ADC0832 chip seclect
  9. sbit ADDI =P2^4;  //ADC0832 k in
  10. sbit ADDO =P2^4;  //ADC0832 k out
  11. sbit ADCLK =P2^3;  //ADC0832 clock signal


  12. sbit SDA = P2 ^ 1;                                //數據線
  13. sbit SCL = P2 ^ 0;                                //時鐘線
  14. bit bAck;                                          //應答標志 當bbAck=1是為正確的應答

  15. unsigned char dispbitcode[8]={0xf7,0xfb,0xfd,0xfe,0xef,0xdf,0xbf,0x7f};  //位掃描
  16. unsigned char dispcode[11]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xff};  //共陽數碼管字段碼
  17. unsigned char dispbuf[4];
  18. unsigned int temp;
  19. unsigned char getdata; //獲取ADC轉換回來的值


  20. void delay_1ms(void)  //12mhz delay 1.01ms
  21. {
  22.    unsigned char x,y;   
  23.    x=3;
  24.    while(x--)
  25.   {
  26.        y=40;
  27.        while(y--);
  28.     }
  29. }
  30. void display(void)  //數碼管顯示函數
  31. {
  32.   char k;
  33.   for(k=0;k<4;k++)
  34.   {

  35.   P1 = dispbitcode[k];
  36.   P0 = dispcode[dispbuf[k]];
  37.   if(k==1)          //加上數碼管的dp小數點
  38.           P0&=0x7f;
  39.   delay_1ms();         
  40.   }
  41. }

  42. /************
  43. 讀ADC0832函數
  44. ************/

  45. //采集并返回
  46. unsigned int Adc0832(unsigned char channel)     //AD轉換,返回結果
  47. {
  48.     unsigned char i=0;
  49.     unsigned char j;
  50.     unsigned int dat=0;
  51.     unsigned char ndat=0;

  52.     if(channel==0)channel=2;
  53.     if(channel==1)channel=3;
  54.     ADDI=1;
  55.     _nop_();
  56.     _nop_();
  57.     ADCS=0;//拉低CS端
  58.     _nop_();
  59.     _nop_();
  60.     ADCLK=1;//拉高CLK端
  61.     _nop_();
  62.     _nop_();
  63.     ADCLK=0;//拉低CLK端,形成下降沿1
  64.     _nop_();
  65.     _nop_();
  66.     ADCLK=1;//拉高CLK端
  67.     ADDI=channel&0x1;
  68.     _nop_();
  69.     _nop_();
  70.     ADCLK=0;//拉低CLK端,形成下降沿2
  71.     _nop_();
  72.     _nop_();
  73.     ADCLK=1;//拉高CLK端
  74.     ADDI=(channel>>1)&0x1;
  75.     _nop_();
  76.     _nop_();
  77.     ADCLK=0;//拉低CLK端,形成下降沿3
  78.     ADDI=1;//控制命令結束
  79.     _nop_();
  80.     _nop_();
  81.     dat=0;
  82.     for(i=0;i<8;i++)
  83.     {
  84.         dat|=ADDO;//收數據
  85.         ADCLK=1;
  86.         _nop_();
  87.         _nop_();
  88.         ADCLK=0;//形成一次時鐘脈沖
  89.         _nop_();
  90.         _nop_();
  91.         dat<<=1;
  92.         if(i==7)dat|=ADDO;
  93.     }  
  94.     for(i=0;i<8;i++)
  95.     {
  96.         j=0;
  97.         j=j|ADDO;//收數據
  98.         ADCLK=1;
  99.         _nop_();
  100.         _nop_();
  101.         ADCLK=0;//形成一次時鐘脈沖
  102.         _nop_();
  103.         _nop_();
  104.         j=j<<7;
  105.         ndat=ndat|j;
  106.         if(i<7)ndat>>=1;
  107.     }
  108.     ADCS=1;//拉低CS端
  109.     ADCLK=0;//拉低CLK端
  110.     ADDO=1;//拉高數據端,回到初始狀態
  111.     dat<<=8;
  112.     dat|=ndat;
  113.     return(dat);            //return ad k
  114. }

  115. //啟動I2C總線,即發送起始條件
  116. void StartI2C()
  117. {
  118.         SDA = 1;                              //發送起始條件數據信號
  119.         _nop_();
  120.         SCL = 1;
  121.         _nop_();                                    //起始建立時間大于4.7us
  122.         _nop_();
  123.         _nop_();
  124.         _nop_();
  125.         _nop_();
  126.         SDA = 0;                              //發送起始信號
  127.         _nop_();
  128.         _nop_();
  129.         _nop_();
  130.         _nop_();
  131.         _nop_();
  132.         SCL = 0;                                //時鐘操作
  133.         _nop_();
  134.         _nop_();
  135. }
  136. //結束I2C總線,即發送I2C結束條件
  137. void StopI2C()
  138. {
  139.         SDA = 0;                                //發送結束條件的數據信號
  140.         _nop_();                                      //發送結束條件的時鐘信號
  141.         SCL = 1;                                //結束條件建立時間大于4us
  142.         _nop_();
  143.         _nop_();
  144.         _nop_();
  145.         _nop_();
  146.         _nop_();
  147.         SDA = 1;                                //發送I2C總線結束命令
  148.         _nop_();
  149.         _nop_();
  150.         _nop_();
  151.         _nop_();
  152.         _nop_();      
  153. }
  154. //發送一個字節的數據
  155. void        SendByte(unsigned char c)
  156. {
  157.         unsigned char BitCnt;
  158.         for(BitCnt = 0;BitCnt < 8;BitCnt++)                                  //一個字節
  159.                 {
  160.                         if((c << BitCnt)& 0x80) SDA = 1;                   //判斷發送位
  161.                         else        SDA = 0;
  162.                         _nop_();
  163.                         SCL = 1;                              //時鐘線為高,通知從機開始接收數據
  164.                         _nop_();
  165.                         _nop_();
  166.                         _nop_();
  167.                         _nop_();
  168.                         _nop_();
  169.                         SCL = 0;
  170.                 }
  171.         _nop_();
  172.         _nop_();
  173.         SDA = 1;                                                //釋放數據線,準備接受應答位
  174.         _nop_();
  175.         _nop_();
  176.         SCL = 1;
  177.         _nop_();
  178.         _nop_();
  179.         _nop_();
  180.         if(SDA == 1) bAck =0;
  181.         else bAck = 1;                                                //判斷是否收到應答信號
  182.         SCL = 0;
  183.         _nop_();
  184.         _nop_();
  185. }
  186. //接收一個字節的數據
  187. unsigned char RevByte()
  188. {
  189.         unsigned char retc;
  190.         unsigned char BitCnt;
  191.         retc = 0;
  192.         SDA = 1;
  193.         for(BitCnt=0;BitCnt<8;BitCnt++)
  194.         {
  195.                 _nop_();
  196.                 SCL = 0;                                            //置時鐘線為低,準備接收
  197.                 _nop_();
  198.                 _nop_();
  199.                 _nop_();
  200.                 _nop_();
  201.                 _nop_();
  202.                 SCL = 1;                                            //置時鐘線為高使得數據有效
  203.                 _nop_();
  204.                 _nop_();
  205.                 retc = retc << 1;                                    //左移補零
  206.                 if (SDA == 1)
  207.                 retc = retc + 1;                                     //當數據為1則收到的數據+1
  208.                 _nop_();
  209.                 _nop_();
  210.         }
  211.         SCL = 0;
  212.         _nop_();
  213.         _nop_();
  214.         return(retc);                                   //返回收到的數據
  215. }

  216. //WChipAdd:寫器件地址;RChipAdd:讀器件地址;InterAdd:內部地址;如寫正確則返回數據,
  217. //否則返回對應錯誤步驟序號
  218. //向指定器件的內部指定地址發送一個指定字節
  219. unsigned char WIICByte(unsigned char WChipAdd,unsigned char InterAdd,unsigned char WIICData)
  220. {
  221.         StartI2C();                                                                                      //啟動總線
  222.         SendByte(WChipAdd);                                                        //發送器件地址以及命令
  223.         if (bAck==1)                                                                                          //收到應答
  224.         {
  225.                 SendByte(InterAdd);                                                                //發送內部子地址
  226.                 if (bAck ==1)
  227.                 {
  228.                         SendByte(WIICData);                                                        //發送數據
  229.                         if(bAck == 1)
  230.                         {
  231.                                 StopI2C();                    //停止總線
  232.                                 return(0xff);
  233.                         }
  234.                         else
  235.                         {
  236.                                 return(0x03);
  237.                         }                       
  238.                 }
  239.                 else
  240.                 {
  241.                         return(0x02);
  242.                 }
  243.         }
  244.         return(0x01);
  245. }
  246. //讀取指定器件的內部指定地址一個字節數據
  247. unsigned char RIICByte(unsigned char WChipAdd,unsigned char RChipAdd,unsigned char InterDataAdd)
  248. {
  249.         unsigned char TempData;      
  250.         TempData = 0;
  251.         StartI2C();                                                                        //啟動
  252.         SendByte(WChipAdd);                                                    //發送器件地址以及讀命令
  253.         if (bAck==1)                                                                            //收到應答
  254.         {
  255.                 SendByte(InterDataAdd);                                        //發送內部子地址
  256.                 if (bAck ==1)
  257.                 {
  258.                         StartI2C();
  259.                         SendByte(RChipAdd);      
  260.                         if(bAck == 1)
  261.                         {
  262.                                 TempData = RevByte();       //接收數據
  263.                                 StopI2C();                  //停止I2C總線
  264.                                 return(TempData);           //返回數據
  265.                         }
  266.                         else
  267.                         {
  268.                                 return(0x03);
  269.                         }      
  270.                 }
  271.                 else
  272.                 {
  273.                         return(0x02);
  274.                 }
  275.         }
  276.         else
  277.         {
  278.                 return(0x01);
  279.         }
  280. }


  281. void main(void)
  282. {
  283.   unsigned int OverCounter = 0;
  284.   unsigned char ptemp;
  285.   bit OverFlg = 0;
  286.   unsigned int temp,ppress = 0;
  287.   float  press;      
  288.   while(1)
  289.   {         
  290.                      
  291.           getdata=Adc0832(0);
  292.           if(14<getdata<243)                                       //當壓力值介于15kpa到115kpa之間時,遵循線性變換
  293.                  {                           
  294.                   int vary=getdata;                                                //y=(115-15)/(243-13)*X+15kpa                       
  295.                         press=((10.0/23.0)*vary)+9.3;                        //測試時補償值為9.3                                                                                                         
  296.                         temp=(int)(press*10);                  //放大10倍,便于后面的計算
  297.       if(temp != ppress)
  298.       {
  299.         ppress = temp;
  300.         OverFlg = 1;
  301.       }                                                                                          
  302.                         dispbuf[3]=temp/1000;                                     //取壓力值百位
  303.                         dispbuf[2]=(temp%1000)/100;                            //取壓力值十位
  304.                         dispbuf[1]=((temp%1000)%100)/10;                    //取壓力值個位
  305.                         dispbuf[0]=((temp%1000)%100)%10;                        //取壓力值十分位
  306.                         display();
  307.       if (temp > 100)
  308.       {
  309.           if(OverFlg == 1)    //如果是新的一輛車通過
  310.           {
  311.             OverCounter++;
  312.             WIICByte(W24C04ADD,0x01,(OverCounter/0xff));    //低位
  313.             WIICByte(W24C04ADD,0x02,(OverCounter%0xff));    //高位
  314. //            ptemp = printf("%f\n",OverCounter);
  315.             OverFlg = 0;    //清除標志
  316.           }
  317.       }

  318.            }            
  319.   }
  320. }

復制代碼
本人初學,僅供參考,存在錯誤和不足之處,請大家回帖多多指教,切勿照搬,文件下載:
Keil代碼與Proteus8.8仿真下載: 仿真代碼.7z (45.49 KB, 下載次數: 37)

評分

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

查看全部評分

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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲成人精品免费 | 国产精品a免费一区久久电影 | 日韩成人免费视频 | 色啪网 | 波多野结衣av中文字幕 | 国产精品大全 | 日本三级线观看 视频 | 国产精品一级在线观看 | 久久婷婷色| 国产精品永久免费观看 | 久草热8精品视频在线观看 午夜伦4480yy私人影院 | 久草青青 | 日韩欧美1区2区 | 完全免费在线视频 | 欧美一级淫片007 | 久久久精彩视频 | 伊人久操| 操视频网站 | 涩涩99| 欧美多人在线 | 美女日批免费视频 | 欧美精品成人一区二区三区四区 | 台湾av在线 | 欧美一区免费在线观看 | 大学生a级毛片免费视频 | 中文字幕在线二区 | 美女黄频| 亚洲精品一区二区网址 | 精品国产乱码久久久久久a丨 | 久久综合久色欧美综合狠狠 | 国产精品一区二区三区久久久 | 婷婷在线视频 | 一区二区视频在线 | 日韩三级| 成人免费淫片aa视频免费 | 国产精品久久一区二区三区 | 成人av一区二区亚洲精 | 91av在线免费播放 | 亚洲乱码一区二区三区在线观看 | 精品久久久久久久久久久 | 在线视频 亚洲 |