最临近插值和双线性插值

插值在图像中的应用一般为处理图像的缩放。所谓缩放就是缩小和放大。在所有插值缩放算法中要数最邻近插值最简单最暴力,当然效果也是最不好的。经过该算法进行放大的图片会出现马赛克现象,而进行缩小的图片也会丢失较大的图像信息。但是由于其简单,也是介绍该类算法不可不了解的。接下来首先介绍它。

  1. 最临近插值
    在介绍该算法之前,我们先介绍下计算机中图像的知识。一般我们数字处理的图像都为像素图,即位图。对于一张位图而言,我们一般会给其一套坐标系。横轴x和纵轴y。而坐标原点我们一般选取图像的左上角。所以图像上的每个像素都有他们自己的坐标。因为是数字图像,其坐标值也是离散的。(0, 0)代表原点,(0, 1)代表第一行第二列的像素点。
    知道了以上的图像知识后,我们就可以来介绍算法本身了。以放大为例。假设我们现在有一张 5 x 5 大小的图片,要把它放大成 10 x 10 大小的图片。那么我们生成一个 10 x 10 大小的图像。然后对于每个像素点我们按照一定的方法给它赋上相应的像素值,那么就完成了放大。而最临近插值就是根据生成图的坐标 (x,y)计算得到原图上的对应坐标(x/(10/5),y/(10/5))。然后取原图上该点的像素点值赋值给生成图。当然,前面的对应坐标计算中可能出现小数的情况,这时候我们可以用四舍五入或者向下或向上取整的方法来获得对应的原图坐标。正因为这个机制的引入,才导致最后的生成图效果不佳。
    下面我给出一段自己写的 python 的代码,可以快速的理解算法的原理:
def resize(src_data, dst_height, dst_width):
    ori_height, ori_width, channel = src_data.shape
    ratio_height = ori_height / dst_height
    ratio_width = ori_width / dst_width
    dst_data = np.zeros((dst_height, dst_width, channel), np.uint8)
    for i in range(channel):
        for y in range(dst_height):
            for x in range(dst_width):
                x_ori = int(x * ratio_width)
                y_ori = int(y * ratio_height)
                dst_data[y, x, i] = src_data[y_ori, x_ori, i]
    return dst_data

其中,src_data 为原图片数据,dst_height 和 dst_width 是我们想要 resize 后的高和宽。返回我们要的图像数据。下面是该算法的结果图:(原图为 960 * 1440。分别缩小为 200 * 500 以及放大为 1200 * 2500。)


原图.png
放大图.png
缩小图.png
  1. 双向性插值
    介绍双向性插值之前,我们有必要知道下线性插值的知识。
    顾名思义,双线性插值就是使用两次线性插值来获取未知点的值。在数学上,双线性插值是对线性插值在二位网络中的延伸。
    如图,假如我们想得到未知函数 f 在点 P=(x,y)的值,假设我们已知函数 f 在 Q11=(x1,y1), Q12=(x1,y2), Q21=(x2,y1), 及 Q22=(x2,y2) 四个点的值。
    插值图.png

    首先在 x 方向进行线性插值,得到
    f(x,y1) ≈ (x2−x / x2−x1) * f(Q11) + (x−x1 / x2−x1) * f(Q21), f(x,y2) ≈ (x2−x / x2−x1) * f(Q12) + (x−x1 / x2−x1) * f(Q22).
    然后在 y 方向进行线性插值,得到
    f(x,y) ≈ (y2−y / y2−y1) * f(x,y1) + (y−y1 / y2−y1) * f(x,y2)。带入上面的式子并整理可得到:
    式子.png

    当然在图像中的应用,我们可以知道公共分母 (x2 - x1)(y2 - y1) 是 1 * 1 为 1。因此,上面的公式就简化为: (x2 - x)(y2 - y) * f(Q11) + (x - x1)(y2 - y) * f(Q21) + (x2 - x)(y - y1) * f(Q12) + (x - x1)(y - y1) * f(Q22)。这也就是双线性插值在图像传统算法中的应用。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容