0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于单片机的简易波形发生器设计

CHANBAEK 来源: 小小硬件工程师 作者: 小小硬件工程师 2023-11-09 09:55 次阅读

一、硬件电路

电路如下,左上角是一个LCD显示器,下面就是我们常用的单片机系统电路,当然这里的电路并非完全,现实中还要给单片机接上电源,但是仿真中完全不需要担心哦!右上角就是波形发生电路,采用了DAC0832,下面就是个示波器,方便我们观察仿真结果。

图片

二、软件程序

程序的话功能还算全面,但是如果要满足你们的课设需求的话,还需要很多修改,需要的小伙伴不妨简单修改下,然后再进行仿真验证哦!还是非常方便的。

C程序:

#include < reg51.h >
#include< string.h >
#define uchar unsigned char
#define uint unsigned int
sbit RS=P3^0;
sbit RW=P3^1;
sbit EN=P3^3;
sbit K1=P2^0;
sbit K2=P2^1;
sbit K3=P2^2;
sbit K4=P2^3;
sbit K5=P2^4;
uchar WaveChoice=1;
uchar ys=30;
uchar i,a=0;
uchar sqar_num=128;
uint freq;
uchar code Sin[]={"Sine      "};
uchar code Squ[]={"Square    "} ;
uchar code Tri[]={"Triangle  "};
uchar code Saw[]={"Sawtooth  "} ;
uchar code No[]={"No Signal out "};
uchar code Wave[]={"Wave :"}; 
uchar code Fre[]={"Freq :"};
uchar code tosin[256]=
{0x80,0x83,0x86,0x89,0x8d,0x90,0x93,0x96,0x99,0x9c,0x9f,0xa2,0xa5,0xa8,0xab,
0xae,0xb1,0xb4,0xb7,0xba,0xbc,0xbf,0xc2,0xc5,0xc7,0xca,0xcc,0xcf,0xd1,0xd4,0xd6,0xd8,
0xda,0xdd,0xdf,0xe1,0xe3,0xe5,0xe7,0xe9,0xea,0xec,0xee,0xef,0xf1,0xf2,0xf4,
0xf5,0xf6,0xf7,0xf8,0xf9,0xfa,0xfb,0xfc,0xfd,0xfd,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,
0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xfd,0xfd,0xfc,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,
0xf4,0xf2,0xf1,0xef,0xee,0xec,0xea,0xe9,0xe7,0xe5,0xe3,0xe1,0xde,0xdd,0xda,0xd8,
0xd6,0xd4,0xd1,0xcf,0xcc,0xca,0xc7,0xc5,0xc2,0xbf,0xbc,0xba,0xb7,0xb4,0xb1,0xae,0xab,
0xa8,0xa5,0xa2,0x9f,0x9c,0x99,0x96,0x93,0x90,0x8d,0x89,0x86,0x83,0x80,
0x80,0x7c,0x79,0x76,0x72,0x6f,0x6c,0x69,0x66,0x63,0x60,0x5d,0x5a,0x57,0x55,
0x51,0x4e,0x4c,0x48,0x45,0x43,0x40,0x3d,0x3a,0x38,0x35,0x33,0x30,0x2e,0x2b,
0x29,0x27,0x25,0x22,0x20,0x1e,0x1c,0x1a,0x18,0x16,0x15,0x13,0x11,0x10,0x0e,
0x0d,0x0b,0x0a,0x09,0x08,0x07,0x06,0x05,0x04,0x03,0x02,0x02,0x01,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x02 ,0x02,0x03,0x04,
0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,0x0d,0x0e,0x10,0x11,0x13,0x15,0x16,0x18,
0x1a,0x1c,0x1e,0x20,0x22,0x25,0x27,0x29,0x2b,0x2e,0x30,0x33,0x35,0x38,0x3a,
0x3d,0x40,0x43,0x45,0x48,0x4c,0x4e ,0x51,0x55,0x57,0x5a,0x5d,0x60,0x63,0x66 ,
0x69,0x6c,0x6f,0x72,0x76,0x79,0x7c,0x80 }; 
void DelayMS(uchar ms)
{
  uchar i;
  while(ms--) for(i=0;i< 120;i++);
}
 void Delay1(uint y)
 {
   uint i;
  for(i=y;i >0;i--);
 }
uchar Busy_Check()
{
  uchar LCD_Status;
  RS=0;  //  寄存器选择
  RW=1; //读状态寄存器
  EN=1;  // 开始读
  DelayMS(1);
  LCD_Status=P1;
  EN=0;
  return  LCD_Status;


}
void Write_LCD_Command(uchar cmd)
{
     while((Busy_Check()&0x80)==0x80);   //忙等待
     RS=0;  //选择命令寄存器
     RW=0;  //写
     EN=0;
     P1=cmd;EN=1;DelayMS(1);EN=0;
}
void Write_LCD_Data(uchar dat)
{
   while((Busy_Check()&0x80)==0x80);   //忙等待  
    RS=1;  RW=0; EN=0; P1=dat;EN=1;DelayMS(1);EN=0;  
}
void Init_LCD()
{    
  Write_LCD_Command(0x38);
  DelayMS(1);
  Write_LCD_Command(0x01); //清屏
  DelayMS(1);
  Write_LCD_Command(0x06); //字符进入模式:屏幕不动,字符后移
  DelayMS(1);
  Write_LCD_Command(0x0C); //显示开、关光标
  DelayMS(1);
}
void Write_freq(uint k)
{
  uchar qian,bai,shi,ge;
  qian=k/1000;
  bai=k/100%10;
  shi=k/10%10;
  ge=k%10;
  Write_LCD_Command(0x86+0x40);
  Write_LCD_Data(0x30+qian);
  Write_LCD_Data(0x30+bai);
  Write_LCD_Data(0x30+shi);
  Write_LCD_Data(0x30+ge);
  Write_LCD_Data(0x48);
  Write_LCD_Data(0x5a);
}
  void Xianshi_f()       
{
  if(WaveChoice==1)
  {
     freq=(10000000/(50000+2860*ys));
   Write_freq(freq);
  }
  if(WaveChoice==2)
  {
     freq=(10000000/(50000+2300*ys));
   Write_freq(freq);
  }
   if(WaveChoice==3)
  {
     freq=(10000000/(14000+2300*ys));
   Write_freq(freq);
  }
    if(WaveChoice==4)
  {
     freq=(10000000/(15000+2300*ys));
   Write_freq(freq);
  }
}
void Write_wave(uchar  t )
{
  switch(t)
  {
    case 0:
         Write_LCD_Command(0x86);
           DelayMS(5);
            for (i=0;i< sizeof(No)-1;i++)
          {
            Write_LCD_Data(No[i]);
            DelayMS(5);
          }
          break;
    case 1:
        ys=25;
        Write_LCD_Command(0x86);
           DelayMS(5);
            for (i=0;i< sizeof(Sin)-1;i++)
          {
            Write_LCD_Data(Sin[i]);
            DelayMS(5);
          }
        break;
    case 2:
        ys=30;
        Write_LCD_Command(0x86);
           DelayMS(5);
            for (i=0;i< sizeof(Squ)-1;i++)
          {
            Write_LCD_Data(Squ[i]);
            DelayMS(5);
           }

        break;
    case 3:
        ys=30;
        Write_LCD_Command(0x86);
           DelayMS(5);
            for (i=0;i< sizeof(Tri)-1;i++)
          {
            Write_LCD_Data(Tri[i]);
            DelayMS(5);
          }
        break;
    case 4:
        ys=30;
           Write_LCD_Command(0x86);//液晶显示位置
           DelayMS(5);
            for (i=0;i< sizeof(Saw)-1;i++)
          {
            Write_LCD_Data(Saw[i]);
            DelayMS(5);
           }
        break;
  }
}
void Out_Wave(uchar i)
{   uchar j;  
  switch(i)
  {
    case 0:  P0=0x00;break;
    case 1:
        for (j=0;j< 255;j++)
        {
          P0=tosin[j];
          Delay1(ys);
        } 
         break;
    case 2:
            {
          if(a< sqar_num)
            {
              P0=0xff;
              Delay1(ys);
            }
          else  
            {
              P0=0x00;
              Delay1(ys);
            }
            a++;
        }  break;
    case 3:
        {
          if(a< 128)
            {
              P0=a;
              Delay1(ys);
            }
          else  
            {
              P0=255-a;
              Delay1(ys);
            }
            a++;
        }   break;
    case 4:
        {
           if(a< 255)
          {
            P0=a;
            Delay1(ys);
          }

        a++;
      if(a==255)
        {
          a=0;
        }   break;
    }
  }
}
void keyscanf()
{  
  if(K2==0)
  {
    DelayMS(5);
    if(K2==0)
    {
      while(!K2);
      ys--;
      if(ys==0)
      ys=20;
    }
  }
  if(K3==0)
  {
    DelayMS(5);
    if(K3==0)
    {
      while(!K3);
      ys++;
      if(ys >22)
      ys=20;
    }
  }
  if(K4==0)
  {
    DelayMS(5);
    if(K4==0)
    {
      while(!K4);
      if(WaveChoice==2)
      sqar_num=sqar_num+2;
      if(sqar_num==238)
        sqar_num=128;
    }
  }
  if(K5==0)
  {
    DelayMS(5);
    if(K5==0)
    {
      while(!K5);
      if(WaveChoice==2)
      sqar_num=sqar_num-2;
      if(sqar_num==18)
        sqar_num=128;      
    }
  }
} 
void main()
{
  Init_LCD();
  IE=0X81;
  IT0=1;
  Write_LCD_Command(0x80);//--显示wave:
     DelayMS(5);     
   for (i=0;i< sizeof(Wave)-1;i++)
    {
      Write_LCD_Data(Wave[i]);
      DelayMS(5);
    }
      Write_LCD_Command(0x80+0X40);//----显示freq:
     DelayMS(5);
    for (i=0;i< sizeof(Fre)-1;i++)
    {
      Write_LCD_Data(Fre[i]);
      DelayMS(5);
    }
     Write_wave(WaveChoice);
  while (1)
  {
       keyscanf();
    Out_Wave(WaveChoice);
    if(!(K1&K2&K3))
        Xianshi_f();
  }    
}
void EX_INT0() interrupt 0
{
    WaveChoice++;
    if(WaveChoice==5) WaveChoice=1;
    Write_wave(WaveChoice);
}

三、仿真展示

程序很简单,小伙伴们可以根据需要自己修改程序,然后进行验证哦!

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6001

    文章

    43978

    浏览量

    620874
  • 显示器
    +关注

    关注

    21

    文章

    4738

    浏览量

    137880
  • lcd
    lcd
    +关注

    关注

    34

    文章

    4278

    浏览量

    164137
  • 波形发生器
    +关注

    关注

    3

    文章

    284

    浏览量

    31188
收藏 人收藏

    评论

    相关推荐

    关于基于51单片机波形发生器的设计

    最近遇上这样一个问题,关于基于单片机波形发生器,都有哪些方法?希望得到前辈的指点,谢谢
    发表于 01-11 23:29

    基于单片机波形发生器设计

    基于单片机波形发生器设计
    发表于 01-22 10:59

    单片机波形发生器

    有没有单片机AT89S51波形发生器的程序和仿真电路图,波形发生器要求产生方波、三角波、正弦波以及梯形波
    发表于 06-25 18:51

    如何实现基于51单片机波形发生器的设计?

    如何实现基于51单片机波形发生器的设计?
    发表于 10-26 07:00

    如何去制作一个基于单片机简易波形发生器

    简易波形发生器 (限MSP430、STM32单片机)任务要求:制作一个简易波形
    发表于 11-29 06:40

    基于单片机波形发生器设计

    基于单片机波形发生器设计大家参考一下吧。
    发表于 05-13 15:35 39次下载

    简易波形发生器

    简易波形发生器,能自制低频信号发生器产生(V) Hz的脉冲波、锯齿波、正弦波I,输出电压幅度峰峰值为1V;正弦波II输出电压幅度峰峰值为9V。
    发表于 06-03 15:23 9次下载

    基于单片机波形发生器

    基于单片机波形发生器
    发表于 12-11 22:52 21次下载

    简易波形发生器

    简易波形发生器
    发表于 01-05 14:34 28次下载

    基于单片机简易波形发生器(采用ICL8038函数发生器)

    发表于 01-08 16:07 165次下载

    使用C51单片机和Proteus仿真设计简易波形发生器的应用实例资料说明

    本文档的主要内容详细介绍的是使用C51单片机和Proteus仿真设计简易波形发生器的应用实例资料说明。
    发表于 05-20 08:00 18次下载
    使用C51<b class='flag-5'>单片机</b>和Proteus仿真设计<b class='flag-5'>简易</b><b class='flag-5'>波形</b><b class='flag-5'>发生器</b>的应用实例资料说明

    使用单片机制作的简易波形发生器的C语言程序和工程文件免费下载

    本文档的主要内容详细介绍的是使用单片机制作的简易波形发生器的C语言程序和工程文件免费下载。
    发表于 06-05 08:00 17次下载
    使用<b class='flag-5'>单片机</b>制作的<b class='flag-5'>简易</b><b class='flag-5'>波形</b><b class='flag-5'>发生器</b>的C语言程序和工程文件免费下载

    MSP430F149 单片机 波形发生器 示波器

    简易波形发生器 (限MSP430、STM32单片机)任务要求:制作一个简易波形
    发表于 11-19 17:21 15次下载
    MSP430F149 <b class='flag-5'>单片机</b> <b class='flag-5'>波形</b><b class='flag-5'>发生器</b> 示波器

    基于单片机四种波形发生器仿真设计-毕设课设

    基于单片机四种波形发生器仿真设计-毕设课设
    发表于 11-22 18:51 45次下载
    基于<b class='flag-5'>单片机</b>四种<b class='flag-5'>波形</b><b class='flag-5'>发生器</b>仿真设计-毕设课设

    基于单片机智能波形发生器设计

    基于单片机智能波形发生器设计
    发表于 11-23 18:21 11次下载
    基于<b class='flag-5'>单片机</b>智能<b class='flag-5'>波形</b><b class='flag-5'>发生器</b>设计