annotate tools/myTools/bin/crit2.R @ 1:7e5c71b2e71f draft default tip

Uploaded
author laurenmarazzi
date Wed, 22 Dec 2021 16:00:34 +0000
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
1 #!/usr/bin/env Rscript
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
2 .libPaths('~/R_libs_36')
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
3 args = commandArgs(trailingOnly=TRUE)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
4
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
5 library(plyr)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
6 library("dplyr", warn.conflicts = FALSE)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
7 library(reshape2)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
8 library(readr)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
9 getwd()
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
10
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
11 exp<-read.delim(args[1],sep=" ",row.names = 1)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
12 samples<-read.delim(args[2],sep="\t",row.names = 1)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
13 exp<-exp %>% dplyr::filter(row.names(exp) %in% row.names(samples))
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
14 desired<-args[3]
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
15 undesired<-args[4]
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
16 filter<-args[5]
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
17
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
18
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
19 dfdes<- exp %>% filter(rownames(exp) %in% rownames(samples[samples$phenotype %in% desired,,drop=FALSE]))
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
20 meandes<- apply(dfdes,2,mean)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
21 dfundes<- exp %>% filter(rownames(exp) %in% rownames(samples[samples$phenotype %in% undesired,,drop=FALSE]))
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
22 meandundes<-apply(dfundes,2,mean)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
23 test<-meandes-meandundes
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
24 disc<-test
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
25 disc[disc<0]<-0
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
26 disc[disc>0]<-1
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
27 nodes<-colnames(dfdes)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
28
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
29 is<-read.delim(args[6],sep=" ") #internal_markers.txt
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
30 isdisc<-is
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
31 if (filter=="strict"){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
32 for (node in nodes){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
33 if (disc[node]==0){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
34 val=max(dfdes[,node])
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
35 isdisc[,node]<-replace(isdisc[,node],is[,node]<val, 0)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
36 isdisc[,node]<-replace(isdisc[,node],is[,node]>val, 1)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
37 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
38 if (disc[node]==1){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
39 val=min(dfdes[,node])
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
40 isdisc[,node]<-replace(isdisc[,node],is[,node]>val, 1)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
41 isdisc[,node]<-replace(isdisc[,node],is[,node]<val, 0)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
42 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
43 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
44 }else { #filter=="relaxed"
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
45 for (node in nodes){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
46 if (disc[node]==0){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
47 val=min(dfundes[,node])
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
48 isdisc[,node]<-replace(isdisc[,node],is[,node]<val, 0)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
49 isdisc[,node]<-replace(isdisc[,node],is[,node]>val, 1)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
50 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
51 if (disc[node]==1){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
52 val=max(dfdes[,node])
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
53 isdisc[,node]<-replace(isdisc[,node],is[,node]>val, 1)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
54 isdisc[,node]<-replace(isdisc[,node],is[,node]<val, 0)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
55 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
56 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
57
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
58 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
59
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
60
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
61
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
62 hammings<-data.frame(isdisc$replicate,isdisc$perturbation)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
63 colnames(hammings)=c("replicate","perturbation")
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
64 hammings$hammingdist<-sapply(isdisc[,3],function(x) sum(disc != x))
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
65
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
66 if (length(nodes)<10){
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
67 hams1_1<-hammings %>%filter(hammingdist<1)
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
68 }else{
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
69 hams1_1<-hammings %>%filter(hammingdist<=length(nodes)-round(.9*length(nodes)))
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
70 }
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
71
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
72 write.table(hams1_1[,c(1,2)],'crit2_perturbations.txt',quote=FALSE,row.names = FALSE,sep=" ")
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
73
7e5c71b2e71f Uploaded
laurenmarazzi
parents:
diff changeset
74