123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- #ifndef KISS_FFT_GUTS_H
- #define KISS_FFT_GUTS_H
- #define MIN(a,b) ((a)<(b) ? (a):(b))
- #define MAX(a,b) ((a)>(b) ? (a):(b))
- #include "kiss_fft.h"
- #ifdef FIXED_POINT
- #include "arch.h"
- #define SAMP_MAX 2147483647
- #define TWID_MAX 32767
- #define TRIG_UPSCALE 1
- #define SAMP_MIN -SAMP_MAX
- # define S_MUL(a,b) MULT16_32_Q15(b, a)
- # define C_MUL(m,a,b) \
- do{ (m).r = SUB32_ovflw(S_MUL((a).r,(b).r) , S_MUL((a).i,(b).i))
- (m).i = ADD32_ovflw(S_MUL((a).r,(b).i) , S_MUL((a).i,(b).r))
- # define C_MULC(m,a,b) \
- do{ (m).r = ADD32_ovflw(S_MUL((a).r,(b).r) , S_MUL((a).i,(b).i))
- (m).i = SUB32_ovflw(S_MUL((a).i,(b).r) , S_MUL((a).r,(b).i))
- # define C_MULBYSCALAR( c, s ) \
- do{ (c).r = S_MUL( (c).r , s )
- (c).i = S_MUL( (c).i , s )
- # define DIVSCALAR(x,k) \
- (x) = S_MUL( x, (TWID_MAX-((k)>>1))/(k)+1 )
- # define C_FIXDIV(c,div) \
- do { DIVSCALAR( (c).r , div)
- DIVSCALAR( (c).i , div)
- #define C_ADD( res, a,b)\
- do {(res).r=ADD32_ovflw((a).r,(b).r)
- }while(0)
- #define C_SUB( res, a,b)\
- do {(res).r=SUB32_ovflw((a).r,(b).r)
- }while(0)
- #define C_ADDTO( res , a)\
- do {(res).r = ADD32_ovflw((res).r, (a).r)
- }while(0)
- #define C_SUBFROM( res , a)\
- do {(res).r = ADD32_ovflw((res).r,(a).r)
- }while(0)
- #if defined(OPUS_ARM_INLINE_ASM)
- #include "arm/kiss_fft_armv4.h"
- #endif
- #if defined(OPUS_ARM_INLINE_EDSP)
- #include "arm/kiss_fft_armv5e.h"
- #endif
- #if defined(MIPSr1_ASM)
- #include "mips/kiss_fft_mipsr1.h"
- #endif
- #else
- # define S_MUL(a,b) ( (a)*(b) )
- #define C_MUL(m,a,b) \
- do{ (m).r = (a).r*(b).r - (a).i*(b).i
- (m).i = (a).r*(b).i + (a).i*(b).r
- #define C_MULC(m,a,b) \
- do{ (m).r = (a).r*(b).r + (a).i*(b).i
- (m).i = (a).i*(b).r - (a).r*(b).i
- #define C_MUL4(m,a,b) C_MUL(m,a,b)
- # define C_FIXDIV(c,div)
- # define C_MULBYSCALAR( c, s ) \
- do{ (c).r *= (s)
- (c).i *= (s)
- #endif
- #ifndef CHECK_OVERFLOW_OP
- # define CHECK_OVERFLOW_OP(a,op,b)
- #endif
- #ifndef C_ADD
- #define C_ADD( res, a,b)\
- do { \
- CHECK_OVERFLOW_OP((a).r,+,(b).r)\
- CHECK_OVERFLOW_OP((a).i,+,(b).i)\
- (res).r=(a).r+(b).r
- }while(0)
- #define C_SUB( res, a,b)\
- do { \
- CHECK_OVERFLOW_OP((a).r,-,(b).r)\
- CHECK_OVERFLOW_OP((a).i,-,(b).i)\
- (res).r=(a).r-(b).r
- }while(0)
- #define C_ADDTO( res , a)\
- do { \
- CHECK_OVERFLOW_OP((res).r,+,(a).r)\
- CHECK_OVERFLOW_OP((res).i,+,(a).i)\
- (res).r += (a).r
- }while(0)
- #define C_SUBFROM( res , a)\
- do {\
- CHECK_OVERFLOW_OP((res).r,-,(a).r)\
- CHECK_OVERFLOW_OP((res).i,-,(a).i)\
- (res).r -= (a).r
- }while(0)
- #endif
- #ifdef FIXED_POINT
- # define KISS_FFT_COS(phase) floor(.5+TWID_MAX*cos (phase))
- # define KISS_FFT_SIN(phase) floor(.5+TWID_MAX*sin (phase))
- # define HALF_OF(x) ((x)>>1)
- #elif defined(USE_SIMD)
- # define KISS_FFT_COS(phase) _mm_set1_ps( cos(phase) )
- # define KISS_FFT_SIN(phase) _mm_set1_ps( sin(phase) )
- # define HALF_OF(x) ((x)*_mm_set1_ps(.5f))
- #else
- # define KISS_FFT_COS(phase) (kiss_fft_scalar) cos(phase)
- # define KISS_FFT_SIN(phase) (kiss_fft_scalar) sin(phase)
- # define HALF_OF(x) ((x)*.5f)
- #endif
- #define kf_cexp(x,phase) \
- do{ \
- (x)->r = KISS_FFT_COS(phase)
- (x)->i = KISS_FFT_SIN(phase)
- }while(0)
- #define kf_cexp2(x,phase) \
- do{ \
- (x)->r = TRIG_UPSCALE*celt_cos_norm((phase))
- (x)->i = TRIG_UPSCALE*celt_cos_norm((phase)-32768)
- }while(0)
- #endif
|