为了账号安全,请及时绑定邮箱和手机立即绑定

R数据科学笔记——data transformation2

标签:
Java

6.grouped summaries with summarise()

6.7 Exercises

  1. Brainstorm at least 5 different ways to assess the typical delay characteristics of a group of flights. Consider the following scenarios:

  • A flight is 15 minutes early 50% of the time, and 15 minutes late 50% of the time.

  • A flight is always 10 minutes late.

  • A flight is 30 minutes early 50% of the time, and 30 minutes late 50% of the time.

  • 99% of the time a flight is on time. 1% of the time it’s 2 hours late.

方法一

> not_cancelled%>%
+ group_by(flight)%>%
+ filter((mean(arr_delay==-15)==0.5)&(mean(arr_delay==15)==0.5))
>not_cancelled%>%
+ group_by(flight)%>%
+ filter((mean(arr_delay==-15)==0.5)&(mean(arr_delay==15)==0.5))
> not_cancelled%>%
+ group_by(flight)%>%
+ filter(mean(arr_delay==10)==1)
> not_cancelled%>%
+ group_by(flight)%>%
+ filter((mean(arr_delay==-30)==0.5)&(mean(arr_delay==30)==0.5))
> not_cancelled%>%
+ group_by(flight)%>%
+ filter((mean(arr_delay==0)==0.99)&(mean(arr_delay==120)==0.01))

方法二

> percent<-not_cancelled%>%
+      group_by(flight)%>%
+     summarise(n=n(),percent_15ahead=sum(arr_delay==-15)/n,
+                  percent_15late=sum(arr_delay==15)/n,
+                  percent_10late=sum(arr_delay==10)/n,
+                  percent_30ahead=sum(arr_delay==-30)/n,
+                  percent_30late=sum(arr_delay==30)/n,
+                  percent_ontime=sum(arr_delay==0)/n,
+                  percent_2hlate=sum(arr_delay==120)/n)
> percent# A tibble: 3,835 x 9
   flight     n percent_15ahead percent_15late percent_10late percent_30ahead percent_30late
    <int> <int>           <dbl>          <dbl>          <dbl>           <dbl>          <dbl> 1      1   697         0.0215         0.0100         0.00574         0.00574        0.00574
 2      2    51         0.0392         0.0196         0               0              0      
 3      3   628         0.00955        0.00637        0.0159          0.0159         0.00318
 4      4   391         0.0358         0.0102         0.00767         0.0128         0.00256
 5      5   324         0.0123         0.00617        0.00926         0.0216         0      
 6      6   206         0.0291         0.00485        0.00485         0.0291         0      
 7      7   236         0.0169         0.00424        0               0.00847        0.00424
 8      8   234         0.0556         0.00855        0.0214          0              0      
 9      9   152         0.0132         0.0132         0.0197          0              0      10     10    61         0.0164         0.0164         0.0328          0              0      # ... with 3,825 more rows, and 2 more variables: percent_ontime <dbl>, percent_2hlate <dbl>> percent%>%
+ filter(percent_15ahead==0.5&percent_15late==0.5)# A tibble: 0 x 9# ... with 9 variables: flight <int>, n <int>, percent_15ahead <dbl>, percent_15late <dbl>,#   percent_10late <dbl>, percent_30ahead <dbl>, percent_30late <dbl>, percent_ontime <dbl>,#   percent_2hlate <dbl>> percent%>%
+ filter(percent_10late==1)# A tibble: 5 x 9
  flight     n percent_15ahead percent_15late percent_10late percent_30ahead percent_30late
   <int> <int>           <dbl>          <dbl>          <dbl>           <dbl>          <dbl>1   2254     1               0              0              1               0              02   3656     1               0              0              1               0              03   3785     1               0              0              1               0              04   3880     1               0              0              1               0              05   5854     1               0              0              1               0              0# ... with 2 more variables: percent_ontime <dbl>, percent_2hlate <dbl>> percent%>%
+ filter(percent_30ahead==0.5&percent_30late==0.5)# A tibble: 0 x 9# ... with 9 variables: flight <int>, n <int>, percent_15ahead <dbl>, percent_15late <dbl>,#   percent_10late <dbl>, percent_30ahead <dbl>, percent_30late <dbl>, percent_ontime <dbl>,#   percent_2hlate <dbl>> percent%>%
+ filter(percent_ontime==0.99&percent_2hlate==0.01)# A tibble: 0 x 9# ... with 9 variables: flight <int>, n <int>, percent_15ahead <dbl>, percent_15late <dbl>,#   percent_10late <dbl>, percent_30ahead <dbl>, percent_30late <dbl>, percent_ontime <dbl>,#   percent_2hlate <dbl>

还有个问题,如果这里的比例是算上cancel的怎么办?
Which is more important: arrival delay or departure delay?
我觉得应该是arr_delay吧,因为的确有起飞延误然后返航或者备降的航班?(dep_delay=na)

  1. Come up with another approach that will give you the same output as not_cancelled %>% count(dest) and not_cancelled %>% count(tailnum, wt = distance) (without using count()).

    > not_cancelled%>%
    + group_by(dest)%>%
    + summarise(n=n())
    
    > not_cancelled%>%
    + group_by(tailnum)%>%
    + summarise(n=sum(distance))#被自己蠢哭了..#wt=distance就是count=sum(n(x)*distance(x)),那直接分组后sum(distance)就好了啊
  2. Our definition of cancelled flights (is.na(dep_delay) | is.na(arr_delay) ) is slightly suboptimal. Why? Which is the most important column?

    >summarise(flights,exist_dep_delay=sum(!is.na(dep_delay)),exist_arr_delay=sum(!is.na(arr_delay)),not_cancelled=sum(!(is.na(dep_delay)|is.na(arr_delay))))# A tibble: 1 x 3
      exist_dep_delay exist_arr_delay not_cancelled
                <int>           <int>         <int>1          328521          327346        327346> #也就是说,存在只有dep_delay的数据而无arr_delay的数据,那意思是返航了?所以应该扩大点范围?> #只要存在dep_delay就应该不算取消吗?>#我明白了,不可能有到达了但没有起飞的航班,so只需关注dep_delay
  3. Look at the number of cancelled flights per day. Is there a pattern? Is the proportion of cancelled flights related to the average delay?

    > flights%>%#题目里的pattern啥意思?+group_by(year,month,day)%>%
    +summarise(cancel=sum(is.na(dep_delay)|is.na(arr_delay)),cancel_prop=mean(is.na(dep_delay)|is.na(arr_delay)),avg_delay=mean(arr_delay,na.rm=TRUE))%>%
    +ggplot(mapping=aes(x=avg_delay,y=cancel_prop))+geom_point()+geom_smooth(se=FALSE)
    `geom_smooth()` using method = 'loess' and formula 'y ~ x'

webp


不太明白题目里pattern啥意思。看图的话两个应该是正相关的

  1. Which carrier has the worst delays? Challenge: can you disentangle the effects of bad airports vs. bad carriers? Why/why not? (Hint: think about flights %>% group_by(carrier, dest) %>% summarise(n()))
    > not_cancelled%>%
    + group_by(carrier)%>%
    + summarise(mean_delay=mean(arr_delay[arr_delay>0]))%>%
    + ggplot(mapping=aes(x=carrier,y=mean_delay))+geom_bar(stat="identity")

webp


怎么去定义worst delay?如果是指mean_delay最高的话,那应该是OO。
题目的后半部分不会做.我觉得没办法,因为有些地方的机场只有一个或两个carrier,或者说有的carrier只有一个航线。无法区分是bad carrier还是bad airport

  1. What does the sort argument to count() do. When might you use it?

    sort     if TRUE will sort output in descending order of n

> not_cancelled%>%
+ count(dest,sort=TRUE)#当想看哪个变量的数量最多时用很方便# A tibble: 104 x 2
   dest      n
   <chr> <int> 1 ATL   16837
 2 ORD   16566
 3 LAX   16026
 4 BOS   15022
 5 MCO   13967
 6 CLT   13674
 7 SFO   13173
 8 FLL   11897
 9 MIA   1159310 DCA    9111# ... with 94 more rows

等价于

not_cancelled%>%
group_by(dest)%>%
summarise(n=n())%>%
arrange(desc(n))

7.Grouped mutates (and filters)

Find the worst members of each group:
flights_sml %>% 
  group_by(year, month, day) %>%
  filter(rank(desc(arr_delay)) < 10)#注意这里找的是每天arr_delay最高的九个航班,不是arr_delay最高的日子#每天9个所以有3300多行哦
Find all groups bigger than a threshold:
> popular_dest<-flights%>%
+ group_by(dest)%>%
+ filter(n()>365)
> popular_dest
Standardise to compute per group metrics:
> popular_dest%>%#这个数据集已经按dest分组了+ filter(arr_delay>0)%>%#这里的filter是对每行数据+ mutate(prop_delay=arr_delay/sum(arr_delay))%>%#sum_delay是整组的sum(每个dest在整个数据集中的总delay)#得到的prop是每一个单独的航程,占该dest全年所有航班总delay的比例+ select(year:day,arr_delay,prop_delay)
Adding missing grouping variables: `dest`

Exercise

  1. Refer back to the lists of useful mutate and filtering functions. Describe how each operation changes when you combine it with grouping.
    ?我觉得没啥变化,只不过这些函数都是在group内进行啊

  2. Which plane (tailnum) has the worst on-time record?

#还是那个问题,怎么定义worst?是发生delay的比例吗还是平均delay时间?#如果先group再做filter/select,都是针对组内进行操作#如果要对整组的情况做一个总体的描述,得用summarise#这里如果先group_by(tailnum),后面得用summarise吧?> tailnum<-not_cancelled%>%
+ group_by(tailnum)%>%
+ summarise(prop_delay=sum(arr_delay>0)/n(),mean_delay=sum(arr_delay)/n())
> arrange(tailnum,desc(prop_delay))# A tibble: 4,037 x 3
   tailnum prop_delay mean_delay
   <chr>        <dbl>      <dbl>
 1 N121DE           1       15  
 2 N136DL           1      146  
 3 N143DA           1       24  
 4 N17627           1       15.5
 5 N240AT           1       53.6
 6 N26906           1       19  
 7 N295AT           1       30.8
 8 N302AS           1       29  
 9 N303AS           1       46  
10 N32626           1        5  
# ... with 4,027 more rows> arrange(tailnum,desc(mean_delay))# A tibble: 4,037 x 3
   tailnum prop_delay mean_delay
   <chr>        <dbl>      <dbl>
 1 N844MH       1           320 
 2 N911DA       1           294 
 3 N922EV       1           276 
 4 N587NW       1           264 
 5 N851NW       1           219 
 6 N928DN       1           201 
 7 N7715E       1           188 
 8 N654UA       1           185 
 9 N665MQ       0.667       175.
10 N427SW       1           157 
# ... with 4,027 more rows#可是我用filter(rank(desc(prop_delay))<10)就怎么都返回空表诶

怎样精简代码呢?

  1. What time of day should you fly if you want to avoid delays as much as possible?

  2. For each destination, compute the total minutes of delay. For each flight, compute the proportion of the total delay for its destination.

> not_cancelled%>%
+ group_by(dest)%>%
+ summarise(total_by_dest=sum(arr_delay))

我不明白这里的flight,是指一个航班号(每天都飞,总共有很多行数据,是一个组)还是每一个单独的航程(就是单行数据)
先按航班号理解好了
思路:先按dest分组,用mutate计算每一个单独航程的比例,再按flight分组,sum

> by_flight<-not_cancelled%>%
+ group_by(flight)
> by_dest%>%
+ mutate(prop_each=arr_delay/sum(arr_delay))%>%
+ group_by(flight)%>%
+ mutate(prop_flight=sum(prop_each))%>%
+ select(year:day,flight,prop_each,prop_flight)# A tibble: 327,346 x 6# Groups:   flight [3,835]
    year month   day flight  prop_each prop_flight
   <int> <int> <int>  <int>      <dbl>       <dbl> 1  2013     1     1   1545  0.000366      0.0116 
 2  2013     1     1   1714  0.000666      0.0647 
 3  2013     1     1   1141  0.00952      -0.119  
 4  2013     1     1    725 -0.00246       0.0240 
 5  2013     1     1    461 -0.000131     -0.0243 
 6  2013     1     1   1696  0.000123      0.00471
 7  2013     1     1    507  0.000198      0.0508 
 8  2013     1     1   5708 -0.000188      0.00154
 9  2013     1     1     79 -0.000105     -0.0049110  2013     1     1    301  0.0000822    -0.177  # ... with 327,336 more rows
  1. Delays are typically temporally correlated: even once the problem that caused the initial delay has been resolved, later flights are delayed to allow earlier flights to leave. Using lag(), explore how the delay of a flight is related to the delay of the immediately preceding flight.
    思路:按origin分组,将数据按预计起飞时间(sched)排序,x=lag(dep_delay),y=dep_delay作图,得到前一个航班的delay时间与当前航班delay时间的相关关系

> flights%>%
+ group_by(origin)%>%
+ arrange(year,month,day,sched_dep_time)%>%
+ mutate(prev_delay=lag(dep_delay))%>%
+ ggplot(mapping=aes(x=prev_delay,y=dep_delay))+geom_point()

webp

所以这图传达了什么信息呢?


所以这图是说,相关性不大吗orz

  1. Look at each destination. Can you find flights that are suspiciously fast? (i.e. flights that represent a potential data entry error). Compute the air time a flight relative to the shortest flight to that destination. Which flights were most delayed in the air?
    思路:定义suspciously fast为air_time<=30min
    按dest分组,去掉缺失值,去掉suspciously fast航班,找出最短飞行时间再计算

> not_cancelled%>%
+ filter(air_time<=30)
> not_cancelled%>%
+ filter(air_time>30)%>%
+ group_by(dest)%>%
+ mutate(rel_airtime=air_time/min(air_time))%>%
+ filter(rank(desc(rel_airtime))<10)# A tibble: 940 x 20# Groups:   dest [104]
    year month   day dep_time sched_dep_time dep_delay arr_time sched_arr_time arr_delay carrier
   <int> <int> <int>    <int>          <int>     <dbl>    <int>          <int>     <dbl> <chr>  
 1  2013     1     1      646            645         1     1023           1030        -7 UA     
 2  2013     1     1      656            705        -9     1007            940        27 MQ     
 3  2013     1     1      805            815       -10     1006           1010        -4 MQ     
 4  2013     1     1      817            810         7     1005            948        17 B6     
 5  2013     1     1      848            851        -3     1155           1136        19 UA     
 6  2013     1     1      926            928        -2     1233           1220        13 UA     
 7  2013     1     1     1032           1035        -3     1305           1250        15 EV     
 8  2013     1     1     1044           1045        -1     1231           1212        19 EV     
 9  2013     1     1     1147           1155        -8     1335           1327         8 FL     
10  2013     1     1     1330           1321         9     1613           1536        37 EV
  1. Find all destinations that are flown by at least two carriers. Use that information to rank the carriers.
    其实没懂题目啥意思,以下代码是在github看见的

> flights%>%
+ group_by(dest)%>%
+ filter(n_distinct(carrier)>=2)%>%
+ group_by(carrier)%>%
+ mutate(possible_transfers=n_distinct(dest))%>%
+ arrange(desc(possible_transfers))%>%
+ select(dest,year:day,possible_transfers)
Adding missing grouping variables: `carrier`# A tibble: 325,397 x 6# Groups:   carrier [16]
   carrier dest   year month   day possible_transfers
   <chr>   <chr> <int> <int> <int>              <int> 1 EV      IAD    2013     1     1                 51
 2 EV      MSP    2013     1     1                 51
 3 EV      IAD    2013     1     1                 51
 4 EV      JAX    2013     1     1                 51
 5 EV      CHS    2013     1     1                 51
 6 EV      MEM    2013     1     1                 51
 7 EV      CLE    2013     1     1                 51
 8 EV      RDU    2013     1     1                 51
 9 EV      DCA    2013     1     1                 5110 EV      AVL    2013     1     1                 51# ... with 325,387 more rows

我有一个疑问,这里第二次group_by的时候是在先按dest分组的情况下分还是直接在原tibble重新分组?按最后输出结果以及可以用dest当运算参数看应该是重新分组的?我有点不懂这个管道操作是什么个意思了

  1. For each plane, count the number of flights before the first delay of greater than 1 hour.
    思路:应该是按示例中的threshold类型处理。
    想要得到一个第一次delay超过1小时之前的数据的tibble,得排序
    哭泣了这题也不会做是在StackOverflow上找的答案
    方法一:用first()函数得到第一个delay超过一小时的数据

> filghts_del<-flights%>%
+ group_by(tailnum)%>%
+ arrange(year,month,day,dep_time)%>%
+ filter(arr_delay>60)%>%
+ summarise(first_month=first(month),first_day=first(day),first_time=first(dep_time))
> filghts_del# A tibble: 3,371 x 4
   tailnum first_month first_day first_time
   <chr>         <int>     <int>      <int> 1 D942DN            2        11       1508
 2 N0EGMQ            1         1       1604
 3 N10156            1        13       2221
 4 N102UW            6        22       2141
 5 N104UW            2        13       1331
 6 N10575            1         2       1548
 7 N105UW            7        11       1411
 8 N107US            7        27       1624
 9 N108UW            8        13       132910 N109UW            9        13       1643# ... with 3,361 more rows> not_cancelled%>%
+ group_by(tailnum)%>%
+ summarise(n=sum(month<filghts_del$first_month)+sum(month==filghts_del$first_month&day<filghts_del$first_day)+sum(month==filghts_del$first_month&day==filghts_del$first_day&dep_time<filghts_del$first_time))# A tibble: 4,037 x 2
   tailnum     n
   <chr>   <int> 1 D942DN   1390
 2 N0EGMQ    913
 3 N10156   1150
 4 N102UW    671
 5 N103US    693
 6 N104UW    632
 7 N10575    930
 8 N105UW    476
 9 N107US    58310 N108UW    578# ... with 4,027 more rowsThere were 50 or more warnings (use warnings() to see the first 50)



作者:The_Catcher
链接:https://www.jianshu.com/p/b2f8845a12f8


点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消