Bootstrapping to compare two groups

后端 未结 3 1347
不思量自难忘°
不思量自难忘° 2021-01-13 09:47

In the following code I use bootstrapping to calculate the C.I. and the p-value under the null hypothesis that two different fertilizers applied to tomato plants have no eff

相关标签:
3条回答
  • 2021-01-13 10:14

    Following John, I think the appropriate way to use bootstrap to test if the sums of these two different populations are significantly different is as follows:

    x <- c(1.4,2.3,2.9,1.5,1.1)
    y <- c(23.7,26.6,28.5,14.2,17.9,24.3)
    
    
    b_x <- boot(x, sum, R = 10000)
    b_y <- boot(y, sum, R = 10000)
    
    z<-(b_x$t0-b_y$t0)/sqrt(var(b_x$t[,1])+var(b_y$t[,1]))
    pnorm(z)
    

    So we can clearly reject the null that they are the same population. I may have missed a degree of freedom adjustment, I am not sure how bootstrapping works in that regard, but such an adjustment will not change your results drastically.

    0 讨论(0)
  • 2021-01-13 10:21

    While the actual soil beds could be considered a stratified variable in some instances this is not one of them. You only have the one manipulation, between the groups of plants. Therefore, your null hypothesis is that they really do come from the exact same population. Treating the items as if they're from a single set of 11 samples is the correct way to bootstrap in this case.

    If you have two plots, and in each plot tried the different fertilizers over different seasons in a counterbalanced fashion then the plots would be statified samples and you'd want to treat them as such. But that isn't the case here.

    0 讨论(0)
  • 2021-01-13 10:32

    EDIT2 : Hack deleted as it was a wrong solution. Instead one has to use the argument strata of the boot function :

    total <- c(x,y)
    id <- as.factor(c(rep("x",length(x)),rep("y",length(y))))
    b <- boot(total, diff, strata=id, R = 10000)
    ...
    

    Be aware you're not going to get even close to a correct estimate of your p.value :

    x <- c(1.4,2.3,2.9,1.5,1.1)
    y <- c(23.7,26.6,28.5,14.2,17.9,24.3)
    
    total <- c(x,y)
    
    b <- boot(total, diff, strata=id, R = 10000)
    ci <- boot.ci(b)
    p.value <- sum(b$t>=b$t0)/b$R
    > p.value
    [1] 0.5162
    

    How would you explain a p-value of 0.51 for two samples where all values of the second are higher than the highest value of the first?

    The above code is fine to get a -biased- estimate of the confidence interval, but the significance testing about the difference should be done by permutation over the complete dataset.

    0 讨论(0)
提交回复
热议问题