标题: 51单片机Proteus ADC0804仿真实验 源程序 [打印本页]

作者: changfeng1_best    时间: 2021-11-20 10:04
标题: 51单片机Proteus ADC0804仿真实验 源程序
采用ADC0804进行ADC转换,数码管进行显示,并与万用表数值进行准确度的对比,程序在附件中

调节滑动变阻,万用表和数码管显示相同电压

注意滑动电阻的精度,精度太低,数码管第四位一直为0

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. #include <reg52.h>
  2. #include <intrins.h>
  3. sbit adcs = P2^4;
  4. sbit adrd = P2^5;
  5. sbit adwr = P2^6;
  6. sbit intr = P2^7;
  7. sbit CLK = P3^3;
  8. double num_int;
  9. unsigned num_out;
  10. unsigned char  text[] = {0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};
  11. unsigned char  text_1[] = {0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10};
  12. void display();

  13. void delay( )               
  14. {
  15.         unsigned char q, j;

  16.         _nop_();
  17.         _nop_();
  18.         for(q=16;q>0;q--)
  19.         {
  20.                         for(j=6;j>0;j--);
  21.         }
  22. }
  23. ///////////定时器/////////////////////
  24. void TimeInitial()
  25. {
  26.          TMOD=0x10;        
  27.          TH1=(65536-200)/256;
  28.          TL1=(65536-200)%256;
  29.          EA=1;
  30.          ET1=1;
  31.          TR1=1;
  32. }
  33. void Timer1(void) interrupt 3 using 0
  34. {
  35.   TH1=(65536-200)/256;
  36.   TL1=(65536-200)%256;
  37.   CLK=~CLK;
  38. }
  39. //////////////////////////////////////


  40. //////////////数码管显示///////////////
  41. void Display(unsigned char value,unsigned char pos) //段选,位选函数
  42. {
  43.         P2=0x01<<pos;
  44.         P0=value;
  45. }

  46. void display()                                     //数码管显示函数
  47. {
  48.        
  49.                 Display((text[num_out/1000])&0x7f,0);  //1234  +小数点
  50. //                Display((text_1[num_out/1000]),0);
  51.                 delay();               
  52.                 Display(text[num_out%1000/100],1);
  53.                 delay();               
  54.                 Display(text[num_out%100/10],2);
  55.                 delay();               
  56.                 Display(text[num_out%10],3);
  57.                 delay();
  58. }
  59. ////////////////////////////////////////////


  60. ////////////////////////主函数//////////////
  61. void main()
  62. {        
  63.          unsigned char x = 0;   
  64.          TimeInitial();
  65.          while(1)
  66.          {
  67.                                 adcs = 0;   
  68.                                 adwr = 0;   
  69.                                 _nop_();   
  70.                                 adwr = 1;   
  71.                                
  72.                                 while(intr);
  73.                                 P1 = 0xff;
  74.                                 adcs = 0;
  75.                                 adrd = 0;   
  76.                                 _nop_();
  77.                                 x = P1;      
  78.                                 adrd = 1;                       
  79.                  
  80.                                 num_int = x * (1.0/255)*5000;  
  81.                                 num_out=(int)num_int;
  82.                                 display();               
  83.                 }       
  84. }
复制代码

所有资料51hei附件下载:
实验7.zip (94.58 KB, 下载次数: 35)





欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1