找回密码
 立即注册

QQ登录

只需一步,快速开始

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

数字信号发生器仿真 可连续调频调幅,显示幅度值,频率,任选波形

[复制链接]
跳转到指定楼层
楼主
这个一个51单片机做的数字信号发生器仿真 可连续调频调幅,显示幅度值,频率,任选波形.下面是仿真原理图:



所有资料下载: 数字信号发生器完美版.zip (30.69 KB, 下载次数: 161)

下面是部分程序预览:
  1. #include<reg51.h>
  2. #include<absacc.h>
  3. #define DAC0832 XBYTE[0x7fff]
  4. #define ADC0808 XBYTE[0xfeff]
  5. #define ADC08081 XBYTE[0xefff]
  6. sbit s0=P2^1;
  7. sbit s1=P2^2;
  8. sbit s2=P2^3;
  9. sbit s3=P3^0;
  10. sbit A0=P2^5;
  11. sbit A1=P2^6;
  12. sbit B0=P3^4;
  13. sbit B1=P3^5;
  14. unsigned int i,j;
  15. unsigned int x=0;
  16. unsigned char freq,voltage;
  17. unsigned char f[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xbf};
  18. unsigned char v[]={0x40,0x79,0x24,0x30,0x19,0x12,0x02,0x78,0x00,0x10,0x3f};
  19. char code s[]={0,22,44,64,82,98,111,120,126,127,126,120,111,98,82,64,44,22,0,-22,-44,-64,-82,-98,-111,-120,-126,-127,-126,-120,-111,-98,-82,-64,-44,-22}; //正弦波形表   
  20. char code jc[]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35};
  21. char code sj[]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,17,16,15,14,13,12,11,10,9,8,7,6,5,4,3,2,1,0};
  22. char code fb[]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255};
  23. void delay(unsigned int i)
  24. {
  25. while(i--);
  26. }            
  27. void sin()
  28. {
  29. while(s0==0)
  30. {
  31. ADC0808=0;
  32. for(x=0;x<9;x++)
  33. {
  34. P1=f[(33-freq/8)%10];
  35. A0=1;
  36. for(i=0;i<freq+1;i++)
  37. DAC0832=(s[4*x]+128);
  38. delay(150);
  39. A0=0;
  40. P1=f[(33-freq/8)/10];
  41. A1=1;
  42. for(i=0;i<freq+1;i++)
  43. DAC0832=(s[4*x+1]+128);
  44. delay(150);
  45. A1=0;
  46. P1=f[(voltage/4)%10];
  47. B0=1;
  48. for(i=0;i<freq+1;i++)
  49. DAC0832=(s[4*x+2]+128);
  50. delay(10);
  51. B0=0;
  52. P1=v[(voltage/4)/10];
  53. B1=1;
  54. for(i=0;i<freq+1;i++)
  55. DAC0832=(s[4*x+3]+128);
  56. delay(10);
  57. B1=0;
  58. }
  59. ADC08081=0;
  60. }
  61. }
  62. void jvchi()
  63. {
  64. while(s1==0)
  65. {
  66. ADC0808=0;
  67. for(x=0;x<9;x++)
  68. {
  69. P1=f[(38-freq/7)%10];
  70. A0=1;
  71. for(i=0;i<freq+1;i++)
  72. DAC0832=jc[4*x]*7;
  73. delay(130);
  74. A0=0;
  75. P1=f[(37-freq/7)/10];
  76. A1=1;
  77. for(i=0;i<freq+1;i++)
  78. DAC0832=jc[4*x+1]*7;
  79. delay(130);
  80. A1=0;
  81. P1=f[(voltage/4)%10];
  82. B0=1;
  83. for(i=0;i<freq+1;i++)
  84. DAC0832=jc[4*x+2]*7;
  85. delay(10);
  86. B0=0;
  87. P1=v[(voltage/4)/10];
  88. B1=1;
  89. for(i=0;i<freq+1;i++)
  90. DAC0832=jc[4*x+3]*7;
  91. delay(10);
  92. B1=0;
  93. }
  94. ADC08081=0;
  95. }
  96. }
  97. void triangle()
  98. {
  99. while(s2==0)
  100. {
  101. ADC0808=0;
  102. for(x=0;x<9;x++)
  103. {
  104. P1=f[(44-freq/6)%10];
  105. A0=1;
  106. for(i=0;i<freq+1;i++)
  107. DAC0832=sj[4*x]*14;
  108. delay(100);
  109. A0=0;
  110. P1=f[(45-freq/6)/10];
  111. A1=1;
  112. for(i=0;i<freq+1;i++)
  113. DAC0832=sj[4*x+1]*14;
  114. delay(100);
  115. A1=0;
  116. P1=f[(voltage/4)%10];
  117. B0=1;
  118. for(i=0;i<freq+1;i++)
  119. DAC0832=sj[4*x+2]*14;
  120. delay(10);
  121. B0=0;
  122. P1=v[(voltage/4)/10];
  123. B1=1;
  124. for(i=0;i<freq+1;i++)
  125. DAC0832=sj[4*x+3]*14;
  126. delay(10);
  127. B1=0;
  128. }
  129. ADC08081=0;
  130. }
  131. }
  132. void fangbo()
  133. {
  134. while(s3==0)
  135. {
  136. ADC0808=0;
  137. for(x=0;x<9;x++)
  138. {
  139. P1=f[(53-freq/5)%10];
  140. A0=1;
  141. for(i=0;i<freq+1;i++)
  142. DAC0832=fb[4*x];
  143. delay(80);
  144. A0=0;
  145. P1=f[(52-freq/5)/10];
  146. A1=1;
  147. for(i=0;i<freq+1;i++)
  148. DAC0832=fb[4*x+1];
  149. delay(80);
  150. A1=0;
  151. P1=f[(voltage/4)%10];
  152. B0=1;
  153. for(i=0;i<freq+1;i++)
  154. DAC0832=fb[4*x+2];
  155. delay(20);
  156. B0=0;
  157. P1=v[(voltage/4)/10];
  158. B1=1;
  159. for(i=0;i<freq+1;i++)
  160. DAC0832=fb[4*x+3];
  161. delay(10);
  162. B1=0;
  163. }
  164. ADC08081=0;
  165. }
  166. }
  167. void main()
  168. {
  169. IE=0X81;
  170. EX1=1;
  171. sin();
  172. jvchi();
  173. triangle();
  174. fangbo();
  175. }
  176. extern0()interrupt 0
  177. {
  178. freq=ADC0808;
  179. }
  180. extern1()interrupt 2
  181. {
  182. voltage=ADC08081;
  183. }
复制代码



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

使用道具 举报

沙发
ID:197660 发表于 2017-5-11 22:06 | 只看该作者
刚做示波器,需要一个信号发生器
回复

使用道具 举报

板凳
ID:210067 发表于 2017-6-11 18:19 | 只看该作者
正需要,谢谢
回复

使用道具 举报

地板
ID:327323 发表于 2018-5-25 09:02 | 只看该作者
谢谢了,正需要
回复

使用道具 举报

5#
ID:335213 发表于 2018-6-4 17:02 | 只看该作者
下载下来学习下
回复

使用道具 举报

6#
ID:251709 发表于 2018-7-20 13:16 | 只看该作者
感谢分享,学习了
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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