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 #include "libavutil/common.h"
00032
00033 #if !CONFIG_HARDCODED_TABLES
00034 SINETABLE( 32);
00035 SINETABLE( 64);
00036 SINETABLE( 128);
00037 SINETABLE( 256);
00038 SINETABLE( 512);
00039 SINETABLE(1024);
00040 SINETABLE(2048);
00041 SINETABLE(4096);
00042 SINETABLE(8192);
00043 #else
00044 #include "libavcodec/sinewin_tables.h"
00045 #endif
00046
00047 SINETABLE_CONST float * const ff_sine_windows[] = {
00048 NULL, NULL, NULL, NULL, NULL,
00049 ff_sine_32 , ff_sine_64 ,
00050 ff_sine_128, ff_sine_256, ff_sine_512, ff_sine_1024, ff_sine_2048, ff_sine_4096, ff_sine_8192
00051 };
00052
00053
00054 av_cold void ff_sine_window_init(float *window, int n) {
00055 int i;
00056 for(i = 0; i < n; i++)
00057 window[i] = sinf((i + 0.5) * (M_PI / (2.0 * n)));
00058 }
00059
00060 av_cold void ff_init_ff_sine_windows(int index) {
00061 assert(index >= 0 && index < FF_ARRAY_ELEMS(ff_sine_windows));
00062 #if !CONFIG_HARDCODED_TABLES
00063 ff_sine_window_init(ff_sine_windows[index], 1 << index);
00064 #endif
00065 }
00066
00067 #endif