- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试运行以下代码来在上述型号的DSP处理器中实现FFT。代码是用C语言编写的
//All codes submitted by Srivatsa Sinha
/*Include Library Files*/
#include <stdio.h>
#include<math.h>
/*Templates*/
//#define ll long long
#define cmp struct complex
#define print_cmp(z) printf("%lf + %lfj\n",z.re,z.im)
#define M_PI 3.14159265358979
struct complex
{
float re;
float im;
}res,w,w_var,t,u;
cmp signal[4];
cmp result[4];
int j,s,k,n,z,x,no_of_bit,rev,pow2[10],m,a;
void calc()
{
pow2[0]=1;
for(k=1; k<10; k++) { pow2[k] = pow2[k-1]*2;}
}
cmp add(cmp a, cmp b)
{
res.re = a.re + b.re;
res.im = a.im + b.im;
return res;
}
cmp sub(cmp a, cmp b)
{
res.re = a.re - b.re;
res.im = a.im - b.im;
return res;
}
cmp mul(cmp a, cmp b)
{
res.re = a.re*b.re - a.im*b.im;
res.im = a.re*b.im + a.im*b.re;
return res;
}
cmp cmp_pow(cmp base, int exp)
{
res.re = 1.0; res.im = 0.0;
for(a=1; a<=exp; a++)
res = mul(res,base);
return res;
}
void bit_rev()
{
no_of_bit = log2(n);
for(z=0; z<n; z++)
{
rev = 0;
for(x=0; x<no_of_bit; x++)
{
if((z>>x)&1)
{
rev = rev|(1<<(no_of_bit-1-x));
}
}
result[rev] = signal[z];
}
}
void fft()
{
bit_rev();
for(s=1; s<=(int)log2(n); s++)
{
m = pow2[s];
w.re = (float)cos(((float)2.0*(float)M_PI)/(float)m); w.im = (float)-1.0*sin(((float)2.0*(float)M_PI)/(float)m);
for(k=0; k<n; k+=m)
{
w_var.re = 1; w_var.im = 0;
for(j=0; j<=(m/2 - 1); j++)
{
t = mul(w_var, result[k+j+(int)(m/2)]);
u = result[k+j];
result[k+j] = add(u,t);
result[k+j+(int)(m/2)] = sub(u,t);
w_var = mul(w_var, w);
}
}
}
}
void dft()
{
w.re = (float)cos(((float)2.0*(float)M_PI)/(float)n); w.im = (float)-1.0*sin(((float)2.0*(float)M_PI)/(float)n);
for(k=0; k<n; k++)
{
result[k].re = 0.0; result[k].im = 0.0;
for(j=0; j<n; j++)
{
result[k] = add(result[k],mul(signal[j],cmp_pow(w,k*j)));
}
}
}
int main()
{
calc();
printf("Enter length of the signal: ");
scanf("%d",&n);
printf("Enter the signal sequence: \n");
for(k=0;k<n; k++)
{
scanf("%f",&signal[k].re);
scanf("%f",&signal[k].im);
}
fft();
printf("The Result of FFT is: \n");
for(k=0; k<n; k++)
{
print_cmp(result[k]);
}
dft();
printf("The Result of DFT is: \n");
for(k=0; k<n; k++)
{
print_cmp(result[k]);
}
return 0;
}
编译前添加以下文件:
hello.cmd The Linker file
rts6700.lib The Library file
虽然代码编译成功,但是构建时出现以下错误:
can't allocate .stack size 00000400 (page 0) in IRAM (avail: 000003ec)
can't allocate .sysmem size 00000400 (page 0) in IRAM (avail: 000003ec)
can't allocate .cio size 00000120 (page 0) in IRAM (avail: 0000010a)
errors in input - ./Debug/FFTa.out not built
请帮忙?
最佳答案
谢谢你给我的记忆。我使用 TI 工具已经有几年了。我无法再访问他们的文档,但看起来您需要设置链接器控制文件。如果您使用 CodeComposer,则需要创建一个目标(或指定一个模拟模型)来定义 RAM 位置。如果您需要从处理器中获得高性能,您将需要深入研究各种内存类型,以最大限度地减少总线延迟。
关于c - 在 TMS320C6713 DSK 中运行代码时出错?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40283759/
我正在使用 bitbake 构建 yocto 图像,图像类型为 dsk(默认为 wic,我在 中更改为 dsk本地.conf)。它生成 bzImage, boot/grub/grub.conf。但是这
我正在尝试使用 R 库 Ggmap 对向量进行地理定位。 location_google_10000 geocodeQueryCheck() 2500 geocoding queries remai
我正在尝试运行以下代码来在上述型号的DSP处理器中实现FFT。代码是用C语言编写的 //All codes submitted by Srivatsa Sinha /*Include Library
datasciencetoolkit.org 从 2019 年 2 月 12 日起终止了其 map 服务。还有其他人遇到同样的问题吗?此外,还有任何其他简单的方法可以在 R 中对位置进行地理编码,因为
各位程序员 friend ,我从这个优秀的网站学到了很多东西,也许还有其他可以学到的东西。 好吧,我从别人那里接手了一个delphi 7项目,对其进行了一些小改动,主要是if then子句,我根本没有
是否可以在 Delphi 中只将断点保存在项目的 .DSK 文件中,而不保存其他桌面设置? 大多数 .DSK 都妨碍了,但无法保存调试断点是一个真正的痛苦(尤其是当它们是有条件的或附加了操作时)。 最
我是一名优秀的程序员,十分优秀!