NLS 函数组
NLS Function By Group
我有一个数据集,我想在其中按组应用非线性最小二乘法。这是我之前问题的延续:
数据集如下所示:
df
x y GRP
0 0 1
426 9.28 1
853 18.5 1
1279 27.8 1
1705 37.0 1
2131 46.2 1
0 0 2
450 7.28 2
800 16.5 2
1300 30.0 2
2000 40.0 2
2200 48.0 2
如果我要对一组进行此操作,它会是这样的:
df1<-filter(df, GRP==1)
a.start <- max(df1$y)
b.start <- 1e-06
control1 <- nls.control(maxiter= 10000,tol=1e-02, warnOnly=TRUE)
nl.reg <- nls(y ~ a * (1-exp(-b * x)),data=df1,start=
list(a=a.start,b=b.start),
control= control1)
coef(nl.reg)[1]
coef(nl.reg)[2]
> coef(nl.reg)[1]
a
5599.075
> coef(nl.reg)[2]
b
3.891744e-06
然后我会为 GRP2 做同样的事情。我希望我的最终输出看起来像这样:
x y GRP a b
0 0 1 5599.075 3.891744e-06
426 9.28 1 5599.075 3.891744e-06
853 18.5 1 5599.075 3.891744e-06
1279 27.8 1 5599.075 3.891744e-06
1705 37.0 1 5599.075 3.891744e-06
2131 46.2 1 5599.075 3.891744e-06
0 0 2 New Value for a GRP2 New Value for b GRP2
450 7.28 2 New Value for a GRP2 New Value for b GRP2
800 16.5 2 New Value for a GRP2 New Value for b GRP2
1300 30.0 2 New Value for a GRP2 New Value for b GRP2
2000 40.0 2 New Value for a GRP2 New Value for b GRP2
2200 48.0 2 New Value for a GRP2 New Value for b GRP2
理想情况下,我认为 dplyr 是最好的方法,但我不知道该怎么做。这就是我认为它可能看起来像的样子:
control1 <- nls.control(maxiter= 10000,tol=1e-02, warnOnly=TRUE)
b.start <- 1e-06
df %>%
group_by(GRP) %>%
do(nlsfit = nls( form = y ~ a * (1-exp(-b * x)), data=.,
start= list( a=max(.$y), b=b.start),
control= control1) ) %>%
list(a = coef(nlsfit)[1], b = coef(nlsfit)[2])
错误:
in nlsModel(formula, mf, start, wts) :
singular gradient matrix at initial parameter estimates
虽然不太确定如何执行此操作,但任何帮助都将非常有用。谢谢!
我最初收到的错误消息(关于:在 nls
中找不到对象 'y')与我最初尝试使用 lapply-split-function
范式并继续搜索:“[r] 在函数内部使用 nls”。我已将 attach
的原始用法更改为 list2env
:
sapply( split( df , df$GRP), function(d){ dat <- list2env(d)
nlsfit <- nls( form = y ~ a * (1-exp(-b * x)), data=dat, start= list( a=max(y), b=b.start),
control= control1)
list(a = coef(nlsfit)[1], b = coef(nlsfit)[2])} )
#---
1 2
a 14.51827 441.5489
b 2.139378e-06 -6.775562e-06
您还会收到预期的警告。这些可以用 suppressWarnings( ... )
抑制
其中一个建议是使用 attach
。然后我极不情愿地做了,因为我经常警告新手不要使用 attach
。但在这里,它似乎强行构建了一个本地环境。我更喜欢 list2env 作为满足 nls 的机制。 nls
的代码顶部是促使我做出该选择的原因:
if (!is.list(data) && !is.environment(data))
stop("'data' must be a list or an environment")
我有一个数据集,我想在其中按组应用非线性最小二乘法。这是我之前问题的延续:
数据集如下所示:
df
x y GRP
0 0 1
426 9.28 1
853 18.5 1
1279 27.8 1
1705 37.0 1
2131 46.2 1
0 0 2
450 7.28 2
800 16.5 2
1300 30.0 2
2000 40.0 2
2200 48.0 2
如果我要对一组进行此操作,它会是这样的:
df1<-filter(df, GRP==1)
a.start <- max(df1$y)
b.start <- 1e-06
control1 <- nls.control(maxiter= 10000,tol=1e-02, warnOnly=TRUE)
nl.reg <- nls(y ~ a * (1-exp(-b * x)),data=df1,start=
list(a=a.start,b=b.start),
control= control1)
coef(nl.reg)[1]
coef(nl.reg)[2]
> coef(nl.reg)[1]
a
5599.075
> coef(nl.reg)[2]
b
3.891744e-06
然后我会为 GRP2 做同样的事情。我希望我的最终输出看起来像这样:
x y GRP a b
0 0 1 5599.075 3.891744e-06
426 9.28 1 5599.075 3.891744e-06
853 18.5 1 5599.075 3.891744e-06
1279 27.8 1 5599.075 3.891744e-06
1705 37.0 1 5599.075 3.891744e-06
2131 46.2 1 5599.075 3.891744e-06
0 0 2 New Value for a GRP2 New Value for b GRP2
450 7.28 2 New Value for a GRP2 New Value for b GRP2
800 16.5 2 New Value for a GRP2 New Value for b GRP2
1300 30.0 2 New Value for a GRP2 New Value for b GRP2
2000 40.0 2 New Value for a GRP2 New Value for b GRP2
2200 48.0 2 New Value for a GRP2 New Value for b GRP2
理想情况下,我认为 dplyr 是最好的方法,但我不知道该怎么做。这就是我认为它可能看起来像的样子:
control1 <- nls.control(maxiter= 10000,tol=1e-02, warnOnly=TRUE)
b.start <- 1e-06
df %>%
group_by(GRP) %>%
do(nlsfit = nls( form = y ~ a * (1-exp(-b * x)), data=.,
start= list( a=max(.$y), b=b.start),
control= control1) ) %>%
list(a = coef(nlsfit)[1], b = coef(nlsfit)[2])
错误:
in nlsModel(formula, mf, start, wts) :
singular gradient matrix at initial parameter estimates
虽然不太确定如何执行此操作,但任何帮助都将非常有用。谢谢!
我最初收到的错误消息(关于:在 nls
中找不到对象 'y')与我最初尝试使用 lapply-split-function
范式并继续搜索:“[r] 在函数内部使用 nls”。我已将 attach
的原始用法更改为 list2env
:
sapply( split( df , df$GRP), function(d){ dat <- list2env(d)
nlsfit <- nls( form = y ~ a * (1-exp(-b * x)), data=dat, start= list( a=max(y), b=b.start),
control= control1)
list(a = coef(nlsfit)[1], b = coef(nlsfit)[2])} )
#---
1 2
a 14.51827 441.5489
b 2.139378e-06 -6.775562e-06
您还会收到预期的警告。这些可以用 suppressWarnings( ... )
其中一个建议是使用 attach
。然后我极不情愿地做了,因为我经常警告新手不要使用 attach
。但在这里,它似乎强行构建了一个本地环境。我更喜欢 list2env 作为满足 nls 的机制。 nls
的代码顶部是促使我做出该选择的原因:
if (!is.list(data) && !is.environment(data))
stop("'data' must be a list or an environment")