[FFmpeg-cvslog] lavfi/separatefields: adjust tb to avoid rounding errors.
Clément Bœsch
git at videolan.org
Wed Apr 10 02:39:00 CEST 2013
ffmpeg | branch: master | Clément Bœsch <ubitux at gmail.com> | Wed Apr 10 02:38:07 2013 +0200| [d2e051e30c0ffc1e80a7e7e76ccdfbeb2956daa6] | committer: Clément Bœsch
lavfi/separatefields: adjust tb to avoid rounding errors.
Since the PTS need double accuracy, the timebase denominator is doubled
as well, and this new time base is used for the timestamp unit.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=d2e051e30c0ffc1e80a7e7e76ccdfbeb2956daa6
---
libavfilter/vf_separatefields.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/libavfilter/vf_separatefields.c b/libavfilter/vf_separatefields.c
index 81f37cf..5849b62 100644
--- a/libavfilter/vf_separatefields.c
+++ b/libavfilter/vf_separatefields.c
@@ -41,11 +41,13 @@ static int config_props_output(AVFilterLink *outlink)
return AVERROR_INVALIDDATA;
}
+ outlink->time_base.num = inlink->time_base.num;
+ outlink->time_base.den = inlink->time_base.den * 2;
outlink->frame_rate.num = inlink->frame_rate.num * 2;
outlink->frame_rate.den = inlink->frame_rate.den;
outlink->w = inlink->w;
outlink->h = inlink->h / 2;
- sf->ts_unit = av_q2d(av_inv_q(av_mul_q(outlink->frame_rate, inlink->time_base)));
+ sf->ts_unit = av_q2d(av_inv_q(av_mul_q(outlink->frame_rate, outlink->time_base)));
return 0;
}
More information about the ffmpeg-cvslog
mailing list