欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 9644|回復(fù): 4
打印 上一主題 下一主題
收起左側(cè)

51單片機(jī)ADC采樣傅里葉變換頻譜輸出

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:140343 發(fā)表于 2016-9-25 10:56 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
  1. //完成顯示數(shù)據(jù)的轉(zhuǎn)換工作,包括定點(diǎn)下落速度控制以及定點(diǎn)更新定格
  2. // 對(duì)fft數(shù)據(jù)進(jìn)行處理,得到各個(gè)頻率短的電壓增幅值
  3. //++++++++++++++++++++++++++++++++++++++//
  4. //復(fù)數(shù)乘法
  5. void ee(struct compx b1,uchar data b2)
  6. {
  7. temp.real=b1.real*iw[2*b2]-b1.imag*iw[2*b2+1];
  8. temp.imag=b1.real*iw[2*b2+1]+b1.imag*iw[2*b2];
  9. }
  10. //++++++++++++++++++++++++++++++++++++++//  
  11. //乘方函數(shù)
  12. uint mypow(uchar data nbottom,uchar data ntop)
  13. {
  14.     uint data result=1;
  15.     uchar data t;   
  16.     for(t=0;t<ntop;t++)result*=nbottom;
  17.     return result;
  18. }
  19. //++++++++++++++++++++++++++++++++++++++//
  20. //快速傅里葉變換
  21. void fft(struct compx *xin,uchar data N)
  22. {
  23. uchar data  fftnum,i,j,k,l,m,n,disbuff,dispos,dissec;
  24. data struct compx t;
  25. fftnum=N;                         //傅里葉變換點(diǎn)數(shù)
  26. for(m=1;(fftnum=fftnum/2)!=1;m++);//求得M的值
  27. for(k=0;k<=N-1;k++)               //碼位倒置
  28. {
  29. n=k;
  30. j=0;
  31. for(i=m;i>0;i--)             //倒置
  32. {
  33. j=j+((n%2)<<(i-1));
  34. n=n/2;
  35. }
  36. if(k<j){t=xin[1+j];xin[1+j]=xin[1+k];xin[1+k]=t;}//交換數(shù)據(jù)
  37. }  
  38. for(l=1;l<=m;l++)                //FFT運(yùn)算
  39. {
  40. disbuff=mypow(2,l);          //求碟間距離
  41. dispos=disbuff/2;            //求碟間兩點(diǎn)之間距離
  42. for(j=1;j<=dispos;j++)
  43. for(i=j;i<N;i=i+disbuff) //遍歷M級(jí)所有碟形
  44. {
  45. dissec=i+dispos;     //求第二點(diǎn)位置
  46. ee(xin[dissec],(uint)(j-1)*(uint)N/disbuff);//復(fù)數(shù)乘法
  47. t=temp;
  48. xin[dissec].real=xin[i].real-t.real;
  49. xin[dissec].imag=xin[i].imag-t.imag;
  50. xin[i].real=xin[i].real+t.real;
  51. xin[i].imag=xin[i].imag+t.imag;
  52. }
  53. }
  54. }














  55. void processfft(void)
  56. {
  57.     uchar data pt=0,tmp;

  58.     for(pt=1;pt<65;pt++)
  59.     {
  60.         dd[pt].imag=0;                //清零需部
  61.     }
  62.     fft(dd,64);                       //對(duì)當(dāng)前數(shù)據(jù)進(jìn)行傅里葉變換

  63.     for(pt=1;pt<65;pt++)
  64.     {                                      
  65.         dd[pt].real=sqrt(dd[pt].real*dd[pt].real+dd[pt].imag*dd[pt].imag);//取均方根
  66.     }

  67. if(Menu==1)
  68. {
  69. for(pt=2;pt<34;pt+=2)
  70.    {      
  71. for(tmp=(dd[pt].real/32)+1,LEDBuf[pt]=0xFF;tmp>=1;tmp--)//tmp>1;不保留最低位那一行長亮
  72. {
  73. LEDBuf[pt]<<=1;
  74. }
  75. LEDBuf[pt]=~(LEDBuf[pt]);

  76. }
  77. }
  78. else if(Menu==2)
  79. {

  80. //ÏÂÂä¸D
  81. for(pt=2;pt<34;pt+=2)
  82.    {      
  83. tmp=(dd[pt].real/32)+1;
  84. if(refreshflag[pt]<tmp)            //刷新數(shù)據(jù)取較大高度值 存儲(chǔ)顯示
  85. {
  86. for(LEDBuf[pt]=0xFF;tmp>1;tmp--)//tmp>1;不保留  最低位那一行長亮;{}一次也不執(zhí)行
  87. {
  88. LEDBuf[pt]<<=1;
  89. }
  90. refreshflag[pt]=(dd[pt].real/32)+1;
  91. }
  92. else
  93. {
  94. if(refreshflag[pt]>1)refreshflag[pt]--;                //定點(diǎn)下落速度控制  改變值可以改變下落速度
  95. for(LEDBuf[pt]=0xFF,tmp=refreshflag[pt];tmp>1;tmp--)   //tmp>1;不保留  最低位 那一行長亮
  96. {
  97. LEDBuf[pt]<<=1;
  98. }
  99. }
  100. }
  101. }
  102. else if(Menu==0)
  103. {

  104. //ÏÂÂä¸DÆμÆ×
  105. for(pt=2;pt<34;pt+=2)
  106.    {      
  107. tmp=(dd[pt].real/32)+1;
  108. if(refreshflag[pt]<tmp)          //刷新數(shù)據(jù)取較大高度值 存儲(chǔ)顯示
  109. {
  110. for(LEDBuf[pt]=0xFF;tmp>=1;tmp--)//tmp>1;不保留  最低位那一行長亮;{}一次也不執(zhí)行
  111. {
  112. LEDBuf[pt]<<=1;
  113. }
  114. refreshflag[pt]=(dd[pt].real/32)+1;
  115. }
  116. else
  117. {
  118. if(refreshflag[pt]>1)refreshflag[pt]--;                        
  119. for(LEDBuf[pt]=0xFF,tmp=refreshflag[pt];tmp>=1;tmp--)
  120. {
  121. LEDBuf[pt]<<=1;
  122. }
  123. }
  124. LEDBuf[pt]=~(LEDBuf[pt]);
  125. }
  126. }
  127. }  
復(fù)制代碼
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏5 分享淘帖 頂 踩
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:238767 發(fā)表于 2017-10-12 09:18 | 只看該作者
請(qǐng)問這里 “Menu” = 0,1,2 是什么意思?
回復(fù)

使用道具 舉報(bào)

板凳
ID:254064 發(fā)表于 2018-3-12 15:50 | 只看該作者
yxf0915 發(fā)表于 2017-10-12 09:18
**** 作者被禁止或刪除 內(nèi)容自動(dòng)屏蔽 ****

我也搞不懂這個(gè),同問
回復(fù)

使用道具 舉報(bào)

地板
ID:336427 發(fā)表于 2018-7-29 12:13 | 只看該作者
可用嗎
回復(fù)

使用道具 舉報(bào)

5#
ID:188748 發(fā)表于 2019-9-2 15:14 | 只看該作者
這代碼亂寫的,沒啥用
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表