找回密码
 立即注册

QQ登录

只需一步,快速开始

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

信号发生器proteus仿真 带单片机源程序

[复制链接]
跳转到指定楼层
楼主

上面是proteus做的信号发生器的仿真,用到51单片机和DAC0832,工程文件请下载附件

下面是部分源程序(完整代码和仿真工程文件请下载本帖最后的附件)
  1. #include <reg52.h>
  2. #include <absacc.h>

  3. #define uchar unsigned char
  4. #define DA0832 XBYTE[0xffff]

  5. uchar code tab[13]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39};
  6. uchar code num [93]={0,0,1,0,3,0,0,2,9,0,2,8,0,2,7,0,2,6,
  7. 0,2,5,0,2,4,0,2,3,0,2,2,0,2,1,0,2,0,0,1,9,0,1,8,0,1,7,0,1,6,0,1,5,0,1,4,0,1,3,
  8. 0,1,2,0,1,1,0,1,0,0,0,9,0,0,8,0,0,7,0,0,6,0,0,5,0,0,4,0,0,3,0,0,2,0,0,1};
  9. uchar code tosin[256]={0x7F,0x82,0x85,0x88,0x8B,0x8F,0x92,0x95,0x98,0x9B,0x9E,0xA1,0xA4,0xA7,0xAA,0xAD
  10. ,0xB0,0xB3,0xB6,0xB8,0xBB,0xBE,0xC1,0xC3,0xC6,0xC8,0xCB,0xCD,0xD0,0xD2,0xD5,0xD7
  11. ,0xD9,0xDB,0xDD,0xE0,0xE2,0xE4,0xE5,0xE7,0xE9,0xEB,0xEC,0xEE,0xEF,0xF1,0xF2,0xF4
  12. ,0xF5,0xF6,0xF7,0xF8,0xF9,0xFA,0xFB,0xFB,0xFC,0xFD,0xFD,0xFE,0xFE,0xFE,0xFE,0xFE
  13. ,0xFE,0xFE,0xFE,0xFE,0xFE,0xFE,0xFD,0xFD,0xFC,0xFB,0xFB,0xFA,0xF9,0xF8,0xF7,0xF6
  14. ,0xF5,0xF4,0xF2,0xF1,0xEF,0xEE,0xEC,0xEB,0xE9,0xE7,0xE5,0xE4,0xE2,0xE0,0xDD,0xDB
  15. ,0xD9,0xD7,0xD5,0xD2,0xD0,0xCD,0xCB,0xC8,0xC6,0xC3,0xC1,0xBE,0xBB,0xB8,0xB6,0xB3
  16. ,0xB0,0xAD,0xAA,0xA7,0xA4,0xA1,0x9E,0x9B,0x98,0x95,0x92,0x8F,0x8B,0x88,0x85,0x82
  17. ,0x7F,0x7C,0x79,0x76,0x73,0x6F,0x6C,0x69,0x66,0x63,0x60,0x5D,0x5A,0x57,0x54,0x51
  18. ,0x4E,0x4B,0x48,0x46,0x43,0x40,0x3D,0x3B,0x38,0x36,0x33,0x31,0x2E,0x2C,0x29,0x27
  19. ,0x25,0x23,0x21,0x1E,0x1C,0x1A,0x19,0x17,0x15,0x13,0x12,0x10,0x0F,0x0D,0x0C,0x0A
  20. ,0x09,0x08,0x07,0x06,0x05,0x04,0x03,0x03,0x02,0x01,0x01,0x00,0x00,0x00,0x00,0x00
  21. ,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x01,0x02,0x03,0x03,0x04,0x05,0x06,0x07,0x08
  22. ,0x09,0x0A,0x0C,0x0D,0x0F,0x10,0x12,0x13,0x15,0x17,0x19,0x1A,0x1C,0x1E,0x21,0x23
  23. ,0x25,0x27,0x29,0x2C,0x2E,0x31,0x33,0x36,0x38,0x3B,0x3D,0x40,0x43,0x46,0x48,0x4B
  24. ,0x4E,0x51,0x54,0x57,0x5A,0x5D,0x60,0x63,0x66,0x69,0x6C,0x6F,0x73,0x76,0x79,0x7C};

  25. uchar fun=1,b=0,c=0,d=0,e=0,tl,th,flag=0;

  26. sbit  P3_0=P3^0;
  27. sbit  P3_1=P3^1;
  28. sbit  P3_2=P3^2;
  29. sbit  P2_7=P2^7;

  30. uchar de1,de2;
  31. uchar A=3;

  32. void key1(void);
  33. void key2(void);
  34. void key3(void);

  35. void delay(uchar k);

  36. void main(void)
  37. {
  38. TMOD=0X01;
  39. th=0xff;
  40. tl=0x1e;
  41. TH0=th;
  42. TL0=tl;
  43. ET0=1;
  44. EA=1;
  45. EX1=1;
  46. PX1=1;
  47. IT1=1;
  48. TR0=1;
  49. while(1)
  50. {  
  51. P3_0=0; P3_1=1;  P3_2=0;
  52. if(num[flag*3]!=0)
  53. {
  54. P1=tab[num[flag*3]];
  55. delay(0.01);
  56. }
  57. else{
  58. P1=0;
  59. P3_0=1;
  60. P3_1=0;  
  61. P3_2=0;
  62. P1=tab[num[flag*3+1]];
  63. delay(0.01);
  64. P1=0;
  65. P3_0=0; P3_1=0;  P3_2=0;
  66. P1=tab[num[flag*3+2]];
  67. delay(0.01);
  68. P1=0;
  69. P3_0=1; P3_1=1;  P3_2=0;
  70. P1=tab[fun+9];
  71. delay(0.01);
  72. P1=0;
  73.   }
  74.   }
  75. }

  76. void  delay(uchar k)   //延时程序
  77. {
  78. for(de1=0;de1<10;de1++)
  79.      for(de2=0;de2<k;de2++){;}
  80. }

  81. void key1(void)             //1键选择发波类型,1为正弦波,2为三角波,3为方波
  82. {
  83. fun++;
  84. if(fun==4)
  85.         fun=0x01;         
  86. }

  87. void key2(void)            //2键加大频率
  88. {
  89.         tl+=0x00;
  90.         if(tl>0x1e)
  91.         tl=0x01;
  92.         if(flag>0)
  93.         flag--;
  94.         else               
  95.         flag=30;
  96. }

  97. void key3(void)           //3键减小频率
  98. {
  99.         if(th>0x00)
  100.         {        
  101.                 th-=0x1;        
  102.                 if(flag<30)        
  103.                 flag++;        
  104.                 else         
  105.                 flag=0;        
  106.         }
  107. }



  108. void time0_int(void) interrupt 1   //中断服务程序
  109. {
  110.        TR0=0;
  111.        if(fun==1)
  112.        {
  113.                DA0832=tosin[b]/4*A;              //正弦波
  114.                    delay(flag) ;
  115.                  
  116.                b++;
  117.        }
  118.        else if(fun==2)                   //三角波
  119.        {
  120.                if(c<128)
  121.                    {
  122.                    DA0832=c*2/4*A;
  123.                    delay(flag);
  124.                }
  125.                    else
  126.                    {
  127.                    DA0832=(255-c)*2/4*A;
  128.                    delay(flag);
  129.               
  130.                    }
  131.                    c++;
  132.        }

  133.        else if(fun==3)                   // 方波
  134.        {
  135.                d++;
  136.                if(d<=128)
  137.                    {
  138.                    DA0832=0x00;
  139.                        delay(flag);
  140.                    }
  141.                    else
  142.                    {
  143.                     DA0832=0xff/4*A;
  144.                           delay(flag);
  145.                    }
  146.            }
  147.                 TH0=th;
  148.                 TL0=tl;
  149.                 TR0=1;
  150. }

  151. void  int1 (void) interrupt 2       //int1中断服务程序

  152. {
  153.    if(P2!=0xff)
  154.          delay(flag);
  155.         if(P2==0xff)
  156.         return;
  157.    if(P2==0xef) key1();
  158.    if(P2==0xdf) key2();
  159.    if(P2==0xbf) key3();

  160. }
复制代码



所有资料下载: 信号发生器.rar (97.63 KB, 下载次数: 81)
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:311913 发表于 2018-4-19 19:25 | 只看该作者
正在做信号这方面的毕设,参考下
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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