Имитация t-критерия p-значений с использованием цикла for - PullRequest
0 голосов
/ 19 мая 2010

Для этого проекта мне необходимо использовать R-скрипт для имитации эффективности t-теста. Я должен использовать цикл for будет использоваться для выполнения следующих 2000 раз:

Будет ли цикл выглядеть примерно так

i <- 1
for (i <= 2001) { 
    x <-rf(5,df1=5,df2=10)
    b <- df2
    p.value <-t.test(x,mu=(b/(b-2))$p.value
    i <- i+1
}

1 Ответ

6 голосов
/ 19 мая 2010

Как вы и написали, это будет цикл "while".

Для циклов в R имеют следующий синтаксис:

for (i in 1:2000) {
    df1 <- 5
    df2 <- 10
    x <-rf(5, df1=df1, df2=df2)
    b <- df2
    p.value <- t.test(x, mu=(b/(b-2)))$p.value
}

Кроме того, может быть более эффективно использовать конструкцию apply, например, с replicate, и включать df в качестве аргументов функции:

get.p.value <- function(df1, df2) {
        x <- rf(5, df1=df1, df2=df2)
        p.value <- t.test(x, mu=(df2/(df2-2)))$p.value
    }
replicate (2000, get.p.value(df1 = 5, df2 = 10))

Это не всегда так, но упрощает восстановление значений p.value.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...