PreMode / analysis /fig.5c.R
gzhong's picture
Upload folder using huggingface_hub
7718235 verified
library(ggplot2)
result.plot <- readRDS('figs/fig.5.prepare.RDS')
result.plot$use.lw <- F
# remove itan tasks
result.plot <- result.plot[grepl('.itan.split', result.plot$task.id),]
pick.cond <- 'auc'
# get unique models
uniq.models <- unique(gsub('.lw', '', result.plot$model))
# only keep the original models
uniq.models <- uniq.models[grepl('/$', uniq.models)]
# get unique genes, remove Q14524
uniq.genes <- unique(result.plot$task.id)
uniq.genes <- uniq.genes[uniq.genes != "Q14524"]
# for each gene and each fold, decide weather to use large window
for (g in uniq.genes) {
for (m in uniq.models) {
for (f in 0:4) {
lw.loss <- result.plot$val.loss[result.plot$model == paste0(m, '.lw') & result.plot$task.id == g & result.plot$fold==f]
loss <- result.plot$val.loss[result.plot$model == m & result.plot$task.id == g & result.plot$fold==f]
lw.tr.auc <- result.plot$tr.auc[result.plot$model == paste0(m, '.lw') & result.plot$task.id == g & result.plot$fold==f]
tr.auc <- result.plot$tr.auc[result.plot$model == m & result.plot$task.id == g & result.plot$fold==f]
if (pick.cond == 'auc') {
cond <- !is.na(mean(lw.tr.auc)) & lw.tr.auc > tr.auc
} else if (pick.cond == 'loss') {
cond <- !is.na(mean(lw.loss)) & loss > lw.loss
} else if (pick.cond == 'auc+loss') {
cond <- !is.na(lw.loss) & !is.na(lw.tr.auc) & (lw.tr.auc/lw.loss > tr.auc/loss)
} else if (pick.cond == 'auc&loss') {
cond <- !is.na(lw.loss) & !is.na(lw.tr.auc) & (lw.tr.auc > tr.auc) & (loss > lw.loss)
} else if (pick.cond == 'lw') {
cond <- T
} else {
cond <- F
}
if (cond) {
# use lw
to.remove <- which(result.plot$model == m & result.plot$task.id == g & result.plot$fold==f)
to.anno <- which(result.plot$model == paste0(m, '.lw') & result.plot$task.id == g & result.plot$fold==f)
result.plot$model[to.anno] <- m
result.plot$use.lw[to.anno] <- T
result.plot <- result.plot[-to.remove,]
} else {
to.remove <- which(result.plot$model == paste0(m, '.lw') & result.plot$task.id == g & result.plot$fold==f)
result.plot <- result.plot[-to.remove,]
}
}
}
}
result.plot <- result.plot[result.plot$model %in% c("PreMode/",
"Itan.1"),]
result.plot$task.name[result.plot$task.id == "Q14524.clean.itan.split"] <- "Gene: SCN5A"
model.dic <- c("PreMode/"="1: PreMode",
"Itan.1"="2: LoGoFunc")
result.plot$model <- model.dic[result.plot$model]
num.models <- length(unique(result.plot$model))
p1 <- ggplot(result.plot, aes(y=auc, x=task.name, col=model)) +
geom_point(alpha=0) +
stat_summary(data = result.plot,
aes(x=as.numeric(factor(task.name))+0.4*(as.numeric(factor(model)))/num.models-0.2*(num.models+1)/num.models,
y = auc, col=model),
fun.data = mean_se, geom = "errorbar", width = 0.2) +
stat_summary(data = result.plot,
aes(x=as.numeric(factor(task.name))+0.4*(as.numeric(factor(model)))/num.models-0.2*(num.models+1)/num.models,
y = auc, col=model),
fun.data = mean_se, geom = "point") +
labs(x = "task", y = "AUC", fill = "model") +
theme_bw() +
theme(axis.text.x = element_text(angle=60, vjust = 1, hjust = 1),
text = element_text(size = 16),
plot.title = element_text(size=15),
legend.position="bottom",
legend.direction="horizontal") +
ggtitle('PreMode compared to LoGoFunc') +
ggeasy::easy_center_title() +
coord_flip() + guides(col=guide_legend(nrow=1),
shape=guide_legend(nrow=1)) +
ylim(0.25, 1) + xlab('task: Genetics Level Mode of Action')
ggsave(paste0('figs/fig.5c.pdf'), p1, height = 5, width = 6)