【图像插值】基于稀疏拉普拉斯滤波器处理红绿蓝三种像素实现插值效果附matlab代码

简介: 【图像插值】基于稀疏拉普拉斯滤波器处理红绿蓝三种像素实现插值效果附matlab代码

1 内容介绍

本文研究了一种空域中的图像分解技术,进而利用改种分解方法,探 讨了图像插值算法.本文提出的图像分解方法的主要思想是:利用类型确定的滤波器(如低通)对原始图像滤波,将图像分解为高频和低频两部分,并对分解得到的 低频或高频成分进行处理,图像可分解成不同频率分量的图层之和,进而在各个图层上进行相应的插值处理,最后利用逆变换得到最终的结果.

2 仿真代码

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%

%   Implementation of 'Minimized-Laplacian Residual Interpolation for Color Image Demosaicking'

%

%   This code is available only for reserch purpose.

%   If you use this code for future publications,

%   please cite the following paper.

%

%   Daisuke Kiku, Yusuke Monno, Masayuki Tanaka, and Masatoshi Okutomi,

%   'Minimized-Laplacian Residual Interpolation for Color Image Demosaicking',

%   IS&T/SPIE Electronic Imaging, Digital Photography X, 2014.

%

%   Main funtion

%     rgb_dem = demosaick(rgb, pattern, sigma)

%

%      Input

%       - rgb : full RGB image

%       - pattern : mosaic pattern

%                       default : 'grbg'

%                       others  : 'rggb','gbrg','bggr'

%       - sigma : standard deviation of gaussian filter(default : 1.4)

%                       * For IMAX image dataset, 1 works well.

%                       * For Kodak image dataset, 1e8 works well.

%

%      Output

%       - rgb_dem   : result image

%

%   Copyright (C) 2013 Daisuke Kiku. All rights reserved.

%   dkiku@ok.ctrl.titech.ac.jp

%

%   November 26, 2013.

%

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

clear all

close all

% read image

rgb = imread('lena.tiff');

figure

subplot(211)

imshow(rgb,[]);title('原图')

% cast to double

rgb = double(rgb);

% mosaic pattern

% G R ..

% B G ..

% : :  

pattern = 'grbg';

% demosaicking

sigma = 1.4;

rgb_dem = demosaick(rgb, pattern, sigma);

% save image

imwrite(uint8(rgb_dem), 'lena_MLRI.tiff');

% show image


subplot(212)

imshow(rgb_dem/255);title('插值图')

% calculate PSNR and CPSNR

psnr = impsnr(rgb, rgb_dem, 255, 10);

cpsnr = imcpsnr(rgb, rgb_dem, 255, 10);


% print PSNR and CPSNR

fprintf( sprintf( 'Red:%f\n',     psnr(1)     ) );

fprintf( sprintf( 'Green:%f\n',   psnr(2)     ) );

fprintf( sprintf( 'Blue:%f\n',    psnr(3)     ) );

fprintf( sprintf( 'CPSNR:%f\n',   cpsnr       ) );

3 运行结果

4 参考文献

[1]吴颖, 田岩. 基于滤波器分解的图像插值算法[J]. 武汉船舶职业技术学院学报, 2009, 8(2):3.

博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

部分理论引用网络文献,若有侵权联系博主删除。


相关文章
|
1月前
|
算法
m基于OFDM+QPSK和LDPC编译码以及MMSE信道估计的无线图像传输matlab仿真,输出误码率,并用图片进行测试
MATLAB2022a仿真实现了无线图像传输的算法,包括OFDM、QPSK调制、LDPC编码和MMSE信道估计。OFDM抗频率选择性衰落,QPSK用相位表示二进制,LDPC码用于前向纠错,MMSE估计信道响应。算法流程涉及编码、调制、信道估计、均衡、解码和图像重建。MATLAB代码展示了从串行数据到OFDM信号的生成,经过信道模型、噪声添加,再到接收端的信道估计和解码过程,最终计算误码率。
20 1
|
3天前
|
文字识别 算法 计算机视觉
图像倾斜校正算法的MATLAB实现:图像倾斜角检测及校正
图像倾斜校正算法的MATLAB实现:图像倾斜角检测及校正
12 0
|
3天前
matlab使用移动平均滤波器、重采样和Hampel过滤器进行信号平滑处理
matlab使用移动平均滤波器、重采样和Hampel过滤器进行信号平滑处理
|
11天前
|
存储 人工智能 机器人
【Matlab】Matlab电话拨号音合成与识别(代码+论文)【独一无二】
【Matlab】Matlab电话拨号音合成与识别(代码+论文)【独一无二】
|
1月前
|
算法
【MATLAB】语音信号识别与处理:滤波器滤波算法去噪及谱相减算法呈现频谱
【MATLAB】语音信号识别与处理:滤波器滤波算法去噪及谱相减算法呈现频谱
19 2
|
1月前
|
资源调度 算法
m基于OFDM+QPSK和LDPC编译码以及LS信道估计的无线图像传输matlab仿真,输出误码率,并用图片进行测试
m基于OFDM+QPSK和LDPC编译码以及LS信道估计的无线图像传输matlab仿真,输出误码率,并用图片进行测试
26 2
|
1月前
|
编解码 算法 计算机视觉
基于FPGA的图像最近邻插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
基于FPGA的图像最近邻插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
|
3月前
|
Perl
【MFAC】基于全格式动态线性化的无模型自适应控制(Matlab代码)
【MFAC】基于全格式动态线性化的无模型自适应控制(Matlab代码)
|
3月前
【数值分析】迭代法求方程的根(附matlab代码)
【数值分析】迭代法求方程的根(附matlab代码)
|
3月前
【数值分析】Jacobi、Seidel和Sor迭代法求解线性方程组(附matlab代码)
【数值分析】Jacobi、Seidel和Sor迭代法求解线性方程组(附matlab代码)

热门文章

最新文章