-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrunInferenceEqMAg20201122.R
86 lines (57 loc) · 1.87 KB
/
runInferenceEqMAg20201122.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
library(doParallel)
library(foreach)
source("Eq.R")
source("InferenceEqMag20201117.R")
args = commandArgs(trailingOnly=TRUE)
print(args)
#Usage: Rscript runInferenceEqMAg20200117.R numberOfCores nameOfRun rdsFileArrayOfExperimentalData numberOfStepsForRun OutputFilesLocation OptionalBooleanForOnlyAdjacentTransitions OptionalInitialStateForMCMC
cores = as.numeric(args[1])
prefix = args[2]
print(paste("This chain is ", prefix,".rds",sep = ""))
print(prefix)
superexperiment = readRDS(args[3])
experiment = superexperiment
equilibria = calcEQs(experiment)
steps = as.numeric(args[4])
output = args[5]
if(length(args)>5){
adjacentOnly = as.logical(args[6])
} else{
adjacentOnly = FALSE
}
if(is.na(adjacentOnly)){
adjacentOnly = FALSE
args[7] = args[6]
}
kill.rates = 1-diag(dim(experiment)[1])
if(adjacentOnly){
for(i in 1:nrow(kill.rates)){
for(j in i:ncol(kill.rates)){
if(abs(j-i)>1){
kill.rates[i,j] =0
kill.rates[j,i] = 0
}
}
}
}
if(length(args)>6){
pars = readRDS(args[7])
pars.init = pars[[length(pars)]]$eqmag
if(is.null(pars.init)){
pars.init = rates.to.eqmag(pars[[length(pars)]]$rates)
}
}
print("should pars.init")
sink(paste(output,prefix,".out", sep = ""))
begin = Sys.time()
if(exists("pars.init")){
print("program thinks it has an initial condition")
print(pars.init)
main(experiment,equilibria = equilibria, total.iter = steps,experiments.per.iter = 10000,cores = cores, name = paste(output,prefix,sep = ''),init.eqmag=pars.init, kill.rates = kill.rates)
} else{
main(experiment,equilibria = equilibria, total.iter = steps,experiments.per.iter = 10000,cores = cores, name = paste(output,prefix, sep =''), kill.rates = kill.rates)
}
Rprof(NULL)
end = Sys.time()
print(paste("Time elapsed for run:",end-begin))
sink()