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

几种矩阵内积的定义和计算

1. Frobenius Inner Product(矩阵内积)

定义:Frobenius 内积是两个矩阵逐元素乘积的总和。
对于两个维度相同的矩阵 A A A B B B,其内积定义为:

⟨ A , B ⟩ = tr ( A T B ) = ∑ i = 1 m ∑ j = 1 n a i j b i j \langle A, B \rangle = \text{tr}(A^T B) = \sum_{i=1}^{m} \sum_{j=1}^{n} a_{ij} b_{ij} A,B=tr(ATB)=i=1mj=1naijbij

矩阵限制:两个矩阵 A A A B B B 必须具有相同的维度 m × n m \times n m×n
结果:内积是一个标量。

2. Dot Product(点积)

定义:点积是向量的标量乘积的延伸。
对于两个向量 u , v \mathbf{u}, \mathbf{v} u,v

u ⋅ v = ∑ i = 1 n u i v i \mathbf{u} \cdot \mathbf{v} = \sum_{i=1}^{n} u_i v_i uv=i=1nuivi

矩阵情况:可以将矩阵行列展开为向量后计算点积。
如果矩阵 A A A 1 × n 1 \times n 1×n n × 1 n \times 1 n×1,点积适用:

A ⋅ B = ∑ i = 1 n a i b i A \cdot B = \sum_{i=1}^{n} a_i b_i AB=i=1naibi

3. Kronecker Product(克罗内克积)

定义:Kronecker 积生成一个更大的矩阵。
给定矩阵 A A A 的大小为 m × n m \times n m×n,矩阵 B B B 的大小为 p × q p \times q p×q,克罗内克积定义为:

A ⊗ B = [ a 11 B a 12 B … a 1 n B a 21 B a 22 B … a 2 n B ⋮ ⋮ ⋱ ⋮ a m 1 B a m 2 B … a m n B ] A \otimes B = \begin{bmatrix} a_{11}B & a_{12}B & \dots & a_{1n}B \\ a_{21}B & a_{22}B & \dots & a_{2n}B \\ \vdots & \vdots & \ddots & \vdots \\ a_{m1}B & a_{m2}B & \dots & a_{mn}B \end{bmatrix} AB= a11Ba21Bam1Ba12Ba22Bam2Ba1nBa2nBamnB

结果大小 ( m p ) × ( n q ) (mp) \times (nq) (mp)×(nq)

4. Outer Product(外积)

定义:外积是两个向量生成矩阵的方法。
对于两个向量 u ∈ R m \mathbf{u} \in \mathbb{R}^m uRm v ∈ R n \mathbf{v} \in \mathbb{R}^n vRn,外积为:

u ⊗ v = u v T = [ u 1 v 1 u 1 v 2 … u 1 v n u 2 v 1 u 2 v 2 … u 2 v n ⋮ ⋮ ⋱ ⋮ u m v 1 u m v 2 … u m v n ] \mathbf{u} \otimes \mathbf{v} = \mathbf{u} \mathbf{v}^T = \begin{bmatrix} u_1v_1 & u_1v_2 & \dots & u_1v_n \\ u_2v_1 & u_2v_2 & \dots & u_2v_n \\ \vdots & \vdots & \ddots & \vdots \\ u_mv_1 & u_mv_2 & \dots & u_mv_n \end{bmatrix} uv=uvT= u1v1u2v1umv1u1v2u2v2umv2u1vnu2vnumvn

结果大小 m × n m \times n m×n

5. Hadamard Product(哈达玛积)

定义:Hadamard 积是两个矩阵对应元素相乘的结果。
对于两个矩阵 A , B A, B A,B

A ∘ B = [ a 11 b 11 a 12 b 12 … a 1 n b 1 n a 21 b 21 a 22 b 22 … a 2 n b 2 n ⋮ ⋮ ⋱ ⋮ a m 1 b m 1 a m 2 b m 2 … a m n b m n ] A \circ B = \begin{bmatrix} a_{11}b_{11} & a_{12}b_{12} & \dots & a_{1n}b_{1n} \\ a_{21}b_{21} & a_{22}b_{22} & \dots & a_{2n}b_{2n} \\ \vdots & \vdots & \ddots & \vdots \\ a_{m1}b_{m1} & a_{m2}b_{m2} & \dots & a_{mn}b_{mn} \end{bmatrix} AB= a11b11a21b21am1bm1a12b12a22b22am2bm2a1nb1na2nb2namnbmn

矩阵限制:两个矩阵必须具有相同的维度 m × n m \times n m×n
结果大小 m × n m \times n m×n

6 总结表

运算类型输入要求输出形式
Frobenius 内积两矩阵维度相同 m × n m \times n m×n标量
点积两向量长度相同 n n n标量
克罗内克积两矩阵 A ∈ R m × n , B ∈ R p × q A \in \mathbb{R}^{m \times n}, B \in \mathbb{R}^{p \times q} ARm×n,BRp×q ( m p ) × ( n q ) (mp) \times (nq) (mp)×(nq) 矩阵
外积两向量 u ∈ R m , v ∈ R n \mathbf{u} \in \mathbb{R}^m, \mathbf{v} \in \mathbb{R}^n uRm,vRn m × n m \times n m×n 矩阵
哈达玛积两矩阵维度相同 m × n m \times n m×n m × n m \times n m×n 矩阵

7 示例

以下是 Frobenius 内积、点积、Kronecker 积、外积 和 Hadamard 积 在 实数矩阵 和 复数矩阵上的具体示例:

1. Frobenius Inner Product(矩阵内积)
实数矩阵

A = [ 1 2 3 4 ] A = \begin{bmatrix} 1 & 2 \\ 3 & 4 \end{bmatrix} A=[1324] B = [ 5 6 7 8 ] B = \begin{bmatrix} 5 & 6 \\ 7 & 8 \end{bmatrix} B=[5768]
Frobenius 内积为:

⟨ A , B ⟩ = ∑ i = 1 2 ∑ j = 1 2 a i j b i j = 1 ⋅ 5 + 2 ⋅ 6 + 3 ⋅ 7 + 4 ⋅ 8 = 70 \langle A, B \rangle = \sum_{i=1}^{2} \sum_{j=1}^{2} a_{ij} b_{ij} = 1 \cdot 5 + 2 \cdot 6 + 3 \cdot 7 + 4 \cdot 8 = 70 A,B=i=12j=12aijbij=15+26+37+48=70

复数矩阵

A = [ 1 + i 2 i 4 ] A = \begin{bmatrix} 1+i & 2 \\ i & 4 \end{bmatrix} A=[1+ii24] B = [ 3 − i 6 7 8 + i ] B = \begin{bmatrix} 3-i & 6 \\ 7 & 8+i \end{bmatrix} B=[3i768+i]
Frobenius 内积为:

⟨ A , B ⟩ = ∑ i = 1 2 ∑ j = 1 2 a i j b i j ‾ \langle A, B \rangle = \sum_{i=1}^{2} \sum_{j=1}^{2} a_{ij} \overline{b_{ij}} A,B=i=12j=12aijbij

即:

( 1 + i ) ( 3 + i ) + 2 ⋅ 6 + i ⋅ 7 + 4 ⋅ ( 8 − i ) = ( 2 + 4 i ) + 12 + 7 i + ( 32 − 4 i ) = 46 + 7 i (1+i)(3+i) + 2 \cdot 6 + i \cdot 7 + 4 \cdot (8-i) = (2+4i) + 12 + 7i + (32-4i) = 46 + 7i (1+i)(3+i)+26+i7+4(8i)=(2+4i)+12+7i+(324i)=46+7i

2. Dot Product(点积)
实数向量

u = [ 1 2 3 ] \mathbf{u} = \begin{bmatrix} 1 & 2 & 3 \end{bmatrix} u=[123] v = [ 4 5 6 ] \mathbf{v} = \begin{bmatrix} 4 & 5 & 6 \end{bmatrix} v=[456]
点积为:

u ⋅ v = 1 ⋅ 4 + 2 ⋅ 5 + 3 ⋅ 6 = 32 \mathbf{u} \cdot \mathbf{v} = 1 \cdot 4 + 2 \cdot 5 + 3 \cdot 6 = 32 uv=14+25+36=32

复数向量

u = [ 1 + i 2 3 i ] \mathbf{u} = \begin{bmatrix} 1+i & 2 & 3i \end{bmatrix} u=[1+i23i] v = [ 1 2 + i 3 ] \mathbf{v} = \begin{bmatrix} 1 & 2+i & 3 \end{bmatrix} v=[12+i3]
点积为:

u ⋅ v = ( 1 + i ) 1 ‾ + 2 ( 2 + i ) ‾ + ( 3 i ) 3 ‾ \mathbf{u} \cdot \mathbf{v} = (1+i)\overline{1} + 2\overline{(2+i)} + (3i)\overline{3} uv=(1+i)1+2(2+i)+(3i)3

即:

( 1 + i ) ⋅ 1 + 2 ⋅ ( 2 − i ) + 3 i ⋅ 3 = 1 + i + 4 − 2 i + 9 i = 5 + 8 i (1+i) \cdot 1 + 2 \cdot (2-i) + 3i \cdot 3 = 1+i + 4-2i + 9i = 5 + 8i (1+i)1+2(2i)+3i3=1+i+42i+9i=5+8i

3. Kronecker Product(克罗内克积)
实数矩阵

A = [ 1 2 3 4 ] A = \begin{bmatrix} 1 & 2 \\ 3 & 4 \end{bmatrix} A=[1324] B = [ 0 5 6 7 ] B = \begin{bmatrix} 0 & 5 \\ 6 & 7 \end{bmatrix} B=[0657]
克罗内克积为:

A ⊗ B = [ 1 B 2 B 3 B 4 B ] = [ 0 5 0 10 6 7 12 14 0 15 0 20 18 21 24 28 ] A \otimes B = \begin{bmatrix} 1B & 2B \\ 3B & 4B \end{bmatrix} = \begin{bmatrix} 0 & 5 & 0 & 10 \\ 6 & 7 & 12 & 14 \\ 0 & 15 & 0 & 20 \\ 18 & 21 & 24 & 28 \end{bmatrix} AB=[1B3B2B4B]= 0601857152101202410142028

复数矩阵

A = [ i 2 3 4 ] A = \begin{bmatrix} i & 2 \\ 3 & 4 \end{bmatrix} A=[i324] B = [ 1 i i 1 ] B = \begin{bmatrix} 1 & i \\ i & 1 \end{bmatrix} B=[1ii1]
克罗内克积为:

A ⊗ B = [ i B 2 B 3 B 4 B ] = [ i − 1 2 2 i i i 2 i 2 3 3 i 4 4 i 3 i 3 4 i 4 ] A \otimes B = \begin{bmatrix} iB & 2B \\ 3B & 4B \end{bmatrix} = \begin{bmatrix} i & -1 & 2 & 2i \\ i & i & 2i & 2 \\ 3 & 3i & 4 & 4i \\ 3i & 3 & 4i & 4 \end{bmatrix} AB=[iB3B2B4B]= ii33i1i3i322i44i2i24i4

4. Outer Product(外积)
实数向量

u = [ 1 2 3 ] \mathbf{u} = \begin{bmatrix} 1 \\ 2 \\ 3 \end{bmatrix} u= 123 v = [ 4 5 ] \mathbf{v} = \begin{bmatrix} 4 & 5 \end{bmatrix} v=[45]
外积为:

u ⊗ v = [ 1 ⋅ 4 1 ⋅ 5 2 ⋅ 4 2 ⋅ 5 3 ⋅ 4 3 ⋅ 5 ] = [ 4 5 8 10 12 15 ] \mathbf{u} \otimes \mathbf{v} = \begin{bmatrix} 1 \cdot 4 & 1 \cdot 5 \\ 2 \cdot 4 & 2 \cdot 5 \\ 3 \cdot 4 & 3 \cdot 5 \end{bmatrix} = \begin{bmatrix} 4 & 5 \\ 8 & 10 \\ 12 & 15 \end{bmatrix} uv= 142434152535 = 481251015

复数向量

u = [ 1 + i 2 ] \mathbf{u} = \begin{bmatrix} 1+i \\ 2 \end{bmatrix} u=[1+i2] v = [ 3 4 − i ] \mathbf{v} = \begin{bmatrix} 3 \\ 4-i \end{bmatrix} v=[34i]
外积为:

u ⊗ v = [ ( 1 + i ) ⋅ 3 ( 1 + i ) ⋅ ( 4 − i ) 2 ⋅ 3 2 ⋅ ( 4 − i ) ] = [ 3 + 3 i 4 − i + 4 i + 1 6 8 − 2 i ] = [ 3 + 3 i 5 + 3 i 6 8 − 2 i ] \mathbf{u} \otimes \mathbf{v} = \begin{bmatrix} (1+i) \cdot 3 & (1+i) \cdot (4-i) \\ 2 \cdot 3 & 2 \cdot (4-i) \end{bmatrix} = \begin{bmatrix} 3+3i & 4-i+4i+1 \\ 6 & 8-2i \end{bmatrix} = \begin{bmatrix} 3+3i & 5+3i \\ 6 & 8-2i \end{bmatrix} uv=[(1+i)323(1+i)(4i)2(4i)]=[3+3i64i+4i+182i]=[3+3i65+3i82i]

5. Hadamard Product(哈达玛积)
实数矩阵

A = [ 1 2 3 4 ] A = \begin{bmatrix} 1 & 2 \\ 3 & 4 \end{bmatrix} A=[1324] B = [ 5 6 7 8 ] B = \begin{bmatrix} 5 & 6 \\ 7 & 8 \end{bmatrix} B=[5768]
哈达玛积为:

A ∘ B = [ 1 ⋅ 5 2 ⋅ 6 3 ⋅ 7 4 ⋅ 8 ] = [ 5 12 21 32 ] A \circ B = \begin{bmatrix} 1 \cdot 5 & 2 \cdot 6 \\ 3 \cdot 7 & 4 \cdot 8 \end{bmatrix} = \begin{bmatrix} 5 & 12 \\ 21 & 32 \end{bmatrix} AB=[15372648]=[5211232]

复数矩阵

A = [ 1 + i 2 i 4 ] A = \begin{bmatrix} 1+i & 2 \\ i & 4 \end{bmatrix} A=[1+ii24] B = [ 3 6 7 8 + i ] B = \begin{bmatrix} 3 & 6 \\ 7 & 8+i \end{bmatrix} B=[3768+i]
哈达玛积为:

A ∘ B = [ ( 1 + i ) ⋅ 3 2 ⋅ 6 i ⋅ 7 4 ⋅ ( 8 + i ) ] = [ 3 + 3 i 12 7 i 32 + 4 i ] A \circ B = \begin{bmatrix} (1+i) \cdot 3 & 2 \cdot 6 \\ i \cdot 7 & 4 \cdot (8+i) \end{bmatrix} = \begin{bmatrix} 3+3i & 12 \\ 7i & 32+4i \end{bmatrix} AB=[(1+i)3i7264(8+i)]=[3+3i7i1232+4i]


http://www.kler.cn/a/508736.html

相关文章:

  • Java定时任务不明原因挂掉(定时任务挂掉)以及建议
  • SpringBoot Starter 通用接口加密组件(防篡改)+ RequestBodyAdvice和ResponseBodyAdvice原理
  • [MySQL | 二、基本数据类型]
  • 【2024年华为OD机试】 (C卷,100分)- 小明找位置(Java JS PythonC/C++)
  • 【React】插槽渲染机制
  • LoadBalancer负载均衡服务调用
  • git使用-合并代码查看是否冲突解决冲突
  • 基于springboot+vue.js+uniapp技术开发的一套大型企业MES生产管理系统源码,支持多端管理
  • 麒麟V10系统上安装Oracle
  • Golang:报错no required module provides package github.com/xx的解决方法
  • Oracle连接数满问题解决及排查 ORA-00020:maximumnumber of processes
  • 【人工智能】从Keras到TensorFlow 2.0:深入掌握Python深度学习技术
  • 【统计的思想】假设检验(一)
  • 如何在 Rocky Linux 上安装极狐GitLab?
  • stm32控制直流电机程序
  • 无限世界中的具身导航与交互!InfiniteWorld:通用视觉语言机器人交互的统一仿真框架
  • C++多态的认识与理解
  • doris: Flink导入数据
  • AI自动化编程:编程教育的变革之风
  • MarsCode青训营打卡Day1(2025年1月14日)|稀土掘金-16.最大矩形面积问题
  • EAMM: 通过基于音频的情感感知运动模型实现的一次性情感对话人脸合成
  • JAVA-Exploit编写(5)--http-request库使用
  • Python 爬虫:获取网页数据的 5 种方法
  • Maven在Win10上的安装教程
  • 家政服务小程序,打造智慧家政新体验
  • Rust:指针 `*T` 和引用 `T`的区别