R - Moindres carrés non linéaires
Lors de la modélisation de données du monde réel pour l'analyse de régression, nous observons qu'il est rarement le cas que l'équation du modèle soit une équation linéaire donnant un graphe linéaire. La plupart du temps, l'équation du modèle de données du monde réel implique des fonctions mathématiques de degré supérieur comme un exposant de 3 ou une fonction sin. Dans un tel scénario, le tracé du modèle donne une courbe plutôt qu'une ligne. L'objectif de la régression linéaire et non linéaire est d'ajuster les valeurs des paramètres du modèle pour trouver la ligne ou la courbe qui se rapproche le plus de vos données. En trouvant ces valeurs, nous pourrons estimer la variable de réponse avec une bonne précision.
Dans la régression des moindres carrés, nous établissons un modèle de régression dans lequel la somme des carrés des distances verticales de différents points de la courbe de régression est minimisée. Nous commençons généralement avec un modèle défini et supposons quelques valeurs pour les coefficients. Nous appliquons ensuite lenls() fonction de R pour obtenir les valeurs les plus précises avec les intervalles de confiance.
Syntaxe
La syntaxe de base pour créer un test des moindres carrés non linéaire dans R est -
nls(formula, data, start)
Voici la description des paramètres utilisés -
formula est une formule de modèle non linéaire comprenant des variables et des paramètres.
data est une base de données utilisée pour évaluer les variables de la formule.
start est une liste nommée ou un vecteur numérique nommé d'estimations de départ.
Exemple
Nous considérerons un modèle non linéaire avec hypothèse des valeurs initiales de ses coefficients. Ensuite, nous verrons quels sont les intervalles de confiance de ces valeurs supposées afin que nous puissions juger dans quelle mesure ces valeurs intègrent le modèle.
Considérons donc l'équation ci-dessous à cet effet -
a = b1*x^2+b2
Supposons que les coefficients initiaux soient 1 et 3 et ajustons ces valeurs dans la fonction nls ().
xvalues <- c(1.6,2.1,2,2.23,3.71,3.25,3.4,3.86,1.19,2.21)
yvalues <- c(5.19,7.43,6.94,8.11,18.75,14.88,16.06,19.12,3.21,7.58)
# Give the chart file a name.
png(file = "nls.png")
# Plot these values.
plot(xvalues,yvalues)
# Take the assumed values and fit into the model.
model <- nls(yvalues ~ b1*xvalues^2+b2,start = list(b1 = 1,b2 = 3))
# Plot the chart with new data by fitting it to a prediction from 100 data points.
new.data <- data.frame(xvalues = seq(min(xvalues),max(xvalues),len = 100))
lines(new.data$xvalues,predict(model,newdata = new.data))
# Save the file.
dev.off()
# Get the sum of the squared residuals.
print(sum(resid(model)^2))
# Get the confidence intervals on the chosen values of the coefficients.
print(confint(model))
Lorsque nous exécutons le code ci-dessus, cela produit le résultat suivant -
[1] 1.081935
Waiting for profiling to be done...
2.5% 97.5%
b1 1.137708 1.253135
b2 1.497364 2.496484
On peut en conclure que la valeur de b1 est plus proche de 1 tandis que la valeur de b2 est plus proche de 2 et non de 3.