人工智能入门 数学基础 线性代数 笔记

必备的数学知识是理解人工智能不可或缺的要素,今天的种种人工智能技术归根到底都建立在数学模型之上,而这些数学模型又都离不开线性代数(linear algebra)的理论框架。

线性代数的核心意义:世间万事万物都可以被抽象成某种特征组合,并可以再预配置的规则框架下以静态和动态的方式观察。

基本概念

集合Set

某些特定对象汇总处的集体,而集合中每些元素会有某些共性。

对于集合 { 苹果,橘子,梨 } 来说, 所有元素的共性是它们都是水果;对于集合 {牛,马,羊} 来说,所有元素的共性是它们都是动物。

当然 { 苹果,牛 } 也可以构成一个集合,但这两个元素并没有明显的共性,这样的集合在解决实际问题中的作用也就相当有限。

“苹果”或是“牛”这样的具体概念显然超出了数学的处理范围,因而集合的元素需要进行进一步的抽象——用数字或符号来表示。

标量Scalar

在线性代数中,由单独的数 a 构成的元素被称为标量(scalar):一个标量 a 可以是整数、实数或复数。

向量Vector(去重)

如果多个标量a1、a2、a3、。。。an,按一定顺序组成一个序列,这个序列就可以叫向量(Vector)

向量可以看做是标量的扩展,原始的一个数的标量可以被替代一组向量,带来维度上的增加,给定索引下标才能确定向量中的唯一元素。

矩阵(Matrix)

每个向量都由若干个标量组成,而将向量的所有规格的标量都替换为相同规格的向量,则是矩阵(Matrix)

( a 11 a 12 a 13 a 21 a 22 a 23 a 31 a 32 a 33 ) \begin{pmatrix}a_{11} & a_{12} & a_{13} \\a_{21} & a_{22} & a_{23} \\a_{31} & a_{32} & a_{33}\end{pmatrix} a11a21a31a12a22a32a13a23a33

对于向量,矩阵同样增加了维度。

使用矩阵的某个元素,需要使用两个索引。

张量(Tensor)

如果将矩阵中的每个标量元素替换为向量的话,得到的就是张量(tensor),更高阶的矩阵。

举例:

image.png

如果把三阶魔方的每一个小方块看作一个数,它就是个 3×3×3 的张量,3×3 的矩阵则恰是这个魔方的一个面,也就是张量的一个切片。相比于向量和矩阵,张量是更加复杂,直观性也更差的概念。

数学概念魔方类比维度例子
标量(Scalar)单个小方块的颜色0D“红”
向量(Vector)一行或一列1D[红,绿,黄][红, 绿, 黄][红,绿,黄]
矩阵(Matrix)魔方的一个面2D[[红,绿,黄],[红, 绿, 黄],[红,绿,黄]]
张量(Tensor)整个魔方3D3×3×33×3×33×3×3 立方体存储颜色
  • 在计算机存储中,标量占据的是零维数组;
  • 向量占据的是一维数组,例如语音信号;
  • 矩阵占据的是二维数组,例如灰度图像;
  • 张量占据的是三维乃至更高维度的数组,例如 RGB 图像和视频。

数学语言

描述作为数学对象的向量需要有特定的数学语言,范数内积就是代表。

范数(Norm)

范数(norm)是对单个向量大小的度量,描述的是向量自身的性质,其作用是将向量映射为一个非负的数值

对于给定向量:

X = ( X 1 , X 2 , X 3 , … , X n ) \mathbf{X} = (X_1,X_2,X_3,\dots,X_n) X=(X1,X2,X3,,Xn)

通用 L p L^p Lp范数定义:

∣ x ∣ p = ( ∑ i ∣ x i ∣ p ) 1 p |\mathbf{x}|_p = \left( \sum_{i} |x_i|^p \right)^{\frac{1}{p}} xp=(ixip)p1

对⼀个给定向量,

  • L1 范数计算的是向量所有元素绝对值的和(曼哈顿范数),

∥ x ∥ 1 = ∑ i = 1 n ∣ x i ∣ \|\mathbf{x}\|1 = \sum{i=1}^{n} |x_i| x∥1=i=1nxi

计算的是向量所有元素绝对值的和。

  • L2 范数计算的是通常意义上的向量长度, ∥ x ∥ 2 = ∑ i = 1 n x i 2 = x 1 2 + x 2 2 + ⋯ + x n 2 \|\mathbf{x}\|_2 = \sqrt{\sum_{i=1}^{n} x_i^2} = \sqrt{x_1^2 + x_2^2 + \cdots + x_n^2} x2=i=1nxi2 =x12+x22++xn2 计算的是通常意义上的向量长度,即从原点到向量 的直线距离。
  • L∞ 范数计算的则是向量中最大元素的取值。 ∥ x ∥ ∞ = lim ⁡ p → ∞ ∥ x ∥ p = max ⁡ 1 ≤ i ≤ n ∣ x i ∣ \|\mathbf{x}\|_\infty = \lim_{p \to \infty} \|\mathbf{x}\|_p = \max_{1 \leq i \leq n} |x_i| x=limpxp=max1inxi

内积(Inner Product)

范数计算的是单个向量的尺度,内积(inner product)计算的则是两个向量之间的关系。

两个相同维数向量内积的表达式为:

⟨ x , y ⟩ = ∑ i x i ⋅ y i ⟨x,y⟩=\sum_i{xi⋅yi} x,y=ixiyi

即对应元素乘积的求和。内积能够表示两个向量之间的相对位置,即向量之间的夹角

一种特殊的情况是内积为 0,即 ⟨x,y⟩=0。在二维空间上,这意味着两个向量的夹角为 90 ,即相互垂直

⟨ x , y ⟩ = 0 \langle \mathbf{x}, \mathbf{y} \rangle = 0 x,y=0

  • 说明两个向量正交(orthogonal),即互相垂直(夹角90°)
  • 代表线性无关

线性空间和内积空间

线性空间(Linear Space)

如果有一个集合,它的元素都是相同维数的向量,并且我们可以进行加法(vector addition)和数乘(scalar multiplication),这样的集合被称为 线性空间(向量空间)。

例子:

  • 几何上的向量空间:二维空间 R 2 \mathbb{R}^2 R2 和三维空间 R 3 \mathbb{R}^3 R3 都是线性空间。
  • 数据特征空间:比如所有人的身高、体重和年龄组成的三维向量集合。

线性空间特征

线性空间的一个重要特征是能够承载变化。当作为参考系的标准正交基确定后,空间中的点就可以用向量表示。当这个点从一个位置移动到另一个位置时,描述它的向量也会发生改变。点的变化对应着向量的线性变换(linear transformation),而描述对象变化抑或向量变换的数学语言,正是矩阵。

在线性空间中,变化的实现有两种方式:一是点本身的变化,二是参考系的变化。

使某个点发生变化的方法是用代表变化的矩阵乘以代表对象的向量。可是反过来,如果保持点不变。

而是换一种观察的角度,得到的也将是不同的结果,正所谓“横看成岭侧成峰,远近高低各不同”。

内积空间(Inner Product Space)

如果在线性空间中定义了内积运算,则称其为 内积空间,这意味着可以衡量向量之间的角度和相似度。

  • 在几何中,内积描述了向量的夹角

⟨ x , y ⟩ = ∥ x ∥ 2 ∥ y ∥ 2 c o s ⁡ θ ⟨ x , y ⟩ = ∥ x ∥ 2 ∥ y ∥ 2 cos ⁡ θ ⟨x,y⟩=∥x∥2∥y∥2cos⁡θ\langle \mathbf{x}, \mathbf{y} \rangle = \|\mathbf{x}\|_2 \|\mathbf{y}\|_2 \cos\theta x,y=x∥2∥y∥2cosθx,y=x2y2cosθ

这有助于分析向量在某个方向上的投影。

  • 在机器学习中,特征空间中的点代表数据对象,内积用于计算数据对象之间的相似性

高维空间(如深度学习中的向量嵌入空间),所有数据点都可以看作是一个向量,每个点都有一个唯一的向量表示。因此,点和向量是等价的

数据点 ⟺ 特征向量 \text{数据点} \Longleftrightarrow \text{特征向量} 数据点特征向量

概念作用数学表达实际意义
向量(Vector)代表一个对象或行为的特征 x = ( x 1 , x 2 , . . . , x n ) x = ( x 1 , x 2 , . . . , x n ) x = ( x 1 ​ , x 2 ​ , . . . , x n ​ ) x=(x1,x2,...,xn)\mathbf{x} = (x_1, x_2, ..., x_n)x=(x1​,x2​,...,xn​) x=(x1,x2,...,xn)x=(x1,x2,...,xn)x=(x1​,x2​,...,xn)图片、文本、用户行为等数据都可以表示为向量
范数(Norm)衡量向量的大小 ∥ x ∥ p ​ = ( i ∑ ​ ∣ x i ​ ∣ p ) p 1 ∥x∥p​=(i∑​∣xi​∣p)p1 xp=(ixip)p1x_i
内积(Inner Product)衡量两个向量的关系 ⟨ x , y ⟩ = ∑ x i y i ⟨ x , y ⟩ = ∑ x i y i ⟨ x , y ⟩ = ∑ x i ​ y i ⟨x,y⟩=∑xiyi\langle \mathbf{x}, \mathbf{y} \rangle = \sum x_i y_i⟨x,y⟩=∑xi​yi x,y=xiyix,y=xiyix,y=xiyi计算相似性,预测匹配程度

向量变换(linear transformation)

矩阵作用到向量 Ax=y

假设我们有一个矩阵A和一个向量x,它们的乘积定义为:

A x = y A\mathbf{x} = \mathbf{y} Ax=y

这表示矩阵 A 对向量 x 进行了某种变换,结果是一个新的向量 y(维度与x 相同)。

示例

如果矩阵 A 是一个 旋转矩阵,那么它的作用可能是旋转向量 x 而不改变其长度。
如果矩阵 A 是一个 缩放矩阵,那么它可能是将向量的长度按比例放大或缩小。

特征向量与特征值

有一种特殊情况:如果矩阵 AAA 作用在某个向量 xxx 上后,得到的结果仍然是它自己的缩放版本,即:

A x = b x A\mathbf{x} = b \mathbf{x} Ax=bx

那么,x 就被称为 矩阵 A 的特征向量(eigenvector),而 b 就是对应的特征值(eigenvalue)

直观理解

  • 特征向量 是在矩阵变换下方向不变的向量,只可能被拉伸或缩短,而不会被旋转到其他方向。
  • 特征值 是拉伸或缩短的比例因子。

示例

假设:
A = [ 2 0 0 3 ] , x = [ 1 0 ] A= \begin{bmatrix} 2 & 0 \\ 0 & 3 \end{bmatrix}, \quad x = \begin{bmatrix} 1 \\ 0 \end{bmatrix} A=[2003],x=[10]

计算矩阵乘法:
image-20250205184945550

我们发现:

  • 向量 x = [ 1 0 ] x = \begin{bmatrix} 1 \\ 0 \end{bmatrix} x=[10]没有改变方向,只是被拉伸了 2 倍。
  • 这意味着 x 是 A 的特征向量,对应的特征值是 2。

要点

  • 线性代数的本质在于将具体事物抽象为数学对象,并描述其静态和动态的特性;
  • 向量的实质是 n 维线性空间中的静止点;
  • 线性变换描述了向量或者作为参考系的坐标系的变化,可以用矩阵表示。
  • 矩阵的特征值和特征向量描述了变化的速度与方向。

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

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

相关文章

C# Winform怎么设计串口,客户端和相机控件界面显示

首先我们必须把这个类创建好 INIAPI using System; using System.Text; using System.Runtime.InteropServices;namespace Ini {public class IniAPI{#region INI文件操作/** 针对INI文件的API操作方法,其中的节点(Section)、键(KEY&#x…

【大数据技术】用户行为日志分析(python+hadoop+mapreduce+yarn+hive)

用户行为日志分析(python+hadoop+mapreduce+yarn+hive) 搭建完全分布式高可用大数据集群(VMware+CentOS+FinalShell) 搭建完全分布式高可用大数据集群(Hadoop+MapReduce+Yarn) 本机PyCharm远程连接虚拟机Python 搭建完全分布式高可用大数据集群(MySQL+Hive)

在 Windows 上使用 ZIP 包安装 MySQL 的详细步骤

以下是使用官方 ZIP 包在 Windows 上安装 MySQL 的详细步骤,确保能通过 mysql -uroot -p 成功连接。 步骤 1:下载 MySQL ZIP 包 访问 MySQL 官方下载页面: https://dev.mysql.com/downloads/mysql/选择 Windows (x86, 64-bit), ZIP Archive&…

前端学习-页面尺寸事件以及阻止默认行为(三十三)

目录 前言 页面尺寸事件 语法 检测屏幕宽度 获取宽高 元素尺寸的位置 总结 示例代码 阻止默认行为 阻止冒泡 语法 阻止冒泡如何做 阻止元素默认行为如何做 总结 前言 晚上好各位 页面尺寸事件 会在窗口尺寸改变的时候触发条件 语法 window.addEventListener(…

el-table表格点击单元格实现编辑

使用 el-table 和 el-table-column 创建表格。在单元格的默认插槽中,使用 div 显示文本内容,单击时触发编辑功能。使用 el-input 组件在单元格中显示编辑框。data() 方法中定义了 tableData,tabClickIndex: null,tabClickLabel: ,用于判断是否…

Windows逆向工程入门之汇编环境搭建

公开视频 -> 链接点击跳转公开课程博客首页 -> ​​​链接点击跳转博客主页 Visual Studio逆向工程配置 基础环境搭建 Visual Studio 官方下载地址安装配置选项(后期可随时通过VS调整) 使用C的桌面开发 拓展可选选项 MASM汇编框架 配置MASM汇编项目 创建新项目 选择空…

redis专栏解读

本篇起导读、目录的作用,介绍redis专栏涉及的内容以及目录。 redis是我们日常开发中常用的NOSQL数据库,本专栏讲讲解redis的内部实现原理,不会侧重于API的使用,遇到API使用上会简单概括。本专栏大致会分为基础部分(数…

【华为OD机考】华为OD笔试真题解析(1)--AI处理器组合

一、题目描述 某公司研发了一款高性能AI处理器,每台物理设备具备8颗AI处理器,编号分别为0、1、2、3、4、5、6、7。 编号0~3的处理器处于同一链路中,编号4~7的处理器处于另外一个链路中,不同链路中的处理器不能通信,如…

网络安全-HSTS

什么是HSTS? HTTP严格传输安全协议(HTTP Strict Transport Security,简称:HSTS) 是互联网安全策略机制。网站可以选择使用HSTS策略,来让浏览器强制使用HTTPS与网站进行通信,以减少会话劫持风险。…

手写一个C++ Android Binder服务及源码分析

手写一个C Android Binder服务及源码分析 前言一、 基于C语言编写Android Binder跨进程通信Demo总结及改进二、C语言编写自己的Binder服务Demo1. binder服务demo功能介绍2. binder服务demo代码结构图3. binder服务demo代码实现3.1 IHelloService.h代码实现3.2 BnHelloService.c…

DeepSeekMoE 论文解读:混合专家架构的效能革新者

论文链接:DeepSeekMoE: Towards Ultimate Expert Specialization in Mixture-of-Experts Language Models 目录 一、引言二、背景知识(一)MoE架构概述(二)现有MoE架构的问题 三、DeepSeekMoE架构详解(一&a…

人工智能领域-CNN 卷积神经网络 性能调优

在自动驾驶领域,对卷积神经网络(CNN)进行性能调优至关重要,以下从数据处理、模型架构、训练过程、超参数调整和模型部署优化等多个方面为你详细介绍调优方法,并给出相应的代码示例。 1. 数据处理 数据增强&#xff1…

[每周一更]-(第133期):Go中MapReduce架构思想的使用场景

文章目录 **MapReduce 工作流程**Go 中使用 MapReduce 的实现方式:**Go MapReduce 的特点****哪些场景适合使用 MapReduce?**使用场景1. 数据聚合2. 数据过滤3. 数据排序4. 数据转换5. 数据去重6. 数据分组7. 数据统计8.**统计文本中单词出现次数****代码…

【Pandas】pandas Series var

Pandas2.2 Series Computations descriptive stats 方法描述Series.abs()用于计算 Series 中每个元素的绝对值Series.all()用于检查 Series 中的所有元素是否都为 True 或非零值(对于数值型数据)Series.any()用于检查 Series 中是否至少有一个元素为 T…

Http 的响应码有哪些? 分别代表的是什么?

HTTP 状态码分为多个类别,下面是常见的 HTTP 状态码及其含义,包括 3xx 重定向状态码的详细区别: 📌 HTTP 状态码分类 分类状态码范围说明1xx100-199信息性状态码,表示请求已被接收,继续处理2xx200-299成功…

【工具篇】深度剖析 Veo2 工具:解锁 AI 视频创作新境界

在当下这个 AI 技术日新月异的时代,各种 AI 工具如雨后春笋般涌现,让人目不暇接。今天,我就来给大家好好说道说道谷歌旗下的 Veo2,这可是一款在 AI 视频创作领域相当有分量的工具。好多朋友都在问,Veo2 到底厉害在哪?好不好上手?能在哪些地方派上用场?别着急,今天我就…

slam学习笔记8---fastlio2运行效率高缘由

前言:lio里面,fastlio2的精度和速度表现很显眼。有必要总结一下运行效果高的缘由。参考各大家,从个人对fastlio2理解,汇总所得。 Fast-LIO2 运行速度快的主要原因可以归结为以下几个方面: 🔹 1. 采用增量…

【C++高并发服务器WebServer】-13:多线程服务器开发

本文目录 一、多线程服务器开发二、TCP状态转换三、端口复用 一、多线程服务器开发 服务端代码如下。 #include <stdio.h> #include <arpa/inet.h> #include <unistd.h> #include <stdlib.h> #include <string.h> #include <pthread.h>s…

SpringCloud面试题----Nacos和Eureka的区别

功能特性 服务发现 Nacos&#xff1a;支持基于 DNS 和 RPC 的服务发现&#xff0c;提供了更为灵活的服务发现机制&#xff0c;能满足不同场景下的服务发现需求。Eureka&#xff1a;主要基于 HTTP 的 RESTful 接口进行服务发现&#xff0c;客户端通过向 Eureka Server 发送 HT…

在 Open WebUI+Ollama 上运行 DeepSeek-R1-70B 实现调用

在 Open WebUI Ollama 上运行 DeepSeek-R1-70B 实现调用 您可以使用 Open WebUI 结合 Ollama 来运行 DeepSeek-R1-70B 模型&#xff0c;并通过 Web 界面进行交互。以下是完整的部署步骤。 1. 安装 Ollama Ollama 是一个本地化的大模型管理工具&#xff0c;它可以在本地运行 …