[FFmpeg-cvslog] rational: add av_inv_q() returning the inverse of	an AVRational
    Mans Rullgard 
    git at videolan.org
       
    Sun Aug  5 23:06:31 CEST 2012
    
    
  
ffmpeg | branch: master | Mans Rullgard <mans at mansr.com> | Sun Jul 29 14:58:53 2012 +0100| [82494835c4ee2adf5afc51bfd19964b82eb80da9] | committer: Mans Rullgard
rational: add av_inv_q() returning the inverse of an AVRational
This allows simplifying a few expressions.
Signed-off-by: Mans Rullgard <mans at mansr.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=82494835c4ee2adf5afc51bfd19964b82eb80da9
---
 avconv.c             |    6 ++----
 libavutil/rational.h |   11 +++++++++++
 2 files changed, 13 insertions(+), 4 deletions(-)
diff --git a/avconv.c b/avconv.c
index 07de66e..b20dbec 100644
--- a/avconv.c
+++ b/avconv.c
@@ -797,8 +797,7 @@ static int configure_input_video_filter(FilterGraph *fg, InputFilter *ifilter,
     AVFilterContext *first_filter = in->filter_ctx;
     AVFilter *filter = avfilter_get_by_name("buffer");
     InputStream *ist = ifilter->ist;
-    AVRational tb = ist->framerate.num ? (AVRational){ist->framerate.den,
-                                                      ist->framerate.num} :
+    AVRational tb = ist->framerate.num ? av_inv_q(ist->framerate) :
                                          ist->st->time_base;
     AVRational sar;
     char args[255], name[255];
@@ -2197,8 +2196,7 @@ static int output_packet(InputStream *ist, const AVPacket *pkt)
             if (avpkt.duration)
                 ist->next_dts += av_rescale_q(avpkt.duration, ist->st->time_base, AV_TIME_BASE_Q);
             else if (ist->st->avg_frame_rate.num)
-                ist->next_dts += av_rescale_q(1, (AVRational){ist->st->avg_frame_rate.den,
-                                                              ist->st->avg_frame_rate.num},
+                ist->next_dts += av_rescale_q(1, av_inv_q(ist->st->avg_frame_rate),
                                               AV_TIME_BASE_Q);
             else if (ist->st->codec->time_base.num != 0) {
                 int ticks      = ist->st->parser ? ist->st->parser->repeat_pict + 1 :
diff --git a/libavutil/rational.h b/libavutil/rational.h
index 0ec18ec..5d7dab7 100644
--- a/libavutil/rational.h
+++ b/libavutil/rational.h
@@ -115,6 +115,17 @@ AVRational av_add_q(AVRational b, AVRational c) av_const;
 AVRational av_sub_q(AVRational b, AVRational c) av_const;
 
 /**
+ * Invert a rational.
+ * @param q value
+ * @return 1 / q
+ */
+static av_always_inline AVRational av_inv_q(AVRational q)
+{
+    AVRational r = { q.den, q.num };
+    return r;
+}
+
+/**
  * Convert a double precision floating point number to a rational.
  * inf is expressed as {1,0} or {-1,0} depending on the sign.
  *
    
    
More information about the ffmpeg-cvslog
mailing list