找回密码
 立即注册

QQ登录

只需一步,快速开始

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

波形发生器(4种)Proteus仿真程序

[复制链接]
跳转到指定楼层
楼主
具备如下功能:要求能够能够输出方波、锯齿波、三角波、正弦波;能够通过按键选择输出波形。
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. #include<reg51.h>

  2. sbit wr=P3^6;
  3. sbit rd=P3^2;

  4. sbit key0=P1^0;
  5. sbit key1=P1^1;
  6. sbit key2=P1^2;
  7. sbit key3=P1^3;

  8. unsigned char flag;//flag为0、1、2、3、4时分别为正弦波、方波、三角波、梯形波、锯齿波

  9. unsigned char const code ZXB_code[256]={
  10. 0x80,0x83,0x86,0x89,0x8c,0x8f,0x92,0x95,0x98,0x9c,0x9f,0xa2,
  11. 0xa5,0xa8,0xab,0xae,0xb0,0xb3,0xb6,0xb9,0xbc,0xbf,0xc1,0xc4,
  12. 0xc7,0xc9,0xcc,0xce,0xd1,0xd3,0xd5,0xd8,0xda,0xdc,0xde,0xe0,
  13. 0xe2,0xe4,0xe6,0xe8,0xea,0xec,0xed,0xef,0xf0,0xf2,0xf3,0xf4,
  14. 0xf6,0xf7,0xf8,0xf9,0xfa,0xfb,0xfc,0xfc,0xfd,0xfe,0xfe,0xff,
  15. 0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xfe,
  16. 0xfd,0xfc,0xfc,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,0xf3,0xf2,
  17. 0xf0,0xef,0xed,0xec,0xea,0xe8,0xe6,0xe4,0xe3,0xe1,0xde,0xdc,
  18. 0xda,0xd8,0xd6,0xd3,0xd1,0xce,0xcc,0xc9,0xc7,0xc4,0xc1,0xbf,
  19. 0xbc,0xb9,0xb6,0xb4,0xb1,0xae,0xab,0xa8,0xa5,0xa2,0x9f,0x9c,
  20. 0x99,0x96,0x92,0x8f,0x8c,0x89,0x86,0x83,0x80,0x7d,0x79,0x76,
  21. 0x73,0x70,0x6d,0x6a,0x67,0x64,0x61,0x5e,0x5b,0x58,0x55,0x52,
  22. 0x4f,0x4c,0x49,0x46,0x43,0x41,0x3e,0x3b,0x39,0x36,0x33,0x31,
  23. 0x2e,0x2c,0x2a,0x27,0x25,0x23,0x21,0x1f,0x1d,0x1b,0x19,0x17,
  24. 0x15,0x14,0x12,0x10,0xf,0xd,0xc,0xb,0x9,0x8,0x7,0x6,0x5,0x4,
  25. 0x3,0x3,0x2,0x1,0x1,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,
  26. 0x0,0x1,0x1,0x2,0x3,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xa,0xc,0xd,
  27. 0xe,0x10,0x12,0x13,0x15,0x17,0x18,0x1a,0x1c,0x1e,0x20,0x23,
  28. 0x25,0x27,0x29,0x2c,0x2e,0x30,0x33,0x35,0x38,0x3b,0x3d,0x40,
  29. 0x43,0x46,0x48,0x4b,0x4e,0x51,0x54,0x57,0x5a,0x5d,0x60,0x63,
  30. 0x66,0x69,0x6c,0x6f,0x73,0x76,0x79,0x7c
  31. };        //用于生成正弦


  32. unsigned char keyscan()          //键盘扫描函数
  33. {
  34.   unsigned char keyscan_num,temp;

  35.   P1=0xff;
  36.   temp=P1;
  37.   if(~(temp&0xff))
  38.   {
  39.     if(key0==0)
  40.         {
  41.           keyscan_num=1;
  42.         }
  43.         else if(key1==0)
  44.         {
  45.           keyscan_num=2;
  46.         }
  47.         else if(key2==0)
  48.         {
  49.           keyscan_num=3;
  50.         }
  51.         else if(key3==0)
  52.         {
  53.           keyscan_num=4;
  54.         }
  55.         else
  56.         {
  57.           keyscan_num=0;
  58.         }

  59.         return keyscan_num;
  60.   }
  61. }

  62. void init_DA0832()//DA芯片准备函数
  63. {
  64.   rd=0;
  65.   wr=0;
  66. }

  67. void ZXB()//正弦波函数
  68. {
  69.   unsigned int i;
  70.   
  71.   do{
  72.     P2=ZXB_code[i];
  73.         i=i+1;
  74.         }while(i<256);
  75. }

  76. void FB()//方波
  77. {
  78.   EA=1;
  79.   ET0=1;
  80.   TMOD=1;
  81.   TR0=1;
  82.   TH0=0xff;
  83.   TL0=0x83;
  84. }

  85. void SJB()//三角波
  86. {
  87.   P2=0x00;
  88.   do{
  89.     P2=P2+1;
  90.   }while(P2<0xff);
  91.   P2=0xff;
  92.   do{
  93.     P2=P2-1;
  94.   }while(P2>0x00);
  95.   P2=0x00;
  96. }

  97. void JCB()//锯齿波
  98. {
  99.   P2=0x00;
  100.   do{
  101.     P2=P2+1;
  102.   }while(P2<=0xff);
  103. }

  104. void main()
  105. {
  106.   init_DA0832();
  107.   do
  108.     {
  109.       flag=keyscan();
  110.     }while(!flag);//等待按键按下
  111.   while(1)
  112.   {
  113.     switch(flag)
  114.     {
  115.       case 1:
  116.             do{
  117.               flag=keyscan();
  118.               ZXB();
  119.              }while(flag==1);
  120.             break;
  121.           case 2:
  122.             FB();
  123.             do{
  124.               flag=keyscan();
  125.                   }while(flag==2);
  126.                   TR0=0;
  127.             break;
  128.           case 3:
  129.             do{
  130.               flag=keyscan();
  131.               SJB();
  132.                   }while(flag==3);
  133.             break;
  134.           case 4:
  135.             do{
  136.               flag=keyscan();
  137.               JCB();
  138.                   }while(flag==4);
  139.             break;
  140.           default:
  141.             flag=keyscan();
  142.             break;
  143.     }        
  144.   }
  145. }

  146. void timer0(void) interrupt 1
  147. {
  148.   P2=~P2;
  149.   TH0=0xff;
  150.   TL0=0x83;
  151.   TR0=1;
  152. }
复制代码

所有资料51hei提供下载:
波形发生OK.zip (68.4 KB, 下载次数: 79)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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