-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsurvival.R
99 lines (77 loc) · 3.45 KB
/
survival.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
# Analysis of prognostic relevance of the collagen-related gene expression
#
# 1) 'Univariable' analyses of prognostic relevance of single genes for OS
# and RFS. The variables are stratified by their respective optimal cutoffs
# corresponding to the largest difference in survival as assessed by
# Mentel-Henszel test. Significant effects are defined as significant genes
# shared by at least four cohorts
# tools -------
library(tidyverse)
library(rlang)
library(trafo)
library(stringi)
library(clustTools)
library(survival)
library(survminer)
library(glmnet)
library(coxExtensions)
library(kmOptimizer)
library(survivalsvm)
library(randomForestSRC)
library(furrr)
library(soucer)
library(ggtext)
explore <- exda::explore
select <- dplyr::select
reduce <- purrr::reduce
set_rownames <- trafo::set_rownames
c('./tools/globals.R',
'./tools/functions.R',
'./tools/svm_tools.R') %>%
source_all(message = TRUE, crash = TRUE)
# analysis data and globals --------
insert_msg('Analysis data and globals')
source_all('./survival scripts/globals.R',
message = TRUE, crash = TRUE)
# Univariable analysis ---------
insert_msg('Univariable analysis')
## resorting to cached versions, because the analyses take a while
access_cache(cache_path = './cache/rfs_cut.RData',
script_path = './survival scripts/univariable_rfs.R',
message = 'Loading cached univariable survival analysis results')
# Multi-parameter survival modeling ---------
insert_msg('Multi-parameter modeling')
list(cache_path = c('./cache/elnet_surv.RData',
'./cache/ridge_surv.RData',
'./cache/lasso_surv.RData',
'./cache/svm_surv.RData',
'./cache/svm_imp.RData',
'./cache/rf_surv.RData',
'./cache/gbm_surv.RData',
'./cache/surv_multi.RData'),
script_path = c('./survival scripts/elastic_net.R',
'./survival scripts/ridge.R',
'./survival scripts/lasso.R',
'./survival scripts/svm_survival.R',
'./survival scripts/svm_importance.R',
'./survival scripts/rf.R',
'./survival scripts/gbm.R',
'./survival scripts/clinic.R'),
message = c('Loading chached results of Elastic Net Cox modeling',
'Loading chached results of Ridge Cox modeling',
'Loading chached results of LASSO Cox modeling',
'Loading cached results of SVM modeling',
'Loading cached importance testing for the SVM survival score',
'Loading cached results of RF modeling',
'Loading cached results of GBM modeling',
'Loading cahced results for modeling with clinical variables')) %>%
pwalk(access_cache)
## summary of the stats and plots for the multi-parameter modeling
## testing for the clinic confounder in the pooled GEO cohort
c('./survival scripts/summary.R',
'./survival scripts/plots.R',
'./survival scripts/clinic_plots.R',
'./survival scripts/cohort.R') %>%
source_all(message = TRUE, crash = TRUE)
# END -------
insert_tail()