找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 4367|回復(fù): 3
打印 上一主題 下一主題
收起左側(cè)

單片機(jī)數(shù)字電流電壓表程序Proteus仿真

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:848043 發(fā)表于 2020-11-24 20:50 | 只看該作者 |只看大圖 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機(jī)源程序如下:
  1. /******引腳說(shuō)明
  2. LCD液晶RS2.5  RW2.6    E2.7       DB0~DB7:P0.0~P0.7
  3. 電壓測(cè)量P1.1;需要0~30v需要加分流電阻,,分辨率0.03v;
  4. 電流側(cè)量P1.7;需要加放大電路如lm358;op07等,分辨率3ma
  5. **********/
  6. //stc12c5a60
  7. //時(shí)間20141107                           
  8. #include<STC12C5A60S2.h>
  9. #include<stdio.h>
  10. #include<intrins.h>//頭文件

  11. #define uchar unsigned char//宏定義
  12. #define uint unsigned int//宏定義
  13. #define ulint unsigned long int//宏定義
  14. #define N 21//ADC中值濾波次數(shù),必須為基數(shù)
  15. #define ISP_TRIG() ISP_TRIG=0x5A,ISP_TRIG=0xA5//ISP觸發(fā)命令

  16. sbit rs=P3^5;//液晶RS
  17. sbit rw=P3^6;//液晶RW
  18. sbit e=P3^4;//液晶E

  19. void AD_init(void);//ADC初始化
  20. void delay(uint z);//延時(shí)函數(shù)
  21. uint AD_get(uchar haha );//讀ADC的數(shù)值
  22. void LCD_data(uchar shuju);//寫(xiě)數(shù)據(jù)
  23. void zhiling(uchar zhilin);//寫(xiě)指令
  24. void LCD_init(void);//初始化LCD
  25. void tablex(uint tab);//數(shù)據(jù)分解
  26. uint filter(uchar dat);//中值濾波
  27. void timer_init(void);//定時(shí)器初始化

  28. uchar h1,h2,h3,h4;//LCD顯示變量
  29. ulint mas,maz;//容量計(jì)算

  30. uchar table[]="0123456789";//顯示數(shù)組
  31. uchar table1[]=".VAWa";

  32. void main()
  33. {
  34.         ulint tempv,tempa;//存放電壓電流值
  35.         AD_init();//ADC初始化
  36.         timer_init();//定時(shí)器初始化
  37.         LCD_init();//LCD初始化
  38.         while(1)
  39.         {
  40.                 tempv=filter(0x88);//設(shè)置ADC通道0、開(kāi)始轉(zhuǎn)換
  41.                 tablex(tempv*3);//分解數(shù)據(jù)
  42.                 zhiling(0x80);//LCD地址
  43.                 LCD_data(table[h1]);//
  44.                 LCD_data(table[h2]);//
  45.                 LCD_data(table1[0]);//
  46.                 LCD_data(table[h3]);//
  47.                 LCD_data(table[h4]);//
  48.                 LCD_data(table1[1]);//顯示
  49.                
  50.                 tempa=filter(0x8f);//設(shè)置ADC通道7、開(kāi)始轉(zhuǎn)換
  51.                 if(tempa<=10)//防止數(shù)據(jù)成負(fù)數(shù)
  52.                         tempa=10;
  53.                 mas=tempa*3-30;//計(jì)算容量取樣賦值
  54.                 tablex(tempa*3-30);//減去LM358失調(diào)的數(shù)值
  55.                 zhiling(0x88);//LCD地址
  56.                 LCD_data(table[h1]);
  57.                 LCD_data(table1[0]);
  58.                 LCD_data(table[h2]);
  59.                 LCD_data(table[h3]);
  60.                 LCD_data(table[h4]);
  61.                 LCD_data(table1[2]);
  62.                
  63.                 tablex((tempv*3/10)*((tempa*3-30)/10)/10);//計(jì)算功率
  64.                 zhiling(0x80+0x40);
  65.                 LCD_data(table[h1]);
  66.                 LCD_data(table[h2]);
  67.                 LCD_data(table1[0]);
  68.                 LCD_data(table[h3]);
  69.                 LCD_data(table[h4]);
  70.                 LCD_data(table1[3]);
  71.                
  72.                 tablex(maz/1000);//顯示MAH
  73.                 zhiling(0x88+0x40);
  74.                 LCD_data(table[h1]);
  75.                 LCD_data(table1[0]);
  76.                 LCD_data(table[h2]);
  77.                 LCD_data(table[h3]);
  78.                 LCD_data(table[h4]);
  79.                 LCD_data(table1[4]);
  80.                
  81.         }
  82. }
  83. //-------------------------------------------------------------
  84. void delay(uint z)///////////////延時(shí)程序
  85. {
  86.    uint x,y;
  87.    for(x=z;x>0;x--)
  88.    for(y=19;y>0;y--);
  89. }
  90. void AD_init(void)/////////////////////初始化ADC
  91. {
  92. P1ASF=0xff;//P1口全部作為模擬功能AD使用
  93. ADC_RES=0;//清零轉(zhuǎn)換結(jié)果寄存器高8位
  94. ADC_RESL=0;//清零轉(zhuǎn)換結(jié)果寄存器低2位
  95. ADC_CONTR=0x80;//開(kāi)啟AD電源
  96. delay(5);//等待1ms,讓AD電源穩(wěn)定
  97. }

  98. uint AD_get(uchar haha )//ADC讀數(shù)
  99. {
  100.         uint rew;
  101.         ADC_CONTR=haha;//開(kāi)啟AD轉(zhuǎn)換
  102.         _nop_(); _nop_(); _nop_(); _nop_();//要經(jīng)過(guò)4個(gè)CPU時(shí)鐘的延時(shí)
  103.         while(!(ADC_CONTR&0x10));//等待轉(zhuǎn)換完成
  104.         ADC_CONTR&=0xe7;//關(guān)閉AD轉(zhuǎn)換,ADC_FLAG位由軟件清0
  105.         rew=ADC_RES*4+ADC_RESL;//組合成10位
  106.         delay(1);//等待
  107.         return rew;//返回ADC值
  108. }
  109. void zhiling(uchar zhilin)//寫(xiě)指令
  110. {
  111.         e=0;
  112.         rs=0;
  113.         rw=0;
  114.         P0=zhilin;
  115.         delay(20);
  116.         e=1;
  117.         delay(20);
  118.         e=0;
  119. }
  120. void LCD_data(uchar shuju)//寫(xiě)數(shù)據(jù)
  121. {
  122.         e=0;
  123.         rs=1;
  124.         rw=0;
  125.         P0=shuju;
  126.         delay(20);
  127.         e=1;
  128.         delay(20);
  129.         e=0;
  130. }
  131. void LCD_init(void)//初始化LCD
  132. {
  133. delay(300);
  134. zhiling(0x38);
  135. delay(100);
  136. zhiling(0x38);
  137. delay(100);
  138. zhiling(0x38);
  139. delay(100);
  140. zhiling(0x38);
  141. zhiling(0x38);
  142. zhiling(0x08);
  143. zhiling(0x01);
  144. zhiling(0x06);
  145. zhiling(0x0c);
  146. }
  147. void tablex(uint tab1)//數(shù)據(jù)分解
  148. {
  149.         h1=tab1/1000;//1023//1
  150.         h2=tab1%1000/100;//023//0
  151.         h3=tab1%100/10;//23//2
  152.         h4=tab1%10;//3
  153. }
  154. uint filter(uchar dat)//中位值濾波
  155. {
  156.    uint value_buf[N];
  157.    uint count,i,j,temp;
  158.    for(count=0;count<N;count++)
  159.    {
  160.                          AD_init();//初始化ADC
  161.       value_buf[count] = AD_get(dat);//讀ADC數(shù)值
  162.       delay(1);
  163.    }
  164.    for (j=0;j<N-1;j++)
  165.    {
  166.       for (i=0;i<N-j;i++)
  167.       {
  168.          if ( value_buf[i]>value_buf[i+1] )
  169.          {
  170.             temp = value_buf[i];
  171.             value_buf[i] = value_buf[i+1];
  172.             value_buf[i+1] = temp;
  173.          }
  174.       }
  175.    }
  176.    return value_buf[(N-1)/2];
  177. }
  178. void timer_init(void)//定時(shí)器初始化
  179. {
  180.         TMOD=0x01;/////////設(shè)置工作方式1
  181.         TH0=(65536-50000)/256;///////賦值
  182.         TL0=(65536-50000)%256;
  183.         EA=1;ET0=1;//開(kāi)總中斷;開(kāi)定時(shí)器中斷
  184.         TR0=1;////////啟動(dòng)計(jì)數(shù)器
  185. }
  186. void timer0()interrupt 1  //定時(shí)中斷
  187. {
  188.         uchar t;
  189.         TR0=0;
  190.         TH0=(65536-50000)/256;///////賦初值
  191.         TL0=(65536-50000)%256;
  192.         t++;
  193.         if(t==20)
  194.         {
  195.                 t=0;
  196.                 maz+=(mas*1000)/3600;
  197.         }
  198.         TR0=1;
  199. }
復(fù)制代碼

全部資料51hei下載地址:
單片機(jī)數(shù)字電壓表.rar (20.96 KB, 下載次數(shù): 47)
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏5 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:1 發(fā)表于 2020-11-25 15:14 | 只看該作者
本帖需要重新編輯補(bǔ)全電路原理圖,源碼,詳細(xì)說(shuō)明與圖片即可獲得100+黑幣(帖子下方有編輯按鈕)
回復(fù)

使用道具 舉報(bào)

板凳
ID:852236 發(fā)表于 2020-12-2 22:15 | 只看該作者
等待樓主補(bǔ)了原理圖好好學(xué)習(xí)下
回復(fù)

使用道具 舉報(bào)

地板
ID:308393 發(fā)表于 2021-3-19 16:06 | 只看該作者
謝謝樓主,但是是分別用兩個(gè)單片機(jī)測(cè)嘛
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表