找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 19878|回复: 18
收起左侧

51单片机简易波形发生器(正弦波 锯齿波 三角波)仿真+源程序+电路原理图

  [复制链接]
ID:137190 发表于 2016-8-31 19:03 | 显示全部楼层 |阅读模式
0.png
51单片机简易波形发生器仿真电路原理图,正弦波 锯齿波 三角波分别用3个按键来控制(清晰版请下载本帖最后的附件)

下面是51单片机简易波形发生器源程序:
  1. #include <AT89X52.h>
  2. #include <math.h>

  3. #define ADDR1 0x2c //MAX5820LEUA

  4. sbit key_sin=P1^0;
  5. sbit key_tran=P1^2;
  6. sbit key_tooth=P1^4;

  7. sbit SCL = P2 ^ 0;
  8. sbit SDA = P2 ^ 1;

  9. unsigned char code sin[256]=     //正弦表
  10.         {
  11.         0x80,0x83,0x86,0x89,0x8d,0x90,0x93,0x96,0x99,0x9c,0x9f,0xa2,0xa5,0xa8,0xab,0xae,0xb1,0xb4,0xb7,0xba,0xbc,0xbf,0xc2,0xc5,
  12.         0xc7,0xca,0xcc,0xcf,0xd1,0xd4,0xd6,0xd8,0xda,0xdd,0xdf,0xe1,0xe3,0xe5,0xe7,0xe9,0xea,0xec,0xee,0xef,0xf1,0xf2,0xf4,0xf5,
  13.         0xf6,0xf7,0xf8,0xf9,0xfa,0xfb,0xfc,0xfd,0xfd,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xfd,
  14.         0xfd,0xfc,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,0xf4,0xf2,0xf1,0xef,0xee,0xec,0xea,0xe9,0xe7,0xe5,0xe3,0xe1,0xde,0xdd,0xda,
  15.         0xd8,0xd6,0xd4,0xd1,0xcf,0xcc,0xca,0xc7,0xc5,0xc2,0xbf,0xbc,0xba,0xb7,0xb4,0xb1,0xae,0xab,0xa8,0xa5,0xa2,0x9f,0x9c,0x99,
  16.         0x96,0x93,0x90,0x8d,0x89,0x86,0x83,0x80,0x80,0x7c,0x79,0x76,0x72,0x6f,0x6c,0x69,0x66,0x63,0x60,0x5d,0x5a,0x57,0x55,0x51,
  17.         0x4e,0x4c,0x48,0x45,0x43,0x40,0x3d,0x3a,0x38,0x35,0x33,0x30,0x2e,0x2b,0x29,0x27,0x25,0x22,0x20,0x1e,0x1c,0x1a,0x18,0x16,
  18.         0x15,0x13,0x11,0x10,0x0e,0x0d,0x0b,0x0a,0x09,0x08,0x07,0x06,0x05,0x04,0x03,0x02,0x02,0x01,0x00,0x00,0x00,0x00,0x00,0x00,
  19.         0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x02,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,0x0d,0x0e,0x10,0x11,0x13,0x15,
  20.         0x16,0x18,0x1a,0x1c,0x1e,0x20,0x22,0x25,0x27,0x29,0x2b,0x2e,0x30,0x33,0x35,0x38,0x3a,0x3d,0x40,0x43,0x45,0x48,0x4c,0x4e,
  21.         0x51,0x55,0x57,0x5a,0x5d,0x60,0x63,0x66,0x69,0x6c,0x6f,0x72,0x76,0x79,0x7c,0x80
  22.         };

  23. bit write_addr(unsigned char,bit);//第一个参数表示地址,第二个参数表示 读:1 写:0
  24. bit write_data(unsigned char);//第一个参数表示数据,第二个参数表示 命令字
  25. void stop();
  26. void Delay(unsigned int);

  27. I2C_Delay(unsigned int I2C_VALUE)
  28. {       
  29.         while ( --I2C_VALUE!= 0 );
  30. }
  31. /*
  32. 函数:I2C_Init()
  33. 功能:I2C 总线初始化,使总线处于空闲状态
  34. 说明:在 main()函数的开始处,通常应当要执行一次本函数
  35. */
  36. void I2C_Init()
  37. {
  38.         SCL = 1;
  39.         I2C_Delay(5);
  40.         SDA = 1;
  41.         I2C_Delay(5);
  42. }
  43. /*
  44. 函数:I2C_Start()
  45. 功能:产生I2C 总线的起始状态
  46. 说明:
  47. SCL处于高电平期间,当SDA 出现下降沿时启动I2C 总线
  48. 不论 SDA 和SCL 处于什么电平状态,本函数总能正确产生起始状态
  49. 本函数也可以用来产生重复起始状态
  50. 本函数执行后,I2C 总线处于忙状态
  51. */
  52. void I2C_Start()
  53. {
  54.         SDA = 1;
  55.         I2C_Delay(5);
  56.         SCL = 1;
  57.         I2C_Delay(5);
  58.         SDA = 0;
  59.         I2C_Delay(5);
  60.         SCL = 0;
  61.         I2C_Delay(5);

  62. }
  63. /*
  64. 函数:I2C_Write()
  65. 功能:向I2C 总线写1 个字节的数据
  66. 参数:
  67. dat:要写到总线上的数据
  68. */
  69. void I2C_Write(char dat)
  70. {
  71.         unsigned char t = 8;
  72.         do
  73.         {
  74.                 SDA = (bit)(dat & 0x80);
  75.                 dat <<= 1;
  76.                 SCL = 1;
  77.                 I2C_Delay(5);
  78.                 SCL = 0;
  79.                 I2C_Delay(5);
  80.         } while ( --t != 0 );
  81. }

  82. bit I2C_GetAck()
  83. {
  84.         bit ack;
  85.         SDA = 1;
  86.         I2C_Delay(5);
  87.         SCL = 1;
  88.         I2C_Delay(5);
  89.         ack = SDA;
  90.         SCL = 0;
  91.         I2C_Delay(5);
  92.         return ack;
  93. }

  94. void I2C_Stop()
  95. {
  96.         unsigned int t = 10;
  97.         SDA = 0;
  98.         I2C_Delay(5);
  99.         SCL = 1;
  100.         I2C_Delay(5);
  101.         SDA = 1;
  102.         I2C_Delay(5);
  103.         while ( --t != 0 ); //在下一次产生Start 之前,要加一定的延时
  104. }

  105. void Delay(unsigned int I2C_Delay_t)
  106. {       
  107.         while ( --I2C_Delay_t!= 0 );
  108. }

  109. bit write_addr(unsigned char addr,bit mod)
  110. {
  111.         unsigned char address;
  112.         address=addr<<1;
  113.         if(mod)
  114.                 address++;
  115.         I2C_Start();
  116.         I2C_Write(address);
  117.         Delay(10);
  118.                
  119.         if(I2C_GetAck())
  120.                 return 1;

  121.         return 0;

  122. }

  123. bit write_data(unsigned char dat)
  124. {

  125.         I2C_Write(dat);
  126.         if(I2C_GetAck())
  127.                 return 1;
  128.         return 0;

  129. }

  130. void stop()
  131. {
  132.         I2C_Stop();
  133.         I2C_Init();
  134. }

  135. void main(void)
  136. {
  137.         unsigned char i;
  138.         loop:
  139.         I2C_Init();
  140.         while(1)
  141.         {
  142.                 if(key_sin==0)        //产生正弦波
  143.                 {
  144.                         while(1)
  145.                         {
  146.                                 for(i=192;i<255;i++)
  147.                                 {
  148.                                         write_addr(ADDR1,0);
  149.                                         write_data(0);
  150.                                         write_data(sin[i]);
  151.                                         stop();
  152.                                         if(!(key_tran!=0&&key_tooth!=0))
  153.                                                 goto loop;
  154.                                 }
  155.                
  156.                                 for(i=0;i<192;i++)
  157.                                 {
  158.                                         write_addr(ADDR1,0);
  159.                                         write_data(0);
  160.                                         write_data(sin[i]);
  161.                                         stop();
  162.                                         if(!(key_tran!=0&&key_tooth!=0))
  163.                                                 goto loop;
  164.                                 }
  165.                         }
  166.                 }
  167.                 if(key_tran==0)        //产生三角波
  168.                 {
  169.                         while(1)
  170.                         {
  171.                                  for(i=0;i<255;i++)
  172.                                 {
  173.                                         write_addr(ADDR1,0);
  174.                                         write_data(0);
  175.                                         write_data(i);
  176.                                         stop();
  177.                                         if(!(key_sin!=0&&key_tooth!=0))
  178.                                                 goto loop;
  179.                                 }
  180.                                 for(;i>0;i--)
  181.                                 {
  182.                                         write_addr(ADDR1,0);
  183.                                         write_data(0);
  184.                                         write_data(i);
  185.                                         stop();
  186.                                         if(!(key_sin!=0&&key_tooth!=0))
  187.                                                  goto loop;
  188.                                 }
  189.                         }
  190.                 }
  191.                 if(key_tooth==0)  //产生锯齿波
  192.                 {
  193.                         while(1)
  194.                         {
  195.                                  for(i=0;i<255;i++)
  196.                                 {
  197.                                         write_addr(ADDR1,0);
  198.                                         write_data(0);
  199.                                         write_data(i);
  200.                                         stop();
  201.                                         if(!(key_tran!=0&&key_sin!=0))
  202.                                                 goto loop;
  203.                                 }
  204.                         }
  205.                 }       
  206.         }
  207. }
复制代码


0.png
51单片机简易波形发生器仿真工程文件及其他资料下载:
http://www.51hei.com/bbs/dpj-54940-1.html
回复

使用道具 举报

ID:244328 发表于 2017-12-12 17:16 | 显示全部楼层
谢谢楼主
回复

使用道具 举报

ID:357373 发表于 2018-6-24 14:21 | 显示全部楼层
前来查看一下
回复

使用道具 举报

ID:354404 发表于 2018-8-1 14:52 | 显示全部楼层
这个波形产生是用什么显示啊????
回复

使用道具 举报

ID:332269 发表于 2018-10-24 20:11 | 显示全部楼层
感觉按键处理有问题呀,比如按下正弦波按键,就没有消抖。该加一个标志位,什么时候上升,什么时候下降
回复

使用道具 举报

ID:148285 发表于 2018-10-27 20:36 | 显示全部楼层
谢谢楼主分享
回复

使用道具 举报

ID:382813 发表于 2019-5-20 11:18 来自手机 | 显示全部楼层
不能用,图片与内容不符合
回复

使用道具 举报

ID:663363 发表于 2019-12-27 14:41 | 显示全部楼层
谢谢分享
回复

使用道具 举报

ID:382454 发表于 2019-12-28 09:45 | 显示全部楼层
楼主可以说说工作原理嘛?
回复

使用道具 举报

ID:707115 发表于 2020-3-12 16:57 | 显示全部楼层
工程师1996 发表于 2017-12-12 17:16
**** 作者被禁止或删除 内容自动屏蔽 ****

怎么没有梯形波呢,梯形波怎么弄呢
回复

使用道具 举报

ID:707115 发表于 2020-3-12 16:58 | 显示全部楼层
梯形波怎么弄啊?
回复

使用道具 举报

ID:707115 发表于 2020-3-12 16:58 | 显示全部楼层
怎么显示
回复

使用道具 举报

ID:783253 发表于 2020-6-18 15:30 | 显示全部楼层
能看频率吗
回复

使用道具 举报

ID:783253 发表于 2020-6-18 15:30 | 显示全部楼层
能看频率吗
回复

使用道具 举报

ID:842628 发表于 2020-11-25 09:12 | 显示全部楼层
zhouwang4135463 发表于 2018-8-1 14:52
这个波形产生是用什么显示啊????

示波器呀  或者仿真软件
回复

使用道具 举报

ID:842628 发表于 2020-11-25 09:12 | 显示全部楼层

示波器可以看频率  
回复

使用道具 举报

ID:862092 发表于 2020-12-17 13:45 | 显示全部楼层
这个每周期的采样点是256个吗
回复

使用道具 举报

ID:150787 发表于 2021-10-29 23:28 | 显示全部楼层
为什么我只能出来方波??是哪里没弄对吗?求教
回复

使用道具 举报

ID:980051 发表于 2021-11-11 13:56 | 显示全部楼层
原理图怎么下载
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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