How do I perform a function on each row of a data frame and have just one element of the output inserted as a new column in that row

后端 未结 2 1507
余生分开走
余生分开走 2021-01-13 03:44

It is easy to do an Exact Binomial Test on two values but what happens if one wants to do the test on a whole bunch of number of successes and number of trials. I created a

相关标签:
2条回答
  • 2021-01-13 04:34

    Here you go:

    R> newres <- do.call(rbind, apply(df, 1, function(x) { 
    +                     bt <- binom.test(x[3], x[2])$conf.int; 
    +                     newdf <- data.frame(t(x), UCL=bt[2]) }))
    R>
    R> head(newres)
      sens enroll succes     UCL
    1 0.10     20      2 0.31698
    2 0.15     20      3 0.37893
    3 0.20     20      4 0.43661
    4 0.25     20      5 0.49105
    5 0.30     20      6 0.54279
    6 0.35     20      7 0.59219
    R> 
    

    This uses apply to loop over your existing data, compute test, return the value you want by sticking it into a new (one-row) data.frame. And we then glue all those 90 data.frame objects into a new single one with do.call(rbind, ...) over the list we got from apply.

    Ah yes, if you just want to directly insert a single column the other answer rocks as it is simple. My longer answer shows how to grow or construct a data.frame during the sweep of apply.

    0 讨论(0)
  • 2021-01-13 04:37

    If this gives you (almost) what you want, then try this:

    binom.test(succes,enroll)$conf.int[2]
    

    And apply across the board or across the rows as it were:

    > df$UCL <- apply(df, 1, function(x)  binom.test(x[3],x[2])$conf.int[2] )
    > head(df)
      sens enroll succes       UCL
    1 0.10     20      2 0.3169827
    2 0.15     20      3 0.3789268
    3 0.20     20      4 0.4366140
    4 0.25     20      5 0.4910459
    5 0.30     20      6 0.5427892
    6 0.35     20      7 0.5921885
    
    0 讨论(0)
提交回复
热议问题