Bootstrap

matlab循环_MATLAB小技巧:巧用矩阵运算,避免循环

微信公众号: MitchHong微信号: ASparkleSubscription作者: Mitch Hong

Untitled

刚刚中午在写作业的时候突然想起来的这个方法,感觉应该有点用,就趁热做了这篇推送来分享一下,哈哈哈。

1c5c037319a6fd004c34130b4e61eb11.png

呐,就是上图中红框的那道题,要把9336712fe5cfe38a0089f04aadb9265a.png给算出来,这我当时就准备用一个循环来算了,但当时我脑海中突然闪过一道光,然后就冒出来了用矩阵来算一下的念头(本人数学菜鸟)。哈哈,不过幸好还记得点线性代数上的一些知识,试了一下算出来了。下面先放上代码再简单解释一下。

A1 = 1;
A2 = 0.5;
A3 = 0.2;
A = [A1, A2, A3];

f0 = 5; %Hz

i = [1:3]';

x3 = @(t) A * sin(2*pi*f0* i * t);

fs = 2048; % 采样频率Hz,每秒2048个点
Ts = 1 / fs; % 采样间隔
n = 0 : 2048 - 1; % 2k个点(正好采1s)
t = n .* Ts; % 时间t

plot(t, x3(t))

下面这是结果

1a8c6bbec6b747cb2d884a56831870f9.png
可视化x3

现在看一下题中的那个式子,它就是下面这三行相加:5074a438372367bcb4bd08cbee3ba292.pngcd2a4f126026a95a1d01c69c35a7a5ae.png1a9249fe55e93c2d3124a571a53c5b8f.png这就能写成3e86139519deca585112ec40a624f8f0.png到这还没结束74a99a8bb40a5137770d2c9fb3c98425.png上面这个矩阵可以写成如下的形式61405b97e72fbc669413fada2c23b280.png嘿嘿,所以那个题中的那个和式可以写成如下的形式7624c299ad0bcd70951f54588e9b15b3.png这便是程序中的这行了

x3 = @(t) A * sin(2*pi*f0* i * t);

注意,A是行向量,i是列向量。到此这个小技巧便说完了,实际上还是数学知识,不算是什么小技巧。艾,这个MarkDown中用latex插入公式简直太好用了,夸一下。


But,要是这个线代中矩阵的乘法都一点也不记得的话,对上面的这个方法没信心,那还是用循环把,如下:

x = 0;
for i = 1 : length(A)
    x = x + A(i).*sin(2*pi*f0*i .*t);

end
sum(x == x3(t)) % 和上面利用矩阵运算的出来的结果对比一下,看看两个算出来的值是否都一样

这个在命令行中输出的结果如下

c53754dea0b3541d4be5fb3e77fc7c01.png

哈哈,说明这2048个点都一样,说明上面用矩阵运算算出来的结果是对的,自信点,哈哈。

本篇内容不多,写了一个多小时,阅读可能就几分钟就读完了。。。

还有昨天那篇推送中的远程仓库链接,忘改成公有的了,这里重新放一下:https://gitee.com/mitchhong/ArrayADT.git

419b4dd24fa6d85fca6807f1c3a65b1d.png
;