00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
00020 
00021 
00022 
00023 #ifndef AVCODEC_SINEWIN_TABLEGEN_H
00024 #define AVCODEC_SINEWIN_TABLEGEN_H
00025 
00026 #include <assert.h>
00027 
00028 
00029 #include <math.h>
00030 #include "libavutil/attributes.h"
00031 
00032 #if !CONFIG_HARDCODED_TABLES
00033 SINETABLE(  32);
00034 SINETABLE(  64);
00035 SINETABLE( 128);
00036 SINETABLE( 256);
00037 SINETABLE( 512);
00038 SINETABLE(1024);
00039 SINETABLE(2048);
00040 SINETABLE(4096);
00041 #else
00042 #include "libavcodec/sinewin_tables.h"
00043 #endif
00044 
00045 SINETABLE_CONST float * const ff_sine_windows[] = {
00046     NULL, NULL, NULL, NULL, NULL, 
00047     ff_sine_32 , ff_sine_64 ,
00048     ff_sine_128, ff_sine_256, ff_sine_512, ff_sine_1024, ff_sine_2048, ff_sine_4096
00049 };
00050 
00051 
00052 av_cold void ff_sine_window_init(float *window, int n) {
00053     int i;
00054     for(i = 0; i < n; i++)
00055         window[i] = sinf((i + 0.5) * (M_PI / (2.0 * n)));
00056 }
00057 
00058 av_cold void ff_init_ff_sine_windows(int index) {
00059     assert(index >= 0 && index < FF_ARRAY_ELEMS(ff_sine_windows));
00060 #if !CONFIG_HARDCODED_TABLES
00061     ff_sine_window_init(ff_sine_windows[index], 1 << index);
00062 #endif
00063 }
00064 
00065 #endif