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

Project1

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

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

[复制链接]

Lv2.观梦者

(?????)

梦石
0
星屑
700
在线时间
1327 小时
注册时间
2011-7-18
帖子
3184

贵宾

跳转到指定楼层
1
发表于 2011-11-24 08:00:12 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

加入我们,或者,欢迎回来。

您需要 登录 才可以下载或查看,没有帐号?注册会员

x
首先声明……我没学过算法……数学水平初中毕业 - - b

实现的原理是:
计算出缩放后图片每个像素相对原图的浮点数坐标,分别取顶数和底数组成4对坐标,
分别在原图取这4个坐标的颜色值,根据浮点数小数部分加权平均得到缩放后的像素的颜色值。
(语文水平初中毕业 = = b 你看不懂我也没办法……)
好吧我不知道这叫什么算法……貌似和双线性很接近?


于是这是测试图……

悲剧的效率&悲剧的质量……图像边缘有明显的“锯齿”……而且缩小的时候貌似无效?

{:nm_9:} 求指点……
插值算法测试.zip (302.2 KB, 下载次数: 357)

Lv1.梦旅人

追从自然的旅行者
奇特空·煦

梦石
0
星屑
107
在线时间
1387 小时
注册时间
2010-12-31
帖子
4944

开拓者贵宾

2
发表于 2011-11-24 12:27:50 | 只看该作者
我不知道这是啥算法,
但我知道这个时间复杂度高了把
回复 支持 反对

使用道具 举报

Lv1.梦旅人

Mr.Gandum

梦石
0
星屑
226
在线时间
2070 小时
注册时间
2007-1-31
帖子
3039

贵宾

3
发表于 2011-11-24 12:35:45 | 只看该作者
新像素点的坐标X缩放倍数?
好吧无视这个。
回复 支持 反对

使用道具 举报

Lv1.梦旅人

梦石
0
星屑
100
在线时间
5250 小时
注册时间
2011-10-7
帖子
1885

开拓者贵宾

4
发表于 2011-11-24 12:48:48 | 只看该作者
从初中到现在数学没怎么及格的数学小白路过…
算法是必修三的,不过那个也不讲这种图象用的算法…
百度一下读读其它比如c++写的这种东西吧,应该会有所帮助的…
回复 支持 反对

使用道具 举报

Lv2.观梦者

(?????)

梦石
0
星屑
700
在线时间
1327 小时
注册时间
2011-7-18
帖子
3184

贵宾

5
 楼主| 发表于 2011-11-24 22:32:17 | 只看该作者
顶起……求指导……

点评

OpenCV随便到处一下啊。。。  发表于 2012-1-2 23:59
用C+RGSS啊  发表于 2012-1-2 22:40
回复 支持 反对

使用道具 举报

Lv1.梦旅人

追从自然的旅行者
奇特空·煦

梦石
0
星屑
107
在线时间
1387 小时
注册时间
2010-12-31
帖子
4944

开拓者贵宾

6
发表于 2011-11-24 23:09:32 | 只看该作者
各种压力的猫君 发表于 2011-11-24 22:32
顶起……求指导……

指导就是,改进时间复杂度(提高运行速度随着数据增长的增长速度)和空间复杂度(压缩空间)

点评

表示百度一下我顺懂 O。O  发表于 2011-11-25 00:35
(╯-_-)╯╧╧  发表于 2011-11-24 23:10
回复 支持 反对

使用道具 举报

Lv2.观梦者

傻♂逼

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

烫烫烫开拓者

7
发表于 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-5-4 20:59

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

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