Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(291)

Side by Side Diff: patched-ffmpeg-mt/libavutil/mathematics.c

Issue 789004: ffmpeg roll of source to mar 9 version... (Closed) Base URL: svn://chrome-svn/chrome/trunk/deps/third_party/ffmpeg/
Patch Set: '' Created 10 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2005 Michael Niedermayer <michaelni@gmx.at> 2 * Copyright (c) 2005 Michael Niedermayer <michaelni@gmx.at>
3 * 3 *
4 * This file is part of FFmpeg. 4 * This file is part of FFmpeg.
5 * 5 *
6 * FFmpeg is free software; you can redistribute it and/or 6 * FFmpeg is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public 7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either 8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version. 9 * version 2.1 of the License, or (at your option) any later version.
10 * 10 *
(...skipping 118 matching lines...) Expand 10 before | Expand all | Expand 10 after
129 int64_t av_rescale(int64_t a, int64_t b, int64_t c){ 129 int64_t av_rescale(int64_t a, int64_t b, int64_t c){
130 return av_rescale_rnd(a, b, c, AV_ROUND_NEAR_INF); 130 return av_rescale_rnd(a, b, c, AV_ROUND_NEAR_INF);
131 } 131 }
132 132
133 int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq){ 133 int64_t av_rescale_q(int64_t a, AVRational bq, AVRational cq){
134 int64_t b= bq.num * (int64_t)cq.den; 134 int64_t b= bq.num * (int64_t)cq.den;
135 int64_t c= cq.num * (int64_t)bq.den; 135 int64_t c= cq.num * (int64_t)bq.den;
136 return av_rescale_rnd(a, b, c, AV_ROUND_NEAR_INF); 136 return av_rescale_rnd(a, b, c, AV_ROUND_NEAR_INF);
137 } 137 }
138 138
139 int av_compare_ts(int64_t ts_a, AVRational tb_a, int64_t ts_b, AVRational tb_b){
140 int64_t a= tb_a.num * (int64_t)tb_b.den;
141 int64_t b= tb_b.num * (int64_t)tb_a.den;
142 if (av_rescale_rnd(ts_a, a, b, AV_ROUND_DOWN) < ts_b) return -1;
143 if (av_rescale_rnd(ts_b, b, a, AV_ROUND_DOWN) < ts_a) return 1;
144 return 0;
145 }
146
139 #ifdef TEST 147 #ifdef TEST
140 #include "integer.h" 148 #include "integer.h"
141 #undef printf 149 #undef printf
142 int main(void){ 150 int main(void){
143 int64_t a,b,c,d,e; 151 int64_t a,b,c,d,e;
144 152
145 for(a=7; a<(1LL<<62); a+=a/3+1){ 153 for(a=7; a<(1LL<<62); a+=a/3+1){
146 for(b=3; b<(1LL<<62); b+=b/4+1){ 154 for(b=3; b<(1LL<<62); b+=b/4+1){
147 for(c=9; c<(1LL<<62); c+=(c*2)/5+3){ 155 for(c=9; c<(1LL<<62); c+=(c*2)/5+3){
148 int64_t r= c/2; 156 int64_t r= c/2;
149 AVInteger ai; 157 AVInteger ai;
150 ai= av_mul_i(av_int2i(a), av_int2i(b)); 158 ai= av_mul_i(av_int2i(a), av_int2i(b));
151 ai= av_add_i(ai, av_int2i(r)); 159 ai= av_add_i(ai, av_int2i(r));
152 160
153 d= av_i2int(av_div_i(ai, av_int2i(c))); 161 d= av_i2int(av_div_i(ai, av_int2i(c)));
154 162
155 e= av_rescale(a,b,c); 163 e= av_rescale(a,b,c);
156 164
157 if((double)a * (double)b / (double)c > (1LL<<63)) 165 if((double)a * (double)b / (double)c > (1LL<<63))
158 continue; 166 continue;
159 167
160 if(d!=e) printf("%"PRId64"*%"PRId64"/%"PRId64"= %"PRId64"=%"PRId 64"\n", a, b, c, d, e); 168 if(d!=e) printf("%"PRId64"*%"PRId64"/%"PRId64"= %"PRId64"=%"PRId 64"\n", a, b, c, d, e);
161 } 169 }
162 } 170 }
163 } 171 }
164 return 0; 172 return 0;
165 } 173 }
166 #endif 174 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698