标题: 数字信号发生器仿真 可连续调频调幅,显示幅度值,频率,任选波形 [打印本页]

作者: 51黑ff    时间: 2016-9-25 23:11
标题: 数字信号发生器仿真 可连续调频调幅,显示幅度值,频率,任选波形
这个一个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. }
复制代码




作者: dashushi1603    时间: 2017-5-11 22:06
刚做示波器,需要一个信号发生器
作者: qzm    时间: 2017-6-11 18:19
正需要,谢谢
作者: 1207642942    时间: 2018-5-25 09:02
谢谢了,正需要
作者: 一杯树同学    时间: 2018-6-4 17:02
下载下来学习下
作者: 嘞嘎明    时间: 2018-7-20 13:16
感谢分享,学习了




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1