图像修复 "Region filling and object removal by exemplar-based image inpainting" matlab实现

介绍

本代码是对Region filling and object removal by exemplar-based image inpaintingMATLAB实现,用来对图像进行区域填充、物体移除。

😛😜😝代码托管在github上:exemplar-based-image-inpainting

算法

如图1所示,为算法伪代码。


图1 算法伪代码
区域划分

实现这个算法,首先需要进行图像区域的划分。如图2所示,\Omega为目标区域,是需要进行填充的区域,\phi为源区域,作为填充数据的来源。\Omega的边界为\delta\Omega。如果从像素值来看的话,可以将目标区域的像素值设置为0,但是0在图像中为黑色的意思,所以最好可以有一个辅助数组来标志缺失区域。

图2 区域划分与边界

计算边界区域

使用下面的代码可以方便地计算出边界点的位置。map是一个二值数组,只有0、1,其中1表示缺失像素值所在位置。计算出来的结果result中,1所在的位置就是边界点所在的位置。

result = imdilate(map, se) - map;
优先级的计算公式

边界上有很多像素点,以这些点为中心可以得到很多patch(比如9×9的patch),对于这些patch,都需要计算一下他们的优先级是多少,以便从中选出一个优先级最大的块作为首要修复的对象。

  • 对于一个patch,块的优先级计算公式:
    P(p)=C(p) \ast D(p) \tag{1}
    其中,p代表这个待修复块的中心点,C(p)表示块的置信度,D(p)为data term。

  • 置信度的计算公式是:
    C(p)=\frac{\sum_{q\in\psi_p\cap(I-\Omega)} c(q)}{\psi_p} \tag{2}
    其中,C(p)表示置信度,其中I为整张图像,\OmegaI的缺失区域,\psi_p为待填充的块,|\psi_p|为块的面积。c(q)为块中的像素点的置信度,在初始化的时候,已存在的像素点的置信度为1,缺失的像素点的置信度为0,在修复过程中,修复出来的像素点的置信度被更新为块的置信度C(p),由此可知,随着修复过程的推进,修复出来的像素点的置信度会越来越小。

  • data term的计算公式为:
    D(p) =\frac{|\bigtriangledown I^{\perp}_p \ast n_p|}{\alpha} \tag{3}
    公式3,这里是等照度向量与法向量n_p的点乘再求模长,\alpha为归一化因子。
    在计算等照度向量的时候需要先计算p点的image gradient,等照度线向量为gradient逆时针旋转90°,gradient代表了像素值变化最快的方向,而等照度线向量与gradient垂直,代表了变化最慢的方向。

  • image gradient
    \bigtriangledown f = [ \begin{matrix} g_x \\ g_y \end{matrix}]=[ \begin{matrix} \frac{\partial f}{\partial x} \\ \frac{\partial f}{\partial y} \end{matrix}] \tag{4}

暴力搜索

计算出每一个patch的优先级之后,从中选出一个优先级最高的patch作为待修复对象,如Pt。再使用暴力法,从源区域中选出一个与之最相近的块Ps,将Ps中对应的像素拷到Pt中(这里只需要修复Pt中缺失的像素点)。使用暴力法的时候,衡量两个块之间的距离时,使用SSD(差的平方和)作为距离,由于Pt本身就缺失了部分像素值,所以计算的就是Pt非缺失像素和其他patch对应位置像素值的SSD

注意,在修复过程的迭代中,缺失区域逐渐变小,但是提供像素来源的目标区域固定不变。因为目标区域中,修复出来的像素值可信度比较低,不予以采用。

效果

原图

缺失信息

修复之后

参考文献

  1. Criminisi A, Pérez P, Toyama K. Region filling and object removal by exemplar-based image inpainting[J]. IEEE Transactions on image processing, 2004, 13(9): 1200-1212.
  2. Criminisi A, Perez P, Toyama K. Object removal by exemplar-based inpainting[C]//Computer Vision and Pattern Recognition, 2003. Proceedings. 2003 IEEE Computer Society Conference on. IEEE, 2003, 2: II-II.
  3. https://github.com/IouJenLiu/Region-Filling-and-Object-Removal
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352