Matlab movmean movstd movvar movmedian函数

R2016a 引入的几个统计函数学习


背景: 在统计学习中,有时候我们需要解决以下问题

序号数值
185
276
388
496
5102
677
784
899
963
1087

对以上数据,我们要计算相邻两点的平均值,即

编号数值
1.580.5
2.582
3.592
4.599
5.589.5
6.580.5
7.591.5
8.581
9.575

在R2016a以前,解决这个问题的方法是

t = 1 : 10;
A = [85 76 88 96 102 77 84 99 63 87];
R = (A(1:end-1) + A(2:end))/2

但这只是一种比较简单的情况,如果是相邻的 N 个点求平均呢?如果要计算当前点的邻域点(前N1个点,后 N2 个点)的平均值呢?如果要计算的不是均值,而是中值、标准差、方差呢?


R2016a引入了几个新的函数,为这一类问题提供了比较好的解决方案:
movmean—–移动窗口求平均值;
movstd——–移动窗口求标准差 ;
movvar——–移动窗口求方差 ;
movmedian–移动窗口求中值.


这几个函数的唯一不同只在于执行的局部运算不同,因此以下以movmean为例介绍此类函数的使用方法.


语法 Syntax
M = movmean(A, k)
M = movmean(A, [kb kf])
M = movmean( __, dim)
M = movmean( __, nanflag)
M = movmean( __, ‘Endpoints’, endptmethod)


描述


M = movmean(A,k) 返回一个计算局部k点均值的数组,其中每一个均值都是通过长度为k的滑动窗口对A点相邻几个元素进行划分所求得。
当k是奇数时,滑动窗口的中心就是当前的元素位置;
当k是偶数时,滑动窗口的中心是前一个元素和当前元素的中间位置。
当窗口中元素数量小于定义的窗口长度时,将自动截取在窗口长度范围内的元素作为区间端点;
当窗口中元素数量小于定义的窗口长度时,只对填满窗口位置的元素进行均值计算;
M的大小和A一致.

  • 如果A是一个向量,则movmean沿着向量的长度方向进行计算;
  • 如果A是一个多维数组,则movmean沿着维数顺序中第一个不是1维的维度的方向进行计算.

M = movmean(A, [kb kf])计算包含当前位置元素共kb+kf+1长度的窗口中的均值, kb个后向元素(k-backward),kf个前向元素(k-forward).


M = movmean( __, dim) 在前面几个语法的基础上计算沿dim维度方向的均值. 例如,如果A是一个矩阵(维度大于等于2),movmean(A,k,2)沿着A的列向计算, 即对每一列计算k元素滑动平均.


M = movmean( __, nanflag)在前面几个语法的基础上确定包含还是省略计算中NaN的值. movmean(A,k,’includenan’)包含所有 NaN值,而movmean(A,k,’omitnan’)则在计算中无视NaN值,既不计算个数,也不计算值.


M = movmean( __, ‘Endpoints’, endptmethod) 确定控制区间端点的方法,’Endpoints’的属性可在’shrink’,’discard’,’fill’三个值其中之一选择一个,或者一个标量或逻辑值. 例如, movmean(A,k,’Endpoints’,’discard’)只输出包含有k个元素的窗口均值,而不包括那些填不满的窗口.


举例及解析


A = [4 8 6 -1 -2 -3 -1 3 4 5];
M = movmean(A,3)

M =

Columns 1 through 7

6.0000    6.0000    4.3333    1.0000   -2.0000   -2.0000   -0.3333

Columns 8 through 10

2.0000    4.0000    4.5000

注意上例中,窗口宽度为3,则第一个窗和最后一个窗的长度均不足,所以第一个窗的元素只有(粗体元素为窗口的中心)
[ ] 4 8
有效元素个数为2,总和为12,所以均值计算为6;
而最后一个窗的元素只有
4 5 [ ]
有效元素个数也为2,总和为9,所以均值计算为4.5.


A = [4 8 6 -1 -2 -3 -1 3 4 5];
M = movmean(A,[2 0])

M =

Columns 1 through 7

4.0000    6.0000    6.0000    4.3333    1.0000   -2.0000   -2.0000

Columns 8 through 10

-0.3333 2.0000 4.0000

注意上例中,窗口宽度为3,窗口的中心位置(粗体元素)是第三个元素,窗口计算前2个后0个元素:

第一个窗口为
[ ] [ ] 4
均值为4

第二个窗口为
[ ] 4 8
均值为6

第三个窗口为
4 8 6
均值为6

最后一个窗口为
3 4 5
均值为4


movmean用于矩阵

A = [4 8 6; -1 -2 -3; -1 3 4]
M = movmean(A,3,2)

A =

 4     8     6
-1    -2    -3
-1     3     4

M =

 6.0000    6.0000    7.0000
-1.5000   -2.0000   -2.5000
1.0000    2.0000    3.5000

注意上例中,窗口长度为3,窗口是中心元素定位法,窗口的方向沿第2维度,即column方向.

行列123
1[ ] 4 84 8 68 6 [ ]
2[ ] -1 -2-1 -2 -3-2 -3 [ ]
3[ ] -1 3-1 3 43 4 [ ]

A = [4 8 NaN -1 -2 -3 NaN 3 4 5];
M = movmean(A,3)

M =

Columns 1 through 7

6.0000       NaN       NaN       NaN   -2.0000       NaN       NaN

Columns 8 through 10

   NaN    4.0000    4.5000

窗口中所有包含NaN的窗口,均值均被计算为NaN了.


M = movmean(A,3,'omitnan')

M =

Columns 1 through 7

6.0000    6.0000    3.5000   -1.5000   -2.0000   -2.5000         0

Columns 8 through 10

3.5000    4.0000    4.5000

注意所有含有NaN的窗口中,NaN都被省略了,既没有被当作有效元素个数,也没有占据平均时元素的个数.
特别注意的是,全是NaN的那个窗口中最终计算结果为0.


A = [4 8 6 -1 -2 -3 -1 3 4 5];
M = movmean(A,3,'Endpoints','discard')

M =

Columns 1 through 7

6.0000    4.3333    1.0000   -2.0000   -2.0000   -0.3333    2.0000

Column 8

4.0000

当’Endpoints’设置为’discard’时,未填满的窗口都被省略掉了.


k中心窗口

这里写图片描述

[kb kf]窗口
这里写图片描述


回到最初的问题,解决起来就非常容易了:

t = 1 : 10;
A = [85 76 88 96 102 77 84 99 63 87];
R = movmean(A,2,'Endpoints','discard')
  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值