首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在Excel或R中不使用for循环进行滚动和

如何在Excel或R中不使用for循环进行滚动和
EN

Stack Overflow用户
提问于 2015-08-10 16:10:43
回答 2查看 259关注 0票数 0

我有一列1000个随机数,我想计算一个窗口长度为10的滚动和,在Excel或R中,对于前10个观察,滚动和仍然应该用部分窗口长度来计算。不过,我没有在Excel或R中找到滚动和功能。

我目前在R中的尝试是使用循环。然而,循环工作正常,效率很低。请看下面我的尝试。

代码语言:javascript
运行
复制
 vector = as.vector(matrix(1,1000,nrow = 1))
for (i in 1:1000) {
  if (i<11) {
    rolling.sum[i]=sum(vector[1:i])
  } else {
    rolling.sum[i] = sum(vector[(i-10):i])
  }
}
  • “向量”是指需要计算滚动和的随机数向量。
  • "rolling.window“是存储滚动和的变量。
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-10-12 05:35:33

我已经想出了一种在R中这样做的方法,它使用了动物园包中的rollapply函数。使用rollapply(),输入值向量作为第一个参数,窗口长度作为第二个参数,然后指示它应该是滚动和。最后一个参数指出,当窗口长度不够长时,它还计算部分和。请注意,宽度参数必须指定窗口是向前看还是向后看。例子如下:

代码语言:javascript
运行
复制
vector = as.vector(matrix(1,1000,nrow = 1))
rolling.sum<<-rollapply(vector, width = list(-1:-10), sum, partial=T)
票数 1
EN

Stack Overflow用户

发布于 2015-10-05 16:21:49

为了保持标题的精神,在另一个单元格中随意使用,将1 (或您选择的不同的起始值)放在一个单元格中,> Editing,Series .,选择列in,Linear,输入1作为步骤值:和(“在单元格旁边”)停止值:无论你想要什么限制/先例值,都行。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31924324

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档