实验四、彩色图像处理

news2024/11/25 14:50:22
  • 实验目的

使用MatLab软件对图像进行彩色处理,熟悉使用MatLab软件进行图像彩色处理的有关方法,并体会到图像彩色处理技术以及对图像处理的效果。

  • 作业1:生成一副256*256的RGB图像,使得该图像左上角为黄色或者青色,左下角为蓝色,右上角为绿色,右下角为黑色。

rgb_R=zeros(256, 256); %红色分量

rgb_R(1:128,1:128)=1;

rgb_G=zeros(256, 256); %绿色分量

rgb_G(1:128,1:256)=1;

rgb_B=zeros(256, 256); %蓝色分量

rgb_B(128:256,1:128)=1;

rgb=cat(3,rgb_R,rgb_G,rgb_B); %生成一副RGB彩色图像的基本语法

imshow(rgb);title('RGB 彩色图像')

 

  • 作业2:利用作业1生成的RGB图像展示其R、G、B三个分量与RGB图;将其转化为HSI彩色模型,然后展示H、S、I三个分量及HSI图。

I=RGB;

r=I(:,:,1);

g=I(:,:,2);

b=I(:,:,3);

figure;

subplot(2,2,1);imshow(I);title('RGB彩色图像');

subplot(2,2,2);imshow(r);title('R分量');

subplot(2,2,3);imshow(g);title('G分量');

subplot(2,2,4);imshow(b);title('B分量');

hsi = rgb2hsv(I);

h=hsi(:,:,1);

s=hsi(:,:,2);

i=hsi(:,:,3);

figure;

subplot(2,3,1);imshow(I);title('original image');

subplot(2,3,2);imshow(hsi);title('HSI彩色图形');

subplot(2,3,4);imshow(h);title('色调H');

subplot(2,3,5);imshow(s);title('饱和度S');

subplot(2,3,6);imshow(i);title('亮度I');

rgb_hsi=hsv2rgb(hsi);

subplot(2,3,3);imshow(rgb_hsi);title('RGB彩色图形');

 

  • 作业3:将作业1中的图像进行上下镜像。

image=imread('D:\ALLDOWNLOAD\实验四、彩色图像处理\彩色图像处理\shiyan4.1.png');

res = im2uint8(zeros(size(image)));%生成image图像大小的0值unit8图片

[rows,cols,n] = size(image); % 图像行列数

res1 = im2uint8(zeros([rows,cols]));

res2 = im2uint8(zeros([rows,cols]));

res3 = im2uint8(zeros([rows,cols]));

temp1 = image(:, :, 1);

temp2 = image(:, :, 2);

temp3 = image(:, :, 3);

for i = 1:rows

for j = 1:cols

% 左右镜像

res1(rows-i+1,j) = temp1(i,j);

res2(rows-i+1,j) = temp2(i,j);

res3(rows-i+1,j) = temp3(i,j);

end

end

res(:, :, 1) = res1;

res(:, :, 2) = res2;

res(:, :, 3) = res3;

res = uint8(res);

subplot(121),imshow(image);

subplot(122),imshow(res);

 

  • 作业4:对例3的图片进行5x5均值滤波后的图片进行拉普拉斯锐化并显示。

>> f=imread('D:\ALLDOWNLOAD\实验四、彩色图像处理\彩色图像处理\lena_color.bmp');

w=ones(5)/(5*5);

f1=imfilter(f,w,'replicate');

w4=fspecial('laplacian',0);

w8=[1 1 1; 1 -8 1; 1 1 1];

g4=imfilter(f,w4,'replicate');

figure,imshow(g4),title('g4');

g4g=f-g4;

figure,imshow(g4g),title('g4g');

g8=imfilter(f,w8,'replicate');

f2=im2double(f);g8_f2=imfilter(f2,w8,'replicate');

figure,

subplot(221),imshow(g8),title('g8');

subplot(222),imshow(g8_f2),title('g8_f2');

g8g_f2=f2-g8_f2;

g8g=f-g8;

figure

subplot(223),imshow(g8g),title('g8g');

subplot(224),imshow(g8g_f2),title('g8g_f2');

>>

 

  • 作业5:采用’canny’方法寻找彩色边缘;或者自选一幅图像计算彩色图像的梯度并绘图。

I=imread('D:\ALLDOWNLOAD\实验四、彩色图像处理\彩色图像处理\lena_color.bmp');

subplot(231),imshow(I);title('原图像');%显示原图像

% edge - 查找强度图像的边缘

% 此 MATLAB 函数 返回二值图像 BW,其中的值 1 对应于灰度或二值图像 I 中函数找到边缘的位置,值 0 对应于其他位置。默认情况下,edge 使用 Sobel 边缘检测方法。

I_R=I(:,:,1);

BW1_R=edge(I_R,'sobel');

I_G=I(:,:,2);

BW1_G=edge(I_G,'sobel');

I_B=I(:,:,3);

BW1_B=edge(I_B,'sobel');

out(:,:,1)=BW1_R;

out(:,:,2)=BW1_G;

out(:,:,3)=BW1_B;

subplot(232);imshow(double(out),[]);title('out3arrays');

out2=cat(3,BW1_R,BW1_G,BW1_B);

subplot(233);imshow(double(out2),[]);title('cat3arrays');

%f 是RGB 图像,T是[0,1]范围内的阈值选项(默认为0);VG是RGB向量梯度F(x, y);

%A 是以弧度计的角度θ(x, y),并且PPG 是由单独彩色平面的2D 梯度之和形成的梯度图像

[VG,A,PPG]=colorgrad(I);%计算彩色图像的梯度

subplot(234);imshow(VG);title('VG');

subplot(235);imshow(A);title('A');

subplot(236);imshow(PPG);title('PPG');

 

 

I=imread('D:\ALLDOWNLOAD\彩色图像处理-实验\你的图.tif');

subplot(331),imshow(I);title('原图像');

I_R=I(:,:,1);

BW1_R=edge(I_R,'sobel');

I_G=I(:,:,2);

BW1_G=edge(I_G,'sobel');

I_B=I(:,:,3);

BW1_B=edge(I_B,'sobel');

out(:,:,1)=BW1_R;

out(:,:,2)=BW1_G;

out(:,:,3)=BW1_B;

subplot(332);imshow(double(out),[]);title('out3arrays');

out2=cat(3,BW1_R,BW1_G,BW1_B);

subplot(333);imshow(double(out2),[]);title('cat3arrays');

[VG,A,PPG]=colorgrad(I);

subplot(334);imshow(VG);title('VG');

subplot(335);imshow(A);title('A');

subplot(336);imshow(PPG);title('PPG');

subplot(337);imshow(BW1_R);title('Red Sobel edge');

 

 

应用:证件照更换底色(附加内容,自愿)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/480513.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

day04_基本数据类型丶变量丶类型转换

前置知识 计算机世界中只有二进制。那么在计算机中存储和运算的所有数据都要转为二进制。包括数字、字符、图片、声音、视频等。 进制 进制也就是进位计数制,是人为定义的带进位的计数方法 。不同的进制可以按照一定的规则进行转换。 进制的分类 十进制&#x…

Seurat -- Perform linear dimensional reduction

brief 什么是线性降维? 这里是一个很形象的网页演示,其中包括了一个视频链接。 这里是如何用R 包psych做线性降维的演示,其中也有原理的简述。 为什么要做线性降维? 因为下一步的聚类分析需要这里的降维结果作为输入。降维做的好…

14-3-进程间通信-消息队列

前面提到的管道pipe和fifo是半双工的,在某些场景不能发挥作用; 接下来描述的是消息队列(一种全双工的通信方式); 比如消息队列可以实现两个进程互发消息(不像管道,只能1个进程发消息&#xff…

vulnhub靶机Misdirection

环境准备 下载链接:https://download.vulnhub.com/misdirection/Misdirection.zip 解压后双击ovf文件导入虚拟机 网络:DHCP、NAT、192.168.100.0/24网段 信息收集 主机发现 192.168.100.133是新增的ip 端口扫描 发现开放了以上端口,继续…

【Java笔试强训 28】

🎉🎉🎉点进来你就是我的人了博主主页:🙈🙈🙈戳一戳,欢迎大佬指点! 欢迎志同道合的朋友一起加油喔🤺🤺🤺 目录 一、选择题 二、编程题 🔥猴子分桃…

【Python入门】Python搭建编程环境-安装Python3解释器(内含Windows版本、MacOS版本、Linux版本)

前言 📕作者简介:热爱跑步的恒川,致力于C/C、Java、Python等多编程语言,热爱跑步,喜爱音乐的一位博主。 📗本文收录于Python零基础入门系列,本专栏主要内容为Python基础语法、判断、循环语句、函…

与其焦虑被 AI 取代或猜测前端是否已死, 不如看看 vertical-align 扎实你的基础!!!

与其焦虑被 AI 取代或猜测前端是否已死, 不如看看 vertical-align 扎实你的基础!!! vertical-align 设置 display 值为 inline, inline-block 和 table-cell 的元素竖直对齐方式. 从 line-height: normal 究竟是多高说起 我们先来看一段代码, 分析一下为什么第二行的行高, 也就…

D. Mysterious Crime(单个位置贡献)

Problem - D - Codeforces Acingel是一个小镇。这里只有一位医生——Miss Ada。她非常友善,没有人曾经对她说过坏话,所以谁能想到Ada会在她的房子里被发现死亡?世界著名侦探Gawry先生被任命查找罪犯。他询问Ada的邻居关于那个不幸的日子里拜访…

Java回收垃圾的基本过程与常用算法

目录 一、基本概述 二、垃圾分类 基本背景 举例说明各种引用类型的作用 强引用(Strong Reference) 软引用(Soft Reference) 弱引用(Weak Reference) 虚引用(Phantom Reference&#xff…

广搜的优化技巧(备赛中)

A.电路维修 这道题我们对于每一个点都有四个方向,分别为 char op[]{"\\/\\/"}; 如果我们当前点到下一个点的方向不是对应的方向时我们的distance就加1,因为我们要求最优距离,所以我们采取一个小贪心的法则,每一次我们将…

「神州数码DCN」SAVI在IPV6环境下的应用

前言 介绍 ISIS,中间系统到中间系统的网络协议,最初是OSI组织为了他的CLNP(类似于TCP/IP中的IP网络)而设计的动态路由协议,后IETF对其进行修改和填充,现可以在TCP/IP和OSI环境中使用,称为&…

JavaWeb学习------jQuery

JavaWeb学习------jQuery jQuery函数库下载 jQuery函数库下载官网:Download jQuery | jQuery配套资料,免费下载 链接:https://pan.baidu.com/s/1aXBfItEYG4uM53u6PUEMTg 提取码:6c9i 然后下载? 来到官网&#xf…

Spark 1:Spark基础入门

Spark是什么 定义:Apache Spark是用于大规模数据(large-scala data)处理的统一(unified)分析引擎。 Spark 借鉴了 MapReduce 思想发展而来,保留了其分布式并行计算的优点并改进了其明显的缺陷。让中间数据存…

Winform从入门到精通(36)—ColorDialog(史上最全)

文章目录 前言一、属性1、AllowFullOpen2、AnyColor3、Color4、FullOpen5、ShowHelp6、SolidColorOnly7、Tag二、事件1、HelpRequest前言 当我们需要设置某个控件的颜色时,并且需要弹出一个可以选择颜色的对话框时,这时候就需要使用ColorDialog 一、属性 1、AllowFullOpen…

详解正则化

(一)正则化目的 防止过拟合现象,通过降低模型在训练集上的精度来提高其泛化能力,从而增加正则项 常见的降低过拟合方法 ■增加数据集的数据个数。数据量太小时,非常容易过拟合,因为 小数据集很容易精确拟…

Linux线程相关函数:线程的创建、回收、退出、取消

1. 线程号 进程号在系统中唯一&#xff0c;但线程号只在其所属进程环境中有效。 &#xff08;1&#xff09;pthread_self函数 #include<pthread.h>pthread_t pthread_self(void); /* 功能&#xff1a;获取线程号 返回值&#xff1a;调用此函数线程的ID */ pthread_se…

基于ssm的论坛系统的设计与实现【附源码】

基于ssm的论坛系统的设计与实现 摘 要 早期的网络论坛系统已经诞生一段时间&#xff0c;随着互联网技术的发展&#xff0c;它已经从最初的简单电子公告板系统变成了一种丰富的论坛系统社区模型。人们通过论坛系统进行信息的获取、发布和交流已经成为一种普遍的社交方式&#x…

一键开关机电路

一键开关机电路&#xff0c;通常用在防止关机导致数据保存发生错误&#xff0c;特别是在写EEPROM&#xff0c;FLASH和SD卡时&#xff0c;如果正在写入数据时断电&#xff0c;可能会导致数据保存错误&#xff0c;甚至导致元件损坏。一键开关机电路是由CPU来掌控&#xff0c;决定…

零基础带你认识HTML常用标签

目录 HTML 结构认识 HTML 标签HTML 文件基本结构标签层次结构快速生成代码框架 HTML 常见标签注释标签标题标签&#xff1a;h1 - h6水平线 hr 标签段落标签: p换行标签: br格式化标签图片标签: imgimg 标签的其他属性 超链接标签: a 表格标签基本使用和并单元格 列表标签表单标…

Compiler Lab1- 自制词法分析器

由于编译原理课的Lab1为自制词法分析器&#xff0c;所以笔者用C实现了一个极简的C语言词法分析器&#xff0c;用于分析C语言源代码。它可以处理关键字、标识符、整数、实数、浮点数的科学计数法表示、运算符、分隔符、字符串字面量、字符字面量、注释和预处理指令。请注意&…