http://blog.csdn.net/fireroll/article/details/8485482

一、函数声明:

int64_t av_rescale_rnd(int64_t a, int64_t b, int64_t c, enum AVRounding rnd); 

直接看代码, 它的作用是计算 "a * b / c" 的值并分五种方式来取整.

用在FFmpeg中,

则是将以 "时钟基c" 表示的 数值a 转换成以 "时钟基b" 来表示。

一共有5种方式:

二、函数定义(见于libavutil/mathematics.c):

 int64_t av_rescale_rnd(int64_t a, int64_t b, int64_t c, enum AVRounding rnd){
int64_t r=;
av_assert2(c > );
av_assert2(b >=);
av_assert2((unsigned)(rnd&~AV_ROUND_PASS_MINMAX)<= && (rnd&~AV_ROUND_PASS_MINMAX)!=); if (c <= || b < || !((unsigned)(rnd&~AV_ROUND_PASS_MINMAX)<= && (rnd&~AV_ROUND_PASS_MINMAX)!=))
return INT64_MIN; if (rnd & AV_ROUND_PASS_MINMAX) {
if (a == INT64_MIN || a == INT64_MAX)
return a;
rnd -= AV_ROUND_PASS_MINMAX;
} if(a< && a != INT64_MIN) return -av_rescale_rnd(-a, b, c, rnd ^ ((rnd>>)&)); if(rnd==AV_ROUND_NEAR_INF) r= c/;
else if(rnd&) r= c-; if(b<=INT_MAX && c<=INT_MAX){
if(a<=INT_MAX)
return (a * b + r)/c;
else
return a/c*b + (a%c*b + r)/c;
}else{
#if 1
uint64_t a0= a&0xFFFFFFFF;
uint64_t a1= a>>;
uint64_t b0= b&0xFFFFFFFF;
uint64_t b1= b>>;
uint64_t t1= a0*b1 + a1*b0;
uint64_t t1a= t1<<;
int i; a0 = a0*b0 + t1a;
a1 = a1*b1 + (t1>>) + (a0<t1a);
a0 += r;
a1 += a0<r; for(i=; i>=; i--){
// int o= a1 & 0x8000000000000000ULL;
a1+= a1 + ((a0>>i)&);
t1+=t1;
if(/*o || */c <= a1){
a1 -= c;
t1++;
}
}
return t1;
}
#else
AVInteger ai;
ai= av_mul_i(av_int2i(a), av_int2i(b));
ai= av_add_i(ai, av_int2i(r)); return av_i2int(av_div_i(ai, av_int2i(c)));
}
#endif
}

三、实例分析
将以"1MHz时钟基" 表示的 "PTS/DTS值a" 转换成以 "90kHz时钟基" 表示。

 av_rescale_q(a=-,
bq={num=, den=},
cq={num=, den=))
{
int64_t b= bq.num * (int64_t)cq.den; // = 1 * 90000 = 90000;
int64_t c= cq.num * (int64_t)bq.den; // = 1 * 1000000 = 1000000
return av_rescale_rnd(a, b, c, );
} av_rescale_rnd(a=, b=, c=, rnd=)
{
if (rnd==)
r = c / ; // r =500000; if (b<=INT_MAX && c<=INT_MAX)
{
if (a<=INT_MAX)
return (a * b + r)/c;
else
return a/c*b + (a%c*b + r)/c; // = 10949117256 / 1000000 * 90000 +
// (10949117256 % 1000000 * 90000 + 500000) / 1000000
// = 985420553
}
else
{
...
}
}

最新文章

  1. 基于MemoryCache的缓存辅助类
  2. IntelliJ IDEA 14.x 与 Tomcat 集成,创建并运行Java Web项目
  3. Fiddler-2 Fiddler抓包原理
  4. [转]ASP.NET MVC 入门3、Routing
  5. jquery上传图片
  6. Binder机制,从Java到C (6. Binder in Native : libbinder)
  7. android 之 java环境部署
  8. Neuron:Neural activities in V1 create a bottom-up saliency map
  9. Linux下crontab计划任务使用详解
  10. LeetCode链表解题模板
  11. 浅谈Kotlin(二):基本类型、基本语法、代码风格
  12. moment.js 时间戳转换
  13. 从输入 URL 到页面加载完成的过程详解---【XUEBIG】
  14. ABAP语言实现 左移 &lt;&lt;、无符号右移 &gt;&gt;&gt; 位移操作
  15. http1.1 和 http2 的协议对比测试
  16. sqlserver编号
  17. POJ2274
  18. struts2的execAndWait拦截器
  19. Mac下百度网盘破解
  20. Python进行数据分析—可视化之seaborn

热门文章

  1. CodeForces - 600F Edge coloring of bipartite graph
  2. 品质与合身 无须昂贵 | Tailorwoods在线男装定制
  3. 【Jpa hibernate】一对多@OneToMany,多对一@ManyToOne的使用
  4. weblogic92 启动慢解决办法
  5. C#规范整理&#183;集合和Linq
  6. 【转载】GitHub中国区前100名到底是什么样的人
  7. [反汇编练习] 160个CrackMe之032
  8. 怎样使用Entityframework.Extended
  9. 百科知识 epub文件如何打开
  10. 每天进步一点点——Linux中的线程局部存储(二)