FFmpeg
vf_fps.c
Go to the documentation of this file.
1 /*
2  * Copyright 2007 Bobby Bingham
3  * Copyright 2012 Robert Nagy <ronag89 gmail com>
4  * Copyright 2012 Anton Khirnov <anton khirnov net>
5  * Copyright 2018 Calvin Walton <calvin.walton@kepstin.ca>
6  *
7  * This file is part of FFmpeg.
8  *
9  * FFmpeg is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU Lesser General Public
11  * License as published by the Free Software Foundation; either
12  * version 2.1 of the License, or (at your option) any later version.
13  *
14  * FFmpeg is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17  * Lesser General Public License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public
20  * License along with FFmpeg; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22  */
23 
24 /**
25  * @file
26  * a filter enforcing given constant framerate
27  */
28 
29 #include <float.h>
30 #include <stdint.h>
31 
32 #include "libavutil/avassert.h"
33 #include "libavutil/eval.h"
34 #include "libavutil/mathematics.h"
35 #include "libavutil/opt.h"
36 #include "avfilter.h"
37 #include "ccfifo.h"
38 #include "filters.h"
39 #include "video.h"
40 
41 enum EOFAction {
45 };
46 
47 static const char *const var_names[] = {
48  "source_fps",
49  "ntsc",
50  "pal",
51  "film",
52  "ntsc_film",
53  NULL
54 };
55 
56 enum var_name {
63 };
64 
65 static const double ntsc_fps = 30000.0 / 1001.0;
66 static const double pal_fps = 25.0;
67 static const double film_fps = 24.0;
68 static const double ntsc_film_fps = 24000.0 / 1001.0;
69 
70 typedef struct FPSContext {
71  const AVClass *class;
72 
73  double start_time; ///< pts, in seconds, of the expected first frame
74 
75  char *framerate; ///< expression that defines the target framerate
76  int rounding; ///< AVRounding method for timestamps
77  int eof_action; ///< action performed for last frame in FIFO
78 
79  /* Set during outlink configuration */
80  int64_t in_pts_off; ///< input frame pts offset for start_time handling
81  int64_t out_pts_off; ///< output frame pts offset for start_time handling
82 
83  /* Runtime state */
84  int status; ///< buffered input status
85  int64_t status_pts; ///< buffered input status timestamp
86 
87  AVFrame *frames[2]; ///< buffered frames
88  int frames_count; ///< number of buffered frames
89  CCFifo cc_fifo; ///< closed captions
90 
91  int64_t next_pts; ///< pts of the next frame to output
92 
93  /* statistics */
94  int cur_frame_out; ///< number of times current frame has been output
95  int frames_in; ///< number of frames on input
96  int frames_out; ///< number of frames on output
97  int dup; ///< number of frames duplicated
98  int drop; ///< number of framed dropped
99 } FPSContext;
100 
101 #define OFFSET(x) offsetof(FPSContext, x)
102 #define V AV_OPT_FLAG_VIDEO_PARAM
103 #define F AV_OPT_FLAG_FILTERING_PARAM
104 static const AVOption fps_options[] = {
105  { "fps", "A string describing desired output framerate", OFFSET(framerate), AV_OPT_TYPE_STRING, { .str = "25" }, 0, 0, V|F },
106  { "start_time", "Assume the first PTS should be this value.", OFFSET(start_time), AV_OPT_TYPE_DOUBLE, { .dbl = DBL_MAX}, -DBL_MAX, DBL_MAX, V|F },
107  { "round", "set rounding method for timestamps", OFFSET(rounding), AV_OPT_TYPE_INT, { .i64 = AV_ROUND_NEAR_INF }, 0, 5, V|F, .unit = "round" },
108  { "zero", "round towards 0", 0, AV_OPT_TYPE_CONST, { .i64 = AV_ROUND_ZERO }, 0, 0, V|F, .unit = "round" },
109  { "inf", "round away from 0", 0, AV_OPT_TYPE_CONST, { .i64 = AV_ROUND_INF }, 0, 0, V|F, .unit = "round" },
110  { "down", "round towards -infty", 0, AV_OPT_TYPE_CONST, { .i64 = AV_ROUND_DOWN }, 0, 0, V|F, .unit = "round" },
111  { "up", "round towards +infty", 0, AV_OPT_TYPE_CONST, { .i64 = AV_ROUND_UP }, 0, 0, V|F, .unit = "round" },
112  { "near", "round to nearest", 0, AV_OPT_TYPE_CONST, { .i64 = AV_ROUND_NEAR_INF }, 0, 0, V|F, .unit = "round" },
113  { "eof_action", "action performed for last frame", OFFSET(eof_action), AV_OPT_TYPE_INT, { .i64 = EOF_ACTION_ROUND }, 0, EOF_ACTION_NB-1, V|F, .unit = "eof_action" },
114  { "round", "round similar to other frames", 0, AV_OPT_TYPE_CONST, { .i64 = EOF_ACTION_ROUND }, 0, 0, V|F, .unit = "eof_action" },
115  { "pass", "pass through last frame", 0, AV_OPT_TYPE_CONST, { .i64 = EOF_ACTION_PASS }, 0, 0, V|F, .unit = "eof_action" },
116  { NULL }
117 };
118 
120 
122 {
123  FPSContext *s = ctx->priv;
124 
125  s->status_pts = AV_NOPTS_VALUE;
126  s->next_pts = AV_NOPTS_VALUE;
127 
128  return 0;
129 }
130 
131 /* Remove the first frame from the buffer, returning it */
133 {
134  AVFrame *frame;
135 
136  /* Must only be called when there are frames in the buffer */
137  av_assert1(s->frames_count > 0);
138 
139  frame = s->frames[0];
140  s->frames[0] = s->frames[1];
141  s->frames[1] = NULL;
142  s->frames_count--;
143 
144  /* Update statistics counters */
145  s->frames_out += s->cur_frame_out;
146  if (s->cur_frame_out > 1) {
147  av_log(ctx, AV_LOG_DEBUG, "Duplicated frame with pts %"PRId64" %d times\n",
148  frame->pts, s->cur_frame_out - 1);
149  s->dup += s->cur_frame_out - 1;
150  } else if (s->cur_frame_out == 0) {
151  av_log(ctx, AV_LOG_DEBUG, "Dropping frame with pts %"PRId64"\n",
152  frame->pts);
153  s->drop++;
154  }
155  s->cur_frame_out = 0;
156 
157  return frame;
158 }
159 
161 {
162  FPSContext *s = ctx->priv;
163 
164  AVFrame *frame;
165 
166  while (s->frames_count > 0) {
167  frame = shift_frame(ctx, s);
169  }
170  ff_ccfifo_uninit(&s->cc_fifo);
171 
172  av_log(ctx, AV_LOG_VERBOSE, "%d frames in, %d frames out; %d frames dropped, "
173  "%d frames duplicated.\n", s->frames_in, s->frames_out, s->drop, s->dup);
174 }
175 
176 static int config_props(AVFilterLink* outlink)
177 {
178  AVFilterContext *ctx = outlink->src;
179  AVFilterLink *inlink = ctx->inputs[0];
181  FilterLink *ol = ff_filter_link(outlink);
182  FPSContext *s = ctx->priv;
183 
184  double var_values[VARS_NB], res;
185  int ret;
186 
187  var_values[VAR_SOURCE_FPS] = av_q2d(il->frame_rate);
188  var_values[VAR_FPS_NTSC] = ntsc_fps;
189  var_values[VAR_FPS_PAL] = pal_fps;
190  var_values[VAR_FPS_FILM] = film_fps;
191  var_values[VAR_FPS_NTSC_FILM] = ntsc_film_fps;
192  ret = av_expr_parse_and_eval(&res, s->framerate,
193  var_names, var_values,
194  NULL, NULL, NULL, NULL, NULL, 0, ctx);
195  if (ret < 0)
196  return ret;
197 
198  ol->frame_rate = av_d2q(res, INT_MAX);
199  outlink->time_base = av_inv_q(ol->frame_rate);
200 
201  /* Calculate the input and output pts offsets for start_time */
202  if (s->start_time != DBL_MAX && s->start_time != AV_NOPTS_VALUE) {
203  double first_pts = s->start_time * AV_TIME_BASE;
204  if (first_pts < INT64_MIN || first_pts > INT64_MAX) {
205  av_log(ctx, AV_LOG_ERROR, "Start time %f cannot be represented in internal time base\n",
206  s->start_time);
207  return AVERROR(EINVAL);
208  }
209  s->in_pts_off = av_rescale_q_rnd(first_pts, AV_TIME_BASE_Q, inlink->time_base,
210  s->rounding | AV_ROUND_PASS_MINMAX);
211  s->out_pts_off = av_rescale_q_rnd(first_pts, AV_TIME_BASE_Q, outlink->time_base,
212  s->rounding | AV_ROUND_PASS_MINMAX);
213  s->next_pts = s->out_pts_off;
214  av_log(ctx, AV_LOG_VERBOSE, "Set first pts to (in:%"PRId64" out:%"PRId64") from start time %f\n",
215  s->in_pts_off, s->out_pts_off, s->start_time);
216  }
217 
218  ret = ff_ccfifo_init(&s->cc_fifo, ol->frame_rate, ctx);
219  if (ret < 0) {
220  av_log(ctx, AV_LOG_ERROR, "Failure to setup CC FIFO queue\n");
221  return ret;
222  }
223 
224  av_log(ctx, AV_LOG_VERBOSE, "fps=%d/%d\n", ol->frame_rate.num, ol->frame_rate.den);
225 
226  return 0;
227 }
228 
229 /* Read a frame from the input and save it in the buffer */
231 {
232  AVFrame *frame;
233  int ret;
234  int64_t in_pts;
235 
236  /* Must only be called when we have buffer room available */
237  av_assert1(s->frames_count < 2);
238 
240  /* Caller must have run ff_inlink_check_available_frame first */
241  av_assert1(ret);
242  if (ret < 0)
243  return ret;
244 
245  /* Convert frame pts to output timebase.
246  * The dance with offsets is required to match the rounding behaviour of the
247  * previous version of the fps filter when using the start_time option. */
248  in_pts = frame->pts;
249  frame->pts = s->out_pts_off + av_rescale_q_rnd(in_pts - s->in_pts_off,
250  inlink->time_base, outlink->time_base,
251  s->rounding | AV_ROUND_PASS_MINMAX);
252 
253  av_log(ctx, AV_LOG_DEBUG, "Read frame with in pts %"PRId64", out pts %"PRId64"\n",
254  in_pts, frame->pts);
255 
256  ff_ccfifo_extract(&s->cc_fifo, frame);
257  s->frames[s->frames_count++] = frame;
258  s->frames_in++;
259 
260  return 1;
261 }
262 
263 /* Write a frame to the output */
265 {
266  AVFrame *frame;
267 
268  av_assert1(s->frames_count == 2 || (s->status && s->frames_count == 1));
269 
270  /* We haven't yet determined the pts of the first frame */
271  if (s->next_pts == AV_NOPTS_VALUE) {
272  if (s->frames[0]->pts != AV_NOPTS_VALUE) {
273  s->next_pts = s->frames[0]->pts;
274  av_log(ctx, AV_LOG_VERBOSE, "Set first pts to %"PRId64"\n", s->next_pts);
275  } else {
276  av_log(ctx, AV_LOG_WARNING, "Discarding initial frame(s) with no "
277  "timestamp.\n");
278  frame = shift_frame(ctx, s);
280  *again = 1;
281  return 0;
282  }
283  }
284 
285  /* There are two conditions where we want to drop a frame:
286  * - If we have two buffered frames and the second frame is acceptable
287  * as the next output frame, then drop the first buffered frame.
288  * - If we have status (EOF) set, drop frames when we hit the
289  * status timestamp. */
290  if ((s->frames_count == 2 && s->frames[1]->pts <= s->next_pts) ||
291  (s->status && s->status_pts <= s->next_pts)) {
292 
293  frame = shift_frame(ctx, s);
295  *again = 1;
296  return 0;
297 
298  /* Output a copy of the first buffered frame */
299  } else {
300  frame = av_frame_clone(s->frames[0]);
301  if (!frame)
302  return AVERROR(ENOMEM);
303  // Make sure Closed Captions will not be duplicated
304  ff_ccfifo_inject(&s->cc_fifo, frame);
305  frame->pts = s->next_pts++;
306  frame->duration = 1;
307 
308  av_log(ctx, AV_LOG_DEBUG, "Writing frame with pts %"PRId64" to pts %"PRId64"\n",
309  s->frames[0]->pts, frame->pts);
310  s->cur_frame_out++;
311  *again = 1;
312  return ff_filter_frame(outlink, frame);
313  }
314 }
315 
316 /* Convert status_pts to outlink timebase */
318 {
319  int eof_rounding = (s->eof_action == EOF_ACTION_PASS) ? AV_ROUND_UP : s->rounding;
320  s->status_pts = av_rescale_q_rnd(status_pts, inlink->time_base, outlink->time_base,
321  eof_rounding | AV_ROUND_PASS_MINMAX);
322 
323  av_log(ctx, AV_LOG_DEBUG, "EOF is at pts %"PRId64"\n", s->status_pts);
324 }
325 
327 {
328  FPSContext *s = ctx->priv;
329  AVFilterLink *inlink = ctx->inputs[0];
330  AVFilterLink *outlink = ctx->outputs[0];
331 
332  int ret;
333  int again = 0;
334  int64_t status_pts;
335 
337 
338  /* No buffered status: normal operation */
339  if (!s->status) {
340 
341  /* Read available input frames if we have room */
342  while (s->frames_count < 2 && ff_inlink_check_available_frame(inlink)) {
343  ret = read_frame(ctx, s, inlink, outlink);
344  if (ret < 0)
345  return ret;
346  }
347 
348  /* We do not yet have enough frames to produce output */
349  if (s->frames_count < 2) {
350  /* Check if we've hit EOF (or otherwise that an error status is set) */
351  ret = ff_inlink_acknowledge_status(inlink, &s->status, &status_pts);
352  if (ret > 0)
353  update_eof_pts(ctx, s, inlink, outlink, status_pts);
354 
355  if (!ret) {
356  /* If someone wants us to output, we'd better ask for more input */
358  return 0;
359  }
360  }
361  }
362 
363  /* Buffered frames are available, so generate an output frame */
364  if (s->frames_count > 0) {
365  ret = write_frame(ctx, s, outlink, &again);
366  /* Couldn't generate a frame, so schedule us to perform another step */
367  if (again && ff_inoutlink_check_flow(inlink, outlink))
368  ff_filter_set_ready(ctx, 100);
369  return ret;
370  }
371 
372  /* No frames left, so forward the status */
373  if (s->status && s->frames_count == 0) {
374  ff_outlink_set_status(outlink, s->status, s->next_pts);
375  return 0;
376  }
377 
378  return FFERROR_NOT_READY;
379 }
380 
382  {
383  .name = "default",
384  .type = AVMEDIA_TYPE_VIDEO,
385  .config_props = config_props,
386  },
387 };
388 
390  .name = "fps",
391  .description = NULL_IF_CONFIG_SMALL("Force constant framerate."),
392  .init = init,
393  .uninit = uninit,
394  .priv_size = sizeof(FPSContext),
395  .priv_class = &fps_class,
396  .activate = activate,
400 };
AV_ROUND_UP
@ AV_ROUND_UP
Round toward +infinity.
Definition: mathematics.h:134
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:215
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
VARS_NB
@ VARS_NB
Definition: vf_fps.c:62
var_name
var_name
Definition: noise.c:47
ff_filter_frame
int ff_filter_frame(AVFilterLink *link, AVFrame *frame)
Send a frame of data to the next filter.
Definition: avfilter.c:1062
FFERROR_NOT_READY
return FFERROR_NOT_READY
Definition: filter_design.txt:204
AV_TIME_BASE_Q
#define AV_TIME_BASE_Q
Internal time base represented as fractional value.
Definition: avutil.h:264
int64_t
long long int64_t
Definition: coverity.c:34
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
EOF_ACTION_PASS
@ EOF_ACTION_PASS
Definition: vf_fps.c:43
av_frame_free
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
Definition: frame.c:162
FILTER_INPUTS
#define FILTER_INPUTS(array)
Definition: filters.h:262
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:389
VAR_FPS_NTSC
@ VAR_FPS_NTSC
Definition: vf_fps.c:58
AVOption
AVOption.
Definition: opt.h:429
AV_ROUND_ZERO
@ AV_ROUND_ZERO
Round toward zero.
Definition: mathematics.h:131
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:225
float.h
ntsc_fps
static const double ntsc_fps
Definition: vf_fps.c:65
var_names
static const char *const var_names[]
Definition: vf_fps.c:47
mathematics.h
AVFilter::name
const char * name
Filter name.
Definition: avfilter.h:205
pal_fps
static const double pal_fps
Definition: vf_fps.c:66
video.h
init
static av_cold int init(AVFilterContext *ctx)
Definition: vf_fps.c:121
FF_FILTER_FORWARD_STATUS_BACK
#define FF_FILTER_FORWARD_STATUS_BACK(outlink, inlink)
Forward the status on an output link to an input link.
Definition: filters.h:434
config_props
static int config_props(AVFilterLink *outlink)
Definition: vf_fps.c:176
ff_inoutlink_check_flow
int ff_inoutlink_check_flow(AVFilterLink *inlink, AVFilterLink *outlink)
Check for flow control between input and output.
Definition: avfilter.c:1625
uninit
static av_cold void uninit(AVFilterContext *ctx)
Definition: vf_fps.c:160
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:1491
ff_ccfifo_uninit
void ff_ccfifo_uninit(CCFifo *ccf)
Free all memory allocated in a CCFifo and clear the context.
Definition: ccfifo.c:46
EOFAction
EOFAction
Definition: framesync.h:26
AVRational::num
int num
Numerator.
Definition: rational.h:59
AVFilterPad
A filter pad used for either input or output.
Definition: filters.h:38
avassert.h
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:209
update_eof_pts
static void update_eof_pts(AVFilterContext *ctx, FPSContext *s, AVFilterLink *inlink, AVFilterLink *outlink, int64_t status_pts)
Definition: vf_fps.c:317
av_cold
#define av_cold
Definition: attributes.h:90
ff_video_default_filterpad
const AVFilterPad ff_video_default_filterpad[1]
An AVFilterPad array whose only entry has name "default" and is of type AVMEDIA_TYPE_VIDEO.
Definition: video.c:37
ff_ccfifo_inject
int ff_ccfifo_inject(CCFifo *ccf, AVFrame *frame)
Insert CC data from the FIFO into an AVFrame (as side data)
Definition: ccfifo.c:133
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:424
FPSContext::eof_action
int eof_action
action performed for last frame in FIFO
Definition: vf_fps.c:77
s
#define s(width, name)
Definition: cbs_vp9.c:198
FPSContext::frames_in
int frames_in
number of frames on input
Definition: vf_fps.c:95
AV_OPT_TYPE_DOUBLE
@ AV_OPT_TYPE_DOUBLE
Underlying C type is double.
Definition: opt.h:267
V
#define V
Definition: vf_fps.c:102
av_q2d
static double av_q2d(AVRational a)
Convert an AVRational to a double.
Definition: rational.h:104
filters.h
AV_LOG_DEBUG
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
Definition: log.h:230
ctx
AVFormatContext * ctx
Definition: movenc.c:49
av_frame_clone
AVFrame * av_frame_clone(const AVFrame *src)
Create a new frame that references the same data as src.
Definition: frame.c:597
FPSContext::frames_count
int frames_count
number of buffered frames
Definition: vf_fps.c:88
AV_ROUND_NEAR_INF
@ AV_ROUND_NEAR_INF
Round to nearest and halfway cases away from zero.
Definition: mathematics.h:135
FILTER_OUTPUTS
#define FILTER_OUTPUTS(array)
Definition: filters.h:263
AV_ROUND_PASS_MINMAX
@ AV_ROUND_PASS_MINMAX
Flag telling rescaling functions to pass INT64_MIN/MAX through unchanged, avoiding special cases for ...
Definition: mathematics.h:159
write_frame
static int write_frame(AVFilterContext *ctx, FPSContext *s, AVFilterLink *outlink, int *again)
Definition: vf_fps.c:264
FPSContext::out_pts_off
int64_t out_pts_off
output frame pts offset for start_time handling
Definition: vf_fps.c:81
ntsc_film_fps
static const double ntsc_film_fps
Definition: vf_fps.c:68
OFFSET
#define OFFSET(x)
Definition: vf_fps.c:101
framerate
float framerate
Definition: av1_levels.c:29
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:75
NULL
#define NULL
Definition: coverity.c:32
avfilter_vf_fps_outputs
static const AVFilterPad avfilter_vf_fps_outputs[]
Definition: vf_fps.c:381
ff_ccfifo_extract
int ff_ccfifo_extract(CCFifo *ccf, AVFrame *frame)
Extract CC data from an AVFrame.
Definition: ccfifo.c:183
FPSContext::status_pts
int64_t status_pts
buffered input status timestamp
Definition: vf_fps.c:85
FPSContext::frames
AVFrame * frames[2]
buffered frames
Definition: vf_fps.c:87
CCFifo
Definition: ccfifo.h:40
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:1438
VAR_FPS_FILM
@ VAR_FPS_FILM
Definition: vf_fps.c:60
ff_filter_link
static FilterLink * ff_filter_link(AVFilterLink *link)
Definition: filters.h:197
AV_ROUND_DOWN
@ AV_ROUND_DOWN
Round toward -infinity.
Definition: mathematics.h:133
FPSContext::status
int status
buffered input status
Definition: vf_fps.c:84
read_frame
static int read_frame(AVFilterContext *ctx, FPSContext *s, AVFilterLink *inlink, AVFilterLink *outlink)
Definition: vf_fps.c:230
eval.h
FPSContext
Definition: vf_fps.c:70
ff_inlink_check_available_frame
int ff_inlink_check_available_frame(AVFilterLink *link)
Test if a frame is available on the link.
Definition: avfilter.c:1460
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
av_expr_parse_and_eval
int av_expr_parse_and_eval(double *d, const char *s, const char *const *const_names, const double *const_values, const char *const *func1_names, double(*const *funcs1)(void *, double), const char *const *func2_names, double(*const *funcs2)(void *, double, double), void *opaque, int log_offset, void *log_ctx)
Parse and evaluate an expression.
Definition: eval.c:803
start_time
static int64_t start_time
Definition: ffplay.c:326
AV_NOPTS_VALUE
#define AV_NOPTS_VALUE
Undefined timestamp value.
Definition: avutil.h:248
ff_vf_fps
const AVFilter ff_vf_fps
Definition: vf_fps.c:389
EOF_ACTION_ROUND
@ EOF_ACTION_ROUND
Definition: vf_fps.c:42
FPSContext::next_pts
int64_t next_pts
pts of the next frame to output
Definition: vf_fps.c:91
FF_FILTER_FORWARD_WANTED
FF_FILTER_FORWARD_WANTED(outlink, inlink)
EOF_ACTION_NB
@ EOF_ACTION_NB
Definition: vf_fps.c:44
FPSContext::drop
int drop
number of framed dropped
Definition: vf_fps.c:98
shift_frame
static AVFrame * shift_frame(AVFilterContext *ctx, FPSContext *s)
Definition: vf_fps.c:132
FPSContext::framerate
char * framerate
expression that defines the target framerate
Definition: vf_fps.c:75
AV_TIME_BASE
#define AV_TIME_BASE
Internal time base represented as integer.
Definition: avutil.h:254
AV_ROUND_INF
@ AV_ROUND_INF
Round away from zero.
Definition: mathematics.h:132
FPSContext::cc_fifo
CCFifo cc_fifo
closed captions
Definition: vf_fps.c:89
av_assert1
#define av_assert1(cond)
assert() equivalent, that does not lie in speed critical code.
Definition: avassert.h:56
av_d2q
AVRational av_d2q(double d, int max)
Convert a double precision floating point number to a rational.
Definition: rational.c:106
av_inv_q
static av_always_inline AVRational av_inv_q(AVRational q)
Invert a rational.
Definition: rational.h:159
AVFilterPad::name
const char * name
Pad name.
Definition: filters.h:44
AVFilter
Filter definition.
Definition: avfilter.h:201
ff_ccfifo_init
int ff_ccfifo_init(CCFifo *ccf, AVRational framerate, void *log_ctx)
Initialize a CCFifo.
Definition: ccfifo.c:53
ret
ret
Definition: filter_design.txt:187
frame
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
Definition: filter_design.txt:264
again
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 again
Definition: filter_design.txt:25
AVRational::den
int den
Denominator.
Definition: rational.h:60
AV_OPT_TYPE_INT
@ AV_OPT_TYPE_INT
Underlying C type is int.
Definition: opt.h:259
avfilter.h
AVFILTER_FLAG_METADATA_ONLY
#define AVFILTER_FLAG_METADATA_ONLY
The filter is a "metadata" filter - it does not modify the frame data in any way.
Definition: avfilter.h:168
FPSContext::in_pts_off
int64_t in_pts_off
input frame pts offset for start_time handling
Definition: vf_fps.c:80
film_fps
static const double film_fps
Definition: vf_fps.c:67
F
#define F
Definition: vf_fps.c:103
FPSContext::dup
int dup
number of frames duplicated
Definition: vf_fps.c:97
AVFilterContext
An instance of a filter.
Definition: avfilter.h:457
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
FPSContext::start_time
double start_time
pts, in seconds, of the expected first frame
Definition: vf_fps.c:73
AVFILTER_DEFINE_CLASS
AVFILTER_DEFINE_CLASS(fps)
activate
static int activate(AVFilterContext *ctx)
Definition: vf_fps.c:326
fps_options
static const AVOption fps_options[]
Definition: vf_fps.c:104
flags
#define flags(name, subs,...)
Definition: cbs_av1.c:482
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:27
ccfifo.h
FPSContext::cur_frame_out
int cur_frame_out
number of times current frame has been output
Definition: vf_fps.c:94
VAR_FPS_NTSC_FILM
@ VAR_FPS_NTSC_FILM
Definition: vf_fps.c:61
AV_OPT_TYPE_STRING
@ AV_OPT_TYPE_STRING
Underlying C type is a uint8_t* that is either NULL or points to a C string allocated with the av_mal...
Definition: opt.h:276
VAR_SOURCE_FPS
@ VAR_SOURCE_FPS
Definition: vf_fps.c:57
AV_OPT_TYPE_CONST
@ AV_OPT_TYPE_CONST
Special option type for declaring named constants.
Definition: opt.h:299
av_rescale_q_rnd
int64_t av_rescale_q_rnd(int64_t a, AVRational bq, AVRational cq, enum AVRounding rnd)
Rescale a 64-bit integer by 2 rational numbers with specified rounding.
Definition: mathematics.c:134
FPSContext::frames_out
int frames_out
number of frames on output
Definition: vf_fps.c:96
FPSContext::rounding
int rounding
AVRounding method for timestamps.
Definition: vf_fps.c:76
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:239
VAR_FPS_PAL
@ VAR_FPS_PAL
Definition: vf_fps.c:59