当前位置: 首页 > news >正文

计算机视觉基础:矩阵运算

矩阵及其表示方式

一个矩阵是由行(row)和列(column)组成的一个矩形数组,通常包含数字。我们可以用大写字母(如 A、B)来表示一个矩阵。例如,矩阵 A 可能看起来像这样:

A = [ a11 a12 a13 ][ a21 a22 a23 ][ a31 a32 a33 ]

其中,a11是位于第一行第一列的元素,a12是第一行第二列的元素,以此类推。图像可以被看作是一个巨大的矩阵,其中每个像素点对应矩阵中的一个元素。

矩阵基础运算

  • 矩阵加法和减法:矩阵的加减法是对应位置元素相加或相减。例如,如果有两个相同大小的矩阵 A 和 B,它们的加法 A+B 将产生一个新矩阵 C,其中 cij = aij + bij。
  • 矩阵数乘:矩阵 A 与一个标量 k 的数乘是将 A 中的每个元素乘以 k。

矩阵乘法

矩阵乘法是线性代数中的一个核心操作,它在图像处理、计算机图形学以及数据科学的许多方面都非常重要。现在,我将更详细地解释矩阵乘法以及如何计算两个矩阵的产品。

矩阵乘法详解

当你乘以两个矩阵时,你其实是在将第一个矩阵的行与第二个矩阵的列组合。对于两个矩阵 A 和 B,矩阵 A 的列数必须等于矩阵 B 的行数才能进行乘法。

我们来逐步分析一下具体的操作步骤:

  1. 确认矩阵 A 的列数等于矩阵 B 的行数。
  2. 创建结果矩阵 C,其维度将是矩阵 A 的行数乘以矩阵 B 的列数(如果 A 是 m×n 维,B 是 n×p 维,那么 C 是 m×p 维)。
  3. 计算矩阵 C 的每个元素 cij。为了找到 cij,你需要取矩阵 A 的第 i 行和矩阵 B 的第 j 列。
  4. 将 A 的第 i 行与 B 的第 j 列上的对应元素进行相乘,并将乘积相加。这个总和就是矩阵 C 的元素 cij。

简单举例解释

使用一个 2×3 的矩阵 A 和一个 3×2 的矩阵 B。

A = [ a11 a12 a13 ]     B = [ b11 b12 ][ a21 a22 a23 ]         [ b21 b22 ][ b31 b32 ]

令矩阵 A 和 B 为:

A = [ 1 2 3 ]    B = [ 7 8 ][ 4 5 6 ]        [ 9 0 ][ 1 2 ]

根据矩阵乘法的规则,我们可以计算矩阵 A 和 B 的乘积 C,结果矩阵 C 的大小将是 2×2。我们现在按步骤计算,并将乘积算式放到结果矩阵 C 中:

C = [ (a11*b11 + a12*b21 + a13*b31) (a11*b12 + a12*b22 + a13*b32) ][ (a21*b11 + a22*b21 + a23*b31) (a21*b12 + a22*b22 + a23*b32) ]

代入我们给定的矩阵:

C = [ (1*7 + 2*9 + 3*1) (1*8 + 2*0 + 3*2) ][ (4*7 + 5*9 + 6*1) (4*8 + 5*0 + 6*2) ]

计算得到结果矩阵 C 的每个元素:

C = [ (7 + 18 + 3) (8 + 0 + 6) ][ (28 + 45 + 6) (32 + 0 + 12) ]

将每个元素中的数值相加:

C = [ 28 14 ][ 79 44 ]

所以,矩阵 A 和 B 的乘积 C 是:

C = [ 28 14 ][ 79 44 ]

这就是矩阵乘法的结果。

稍复杂举例解释

我们让矩阵 A 是一个 2×3 的矩阵,矩阵 B 是一个 3×4 的矩阵。下面是 A 和 B 的示例:

A = [ a11 a12 a13 ]     B = [ b11 b12 b13 b14 ][ a21 a22 a23 ]         [ b21 b22 b23 b24 ][ b31 b32 b33 b34 ]

由于矩阵 A 的大小是 2×3,矩阵 B 的大小是 3×4,矩阵 A 的列数和矩阵 B 的行数相同,我们可以计算出它们的乘积 C。结果矩阵 C 的大小将是 2×4。

让我们具体计算矩阵 A 和 B 的乘积,并将乘积算式直接写在结果矩阵 C 中。

C = [ (a11*b11 + a12*b21 + a13*b31) (a11*b12 + a12*b22 + a13*b32) (a11*b13 + a12*b23 + a13*b33) (a11*b14 + a12*b24 + a13*b34) ][ (a21*b11 + a22*b21 + a23*b31) (a21*b12 + a22*b22 + a23*b32) (a21*b13 + a22*b23 + a23*b33) (a21*b14 + a22*b24 + a23*b34) ]

现在,我们来设定具体的数字来完成乘法:

A = [ 1 2 3 ]     B = [ 2 0 1 4 ][ 4 5 6 ]         [ 0 1 3 2 ][ 7 8 5 6 ]

计算出结果矩阵 C 的每个元素:

C = [ (1*2 + 2*0 + 3*7) (1*0 + 2*1 + 3*8) (1*1 + 2*3 + 3*5) (1*4 + 2*2 + 3*6) ][ (4*2 + 5*0 + 6*7) (4*0 + 5*1 + 6*8) (4*1 + 5*3 + 6*5) (4*4 + 5*2 + 6*6) ]

进行计算,我们得到:

C = [ (2 + 0 + 21) (0 + 2 + 24) (1 + 6 + 15) (4 + 4 + 18) ][ (8 + 0 + 42) (0 + 5 + 48) (4 + 15 + 30) (16 + 10 + 36) ]

将 C 中的每个元素简化:

C = [ 23 26 22 26 ][ 50 53 49 62 ]

所以,经过计算,我们得到的最终结果矩阵 C 是:

C = [ 23 26 22 26 ][ 50 53 49 62 ]

这个结果就是我们从矩阵 A 和 B 计算得到的乘积。

练习

假设我们有两个矩阵 A 和 B:

A = [1 2]    B = [5 6][3 4]        [7 8]

矩阵 A 是一个 2×2 的矩阵,矩阵 B 也是一个 2×2 的矩阵。它们的乘积 AB 将产生另一个 2×2 的矩阵 C。那么 C 就是:

C = [ c11 c12 ][ c21 c22 ]

我们现在来计算 C 的每一个元素。

  • 计算 c11:
    我们取 A 的第一行 [1 2] 和 B 的第一列 [5 7],
    之后将对应元素相乘并相加:1×5 + 2×7 = 5 + 14 = 19。
  • 计算 c12:
    我们取 A 的第一行 [1 2] 和 B 的第二列 [6 8],
    之后将对应元素相乘并相加:1×6 + 2×8 = 6 + 16 = 22。
  • 计算 c21:
    我们取 A 的第二行 [3 4] 和 B 的第一列 [5 7],
    之后将对应元素相乘并相加:3×5 + 4×7 = 15 + 28 = 43。
  • 计算 c22:
    我们取 A 的第二行 [3 4] 和 B 的第二列 [6 8],
    之后将对应元素相乘并相加:3×6 + 4×8 = 18 + 32 = 50。

所以,矩阵 C 就是:

C = [19 22][43 50]

这就完成了矩阵 A 和 B 的乘积。

矩阵乘法不符合交换律,也就是说,通常 AB ≠ BA。这是计算矩阵乘积时要特别注意的一点。

理解好矩阵乘法之后,在处理图像时,你会经常用到它来进行变换、过滤和其他操作。希望这个例子能够帮助你理解矩阵乘法的具体过程。

单位矩阵和逆矩阵

  • 单位矩阵:是一个特殊的方阵,其所有对角线上的元素都是 1,其余元素都是 0,记为 I。例如:
I = [ 1 0 0 ][ 0 1 0 ][ 0 0 1 ]
  • 逆矩阵:对于一个方阵 A,如果存在另一个方阵 B,使得 AB = BA = I,则我们说 B 是 A 的逆矩阵,记作 A^(-1)。不是所有矩阵都有逆矩阵,只有那些行列式(determinant)不为 0 的方阵才有逆矩阵。

矩阵的转置

转置操作将矩阵的行和列交换位置。对于矩阵 A,它的转置记为 A^T。A 的一个元素 aij 在 A^T 中的位置变成了 aji。

例如,如果有矩阵 A:

A = [ 1 2 ][ 3 4 ]

那么 A^T 就是:

A^T = [ 1 3 ][ 2 4 ]

相关文章:

计算机视觉基础:矩阵运算

矩阵及其表示方式 一个矩阵是由行(row)和列(column)组成的一个矩形数组,通常包含数字。我们可以用大写字母(如 A、B)来表示一个矩阵。例如,矩阵 A 可能看起来像这样: A [ a11 a12 a13 ][ a21 a22 a23 ][ a31 a32 a3…...

Gateway中Spring Security6统一处理CORS

文章目录 一、起因二、解决方法 一、起因 使用了gateway微服务作为整体的网关,并且整合了Spring Security6;还有一个system微服务,作为被请求的资源,当浏览器向gateway发送请求,请求system资源时,遇到CORS…...

突破编程_C++_基础教程(输入、输出与文件)

1 流和缓冲区 C中,流( stream )和缓冲区( buffer )是两个紧密相关的概念,它们在处理输入和输出时起着重要的作用。 流( Stream ) 流是一种抽象的概念,用于表示数据的流动…...

UE的 HUD 类中的必备方法和属性

在屏幕上绘制的方法 1. DrawText() DrawText() 方法允许开发者在屏幕上渲染文本。参数包括文本内容、位置、颜色、字体、缩放等。 void DrawText(const FString& Text, const FLinearColor& TextColor, float ScreenX, float ScreenY, UFont* Font, float Scale 1.…...

单片机的认识

单片机的定义 先简单理解为: 在一片集成电路芯片上集成了微处理器(CPU )存储器(ROM和RAM)、I/O 接口电路,构成单芯片微型计算机,即为单片机。 把组成微型计算机的控制器、运算器、存储器、输…...

转发:udig安装 用来为geoserver上shp地图配置显示样式 颜色

下载udig,解压缩 这东东是基于eclipse的,需要Java JRE 把 JDK 1.8 里面的jre目录拷贝到 udig目录下面 udig下载、安装及汉化,简单生成geoserver图层样式sld-CSDN博客...

Linux--常用命令(详解)

详细目录 一、终端命令格式二、显示文件列表命令-ls2.1作用2.2格式2.3 ls常用选项2.3.1 ls -a2.3.2 ls -l(等价于 ll)2.3.2 ls -h 三、相对路径与绝对路径3.1绝对路径3.2相对路径 四、目录操作命令 -cd4.1作用4.2格式4.3案例4.3.1 cd -: 返回上一次所在目录4.3.2 cd…...

SouthLeetCode-打卡24年02月第1周

SouthLeetCode-打卡24年02月第1周 // Date : 2024/02/01 ~ 2024/02/04 034.合并两个有序链表 (1) 题目描述 034#LeetCode.21.#北岸计划2024/02/01 将两个升序链表合并为一个新的 升序 链表并返回。 新链表是通过拼接给定的两个链表的所有节点组成的。 (2) 题解代码 cla…...

vscode的cmake工具小三角符号旁边没有目标的解决方法

vscode里面写了个项目,找了半天没办法用cmake调试,最后发现是cmake里面的set(CMAKE_BUILD_TYPE Release)导致的,都是release模式了当然不能调试了;改成Debug就行了 参考:https://stackoverflow.com/questions/7549672…...

Servlet JSP-Eclipse安装配置Maven插件

Maven 是一款比较常用的 Java 开发拓展包,它相当于一个全自动 jar 包管理器,会导入用户开发时需要使用的相应 jar 包。使用 Maven 开发 Java 程序,可以极大提升开发者的开发效率。下面我就跟大家介绍一下如何在 Eclipse 里安装和配置 Maven 插…...

os模块

os 模块是 Python 中用于与操作系统进行交互的标准库之一。它提供了许多函数来执行文件和目录操作,管理进程以及与操作系统交互的其他功能。 下面是一些 os 模块中常用的函数和功能: 文件和目录操作: os.getcwd(): 返回当前工作目录的路径。…...

【C语言进阶】深度剖析数据在内存中的存储--上

1. C语言中的数据类型的简单介绍 注:C99标准里面,定义了bool类型变量。这时,只要引入头文件stdbool.h ,就能在C语言里面正常使用bool类型。 1.1 在C语言中各类型所占内存空间的大小如下 char类型的数据类型大小为1字节即8比特位。…...

【doghead】VS2022 win11 安装配置WSL2 以编译linux端的cmake项目并运行2

【bifrost】VS2022 win11 安装配置WSL2 以编译linux端的cmake项目并运行1 完成了WSL2的安装。13900K 的电脑安装了ubuntu22.04构建中出现了一些问题,fix了。发现libuv 似乎不识别,认为是libuv.so ,无法让worker识别到uv 从而没构建。干脆单独构建好了,官方的脚本如此:而且…...

【教程】C++语言基础学习笔记(七)——Array数组

写在前面: 如果文章对你有帮助,记得点赞关注加收藏一波,利于以后需要的时候复习,多谢支持! 【C语言基础学习】系列文章 第一章 《项目与程序结构》 第二章 《数据类型》 第三章 《运算符》 第四章 《流程控制》 第五章…...

BUGKU-WEB GET

题目描述 没有提示,就一个get,启动场景看看: 解题思路 显然是PHP语言解读分析代码吧写出你的payload 相关工具 略 解题步骤 进入场景分析代码 $what$_GET[what]; echo $what; if($whatflag) echo flag{****};前两句:使用get…...

蓝桥杯每日一题----唯一分解定理

唯一分解定理 1.内容 任何一个大于1的整数n都可以分解成若干个质数的连乘积,如果不计各个质数的顺序,那么这种分解是惟一的,即若n>1,则有 n ∏ p i j n\prod{p^j_i} n∏pij​ 这里的 p i p_i pi​是质数。可以进行简单证明…...

openssl3.2 - osslsigncode工程的学习

文章目录 openssl3.2 - osslsigncode工程的学习概述笔记工程库地址工程的编译osslsigncodeM工程文件列表osslsigncodeM工程搭建细节原始工程实现的改动自己封装的包含openssl和curl的实现osslsigncodeM工程命令行的用法备注 - VS2019调试环境备注 - 如果要单步openssl的API学学…...

HTML 超文本标记语言

超文本标记语言 HTML 在一个客户程序主窗口上显示出的万维网文档称为页面 (page)。 页面制作的标准语言:HTML。 超文本标记语言 HTML (HyperText Markup Language) 是一种制作万维网页面的标准语言,它消除了不同计算机之间信息交流的障碍&#xff0c…...

sklearn:机器学习 分类特征编码category_encoders

文章目录 category_encoders简介OrdinalEncoder 序列编码OneHotEncoder 独热编码TargetEncoder 目标编码Binary Encoder 二进制编码BaseNEncoder 贝叶斯编码LeaveOneOutEncoder 留一法HashingEncoder 哈希编码CatBoostEncoder catboost目标编码CountEncoder 频率编码WOEEncoder…...

C++错误[错误] call of overloaded ‘min(int, int)‘ is ambiguous

错误代码&#xff1a; #include<iostream> using namespace std;template <class T> T min(T x,T y){if(x<y){return x;}else return y; }int main(){int n12,n210;double d11.5,d25.6;cout<<min(n1,n2)<<endl;cout<<min(d1,d2)<<endl…...

[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解

突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 ​安全措施依赖问题​ GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

Java如何权衡是使用无序的数组还是有序的数组

在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

无法与IP建立连接,未能下载VSCode服务器

如题&#xff0c;在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈&#xff0c;发现是VSCode版本自动更新惹的祸&#xff01;&#xff01;&#xff01; 在VSCode的帮助->关于这里发现前几天VSCode自动更新了&#xff0c;我的版本号变成了1.100.3 才导致了远程连接出…...

基于Flask实现的医疗保险欺诈识别监测模型

基于Flask实现的医疗保险欺诈识别监测模型 项目截图 项目简介 社会医疗保险是国家通过立法形式强制实施&#xff0c;由雇主和个人按一定比例缴纳保险费&#xff0c;建立社会医疗保险基金&#xff0c;支付雇员医疗费用的一种医疗保险制度&#xff0c; 它是促进社会文明和进步的…...

【Go】3、Go语言进阶与依赖管理

前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课&#xff0c;做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程&#xff0c;它的核心机制是 Goroutine 协程、Channel 通道&#xff0c;并基于CSP&#xff08;Communicating Sequential Processes&#xff0…...

Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)

引言&#xff1a;为什么 Eureka 依然是存量系统的核心&#xff1f; 尽管 Nacos 等新注册中心崛起&#xff0c;但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制&#xff0c;是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...

优选算法第十二讲:队列 + 宽搜 优先级队列

优选算法第十二讲&#xff1a;队列 宽搜 && 优先级队列 1.N叉树的层序遍历2.二叉树的锯齿型层序遍历3.二叉树最大宽度4.在每个树行中找最大值5.优先级队列 -- 最后一块石头的重量6.数据流中的第K大元素7.前K个高频单词8.数据流的中位数 1.N叉树的层序遍历 2.二叉树的锯…...

华硕a豆14 Air香氛版,美学与科技的馨香融合

在快节奏的现代生活中&#xff0c;我们渴望一个能激发创想、愉悦感官的工作与生活伙伴&#xff0c;它不仅是冰冷的科技工具&#xff0c;更能触动我们内心深处的细腻情感。正是在这样的期许下&#xff0c;华硕a豆14 Air香氛版翩然而至&#xff0c;它以一种前所未有的方式&#x…...

九天毕昇深度学习平台 | 如何安装库?

pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子&#xff1a; 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...

return this;返回的是谁

一个审批系统的示例来演示责任链模式的实现。假设公司需要处理不同金额的采购申请&#xff0c;不同级别的经理有不同的审批权限&#xff1a; // 抽象处理者&#xff1a;审批者 abstract class Approver {protected Approver successor; // 下一个处理者// 设置下一个处理者pub…...