数字图像处理和机器视觉中的常用特殊矩阵及MATLAB实现详解

news2025/1/11 0:05:57

一、前言

       Matlab的名称来源于“矩阵实验室(Matrix Laboratory)”,其对矩阵的操作具有先天性的优势(特别是相对于C语言的数组来说)。在数字图像处理和机器视觉实践中,为了提高编程效率,MATLAB 提供了多种方式来创建特殊的矩阵,如全零矩阵、全1矩阵、单位矩阵、空矩阵个、序列矩阵、稀疏矩阵、随机矩阵等。这些函数在图像模拟、统计分析、优化算法等多个领域都有广泛的应用。通过调整参数和结合MATLAB的其他功能,可以灵活地生成各种满足特定数字图像处理需求的随机矩阵。为了更好地快速掌握这里特殊矩阵的使用,每个矩阵后都附有实例,便于大家学习和交流。

二、特殊矩阵的生成及应用

1.全零矩阵

       元素全为零的矩阵称为全零矩阵,MATLAB可以使用zeros创建全零矩阵。如zeros(5),生成一个5×5的矩阵元素全为零的方阵,而zeros(3,4)则生成3×4的矩阵元素全为零的矩阵

       注意:如果使用zeros生成全零矩阵,其在MATLAB图像显示是黑色。

>> I=zeros(256,256);

>> imshow(I),title('全零矩阵图像')

2.全1矩阵

      元素全为1的矩阵称为全1矩阵,MATLAB可以使用ones创建全1矩阵。如ones(5),生成一个5×5的矩阵元素全为1的方阵,而ones(3,4)则生成3×4的矩阵元素全为1的矩阵。

注意:如果一个矩阵是全1矩阵,其在MATLAB图像显示是白色。

>> onesMatrix=ones(256,256);

>> figure,imshow(onesMatrix),title(‘全1矩阵’)

>> whos onesMatrix

       矩阵元素的数据类型为double,一个像素占8个Bytes。

3.单位矩阵

       如果一个方阵对角线上的元素全为1,而其他的元素全为零则称单位矩阵,MATLAB可以使用eys创建单位矩阵。

如eye(5),生成一个5×5的单位矩阵。

I=eye(5);

figure,imshow(I)

whos I

 

        矩阵元素的数据类型为double。

4. 空矩阵

空矩阵是指有一个或多个等于零的维度(0×0,0×1,1×0)

示例:

emptyMatrix=[]          %创建空矩阵

size(emptyMatrix)       %行列数都为0

length(emptyMatrix)     %矩阵长度为0

numel(emptyMatrix)      %元素个数为0

isempty(emptyMatrix)    %判断是否为空矩阵,返回逻辑值1(真)

5. 序列矩阵

在MATLAB中创建一个序列矩阵,可以使用冒号操作符 : 或者函数 linspace 和 meshgrid。以下是一些示例:

 5.1 创建一个1到20间隔为2的序列矩阵(从1开始):

1)使用冒号操作符 “:”创建

>> A = 1:2:20;

2) 使用linspace函数创建

>> A=linspace(1,19,10) %保存10个数据

5.2 生成一个二维网格采样点矩阵和生成三维曲面图

       Matlab的meshgrid函数是用于生成网格坐标的函数,它可以将二维或三维数组作为输入,生成对应的网格坐标矩阵。这个函数在绘制三维图形、进行数值分析等方面有着广泛的应用。

语法格式: meshgrid(x, y)或meshgrid(X,Y,Z)

其中,x和y可以是任何一维或二维数组,分别表示x轴和y轴的坐标;X和Y可以是任何一维或二维数组,表示x轴和y轴坐标的范围;Z是可选的,如果提供,则生成三维图形的网格坐标矩阵。

示例1-生成二维网格采样点矩阵并绘制其矩阵点图

%使用meshgrid生成二维矩阵点并绘制二维坐标点图
clear all;
close all;
clc;
x=1:3;y=2:5;
 [X,Y]=meshgrid(x,y)
 plot(X,Y,'+','LineWidth',2,'Color','r'),title('显示meshgrid生成的二维网格点');
 xlim([-2,5]);
 ylim([-2,6]);
 grid on

上面程序运行结果如下所示:

    由上可知X和Y都是3行4列的矩阵,X矩阵的每一列值相同,分别是1、2和3,Y矩阵的每一行值都相同,分别是2、3、4和5,这是因为MATLAB的坐标原点是左上角,X正方向水平向右,Y正方向垂直向下。

示例2-生成三维曲面图:

[X,Y] = meshgrid(-2:.2:2, -4:.4:4);

Z = X .* exp(-X.^2 - Y.^2);

surf(X,Y,Z)%创建三维曲面图

6. 稀疏矩阵

       稀疏矩阵—在矩阵中,若数值为0的元素数目远远多于非0元素的数目,并且非0元素分布没有规律时,则称该矩阵为稀疏矩阵;与之相反,若非0元素数目占大多数时,则称该矩阵为稠密矩阵。MATLAB提供了sparse函数来创建稀疏矩阵。在MATLAB中,创建一个稀疏矩阵可以通过sparse函数实现,该函数接受行索引、列索引和非零值作为输入,并生成一个稀疏矩阵。

以下是创建稀疏矩阵的示例代码:

% 定义行索引、列索引和对应的值  

rows = [1; 3; 4; 5;6];  

cols = [1; 2; 3; 4; 8];  

values = [10; 20; 30; 35;40];  

% 使用sparse函数创建稀疏矩阵  

S = sparse(rows, cols, values);  

% 显示稀疏矩阵  

disp('显示稀疏矩阵的行列和非零值'),disp(S);  

% 如果你想要看到稀疏矩阵的完整形式(包括零),可以使用full函数  

disp('显示稀疏矩阵的完整形式'),disp(full(S));  

上面程序运行结果如下:

7.随机矩阵

       在MATLAB中,生成随机矩阵的常用函数是rand、randn、randi等。这些函数提供了不同的随机分布选项,以满足不同的应用需求,下面对上述各函数的含义和使用方法进行简要说明。

7.1 rand 函数

     rand函数生成均匀分布的随机数。其基本语法是rand(n)生成一个n×n的矩阵,rand(m,n)生成一个m×n的矩阵,而rand(size(A))生成与矩阵A相同大小的矩阵。

应用实例:生成一个5×5的均匀分布随机矩阵,并计算其均值和标准差。

MATLAB程序代码如下:

% 生成5x5的随机矩阵并计算其均值和标准差  

A = rand(5);  

% 计算均值  

%meanA = mean(A(:));  

meanA=mean2(A);  

% 计算标准差  

%stdA = std(A(:));  

stdA=std2(A);

disp('随机矩阵A:');  

disp(A);  

disp(['均值: ', num2str(meanA)]);  

disp(['标准差: ', num2str(stdA)]);

运行结果如下图所示:

7.2  randn

      randn(random normal distribution)是一种产生标准正态分布的随机数或矩阵的函数。randn函数生成标准正态分布的随机数(均值为0,标准差为1)。其语法与rand相同。

应用实例:生成一个10×10的标准正态分布随机矩阵,并计算其均值和标准差,并绘制其直方图以验证分布。

MATLAB程序代码如下:

% 生成10x10的标准正态分布随机矩阵  

B = randn(10,10);  %rand(10,10) 等价于rand(10)

meanB=mean2(B);   

stdB=std2(B);

% 绘制直方图  

figure;  

histogram(B(:), 'Normalization', 'pdf');  

title('标准正态分布随机矩阵的直方图');  

xlabel('值');  

ylabel('概率密度');

disp('随机矩阵B:');  

disp(B);  

disp(['均值: ', num2str(meanB)]);  %数据(n*n)不足够多,均值不绝对为0

disp(['标准差: ', num2str(stdB)]); %数据(n*n)不足够多,标准差不绝对为1

7.3  randi 函数

      在MATLAB命令提示符下,输入help  randi就会显示如下帮助:

randi- Pseudorandom integers from a uniform discrete distribution.因此randi函数生成指定范围内的均匀分布的伪随机整数。其基本语法是randi([imin, imax])生成介于imin和 imax之间的随机整数(包含imin和imax),或者randi(imax)生成1到imax之间的随机整数。

应用实例:生成一个10×12的矩阵,其元素为0到7(每个像素占用3bit)之间的随机整数,并计算矩阵各行的和,矩阵的最小值,最大值和平均值,显示其数字图像和randi分布随机矩阵的直方图。

MATLAB程序代码如下:

%%randi的应用

% 生成10x12的随机整数矩阵  

C = randi([0, 7], 10, 12);  

% 计算每行的和  

rowSums = sum(C, 2);  

meanC=mean2(C);  %计算其均值

minC=min(C(:));  %计算其最小值

maxC=max(C(:));  %计算其最大值

disp('随机整数矩阵C:');  

disp(C);  

disp('每行的和:');  

disp(rowSums);

figure,imshow(C,[]);

figure;  

histogram(C(:));  

title('randi分布随机矩阵的直方图');  

xlabel('灰度值');  

ylabel('频数');

程序的部分运行结果如下:

randi生成的矩阵C如下:

        矩阵C最大值maxC是7,最小值minC是0,平均值meanC是3.45(接近平均数(0+1+2+3+4+5+6+7)/8=3.5)。

矩阵C的图像显示如下图所示:

                   

       矩阵C的灰度直方图如下图所示:

             

       由直方图也可以看出,该分布其接近于均匀分布。大家可以使用上面程序生成100x120的随机整数矩阵并进行图像分析(矩阵的最大值、最小值和平均值和直方图等)。

      撰写博客不宜,如果大家觉得本文对大家学习有帮助,请点赞、收藏和评论,谢谢大家!

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

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

相关文章

用Java手写jvm之实现查找class

写在前面 完成类加载器加载class的三阶段,加载,解析,初始化中的加载😀😀😀 源码 。 jvm想要运行class,是根据类全限定名称来从特定的位置基于类加载器来查找的,分别如下:…

MySQL常见指令

MySQL中的数据类型 大致分为五种:数值,日期和时间,字符串,json,空间类型 每种类型也包括也一些不同的子类型,根据需要来选择。 如数值类型包括整数类型和浮点数类型 整数类型根据占用的存储空间的不同 又…

Javascript 沙漏图案(Hour-glass Pattern)

给定正整数 n,以沙漏形式打印数字模式。示例: 输入:rows_no 7 输出: 1 2 3 4 5 6 7 2 3 4 5 6 7 3 4 5 6 7 4 5 6 7 5 6 7 6 7 7 6 7 5 6 7 4 5 6 7 3 4 5 6 7 2 3 4 5 6 7 1 2 3 4 5 6…

指针的面试题

这里写目录标题 判断链表中是否有环描述代码检测链表中是否存在环链表中存在环想检测链表中是否存在环,而不需要找到环的入口 判断链表中是否有环 题目 描述 判断给定的链表中是否有环。如果有环则返回true,否则返回false。 数据范围:链表…

Java语言程序设计——篇九(1)

🌿🌿🌿跟随博主脚步,从这里开始→博主主页🌿🌿🌿 内部类 概述内部类—内部类的分类成员内部类实战演练 局部内部类实战演练 匿名内部类实战演练 静态内部类实战演练 概述 内部类或嵌套类&#…

不支持jdk8的jenkins部署jdk8项目

1、背景 目前最新的jenkins必须基于jdk8以上,才能安装。jenkins最新的插件部分也不支持jdk8了。 2、全局工具配置 配置一个jdk8 配置一个jdk8以上的版本,如jdk17 3、部署maven项目 jdk17项目 可以直接使用maven插件,部署。 jdk8项目 由…

Zenario CMS 9.2 文件上传漏洞(CVE-2022-23043)

前言 CVE-2022-23043 是一个影响 Zenario CMS 9.2 的严重漏洞。该漏洞允许经过身份验证的管理员用户绕过文件上传限制。具体来说,管理员可以通过创建一个新的带有 ".phar" 扩展名的“文件/MIME 类型”,然后上传一个恶意文件。在上传过程中&am…

运维锅总详解NFS

NFS是什么?如何对NFS进行部署及优化?NFS工作流程是什么?NFS的性能及优缺点是什么?NFS发展历史又是怎样的?希望本文能帮您解答这些疑惑! 一、NFS简介 NFS (Network File System) 是由 Sun Microsystems 在…

【最新】cudnn安装教程

最近换了新电脑需要重新安装cuda和cudnn,发现现在cudnn的安装比以前方便多了,直接在官网下载exe安装包一键运行即可。安装的时候注意cuda和cudnn的对应关系即可:【最新】cuda和cudnn和显卡驱动的对应关系-CSDN博客 访问cudnn下载链接cuDNN 9…

docker-compose 根据yaml拉取镜像出问题

在学习go微服务时,用docker-compose启动nacos以及对应的mysql时出现上面的问题, 使用的yaml如下 version: "3.8" services:nacos:image: nacos/nacos-server:${NACOS_VERSION}container_name: nacos-standalone-mysqlenv_file:- ../env/cust…

SpringCloud+Vue3多对多,多表联查

♥️作者:小宋1021 🤵‍♂️个人主页:小宋1021主页 ♥️坚持分析平时学习到的项目以及学习到的软件开发知识,和大家一起努力呀!!! 🎈🎈加油! 加油&#xff01…

c/c++的内存管理(超详细)

一、c/c的内存分布 这是操作系统中对于内存的划分: 我们重点掌握以下几个区域即可: 1.栈 (调用函数会建立栈帧) 2.堆(动态开辟的空间) 3.数据段(静态区):存放静态变量以及全局变量 4.代码段 (常量区) 先来看看一个题目: int…

JDK的配置

安装好JDK后,配置三个环境变量 第一步,配置JAVA_HOME. 先找到JDK的安装目录,然后复制路径,在电脑的环境变量里增添变量名为JAVA_HOME,变量值为 C:\Program Files\Java\jdk1.8.0_192。(具体根据你的JDK安装路径&…

Lombok的认识

Lombok的作用 Lombok是一个Java库,它可以通过简单的注解形式来帮助开发人员简化Java代码的编写,特别是减少模板代码的书写。具体来说,Lombok的主要作用包括: 减少模板代码:Lombok可以通过注解自动生成getter、setter、…

Python——Pandas(第三讲)

文章目录 修改替换变量值对应数值的替换指定数值范围的替换 虚拟变量变换数值变量分段数据分组基于拆分进行筛选 分组汇总使用 agg 函数进行汇总引用自定义函数 长宽格式转换转换为最简格式长宽型格式的自由互转 多个数据源的合并数据的横向合并concat 命令 处理缺失值认识缺失…

【Apache Doris】3.0存算分离|标准部署篇(一)

【Apache Doris】3.0存算分离|标准部署篇(一) 一、前提概要二、环境信息三、前置准备四、FoundationDB安装五、OpenJDK 17安装六、 Meta Service安装七、集群安装八、快速体验 接上 数据架构新篇章:存算一体与存算分离的协同演进。…

Meta 发布Llama 3.1开源模型 NVIDIA推出AI 代工服务

在这周二,Meta发布了最新的AI模型Llama 3.1,并且是一个开源模型,面向公众免费提供,且提供8B、70B、305B参数版本,模型整体效果可与 GPT-4、GPT-4o、Claude 3.5 Sonnet 等领先的闭源模型相媲美。 此次Llama 3.1 系列改…

Hadoop3.3.5的安装与单机/伪分布式配置

文章目录 一、安装须知二、安装jdk三、安装shh四、安装配置hadoop五、运行hadoop 一、安装须知 本次安装的Hadoop版本为hadoop3.3.5。 在这之前完成了VMware虚拟软件的安装,并安装了Ubuntu22.04,在这基础上进行相关配置。 二、安装jdk 在Ubuntu中使用…

顺序表算法题

在学习了顺序表专题后,了解的顺序表的结构以及相关概念后就可以来试着完成一些顺序表的算法题了,在本篇中将对三道顺序表相关的算法题进行讲解,希望能对你有所帮助,一起加油吧!!! 1.移除元素 2…

Lago - 使用 ClickHouse 扩展事件引擎

本文字数:4540;估计阅读时间:12 分钟 作者:Mathew Pregasen 本文在公众号【ClickHouseInc】首发 本周,我们欢迎来自 Lago 的一篇博客文章,介绍了他们如何使用 ClickHouse 扩展一个事件引擎,并在…