久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

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 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 精品在线一区二区 | av影音在线 | 日韩一区二区三区在线看 | 久草免费视 | 欧美成人精品二区三区99精品 | 亚洲第一成人影院 | 日韩精品999 | 精品一区二区三区不卡 | 亚洲欧美日韩在线 | 成人夜晚看av | 九九色综合| 日韩一级二级片 | 国产精品一区二区三区在线 | 国产精品五月天 | 免费三级网 | 91亚洲精品国偷拍自产在线观看 | 四季久久免费一区二区三区四区 | 国产精品久久久99 | 日韩欧美在线不卡 | 成av在线| 国产黄色大片在线免费观看 | 人人干人人干人人 | 四虎免费视频 | 国产精品自产av一区二区三区 | 欧美一区 | 国产精品自产拍 | 国产一区二区在线免费观看 | 奇米影视首页 | 色女人天堂 | 日本在线视频一区二区 | 亚洲 成人 在线 | 日韩在线视频一区二区三区 | 欧美精品一区三区 | 国内精品久久久久 | 亚洲国产精品va在线看黑人 | 日本三级黄视频 | 久久亚洲一区二区三区四区 | 欧美二区三区 | 欧美精品一区二区在线观看 | 中文字幕av一区 | 最新高清无码专区 |