I wrote the following function in R. I want to iterate it, say 50000 times. I used "sapply" in my function but it runs slowly in R.My PC is still working about 20h now and I have no idea about the run time. Any ideas how to speed up this operation? Thanks.
data=matrix(c(0.01132162,1,0.04056053,1,0.11676735,0,0.12029087,1,
0.16197702,1,0.17190980,1,0.20386841,1,0.21251687,0,
0.36536492,0,0.40256414,1),ncol=2,byrow=T)
GIBS=function(data,a,b,beta,R)
{
m=length(R)
n1=sum(data[,2]==1)
n2=m-n1
n=m+sum(R)
N=c(n1,n2)
R1=c(0,R)
nstar=c()
for(i in 1:m) nstar[i]=n-(i-1)-sum(R1[1:i])
Z=c(data[1,1],data[2:m,1]-data[1:(m-1),1])
f=function(x)
{
A=0
for(i in 1:m) A=A+x^i*nstar[i]*Z[i]
FR=1
for(j in 1:2) FR=FR*(A+b[j])^(N[j]+a[j])
return(x^(m*(m+1)/2)*exp(-beta*(x-1))/FR)
}
INT=integrate(f,1,Inf)$value
SG=function(it)
{
uu=runif(1)
g0=function(t) integrate(f,1,t)$value/INT-uu
aa=5
if(g0(1)>0) {while(g0(aa)>0) aa=aa+1} else {while(g0(aa)<0) aa=aa+1}
ra=uniroot(g0,c(1,aa))$root
A1=sum(ra^(1:m)*nstar*Z)
rl1=rgamma(1,n1+a[1],A1+b[1])
rl2=rgamma(1,n2+a[2],A1+b[2])
return(c(ra,rl1,rl2))
}
return(colMeans(t(sapply(1:10000,SG,simplify = "array"))))
}
########
BGI=matrix(NA,ncol=3,nrow=50000)
for(iter in 1:50000)
{
BGI[iter,]=GIBS(data,c(2,1.6),c(2,2),5,c(10,rep(0,9)))
cat(iter, "of 50000\r")
flush.console()
}