-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMegaLMM_ggcorr.R
118 lines (97 loc) · 3.77 KB
/
MegaLMM_ggcorr.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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#################################################################
path.output = "./outputs"
path.geno = "../Geno"
library(MegaLMM)
library(tidyverse)
#################################################################
MegaLMM_pred_func <- function(treatment = "Control"){
# G matrix
load("../Geno/GL.RData")
G <- GL[[treatment]]
name <- c(paste0("a",1:10),paste0("b",1:10),paste0("c",1:10),paste0("d",1:10),paste0("e",1:10),paste0("f",1:10),paste0("g",1:10),paste0("h",1:3))
met2remove=c(13,28,30,33,38,62,67)
name = name[-met2remove]
# predictive correlation
# corRL <- list()
met0<-list()
# CV
for (i in 1:1) {
# i=1
# random-sampling to decide testing & reference accessions
met0[[i]] = read.csv(paste0("../Met/CrossValidation/cv_",i,"/met_cv_",i,".csv"))
met.wide0 <- met0[[i]] %>% filter(Treatment == treatment)
met.wide <- dplyr::select(met.wide0, all_of(c(name, "NSFTV_ID", "set")))
met.long <- tidyr::gather(met.wide,
key="met",
value="value",
-c(NSFTV_ID,set),
factor_key = F)
data_matrices = create_data_matrices(
tall_data = met.long,
id_cols = c('NSFTV_ID', "set"),
names_from = 'met',
values_from = 'value'
)
Y = data_matrices$Y
sample_data = data_matrices$data
id_train = sample_data$NSFTV_ID[sample_data$set=="train"]
id_test = sample_data$NSFTV_ID[sample_data$set=="test"]
fold_ID = i
Y_train = Y_testing = Y
run_parameters = MegaLMM_control(
h2_divisions = 20,
burn = 0,
thin = 1,
K = nnFA
)
MegaLMM_state = setup_model_MegaLMM(
Y = Y_train,
formula = ~ (1|NSFTV_ID),
data = sample_data,
relmat = list(NSFTV_ID = G),
run_parameters=run_parameters,
run_ID = sprintf('MegaLMM_fold_%02d',fold_ID)
)
Lambda_prior = list(
sampler = sample_Lambda_prec_horseshoe,
prop_0 = 0.1,
delta = list(shape = 3, scale = 1),
delta_iterations_factor = 100
)
priors = MegaLMM_priors(
tot_Y_var = list(V = 0.5, nu = 5),
tot_F_var = list(V = 18/20, nu = 20),
h2_priors_resids_fun = function(h2s,n) 1,
h2_priors_factors_fun = function(h2s,n) 1,
Lambda_prior = Lambda_prior
)
MegaLMM_state = set_priors_MegaLMM(MegaLMM_state,priors)
MegaLMM_state = initialize_variables_MegaLMM(MegaLMM_state)
MegaLMM_state = initialize_MegaLMM(MegaLMM_state,verbose = T)
MegaLMM_state$Posterior$posteriorSample_params = c('Lambda','F_h2','resid_h2','tot_Eta_prec')
MegaLMM_state$Posterior$posteriorMean_params = 'Eta_mean'
MegaLMM_state$Posterior$posteriorFunctions = list(
U = 'U_F %*% Lambda + U_R',
G = 't(Lambda) %*% diag(F_h2[1,]) %*% Lambda + diag(resid_h2[1,]/tot_Eta_prec[1,])',
R = 't(Lambda) %*% diag(1-F_h2[1,]) %*% Lambda + diag((1-resid_h2[1,])/tot_Eta_prec[1,])',
h2 = '(colSums(F_h2[1,]*Lambda^2)+resid_h2[1,]/tot_Eta_prec[1,])/(colSums(Lambda^2)+1/tot_Eta_prec[1,])'
)
MegaLMM_state = clear_Posterior(MegaLMM_state)
n_iter = 250
for(jj in 1:40) {
print(sprintf('Sampling run %d',jj))
MegaLMM_state = sample_MegaLMM(MegaLMM_state,n_iter)
MegaLMM_state = save_posterior_chunk(MegaLMM_state)
print(MegaLMM_state)
}
G_samples = load_posterior_param(MegaLMM_state,'G')
}
return(G_samples)
}
#################################################################
nnFA = 4
varcov_control <- MegaLMM_pred_func(treatment = "Control")
save(varcov_control, file="../temp/varcov_control.RDS")
nnFA = 5
varcov_stress <- MegaLMM_pred_func(treatment = "Stress")
save(varcov_stress, file = "../temp/varcov_stress.RDS")