找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2461|回复: 0
收起左侧

51单片机低频信号发生器电路原理图程序电路图和Proteus仿真

[复制链接]
ID:954862 发表于 2021-10-31 00:35 | 显示全部楼层 |阅读模式
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
51hei.gif 7{{TH[32NC_GY]F}JW17`IW.png 51hei.png 64PDA@AV_OE258C{VEZYHX6.png

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


  4. sbit s1=P3^2;
  5. sbit s2=P3^3;
  6. uchar k=0,p=0,delay=0;
  7. uchar bxxz=0;pinglv=0;
  8. uchar a=1,b=0,c=0,d=0;

  9. //正弦波数据
  10. uchar code sin[64]={
  11. 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,
  12. 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
  13. };
  14. //方波数据报表
  15. uchar code juxing[64]={
  16. 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,
  17. 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
  18. };

  19. //锯齿波数据
  20. uchar code juchi[64]={
  21. 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,
  22. 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
  23. };

  24. //三角波数据
  25. uchar code sanjiao[64]={
  26. 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,
  27. 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
  28. };
  29. void delay1()                  //延时  ms级
  30. {
  31.         int a,b;
  32.         for(a=1;a>0;a--)
  33.                 for(b=122;b>0;b--);
  34. }
  35. void int0() interrupt 0          //外部中断0  P3.2  中断处理,用于波形切换
  36. {       
  37.         EX0=0;
  38.         delay1();

  39.         if(s1==0)
  40.         {               
  41.                 bxxz++;
  42.                 if(bxxz==4)
  43.                 bxxz=0;
  44.                 switch(bxxz)
  45.                 {
  46.                         case 0 :
  47.                                 {a=1,b=0,c=0,d=0;}                //正弦波
  48.                                 break;
  49.                         case 1 :
  50.                                 {a=0,b=1,c=0,d=0;}                //方波
  51.                                 break;
  52.                         case 2 :                                       
  53.                                 {a=0,b=0,c=1,d=0;}                  //锯齿波
  54.                                 break;       
  55.                         case 3 :
  56.                                 {a=0,b=0,c=0,d=1;}                  //三角波
  57.                                 break;
  58.                 }
  59.                 delay1();
  60.                 while(!s1);       
  61.         }

  62.         while(!s1);
  63.         EX0=1;          
  64. }

  65. void int1() interrupt 2                //外部中断1  P3.3  中断处理,用于频率调节
  66. {
  67.         EX1=0;       
  68.         delay1();
  69.         if(s2==0){               
  70.         p++;
  71.         if(p==8)
  72.         p=0;
  73.         switch(p)
  74.         {
  75.                 case 1 :
  76.                         pinglv=4;                //400Hz
  77.                         break;
  78.                 case 2 :
  79.                         pinglv=8;                //250Hz
  80.                         break;       
  81.                 case 3 :
  82.                         pinglv=16;          //140Hz
  83.                         break;
  84.                 case 4 :
  85.                         pinglv=32;         //75Hz
  86.                         break;
  87.                 case 5 :
  88.                         pinglv=64;         //40Hz
  89.                         break;
  90.                 case 6 :
  91.                         pinglv=125;                //20Hz
  92.                         break;
  93.                 case 7 :
  94.                         pinglv=255;                   //10Hz
  95.                         break;                               
  96.                 default :
  97.                         pinglv=0;                   //1000Hz
  98.                         break;
  99.                 }
  100.                 delay1();
  101.                 while(!s2);       
  102.         }
  103.         while(!s2);       
  104.         EX1=1;        //开中断
  105. }
  106. void main()
  107. {

  108.         EA=1;
  109.         IT0=1;
  110.         EX0=1;
  111.         IT1=1;
  112.         EX1=1;
  113.         pinglv=15;

  114.         while(1)
  115.         {
  116.             
  117.                 while(a)               //产生正弦波
  118.                 {
  119.                         delay=pinglv; //获取周期数据
  120.                         P2=sin[k];          //数据数P2口进行波形转换
  121.                         k++;
  122.                         if(k==64)          //一个周期取64点波数据
  123.                         k=0;

  124.                         while(delay)  //延时处理         
  125.                     delay--;
  126.                 }
  127.                 while(b)                   //产生方波
  128.                 {
  129.                         delay=pinglv;
  130.                         P2=juxing[k];
  131.                         k++;
  132.                         if(k==64)
  133.                         k=0;
  134.                         while(delay)           
  135.                     delay--;
  136.                 }
  137.                 while(c)                   //产生锯齿波
  138.                 {
  139.                         delay=pinglv;
  140.                         P2=juchi[k];
  141.                         k++;
  142.                         if(k==64)
  143.                         k=0;
  144.                         while(delay)            
  145.                             delay--;
  146.                 }
  147.                 while(d)                         //产生三角波     
  148.                 {
  149.                         delay=pinglv;
  150.                         P2=sanjiao[k];
  151.                         k++;
  152.                         if(k==64)
  153.                         k=0;
  154.                         while(delay)            
  155.                     delay--;
  156.                 }
  157.         }
  158. }
复制代码

所有资料51hei附件下载:
资料.7z (94.29 KB, 下载次数: 50)

评分

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

查看全部评分

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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