Eu criei uma regressão logística usando o seguinte código:
full.model.f = lm(Ft_45 ~ ., LOG_D)
base.model.f = lm(Ft_45 ~ IP_util_E2pl_m02_flg)
step(base.model.f, scope=list(upper=full.model.f, lower=~1),
direction="forward", trace=FALSE)
Em seguida, usei a saída para criar um modelo final:
final.model.f = lm(Ft_45 ~ IP_util_E2pl_m02_flg + IP_util_E2_m02_flg +
AE_NumVisit1_flg + OP_NumVisit1_m01_flg + IP_TotLoS_m02 +
Ft1_45 + IP_util_E1_m05_flg + IP_TotPrNonElecLoS_m02 +
IP_util_E2pl_m03_flg + LTC_coding + OP_NumVisit0105_m03_flg +
OP_NumVisit11pl_m03_flg + AE_ArrAmb_m02_flg)
Em seguida, previ os resultados para um conjunto diferente de dados usando a função de previsão:
log.pred.f.v <- predict(final.model.f, newdata=LOG_V)
Consegui usar uma curva ROC agradável e criei uma tabela para estabelecer a sensibilidade e a especificidade que me dão respostas que eu esperaria.
No entanto, o que estou tentando fazer é estabelecer para cada linha de dados qual é a probabilidade de Ft_45 ser 1. Se eu olhar para a saída de log.pred.fv, obtenho, por exemplo:
1 -0.171739593
2 -0.049905948
3 0.141146419
4 0.11615669
5 0.07342591
6 0.093054334
7 0.957164383
8 0.098415639
.
.
.
104 0.196368229
105 1.045208447
106 1.05499112
Como só tenho uma idéia provisória do que estou fazendo, estou lutando para entender como interpretar os valores negativos e maiores que 1, pois esperaria que a probabilidade estivesse entre 0 e 1.
Portanto, minha pergunta é: estou apenas perdendo uma etapa em que preciso transformar a saída ou estou completamente errado. Agradecemos antecipadamente por qualquer ajuda que você possa oferecer.
fonte
probs <- exp(predict(logit, type = "response" , newdata=data)
ou pelo menos `probs <- 1 / (1 + exp (-pred))Olhando para a documentação do
predict.glm
, parece tão fácil quanto usar um parâmetro extra napredict
chamada:Veja a documentação:
fonte