exemplo reproduzivel.........................................
bastaria vc dizer quais sao os valores de sum(X2) e os graus de liberdade...
b
2012/4/13 Vitor Aguiar <
vitor.aguiar@me.com>:
Sandro,
usando format com nsmall = 20, eu tenho um resultado de 1.000000000000000000.
Mas eu tenho certeza que esse número é na realidade alguma coisa menor que 1.
Eu não sei se isso ocorre pelo modo como o R mostra o número (com 22 casas) ou se é um problema em como os valores estão guardados no R. Eu estou usando os valores como "doubles" mas ainda assim parece não ser suficiente.
Benílton,
se eu colocar o log=TRUE o resultado do cálculo passa a ser 0 (zero), ao invés de 1. Assim, também não consigo nenhuma medida do que quero medir.
Tura,
usando
pvalue = 2 * pchisq(sum(X2, na.rm = TRUE), dfreedom(X2),lower.tail=F)
o resultado ainda é 0 (zero). E se eu usar o format(x, nsmall = 20) nisso eu ainda tenho 0.00000000000000000.
A propósito, há alguma forma de guardar números no R com mais bits do que "as doubles"?
Obrigado a todos,
Vitor
On Apr 12, 2012, at 2:28 AM, Bernardo Rangel Tura wrote:
On 04/11/2012 07:26 PM, Vitor Aguiar wrote:
Caros,
quero fazer o seguinte cálculo:
pvalue = 1 - pchisq(sum(X2, na.rm = TRUE), dfreedom(X2)) #dfreedom( ) é
uma função escrita por mim
mas usando os meus dados isso dá sempre 0 (zero), porque a parte do
pchisq( ) é um valor muito próximo de 1, então o R arredonda para 1,
ficando 1 - 1 = 0.
Mesmo que o verdadeiro valor desse cálculo seja algo muitíssimo pequeno,
como zero seguido de vários zeros e eventualmente algum outro número, eu
preciso saber qual é.
Como fazer isso?
Desde já agradeço a quem puder ajudar.
Vitor Aguiar
Vitor,
Primeiro você ha de convir que 1-número muito pequeno = 1
Mas acho que no seu caso é mais fácil de resolver
Em vez de
pvalue = 1 - pchisq(sum(X2, na.rm = TRUE), dfreedom(X2))
use
pvalue = 2 * pchisq(sum(X2, na.rm = TRUE), dfreedom(X2),lower.tail=F)
No primeiro você calcula 1 - P[X <= x] enquanto no segundo 2 * P[X > x].
Desta forma o número muito pequeno deve aparecer, se persistir o problema (o que eu duvido) use a opção "log.p=T", se ainda assim não resolver (o que acredito ser inverossímil) manda um exemplo para a lista
[]s
Tura
_______________________________________________
R-br mailing list
R-br@listas.c3sl.ufpr.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) e forneça código mínimo reproduzível.
_______________________________________________
R-br mailing list
R-br@listas.c3sl.ufpr.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) e forneça código mínimo reproduzível.
_______________________________________________
R-br mailing list
R-br@listas.c3sl.ufpr.brhttps://listas.inf.ufpr.br/cgi-bin/mailman/listinfo/r-brLeia o guia de postagem (http://www.leg.ufpr.br/r-br-guia) e forneça código mínimo reproduzível.