matlab常用命令整理(一)——未完待续,明天继续

本文介绍了Matlab中处理张量的一些常用命令,包括ttv(模-n 乘)、ttm(模-n 矩阵乘)、tenmat、sort、reshape和cat等,详细解释了每个命令的功能和用法,并通过实例进行了演示。
摘要由CSDN通过智能技术生成

matlab中常用命令总结(哈哈,这个是按我自己常用的命令总结的哈)

创建张量的常用的命令

(1) A=tenrand([2,3,2])
(2) A=tensor(rand([4 3 2]))
(3) A=tenones([3 4 2])
(4) A=tenzeros([2 4 3])
(5) A=tensor(1:24,[3 2 2 2])
A.data
A.tsize
A.cdims
A.rdims

ttv

Mode-n Product (ttv): X ∈ R I 1 × I 2 × ⋯ × I N \mathcal{X}\in \mathbb{R}^{I_1\times I_2 \times \cdots \times I_N} XRI1×I2××IN, v ∈ R I k v \in \mathbb{R}^{I_k} vRIk

( X × k v ) i 1 , ⋯   , i k − 1 , i k + 1 , ⋯   , i N = ∑ i k = 1 I k x i 1 i 2 ⋯ i N v i k (\mathcal{X} \times_k v )_{i_1,\cdots,i_{k-1},i_{k+1},\cdots,i_N}=\sum_{i_k=1}^{I_k}x_{i_1i_2\cdots i_N} v_{i_k} (X×kv)i1,,ik1,ik+1,,iN=ik=1Ikxi1i2iNvik

(注意在这个公式中向量 v v v的维数需和张量第 k k k模块的维数一致才能进行乘法)

一个向量和一个张量进行模乘可以减少张量的阶数,下图将一个3阶张量变为0阶张量:
在这里插入图片描述
(1) ttv( A, x, dim )
(2) ttv( A, {x1, x2, …, xn }, [1 2 … n] )
举例:
在这里插入图片描述

ttm

Mode-n Product (ttm): X ∈ R I 1 × I 2 × ⋯ × I N \mathcal{X}\in \mathbb{R}^{I_1\times I_2 \times \cdots \times I_N} XRI1×I2××IN, P ∈ R J × I k P \in \mathbb{R}^{J\times I_k} PRJ×Ik

( X × k P ) i 1 , ⋯   , i k − 1 , j , i k + 1 , ⋯   , i N = ∑ i k = 1 I k x i 1 i 2 ⋯ i N p j i k (\mathcal{X} \times_k P )_{i_1,\cdots,i_{k-1},j,i_{k+1},\cdots,i_N}=\sum_{i_k=1}^{I_k}x_{i_1i_2\cdots i_N} p_{ji_k} (X×kP)i1,,ik1,j,ik+1,,iN=ik=1Ikxi1i2iNpjik

上述定义可以写成沿mode-k展开的形式,即:

Y = X × n U    ⟺    Y ( n ) = U X ( n ) Y=\mathcal{X} \times_n U \iff Y_{(n)}=UX_{(n)} Y=X×nUY(n)=UX(n)

注意在上述公式中,矩阵 P P P 的列要同张量第 k k k 模块的维数一致

如果 J < I n J<I_n J<In ,那么一个矩阵和一个张量进行模乘可以看成一个降维的过程(被乘模式的维数降低),下图演示了一个 7 × 5 × 8 7\times5\times 8 7×5×8 的张量和一个 4 × 7 4\times 7 4×7 矩阵的相乘最终得一个 4 × 5 × 8 4\times 5 \times 8 4×5×8 的张量:
在这里插入图片描述
(1) ttm( A, P, dim )
(2) ttm( A, { P1, P2, …, Pn }, [1 2 … n ] )

举例:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

tenmat

(1) A=tenmat(X,dim)
举例:
在这里插入图片描述
在这里插入图片描述

sort

(1)B=sort(A)
(2)B=sort(A,dim)
(3) B=sort(_,direction)

功能:
(1) 实现对向量A的从小到大排列
(2)对矩阵A实现按(dim)从小到大排列
(3)对矩阵实现按一定方向的排序
举例:
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

reshap

(1)、B = reshape(A,m,n)
(2)、B = reshape(A,m,n,p,…) 或 B = reshape(A,[m n p …])
(3)、B = reshape(A,…,[ ],…)

说明:
(1)返回一个m × \times × n的矩阵B, B中元素是按列从A中得到的。如果A中元素个数没有m × \times ×n个, 则会引发错误。

(2)返回一个和A具有相同元素的N(即A的元素个数)维数组。但B的尺寸是m × \times ×n × \times ×p × \times ×…, m ⋅ \cdot n ⋅ \cdot p…必须和prod(size(A))相等(即A和B元素个数相等)。

(3)计算由占位符[ ]所表示的尺寸的长度,这样维度的乘积等价于 prod(size(A))。而prod(size(A))的值必须能被指定维数的乘积所整除。在这里面占位符[ ] 只能使用一次。

举例:
在这里插入图片描述
在这里插入图片描述

cat

(1) C = cat(dim, A, B)
(2) C = cat(dim, A1, A2, A3, A4, …)

功能:
将矩阵A和B按照第dim个维度连接到一起
将矩阵A1,A2,A3…按照第dim个维度连接到一起
举例:
在这里插入图片描述

nargin

nargin是用来判断输入变量个数的函数,这样就可以针对不同的情况执行不同的功能。通常可以用他来设定一些默认值,如下面的函数。

例子,函数test1的功能是输出a和b的和。如果只输入一个变量,则认为另一个变量为1; 如果两个变量都没有输入,则默认两者均为1,返回值为2。

function y=test1(a,b)
if nargin = =0
a=1;
b=1;
else if nargin = =1
b=1;
end
y=a+b;

调用结果:
在这里插入图片描述

tril,triu

(1) tril(A) 取A的下三角部分
(2) tril(A,-1) 取A的严格下三角部分
(3) triu(A) 取A的上三角部分
(4) triu(A,1) 取A的严格下三角部分

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值