找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2587|回复: 2
收起左侧

单片机DAC0832示波器(程序仿真)运放滤波放大

[复制链接]
ID:605640 发表于 2020-12-2 13:27 | 显示全部楼层 |阅读模式
仿真图:
51hei.png
51hei.png
1763378e93d09013472c7cb0dac72cd2.png

系统功能设计框图
该系统采用单片机作为数据处理及控制核心,由单片机完成人机界面、系统控制、信号的采集分析以及信号的处理和变换,采用按键输入,利用虚拟示波器显示波形的方案。将设计任务分解为按键电路、输出转换电路等模块。图3-1为系统的总体框图。

图3-1 总体方框图

3、系统设计原理图
4.1 单片机最小系统的设计
AT89C51是片内有ROM/EPROM的单片机,因此,这种芯片构成的最小系统简单﹑可靠。用AT89C51单片机构成最小应用系统时,只要将单片机接上时钟电路和复位电路即可,如图89C51单片机最小系统所示。由于集成度的限制,最小应用系统只能用作一些小型的控制单元。其应用特点:
(1)有可供用户使用的大量I/O口线。
(2)内部存储器容量有限。
(3)应用系统开发具有特殊性。
标准的51为8K程序空间,128字节的RAM,32条端口,5个中断,2个定时/计数器,12个时钟周期执行一条基本指令,最长的除法为48个周期。
图4-1 AT89C51单片机最小系统
4.2运算放大器电路
本系统的放大电路如图4-2所示:
图4-2运算放大器电路
4.3 波形产生原理及模块设计
波形产生的原理:
1、内存中首先存储波形的数字量值数组TABLE;
2、51单片机读取数组中的值,送入D/A转换器;
3、D/A转换器将输入的数字值转换成模拟量输出;
4、D/A输出的模拟电流量通过运放转换成电压量输出。
由单片机采用编程方法产生四种波形、通过DA转换模块DAC0832在进过滤波放大之后输出。其电路图4-3如下:
      
      图4-3波形产生电路

4.4控制系统设计电路图
图4-4 系统设计电路图







4、程序设计流程图



图5-1 程序设计流程图








5、系统仿真
将keil5编译产生的hex文件加载到仿真软件的单片机里后,单击仿真界面左下方的开始按扭,仿真就开始了。具体仿真过程如下:
(1)f=50HZ正弦波的调试结果
图6-1 正弦波的调试结果
(2)f=50HZ方波的调试结果
图6-2 方波的调试结果
(3)f=50HZ三角波的调试结果
图6-3 三角波的调试结果

程序代码:
  1. #include <reg52.H>
  2. #include<absacc.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int
  5. #define dz XBYTE[0x7fff]//dac0832总线地址

  6. //1602LCD相关
  7. sbit RS = P3^0;   //定义端口
  8. sbit EN = P3^1;
  9. //按键定义
  10. sbit key1 = P3^2;
  11. sbit key2 = P3^3;
  12. sbit key3 = P3^4;
  13. sbit key4 = P3^5;
  14. uchar mode = 0;//输出波形的模式
  15. uchar LCDFlag;//LCD更新显示标志
  16. uchar LCDbuf[16];//LCD显示缓存
  17. uchar TIMER_H;//给计数器的值
  18. uchar TIMER_L;
  19. int Fre10X = 200;//当前频率的10的倍数     此时为20.0hz
  20. uchar CurStal = 1;//步进档位1=0.1x 10=1x 100=10x
  21. uchar code WaveInfo[3][15] = {"Sine Wave     ",//显示当前波形类型
  22.                                     "Triangle Wave ",
  23.                                     "Square Wave   "};
  24. uchar i = 0;
  25. //方波
  26. uchar code Squaretab[64] = {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,
  27. 255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,
  28. 255,255,255,255,255,255,255,255
  29. };
  30. //sin波
  31. uchar code Sinetab[256] = {
  32.                     0x80,0x83,0x86,0x89,0x8d,0x90,0x93,0x96,0x99,0x9c,0x9f,0xa2,
  33.                                         0xa5,0xa8,0xab,0xae,0xb1,0xb4,0xb7,0xba,0xbc,0xbf,0xc2,0xc5,
  34.                                         0xc7,0xca,0xcc,0xcf,0xd1,0xd4,0xd6,0xd8,0xda,0xdd,0xdf,0xe1,
  35.                                         0xe3,0xe5,0xe7,0xe9,0xea,0xec,0xee,0xef,0xf1,0xf2,0xf4,0xf5,
  36.                                         0xf6,0xf7,0xf8,0xf9,0xfa,0xfb,0xfc,0xfd,0xfd,0xfe,0xff,0xff,
  37.                                         0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xfd,
  38.                                         0xfd,0xfc,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,0xf4,0xf2,0xf1,
  39.                                         0xef,0xee,0xec,0xea,0xe9,0xe7,0xe5,0xe3,0xe1,0xde,0xdd,0xda,
  40.                                         0xd8,0xd6,0xd4,0xd1,0xcf,0xcc,0xca,0xc7,0xc5,0xc2,0xbf,0xbc,
  41.                                         0xba,0xb7,0xb4,0xb1,0xae,0xab,0xa8,0xa5,0xa2,0x9f,0x9c,0x99,
  42.                                         0x96,0x93,0x90,0x8d,0x89,0x86,0x83,0x80,0x80,0x7c,0x79,0x76,
  43.                                         0x72,0x6f,0x6c,0x69,0x66,0x63,0x60,0x5d,0x5a,0x57,0x55,0x51,
  44.                                         0x4e,0x4c,0x48,0x45,0x43,0x40,0x3d,0x3a,0x38,0x35,0x33,0x30,
  45.                                         0x2e,0x2b,0x29,0x27,0x25,0x22,0x20,0x1e,0x1c,0x1a,0x18,0x16,
  46.                                         0x15,0x13,0x11,0x10,0x0e,0x0d,0x0b,0x0a,0x09,0x08,0x07,0x06,
  47.                                         0x05,0x04,0x03,0x02,0x02,0x01,0x00,0x00,0x00,0x00,0x00,0x00,
  48.                                         0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x02,0x02,0x03,0x04,0x05,
  49.                                         0x06,0x07,0x08,0x09,0x0a,0x0b,0x0d,0x0e,0x10,0x11,0x13,0x15,
  50.                                         0x16,0x18,0x1a,0x1c,0x1e,0x20,0x22,0x25,0x27,0x29,0x2b,0x2e,
  51.                                         0x30,0x33,0x35,0x38,0x3a,0x3d,0x40,0x43,0x45,0x48,0x4c,0x4e,
  52.                                         0x51,0x55,0x57,0x5a,0x5d,0x60,0x63,0x66 ,0x69,0x6c,0x6f,0x72,
  53.                                         0x76,0x79,0x7c,0x80 };
  54. //三角
  55. uchar code Triangletab[64] = {
  56.   0,  8, 16, 24, 32, 40, 48, 56,
  57. 64, 72, 80, 88, 96,104,112,120,
  58. 128,136,144,152,160,168,176,184,
  59. 192,200,208,216,224,232,240,248,

  60. 248,240,232,224,216,208,200,192,
  61. 184,176,168,160,152,144,136,128,
  62. 120,112,104, 96, 88, 80, 72, 64,
  63. 56, 48, 40, 32, 24, 16, 8, 0};
  64. //锯齿
  65. uchar code juchi[64] = {
  66. 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,
  67. 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
  68. };        
  69. //uS延时函数
  70. void DelayUs2x(uchar t)
  71. {   
  72.     while(--t);
  73. }
  74. //mS延时函数
  75. void DelayMs(uint t)
  76. {

  77.     while(t--)
  78.     {
  79.         DelayUs2x(245);
  80.         DelayUs2x(245);
  81.     }
  82. }
  83. //              写入命令函数
  84. void LCD_Write_Com(uchar com)
  85. {  
  86.     RS = 0;  
  87.     EN = 1;
  88.     P1 = com;   //送入数据
  89.     DelayUs2x(200);
  90.     EN = 0;
  91.     DelayUs2x(500);  //延时等待LCD处理数据
  92. }
  93. //              写入数据函数
  94. void LCD_Write_Data(unsigned char Data)
  95. {
  96.     RS = 1;
  97.     EN = 1;
  98.     P1 = Data;  //送入数据
  99.     DelayUs2x(200);
  100.     EN = 0;   
  101.     DelayUs2x(500);   //延时等待LCD处理数据
  102. }
  103. //                清屏函数
  104. void LCD_Clear(void)
  105. {
  106.     LCD_Write_Com(0x01);
  107.     DelayMs(5);
  108. }
  109. //              写入字符串函数
  110. void LCD_Write_String(uchar x, uchar y, uchar *s)
  111. {     
  112.     if(y == 0)
  113.     {     
  114.         LCD_Write_Com(0x80 + x);     //表示第一行
  115.     }
  116.     else
  117.          {      
  118.         LCD_Write_Com(0xC0 + x);      //表示第二行
  119.          }        
  120.     while(*s)
  121.          {     
  122.         LCD_Write_Data(*s);     
  123.         s++;     
  124.          }
  125. }
  126. /**************************************************
  127.               初始化函数
  128. ***************************************************/
  129. void LCD_Init(void)
  130. {
  131.     LCD_Write_Com(0x38);    //显示模式设置
  132.     DelayMs(5);
  133.     LCD_Write_Com(0x38);
  134.     DelayMs(5);
  135.     LCD_Write_Com(0x38);  
  136.     LCD_Write_Com(0x08);    //显示关闭
  137.     LCD_Write_Com(0x01);    //显示清屏
  138.     LCD_Write_Com(0x06);    //显示光标移动设置
  139.     DelayMs(5);
  140.     LCD_Write_Com(0x0C);    //显示开及光标设置
  141. }
  142. /**************************************************
  143.    在LCD指定位置显示光标
  144. **************************************************/
  145. void LCD_Cursor_Dis(uchar x, uchar y)
  146. {
  147.     if(y == 0)              //LCD第一行
  148.     {
  149.         LCD_Write_Com(0x80 + x);
  150.     }
  151.     else                  //LCD第二行
  152.     {
  153.         LCD_Write_Com(0xC0 + x);
  154.     }
  155.     LCD_Write_Com(0x0F);  //光标显示开
  156.     DelayUs2x(4);         //延时越40us
  157. }
  158. /**************************************************
  159.    关闭光标
  160. **************************************************/
  161. void LCD_Close_Cursor()
  162. {
  163.     LCD_Write_Com(0x0C);  //光标显示关
  164.     DelayUs2x(4);         //延时越40us
  165. }

  166. void keyscanf()         //按键扫描
  167. {
  168.     uint temp;
  169.         if(key1 == 0)//模式选择
  170.         {
  171.                 mode++;
  172.         LCDFlag = 1;
  173.                 if(mode == 4)
  174.                         mode = 0;
  175.                 while(!key1);
  176.         }
  177.         if(key2 == 0)//增加
  178.         {
  179.                 if((Fre10X + CurStal) < 501)
  180.         {
  181.                         Fre10X = Fre10X + CurStal;
  182.             temp = (unsigned long)10000000 / 64 / Fre10X;
  183.             TIMER_H = (65535 - temp) / 256;
  184.             TIMER_L = (65535 - temp) % 256;
  185.         }
  186.         LCDFlag = 1;
  187.                 while(!key2);
  188.         }
  189.         if(key3 == 0)
  190.         {
  191.         if((Fre10X - (int)CurStal) > 1)
  192.         {
  193.                         Fre10X = Fre10X - CurStal;
  194.             temp = (unsigned long)10000000 / 64 / Fre10X;
  195.             TIMER_H = (65535 - temp) / 256;
  196.             TIMER_L = (65535 - temp) % 256;
  197.         }
  198.         LCDFlag = 1;
  199.                 while(!key3);
  200.         }
  201.         if(key4 == 0)
  202.         {
  203.             switch(CurStal)//调整步进档位
  204.         {
  205.                 case 1:        CurStal = 10;
  206.                                 break;
  207.                 case 10: CurStal = 100;
  208.                                 break;
  209.                         case 100: CurStal = 1;
  210.                                 break;
  211.         }
  212.         LCDFlag = 1;
  213.                 while(!key4);
  214.         }
  215. }

  216. void init_time()
  217. {
  218.         EA = 1; //开中断
  219.         ET0 = 1;
  220.         TMOD = 0X01; //初始化
  221.         TR0 = 1; //开定时器
  222. }
  223. void time0() interrupt 1 using 2
  224. {
  225.     TH0 = TIMER_H;
  226.     TL0 = TIMER_L;
  227.         switch(mode)
  228.         {
  229.         case 0://正弦显示
  230.                         dz = Sinetab[i];
  231.                         i = i + 4;
  232.                 break;
  233.         case 1://三角显示
  234.                         dz = Triangletab[i];
  235.                         i = (i + 1) % 64;
  236.                 break;
  237.         case 2://方波显示
  238.                         dz = Squaretab[i];
  239.                         i = (i + 1) % 64;
  240.                 break;
  241.                 case 3://锯齿波显示
  242.                         dz = juchi[i];
  243.                         i = (i + 1) % 64;
  244.                 break;
  245.         }
  246. }
  247. void main()
  248. {
  249.     uint temp;
  250.     init_time();  //定时器初始化调用
  251.     mode = 1;
  252.     temp = (unsigned long)10000000 / 64 / Fre10X;
  253.     TIMER_H = (65535 - temp) / 256;
  254.     TIMER_L = (65535 - temp) % 256;
  255.     LCD_Init();     //初始化液晶
  256.     LCDFlag = 1;     //将液晶需要刷新标志置1
  257.         while(1)
  258.         {
  259.         keyscanf();  //按键一直扫描
  260.         if(LCDFlag)
  261.         {
  262.             LCD_Write_String(0, 0, WaveInfo[mode]);//显示当期选择的波形
  263.             LCDbuf[0] = Fre10X / 100 + 0x30;    //显示当前的频率
  264.             LCDbuf[1] = Fre10X / 10 % 10 + 0x30;  //
  265.             LCDbuf[2] = '.';                //
  266.             LCDbuf[3] = Fre10X % 10 + 0x30;     //
  267.             LCDbuf[4] = 'H';                //
  268.             LCDbuf[5] = 'z';               //
  269.             LCDbuf[6] = 0;                 //
  270.             LCD_Write_String(0, 1, LCDbuf);//
  271.             switch(CurStal)//显示当前选择的步进档位
  272.             {
  273.                 case 1:  LCD_Write_String(8, 1, "+- 0.1Hz");
  274.                                         break;
  275.                 case 10: LCD_Write_String(8, 1, "+-   1Hz");
  276.                                         break;
  277.                 case 100:LCD_Write_String(8, 1, "+-  10Hz");
  278.                                         break;                    
  279.             }
  280.             LCDFlag = 0;
  281.         }
  282.         }
  283. }
复制代码
全部资料51hei下载地址:
简易信号发生器.zip (663.31 KB, 下载次数: 17)

评分

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

查看全部评分

回复

使用道具 举报

ID:584814 发表于 2020-12-4 12:17 | 显示全部楼层
这个不是示波器而是信号发生器,程序在本坛里有疑似抄都不会。
回复

使用道具 举报

ID:756378 发表于 2020-12-4 22:04 | 显示全部楼层
下载卡了一下分没了 资料下不了
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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