我试图在R中使用optim()使用R的本地数据集(来自MASS的Geyser)来实现R中高斯混合的MLE。我的代码如下。问题是,优化工作正常,但是,返回我传递给它的原始参数,并且还说它已经收敛。如果您能指出我要脱轨的地方,我将不胜感激。我的期望是它至少会产生不同的结果 如果不是完全不同的话。使用R中的optim()实现高斯混合MLE
library(ggplot2)
library(MASS)
data("geyser")
externaldata=geyser$waiting
x.vector=externaldata
MLE.x= function(combined.vector)
{ combined.vector=bigvec
x.vector = externaldata
K = k #capital K inside this MLE function, small K defined in the global environment
prob.vector = combined.vector[1:K]
mu.vector =combined.vector[(K+1):((2*K))]
sd.vector=combined.vector[(2*K+1):(3*K)]
prob=matrix(rep(prob.vector,length(x.vector)),byrow=TRUE,nrow = length(x.vector))
mu.sigma=cbind(mu.vector,sd.vector)
x.by.K=matrix(nrow = length(x.vector), ncol = k)
for (i in 1:K){
x.by.K[,i]=dnorm(x.vector,mu.sigma[i,1],mu.sigma[i,2])
}
prob.mat=x.by.K*prob
density=apply(prob.mat,1,sum)
log.density=sum(-log(density))
return(log.density)
}
## k=2 set ##
meanvec=c(50,80)
sigmavec=c(5,5)
k=2
probvec=c(1/3,2/3)
bigvec=c(probvec,meanvec,sigmavec)
est.k2.MLE=MLE.x(bigvec)
z=optim(bigvec,
fn=MLE.x,
method = "L-BFGS-B")
z
#### k=3 set #####
meanvec=c(50,70,80)
sigmavec=c(5,5,5)
k=3
probvec=rep(1/3,3)
bigvec=c(probvec,meanvec,sigmavec)
est.k3.MLE=MLE.x(bigvec)
z=optim(bigvec,
fn=MLE.x,
method = "BFGS")
z
为什么你没有使用你传递给MLE.x的参数? (MLE.x的第一行) –
@ antoine-sac没有先生,只是业余编码 – user2007598
另外,使用'='进行赋值被认为是不好的形式,虽然[正反两方都不是那么清楚](http: //stackoverflow.com/questions/1741820/assignment-operators-in-r-and)。国际海事组织使用'='很好,但我只是确保它是您的选择。 –