Gaussian Texture Inpainting Tutorial
This tutorial can be executed in the Matlab console, provided the archive gaussian_inpainting_matlab.zip has been extracted in the current path.
close all clear all in = 'inpainting_input/'; rng(3); % initialize random seed
Load input image
name = 'wood1008_sq_a_reduced'; u = im2double(imread([in name '.png'])); [M,N,C] = size(u); meanu = mean(mean(u,2)); figure imshow(u) title('Original')
data:image/s3,"s3://crabby-images/9ccb4/9ccb44f95465eed274add63419f0018c6ee69325" alt=""
Create a mask
x1 = 40; y1 = 128;
x2 = 216; y2 = 230;
indm = zeros(M,N,C);
indm(y1:y2,x1:x2,:) = 1;
figure
imshow(indm)
title('Mask')
data:image/s3,"s3://crabby-images/b4681/b468167440dfbb50c27d0488610b7867195b84e7" alt=""
Compute the Conditioning points on the mask border
indc = get_conditioning_points(indm,3);
figure
imshow(double(indc))
title('Conditioning points')
data:image/s3,"s3://crabby-images/f9c16/f9c16c6d7e39a48a3c77885756479cd18f7d1bf8" alt=""
Estimate a Gaussian model outside the mask
xo1 = 1; yo1 = 1;
xo2 = N; yo2 = y1-1;
[t,m] = estimate_adsn_model(u(yo1:yo2,xo1:xo2,:),M,N);
uw = draw_rectangle(u,xo1,xo2,yo1,yo2,2);
figure
imshow(uw.*(1-indm))
title(sprintf('Masked original. ADSN model estimated in the red box'))
data:image/s3,"s3://crabby-images/2780c/2780ccf71eca946d16625d8711d4b2623925e811" alt=""
Check the texture model
z = adsn_periodic(t,repmat(m,[M N 1]));
figure
imshow(z)
title('Realization of the ADSN model')
data:image/s3,"s3://crabby-images/e7af7/e7af7893982123d82d48946dd1801d8dd1e92f95" alt=""
Inpaint by Gaussian conditional simulation
[v,kc,innov] = kriging_inpainting(u.*(1-indm),m,t,indm,indc); figure imshow(u.*(1-indm)); title('Masked texture') drawnow figure imshow(v); title('Inpainted') drawnow figure imshow(kc); title('Kriging component') drawnow figure imshow(innov); title('Innovation component') drawnow
Time to solve the linear system of size 5148 x 5148: 1.727
data:image/s3,"s3://crabby-images/02a41/02a417cc3d8066d79b32b4200cdd05980be20e1a" alt=""
data:image/s3,"s3://crabby-images/9a05a/9a05acbd999244a6044ae67cfdbf36f3470f95f2" alt=""
data:image/s3,"s3://crabby-images/cd9c7/cd9c71bd01c398f7b465109e69b054cb2c403bbf" alt=""
data:image/s3,"s3://crabby-images/db717/db717efb8b0e09a0557cf9365c64f92dd523b489" alt=""