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

必备的数学知识是理解人工智能不可或缺的要素,今天的种种人工智能技术归根到底都建立在数学模型之上,而这些数学模型又都离不开线性代数(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.rhkb.cn/news/14733.html

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

相关文章

5 计算机网络

5 计算机网络 5.1 OSI/RM七层模型 5.2 TCP/IP协议簇 5.2.1:常见协议基础 一、 TCP是可靠的,效率低的; 1.HTTP协议端口默认80,HTTPSSL之后成为HTTPS协议默认端口443。 2.对于0~1023一般是默认的公共端口不需要注册,1024以后的则需…

unity碰撞的监测和监听

1.创建一个地面 2.去资源商店下载一个火焰素材 3.把procedural fire导入到自己的项目包管理器中 4.给magic fire 0 挂在碰撞组件Rigidbody , Sphere Collider 5.创建脚本test 并挂在magic fire 0 脚本代码 using System.Collections; using System.Collections.Generic; usi…

使用云效解决docker官方镜像拉取不到的问题

目录 前言原文地址测试jenkins构建结果:后续使用说明 前言 最近经常出现docker镜像进行拉取不了,流水线挂掉的问题,看到一个解决方案: 《借助阿里个人版镜像仓库云效实现全免费同步docker官方镜像到国内》 原文地址 https://developer.aliyun.com/artic…

element-plus+vue3前端如何根据name进行搜索查到符合条件的数据

界面如图&#xff0c;下面的区域是接口给的所有的&#xff0c;希望前端根据输入的内容自己去匹配。 我是使用的element-plusvue3ts的写法。 <el-input v-model"filters.region" placeholder"输入区域搜索" keyup"filterRegion(filters.region)&q…

电路研究9.3——合宙Air780EP中的AT开发指南(含TCP 示例)

根据合宙的AT研发推荐&#xff0c; AT指令基本上也简单看完了&#xff0c;这里开始转到AT的开发了。 AT 命令采用标准串口进行数据收发&#xff0c;将以前复杂的设备通讯方式转换成简单的串口编程&#xff0c; 大大简化了产品的硬件设计和软件开发成本&#xff0c;这使得几乎所…

cursor指令工具

Cursor 工具使用指南与实例 工具概览 Cursor 提供了一系列强大的工具来帮助开发者提高工作效率。本指南将通过具体实例来展示这些工具的使用方法。 1. 目录文件操作 1.1 查看目录内容 (list_dir) 使用 list_dir 命令可以查看指定目录下的文件结构: 示例: list_dir log…

AI安全最佳实践:AI应用开发安全评估矩阵(上)

生成式AI开发安全范围矩阵简介 生成式AI目前可以说是当下最热门的技术&#xff0c;吸引各大全球企业的关注&#xff0c;并在全球各行各业中带来浪潮般的编个。随时AI能力的飞跃&#xff0c;大语言模型LLM参数达到千亿级别&#xff0c;它和Transformer神经网络共同驱动了我们工…

Java继承简介

继承的本质&#xff1a;是代码的复用&#xff0c;重复使用已经定义好的方法和域&#xff08;即全局变量&#xff09; 要掌握继承首先要了解Java方法的重载和重写 方法的重载和重写 方法的重载 当前方法名相同&#xff0c;但是参数类型不同&#xff0c;发生重载 类比数学函…

【redis】缓存设计规范

本文是 Redis 键值设计的 14 个核心规范与最佳实践&#xff0c;按重要程度分层说明&#xff1a; 一、通用数据类型选择 这里我们先给出常规的选择路径图。 以下是对每个步骤的分析&#xff1a; 是否需要排序&#xff1f;&#xff1a; zset&#xff08;有序集合&#xff09;用…

Unity抖音云启动测试:如何用cmd命令行启动exe

相关资料&#xff1a;弹幕云启动&#xff08;原“玩法云启动能力”&#xff09;_直播小玩法_抖音开放平台 1&#xff0c;操作方法 在做云启动的时候&#xff0c;接完发现需要命令行模拟云环境测试启动&#xff0c;所以研究了下。 首先进入cmd命令&#xff0c;CD进入对应包的文件…

Android studio怎么创建assets目录

在Android Studio中创建assets文件夹是一个简单的步骤&#xff0c;通常用于存储不需要编译的资源文件&#xff0c;如文本文件、图片、音频等 main文件夹&#xff0c;邮件new->folder-assets folder

第26场蓝桥入门赛

5.扑克较量【算法赛】 - 蓝桥云课 C&#xff1a; #include <iostream> #include <algorithm> using namespace std;int a[100005];int main() {int n,k;cin>>n>>k;for (int i1; i<n; i)cin>>a[i], a[i] % k;sort(a1, a1n);int mx a[1]k-a…

公司配置内网穿透方法笔记

一、目的 公司内部有局域网&#xff0c;局域网上有ftp服务器&#xff0c;有windows桌面服务器&#xff1b; 在内网环境下&#xff0c;是可以访问ftp服务器以及用远程桌面登录windows桌面服务器的&#xff1b; 现在想居家办公时&#xff0c;也能访问到公司内网的ftp服务器和win…

c++:list

1.list的使用 1.1构造 1.2迭代器遍历 &#xff08;1&#xff09;迭代器是算法和容器链接起来的桥梁 容器就是链表&#xff0c;顺序表等数据结构&#xff0c;他们有各自的特点&#xff0c;所以底层结构是不同的。在不用迭代器的前提下&#xff0c;如果我们的算法要作用在容器上…

《Wiki.js知识库部署实践 + CNB Git数据同步方案解析》

一、wiki.js 知识库简介 基本概述 定义 &#xff1a;Wiki.js 是一个开源、现代、轻量且功能强大的 Wiki 应用程序&#xff0c;基于 Node.js 构建&#xff0c;旨在帮助个人和团队轻松创建、管理和共享知识。开源性质 &#xff1a;它遵循 AGPLv3 许可证&#xff0c;任何人都可以…

ip地址是手机号地址还是手机地址

在数字化生活的浪潮中&#xff0c;IP地址、手机号和手机地址这三个概念如影随形&#xff0c;它们各自承载着网络世界的独特功能&#xff0c;却又因名称和功能的相似性而时常被混淆。尤其是“IP地址”这一术语&#xff0c;经常被错误地与手机号地址或手机地址划上等号。本文旨在…

微服务 day01 注册与发现 Nacos OpenFeign

目录 1.认识微服务&#xff1a; 单体架构&#xff1a; 微服务架构&#xff1a; 2.服务注册和发现 1.注册中心&#xff1a; 2.服务注册&#xff1a; 3.服务发现&#xff1a; 发现并调用服务&#xff1a; 方法1&#xff1a; 方法2&#xff1a; 方法3:OpenFeign OpenFeig…

网络安全:挑战、技术与未来发展

&#x1f4dd;个人主页&#x1f339;&#xff1a;一ge科研小菜鸡-CSDN博客 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; 1. 引言 在数字化时代&#xff0c;网络安全已成为全球关注的焦点。随着互联网的普及和信息技术的高速发展&#xff0c;网络攻击的…

PostgreSql-COALESCE函数、NULLIF函数、NVL函数使用

COALESCE函数 COALESCE函数是返回参数中的第一个非null的值&#xff0c;它要求参数中至少有一个是非null的; select coalesce(1,null,2),coalesce(null,2,1),coalesce(null,null,null); NULLIF(ex1,ex2)函数 如果ex1与ex2相等则返回Null&#xff0c;不相等返回第一个表达式的值…

neo4j-解决导入数据后出现:Database ‘xxxx‘ is unavailable. Run :sysinfo for more info.

目录 问题描述 解决方法 重新导入 问题描述 最近在linux上部署了neo4j&#xff0c;参照之前写的博客:neo4j-数据的导出和导入_neo4j数据导入导出-CSDN博客 进行了数据导出、导入操作。但是在进行导入后&#xff0c;重新登录网页版neo4j&#xff0c;发现对应的数据库状态变…