微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何对时间序列进行子采​​样GPS 位置的突发

如何解决如何对时间序列进行子采​​样GPS 位置的突发

我有一个时间序列如下:

**Date_time**
2018-06-26 17:19:30
2018-06-26 17:20:40
2018-06-26 17:20:41
2018-06-26 17:20:42
[...]
2018-06-26 17:21:36
2018-06-26 17:21:37
2018-06-26 17:21:38
2018-06-26 17:21:39
2018-06-26 17:23:15

我想对它进行二次采样,例如我获得了以下时间序列(即删除每秒记录的位置,以便粗略地仅保留 1 个位置/分钟)

**Date_time**
2018-06-26 17:19:30
2018-06-26 17:20:40
2018-06-26 17:21:39
2018-06-26 17:23:15

我写了以下代码(但我没有得到预期的时间序列)

tab_subsampled <- tab %>%
   mutate(Date_Time = ymd_hms(Date_Time),year = year(Date_Time),month = month(Date_Time),day = day(Date_Time),hour = hour(Date_Time),minute = minute(Date_Time),second = second(Date_Time)) %>% 
   group_by(year,month,day,hour,minute) %>%
   slice(n()) %>% 
   ungroup() 

非常感谢您的帮助,非常感谢!

解决方法

您可以在整个 df 上使用 substr 和 dplyr。然后您可以在几分钟后删除所有内容,然后只允许唯一值,这样您每分钟只有一个数据点。

library(dplyr)

#Date_time
time<-c("2018-06-26 17:19:30","2018-06-26 17:20:40","2018-06-26 17:20:41","2018-06-26 17:20:42","2018-06-26 17:21:39","2018-06-26 17:23:15")

time<-as.data.frame(time)
colnames(time) = ("Date_time")

time<-time %>%
  mutate(Date_time = substr(Date_time,1,13))

Date.Time_only_minutes<-unique(time$Date_time);Date.Time_only_minutes
,

只需sample_n也可以

library(lubridate)

time<-c("2018-06-26 17:19:30","2018-06-26 18:20:42","2018-06-26 17:23:15","2018-07-26 17:20:30","2018-07-26 17:20:40","2018-08-26 18:20:41","2018-08-26 18:20:42","2018-09-26 17:21:39","2018-09-26 17:21:15")

time<-as.data.frame(time)
                  time
1  2018-06-26 17:19:30
2  2018-06-26 17:20:40
3  2018-06-26 17:20:41
4  2018-06-26 18:20:42
5  2018-06-26 17:21:39
6  2018-06-26 17:23:15
7  2018-07-26 17:20:30
8  2018-07-26 17:20:40
9  2018-08-26 18:20:41
10 2018-08-26 18:20:42
11 2018-09-26 17:21:39
12 2018-09-26 17:21:15


set.seed(1)
time %>% group_by(date(time),hour(time),minute(time)) %>%
  sample_n(1) %>% ungroup() %>%
  select(time)
# A tibble: 8 x 1
  time               
  <chr>              
1 2018-06-26 17:19:30
2 2018-06-26 17:20:41
3 2018-06-26 17:21:39
4 2018-06-26 17:23:15
5 2018-06-26 18:20:42
6 2018-07-26 17:20:30
7 2018-08-26 18:20:41
8 2018-09-26 17:21:39

请注意,您必须在 group_by 语句中添加其他 ID/分组变量才能在这些组中执行此操作。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?