- ネットワークに介入する(薬物影響・遺伝影響)(ロトカ=ヴォルテラ編)
library(sphere)
library(rgl)
StandardLotkaVolterra20111006<-function(n=4,inits=NULL,Nrep=30,drift=FALSE,driftk=0.05,Niter=1000,dt=0.01,us=NULL){
if(is.null(us)){
us<-rep(1,n)
}
Nr<-n
ks<-runif(Nr)
ks<-rep(1,n)
In<-Player<-diag(n)
Out<-matrix(0,Nr,n)
for(i in 1:Nr){
for(j in 1:n){
if(j==i+1){
Player[i,j]<-1
Out[i,j]<-1
}
}
}
Player[Nr,1]<-Out[Nr,1]<-1
S<-1
P<-runif(1,min=0,max=(1/n)^n)
xssum<-NULL
col<-c()
m<-matrix(Niter,n)
if(is.null(inits)){
inits<-runif(n)
}
for(rep in 1:Nrep){
if(drift){
if(rep>1){
prevm<-m
m<-prevm
p<-rep(0,Niter)
p[1]<-0
for(i in 1:n){
p[1]<-p[1]+us[i]*m[1,i]
}
m[1,]<-m[1,]/p[1]
p[1]<-0
for(i in 1:n){
p[1]<-p[1]+us[i]*m[1,i]
}
m[1,]<-prevm[Niter,]
thinsaxis<-1
m[1,thinsaxis]<-m[1,thinsaxis]*(1-runif(1)*driftk)
}else{
m<-matrix(0,Niter,n)
p<-rep(0,Niter)
p[1]<-0
for(i in 1:n){
p[1]<-p[1]+us[i]*m[1,i]
}
m[1,]<-m[1,]/p[1]
p[1]<-0
for(i in 1:n){
p[1]<-p[1]+us[i]*m[1,i]
}
m[1,]<-inits
}
}else{
m<-matrix(0,Niter,n)
p<-rep(0,Niter)
p[1]<-0
for(i in 1:n){
p[1]<-p[1]+us[i]*m[1,i]
}
m[1,]<-m[1,]/p[1]
p[1]<-0
for(i in 1:n){
p[1]<-p[1]+us[i]*m[1,i]
}
m[1,]<-runif(n)
}
library(MCMCpack)
for(i in 2:Niter){
m[i,]<-m[i-1,]
for(j in 1:Nr){
tmp<-ks[j]*dt
pamountIn<-0
pamountOut<-0
for(k in 1:n){
tmp<-tmp*m[i-1,k]^Player[j,k]
pamountIn<-pamountIn+us[k]*In[j,k]
pamountOut<-pamountOut+us[k]*Out[j,k]
}
for(k in 1:n){
m[i,k]<-m[i,k]-In[j,k]*tmp+tmp*pamountIn/pamountOut*us[k]*Out[j,k]/pamountOut*Out[j,k]
}
}
for(j in 1:n){
p[i]<-p[i]+us[j]*m[i,j]
}
}
xs<-matrix(0,Niter,n-1)
cv<-CategoryVector(n)
for(i in 1:Niter){
for(j in 1:n){
xs[i,]<-xs[i,]+m[i,j]*cv[j,]
}
}
xssum<-rbind(xssum,xs)
col<-c(col,rep(rep,Niter))
}
plot3d(xssum[,1],xssum[,2],xssum[,3],col=col)
list(X=xssum,col=col,In=In,Player=Player,Out=Out,m=m,inits=inits)
}
LV.out<-StandardLotkaVolterra20111006(n=4,Nrep=1,drift=TRUE,driftk=0.0)
plot(as.data.frame(LV.out[[1]]),col=LV.out[[2]],cex=0.01)
LV.out2<-StandardLotkaVolterra20111006(n=4,Nrep=10,drift=TRUE,driftk=0.2,inits=LV.out$inits)
plot(as.data.frame(LV.out2[[1]]),col=LV.out2[[2]],cex=0.01)
plot(as.data.frame(rbind(LV.out2[[1]],LV.out[[1]])),col=c(rep(2,length(LV.out2[[2]])),rep(1,length(LV.out[[2]]))),cex=0.01)