设为首页收藏本站|繁體中文

Project1

 找回密码
 注册会员
搜索
查看: 3131|回复: 6
打印 上一主题 下一主题

[讨论] RM图像缩放插值算法的实现

[复制链接]

Lv2.观梦者

傻♂逼

梦石
0
星屑
369
在线时间
1605 小时
注册时间
2007-3-13
帖子
6562

烫烫烫开拓者

1
发表于 2012-1-2 20:28:55 | 显示全部楼层
本帖最后由 yangff 于 2012-1-2 20:31 编辑

= =线性插值我记得写过……不知道丢那里去了……
三次卷积插值:

三次卷积法能够克服以上两种算法的不足,计算精度高,但计算亮更大,他考虑一个浮点坐标(i+u,j+v)周围的16个邻点,目的像素值f(i+u,j+v)可由如下插值公式得到:


    f(i+u,j+v) = [A] * [B] * [C]


[A]=[ S(u + 1) S(u + 0) S(u - 1) S(u - 2) ]


  ┏ f(i-1, j-1) f(i-1, j+0) f(i-1, j+1) f(i-1, j+2)    ┓

[B]=┃ f(i+0, j-1) f(i+0, j+0) f(i+0, j+1) f(i+0, j+2) ┃

  ┃ f(i+1, j-1) f(i+1, j+0) f(i+1, j+1) f(i+1, j+2) ┃

  ┗ f(i+2, j-1) f(i+2, j+0) f(i+2, j+1) f(i+2, j+2) ┛


  ┏ S(v + 1) ┓

[C]=┃ S(v + 0) ┃

  ┃ S(v - 1)  ┃

  ┗ S(v - 2)  ┛


   ┏ 1-2*Abs(x)^2+Abs(x)^3      , 0<=Abs(x)<1

S(x)={ 4-8*Abs(x)+5*Abs(x)^2-Abs(x)^3 , 1<=Abs(x)<2

   ┗ 0                , Abs(x)>=2

S(x)是对 Sin(x*Pi)/x 的逼近(Pi是圆周率——π)


图像缩放中的三次插值都要涉及到两个维度上的16个已有采样点。这并算不上真正的二维插值,只是相当于先后在两个维度上进行一维插值。S(x)是插值的核函数,是关键所在。三次差值核函数跨度为4(-2<x<2)。

至于其他的一下图形学算法可以参考http://sourceforge.net/projects/opencvlibrary/

点评

看上去很爽的样子。  发表于 2012-1-8 20:28
不会C TVT  发表于 2012-1-2 23:22
计算量更大——这一句RM就悲剧了  发表于 2012-1-2 20:56
哎呀,蛋疼什么的最有爱了
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

拿上你的纸笔,建造一个属于你的梦想世界,加入吧。
 注册会员
找回密码

站长信箱:[email protected]|手机版|小黑屋|无图版|Project1游戏制作

GMT+8, 2024-6-17 22:22

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表