arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
我用STM32F3 的DSP库 arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???求指点啊,谢谢啦
RE:arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
请问一下数据是有错误还是高低字节不对?回复:arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
回复第 2 楼 于2013-11-01 14:11:02发表:请问一下数据是有错误还是高低字节不对?
是数据在数组的顺序不对
回复:arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
我拿50HZ和100HZ的信号进行FFT。在1和2出应该是32.可1处是对的,另一个就不对了。跑到40多去了回复:arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
回复第 2 楼 于2013-11-01 14:11:02发表:请问一下数据是有错误还是高低字节不对?
RE:arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
是否可以看一下你的相关代码?回复:arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
<div style="padding:5px;border:1px dashed #ccc;">回复第 6 楼 于2013-11-01 15:30:29发表:是否可以看一下你的相关代码?
//#define fftSize 64 //FFT²ÉÑùµãÊý£¬Èç¹ûÓÃDSP¿â½øÐÐFFTÔò´ÎÊýΪ16¡¢64¡¢256¡¢1024
#define TEST_LENGTH_SAMPLES 128
#define NUM_TAPS 32 //Â˲¨Æ÷µÄÂ˲¨ÏµÊýµÄÄ¿Êý£¬Â˲¨Æ÷³¤¶È
#define BLOCK_SIZE 32//Â˲¨Æ÷ ͬһʱ¼ä´¦ÀíµÄÑù±¾Êý
float32_t testfftInput;
static float32_t testfftOutput;/
uint32_t fftSize = 64;
uint8_t ifftFlag = 0;
uint8_t doBitReverse = 1;
float32_t spidata;
int w;
int m;
float32_t testOutput;
float32_t firStateF32;
float32_t SpiBuffer;
float Value;
u8 SamplingEnd;
u8 SamplingCount;
int next_data_handle(int addr)
{
return (addr) == MAXSIZE ? 0:(addr) ;
}
int main(void)
{
u8 i=0;
u32 j;
u8 k;
arm_fir_instance_f32 S;
arm_cfft_radix4_instance_f32 S1;
float32_t maxValue;
arm_status status;
float32_t *inputF32,*outputF32;
float32_t threshold;//Ææ´Îг²¨°Ù·Ö±È
int flag = 0;
int warn = 0;//±¨¾¯±êÖ¾
//int middle = 0;
int addr1 = 0;
float32_t sum1 = 0;
float32_t sum2 = 0;
float32_t sum3 = 0;
SystemInit();//ϵͳʱÖÓ³õʼ»¯Îª72M
GPIO_Configuration();//¶Ë¿Ú³õʼ»¯
NVIC_Configuration();//ÉèÖÃNVICÖжϷÖ×é2:2λÇÀÕ¼ÓÅÏȼ¶£¬2λÏìÓ¦ÓÅÏȼ¶
SPI_Configuration();
Init_SPI();
USART_Configuration(9600);
TIM_Configuration();
delay_init(72); //ÑÓʱº¯Êý³õʼ»¯
EXTIX_Init();
status = ARM_MATH_SUCCESS;
status = arm_cfft_radix4_init_f32(&S1,fftSize,ifftFlag,doBitReverse);
while(1)
{
if(SamplingEnd==true)//²É¼¯Íê64¸öµã
{
for(i=0;i
回复:arm_cfft_radix4_f32()做FFT后数据对,但是在数组位置不对是怎么回事啊???
回复第 6 楼 于2013-11-01 15:30:29发表:是否可以看一下你的相关代码?
还有就是我把arm_common_tables.h 里的
extern const uint16_t armBitRevTable;和extern const float32_t twiddleCoef;
改成extern uint16_t armBitRevTable和extern const float32_t twiddleCoef;了,
在arm_cfft_radix4_init_f32.c里加了句uint16_t armBitRevTable;否则编译错误
对了我用的是STM32F3的固件库
楼主,请问利用stm32 dsp库做fft运算后,怎样根据得出的幅值验证结果的正确性啊,我在网上看到有一个例子它是根据峰值出现的位置就说跟预期结果相符,请问这是怎么知道的呢?:)
页:
[1]