Sto facendo ricerche sul campo della risposta funzionale degli acari. Vorrei fare una regressione per stimare i parametri (velocità di attacco e tempo di gestione) della funzione di tipo II di Rogers. Ho un set di dati di misurazioni. Come posso determinare meglio i valori anomali?
Per la mia regressione uso il seguente script in R (una regressione non lineare): (il set di date è un semplice file di testo a 2 colonne chiamato data.txt
file con N0
valori (numero di prede iniziali) e FR
valori (numero di prede mangiate durante 24 ore):
library("nlstools")
dat <- read.delim("C:/data.txt")
#Rogers type II model
a <- c(0,50)
b <- c(0,40)
plot(FR~N0,main="Rogers II normaal",xlim=a,ylim=b,xlab="N0",ylab="FR")
rogers.predII <- function(N0,a,h,T) {N0 - lambertW(a*h*N0*exp(-a*(T-h*N0)))/(a*h)}
params1 <- list(attackR3_N=0.04,Th3_N=1.46)
RogersII_N <- nls(FR~rogers.predII(N0,attackR3_N,Th3_N,T=24),start=params1,data=dat,control=list(maxiter= 10000))
hatRIIN <- predict(RogersII_N)
lines(spline(N0,hatRIIN))
summary(RogersII_N)$parameters
Per tracciare i grafici dei residui di calssic uso il seguente script:
res <- nlsResiduals (RogersII_N)
plot (res, type = 0)
hist (res$resi1,main="histogram residuals")
qqnorm (res$resi1,main="QQ residuals")
hist (res$resi2,main="histogram normalised residuals")
qqnorm (res$resi2,main="QQ normalised residuals")
par(mfrow=c(1,1))
boxplot (res$resi1,main="boxplot residuals")
boxplot (res$resi2,main="boxplot normalised residuals")
Domande
- Come posso determinare meglio quali punti dati sono anomali?
- Ci sono test che posso usare in R che sono obiettivi e mi mostrano quali punti dati sono anomali?