FFmpeg
vaf_spectrumsynth.c
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2016 Paul B Mahol
3  *
4  * This file is part of FFmpeg.
5  *
6  * FFmpeg is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * FFmpeg is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with FFmpeg; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19  */
20 
21 /**
22  * @file
23  * SpectrumSynth filter
24  * @todo support float pixel format
25  */
26 
27 #include "libavutil/mem.h"
28 #include "libavutil/tx.h"
29 #include "libavutil/avassert.h"
30 #include "libavutil/cpu.h"
31 #include "libavutil/ffmath.h"
32 #include "libavutil/opt.h"
33 #include "avfilter.h"
34 #include "formats.h"
35 #include "audio.h"
36 #include "filters.h"
37 #include "internal.h"
38 #include "window_func.h"
39 
43 
44 typedef struct SpectrumSynthContext {
45  const AVClass *class;
47  int channels;
48  int scale;
49  int sliding;
50  int win_func;
51  float overlap;
53 
55  AVTXContext *fft; ///< Fast Fourier Transform context
57  AVComplexFloat **fft_in; ///< bins holder for each (displayed) channels
58  AVComplexFloat **fft_out; ///< bins holder for each (displayed) channels
59  int win_size;
60  int size;
61  int nb_freq;
62  int hop_size;
63  int start, end;
64  int xpos;
65  int xend;
66  int64_t pts;
67  float factor;
69  float *window_func_lut; ///< Window function LUT
71 
72 #define OFFSET(x) offsetof(SpectrumSynthContext, x)
73 #define A AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_AUDIO_PARAM
74 #define V AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_VIDEO_PARAM
75 
76 static const AVOption spectrumsynth_options[] = {
77  { "sample_rate", "set sample rate", OFFSET(sample_rate), AV_OPT_TYPE_INT, {.i64 = 44100}, 15, INT_MAX, A },
78  { "channels", "set channels", OFFSET(channels), AV_OPT_TYPE_INT, {.i64 = 1}, 1, 8, A },
79  { "scale", "set input amplitude scale", OFFSET(scale), AV_OPT_TYPE_INT, {.i64 = LOG}, 0, NB_SCALES-1, V, .unit = "scale" },
80  { "lin", "linear", 0, AV_OPT_TYPE_CONST, {.i64=LINEAR}, 0, 0, V, .unit = "scale" },
81  { "log", "logarithmic", 0, AV_OPT_TYPE_CONST, {.i64=LOG}, 0, 0, V, .unit = "scale" },
82  { "slide", "set input sliding mode", OFFSET(sliding), AV_OPT_TYPE_INT, {.i64 = FULLFRAME}, 0, NB_SLIDES-1, V, .unit = "slide" },
83  { "replace", "consume old columns with new", 0, AV_OPT_TYPE_CONST, {.i64=REPLACE}, 0, 0, V, .unit = "slide" },
84  { "scroll", "consume only most right column", 0, AV_OPT_TYPE_CONST, {.i64=SCROLL}, 0, 0, V, .unit = "slide" },
85  { "fullframe", "consume full frames", 0, AV_OPT_TYPE_CONST, {.i64=FULLFRAME}, 0, 0, V, .unit = "slide" },
86  { "rscroll", "consume only most left column", 0, AV_OPT_TYPE_CONST, {.i64=RSCROLL}, 0, 0, V, .unit = "slide" },
87  WIN_FUNC_OPTION("win_func", OFFSET(win_func), A, 0),
88  { "overlap", "set window overlap", OFFSET(overlap), AV_OPT_TYPE_FLOAT, {.dbl=1}, 0, 1, A },
89  { "orientation", "set orientation", OFFSET(orientation), AV_OPT_TYPE_INT, {.i64=VERTICAL}, 0, NB_ORIENTATIONS-1, V, .unit = "orientation" },
90  { "vertical", NULL, 0, AV_OPT_TYPE_CONST, {.i64=VERTICAL}, 0, 0, V, .unit = "orientation" },
91  { "horizontal", NULL, 0, AV_OPT_TYPE_CONST, {.i64=HORIZONTAL}, 0, 0, V, .unit = "orientation" },
92  { NULL }
93 };
94 
95 AVFILTER_DEFINE_CLASS(spectrumsynth);
96 
98 {
99  SpectrumSynthContext *s = ctx->priv;
102  AVFilterLink *magnitude = ctx->inputs[0];
103  AVFilterLink *phase = ctx->inputs[1];
104  AVFilterLink *outlink = ctx->outputs[0];
106  static const enum AVPixelFormat pix_fmts[] = { AV_PIX_FMT_GRAY8, AV_PIX_FMT_GRAY16,
109  int ret, sample_rates[] = { 48000, -1 };
110 
112  if ((ret = ff_formats_ref (formats, &outlink->incfg.formats )) < 0 ||
113  (ret = ff_add_channel_layout (&layout, &FF_COUNT2LAYOUT(s->channels))) < 0 ||
114  (ret = ff_channel_layouts_ref (layout , &outlink->incfg.channel_layouts)) < 0)
115  return ret;
116 
117  sample_rates[0] = s->sample_rate;
119  if (!formats)
120  return AVERROR(ENOMEM);
121  if ((ret = ff_formats_ref(formats, &outlink->incfg.samplerates)) < 0)
122  return ret;
123 
125  if (!formats)
126  return AVERROR(ENOMEM);
127  if ((ret = ff_formats_ref(formats, &magnitude->outcfg.formats)) < 0)
128  return ret;
129 
131  if (!formats)
132  return AVERROR(ENOMEM);
133  if ((ret = ff_formats_ref(formats, &phase->outcfg.formats)) < 0)
134  return ret;
135 
136  return 0;
137 }
138 
139 static int config_output(AVFilterLink *outlink)
140 {
141  AVFilterContext *ctx = outlink->src;
142  SpectrumSynthContext *s = ctx->priv;
143  int width = ctx->inputs[0]->w;
144  int height = ctx->inputs[0]->h;
145  AVRational time_base = ctx->inputs[0]->time_base;
146  AVRational frame_rate = ctx->inputs[0]->frame_rate;
147  float factor, overlap, scale;
148  int i, ch, ret;
149 
150  outlink->sample_rate = s->sample_rate;
151  outlink->time_base = (AVRational){1, s->sample_rate};
152 
153  if (width != ctx->inputs[1]->w ||
154  height != ctx->inputs[1]->h) {
156  "Magnitude and Phase sizes differ (%dx%d vs %dx%d).\n",
157  width, height,
158  ctx->inputs[1]->w, ctx->inputs[1]->h);
159  return AVERROR_INVALIDDATA;
160  } else if (av_cmp_q(time_base, ctx->inputs[1]->time_base) != 0) {
162  "Magnitude and Phase time bases differ (%d/%d vs %d/%d).\n",
163  time_base.num, time_base.den,
164  ctx->inputs[1]->time_base.num,
165  ctx->inputs[1]->time_base.den);
166  return AVERROR_INVALIDDATA;
167  } else if (av_cmp_q(frame_rate, ctx->inputs[1]->frame_rate) != 0) {
169  "Magnitude and Phase framerates differ (%d/%d vs %d/%d).\n",
170  frame_rate.num, frame_rate.den,
171  ctx->inputs[1]->frame_rate.num,
172  ctx->inputs[1]->frame_rate.den);
173  return AVERROR_INVALIDDATA;
174  }
175 
176  s->size = s->orientation == VERTICAL ? height / s->channels : width / s->channels;
177  s->xend = s->orientation == VERTICAL ? width : height;
178 
179  s->win_size = s->size * 2;
180  s->nb_freq = s->size;
181 
182  ret = av_tx_init(&s->fft, &s->tx_fn, AV_TX_FLOAT_FFT, 1, s->win_size, &scale, 0);
183  if (ret < 0) {
184  av_log(ctx, AV_LOG_ERROR, "Unable to create FFT context. "
185  "The window size might be too high.\n");
186  return ret;
187  }
188 
189  s->fft_in = av_calloc(s->channels, sizeof(*s->fft_in));
190  if (!s->fft_in)
191  return AVERROR(ENOMEM);
192  s->fft_out = av_calloc(s->channels, sizeof(*s->fft_out));
193  if (!s->fft_out)
194  return AVERROR(ENOMEM);
195 
196  for (ch = 0; ch < s->channels; ch++) {
197  s->fft_in[ch] = av_calloc(FFALIGN(s->win_size, av_cpu_max_align()), sizeof(**s->fft_in));
198  if (!s->fft_in[ch])
199  return AVERROR(ENOMEM);
200 
201  s->fft_out[ch] = av_calloc(FFALIGN(s->win_size, av_cpu_max_align()), sizeof(**s->fft_out));
202  if (!s->fft_out[ch])
203  return AVERROR(ENOMEM);
204  }
205 
206  s->buffer = ff_get_audio_buffer(outlink, s->win_size * 2);
207  if (!s->buffer)
208  return AVERROR(ENOMEM);
209 
210  /* pre-calc windowing function */
211  s->window_func_lut = av_realloc_f(s->window_func_lut, s->win_size,
212  sizeof(*s->window_func_lut));
213  if (!s->window_func_lut)
214  return AVERROR(ENOMEM);
215  generate_window_func(s->window_func_lut, s->win_size, s->win_func, &overlap);
216  if (s->overlap == 1)
217  s->overlap = overlap;
218  s->hop_size = (1 - s->overlap) * s->win_size;
219  for (factor = 0, i = 0; i < s->win_size; i++) {
220  factor += s->window_func_lut[i] * s->window_func_lut[i];
221  }
222  s->factor = (factor / s->win_size) / FFMAX(1 / (1 - s->overlap) - 1, 1);
223 
224  return 0;
225 }
226 
228  int x, int y, int f, int ch)
229 {
230  const int m_linesize = s->magnitude->linesize[0];
231  const int p_linesize = s->phase->linesize[0];
232  const uint16_t *m = (uint16_t *)(s->magnitude->data[0] + y * m_linesize);
233  const uint16_t *p = (uint16_t *)(s->phase->data[0] + y * p_linesize);
234  float magnitude, phase;
235 
236  switch (s->scale) {
237  case LINEAR:
238  magnitude = m[x] / (double)UINT16_MAX;
239  break;
240  case LOG:
241  magnitude = ff_exp10(((m[x] / (double)UINT16_MAX) - 1.) * 6.);
242  break;
243  default:
244  av_assert0(0);
245  }
246  phase = ((p[x] / (double)UINT16_MAX) * 2. - 1.) * M_PI;
247 
248  s->fft_in[ch][f].re = magnitude * cos(phase);
249  s->fft_in[ch][f].im = magnitude * sin(phase);
250 }
251 
253  int x, int y, int f, int ch)
254 {
255  const int m_linesize = s->magnitude->linesize[0];
256  const int p_linesize = s->phase->linesize[0];
257  const uint8_t *m = (uint8_t *)(s->magnitude->data[0] + y * m_linesize);
258  const uint8_t *p = (uint8_t *)(s->phase->data[0] + y * p_linesize);
259  float magnitude, phase;
260 
261  switch (s->scale) {
262  case LINEAR:
263  magnitude = m[x] / (double)UINT8_MAX;
264  break;
265  case LOG:
266  magnitude = ff_exp10(((m[x] / (double)UINT8_MAX) - 1.) * 6.);
267  break;
268  default:
269  av_assert0(0);
270  }
271  phase = ((p[x] / (double)UINT8_MAX) * 2. - 1.) * M_PI;
272 
273  s->fft_in[ch][f].re = magnitude * cos(phase);
274  s->fft_in[ch][f].im = magnitude * sin(phase);
275 }
276 
277 static void read_fft_data(AVFilterContext *ctx, int x, int h, int ch)
278 {
279  SpectrumSynthContext *s = ctx->priv;
280  AVFilterLink *inlink = ctx->inputs[0];
281  int start = h * (s->channels - ch) - 1;
282  int end = h * (s->channels - ch - 1);
283  int y, f;
284 
285  switch (s->orientation) {
286  case VERTICAL:
287  switch (inlink->format) {
289  case AV_PIX_FMT_GRAY16:
290  for (y = start, f = 0; y >= end; y--, f++) {
291  read16_fft_bin(s, x, y, f, ch);
292  }
293  break;
294  case AV_PIX_FMT_YUVJ444P:
295  case AV_PIX_FMT_YUV444P:
296  case AV_PIX_FMT_GRAY8:
297  for (y = start, f = 0; y >= end; y--, f++) {
298  read8_fft_bin(s, x, y, f, ch);
299  }
300  break;
301  }
302  break;
303  case HORIZONTAL:
304  switch (inlink->format) {
306  case AV_PIX_FMT_GRAY16:
307  for (y = end, f = 0; y <= start; y++, f++) {
308  read16_fft_bin(s, y, x, f, ch);
309  }
310  break;
311  case AV_PIX_FMT_YUVJ444P:
312  case AV_PIX_FMT_YUV444P:
313  case AV_PIX_FMT_GRAY8:
314  for (y = end, f = 0; y <= start; y++, f++) {
315  read8_fft_bin(s, y, x, f, ch);
316  }
317  break;
318  }
319  break;
320  }
321 }
322 
323 static void synth_window(AVFilterContext *ctx, int x)
324 {
325  SpectrumSynthContext *s = ctx->priv;
326  const int h = s->size;
327  int nb = s->win_size;
328  int y, f, ch;
329 
330  for (ch = 0; ch < s->channels; ch++) {
331  read_fft_data(ctx, x, h, ch);
332 
333  for (y = h; y <= s->nb_freq; y++) {
334  s->fft_in[ch][y].re = 0;
335  s->fft_in[ch][y].im = 0;
336  }
337 
338  for (y = s->nb_freq + 1, f = s->nb_freq - 1; y < nb; y++, f--) {
339  s->fft_in[ch][y].re = s->fft_in[ch][f].re;
340  s->fft_in[ch][y].im = -s->fft_in[ch][f].im;
341  }
342 
343  s->tx_fn(s->fft, s->fft_out[ch], s->fft_in[ch], sizeof(AVComplexFloat));
344  }
345 }
346 
347 static int try_push_frame(AVFilterContext *ctx, int x)
348 {
349  SpectrumSynthContext *s = ctx->priv;
350  AVFilterLink *outlink = ctx->outputs[0];
351  const float factor = s->factor;
352  int ch, n, i, ret;
353  int start, end;
354  AVFrame *out;
355 
356  synth_window(ctx, x);
357 
358  for (ch = 0; ch < s->channels; ch++) {
359  float *buf = (float *)s->buffer->extended_data[ch];
360  int j, k;
361 
362  start = s->start;
363  end = s->end;
364  k = end;
365  for (i = 0, j = start; j < k && i < s->win_size; i++, j++) {
366  buf[j] += s->fft_out[ch][i].re;
367  }
368 
369  for (; i < s->win_size; i++, j++) {
370  buf[j] = s->fft_out[ch][i].re;
371  }
372 
373  start += s->hop_size;
374  end = j;
375 
376  if (start >= s->win_size) {
377  start -= s->win_size;
378  end -= s->win_size;
379 
380  if (ch == s->channels - 1) {
381  float *dst;
382  int c;
383 
384  out = ff_get_audio_buffer(outlink, s->win_size);
385  if (!out) {
386  av_frame_free(&s->magnitude);
387  av_frame_free(&s->phase);
388  return AVERROR(ENOMEM);
389  }
390 
391  out->pts = s->pts;
392  s->pts += s->win_size;
393  for (c = 0; c < s->channels; c++) {
394  dst = (float *)out->extended_data[c];
395  buf = (float *)s->buffer->extended_data[c];
396 
397  for (n = 0; n < s->win_size; n++) {
398  dst[n] = buf[n] * factor;
399  }
400  memmove(buf, buf + s->win_size, s->win_size * 4);
401  }
402 
403  ret = ff_filter_frame(outlink, out);
404  if (ret < 0)
405  return ret;
406  }
407  }
408  }
409 
410  s->start = start;
411  s->end = end;
412 
413  return 0;
414 }
415 
417 {
418  SpectrumSynthContext *s = ctx->priv;
419  int ret, x;
420 
421  if (!(s->magnitude && s->phase))
422  return 0;
423 
424  switch (s->sliding) {
425  case REPLACE:
426  ret = try_push_frame(ctx, s->xpos);
427  s->xpos++;
428  if (s->xpos >= s->xend)
429  s->xpos = 0;
430  break;
431  case SCROLL:
432  s->xpos = s->xend - 1;
433  ret = try_push_frame(ctx, s->xpos);
434  break;
435  case RSCROLL:
436  s->xpos = 0;
437  ret = try_push_frame(ctx, s->xpos);
438  break;
439  case FULLFRAME:
440  for (x = 0; x < s->xend; x++) {
441  ret = try_push_frame(ctx, x);
442  if (ret < 0)
443  break;
444  }
445  break;
446  default:
447  av_assert0(0);
448  }
449 
450  av_frame_free(&s->magnitude);
451  av_frame_free(&s->phase);
452  return ret;
453 }
454 
456 {
457  SpectrumSynthContext *s = ctx->priv;
458  AVFrame **staging[2] = { &s->magnitude, &s->phase };
459  int64_t pts;
460  int i, ret;
461 
463 
464  for (i = 0; i < 2; i++) {
465  if (*staging[i])
466  continue;
467  ret = ff_inlink_consume_frame(ctx->inputs[i], staging[i]);
468  if (ret < 0)
469  return ret;
470  if (ret) {
472  return try_push_frames(ctx);
473  }
474  }
475 
476  for (i = 0; i < 2; i++) {
477  if (ff_inlink_acknowledge_status(ctx->inputs[i], &ret, &pts)) {
478  ff_outlink_set_status(ctx->outputs[0], ret, pts);
479  ff_inlink_set_status(ctx->inputs[1 - i], ret);
480  return 0;
481  }
482  }
483 
484  if (ff_outlink_frame_wanted(ctx->outputs[0])) {
485  for (i = 0; i < 2; i++) {
486  if (!*staging[i])
487  ff_inlink_request_frame(ctx->inputs[i]);
488  }
489  }
490 
491  return FFERROR_NOT_READY;
492 }
493 
495 {
496  SpectrumSynthContext *s = ctx->priv;
497  int i;
498 
499  av_frame_free(&s->magnitude);
500  av_frame_free(&s->phase);
501  av_frame_free(&s->buffer);
502 
503  av_tx_uninit(&s->fft);
504 
505  if (s->fft_in) {
506  for (i = 0; i < s->channels; i++)
507  av_freep(&s->fft_in[i]);
508  }
509  if (s->fft_out) {
510  for (i = 0; i < s->channels; i++)
511  av_freep(&s->fft_out[i]);
512  }
513  av_freep(&s->fft_in);
514  av_freep(&s->fft_out);
515  av_freep(&s->window_func_lut);
516 }
517 
519  {
520  .name = "magnitude",
521  .type = AVMEDIA_TYPE_VIDEO,
522  },
523  {
524  .name = "phase",
525  .type = AVMEDIA_TYPE_VIDEO,
526  },
527 };
528 
530  {
531  .name = "default",
532  .type = AVMEDIA_TYPE_AUDIO,
533  .config_props = config_output,
534  },
535 };
536 
538  .name = "spectrumsynth",
539  .description = NULL_IF_CONFIG_SMALL("Convert input spectrum videos to audio output."),
540  .uninit = uninit,
541  .activate = activate,
542  .priv_size = sizeof(SpectrumSynthContext),
546  .priv_class = &spectrumsynth_class,
547 };
formats
formats
Definition: signature.h:48
ff_get_audio_buffer
AVFrame * ff_get_audio_buffer(AVFilterLink *link, int nb_samples)
Request an audio samples buffer with a specific set of permissions.
Definition: audio.c:97
AV_SAMPLE_FMT_FLTP
@ AV_SAMPLE_FMT_FLTP
float, planar
Definition: samplefmt.h:66
AVFilterChannelLayouts
A list of supported channel layouts.
Definition: formats.h:85
try_push_frames
static int try_push_frames(AVFilterContext *ctx)
Definition: vaf_spectrumsynth.c:416
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:71
AVFilterFormatsConfig::samplerates
AVFilterFormats * samplerates
Lists of supported sample rates, only for audio.
Definition: avfilter.h:515
ff_exp10
static av_always_inline double ff_exp10(double x)
Compute 10^x for floating point values.
Definition: ffmath.h:42
AVERROR
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
opt.h
ff_make_format_list
AVFilterFormats * ff_make_format_list(const int *fmts)
Create a list of supported formats.
Definition: formats.c:436
AVFilterFormatsConfig::channel_layouts
AVFilterChannelLayouts * channel_layouts
Lists of supported channel layouts, only for audio.
Definition: avfilter.h:520
out
FILE * out
Definition: movenc.c:55
ff_filter_frame
int ff_filter_frame(AVFilterLink *link, AVFrame *frame)
Send a frame of data to the next filter.
Definition: avfilter.c:1015
sample_fmts
static enum AVSampleFormat sample_fmts[]
Definition: adpcmenc.c:948
ff_channel_layouts_ref
int ff_channel_layouts_ref(AVFilterChannelLayouts *f, AVFilterChannelLayouts **ref)
Add *ref as a new reference to f.
Definition: formats.c:674
FFERROR_NOT_READY
return FFERROR_NOT_READY
Definition: filter_design.txt:204
SpectrumSynthContext::size
int size
Definition: vaf_spectrumsynth.c:60
SpectrumSynthContext::scale
int scale
Definition: vaf_spectrumsynth.c:48
AVTXContext
Definition: tx_priv.h:235
inlink
The exact code depends on how similar the blocks are and how related they are to the and needs to apply these operations to the correct inlink or outlink if there are several Macros are available to factor that when no extra processing is inlink
Definition: filter_design.txt:212
SCROLL
@ SCROLL
Definition: vaf_spectrumsynth.c:41
av_frame_free
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
Definition: frame.c:160
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:375
MagnitudeScale
MagnitudeScale
Definition: vaf_spectrumsynth.c:40
AVOption
AVOption.
Definition: opt.h:346
FILTER_QUERY_FUNC
#define FILTER_QUERY_FUNC(func)
Definition: internal.h:159
AVComplexFloat
Definition: tx.h:27
WIN_FUNC_OPTION
#define WIN_FUNC_OPTION(win_func_opt_name, win_func_offset, flag, default_window_func)
Definition: window_func.h:37
SpectrumSynthContext
Definition: vaf_spectrumsynth.c:44
FFMAX
#define FFMAX(a, b)
Definition: macros.h:47
AVFilter::name
const char * name
Filter name.
Definition: avfilter.h:170
SpectrumSynthContext::buffer
AVFrame * buffer
Definition: vaf_spectrumsynth.c:68
sample_rate
sample_rate
Definition: ffmpeg_filter.c:424
av_tx_init
av_cold int av_tx_init(AVTXContext **ctx, av_tx_fn *tx, enum AVTXType type, int inv, int len, const void *scale, uint64_t flags)
Initialize a transform context with the given configuration (i)MDCTs with an odd length are currently...
Definition: tx.c:903
AVFilterFormats
A list of supported formats for one end of a filter link.
Definition: formats.h:64
formats.h
config_output
static int config_output(AVFilterLink *outlink)
Definition: vaf_spectrumsynth.c:139
ff_inlink_consume_frame
int ff_inlink_consume_frame(AVFilterLink *link, AVFrame **rframe)
Take a frame from the link's FIFO and update the link's stats.
Definition: avfilter.c:1442
FF_FILTER_FORWARD_STATUS_BACK_ALL
#define FF_FILTER_FORWARD_STATUS_BACK_ALL(outlink, filter)
Forward the status on an output link to all input links.
Definition: filters.h:212
AVFILTER_DEFINE_CLASS
AVFILTER_DEFINE_CLASS(spectrumsynth)
SpectrumSynthContext::end
int end
Definition: vaf_spectrumsynth.c:63
SpectrumSynthContext::fft
AVTXContext * fft
Fast Fourier Transform context.
Definition: vaf_spectrumsynth.c:55
pts
static int64_t pts
Definition: transcode_aac.c:644
AV_PIX_FMT_GRAY16
#define AV_PIX_FMT_GRAY16
Definition: pixfmt.h:462
SpectrumSynthContext::start
int start
Definition: vaf_spectrumsynth.c:63
SpectrumSynthContext::sliding
int sliding
Definition: vaf_spectrumsynth.c:49
AVRational::num
int num
Numerator.
Definition: rational.h:59
SpectrumSynthContext::window_func_lut
float * window_func_lut
Window function LUT.
Definition: vaf_spectrumsynth.c:69
AVFilterPad
A filter pad used for either input or output.
Definition: internal.h:33
SpectrumSynthContext::magnitude
AVFrame * magnitude
Definition: vaf_spectrumsynth.c:54
SpectrumSynthContext::sample_rate
int sample_rate
Definition: vaf_spectrumsynth.c:46
avassert.h
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:180
av_cold
#define av_cold
Definition: attributes.h:90
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
ff_outlink_set_status
static void ff_outlink_set_status(AVFilterLink *link, int status, int64_t pts)
Set the status field of a link from the source filter.
Definition: filters.h:189
ff_inlink_request_frame
void ff_inlink_request_frame(AVFilterLink *link)
Mark that a frame is wanted on the link.
Definition: avfilter.c:1568
width
#define width
s
#define s(width, name)
Definition: cbs_vp9.c:198
AV_PIX_FMT_YUV444P16
#define AV_PIX_FMT_YUV444P16
Definition: pixfmt.h:491
Orientation
Orientation
Definition: avf_showspectrum.c:57
AVMEDIA_TYPE_AUDIO
@ AVMEDIA_TYPE_AUDIO
Definition: avutil.h:202
ff_formats_ref
int ff_formats_ref(AVFilterFormats *f, AVFilterFormats **ref)
Add *ref as a new reference to formats.
Definition: formats.c:679
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:40
NB_SLIDES
@ NB_SLIDES
Definition: vaf_spectrumsynth.c:41
filters.h
pix_fmts
static enum AVPixelFormat pix_fmts[]
Definition: libkvazaar.c:304
AV_TX_FLOAT_FFT
@ AV_TX_FLOAT_FFT
Standard complex to complex FFT with sample data type of AVComplexFloat, AVComplexDouble or AVComplex...
Definition: tx.h:47
ctx
AVFormatContext * ctx
Definition: movenc.c:49
channels
channels
Definition: aptx.h:31
synth_window
static void synth_window(AVFilterContext *ctx, int x)
Definition: vaf_spectrumsynth.c:323
A
#define A
Definition: vaf_spectrumsynth.c:73
FILTER_INPUTS
#define FILTER_INPUTS(array)
Definition: internal.h:182
AV_PIX_FMT_YUVJ444P
@ AV_PIX_FMT_YUVJ444P
planar YUV 4:4:4, 24bpp, full scale (JPEG), deprecated in favor of AV_PIX_FMT_YUV444P and setting col...
Definition: pixfmt.h:87
OFFSET
#define OFFSET(x)
Definition: vaf_spectrumsynth.c:72
av_realloc_f
#define av_realloc_f(p, o, n)
Definition: tableprint_vlc.h:32
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:66
NULL
#define NULL
Definition: coverity.c:32
ff_vaf_spectrumsynth
const AVFilter ff_vaf_spectrumsynth
Definition: vaf_spectrumsynth.c:537
AVRational
Rational number (pair of numerator and denominator).
Definition: rational.h:58
double
double
Definition: af_crystalizer.c:131
av_cpu_max_align
size_t av_cpu_max_align(void)
Get the maximum data alignment that may be required by FFmpeg.
Definition: cpu.c:268
generate_window_func
static void generate_window_func(float *lut, int N, int win_func, float *overlap)
Definition: window_func.h:63
AV_PIX_FMT_GRAY8
@ AV_PIX_FMT_GRAY8
Y , 8bpp.
Definition: pixfmt.h:81
ff_add_channel_layout
int ff_add_channel_layout(AVFilterChannelLayouts **l, const AVChannelLayout *channel_layout)
Definition: formats.c:522
try_push_frame
static int try_push_frame(AVFilterContext *ctx, int x)
Definition: vaf_spectrumsynth.c:347
ff_inlink_acknowledge_status
int ff_inlink_acknowledge_status(AVFilterLink *link, int *rstatus, int64_t *rpts)
Test and acknowledge the change of status on the link.
Definition: avfilter.c:1389
spectrumsynth_outputs
static const AVFilterPad spectrumsynth_outputs[]
Definition: vaf_spectrumsynth.c:529
SpectrumSynthContext::xend
int xend
Definition: vaf_spectrumsynth.c:65
VERTICAL
@ VERTICAL
Definition: vaf_spectrumsynth.c:42
c
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
Definition: undefined.txt:32
SpectrumSynthContext::phase
AVFrame * phase
Definition: vaf_spectrumsynth.c:54
SpectrumSynthContext::xpos
int xpos
Definition: vaf_spectrumsynth.c:64
f
f
Definition: af_crystalizer.c:121
ff_inlink_set_status
void ff_inlink_set_status(AVFilterLink *link, int status)
Set the status on an input link.
Definition: avfilter.c:1577
NULL_IF_CONFIG_SMALL
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
Definition: internal.h:94
cpu.h
for
for(k=2;k<=8;++k)
Definition: h264pred_template.c:425
spectrumsynth_inputs
static const AVFilterPad spectrumsynth_inputs[]
Definition: vaf_spectrumsynth.c:518
read_fft_data
static void read_fft_data(AVFilterContext *ctx, int x, int h, int ch)
Definition: vaf_spectrumsynth.c:277
AV_SAMPLE_FMT_NONE
@ AV_SAMPLE_FMT_NONE
Definition: samplefmt.h:56
SpectrumSynthContext::factor
float factor
Definition: vaf_spectrumsynth.c:67
SpectrumSynthContext::hop_size
int hop_size
Definition: vaf_spectrumsynth.c:62
height
#define height
SpectrumSynthContext::orientation
int orientation
Definition: vaf_spectrumsynth.c:52
NB_ORIENTATIONS
@ NB_ORIENTATIONS
Definition: vaf_spectrumsynth.c:42
read16_fft_bin
static void read16_fft_bin(SpectrumSynthContext *s, int x, int y, int f, int ch)
Definition: vaf_spectrumsynth.c:227
SpectrumSynthContext::win_func
int win_func
Definition: vaf_spectrumsynth.c:50
M_PI
#define M_PI
Definition: mathematics.h:67
av_tx_uninit
av_cold void av_tx_uninit(AVTXContext **ctx)
Frees a context and sets *ctx to NULL, does nothing when *ctx == NULL.
Definition: tx.c:295
sample_rates
sample_rates
Definition: ffmpeg_filter.c:424
internal.h
AV_OPT_TYPE_FLOAT
@ AV_OPT_TYPE_FLOAT
Definition: opt.h:238
layout
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel layout
Definition: filter_design.txt:18
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:256
HORIZONTAL
@ HORIZONTAL
Definition: vaf_spectrumsynth.c:42
SpectrumSynthContext::channels
int channels
Definition: vaf_spectrumsynth.c:47
AVSampleFormat
AVSampleFormat
Audio sample formats.
Definition: samplefmt.h:55
SpectrumSynthContext::nb_freq
int nb_freq
Definition: vaf_spectrumsynth.c:61
SpectrumSynthContext::overlap
float overlap
Definition: vaf_spectrumsynth.c:51
AVFilterPad::name
const char * name
Pad name.
Definition: internal.h:39
SpectrumSynthContext::tx_fn
av_tx_fn tx_fn
Definition: vaf_spectrumsynth.c:56
av_calloc
void * av_calloc(size_t nmemb, size_t size)
Definition: mem.c:264
av_cmp_q
static int av_cmp_q(AVRational a, AVRational b)
Compare two rationals.
Definition: rational.h:89
AVFilter
Filter definition.
Definition: avfilter.h:166
ret
ret
Definition: filter_design.txt:187
SpectrumSynthContext::fft_in
AVComplexFloat ** fft_in
bins holder for each (displayed) channels
Definition: vaf_spectrumsynth.c:57
FF_COUNT2LAYOUT
#define FF_COUNT2LAYOUT(c)
Encode a channel count as a channel layout.
Definition: formats.h:102
window_func.h
FULLFRAME
@ FULLFRAME
Definition: vaf_spectrumsynth.c:41
query_formats
static int query_formats(AVFilterContext *ctx)
Definition: vaf_spectrumsynth.c:97
spectrumsynth_options
static const AVOption spectrumsynth_options[]
Definition: vaf_spectrumsynth.c:76
AVRational::den
int den
Denominator.
Definition: rational.h:60
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:72
read8_fft_bin
static void read8_fft_bin(SpectrumSynthContext *s, int x, int y, int f, int ch)
Definition: vaf_spectrumsynth.c:252
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Definition: opt.h:235
avfilter.h
ffmath.h
AV_PIX_FMT_YUV444P
@ AV_PIX_FMT_YUV444P
planar YUV 4:4:4, 24bpp, (1 Cr & Cb sample per 1x1 Y samples)
Definition: pixfmt.h:78
AVFilterContext
An instance of a filter.
Definition: avfilter.h:407
factor
static const int factor[16]
Definition: vf_pp7.c:79
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
mem.h
audio.h
AVFilterFormatsConfig::formats
AVFilterFormats * formats
List of supported formats (pixel or sample).
Definition: avfilter.h:510
V
#define V
Definition: vaf_spectrumsynth.c:74
scale
static void scale(int *out, const int *in, const int w, const int h, const int shift)
Definition: intra.c:291
FFALIGN
#define FFALIGN(x, a)
Definition: macros.h:78
activate
static int activate(AVFilterContext *ctx)
Definition: vaf_spectrumsynth.c:455
FILTER_OUTPUTS
#define FILTER_OUTPUTS(array)
Definition: internal.h:183
av_freep
#define av_freep(p)
Definition: tableprint_vlc.h:34
LOG
@ LOG
Definition: vaf_spectrumsynth.c:40
SpectrumSynthContext::win_size
int win_size
Definition: vaf_spectrumsynth.c:59
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
AVERROR_INVALIDDATA
#define AVERROR_INVALIDDATA
Invalid data found when processing input.
Definition: error.h:61
h
h
Definition: vp9dsp_template.c:2038
ff_outlink_frame_wanted
the definition of that something depends on the semantic of the filter The callback must examine the status of the filter s links and proceed accordingly The status of output links is stored in the status_in and status_out fields and tested by the ff_outlink_frame_wanted() function. If this function returns true
SpectrumSynthContext::fft_out
AVComplexFloat ** fft_out
bins holder for each (displayed) channels
Definition: vaf_spectrumsynth.c:58
LINEAR
@ LINEAR
Definition: vaf_spectrumsynth.c:40
REPLACE
@ REPLACE
Definition: vaf_spectrumsynth.c:41
RSCROLL
@ RSCROLL
Definition: vaf_spectrumsynth.c:41
AV_OPT_TYPE_CONST
@ AV_OPT_TYPE_CONST
Definition: opt.h:244
uninit
static av_cold void uninit(AVFilterContext *ctx)
Definition: vaf_spectrumsynth.c:494
NB_SCALES
@ NB_SCALES
Definition: vaf_spectrumsynth.c:40
SpectrumSynthContext::pts
int64_t pts
Definition: vaf_spectrumsynth.c:66
SlideMode
SlideMode
Definition: avf_ahistogram.c:32
ff_filter_set_ready
void ff_filter_set_ready(AVFilterContext *filter, unsigned priority)
Mark a filter ready and schedule it for activation.
Definition: avfilter.c:235
tx.h