FFmpeg
tx_priv.h
Go to the documentation of this file.
1 /*
2  * This file is part of FFmpeg.
3  *
4  * FFmpeg is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * FFmpeg is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with FFmpeg; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18 
19 #ifndef AVUTIL_TX_PRIV_H
20 #define AVUTIL_TX_PRIV_H
21 
22 #include "tx.h"
23 #include "thread.h"
24 #include "mem_internal.h"
25 #include "common.h"
26 #include "attributes.h"
27 
28 #ifdef TX_FLOAT
29 #define TX_TAB(x) x ## _float
30 #define TX_NAME(x) x ## _float_c
31 #define TX_NAME_STR(x) NULL_IF_CONFIG_SMALL(x "_float_c")
32 #define TX_TYPE(x) AV_TX_FLOAT_ ## x
33 #define TX_FN_NAME(fn, suffix) ff_tx_ ## fn ## _float_ ## suffix
34 #define TX_FN_NAME_STR(fn, suffix) NULL_IF_CONFIG_SMALL(#fn "_float_" #suffix)
35 #define MULT(x, m) ((x) * (m))
36 #define SCALE_TYPE float
37 typedef float TXSample;
38 typedef float TXUSample;
40 #elif defined(TX_DOUBLE)
41 #define TX_TAB(x) x ## _double
42 #define TX_NAME(x) x ## _double_c
43 #define TX_NAME_STR(x) NULL_IF_CONFIG_SMALL(x "_double_c")
44 #define TX_TYPE(x) AV_TX_DOUBLE_ ## x
45 #define TX_FN_NAME(fn, suffix) ff_tx_ ## fn ## _double_ ## suffix
46 #define TX_FN_NAME_STR(fn, suffix) NULL_IF_CONFIG_SMALL(#fn "_double_" #suffix)
47 #define MULT(x, m) ((x) * (m))
48 #define SCALE_TYPE double
49 typedef double TXSample;
50 typedef double TXUSample;
52 #elif defined(TX_INT32)
53 #define TX_TAB(x) x ## _int32
54 #define TX_NAME(x) x ## _int32_c
55 #define TX_NAME_STR(x) NULL_IF_CONFIG_SMALL(x "_int32_c")
56 #define TX_TYPE(x) AV_TX_INT32_ ## x
57 #define TX_FN_NAME(fn, suffix) ff_tx_ ## fn ## _int32_ ## suffix
58 #define TX_FN_NAME_STR(fn, suffix) NULL_IF_CONFIG_SMALL(#fn "_int32_" #suffix)
59 #define MULT(x, m) (((((int64_t)(x)) * (int64_t)(m)) + 0x40000000) >> 31)
60 #define SCALE_TYPE float
61 typedef int32_t TXSample;
62 typedef uint32_t TXUSample;
64 #else
65 typedef void TXComplex;
66 #endif
67 
68 #define TX_DECL_FN(fn, suffix) \
69  void TX_FN_NAME(fn, suffix)(AVTXContext *s, void *o, void *i, ptrdiff_t st);
70 
71 #define TX_DEF(fn, tx_type, len_min, len_max, f1, f2, \
72  p, init_fn, suffix, cf, cd_flags, cf2) \
73  &(const FFTXCodelet){ \
74  .name = TX_FN_NAME_STR(fn, suffix), \
75  .function = TX_FN_NAME(fn, suffix), \
76  .type = TX_TYPE(tx_type), \
77  .flags = FF_TX_ALIGNED | FF_TX_OUT_OF_PLACE | cd_flags, \
78  .factors = { (f1), (f2) }, \
79  .nb_factors = !!(f1) + !!(f2), \
80  .min_len = len_min, \
81  .max_len = len_max, \
82  .init = init_fn, \
83  .cpu_flags = cf2 | AV_CPU_FLAG_ ## cf, \
84  .prio = p, \
85  }
86 
87 #if defined(TX_FLOAT) || defined(TX_DOUBLE)
88 
89 #define CMUL(dre, dim, are, aim, bre, bim) \
90  do { \
91  (dre) = (are) * (bre) - (aim) * (bim); \
92  (dim) = (are) * (bim) + (aim) * (bre); \
93  } while (0)
94 
95 #define SMUL(dre, dim, are, aim, bre, bim) \
96  do { \
97  (dre) = (are) * (bre) - (aim) * (bim); \
98  (dim) = (are) * (bim) - (aim) * (bre); \
99  } while (0)
100 
101 #define UNSCALE(x) (x)
102 #define RESCALE(x) (x)
103 
104 #define FOLD(a, b) ((a) + (b))
105 
106 #define BF(x, y, a, b) \
107  do { \
108  x = (a) - (b); \
109  y = (a) + (b); \
110  } while (0)
111 
112 #elif defined(TX_INT32)
113 
114 /* Properly rounds the result */
115 #define CMUL(dre, dim, are, aim, bre, bim) \
116  do { \
117  int64_t accu; \
118  (accu) = (int64_t)(bre) * (are); \
119  (accu) -= (int64_t)(bim) * (aim); \
120  (dre) = (int)(((accu) + 0x40000000) >> 31); \
121  (accu) = (int64_t)(bim) * (are); \
122  (accu) += (int64_t)(bre) * (aim); \
123  (dim) = (int)(((accu) + 0x40000000) >> 31); \
124  } while (0)
125 
126 #define SMUL(dre, dim, are, aim, bre, bim) \
127  do { \
128  int64_t accu; \
129  (accu) = (int64_t)(bre) * (are); \
130  (accu) -= (int64_t)(bim) * (aim); \
131  (dre) = (int)(((accu) + 0x40000000) >> 31); \
132  (accu) = (int64_t)(bim) * (are); \
133  (accu) -= (int64_t)(bre) * (aim); \
134  (dim) = (int)(((accu) + 0x40000000) >> 31); \
135  } while (0)
136 
137 #define UNSCALE(x) ((double)(x)/2147483648.0)
138 #define RESCALE(x) (av_clip64(llrintf((x) * 2147483648.0), INT32_MIN, INT32_MAX))
139 
140 #define FOLD(x, y) ((int32_t)((x) + (unsigned)(y) + 32) >> 6)
141 
142 #define BF(x, y, a, b) \
143  do { \
144  x = (a) - (unsigned)(b); \
145  y = (a) + (unsigned)(b); \
146  } while (0)
147 
148 #endif /* TX_INT32 */
149 
150 #define CMUL3(c, a, b) CMUL((c).re, (c).im, (a).re, (a).im, (b).re, (b).im)
151 
152 /* Codelet flags, used to pick codelets. Must be a superset of enum AVTXFlags,
153  * but if it runs out of bits, it can be made separate. */
154 #define FF_TX_OUT_OF_PLACE (1ULL << 63) /* Can be OR'd with AV_TX_INPLACE */
155 #define FF_TX_ALIGNED (1ULL << 62) /* Cannot be OR'd with AV_TX_UNALIGNED */
156 #define FF_TX_PRESHUFFLE (1ULL << 61) /* Codelet expects permuted coeffs */
157 #define FF_TX_INVERSE_ONLY (1ULL << 60) /* For non-orthogonal inverse-only transforms */
158 #define FF_TX_FORWARD_ONLY (1ULL << 59) /* For non-orthogonal forward-only transforms */
159 #define FF_TX_ASM_CALL (1ULL << 58) /* For asm->asm functions only */
160 
161 typedef enum FFTXCodeletPriority {
162  FF_TX_PRIO_BASE = 0, /* Baseline priority */
163 
164  /* For SIMD, set base prio to the register size in bits and increment in
165  * steps of 64 depending on faster/slower features, like FMA. */
166 
167  FF_TX_PRIO_MIN = -131072, /* For naive implementations */
168  FF_TX_PRIO_MAX = 32768, /* For custom implementations/ASICs */
170 
171 typedef enum FFTXMapDirection {
172  /* No map. Make a map up. */
174 
175  /* Lookup table must be applied via dst[i] = src[lut[i]]; */
177 
178  /* Lookup table must be applied via dst[lut[i]] = src[i]; */
181 
182 /* Codelet options */
183 typedef struct FFTXCodeletOptions {
184  /* Request a specific lookup table direction. Codelets MUST put the
185  * direction in AVTXContext. If the codelet does not respect this, a
186  * conversion will be performed. */
189 
190 /* Maximum number of factors a codelet may have. Arbitrary. */
191 #define TX_MAX_FACTORS 16
192 
193 /* Maximum amount of subtransform functions, subtransforms and factors. Arbitrary. */
194 #define TX_MAX_SUB 4
195 
196 /* Maximum number of returned results for ff_tx_decompose_length. Arbitrary. */
197 #define TX_MAX_DECOMPOSITIONS 512
198 
199 typedef struct FFTXCodelet {
200  const char *name; /* Codelet name, for debugging */
201  av_tx_fn function; /* Codelet function, != NULL */
202  enum AVTXType type; /* Type of codelet transform */
203 #define TX_TYPE_ANY INT32_MAX /* Special type to allow all types */
204 
205  uint64_t flags; /* A combination of AVTXFlags and codelet
206  * flags that describe its properties. */
207 
208  int factors[TX_MAX_FACTORS]; /* Length factors. MUST be coprime. */
209 #define TX_FACTOR_ANY -1 /* When used alone, signals that the codelet
210  * supports all factors. Otherwise, if other
211  * factors are present, it signals that whatever
212  * remains will be supported, as long as the
213  * other factors are a component of the length */
214 
215  int nb_factors; /* Minimum number of factors that have to
216  * be a modulo of the length. Must not be 0. */
217 
218  int min_len; /* Minimum length of transform, must be >= 1 */
219  int max_len; /* Maximum length of transform */
220 #define TX_LEN_UNLIMITED -1 /* Special length value to permit all lengths */
221 
222  int (*init)(AVTXContext *s, /* Optional callback for current context initialization. */
223  const struct FFTXCodelet *cd,
224  uint64_t flags,
226  int len, int inv,
227  const void *scale);
228 
229  int (*uninit)(AVTXContext *s); /* Optional callback for uninitialization. */
230 
231  int cpu_flags; /* CPU flags. If any negative flags like
232  * SLOW are present, will avoid picking.
233  * 0x0 to signal it's a C codelet */
234 #define FF_TX_CPU_FLAGS_ALL 0x0 /* Special CPU flag for C */
235 
236  int prio; /* < 0 = least, 0 = no pref, > 0 = prefer */
237 } FFTXCodelet;
238 
239 struct AVTXContext {
240  /* Fields the root transform and subtransforms use or may use.
241  * NOTE: This section is used by assembly, do not reorder or change */
242  int len; /* Length of the transform */
243  int inv; /* If transform is inverse */
244  int *map; /* Lookup table(s) */
245  TXComplex *exp; /* Any non-pre-baked multiplication factors,
246  * or extra temporary buffer */
247  TXComplex *tmp; /* Temporary buffer, if needed */
248 
249  AVTXContext *sub; /* Subtransform context(s), if needed */
250  av_tx_fn fn[TX_MAX_SUB]; /* Function(s) for the subtransforms */
251  int nb_sub; /* Number of subtransforms.
252  * The reason all of these are set here
253  * rather than in each separate context
254  * is to eliminate extra pointer
255  * dereferences. */
256 
257  /* Fields mainly useul/applicable for the root transform or initialization.
258  * Fields below are not used by assembly code. */
259  const FFTXCodelet *cd[TX_MAX_SUB]; /* Subtransform codelets */
260  const FFTXCodelet *cd_self; /* Codelet for the current context */
261  enum AVTXType type; /* Type of transform */
262  uint64_t flags; /* A combination of AVTXFlags and
263  * codelet flags used when creating */
264  FFTXMapDirection map_dir; /* Direction of AVTXContext->map */
265  float scale_f;
266  double scale_d;
267  void *opaque; /* Free to use by implementations */
268 };
269 
270 /* This function embeds a Ruritanian PFA input map into an existing lookup table
271  * to avoid double permutation. This allows for compound factors to be
272  * synthesized as fast PFA FFTs and embedded into either other or standalone
273  * transforms.
274  * The output CRT map must still be pre-baked into the transform. */
275 #define TX_EMBED_INPUT_PFA_MAP(map, tot_len, d1, d2) \
276  do { \
277  int mtmp[(d1)*(d2)]; \
278  for (int k = 0; k < tot_len; k += (d1)*(d2)) { \
279  memcpy(mtmp, &map[k], (d1)*(d2)*sizeof(*mtmp)); \
280  for (int m = 0; m < (d2); m++) \
281  for (int n = 0; n < (d1); n++) \
282  map[k + m*(d1) + n] = mtmp[(m*(d1) + n*(d2)) % ((d1)*(d2))]; \
283  } \
284  } while (0)
285 
286 /* This function generates a Ruritanian PFA input map into s->map. */
288  int d1, int d2);
289 
290 /* Create a subtransform in the current context with the given parameters.
291  * The flags parameter from FFTXCodelet.init() should be preserved as much
292  * as that's possible.
293  * MUST be called during the sub() callback of each codelet. */
295  uint64_t flags, FFTXCodeletOptions *opts,
296  int len, int inv, const void *scale);
297 
298 /* Clear the context by freeing all tables, maps and subtransforms. */
300 
301 /* Attempt to factorize a length into 2 integers such that
302  * len / dst1 == dst2, where dst1 and dst2 are coprime. */
304  int len, int inv);
305 
306 /* Generate a default map (0->len or 0, (len-1)->1 for inverse transforms)
307  * for a context. */
309 
310 /*
311  * Generates the PFA permutation table into AVTXContext->pfatab. The end table
312  * is appended to the start table.
313  * The `inv` flag should only be enabled if the lookup tables of subtransforms
314  * won't get flattened.
315  */
317  int inv, int n, int m);
318 
319 /*
320  * Generates a standard-ish (slightly modified) Split-Radix revtab into
321  * AVTXContext->map. Invert lookup changes how the mapping needs to be applied.
322  * If it's set to 0, it has to be applied like out[map[i]] = in[i], otherwise
323  * if it's set to 1, has to be applied as out[i] = in[map[i]]
324  */
326 
327 /*
328  * Generates an index into AVTXContext->inplace_idx that if followed in the
329  * specific order, allows the revtab to be done in-place. The sub-transform
330  * and its map should already be initialized.
331  */
333 
334 /*
335  * This generates a parity-based revtab of length len and direction inv.
336  *
337  * Parity means even and odd complex numbers will be split, e.g. the even
338  * coefficients will come first, after which the odd coefficients will be
339  * placed. For example, a 4-point transform's coefficients after reordering:
340  * z[0].re, z[0].im, z[2].re, z[2].im, z[1].re, z[1].im, z[3].re, z[3].im
341  *
342  * The basis argument is the length of the largest non-composite transform
343  * supported, and also implies that the basis/2 transform is supported as well,
344  * as the split-radix algorithm requires it to be.
345  *
346  * The dual_stride argument indicates that both the basis, as well as the
347  * basis/2 transforms support doing two transforms at once, and the coefficients
348  * will be interleaved between each pair in a split-radix like so (stride == 2):
349  * tx1[0], tx1[2], tx2[0], tx2[2], tx1[1], tx1[3], tx2[1], tx2[3]
350  * A non-zero number switches this on, with the value indicating the stride
351  * (how many values of 1 transform to put first before switching to the other).
352  * Must be a power of two or 0. Must be less than the basis.
353  * Value will be clipped to the transform size, so for a basis of 16 and a
354  * dual_stride of 8, dual 8-point transforms will be laid out as if dual_stride
355  * was set to 4.
356  * Usually you'll set this to half the complex numbers that fit in a single
357  * register or 0. This allows to reuse SSE functions as dual-transform
358  * functions in AVX mode.
359  *
360  * If length is smaller than basis/2 this function will not do anything.
361  *
362  * If inv_lookup is set to 1, it will flip the lookup from out[map[i]] = src[i]
363  * to out[i] = src[map[i]].
364  */
367  int basis, int dual_stride);
368 
369 /* Typed init function to initialize shared tables. Will initialize all tables
370  * for all factors of a length. */
371 void ff_tx_init_tabs_float (int len);
372 void ff_tx_init_tabs_double(int len);
373 void ff_tx_init_tabs_int32 (int len);
374 
375 /* Typed init function to initialize an MDCT exptab in a context.
376  * If pre_tab is set, duplicates the entire table, with the first
377  * copy being shuffled according to pre_tab, and the second copy
378  * being the original. */
379 int ff_tx_mdct_gen_exp_float (AVTXContext *s, int *pre_tab);
380 int ff_tx_mdct_gen_exp_double(AVTXContext *s, int *pre_tab);
381 int ff_tx_mdct_gen_exp_int32 (AVTXContext *s, int *pre_tab);
382 
383 /* Lists of codelets */
384 extern const FFTXCodelet * const ff_tx_codelet_list_float_c [];
385 extern const FFTXCodelet * const ff_tx_codelet_list_float_x86 [];
386 extern const FFTXCodelet * const ff_tx_codelet_list_float_aarch64 [];
387 
388 extern const FFTXCodelet * const ff_tx_codelet_list_double_c [];
389 
390 extern const FFTXCodelet * const ff_tx_codelet_list_int32_c [];
391 
392 #endif /* AVUTIL_TX_PRIV_H */
ff_tx_init_tabs_float
void ff_tx_init_tabs_float(int len)
mem_internal.h
AVTXContext::map
int * map
Definition: tx_priv.h:240
thread.h
ff_tx_clear_ctx
void ff_tx_clear_ctx(AVTXContext *s)
Definition: tx.c:289
AVTXContext
Definition: tx_priv.h:235
AVTXContext::map_dir
FFTXMapDirection map_dir
Definition: tx_priv.h:260
basis
static int16_t basis[64][64]
Definition: mpegvideo_enc.c:4198
FFTXCodeletOptions
Definition: tx_priv.h:183
TX_MAX_DECOMPOSITIONS
#define TX_MAX_DECOMPOSITIONS
Definition: tx_priv.h:197
AVComplexFloat
Definition: tx.h:27
ff_tx_mdct_gen_exp_int32
int ff_tx_mdct_gen_exp_int32(AVTXContext *s, int *pre_tab)
FFTXCodelet::nb_factors
int nb_factors
Definition: tx_priv.h:211
AVTXContext::fn
av_tx_fn fn[TX_MAX_SUB]
Definition: tx_priv.h:246
FF_TX_MAP_GATHER
@ FF_TX_MAP_GATHER
Definition: tx_priv.h:176
type
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf type
Definition: writing_filters.txt:86
TX_MAX_SUB
#define TX_MAX_SUB
Definition: tx_priv.h:194
FFTXCodelet::min_len
int min_len
Definition: tx_priv.h:214
FFTXCodelet::type
enum AVTXType type
Definition: tx_priv.h:202
FFTXCodeletOptions::map_dir
FFTXMapDirection map_dir
Definition: tx_priv.h:187
ff_tx_gen_compound_mapping
int ff_tx_gen_compound_mapping(AVTXContext *s, FFTXCodeletOptions *opts, int inv, int n, int m)
Definition: tx.c:74
AVTXContext::nb_sub
int nb_sub
Definition: tx_priv.h:247
AVTXContext::scale_d
double scale_d
Definition: tx_priv.h:262
FFTXCodelet::factors
int factors[TX_MAX_FACTORS]
Definition: tx_priv.h:208
av_tx_fn
void(* av_tx_fn)(AVTXContext *s, void *out, void *in, ptrdiff_t stride)
Function pointer to a function to perform the transform.
Definition: tx.h:151
FFTXCodeletPriority
FFTXCodeletPriority
Definition: tx_priv.h:161
FFTXMapDirection
FFTXMapDirection
Definition: tx_priv.h:171
AVComplexInt32
Definition: tx.h:35
s
#define s(width, name)
Definition: cbs_vp9.c:198
FFTXCodelet::flags
uint64_t flags
Definition: tx_priv.h:205
FFTXCodelet::prio
int prio
Definition: tx_priv.h:232
ff_tx_mdct_gen_exp_float
int ff_tx_mdct_gen_exp_float(AVTXContext *s, int *pre_tab)
AVTXContext::type
enum AVTXType type
Definition: tx_priv.h:257
ff_tx_gen_inplace_map
int ff_tx_gen_inplace_map(AVTXContext *s, int len)
Definition: tx.c:155
AVTXContext::len
int len
Definition: tx_priv.h:238
ff_tx_mdct_gen_exp_double
int ff_tx_mdct_gen_exp_double(AVTXContext *s, int *pre_tab)
FFTXCodelet::uninit
int(* uninit)(AVTXContext *s)
Definition: tx_priv.h:225
FFTXCodelet::cpu_flags
int cpu_flags
Definition: tx_priv.h:227
ff_tx_init_subtx
int ff_tx_init_subtx(AVTXContext *s, enum AVTXType type, uint64_t flags, FFTXCodeletOptions *opts, int len, int inv, const void *scale)
Definition: tx.c:711
opts
AVDictionary * opts
Definition: movenc.c:50
ff_tx_gen_pfa_input_map
int ff_tx_gen_pfa_input_map(AVTXContext *s, FFTXCodeletOptions *opts, int d1, int d2)
Definition: tx.c:43
FF_TX_PRIO_MAX
@ FF_TX_PRIO_MAX
Definition: tx_priv.h:168
FFTXCodelet::init
int(* init)(AVTXContext *s, const struct FFTXCodelet *cd, uint64_t flags, FFTXCodeletOptions *opts, int len, int inv, const void *scale)
Definition: tx_priv.h:218
scale
static void scale(int *out, const int *in, const int w, const int h, const int shift)
Definition: vvc_intra.c:291
FF_TX_PRIO_BASE
@ FF_TX_PRIO_BASE
Definition: tx_priv.h:162
AVTXType
AVTXType
Definition: tx.h:39
ff_tx_codelet_list_float_aarch64
const FFTXCodelet *const ff_tx_codelet_list_float_aarch64[]
Definition: tx_float_init.c:47
ff_tx_gen_split_radix_parity_revtab
int ff_tx_gen_split_radix_parity_revtab(AVTXContext *s, int len, int inv, FFTXCodeletOptions *opts, int basis, int dual_stride)
Definition: tx.c:240
ff_tx_codelet_list_double_c
const FFTXCodelet *const ff_tx_codelet_list_double_c[]
attributes.h
AVTXContext::inv
int inv
Definition: tx_priv.h:239
FFTXCodelet::max_len
int max_len
Definition: tx_priv.h:215
TXComplex
void TXComplex
Definition: tx_priv.h:65
ff_tx_init_tabs_int32
void ff_tx_init_tabs_int32(int len)
ff_tx_init_tabs_double
void ff_tx_init_tabs_double(int len)
AVTXContext::exp
TXComplex * exp
Definition: tx_priv.h:241
common.h
ff_tx_decompose_length
int ff_tx_decompose_length(int dst[TX_MAX_DECOMPOSITIONS], enum AVTXType type, int len, int inv)
Definition: tx.c:411
AVTXContext::tmp
TXComplex * tmp
Definition: tx_priv.h:243
len
int len
Definition: vorbis_enc_data.h:426
AVComplexDouble
Definition: tx.h:31
FF_TX_MAP_SCATTER
@ FF_TX_MAP_SCATTER
Definition: tx_priv.h:179
ff_tx_gen_ptwo_revtab
int ff_tx_gen_ptwo_revtab(AVTXContext *s, FFTXCodeletOptions *opts)
Definition: tx.c:135
AVTXContext::flags
uint64_t flags
Definition: tx_priv.h:258
AVTXContext::scale_f
float scale_f
Definition: tx_priv.h:261
ff_tx_codelet_list_float_c
const FFTXCodelet *const ff_tx_codelet_list_float_c[]
FF_TX_MAP_NONE
@ FF_TX_MAP_NONE
Definition: tx_priv.h:173
FFTXCodelet
Definition: tx_priv.h:199
ff_tx_gen_default_map
int ff_tx_gen_default_map(AVTXContext *s, FFTXCodeletOptions *opts)
Definition: tx.c:524
AVTXContext::cd_self
const FFTXCodelet * cd_self
Definition: tx_priv.h:256
AVTXContext::opaque
void * opaque
Definition: tx_priv.h:263
FFTXCodelet::name
const char * name
Definition: tx_priv.h:200
ff_tx_codelet_list_float_x86
const FFTXCodelet *const ff_tx_codelet_list_float_x86[]
Definition: tx_float_init.c:230
int32_t
int32_t
Definition: audioconvert.c:56
flags
#define flags(name, subs,...)
Definition: cbs_av1.c:482
ff_tx_codelet_list_int32_c
const FFTXCodelet *const ff_tx_codelet_list_int32_c[]
TX_MAX_FACTORS
#define TX_MAX_FACTORS
Definition: tx_priv.h:191
int
int
Definition: ffmpeg_filter.c:409
AVTXContext::sub
AVTXContext * sub
Definition: tx_priv.h:245
tx.h
AVTXContext::cd
const FFTXCodelet * cd[TX_MAX_SUB]
Definition: tx_priv.h:255
FF_TX_PRIO_MIN
@ FF_TX_PRIO_MIN
Definition: tx_priv.h:167