找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4477|回复: 2
打印 上一主题 下一主题
收起左侧

ADC0804 protues信号发生器的仿真电路图及相关单片机程序

[复制链接]
跳转到指定楼层
楼主
ADC0804信号发生器的仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1.   #include <reg51.h>
  2. #define uchar unsigned char
  3. #define uint  unsigned int         
  4. sbit SQU_K  =P3^4;
  5. sbit SAW_K  =P3^5;
  6. sbit TRI_K  =P3^6;
  7. sbit SIN_K  =P3^7;
  8. sbit SQU_L  =P1^0;
  9. sbit SAW_L  =P1^1;
  10. sbit TRI_L  =P1^2;
  11. sbit SIN_L  =P1^3;
  12. sbit INTad=P3^3;   
  13. sbit CS=P3^0;         //使能端
  14. sbit W_R=P3^2;        //写端口
  15. sbit R_D=P3^1;        //读端口
  16. uchar code sin_tab[]={0,0,0,0,1,1,2,3,4,5,6,8,
  17.                                                 9,11,13,15,17,19,22,24,
  18.                                                 27,30,33,36,39,42,46,49,
  19.                                                 53,56,60,64,68,72,76,80,
  20.                                                 84,88,92,97,101,105,110,114,
  21.                                                 119,123,128,132,136,141,145,150,
  22.                                             154,158,163,167,171,175,179,183,
  23.                                                 187,191,195,199,202,206,209,213,
  24.                                                 216,219,222,225,228,231,233,236,
  25.                                                 238,240,242,244,246,247,249,250,
  26.                                                 251,252,253,254,254,255,255,255 };
  27. //*************************************************
  28. // 读ADC0804子程序
  29. //*************************************************
  30. unsigned char adc0804( void )      
  31. {    uchar dat,i;  
  32.      R_D=1;
  33.      W_R=1;
  34.      INTad=1;          //读ADC0804 前准备
  35.      P2=0xff;          //P2全部置一准备
  36.      CS=0;
  37.      W_R=0;
  38.      W_R=1;            //启动ADC0804开始测电压
  39.      while(INT1==1);   //查询等待A/D转换完毕产生的INT信号
  40.      R_D=0;            //开始读转换后数据
  41.      i=i;              //无意义语句,用于延时等待ADC0804 读数完毕
  42.      dat=P2;           //读出的数据赋与addate
  43.      R_D=1;
  44.              CS=1;             //读数完毕
  45.      return(dat);      //返回最后读出的数据
  46. }
  47. //*************************************************
  48. //方波发生函数
  49. //*************************************************
  50. void square()
  51. {
  52.   uchar a,b;
  53.   for(a=0;a<127;a++)
  54.   {
  55.     P0=0xff;
  56. P2=0xff;
  57.     b=adc0804();
  58. b=~b;
  59.         while(b--);       //调节相位,b的变化越大,相位变化越小
  60.   }
  61.   for(a=0;a<127;a++)
  62.   {
  63.     P0=0;
  64. P2=0xff;
  65.     b=adc0804();
  66. b=~b;
  67.         while(b--);
  68.   }
  69. }
  70. //*************************************************
  71. //锯齿波发生函数
  72. //*************************************************
  73. void sawtooth()
  74. {
  75.    uchar a,b;
  76.   for(a=0;a<255;a++)
  77.   {
  78.     P0=a;
  79.         P2=0xff;
  80.     b=adc0804();
  81.         b=~b;
  82.     while(b--);
  83.   }
  84. }
  85. //*************************************************
  86. // 三角波发生函数
  87. //*************************************************
  88. void triang()
  89. {
  90.    uchar a,b;
  91.   for(a=0;a<254;a=a+2)
  92.   {
  93.     P0=a;
  94.         P2=0xff;
  95.     b=adc0804();
  96.         b=~b;
  97.     while(b--);
  98.   }
  99.   for(a;a>1;a=a-2)
  100.   {
  101.     P0=a;
  102.         P2=0xff;
  103.     b=adc0804();
  104.         b=~b;
  105.     while(b--);
  106.   }
  107. }
  108. //*************************************************
  109. //正弦波发生函数
  110. //*************************************************
  111. void  sinwave()
  112. {
  113.   uchar a,b;
  114.   for(a=0;a<92;a++)
  115.   {
  116.      P0=sin_tab[a];
  117.             P2=0xff;
  118.     b=adc0804();
  119.         b=~b;
  120.         while(b--);
  121.   }
  122.   for(a=a-1;a>0;a--)
  123.   {
  124.     P0=sin_tab[a];
  125.         P2=0xff;
  126.     b=adc0804();
  127.         b=~b;
  128.         while(b--);
  129.   }
  130. }
  131. //*************************************************
  132. //主函数
  133. //*************************************************
  134. void main()
  135. {
  136.   P1=0xff;
  137.   P2=0xff;
  138.   P3=0xff;
  139.   while(1)
  140.   {
  141.     P0=0;
  142.            if(SQU_K==0)
  143.            {
  144.             SQU_L=0;
  145.             square();
  146.         }
  147.         SQU_L=1;
  148.         if(SAW_K==0)
  149. ……………………

  150. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
6.1.rar (89.09 KB, 下载次数: 33)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:246228 发表于 2018-1-18 22:15 | 只看该作者
51黑有你更精彩!!!
回复

使用道具 举报

板凳
ID:779798 发表于 2020-6-17 17:07 | 只看该作者
请问一下蓝色的粗线在Protues中怎么画出来?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表