Code Generation for Denoising Deep Neural Network
This example shows how to generate plain CUDA® MEX from MATLAB® code and denoise grayscale images by using the denoising convolutional neural network (DnCNN [1]). The pretrained denoising network estimates the noise in a noisy image and then removes it, resulting in a clearer, denoised image.
Third-Party Prerequisites
This example generates CUDA MEX and requires CUDA® enabled NVIDIA® GPU and compatible driver.
Verify GPU Environment
Use the coder.checkGpuInstall
function to verify that the compilers and libraries necessary for running this example are set up correctly.
envCfg = coder.gpuEnvConfig('host'); envCfg.DeepLibTarget = 'none'; envCfg.DeepCodegen = 1; envCfg.Quiet = 1; coder.checkGpuInstall(envCfg);
Load Noisy Image
Load a noisy grayscale image into the workspace and display the image.
noisyI = imread('noisy_cameraman.png'); imshow(noisyI); title('Noisy Image');
Get Pretrained Denoising Network
Call the getDenoisingNetwork
helper function to get a pretrained image denoising deep neural network.
net = getDenoisingNetwork;
The getDenoisingNetwork
function returns a pretrained dlnetwork
object. The pretrained denoising deep neural network detects additive white Gaussian noise (AWGN) of unknown levels. The network is a feed-forward denoising convolutional network that implements a residual learning technique to predict a residual image. In other words, the pretrained network computes the difference between a noisy image and the latent clean image.
The network contains 58 layers. To display an interactive visualization of the deep learning network architecture, use the analyzeNetwork
(Deep Learning Toolbox) function.
analyzeNetwork(net);
The denoisenet_predict
Function
The denoisenet_predict
entry-point function takes a noisy image input and returns a denoised image by using a pretrained denoising network.
The function loads the dlnetwork
object returned by getDenoisingNetwork
into a persistent variable dlnet
and reuses the persistent object on subsequent prediction calls. The predict
method returns an estimate of the noise in the input image by using the pretrained denoising image. Then a denoised image is obtained by subtracting the noise from the original image.
type denoisenet_predict
function I = denoisenet_predict(in) %#codegen % Copyright 2018-2024 The bat365, Inc. persistent dlnet; if isempty(dlnet) dlnet = coder.loadDeepLearningNetwork('getDenoisingNetwork', 'DnCNN'); end % Use the network to predict the noise in the input image dlIn = dlarray(in, 'SSC'); res = extractdata(predict(dlnet, dlIn)); % Once the noise is estimated, we subtract the noise from the original % image to obtain a denoised image. I = in - res;
Run MEX Code Generation
To generate CUDA code for the denoisenet_predict.m
entry-point function, create a GPU code configuration object for a MEX target and set the target language to C++. Use the coder.DeepLearningConfig
function to create a deep learning configuration object and set target library to none
. Assign the deep learning configuration object to the DeepLearningConfig
property of cfg
. Run the codegen
command specifying an input size of 256-by-256. This value corresponds to the size of the noisy image that you intend to denoise.
cfg = coder.gpuConfig('mex'); cfg.TargetLang = 'C++'; cfg.DeepLearningConfig = coder.DeepLearningConfig('none'); codegen -config cfg denoisenet_predict -args {ones(256,256,'single')} -report
Code generation successful: View report
Run Generated MEX
The denoising network is trained on input images having an input range [0,1]. Use the im2single
(Image Processing Toolbox) function on noisyI
to rescale the values from [0,255]
to [0,1]
. After rescaling, use denoisenet_predict_predict
to obtain the denoised image denoisedI
.
denoisedI = denoisenet_predict_mex(im2single(noisyI));
View Denoised Image
Display the original noisy image and the denoised image side by side.
imshowpair(noisyI,denoisedI,'montage'); title('Noisy Image (left) and Denoised Image (right)');
References
[1] Zhang, K., W. Zuo, Y. Chen, D. Meng, and L. Zhang. "Beyond a Gaussian Denoiser: Residual Learning of Deep CNN for Image Denoising." IEEE Transactions on Image Processing. Vol. 26, Number 7, Feb. 2017, pp. 3142-3155.
See Also
Functions
Objects
coder.gpuConfig
|coder.CodeConfig
|coder.EmbeddedCodeConfig
|coder.gpuEnvConfig
|coder.CuDNNConfig