[英]How to calculate R-squared in nls package (non-linear model) in R?
我找到了解決方案。 這種方法在統計方面可能不正確(因為 R^2 在非線性模型中無效),但我只想看看我的非線性模型的整體擬合優度。
步驟1>將數據轉換為對數(常用對數)
當我使用非線性模型時,我無法檢查 R^2
nls(formula= agw~a*area^b, data=calibration, start=list(a=1, b=1))
因此,我將數據轉換為日志
x1<- log10(calibration$area)
y1<- log10(calibration$agw)
cal<- data.frame (x1,y1)
Step 2> 分析線性回歸
logdata<- lm (formula= y1~ x1, data=cal)
summary(logdata)
Call:
lm(formula = y1 ~ x1)
該模型提供,y= -0.122 + 1.42x
但是,我想強制截距為零,因此,
步驟 3> 強制截距為零
logdata2<- lm (formula= y1~ 0 + x1)
summary(logdata2)
現在方程是 y= 1.322x,這意味着 log (y) = 1.322 log (x),
所以它是 y= x^1.322。
在功率曲線模型中,我強制截距為零。 R^2 是 0.9994
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.