CMSIS-DSP  
CMSIS DSP Software Library
 
Loading...
Searching...
No Matches

Functions

arm_status arm_cfft_init_4096_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 4096 samples.
 
arm_status arm_cfft_init_2048_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 2048 samples.
 
arm_status arm_cfft_init_1024_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 1024 samples.
 
arm_status arm_cfft_init_512_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 512 samples.
 
arm_status arm_cfft_init_256_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 256 samples.
 
arm_status arm_cfft_init_128_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 128 samples.
 
arm_status arm_cfft_init_64_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 64 samples.
 
arm_status arm_cfft_init_32_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 32 samples.
 
arm_status arm_cfft_init_16_q15 (arm_cfft_instance_q15 *S)
 Initialization function for the cfft q15 function for 16 samples.
 
arm_status arm_cfft_init_q15 (arm_cfft_instance_q15 *S, uint16_t fftLen)
 Generic initialization function for the cfft q15 function.
 
void arm_cfft_q15 (const arm_cfft_instance_q15 *S, q15_t *p1, uint8_t ifftFlag, uint8_t bitReverseFlag)
 Processing function for Q15 complex FFT.
 
arm_cfft_instance_q15arm_cfft_init_dynamic_q15 (uint32_t fftLen)
 Initialize data structure for a FFT.
 

Description

end of ComplexFFTQ31 group

Function Documentation

◆ arm_cfft_init_1024_q15()

arm_status arm_cfft_init_1024_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 1024 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_128_q15()

arm_status arm_cfft_init_128_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 128 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_16_q15()

arm_status arm_cfft_init_16_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 16 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_2048_q15()

arm_status arm_cfft_init_2048_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 2048 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_256_q15()

arm_status arm_cfft_init_256_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 256 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_32_q15()

arm_status arm_cfft_init_32_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 32 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_4096_q15()

arm_status arm_cfft_init_4096_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 4096 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_512_q15()

arm_status arm_cfft_init_512_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 512 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_64_q15()

arm_status arm_cfft_init_64_q15 ( arm_cfft_instance_q15 S)

Initialization function for the cfft q15 function for 64 samples.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h

◆ arm_cfft_init_dynamic_q15()

arm_cfft_instance_q15 * arm_cfft_init_dynamic_q15 ( uint32_t  fftLen)

Initialize data structure for a FFT.

Parameters
[in]fftLenThe fft length
Returns
Pointer to the new structure
This function is only available for Neon
This function is allocating memory. The memory must be released when no more used. This function can be used with FFT lengths longer than the ones supported on Cortex-M

With this function, FFT lengths can also contain factor 3 and 5 (but must be multiple of 4)

◆ arm_cfft_init_q15()

arm_status arm_cfft_init_q15 ( arm_cfft_instance_q15 S,
uint16_t  fftLen 
)

Generic initialization function for the cfft q15 function.

Parameters
[in,out]Spoints to an instance of the floating-point CFFT structure
[in]fftLenfft length (number of complex samples)
Returns
execution status
Use of this function is mandatory only for the Helium and Neon versions of the FFT.
Other versions can still initialize directly the data structure using variables declared in arm_const_structs.h
This function should be used only if you don't know the FFT sizes that you'll need at build time. The use of this function will prevent the linker from removing the FFT tables that are not needed and the library code size will be bigger than needed.
If you use CMSIS-DSP as a static library, and if you know the FFT sizes that you need at build time, then it is better to use the initialization functions defined for each FFT size.

◆ arm_cfft_q15()

void arm_cfft_q15 ( const arm_cfft_instance_q15 S,
q15_t p1,
uint8_t  ifftFlag,
uint8_t  bitReverseFlag 
)

Processing function for Q15 complex FFT.

Parameters
[in]Spoints to an instance of Q15 CFFT structure
[in,out]p1points to the complex data buffer of size 2*fftLen. Processing occurs in-place
[in]ifftFlagflag that selects transform direction
  • value = 0: forward transform
  • value = 1: inverse transform
[in]bitReverseFlagflag that enables / disables bit reversal of output
  • value = 0: disables bit reversal of output
  • value = 1: enables bit reversal of output
Input and Output formats for CFFT Q15
CFFT Size Input Format Output Format Number of bits to upscale
16 1.15 5.11 4
64 1.15 7.9 6
256 1.15 9.7 8
1024 1.15 11.5 10
Input and Output formats for CIFFT Q15
CIFFT Size Input Format Output Format Number of bits to upscale
16 1.15 5.11 0
64 1.15 7.9 0
256 1.15 9.7 0
1024 1.15 11.5 0
Neon version
The neon version has a different API. The input and output buffers must be different. There is a temporary buffer. The temporary buffer has same size as input or output buffer. The bit reverse flag is not more available in Neon version.
const q15_t * src,
q15_t * dst,
q15_t *buffer,
uint8_t ifftFlag)