📄 fft和ifft的c语言程序_声韵.htm
字号:
<TD class=modtc noWrap align=right></TD>
<TD class=modtr width=7> </TD></TR></TBODY></TABLE>
<DIV class=modbox id=m_blog>
<DIV class=tit>fft和ifft的C语言程序</DIV>
<DIV class=date>2008-04-16 19:03</DIV>
<TABLE style="TABLE-LAYOUT: fixed">
<TBODY>
<TR>
<TD>
<DIV class=cnt id=blog_text>
<P>
最近要做FFT和IFFT,在网上搜来搜去,总是不大好理解,于是就根据大学里学的数字信号处理(西电.刘顺兰等)中的图3-9和图3-10自己写了一下,有用的朋友可以拿去,希望能对大家有帮助。</P>
<P>注:其中的M为11,这是因为我做了N=2048个点的FFT,2^11=2048,M值可根据需要更改,若N不是2的整数次幂,应补零。其中xin为输入信号,并且也应该是COMPX类型量。</P>
<P>1、按时间抽取(DIT)的基-2FFT算法(C)</P>
<P>#include "math.h"<BR>typedef
struct
//定义表示复数的结构体<BR>{<BR> float real;<BR> float
imag;<BR>}COMPX;<BR>COMPX EE(COMPX b1,COMPX b2)
//复数相乘函数<BR>{<BR> COMPX b3;<BR>
b3.real=b1.real*b2.real-b1.imag*b2.imag;<BR>
b3.imag=b1.real*b2.imag+b1.imag*b2.real;<BR>
return(b3);<BR>}</P>
<P>void FFT(COMPX *xin,int N)
//FFT运算<BR>{<BR> int
m,LH,nm,I,k,J,M,K;<BR> float p,ps
;<BR> int B,N1;<BR> COMPX
w,T;<BR>
M=11;
//对应N值为2048</P>
<P>//下面是倒序的程序 <BR>
LH=N/2;<BR> J=LH;<BR>
N1=N-2; <BR>
/*变址运算*/<BR> for(I=1;I<=N1;I++)<BR>
{<BR>
if(I<J)<BR>
{<BR>
T=xin[I];xin[I]=xin[J];xin[J]=T;<BR>
}<BR>
K=LH;<BR>
while(J>=K)<BR>
{<BR>
J=J-K;<BR>
K=K/2;<BR>
}<BR>
J=J+K;<BR> }<BR>
<BR> <BR>//下面是DIT-FFT运算程序</P>
<P> for(m=1;m<=M;m++)<BR> {
<BR> B=pow(2,m-1);
<BR>
for(J=0;J<=B-1;J++)<BR>
{<BR>
p=pow(2,M-m)*J;<BR>
ps=2*pi/N*p;<BR>
w.real=cos(ps);<BR>
w.imag=-sin(ps);<BR>
for(k=J;k<=N-1;k=k+pow(2,m))<BR>
{
<BR>
T=EE(xin[k+B],w);<BR>
xin[k+B].real=xin[k].real-T.real;<BR>
xin[k+B].imag=xin[k].imag-T.imag;<BR>
xin[k].real=xin[k].real+T.real;<BR>
xin[k].imag=xin[k].imag+T.imag;<BR>
}<BR>
}<BR> }<BR><BR>}</P>
<P>2、IFFT</P>
<P>根据定义可知,IFFT与FFT算法没有差别,只需将上面的w.imag=-sin(ps);改写为w.imag=sin(ps);</P>
<P>并在最后一个大括号前加上以下语句就可以了:</P>
<P>for(k=0;k<N;k++)<BR> {<BR>
xin[k].real=xin[k].real/N;<BR>
xin[k].imag=xin[k].imag/N;<BR> }<BR>也就是乘了一个常数因子1/N。</P>
<P
align=right>
水林声 作于 嘉兴 JRC大楼 208室 小雨后</P>
<P> </P>
<P>附图:</P>
<P></P>
<DIV forimg="1"><IMG class=blogimg
src="fft和ifft的C语言程序_声韵.files/b8cb30f8eccb171dd8f9fd4e.jpg" border=0
small="0"></DIV>
<DIV forimg="1">
<DIV forimg="1">
<DIV forimg="1"><IMG class=blogimg
src="fft和ifft的C语言程序_声韵.files/06546dfd2975810409244dd1.bmp" border=0
small="0"></DIV></DIV></DIV>
<P> </P></DIV></TD></TR></TBODY></TABLE><BR>
<DIV class=opt><A title=查看该分类中所有文章
href="http://hi.baidu.com/soundlevel/blog/category/×ß¼¼Êõ·Ïß">类别:走技术路线</A> | <A
title=将此文章添加到百度搜藏 onclick="return addToFavor();"
href="http://cang.baidu.com/do/add" target=_blank>添加到搜藏</A> | 浏览(<SPAN
id=result></SPAN>) | <A
href="http://hi.baidu.com/soundlevel/blog/item/898fe1f302e6fc55352acc92.html#send">评论</A> (0)
<SCRIPT language=javascript>/*<![CDATA[*/var pre = [true,'看到了什么!', '看到了什么!','/soundlevel/blog/item/bda914fcf3ce8e87b801a00b.html'];var post = [true,'杏花又开了,这次不能亲眼看到了','杏花又开了,这次不能亲眼看到了', '/soundlevel/blog/item/17b7c4301adea09ca8018ef4.html'];if(pre[0] || post[0]){ document.write('<div style="height:5px;line-height:5px;"> </div><div id="in_nav">'); if(pre[0]){ document.write('上一篇:<a href="' + pre[3] + '" title="' + pre[1] + '">' + pre[2] + '</a> '); } if(post[0]){ document.write('下一篇:<a href="' + post[3] + '" title="' + post[1] + '">' + post[2] + '</a>'); } document.write('</div>');}/*]]>*/</SCRIPT>
</DIV>
<DIV class=line></DIV>
<STYLE type=text/css>#in_related_doc A {
TEXT-DECORATION: none
}
</STYLE>
<DIV id=in_related_tmp></DIV>
<SCRIPT language=javascript type=text/javascript>/*<![CDATA[*/function HI_MOD_IN_RELATED_DOC_CALLBACK(arg){ if(arg.length <= 1) return false; var hasMore = arg[0]; var D=function(A,B){A[A.length]=B;} if(arg.length % 2 == 0) D(arg, ["","","",""]); var html = ['<div id="in_related_doc"><div class="tit">相关文章:</div>']; D(html, '<table cellpadding="0" cellspacing="3" border="0">'); for(var i = 1, j = arg.length; i < j; i += 2){ D(html, '<tr>'); D(html, '<td width="15px"><a style="font-size:25px" >•</a></td><td><a href="http://hi.baidu.com/' + arg[i][3] + '/blog/item/' + arg[i][2] + '.html" target="_blank" title="' + arg[i][0] + '">' + arg[i][1] + '</a>'); D(html, new Array(10).join('\u3000')); D(html, '</td>'); if(arg[i + 1][0] != "") D(html, '<td width="15px"><a style="font-size:25px" >•</a></td><td><a href="http://hi.baidu.com/' + arg[i + 1][3] + '/blog/item/' + arg[i + 1][2] + '.html" target="_blank" title="' + arg[i + 1][0] + '">' + arg[i + 1][1] + '</a></td>'); else D(html, '<td> </td><td> </td>'); D(html, '</tr>'); } if(hasMore) D(html, '<tr><td colspan="4"><a target="_blank" href="/sys/search?pageno=1&type=7&sort=1&word=fft%BA%CDifft%B5%C4C%D3%EF%D1%D4%B3%CC%D0%F2&item=898fe1f302e6fc55352acc92">更多>></a></td></tr>'); D(html, '</table></div><div class="line"> </div>'); var div = document.getElementById('in_related_tmp'); if(div){ div.innerHTML = html.join(''); while(div.firstChild){ div.parentNode.insertBefore(div.firstChild, div); } div.parentNode.removeChild(div); } window.setTimeout("tracker_init('in_related_doc')",100);}if(RelatedDocData == -1){ // not supported xhr var script = document.createElement('script'); script.type = 'text/javascript'; script.src = '/sys/search?type=8&word=fft%BA%CDifft%B5%C4C%D3%EF%D1%D4%B3%CC%D0%F2&item=898fe1f302e6fc55352acc92&t=' + new Date().getTime(); document.getElementsByTagName('HEAD')[0].appendChild(script);}else if(RelatedDocData == null){ GetAndEval = true;}else{ eval(RelatedDocData);}/*]]>*/</SCRIPT>
<DIV id=in_reader>
<DIV class=tit>最近读者:</DIV>
<SCRIPT> var g_spAnnony=true;var g_read=[{}];g_read.length=g_read.length-1;var _rh1="";var _rh2="";function wrreader(){ _rh1 += '<table width="100%" ><tr>'; _rh2+='<tr>'; if(g_spAnnony){ _rh1+='<td align="center" width="10%" ><img border="0" width="55" height="55" src="http://img.baidu.com/hi/img/portraitn.jpg"></td>'; _rh2+='<td> </td>'; if(g_read.length>0){ _rh1+='<td align="left" width="12%">'; }else{ _rh1+='<td align="left" width="100%">'; } _rh1+="<a href='http://passport.baidu.com/?login&tpl=sp&tpl_reg=sp&u="+myref+"' target='_self'>登录</a>后,您就出现在这里。</td>"; _rh2+='<td> </td>' } if(g_read.length==0){ if(!g_spAnnony){ _rh1+='<td align=left width="100%">最近还没有登录用户看过这篇文章……</td>'; _rh2+='<td> </td>'; } }else{ for(i=0,len=g_read.length;i<len;i++){ _rh1+='<td align="center" valign="bottom" width="10%" class="user"><a href="/'+g_read[i][0]+'" target="_blank"><img border="0" src="http://himg.baidu.com/sys/portraitn/item/'+g_read[i][1]+'.jpg"></a></td>'; _rh2+='<td align="center" valign="top" class="user"><a href="/'+g_read[i][0]+'" target="_blank">'+g_read[i][2]+'</a></td>'; } } _rh1+='<td width="100%"></td></tr>'; _rh2+='<td></td></tr></table>'; document.write(_rh1+_rh2);}wrreader();</SCRIPT>
</DIV>
<DIV class=line></DIV>
<SCRIPT language=JavaScript>allkey=allkey+"2e5072ecb59cb82763d09f44_898fe1f302e6fc55352acc92_";</SCRIPT>
<DIV id=in_comment><A name=comment></A>
<DIV class=tit>网友评论:</DIV>
<SCRIPT>function writecmt(type,id,cmtname,cmturl,portraitId){ var html1=""; if(type==1){ html1="<a href='"+cmturl+"' target='_blank' title='"+cmturl+"'><img border='0' src='http://himg.baidu.com/sys/portraitn/item/"+portraitId+".jpg'><br>"+cmtname+"</a>"; }else{ if(cmtname=="" || cmtname=="匿名网友"){ if(cmturl==""){ html1="<a>匿名网友</a>"; }else{ html1="<a href='"+cmturl+"' target='_blank' title='"+cmturl+"'>"+cmtname+"</a>"; } }else{ if(cmturl==""){ html1="<div class='f14' style='display:inline'>网友:<a>"+cmtname+"</a></div>"; }else{ html1="<div class='f14' style='display:inline'>网友:<a href='"+cmturl+"' target='_blank' title='"+cmturl+"'>"+cmtname+"</a></div>"; } } } document.write(html1);}</SCRIPT>
<DIV id=page></DIV></DIV>
<DIV id=in_send><A name=send></A>
<FORM id=popFormSubmit name=form1 onsubmit="return checkcmtform()"
action=/soundlevel/commit method=post><INPUT type=hidden value=8 name=ct> <INPUT
type=hidden value=1 name=cm> <INPUT type=hidden value=898fe1f302e6fc55352acc92
name=spBlogID>
<SCRIPT language=JavaScript> document.write("<input type='hidden' name='spRefURL' value='"+encodeURI(window.location.href)+"'>");</SCRIPT>
<DIV class=tit>发表评论:</DIV>
<TABLE cellSpacing=5 cellPadding=0 width=620 border=0>
<TBODY>
<TR>
<TD class=f14>姓 名:</TD>
<TD><INPUT id=spBlogCmtor style="WIDTH: 220px" onfocus=hidErr(1);
tabIndex=1 maxLength=49 onchange="checkname('spBlogCmtor')"
name=spBlogCmtor>
<SCRIPT>document.write(" <a href='http://passport.baidu.com/?reg&tpl=sp&return_method=get&skip_ok=1&u=http://hi.baidu.com/sys/reg/' target='_blank'>注册</a>");document.write(" | <a href='http://passport.baidu.com/?login&tpl=sp&tpl_reg=sp&u="+myref+"'>登录</a>");</SCRIPT>
<DIV id=nmerror style="DISPLAY: none">*姓名最长为50字节</DIV></TD></TR>
<TR id=1_err style="DISPLAY: none">
<TD> </TD>
<TD>
<DIV class=error id=1_err_con></DIV></TD></TR>
<TR>
<TD class=f14>网址或邮箱:</TD>
<TD><INPUT id=spBlogCmtURL style="WIDTH: 360px" onfocus=hidErr(2);
tabIndex=2 maxLength=128 onchange="checkeandu('spBlogCmtURL')"
name=spBlogCmtURL> (选填)</TD>
<SCRIPT>G("spBlogCmtor").value="";G("spBlogCmtURL").value="";</SCRIPT>
</TR>
<TR id=2_err style="DISPLAY: none">
<TD> </TD>
<TD>
<DIV class=error id=2_err_con></DIV></TD></TR>
<TR>
<TD class=f14 vAlign=top>内 容:</TD>
<TD><TEXTAREA id=spBlogCmtText style="WIDTH: 520px; HEIGHT: 155px" onfocus=hidErr(3); tabIndex=3 name=spBlogCmtText></TEXTAREA>
<SCRIPT>G("spBlogCmtor").value=G("spBlogCmtor").defaultValue;G("spBlogCmtText").value="";</SCRIPT>
</TD></TR>
<TR id=3_err style="DISPLAY: none">
<TD> </TD>
<TD>
<DIV class=error id=3_err_con></DIV></TD></TR>
<TR id=vercode>
<TD class=f14 vAlign=top>验证码:</TD>
<TD vAlign=top><INPUT type=hidden
value=A5FA342A391120B3312E613C794063267E5AF700901741D061F22A65829D0BD1572530DAC5A9C542A52AF79EDE000387D3F4D596843C3D261FD1875163CF8CD6
name=spVcode> <INPUT id=spVerifyKey onfocus=f_focus() tabIndex=4
maxLength=4 size=6 name=spVerifyKey autocomplete="off"><BR>
<SCRIPT type=text/javascript>/*<![CDATA[*/var imgsrc="http://hiup.baidu.com/cgi-bin/genimg?A5FA342A391120B3312E613C794063267E5AF700901741D061F22A65829D0BD1572530DAC5A9C542A52AF79EDE000387D3F4D596843C3D261FD1875163CF8CD6";function f_focus(){ if(G('yanzheng').style.display=="none" ){ G('verifypic').src=imgsrc; G('yanzheng').style.display="block"; }}function newverifypic(){ G("verifypic").src = imgsrc +"&t="+ Math.random(); return false;}/*]]>*/</SCRIPT>
<DIV id=yanzheng style="DISPLAY: none"><IMG id=verifypic height=40
width=120><WBR><A title=看不清左边的字符 onfocus=this.blur();
onclick="return newverifypic();"
href="http://hi.baidu.com/soundlevel/blog/item/898fe1f302e6fc55352acc92.html#">看不清?</A>
</DIV></TD></TR>
<TR>
<TD class=f14 vAlign=top> </TD>
<TD class=f14 vAlign=top><INPUT id=btn_ok tabIndex=5 type=submit value=发表评论 name=btn_ok></TD></TR></TBODY></TABLE></FORM></DIV><BR></DIV>
<TABLE height=8 cellSpacing=0 cellPadding=0 width="100%" border=0>
<TBODY>
<TR>
<TD class=modbl width=7> </TD>
<TD class=modbc> </TD>
<TD class=modbr width=7> </TD></TR></TBODY></TABLE></DIV></DIV></DIV></DIV>
<SCRIPT language=javascript><!--var hstr="/soundlevel/brwstat?key1=1";document.write("<script src='"+hstr+"&key2="+allkey+"'><\/script>");//--></SCRIPT>
<BR>
<CENTER>
<DIV id=ft>©2008 Baidu</DIV></CENTER>
<SCRIPT>if(document.getElementById("m_blog")){ var imgarray = document.getElementById("m_blog").getElementsByTagName('img'); var imgw = document.getElementById("m_blog").offsetWidth; imgw =imgw-40; for(var i=0; i<imgarray.length; i++){ if(imgarray[i].className=="blogimg" && imgarray[i].width>=imgw) imgarray[i].width=imgw; }}// Fix ff bugsvar blog_text = document.getElementById('blog_text');blog_text.innerHTML = blog_text.innerHTML.replace(/href\s*=\s*("|')?(\.\.\/\.\.\/)/gi,"href=$1../$2");</SCRIPT>
</CENTER><IMG style="DISPLAY: none" src=""> </BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -