【图像融合】加权平均法图像融合【含Matlab源码 722期】

在这里插入图片描述

⛄一、获取代码方式

获取代码方式1:
完整代码已上传我的资源:【图像融合】基于matlab加权平均法图像融合【含Matlab源码 722期】
(https://download.csdn.net/download/TIQCmatlab/62925370)
点击上面蓝色字体,直接付费下载,即可。

获取代码方式2:
付费专栏Matlab图像处理(初级版)

备注:
点击上面蓝色字体付费专栏Matlab图像处理(初级版),扫描上面二维码,付费29.9元订阅海神之光博客付费专栏Matlab图像处理(初级版),凭支付凭证,私信博主,可免费获得1份本博客上传CSDN资源代码(有效期为订阅日起,三天内有效);
点击CSDN资源下载链接:1份本博客上传CSDN资源代码

⛄二、加权平均法简介

1 加权平均法图像融合算法的原理
对原图像的像素值直接取相同的权值,然后进行加权平均得到融合图像的像素值,举例说比如要融合两幅图像A,B,那它们的融合后图像的像素值就是A50%+B50%,就这么简单。

2 加权平均融合法融合过程
加权平均融合法是将源图像像素的灰度值进行线性加权平均,生成新的融合图像,是一种最简单、直接的图像融合方法,融合过程如下图所示,一般形式如下:

⛄三、部分源代码

clear
g_R=0;
g_G=0;
g_B=0;
h_R=0;
h_G=0;
h_B=0;
fenzi_R=0;
fenzi_G=0;
fenzi_B=0;
fenmu_up_R=0;
fenmu_up_G=0;
fenmu_up_B=0;
fenmu_low_R=0;
fenmu_low_G=0;
fenmu_low_B=0;
tableR=[];
tableG=[];
tableB=[];
up=imread(‘high.jpg’); %读图像
low=imread(‘low.jpg’);

figure(1)
imshow(up); %读RGB数值

[M,N,color]=size(up);

title(‘加权-RGB表示的高分辨率图像’);

figure(2)
imshow(low);
title(‘加权-RGB表示的低分辨率图像’);
r=double(up(:,:,1));
g=double(up(:,:,2));
b=double(up(:,:,3));
r_low=double(low(:,:,1));
g_low=double(low(:,:,2));
b_low=double(low(:,:,3));
RGB(:,:,1)=0.5r+0.5r_low;
RGB(:,:,2)=0.5g+0.5g_low;
RGB(:,:,3)=0.5b+0.5b_low;
R=RGB(:,:,1);
G=RGB(:,:,2);
B=RGB(:,:,3);
RGB=uint8(round(RGB));
figure(3)
imshow(RGB)
title(‘加权-RGB转化后的图像’);

          %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
          %                       下面是计算平均梯度G                          %
          %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%     

for ii=1:M-1
for jj=1:N-1
g_R=g_R+sqrt((((r(ii+1,jj)-r(ii,jj))2+(r(ii,jj+1)-r(ii,jj))2))/2);
g_G=g_G+sqrt((((g(ii+1,jj)-g(ii,jj))2+(g(ii,jj+1)-g(ii,jj))2))/2);
g_B=g_B+sqrt((((b(ii+1,jj)-b(ii,jj))2+(b(ii,jj+1)-b(ii,jj))2))/2);

end

end
fprintf(‘\n\n highR的清晰度为:%.4f\n highG的清晰度为:%.4f\n highG的清晰度为:%.4f’,…
g_R/(M-1)/(N-1),g_G/(M-1)/(N-1),g_B/(M-1)/(N-1));

g_R=0;
g_G=0;
g_B=0;

for ii=1:M-1
for jj=1:N-1
g_R=g_R+sqrt((((r_low(ii+1,jj)-r_low(ii,jj))2+(r_low(ii,jj+1)-r_low(ii,jj))2))/2);
g_G=g_G+sqrt((((g_low(ii+1,jj)-g_low(ii,jj))2+(g_low(ii,jj+1)-g_low(ii,jj))2))/2);
g_B=g_B+sqrt((((b_low(ii+1,jj)-b_low(ii,jj))2+(b_low(ii,jj+1)-b_low(ii,jj))2))/2);

end

end
fprintf(‘\n\n lowR的清晰度为:%.4f\n lowG的清晰度为:%.4f\n lowG的清晰度为:%.4f’,…
g_R/(M-1)/(N-1),g_G/(M-1)/(N-1),g_B/(M-1)/(N-1));

g_R=0;
g_G=0;
g_B=0;

for ii=1:M-1
for jj=1:N-1
g_R=g_R+sqrt((((R(ii+1,jj)-R(ii,jj))2+(R(ii,jj+1)-R(ii,jj))2))/2);
g_G=g_G+sqrt((((G(ii+1,jj)-G(ii,jj))2+(G(ii,jj+1)-G(ii,jj))2))/2);
g_B=g_B+sqrt((((B(ii+1,jj)-B(ii,jj))2+(B(ii,jj+1)-B(ii,jj))2))/2);

end

⛄四、运行结果

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

⛄五、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]赵娟,孙澎涛,吴粉侠,冯延琴.基于像素级的图像融合[J].长春工程学院学报(自然科学版). 2011,12(02)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

  • 24
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Matlab领域

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值