(转)Matlab movmean movstd movvar movmedian函数

2023-11-29 07:58

本文主要是介绍(转)Matlab movmean movstd movvar movmedian函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载自https://blog.csdn.net/horsee/article/details/73702285

Matlab movmean movstd movvar movmedian函数

2017年06月25日 20:30:01 CarnivoreRabbit 阅读数:1457 标签: matlabmovmean 更多

个人分类: MATLAB

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/horsee/article/details/73702285

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
  • 1
  • 2
  • 3

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


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)
  • 1
  • 2

M =

Columns 1 through 7

6.0000    6.0000    4.3333    1.0000   -2.0000   -2.0000   -0.3333
  • 1

Columns 8 through 10

2.0000    4.0000    4.5000
  • 1

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


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

M =

Columns 1 through 7

4.0000    6.0000    6.0000    4.3333    1.0000   -2.0000   -2.0000
  • 1

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)
  • 1
  • 2

A =

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

M =

 6.0000    6.0000    7.0000
-1.5000   -2.0000   -2.5000
1.0000    2.0000    3.5000
  • 1
  • 2
  • 3

注意上例中,窗口长度为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)
  • 1
  • 2

M =

Columns 1 through 7

6.0000       NaN       NaN       NaN   -2.0000       NaN       NaN
  • 1

Columns 8 through 10

   NaN    4.0000    4.5000
  • 1

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


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

M =

Columns 1 through 7

6.0000    6.0000    3.5000   -1.5000   -2.0000   -2.5000         0
  • 1

Columns 8 through 10

3.5000    4.0000    4.5000
  • 1

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


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

M =

Columns 1 through 7

6.0000    4.3333    1.0000   -2.0000   -2.0000   -0.3333    2.0000
  • 1

Column 8

4.0000
  • 1

当’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')

这篇关于(转)Matlab movmean movstd movvar movmedian函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/432049

相关文章

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串