找回密码
 立即注册

QQ登录

只需一步,快速开始

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

基于DAC0832的函数信号发生器仿真 程序及pcb与原理图

  [复制链接]
跳转到指定楼层
楼主
采用STC89C52单片机设计的基于DAC0832的函数信号发生器,可输出5种波形,三角函数,方波,锯齿波,三角波,梯形波。用4个按键分别实现频率加、频率减、波形切换和清屏功能。
附程序,仿真和AD原理图

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载):


Altium Designer画的原理图和PCB图如下:(51hei附件中可下载工程文件)


单片机源程序如下:
  1. #include<reg52.h>                                           //包含头文件
  2. #include<intrins.h>
  3. #include<absacc.h>
  4. #define uchar unsigned char                           //宏定义
  5. #define uint unsigned int
  6.                                                                           
  7. sbit lcdrs=P3^0;                                           //液晶控制位
  8. sbit lcden=P3^1;


  9. sbit csda=P3^3;                                                   //DA控制位
  10. sbit wr=P3^4;

  11. char num,boxing,u;                                           //定义全局变量
  12. uint pinlv;
  13. uchar code table[]="0123456789";                //定义显示的数组
  14. uchar code table1[]="frequence:boxing:";
  15. uchar code sin[64]={
  16. 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,
  17. 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
  18. };                                          //正弦波取码
  19. uchar code juxing[64]={
  20. 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,
  21. 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
  22. };                                          //矩形波取码
  23. uchar code juchi[64]={
  24. 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,
  25. 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
  26. };                                          //锯齿波取码
  27. uchar code tixing[64]={
  28. 0,13,26,39,52,65,78,91,104,117,130,143,156,169,182,195,208,221,234,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,
  29. 247,247,247,247,247,247,247,242,229,216,203,190,177,164,151,138,125,112,99,86,73,60,47,34,21,8
  30. };                                           //梯形波取码
  31. uchar code sanjiao[64]={
  32. 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,
  33. 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
  34. };                                                //三角波取码


  35. void delay(uint xms)         //延时函数
  36. {
  37.         int a,b;
  38.         for(a=xms;a>0;a--)
  39.                 for(b=110;b>0;b--);
  40. }
  41. void write_com(uchar com)                //写命令函数
  42. {
  43.         lcdrs=0;
  44.         P0=com;       
  45.         delay(1);
  46.         lcden=1;
  47.         delay(1);                                                                           
  48.         lcden=0;
  49. }

  50. void write_date(uchar date)                //写数据函数
  51. {
  52.         lcdrs=1;
  53.         P0=date;
  54.         delay(1);
  55.         lcden=1;
  56.         delay(1);
  57.         lcden=0;
  58. }

  59. void init_lcd()                                        //初始化函数
  60. {                                                                  
  61.         lcden=0;                                        //默认开始状态为关使能端,见时序图  
  62.         write_com(0x0f);
  63.         write_com(0x38);                        //显示模式设置,默认为0x38,不用变。
  64.         write_com(0x01);                        //显示清屏,将上次的内容清除,默认为0x01.
  65.         write_com(0x0c);                        //显示功能设置0x0f为开显示,显示光标,光标闪烁;0x0c为开显示,不显光标,光标不闪
  66.         write_com(0x06);                        //设置光标状态默认0x06,为读一个字符光标加1.
  67.         write_com(0x80);                        //设置初始化数据指针,是在读指令的操作里进行的
  68. }
  69. void initclock()                           //时钟初始化
  70. {
  71.         uint i;
  72.         TMOD=0x01;
  73.         TH0=(65536-1563)/256;
  74.         TL0=(65536-1563)%256;
  75.         EA=1;
  76.         ET0=1;
  77.         TR0=1;
  78.         for(i=10;i<17;i++)                           //显示初始化
  79.         {
  80.                 write_date(table1[i]);
  81.                 delay(5);
  82.         }
  83.         write_com(0x80+0x40);
  84.         for(i=0;i<10;i++)
  85.         {
  86.                 write_date(table1[i]);
  87.                 delay(5);
  88.         }
  89.         write_com(0x80+7);
  90.                 write_date('s');
  91.                 write_date('i');
  92.                 write_date('n');
  93.                 write_date(' ');
  94.                 write_date(' ');
  95.                 write_date(' ');
  96.                 write_date(' ');
  97.                 write_com(0x80+0x40+0xa);
  98.                 write_date(' ');
  99.                 write_date('1');
  100.                 write_date('0');
  101.                 write_date('H');
  102.                 delay(5);
  103.                 write_date('Z');
  104.                 delay(5);
  105. }
  106. void display()                                   //显示函数
  107. {
  108.         uchar bai,shi,ge;
  109.         if(num<10)
  110.         {
  111.                 pinlv=num*10+10;
  112.         }
  113.         if(num>9)
  114.         {
  115.                 pinlv=(num-9)*50+100;
  116.         }
  117.         bai=pinlv/100;
  118.         shi=pinlv%100/10;
  119.         ge=pinlv%100%10;
  120.         write_com(0x80+0x40+0xa);
  121.         if(bai<1)
  122.         {
  123.                   write_date(' ');
  124.                 delay(5);
  125.         }
  126.         if(bai!=0)
  127.         {
  128.                  write_date(table[bai]);
  129.                 delay(5);
  130.         }
  131.        
  132.         write_date(table[shi]);
  133.         delay(5);
  134.         write_date(table[ge]);
  135.         delay(5);
  136.         write_date('H');
  137.         delay(5);
  138.         write_date('Z');
  139.         delay(5);
  140.         if(boxing==0)
  141.         {
  142.                 write_com(0x80+7);
  143.                 write_date('s');
  144.                 write_date('i');
  145.                 write_date('n');
  146.                 write_date(' ');
  147.                 write_date(' ');
  148.                 write_date(' ');
  149.                 write_date(' ');
  150.         }
  151.         if(boxing==1)
  152.         {
  153.                 write_com(0x80+7);
  154.                 write_date('j');
  155.                 write_date('u');
  156.                 write_date('x');
  157.                 write_date('i');
  158.                 write_date('n');
  159.                 write_date('g');
  160.         }
  161.         if(boxing==2)
  162.         {
  163.                 write_com(0x80+7);
  164.                 write_date('j');
  165.                 write_date('u');
  166.                 write_date('c');
  167.                 write_date('h');
  168.                 write_date('i');
  169.                 write_date(' ');
  170.                
  171.         }
  172.         if(boxing==3)
  173.         {
  174.                 write_com(0x80+7);
  175.                 write_date('t');
  176.                 write_date('i');
  177.                 write_date('x');
  178.                 write_date('i');
  179.                 write_date('n');
  180.                 write_date('g');
  181.         }
  182.         if(boxing==4)
  183.         {
  184.                 write_com(0x80+7);
  185.                 write_date('s');
  186.                 write_date('a');
  187.                 write_date('n');
  188.                 write_date('j');
  189.                 write_date('i');
  190.                 write_date('a');
  191.                 write_date('o');
  192.         }

  193. }



  194. //kbscan(void)按键扫描程序
  195. uchar keyscan()                //键盘扫描
  196. {
  197.         uchar h,l,value;
  198.         P1=0xf0;                  //列置0
  199.         h=P1&0Xf0;                 //判断哪一行按下
  200.         if(h!=0xf0)                  //判断是否按下
  201.         {
  202.                 delay(10);   //消抖
  203.                 if(h!=0xf0)
  204.                 {
  205.                        
  206.                         l=P1|0x0f;         //把列置1
  207.                         P1=l;                 //把列状态给P1口
  208.                         l=P1&0x0f;         //判断那一列按下
  209.                         h=P1&0Xf0;         //判断哪一行按下
  210.                         value=h+l;         //组合起来到底是那个按键按下
  211.                 }
  212.                 return value;
  213.         }
  214. }
  215. void keypros()                //按键处理
  216. {
  217.         uchar key=0;
  218.         key=keyscan();
  219.         if(key==0xee)
  220.         {   
  221.             EA=0;
  222.                 delay(200);
  223.               num++;
  224.                 if(num==12)
  225.                 {
  226.                     num=0;
  227.             }
  228.                         display();
  229.                         EA=1;
  230.                 if(num>9)
  231.                 {
  232.                     EA=0;
  233.                 }
  234.          }
  235.         else if(key==0xde)
  236.     {
  237.             EA=0;
  238.                 delay(200);
  239.                 num--;
  240.                 if(num<0)
  241.                 {
  242.                     num=0;
  243.                 }
  244.                 display();       
  245.                 EA=1;
  246.                 if(num>9)
  247.                 {
  248.                 EA=0;
  249.                 }         
  250.         }
  251.     else if(key==0xbe)
  252.   {
  253.                 EA=0;
  254.                 delay(200);
  255.             boxing++;
  256.                 if(boxing==5)
  257.                 {
  258.                     boxing=0;
  259.                 }
  260.                     display();
  261.                         EA=1;
  262.    }
  263.    else if(key==0x7e)
  264.    {
  265.    EA=0;
  266.    write_com(0x01);
  267.    
  268.    }
  269. }          

  270. void delaym()                                //短暂延时
  271. {
  272.         _nop_();_nop_(); _nop_(); _nop_();_nop_();_nop_();       
  273. }
  274. void main()                                         //主函数
  275. {       
  276.         init_lcd();
  277.        
  278. ……………………

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

所有资料51hei提供下载:
函数信号发生器.zip (1.41 MB, 下载次数: 531)


评分

参与人数 3黑币 +60 收起 理由
diudiubiu + 5 真的很需要了!
yuyu628 + 5 回帖助人的奖励!
admin + 50 共享资料的黑币奖励!

查看全部评分

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

使用道具 举报

沙发
ID:1 发表于 2017-7-22 17:50 | 只看该作者
楼主的Proteus仿真工程是Proteus8.8版本的
回复

使用道具 举报

板凳
ID:302175 发表于 2018-4-5 10:22 | 只看该作者
非常棒,正是我需要的,可是币不够,无法下载。
回复

使用道具 举报

地板
ID:247623 发表于 2018-5-8 17:19 | 只看该作者
为什么我解压失败?

1.jpg (113.56 KB, 下载次数: 64)

1.jpg
回复

使用道具 举报

5#
ID:1 发表于 2018-5-8 18:21 | 只看该作者
yilinghai 发表于 2018-5-8 17:19
为什么我解压失败?

我刚测试了一下 没有问题啊 可以成功解压
回复

使用道具 举报

6#
ID:247623 发表于 2018-5-15 14:17 | 只看该作者
换了个解压软件好了,不过仿真文件(.DSN)好像没有,楼主可以加上去吗

搜狗截图20180515141451.jpg (52.9 KB, 下载次数: 77)

搜狗截图20180515141451.jpg
回复

使用道具 举报

7#
ID:335213 发表于 2018-6-4 17:04 | 只看该作者
仿真是8.8版本,你用的7.8版本 当然不行啊 用错版本了
回复

使用道具 举报

8#
ID:358134 发表于 2018-6-25 09:17 | 只看该作者
可以,很好的东西 刚好急需
回复

使用道具 举报

9#
ID:277959 发表于 2018-6-25 14:07 | 只看该作者
好资料,51黑有你更精彩!!!
回复

使用道具 举报

10#
ID:264973 发表于 2018-6-25 20:10 | 只看该作者

好资料,51黑有你更精彩!!!
回复

使用道具 举报

11#
ID:266734 发表于 2018-7-4 13:22 | 只看该作者
确实没有DSN文件
回复

使用道具 举报

12#
ID:364937 发表于 2018-7-4 16:19 | 只看该作者
感谢楼主分享,学习了
回复

使用道具 举报

13#
ID:463090 发表于 2019-1-6 16:22 | 只看该作者
好资料,51黑有你更精彩!!!
回复

使用道具 举报

14#
ID:452539 发表于 2019-1-9 19:49 | 只看该作者
好资料,51有你更精彩!!O(∩_∩)O谢谢
回复

使用道具 举报

15#
ID:537018 发表于 2019-5-13 16:00 | 只看该作者
yilinghai 发表于 2018-5-8 17:19
为什么我解压失败?

第一,原本需要解压的压缩包已经损坏,或者因为什么原因被格式化,所以解压失败
第二,解压的时候有密码设定,密码输入错误所以解压失败
第三,解压文件的格式和解压方式或者命令不匹配,也会造成解压失败
可以先直接双击源文件,进去后直接解压相关的文件夹,看看文件是否都被损坏;如果是第二种情况,那需要得到密码;第三种情况一般出现在终端,每种格式的命令可以参考解压命令大全
回复

使用道具 举报

16#
ID:537018 发表于 2019-5-15 17:12 | 只看该作者
刚好需要
回复

使用道具 举报

17#
ID:607321 发表于 2019-9-7 12:53 | 只看该作者
厉害了楼主
回复

使用道具 举报

18#
ID:79874 发表于 2019-9-26 15:41 | 只看该作者
楼主波型是怎样取的码
回复

使用道具 举报

19#
ID:79874 发表于 2019-9-26 15:42 | 只看该作者
波形是怎样取的码
回复

使用道具 举报

20#
ID:134271 发表于 2019-11-3 17:55 | 只看该作者
没看到有DAC0832的操作函数呢。
回复

使用道具 举报

21#
ID:357402 发表于 2019-11-29 08:19 | 只看该作者

好资料,51黑有你更精彩!!!
回复

使用道具 举报

22#
ID:670766 发表于 2020-1-12 10:49 | 只看该作者
文件很好,只是仿真文件看不了,少了DSN文件,楼主能否补下?
回复

使用道具 举报

23#
ID:499661 发表于 2020-4-25 17:18 | 只看该作者
资料不错,学习一下
回复

使用道具 举报

24#
ID:756748 发表于 2020-5-20 17:54 | 只看该作者
很强,刚好非常需要,谢谢楼主
回复

使用道具 举报

25#
ID:714216 发表于 2020-6-7 18:26 | 只看该作者
很强,刚好非常需要,谢谢楼主
回复

使用道具 举报

26#
ID:380985 发表于 2021-5-13 01:44 | 只看该作者
工程文件好评
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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