找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4557|回复: 8
收起左侧

单片机控制的(方波 锯齿波 三角波)信号发生器仿真与源码

[复制链接]
ID:315529 发表于 2018-4-24 17:35 | 显示全部楼层 |阅读模式
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
33.png 22.png 11.png

单片机源程序如下:
  1. #include<reg51.h>
  2. #define uchar unsigned char
  3. #define uint unsigned int

  4. sbit csda=P2^2;
  5. sbit wr=P2^1;
  6. sbit s1=P3^2;
  7. sbit s2=P3^3;
  8. uchar k=0,p=0,delay=0;
  9. uchar bxxz=0;pinglv=0;
  10. uchar a=1,b=0,c=0,d=0;
  11. //正弦波数据
  12. uchar code sin[64]={
  13. 135,145,158,167,176,188,199,209,218,226,234,240,245,249,252,254,254,253,251,247,243,237,230,222,213,204,193,182,170,158,
  14. 146,133,121,108,96,84,72,61,50,41,32,24,17,11,7,3,1,0,0,2,5,9,14,20,28,36,45,55,66,78,90,102,114,128
  15. };
  16. //方波数据报表
  17. uchar code juxing[64]={
  18. 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
  19. 255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
  20. };

  21. //锯齿波数据
  22. uchar code juchi[64]={
  23. 0,4,8,12,16,20,24,28,32,36,40,45,49,53,57,61,65,69,73,77,81,85,89,93,97,101,105,109,113,117,121,125,130,134,138,142,
  24. 146,150,154,158,162,166,170,174,178,182,186,190,194,198,202,206,210,215,219,223,227,231,235,239,243,247,251,255
  25. };

  26. //三角波数据
  27. uchar code sanjiao[64]={
  28. 0,8,16,24,32,40,48,56,64,72,80,88,96,104,112,120,128,136,144,152,160,168,176,184,192,200,208,216,224,232,240,248,
  29. 248,240,232,224,216,208,200,192,184,176,168,160,152,144,136,128,120,112,104,96,88,80,72,64,56,48,40,32,24,16,8,0
  30. };
  31. void delay1()                  //延时
  32. {
  33.         int a,b;
  34.         for(a=1;a>0;a--)
  35.                 for(b=122;b>0;b--);
  36. }
  37. void int0() interrupt 0          //中断处理,用于波型切换
  38. {       
  39.         EX0=0;
  40.         delay1();
  41.         if(s1==0)
  42.         {               
  43.                 bxxz++;
  44.                 if(bxxz==4)
  45.                 bxxz=0;
  46.                 switch(bxxz)
  47.                 {
  48.                         case 0 :
  49.                                 {a=1,b=0,c=0,d=0;}                //        正弦波
  50.                                 break;
  51.                         case 1 :
  52.                                 {a=0,b=1,c=0,d=0;}                //方波
  53.                                 break;
  54.                         case 2 :                                       
  55.                                 {a=0,b=0,c=1,d=0;}                  // 锯齿波
  56.                                 break;       
  57.                         case 3 :
  58.                                 {a=0,b=0,c=0,d=1;}                  //        三角波
  59.                                 break;
  60.                 }
  61.                 delay1();
  62.                 while(!s1);       
  63.         }
  64.         while(!s1);
  65.         EX0=1;
  66. }
  67. void int1() interrupt 2
  68. {
  69.         EX1=0;       
  70.         delay1();
  71.         if(s2==0){               
  72.         p++;
  73.         if(p==8)
  74.         p=0;
  75.         switch(p)
  76.         {
  77.                 case 1 :
  78.                         pinglv=4;                //400Hz
  79.                         break;
  80.                 case 2 :
  81.                         pinglv=8;                //250Hz
  82.                         break;       
  83.                 case 3 :
  84.                         pinglv=16;          //140Hz
  85.                         break;
  86.                 case 4 :
  87.                         pinglv=32;         //75Hz
  88.                         break;
  89.                 case 5 :
  90.                         pinglv=64;         //40Hz
  91.                         break;
  92.                 case 6 :
  93.                         pinglv=125;                //20Hz
  94.                         break;
  95.                 case 7 :
  96.                         pinglv=255;                   //10Hz
  97.                         break;                               
  98.                 default :
  99.                         pinglv=0;                   //1000Hz
  100.                         break;
  101.                 }
  102.                 delay1();
  103.                 while(!s2);       
  104.         }
  105.         while(!s2);       
  106.         EX1=1;
  107. }

  108. void main()
  109. {
  110.         csda=0;
  111.         wr=0;
  112.         EA=1;
  113.         IT0=1;
  114.         EX0=1;
  115.         IT1=1;
  116.         EX1=1;
  117.         pinglv=15;
  118.         while(1)
  119.         {
  120.             
  121.                 while(a)               //产生正弦波
  122.                 {
  123.                         delay=pinglv; //获取周期数据
  124.                         P0=sin[k];          //数据数P0口进行波形转换
  125.                         k++;
  126.                         if(k==64)          //一个周期取64点波数据
  127.                         k=0;
  128.                         while(delay)  //延时处理         
  129.                     delay--;
  130.                 }
  131.                 while(b)                   //产生方波
  132.                 {
  133.                         delay=pinglv;
  134.                         P0=juxing[k];
  135.                         k++;
  136.                         if(k==64)
  137.                         k=0;
  138.                         while(delay)           
  139.                     delay--;
  140.                 }
  141.                 while(c)                   //产生锯齿波
  142.                 {
  143.                         delay=pinglv;
  144.                         P0=juchi[k];
  145.                         k++;
  146.                         if(k==64)
  147. ……………………

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

所有资料51hei提供下载:
资料.rar (67.64 KB, 下载次数: 116)
回复

使用道具 举报

ID:289396 发表于 2018-5-2 09:06 | 显示全部楼层
请问这个怎么设置成占空比可调的呀
回复

使用道具 举报

ID:335827 发表于 2018-5-23 12:58 | 显示全部楼层
我输出来只有正弦波,请问在哪可以调出来别的波
回复

使用道具 举报

ID:433370 发表于 2018-12-7 10:20 | 显示全部楼层
很好,我想问一下图开始运行动了一下怎么回事
回复

使用道具 举报

ID:433370 发表于 2018-12-7 10:35 | 显示全部楼层
w175628 发表于 2018-5-23 12:58
我输出来只有正弦波,请问在哪可以调出来别的波

有一个改变波形的按键,
回复

使用道具 举报

ID:424947 发表于 2018-12-8 16:27 | 显示全部楼层
非常实用,很赞
回复

使用道具 举报

ID:449435 发表于 2018-12-18 22:49 来自手机 | 显示全部楼层
楼主有汇编语言的程序吗
回复

使用道具 举报

ID:424947 发表于 2018-12-20 10:52 | 显示全部楼层
我想了解一下,只保留正弦波该怎样做啊
回复

使用道具 举报

ID:453293 发表于 2018-12-24 18:59 | 显示全部楼层
帮助很大
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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