[R-br] RES: [R-br Teste de diferça entre proporções via loop

Daniel Tiezzi dtiezzi em usp.br
Sábado Março 26 18:04:47 BRT 2016


Eu não sei do que se trata os seus dados, mas o teste que vc está aplicando diz que os valores de N são menores que o de X.

Tente rodar apenas nas duas primeiras linhas. Vai funcionar.

daniel

Daniel Tiezzi, MD, PhD
Professor Associado
Departamento de Ginecologia e Obstetrícia
Setor de Mastologia e Oncologia Ginecológica
Faculdade de Medicina de Ribeirão Preto - USP
Tel.: 16 3602-2488
e-mail: dtiezzi em fmrp.usp.br





> On Mar 26, 2016, at 8:24 PM, Mauro Sznelwar <sznelwar em uol.com.br> wrote:
> 
> Por que não estou conseguindo rodar?
>  
> > dados <- read.table("data_test.txt", header=T, sep= "\t")
> > dados$p_valor <- apply(dados[,2:4], 1, function(linha) prop.test(x=c(linha[1],linha[2]),n=c(linha[3],linha[3]), correct=F)$p.value)
> Error in prop.test(x = c(linha[1], linha[2]), n = c(linha[3], linha[3]),  : 
>   elements of 'x' must not be greater than those of 'n'
> > dados
>   AREA   X1   X2     N
> 1    1 1982 9416 11398
> 2    2 6546 4084 10630
> 3    3 3418  667  4085
> 4    4 1503 4408  5911
> 5    5  966  339   305
> > 
>  
>  
>  
>  
> Como sugestão para um código mais enxuto, o objetivo poderia ser atingido com a aplicação da função apply:
>  
> > dados <- read.table("data_test.txt", header=T, sep= "\t")
> > dados$p_valor <- apply(dados[,2:4], 1, function(linha) prop.test(x=c(linha[1],linha[2]),n=c(linha[3],linha[3]), correct=F)$p.value)
> > dados
>   AREA   X1   X2     N       p_valor
> 1    1 1982 9416 11398  0,000000e+00
> 2    2 6546 4084 10630 5,362948e-250
> 3    3 3418  667 40850  0,000000e+00
> 4    4 1503 4408 59110  0,000000e+00
> 5    5  966  339 30500  6,472911e-69
>  
> Ademais, se o OP tiver que resolver problemas dessa natureza com frequência, pode ser que valha a pena examinar alguns pacotes que têm funções para facilitar esse tipo de resumos, como, por exemplo, os pacotes descr e reporttools. 
>  
> HTH
> --
> Cesar Rabak
>  
>  
> On Wed, Mar 23, 2016 at 1:46 PM, Daniel Tiezzi <dtiezzi em usp.br <mailto:dtiezzi em usp.br>> wrote:
> Boa tarde Wagner
>  
> Supondo que seus dados esteja uma tabela data_test (em anexo)
>  
> acho que você pode resolver assim
>  
>  
> data<- read.table(“data_test.txt”, header=T, sep= “\t”)
>  
> data_df <- as.data.frame(data)
>  
> res<- list()
>  
> for (i in 1:nrow(data)) {
>   y<- prop.test(x = c(data$X1[i], data$X2[i]), n = c(data$N[i], data$N[i]), correct = FALSE)
>   x= y$p.value
>   res[[paste0(i)]] <- x
> }
>  
> result <- t(as.data.frame(res))
>  
> data_df1 <- cbind(data_df, result)
>  
> data_df1
>  
>  
> Espero que funcione
>  
>  
> daniel
>  
>  
>  
> Daniel Tiezzi, MD, PhD
> Professor Associado
> Departamento de Ginecologia e Obstetrícia
> Setor de Mastologia e Oncologia Ginecológica
> Faculdade de Medicina de Ribeirão Preto - USP
> Tel.: 16 3602-2488
> e-mail: dtiezzi em fmrp.usp.br <mailto:dtiezzi em fmrp.usp.br>
>  
>  
>  
> 
>  
>> On Mar 23, 2016, at 3:50 PM, Wagner Tassinari <wtassinari em gmail.com <mailto:wtassinari em gmail.com>> wrote:
>>  
>> AREA    X1      X2       N       p_valor
>> 1        1982    9416    11398      ?
>> 2        6546    4084    10630      ?
>> 3        3418    667       4085       ?
>> 4        1503    4408      5911       ?
>> 5        966        339       305       ?
> 
>  
> 
> 
>  <https://www.avast.com/sig-email?utm_medium=email&utm_source=link&utm_campaign=sig-email&utm_content=emailclient>	
> Este email foi escaneado pelo Avast antivírus. 
> www.avast.com <https://www.avast.com/sig-email?utm_medium=email&utm_source=link&utm_campaign=sig-email&utm_content=emailclient>
> _______________________________________________
> R-br mailing list
> R-br em listas.c3sl.ufpr.br <mailto:R-br em listas.c3sl.ufpr.br>
> https://listas.inf.ufpr.br/cgi-bin/mailman/listinfo/r-br <https://listas.inf.ufpr.br/cgi-bin/mailman/listinfo/r-br>
> Leia o guia de postagem (http://www.leg.ufpr.br/r-br-guia <http://www.leg.ufpr.br/r-br-guia>) e forneça código mínimo reproduzível.

-------------- Próxima Parte ----------
Um anexo em HTML foi limpo...
URL: <http://listas.inf.ufpr.br/pipermail/r-br/attachments/20160326/fd8d4a62/attachment.html>


Mais detalhes sobre a lista de discussão R-br