IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> Matlab学习4-图像处理之图像加法、图像减法、加噪 -> 正文阅读

[人工智能]Matlab学习4-图像处理之图像加法、图像减法、加噪

图像处理,图像加法(例图像的叠加,调亮色等),图像减法(例捕捉运动图像的轨迹)
环境matlab2020

使用imadd(加)、imsubtract(减)、imresize(改)、imnoise(图像加噪)

matlab函数

imadd(X,Y):
将两个图像相加或在图像中添加常量;
Z=imadd(X,Y)将数组X中的每个元素与数组Y中的对应元素相加,并在输出数组Z的对应元素中返回和。
imsubtract(X,Y)
从一个图像中减去另一个图像或从图像中减去常量;
Z=imsubtract(X,Y)从数组X中的每个元素中减去数组Y中的对应元素,并在输出数组Z的对应元素中返回差。
rgb2gray()
将RGB图像或颜色图转换为灰度图;
I=rgb2gray(RGB)将真彩色图像RGB转换为灰度图像I。通过消除色调和饱和度信息,同时保留亮度,来将RGB图像转换为灰度图。
imnoise():向图像添加噪声
J=imnoise(I,‘gaussian’)将方差为0.01的零均值高斯白噪声添加到灰度图像I。
J=immoise(I,‘gaussian’,m)添加高斯白噪声,均值为m,方差为0.01。
J=imnoise(I,‘gaussian’,m,var_gauss)添加高斯白噪声,均值为m,方差为var_gauss。
J=imnoise(I,‘localvar’,var_local)添加局部方差为var_local的零均值高斯白噪声。
J=imnoise(I,‘localvar’,intensity_map,var_local)添加零均值高斯白噪声。噪声的局部方差 var_1ocal是I中图像强度值的函数。图像强度值到噪声方差的映射由向量intensity_map 指定。
J=imnoise(I,‘poisson’)从数据中生成泊松噪声,而不是向数据中添加人为噪声。有关详细信息,请参阅算法。
J=imnoise(I,'salt&pepper")添加椒盐噪声,默认噪声密度为0.05。这会影响大约5%的像素。
3=imnoise(I,‘salt&pepper’,d)添加椒盐噪声,其中d是噪声密度。这会影响大约dnumel(I)个像素。=imnoise(I,‘speckle’)使用方程]=I+nT 添加乘性噪声,其中n是均值为0、方差为0.05的均匀分布随机噪声。
J=imnoise(I,‘speckle’,var_speckle)添加方差为var_speckle的乘性噪声。

1、图像加法

效果如下:
在这里插入图片描述

test.m代码:

%图像加法
img1=imread("A.bmp");
img2=imread("B.bmp");
%rbg图像转变灰度图像
img3=rgb2gray(img1);
img4=rgb2gray(img2);
%灰度图像相加
img5=imadd(img3,img4);
%显示
subplot(1,3,1),imshow(img3),xlabel("A");
subplot(1,3,2),imshow(img4),xlabel("B");
subplot(1,3,3),imshow(img5),xlabel("A+B");

2、图像融合

效果如下:
在这里插入图片描述

test.m代码:

%图像融合
img1=imread("man.tif");
img2=imread("test1.png");
%修改图像大小
% img1=imresize(img1,[200,200]);
% img2=imresize(img2,[200,200]);

%图像相加,x,y必须具有相同大小和类
img3=imadd(img1,img2);

subplot(1,3,1),imshow(img1),xlabel("A");
subplot(1,3,2),imshow(img2),xlabel("B");
subplot(1,3,3),imshow(img3),xlabel("A+B");

3、图像融合,使用具体参数

效果如下:
在这里插入图片描述

test.m代码:

%图像融合,使用具体参数
img1=imread("test1.png");

%图像相加
img2=imadd(img1,50);
img3=imadd(img1,-50);

subplot(1,3,1),imshow(img1),xlabel("原图像");
subplot(1,3,2),imshow(img2),xlabel("增加亮度后的图像");
subplot(1,3,3),imshow(img3),xlabel("减弱亮度后的图像");

4、图像还原

效果如下:
在这里插入图片描述

test.m代码:

%图像还原
%原始图像
img=imread("test.png");
img=rgb2gray(img);
subplot(2,3,1),imshow(img),xlabel("(a)原图像");
[m,n]=size(img);

%加噪图像(被还原图像)
img1=imnoise(img,"gaussian",0,0.01);%叠加零均值高斯噪声(方差为0.01subplot(2,3,2),imshow(img1),xlabel("(b)加噪图像");

%2幅同类图像进行相加平均
J=zeros(m,n);
J=double(J);
for i=1:2
    X=imnoise(img,"gaussian");
    Y=double(X);
    J=J+Y/2;
end
subplot(2,3,3),imshow(mat2gray(J)),xlabel("(c)2幅图像平均");
%4幅同类图像进行相加平均
J=zeros(m,n);
J=double(J);
for i=1:4
    X=imnoise(img,"gaussian");
    Y=double(X);
    J=J+Y/4;
end
subplot(2,3,4),imshow(mat2gray(J)),xlabel("(d)4幅图像平均");
%8幅同类图像进行相加平均
J=zeros(m,n);
J=double(J);
for i=1:8
    X=imnoise(img,"gaussian");
    Y=double(X);
    J=J+Y/8;
end
subplot(2,3,5),imshow(mat2gray(J)),xlabel("(e)8幅图像平均");
%16幅同类图像进行相加平均
J=zeros(m,n);
J=double(J);
for i=1:16
    X=imnoise(img,"gaussian");
    Y=double(X);
    J=J+Y/16;
end
subplot(2,3,6),imshow(mat2gray(J)),xlabel("(f)16幅图像平均");

5、图像减法

效果如下:
在这里插入图片描述

test.m代码:

%图像减法
img1=imread("A.bmp");
img2=imread("B.bmp");
%修改图像大小
% img1=imresize(img1,[200,200]);
% img2=imresize(img2,[200,200]);

%图像相减,要求图像矩阵相同大小
img3=imsubtract(img1,img2);
subplot(1,3,1),imshow(img1),xlabel("A");
subplot(1,3,2),imshow(img2),xlabel("B");
subplot(1,3,3),imshow(img3),xlabel("A-B");

6、图像减法,捕捉图像运动轨迹

效果如下:
在这里插入图片描述

test.m代码:

%图像减法,运动图像轨迹
img1=imread("F4_8a.bmp");
img2=imread("F4_8b.bmp");
img3=imread("F4_8c.bmp");
subplot(2,3,1),imshow(img1),xlabel("a");
subplot(2,3,2),imshow(img2),xlabel("b");
subplot(2,3,3),imshow(img3),xlabel("c");

%图像相减
img4=imsubtract(img1,img2);
img5=imsubtract(img2,img3);
img6=imsubtract(img1,img3);


subplot(2,3,4),imshow(img4),xlabel("a-b");
subplot(2,3,5),imshow(img5),xlabel("b-c");
subplot(2,3,6),imshow(img6),xlabel("a-c");

素材:https://gitee.com/CYFreud/matlab/tree/master/image_processing/demo4_220328

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-30 18:23:58  更:2022-03-30 18:27:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:31:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码