编辑传播论文AppWand解读

最近看到好几篇论文如Colorization,poisson image editing等都使用线性系统求解泊松方程。今天找一篇文章简单推导一下:

参考论文:AppWand: Editing Measured Materials using Appearance-Driven Optimization, SIGGRAPH 07
在这里插入图片描述
论文是编辑传播领域的经典论文,用于将局部的编辑,传播到图像的所有区域,实现全局合理的颜色编辑。论文的核心能量函数为:

E=i(eigi)2wi+ijNi(eiej)2zij1E =\sum_i{(e_i-g_i})^2w_i +\sum_i\sum_{j\in N_i }(e_i-e_j)^2z_{ij } (1)

其中,eie_i为待求的编辑参数, gig_i为已知的编辑部分,如果第 ii 个像素被着色了, 那么 wi=1w_i = 1, 否则 wi=0w_i = 0zijz_{ij} 为已知量的表示像素 ii 和像素 jj 的相似度。

我们对(1)中 eie_i 求导有:

E/ei=i2(eigi)wi+ijNi2(eiej)zij+ijNi2(ejei)zji\partial E /\partial e_i= \sum_i{2(e_i-g_i})w_i +\sum_i\sum_{j\in N_i }2(e_i-e_j)z_{ij} + \sum_i\sum_{j\in N_i }2(e_j-e_i)z_{ji}

注意最后一项,因为 eie_ieje_j 相邻,所以, eie_i 同样会出现在所有邻居的邻居中。
令上式为0:

E/ei=i2(eigi)wi+ijNi2(eiej)zij+ijNi2(ejei)zji=0\partial E /\partial e_i= \sum_i{2(e_i-g_i})w_i +\sum_i\sum_{j\in N_i }2(e_i-e_j)z_{ij} + \sum_i\sum_{j\in N_i }2(e_j-e_i)z_{ji} = 0

i(eigi)wi+ijNi2(eiej)zij=0\sum_i{(e_i-g_i})w_i +\sum_i\sum_{j\in N_i }2(e_i-e_j)z_{ij} = 0

ieiwi+ijNi2(eiej)zij=igiwi\sum_i{e_iw_i} +\sum_i\sum_{j\in N_i }2(e_i-e_j)z_{ij} =\sum_i{g_iw_i}

实际上已经构建了一个Ae=bAe = b的线性系统:

Aij={wi+2jNizij,i=j2zij,jNi0,otherwise.A_{ij} = \begin{cases} w_i +2 \sum_{j\in N_i}z_{ij} ,& i = j\\ -2z_{ij} ,& j \in N_i\\ 0, & otherwise\end{cases}.

上述案例其实完全可以手动推导,只需要给定如下的水平放置的3个像素即可推导。
在这里插入图片描述
总的能量公式为:

E=(e1g1)2w1+(e3g3)2w3+(e1e2)2z12+(e1e3)2z13+(e2e1)2z21+(e2e3)2z23+(e3e1)2z31+(e3e2)2z32E = (e_1-g_1)^2w_1 + (e_3-g_3)^2w_3 + (e_1-e_2)^2z_{12} +(e_1-e_3)^2z_{13}+(e_2-e_1)^2z_{21} + (e_2-e_3)^2z_{23}+(e_3-e_1)^2z_{31} + (e_3-e_2)^2z_{32}

E/e1=2(e1g1)w1+4(e1e2)z12+4(e1e3)z13\partial E /\partial e_1 =2(e_1-g_1)w_1+4(e_1-e_2)z_{12}+4(e_1-e_3)z_{13}

E/e2=4(e2e1)z21+4(e2e3)z23\partial E /\partial e_2 =4(e_2-e_1)z_{21}+4(e_2-e_3)z_{23}

E/e3=2(e3g3)w3+4(e3e1)z31+4(e3e2)z32\partial E /\partial e_3 =2(e_3-g_3)w_3+4(e_3-e_1)z_{31}+4(e_3-e_2)z_{32}

令几个偏导数 = 0:

e1(w1+2z12+2z13)2e2z122e3z13=g1w1e_1(w_1+2z_{12}+2z_{13}) -2e_2z_{12}-2e_3z_{13} = g_1w_1

e2(z12+z23)e1z12e3z23=0e_2(z_{12}+z_{23}) -e_1z_{12}-e_3z_{23} = 0

e3(w3+2z31+2z32)2e1z312e2z32=g3w3e_3(w_3+2z_{31}+2z_{32}) -2e_1z_{31}-2e_2z_{32} = g_3w_3

因此,跟上面的公式保持一致。

如果直接从矩阵形式推导应该也可以,可能会用到如下几个简单矩阵求导公式:
在这里插入图片描述

参考一本矩阵书:https://www.math.uwaterloo.ca/~hwolkowi/matrixcookbook.pdf

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章