Last updated: 2022-12-08

Checks: 7 0

Knit directory: duplex_sequencing_screen/

This reproducible R Markdown analysis was created with workflowr (version 1.6.2). The Checks tab describes the reproducibility checks that were applied when the results were created. The Past versions tab lists the development history.


Great! Since the R Markdown file has been committed to the Git repository, you know the exact version of the code that produced these results.

Great job! The global environment was empty. Objects defined in the global environment can affect the analysis in your R Markdown file in unknown ways. For reproduciblity it’s best to always run the code in an empty environment.

The command set.seed(20200402) was run prior to running the code in the R Markdown file. Setting a seed ensures that any results that rely on randomness, e.g. subsampling or permutations, are reproducible.

Great job! Recording the operating system, R version, and package versions is critical for reproducibility.

Nice! There were no cached chunks for this analysis, so you can be confident that you successfully produced the results during this run.

Great job! Using relative paths to the files within your workflowr project makes it easier to run your code on other machines.

Great! You are using Git for version control. Tracking code development and connecting the code version to the results is critical for reproducibility.

The results in this page were generated with repository version 912824f. See the Past versions tab to see a history of the changes made to the R Markdown and HTML files.

Note that you need to be careful to ensure that all relevant files for the analysis have been committed to Git prior to generating the results (you can use wflow_publish or wflow_git_commit). workflowr only checks the R Markdown file, but you know if there are other scripts or data files that it depends on. Below is the status of the Git repository when the results were generated:


Ignored files:
    Ignored:    .Rhistory
    Ignored:    .Rproj.user/
    Ignored:    data/Consensus_Data/.Rhistory
    Ignored:    data/Consensus_Data/Novogene_lane13/sample8/variant_caller_outputs/
    Ignored:    data/Consensus_Data/Novogene_lane14/sample13/
    Ignored:    data/Consensus_Data/Novogene_lane14/sample14b/
    Ignored:    data/Consensus_Data/Novogene_lane14/sample1_combined/
    Ignored:    data/Consensus_Data/Novogene_lane14/sample7/variant_caller_outputs/duplex/
    Ignored:    data/Consensus_Data/Novogene_lane14/sample8/variant_caller_outputs/
    Ignored:    data/Consensus_Data/Novogene_lane2/abl_ref/kraken2-master/newdir/
    Ignored:    data/Consensus_Data/Novogene_lane4/.ipynb_checkpoints/
    Ignored:    data/Consensus_Data/Novogene_lane4/GalaxyData/initialanalysis/
    Ignored:    data/Consensus_Data/Novogene_lane4/output/
    Ignored:    data/Consensus_Data/Novogene_lane6/
    Ignored:    data/Consensus_Data/Novogene_lane7/
    Ignored:    data/Consensus_Data/Ranomics_Pooled/RP4/
    Ignored:    data/Consensus_Data/Ranomics_Pooled/RP5/
    Ignored:    data/Consensus_Data/novogene_lane15/sample_2/duplex/variant_caller_outputs/
    Ignored:    data/Consensus_Data/novogene_lane15/sample_4/sscs/sscs_sorted_filtered.tsv.gz
    Ignored:    data/Consensus_Data/novogene_lane15/sample_5/firstrun(lowsequencing)/sscs/variant_caller_outputs/.empty/

Untracked files:
    Untracked:  BCRABL_il3_D2_gray.pdf
    Untracked:  BCRABL_il3_D4_gray.pdf
    Untracked:  BCRABL_il3_D4_scores.pdf
    Untracked:  BCRABL_imat_D4_gray.pdf
    Untracked:  BCRABL_imat_D4_scores.pdf
    Untracked:  bcrabl_il3d0d4_scores.csv
    Untracked:  bcrabl_imatinibd0d4_scores.csv
    Untracked:  code/depth_finder.R
    Untracked:  data/Consensus_Data/Novogene_lane11/sample1/Sample_1.1.consensus.variant-calls.mut
    Untracked:  data/Consensus_Data/Novogene_lane13/sample1/duplex/duplex_sorted_filtered.tsv.gz
    Untracked:  data/Consensus_Data/novogene_lane15/sample_2/duplex/duplex_sorted_filtered.tsv.gz
    Untracked:  data/Consensus_Data/novogene_lane15/sample_3/ngs/
    Untracked:  data/Consensus_Data/novogene_lane15/sample_4/sscs/sscs_sorted_filtered.tsv
    Untracked:  data/Consensus_Data/novogene_lane15/sample_5/sscs/sscs_sorted_filtered.tsv
    Untracked:  data/Consensus_Data/novogene_lane15/sample_6/sscs/sscs_sorted_filtered.tsv
    Untracked:  data/Consensus_Data/novogene_lane15/sample_7/sscs/sscs_sorted_filtered.tsv
    Untracked:  data/Refs/ABL/abl_cds_translation.txt
    Untracked:  errorrates.pdf
    Untracked:  k562_bcrabl_background.pdf

Unstaged changes:
    Modified:   .DS_Store
    Deleted:    BCRABL_imatinib_D2_gray.pdf
    Modified:   analysis/variant_caller_2022.Rmd
    Modified:   code/.DS_Store
    Modified:   data/.DS_Store
    Modified:   data/Consensus_Data/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane11/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane11/sample1/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane11/sample1/duplex/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane11/sample1/sscs/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane13/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane13/sample1/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane13/sample1/sscs/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane13/sample2/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane14/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane14/sample14_combined/.DS_Store
    Modified:   data/Consensus_Data/Novogene_lane14/sample2_combined/.DS_Store
    Modified:   data/Consensus_Data/novogene_lane15/sample_3/.DS_Store
    Modified:   data/Consensus_Data/novogene_lane15/sample_3/sscs/.DS_Store
    Modified:   data/Refs/.DS_Store

Note that any generated files, e.g. HTML, png, CSS, etc., are not included in this status report because it is ok for generated content to have uncommitted changes.


These are the previous versions of the repository in which changes were made to the R Markdown (analysis/BCRABL_FunctionalKinaseAnalysis.Rmd) and HTML (docs/BCRABL_FunctionalKinaseAnalysis.html) files. If you’ve configured a remote Git repository (see ?wflow_git_remote), click on the hyperlinks in the table below to view the files as they were in that past version.

File Version Author Date Message
Rmd 912824f haiderinam 2022-12-08 wflow_publish("analysis/BCRABL_FunctionalKinaseAnalysis.Rmd")
Rmd 9612cc9 haiderinam 2022-11-22 Added analyses on mutant enrichment scores in the imatinib background
Rmd accc9f5 haiderinam 2022-11-16 Lane 15 additional sequencing
html c1aa64b haiderinam 2022-11-12 Build site.
Rmd 5aea8c2 haiderinam 2022-11-12 wflow_publish("analysis/BCRABL_FunctionalKinaseAnalysis.Rmd")
Rmd b794806 haiderinam 2022-11-11 Plotting imatinib enrichment scores distributions etc
html efcc61d haiderinam 2022-11-04 Build site.
Rmd 261bf5f haiderinam 2022-11-04 wflow_publish("analysis/BCRABL_FunctionalKinaseAnalysis.Rmd")
Rmd 3a2f887 haiderinam 2022-11-04 Added analyses of IL3 independence
Rmd 6f54acf haiderinam 2022-11-04 Added analyses of SSCS vs DCS error rates

Plotting the correlation of allele frequencies of stuff that I see in two samples

# samplex=read.csv("data/Consensus_Data/Novogene_lane14/sample10_combined/sscs/variant_caller_outputs/variants_unique_ann.csv",header=T,stringsAsFactors = F)
samplex=read.csv("data/Consensus_Data/Novogene_lane15/sample_6/sscs/variant_caller_outputs/variants_unique_ann.csv",header=T,stringsAsFactors = F)
# "Novogene_lane15/sample_6/sscs","Novogene_lane14/sample12/sscs"
samplex=samplex%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
samplex=samplex%>%mutate(maf=ct/depth)
samplex_simple=samplex%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf)

# sampley=read.csv("data/Consensus_Data/Novogene_lane15/sample_3/sscs/variant_caller_outputs/variants_unique_ann.csv",header=T,stringsAsFactors = F)
sampley=read.csv("data/Consensus_Data/Novogene_lane14/sample12/sscs/variant_caller_outputs/variants_unique_ann.csv",header=T,stringsAsFactors = F)
# sample7=read.csv("data/Consensus_Data/Novogene_lane15/sample_7/sscs/variant_caller_outputs/variants_unique_ann.csv",header=T,stringsAsFactors = F)

sampley=sampley%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
sampley=sampley%>%mutate(maf=ct/depth)
sampley_simple=sampley%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf)

samples_xy=merge(samplex_simple%>%filter(consequence_terms%in%"missense_variant"),sampley_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all = T)

plotly=ggplot(samples_xy%>%filter(protein_start>=242,protein_start<=492),aes(x=maf.x,y=maf.y))+
  geom_point(color="black",shape=21,aes(fill=ct.x))+
    scale_x_continuous(trans="log")+
    scale_y_continuous(trans="log")+
  geom_abline()+
  theme_bw()
ggplotly(plotly)
Warning in L$marker$color[idx] <- aes2plotly(data, params, "fill")[idx]: number
of items to replace is not a multiple of replacement length
# cor(samples_xy$maf.x,samples_xy$maf.y)

Background samples: Lane13 Sample 7, Lane 14 Sample 10, 11? D2 Post iL3 withdrawal: Lane 13 Sample 9,10 D4 Post iL3 withdrawal: Lane 13 Sample 11,12 D2 Post Imatinib treatment: Lane 14 Sample 12

SSCS

source("code/merge_samples.R")
il3all=merge_samples("Novogene_lane14/Sample10_combined/sscs","Novogene_lane13/sample7/sscs")
il3all=merge_samples(il3all,"Novogene_lane14/sample11/sscs")
il3all=merge_samples(il3all,"Novogene_lane15/sample_3/sscs")
il3all=merge_samples(il3all,"Novogene_lane13/Sample10/sscs")
il3all=merge_samples(il3all,"Novogene_lane13/Sample9/sscs")
il3all=merge_samples(il3all,"Novogene_lane15/sample_4/sscs")
il3all=merge_samples(il3all,"Novogene_lane15/sample_5/sscs")
il3all=merge_samples(il3all,"Novogene_lane15/sample_6/sscs")
il3all=merge_samples(il3all,"Novogene_lane15/sample_7/sscs")
a=il3all%>%filter(protein_start%in%c(242:494),consequence_terms%in%"missense_variant")

# il3D0=merge_samples("Novogene_lane14/Sample10_combined/sscs","Novogene_lane15/sample_3/sscs")
# a=il3D0%>%filter(!protein_start%in%c(242:494),type%in%"mnv")
# a=il3D0%>%filter(protein_start%in%c(242:494),consequence_terms%in%"missense_variant")
il3D0=merge_samples("Novogene_lane14/Sample10_combined/sscs","Novogene_lane13/sample7/sscs")
il3D0=merge_samples(il3D0,"Novogene_lane14/sample11/sscs")
il3D0=merge_samples(il3D0,"Novogene_lane15/sample_3/sscs")

il3D0=il3D0%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
il3D0=il3D0%>%mutate(maf=ct/depth)
il3D0=il3D0%>%mutate(totalcells=370,totalmutant=maf*totalcells)
il3D0_simple=il3D0%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf,totalcells,totalmutant)

# a=il3D0%>%filter(protein_start%in%c(242:494),consequence_terms%in%"missense_variant")
# a=il3D0.D2.merge%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494))
il3D2=merge_samples("Novogene_lane13/Sample9/sscs","Novogene_lane13/Sample10/sscs")
il3D2=merge_samples(il3D2,"Novogene_lane15/Sample_4/sscs")
il3D2=il3D2%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
il3D2=il3D2%>%mutate(maf=ct/depth)
il3D2=il3D2%>%mutate(totalcells=1515,totalmutant=maf*totalcells)
il3D2_simple=il3D2%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf,totalcells,totalmutant)


# imatD2=read.csv("data/Consensus_Data/Novogene_lane14/sample12/variant_caller_outputs/variants_unique_ann.csv",stringsAsFactors = F)
imatD2=merge_samples("Novogene_lane15/sample_6/sscs","Novogene_lane14/sample12/sscs")
# imatD2=merge_samples(imatD2,"Novogene_lane15/Sample4")
imatD2=imatD2%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
imatD2=imatD2%>%mutate(maf=ct/depth)
imatD2=imatD2%>%mutate(totalcells=1192,totalmutant=maf*totalcells)
imatD2_simple=imatD2%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf,totalcells,totalmutant)



il3D4=read.csv("data/Consensus_Data/novogene_lane15/sample_5/sscs/variant_caller_outputs/variants_unique_ann.csv")
# imatD2=merge_samples(imatD2,"Novogene_lane15/Sample4")
il3D4=il3D4%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
il3D4=il3D4%>%mutate(maf=ct/depth)
il3D4=il3D4%>%mutate(totalcells=17239,totalmutant=maf*totalcells)
il3D4_simple=il3D4%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf,totalcells,totalmutant)


imatD4=read.csv("data/Consensus_Data/novogene_lane15/sample_7/sscs/variant_caller_outputs/variants_unique_ann.csv")
# imatD2=merge_samples(imatD2,"Novogene_lane15/Sample4")
imatD4=imatD4%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
imatD4=imatD4%>%mutate(maf=ct/depth)
imatD4=imatD4%>%mutate(totalcells=10397,totalmutant=maf*totalcells)
imatD4_simple=imatD4%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf,totalcells,totalmutant)


##########IL3 Day 2 vs IL3 D0############
il3D0.D2=merge(il3D0_simple%>%filter(consequence_terms%in%"missense_variant")%>%mutate(totalmutant=totalmutant*107/370),il3D2_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all.x = T)
il3D0.D2$alt_aa=factor(il3D0.D2$alt_aa,levels=c("P","G","Y","W","F","V","L","I","A","T","S","Q","N","M","C","E","D","R","K","H"))
il3D0.D2[il3D0.D2$ct.y%in%NA,"ct.y"]=.5

il3D0.D2=depth_finder(il3D0.D2,"depth.y")
il3D0.D2=depth_finder(il3D0.D2,"totalcells.y")
il3D0.D2=il3D0.D2%>%mutate(maf.y=ct.y/depth.y,
                           totalmutant.y=maf.y*totalcells.y)

il3D0.D2[il3D0.D2$ct.x%in%NA,"ct.x"]=.5

il3D0.D2=il3D0.D2%>%mutate(score=log2(maf.y/maf.x))
# il3D0.D2[il3D0.D2$score%in%NA,"score"]=-6

il3D0.D2[il3D0.D2$totalmutant.y%in%NA,"totalmutant.y"]=0
il3D0.D2=il3D0.D2%>%mutate(netgr_obs=log(totalmutant.y/totalmutant.x)/48)
il3D0.D2[il3D0.D2$netgr_obs%in%NA,"netgr_obs"]=-.055


##########IL3 Day 4 vs IL3 D2############
il3D2.D4=merge(il3D2_simple%>%filter(consequence_terms%in%"missense_variant"),il3D4_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all.x = T)
il3D2.D4[il3D2.D4$ct.y%in%NA,"ct.y"]=.5

il3D2.D4=depth_finder(il3D2.D4,"depth.y")
il3D2.D4=depth_finder(il3D2.D4,"totalcells.y")
il3D2.D4=il3D2.D4%>%mutate(maf.y=ct.y/depth.y,
                           totalmutant.y=maf.y*totalcells.y)

il3D2.D4[il3D2.D4$ct.x%in%NA,"ct.x"]=.5
il3D2.D4=il3D2.D4%>%mutate(score=log2(maf.y/maf.x))
# il3D2.D4[il3D2.D4$score%in%NA,"score"]=-6

il3D2.D4[il3D2.D4$totalmutant.y%in%NA,"totalmutant.y"]=0
il3D2.D4=il3D2.D4%>%mutate(netgr_obs=log(totalmutant.y/totalmutant.x)/48)
il3D2.D4[il3D2.D4$netgr_obs%in%NA,"netgr_obs"]=-.055

##########IL3 Day 4 vs Imat D0############
il3D0.D4=merge(il3D0_simple%>%filter(consequence_terms%in%"missense_variant")%>%mutate(totalmutant=totalmutant*107/370),il3D4_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all.x = T)
# il3D0.D4[il3D0.D4$ct.y%in%NA,"ct.y"]=0
il3D0.D4[il3D0.D4$ct.y%in%NA,"ct.y"]=.5

il3D0.D4=depth_finder(il3D0.D4,"depth.y")
il3D0.D4=depth_finder(il3D0.D4,"totalcells.y")
il3D0.D4=il3D0.D4%>%mutate(maf.y=ct.y/depth.y,
                           totalmutant.y=maf.y*totalcells.y)

il3D0.D4[il3D0.D4$ct.x%in%NA,"ct.x"]=.5
il3D0.D4=il3D0.D4%>%mutate(score=log2(maf.y/maf.x))
# il3D0.D4[il3D0.D4$score%in%NA,"score"]=-6

il3D0.D4[il3D0.D4$totalmutant.y%in%NA,"totalmutant.y"]=0
il3D0.D4=il3D0.D4%>%mutate(netgr_obs=log(totalmutant.y/totalmutant.x)/96)
il3D0.D4[il3D0.D4$netgr_obs%in%NA,"netgr_obs"]=-.055

##########Imatinib Day 2 vs Imat D0############
imatD0.D2=merge(il3D0_simple%>%filter(consequence_terms%in%"missense_variant"),imatD2_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all.x = T)
# imatD0.D2[imatD0.D2$ct.y%in%NA,"ct.y"]=0
imatD0.D2[imatD0.D2$ct.y%in%NA,"ct.y"]=.5

imatD0.D2=depth_finder(imatD0.D2,"depth.y")
imatD0.D2=depth_finder(imatD0.D2,"totalcells.y")
imatD0.D2=imatD0.D2%>%mutate(maf.y=ct.y/depth.y,
                           totalmutant.y=maf.y*totalcells.y)

imatD0.D2[imatD0.D2$ct.x%in%NA,"ct.x"]=.5
imatD0.D2=imatD0.D2%>%mutate(score=log2(maf.y/maf.x))
# imatD0.D2[imatD0.D2$score%in%NA,"score"]=-6

imatD0.D2[imatD0.D2$totalmutant.y%in%NA,"totalmutant.y"]=0
imatD0.D2=imatD0.D2%>%mutate(netgr_obs=log(totalmutant.y/totalmutant.x)/48)
imatD0.D2[imatD0.D2$netgr_obs%in%NA,"netgr_obs"]=-.055


##########Imatinib Day 4 vs Imat D2############
imatD2.D4=merge(imatD2_simple%>%filter(consequence_terms%in%"missense_variant"),imatD4_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all.x = T)
# imatD2.D4[imatD2.D4$ct.y%in%NA,"ct.y"]=0
imatD2.D4[imatD2.D4$ct.y%in%NA,"ct.y"]=.5

imatD2.D4=depth_finder(imatD2.D4,"depth.y")
imatD2.D4=depth_finder(imatD2.D4,"totalcells.y")
imatD2.D4=imatD2.D4%>%mutate(maf.y=ct.y/depth.y,
                           totalmutant.y=maf.y*totalcells.y)

imatD2.D4[imatD2.D4$ct.x%in%NA,"ct.x"]=.5
imatD2.D4=imatD2.D4%>%mutate(score=log2(maf.y/maf.x))
# imatD2.D4[imatD2.D4$score%in%NA,"score"]=-6

imatD2.D4[imatD2.D4$totalmutant.y%in%NA,"totalmutant.y"]=0
imatD2.D4=imatD2.D4%>%mutate(netgr_obs=log(totalmutant.y/totalmutant.x)/48)
imatD2.D4[imatD2.D4$netgr_obs%in%NA,"netgr_obs"]=-.055

##########Imatinib Day 4 vs Imat D0############
imatD0.D4=merge(il3D0_simple%>%filter(consequence_terms%in%"missense_variant"),imatD4_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all.x = T)
# imatD0.D4[imatD0.D4$ct.y%in%NA,"ct.y"]=0
imatD0.D4[imatD0.D4$ct.y%in%NA,"ct.y"]=.5

imatD0.D4=depth_finder(imatD0.D4,"depth.y")
imatD0.D4=depth_finder(imatD0.D4,"totalcells.y")
imatD0.D4=imatD0.D4%>%mutate(maf.y=ct.y/depth.y,
                           totalmutant.y=maf.y*totalcells.y)

imatD0.D4[imatD0.D4$ct.x%in%NA,"ct.x"]=.5
imatD0.D4=imatD0.D4%>%mutate(score=log2(maf.y/maf.x))
# imatD0.D4[imatD0.D4$score%in%NA,"score"]=-6

imatD0.D4[imatD0.D4$totalmutant.y%in%NA,"totalmutant.y"]=0
imatD0.D4=imatD0.D4%>%mutate(netgr_obs=log(totalmutant.y/totalmutant.x)/96)
imatD0.D4[imatD0.D4$netgr_obs%in%NA,"netgr_obs"]=-.055

######Plotting imat D0 D2 Heatmap####
ggplot(imatD0.D2%>%filter(nchar(as.character(alt_aa))%in%1,protein_start>=242,protein_start<=494),aes(x=protein_start,y=alt_aa,fill=score))+
  geom_tile()+
  theme(panel.background=element_rect(fill="white", colour="black"))+
  scale_fill_gradient2(low ="darkblue",midpoint=-1,mid="white", high ="red",name="Enrichment Score")+
  scale_color_manual(values=c("black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0),breaks = c(250,253,255,276,299,315,317,351,355,359,396,459,486))+
  ylab("Mutant Amino Acid")
Warning: Removed 5 rows containing missing values (geom_tile).

Version Author Date
c1aa64b haiderinam 2022-11-12
efcc61d haiderinam 2022-11-04
# ggsave("BCRABL_imatinib_D2.pdf",height=6,width=24,units="in",useDingbats=F)

######Plotting resistant imat D0 D2 Heatmap####
ggplot(imatD0.D2%>%filter(nchar(as.character(alt_aa))%in%1,protein_start%in%c(250,253,255,276,299,315,317,351,355,359,396,459,486)),aes(x=protein_start,y=alt_aa,fill=score))+
  geom_tile()+
  theme(panel.background=element_rect(fill="white", colour="black"))+
  scale_fill_gradient2(low ="darkblue",midpoint=-1,mid="white", high ="red",name="Enrichment Score")+
  scale_color_manual(values=c("black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0),breaks =c(250,253,255,276,299,315,317,351,355,359,396,459,486))+
  ylab("Mutant Amino Acid")

Version Author Date
c1aa64b haiderinam 2022-11-12
# ggsave("BCRABL_imatinib_D2_resistantresidues.pdf",height=6,width=24,units="in",useDingbats=F)

######Plotting iL3 D0 D2 Heatmap####
il3D0.D2$alt_aa=factor(il3D0.D2$alt_aa,levels=c("P","G","Y","W","F","V","L","I","A","T","S","Q","N","M","C","E","D","R","K","H"))
ggplot(il3D0.D2%>%filter(nchar(as.character(alt_aa))%in%1,protein_start>=242,protein_start<=494),aes(x=protein_start,y=alt_aa,fill=score))+
  geom_tile()+
  theme(panel.background=element_rect(fill="white", colour="black"))+
  scale_fill_gradient2(low ="darkblue",midpoint=-1,mid="white", high ="red",name="Enrichment Score")+
  scale_color_manual(values=c("black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0),breaks = c(248,250,256, 271,275,300,325,350,363,375,381,400,405,425,450,475))+
  ylab("Mutant Amino Acid")
Warning: Removed 5 rows containing missing values (geom_tile).

Version Author Date
c1aa64b haiderinam 2022-11-12
# a=il3D0.D2%>%filter(netgr_obs%in%"-Inf",consequence_terms%in%"missense_variant",protein_start%in%c(242:494))

# ggsave("BCRABL_iL3Independence_D2.pdf",height=6,width=24,units="in",useDingbats=F)
# write.csv(il3D0.D2,"BCRABL_Il3Independence_D2.csv")

#####Focusing on conserved residues#####
ggplot(il3D0.D4%>%filter(nchar(as.character(alt_aa))%in%1,protein_start%in%c(271,363,381:383)),aes(x=protein_start,y=alt_aa,fill=netgr_obs))+
  geom_tile()+
  theme(panel.background=element_rect(fill="white", colour="black"))+
  scale_fill_gradient2(low ="blue",midpoint=0,mid="white", high ="red",name="Enrichment Score")+
  scale_color_manual(values=c("black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0),breaks = c(248,250,256, 271,275,300,325,350,363,375,381,400,405,425,450,475))+
  ylab("Mutant Amino Acid")

Version Author Date
c1aa64b haiderinam 2022-11-12
# ggsave("BCRABL_iL3Independence_D2_essential.pdf",height=6,width=24,units="in",useDingbats=F)


#####Graying out unseen residues#####
###D0 D2 IL3
df_grid  = expand.grid(protein_start = c(242:493),alt_aa = unique(il3D0.D2$alt_aa))

il3D0.D2.merge=merge(df_grid,il3D0.D2,by=c("protein_start","alt_aa"),all=T)
il3D0.D2.merge=il3D0.D2.merge%>%filter(nchar(as.character(alt_aa))%in%1,protein_start>=242,protein_start<=494)
###Trying to add in the score as WT for residues that are wt
reference_seq=read.table("data/Refs/ABL/abl_cds_translation.txt")
il3D0.D2.merge=il3D0.D2.merge%>%
  rowwise()%>%
  # group_by(protein_start)%>%
  mutate(ref_aa=case_when(ref_aa%in%NA~substr(reference_seq,protein_start,protein_start),
                          T~ref_aa))%>%
  mutate(wt=case_when(ref_aa==alt_aa~T,
                      T~F))



##########Plotting gray and yellow heatmap
il3D0.D2.merge$alt_aa=factor(il3D0.D2.merge$alt_aa,levels=c("P","G","Y","W","F","V","L","I","A","T","S","Q","N","M","C","E","D","R","K","H"))
il3D0.D2.merge.filtered=il3D0.D2.merge%>%filter(!protein_start%in%c(290:305))
a=il3D0.D2.merge.filtered%>%filter(wt%in%T)
ggplot(il3D0.D2.merge.filtered,aes(x=protein_start,y=alt_aa))+
  geom_tile(data=subset(il3D0.D2.merge.filtered,!is.na(score)),aes(fill=score))+
  scale_fill_gradient2(low ="darkblue",midpoint=-1,mid="white", high ="red",name="Enrichment Score")+
  geom_tile(data=subset(il3D0.D2.merge.filtered,is.na(score)&wt%in%F),aes(color="white"),linetype = "solid",color="white", fill = "gray90", alpha = 0.8)+
  geom_tile(data=subset(il3D0.D2.merge.filtered,is.na(score)&wt%in%T),aes(color="white"),linetype = "solid",color="white", fill = "yellow", alpha = 0.4)+
  theme(panel.background=element_rect(fill="white", colour="black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0))+
  ylab("Mutant Amino Acid")
Warning: Removed 5 rows containing missing values (geom_tile).

ggsave("BCRABL_il3_D2_gray.pdf",height=6,width=24,units="in",useDingbats=F)
Warning: Removed 5 rows containing missing values (geom_tile).
###D0 D4 IL3
#####Graying out unseen residues#####
df_grid  = expand.grid(protein_start = c(242:493),alt_aa = unique(il3D0.D4$alt_aa))

il3D0.D4.merge=merge(df_grid,il3D0.D4,by=c("protein_start","alt_aa"),all=T)
il3D0.D4.merge=il3D0.D4.merge%>%filter(nchar(as.character(alt_aa))%in%1,protein_start>=242,protein_start<=494)
###Trying to add in the score as WT for residues that are wt
reference_seq=read.table("data/Refs/ABL/abl_cds_translation.txt")
il3D0.D4.merge=il3D0.D4.merge%>%
  rowwise()%>%
  # group_by(protein_start)%>%
  mutate(ref_aa=case_when(ref_aa%in%NA~substr(reference_seq,protein_start,protein_start),
                          T~ref_aa))%>%
  mutate(wt=case_when(ref_aa==alt_aa~T,
                      T~F))

##########Plotting gray and yellow heatmap
il3D0.D4.merge$alt_aa=factor(il3D0.D4.merge$alt_aa,levels=c("P","G","Y","W","F","V","L","I","A","T","S","Q","N","M","C","E","D","R","K","H"))
il3D0.D4.merge.filtered=il3D0.D4.merge%>%filter(!protein_start%in%c(290:305))
# a=il3D0.D4.merge.filtered%>%filter(wt%in%T)
ggplot(il3D0.D4.merge.filtered,aes(x=protein_start,y=alt_aa))+
  geom_tile(data=subset(il3D0.D4.merge.filtered,!is.na(score)),aes(fill=netgr_obs))+
  scale_fill_gradient2(low ="darkblue",midpoint=.04,mid="white", high ="red",name="Net growth rate")+
  geom_tile(data=subset(il3D0.D4.merge.filtered,is.na(score)&wt%in%F),aes(color="white"),linetype = "solid",color="white", fill = "gray90", alpha = 0.8)+
  geom_tile(data=subset(il3D0.D4.merge.filtered,is.na(score)&wt%in%T),aes(color="white"),linetype = "solid",color="white", fill = "yellow", alpha = 0.4)+
  theme(panel.background=element_rect(fill="white", colour="black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0))+
  ylab("Mutant Amino Acid")
Warning: Removed 5 rows containing missing values (geom_tile).

ggplot(il3D0.D4.merge.filtered,aes(x=protein_start,y=alt_aa))+
  geom_tile(data=subset(il3D0.D4.merge.filtered,!is.na(score)),aes(fill=score))+
  scale_fill_gradient2(low ="darkblue",midpoint=0,mid="white", high ="red",name="Enrichment Score")+
  geom_tile(data=subset(il3D0.D4.merge.filtered,is.na(score)&wt%in%F),aes(color="white"),linetype = "solid",color="white", fill = "gray90", alpha = 0.8)+
  geom_tile(data=subset(il3D0.D4.merge.filtered,is.na(score)&wt%in%T),aes(color="white"),linetype = "solid",color="white", fill = "yellow", alpha = 0.4)+
  theme(panel.background=element_rect(fill="white", colour="black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0))+
  ylab("Mutant Amino Acid")
Warning: Removed 5 rows containing missing values (geom_tile).

ggsave("BCRABL_il3_D4_scores.pdf",height=6,width=24,units="in",useDingbats=F)
Warning: Removed 5 rows containing missing values (geom_tile).
###D0 D4 Imat
#####Graying out unseen residues#####
df_grid  = expand.grid(protein_start = c(242:493),alt_aa = unique(imatD0.D4$alt_aa))

imatD0.D4.merge=merge(df_grid,imatD0.D4,by=c("protein_start","alt_aa"),all=T)
imatD0.D4.merge=imatD0.D4.merge%>%filter(nchar(as.character(alt_aa))%in%1,protein_start>=242,protein_start<=494)
###Trying to add in the score as WT for residues that are wt
reference_seq=read.table("data/Refs/ABL/abl_cds_translation.txt")
imatD0.D4.merge=imatD0.D4.merge%>%
  rowwise()%>%
  # group_by(protein_start)%>%
  mutate(ref_aa=case_when(ref_aa%in%NA~substr(reference_seq,protein_start,protein_start),
                          T~ref_aa))%>%
  mutate(wt=case_when(ref_aa==alt_aa~T,
                      T~F))

##########Plotting gray and yellow heatmap
imatD0.D4.merge$alt_aa=factor(imatD0.D4.merge$alt_aa,levels=c("P","G","Y","W","F","V","L","I","A","T","S","Q","N","M","C","E","D","R","K","H"))
imatD0.D4.merge.filtered=imatD0.D4.merge%>%filter(!protein_start%in%c(290:305))
# a=il3D0.D4.merge.filtered%>%filter(wt%in%T)
ggplot(imatD0.D4.merge.filtered,aes(x=protein_start,y=alt_aa))+
  geom_tile(data=subset(imatD0.D4.merge.filtered,!is.na(score)),aes(fill=netgr_obs))+
  scale_fill_gradient2(low ="darkblue",midpoint=.03,mid="white", high ="red",name="Net growth rate")+
  geom_tile(data=subset(imatD0.D4.merge.filtered,is.na(score)&wt%in%F),aes(color="white"),linetype = "solid",color="white", fill = "gray90", alpha = 0.8)+
  geom_tile(data=subset(imatD0.D4.merge.filtered,is.na(score)&wt%in%T),aes(color="white"),linetype = "solid",color="white", fill = "yellow", alpha = 0.4)+
  theme(panel.background=element_rect(fill="white", colour="black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0))+
  ylab("Mutant Amino Acid")
Warning: Removed 5 rows containing missing values (geom_tile).

ggsave("BCRABL_imat_D4_gray.pdf",height=6,width=24,units="in",useDingbats=F)
Warning: Removed 5 rows containing missing values (geom_tile).
ggplot(imatD0.D4.merge.filtered,aes(x=protein_start,y=alt_aa))+
  geom_tile(data=subset(imatD0.D4.merge.filtered,!is.na(score)),aes(fill=score))+
  scale_fill_gradient2(low ="darkblue",midpoint=0,mid="white", high ="red",name="Enrichment Score")+
  geom_tile(data=subset(imatD0.D4.merge.filtered,is.na(score)&wt%in%F),aes(color="white"),linetype = "solid",color="white", fill = "gray90", alpha = 0.8)+
  geom_tile(data=subset(imatD0.D4.merge.filtered,is.na(score)&wt%in%T),aes(color="white"),linetype = "solid",color="white", fill = "yellow", alpha = 0.4)+
  theme(panel.background=element_rect(fill="white", colour="black"))+scale_x_continuous(name="Residue on the ABL Kinase",limits=c(242,493),expand=c(0,0))+
  ylab("Mutant Amino Acid")
Warning: Removed 5 rows containing missing values (geom_tile).

ggsave("BCRABL_imat_D4_scores.pdf",height=6,width=24,units="in",useDingbats=F)
Warning: Removed 5 rows containing missing values (geom_tile).

Plotting enrichment scores

####Plotting Imatinib D4 D2 scores vs Imatinib D2 D0 scores
#First merging IL3 D0 D2 to IL3 D2 D4
scores_all=merge(il3D0.D2%>%dplyr::select(-ct.x,-depth.x,-maf.x,-totalmutant.x,-ct.y,-depth.y,-maf.y,-totalmutant.y,-totalcells.x,-totalcells.y),il3D2.D4%>%dplyr::select(-ct.x,-depth.x,-maf.x,-totalmutant.x,-ct.y,-depth.y,-maf.y,-totalmutant.y,-totalcells.x,-totalcells.y),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),suffixes = c(".il3d0.d2",".il3d2.d4"),all = T)
#Second, adding Imat D0 D2 to dataframe
scores_all=merge(scores_all,imatD0.D2%>%dplyr::select(-ct.x,-depth.x,-maf.x,-totalmutant.x,-ct.y,-depth.y,-maf.y,-totalmutant.y,-totalcells.x,-totalcells.y),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all = T)
scores_all=scores_all%>%rename(score.imatd0.d2=score,netgr_obs.imatd0.d2=netgr_obs)
#Third, adding Imat D2 D4 to dataframe
scores_all=merge(scores_all,imatD2.D4%>%dplyr::select(-ct.x,-depth.x,-maf.x,-totalmutant.x,-ct.y,-depth.y,-maf.y,-totalmutant.y,-totalcells.x,-totalcells.y),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all = T)
scores_all=scores_all%>%rename(score.imatd2.d4=score,netgr_obs.imatd2.d4=netgr_obs)
#Fourth, adding IL3 D4 D0 to dataframe
scores_all=merge(scores_all,il3D0.D4%>%dplyr::select(-ct.x,-depth.x,-maf.x,-totalmutant.x,-ct.y,-depth.y,-maf.y,-totalmutant.y,-totalcells.x,-totalcells.y),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all = T)
scores_all=scores_all%>%rename(score.il3d0.d4=score,netgr_obs.il3d0.d4=netgr_obs)
#Fifth, adding Imatinib D4 D0 to dataframe
scores_all=merge(scores_all,imatD0.D4%>%dplyr::select(-ct.x,-depth.x,-maf.x,-totalmutant.x,-ct.y,-depth.y,-maf.y,-totalmutant.y,-totalcells.x,-totalcells.y),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"),all = T)
scores_all=scores_all%>%rename(score.imatd0.d4=score,netgr_obs.imatd0.d4=netgr_obs)

scores_all=scores_all%>%mutate(resmuts=case_when(protein_start%in%253&alt_aa%in%"H"~T,
                                                         protein_start%in%255&alt_aa%in%"V"~T,
                                                         protein_start%in%486&alt_aa%in%"S"~T,
                                                         protein_start%in%396&alt_aa%in%"P"~T,
                                                         protein_start%in%255&alt_aa%in%"K"~T,
                                                         protein_start%in%315&alt_aa%in%"I"~T,
                                                         protein_start%in%252&alt_aa%in%"H"~T,
                                                         protein_start%in%253&alt_aa%in%"F"~T,
                                                         protein_start%in%250&alt_aa%in%"E"~T,
                                                         protein_start%in%359&alt_aa%in%"C"~T,
                                                         protein_start%in%351&alt_aa%in%"T"~T,
                                                         protein_start%in%355&alt_aa%in%"G"~T,
                                                         protein_start%in%317&alt_aa%in%"L"~T,
                                                         protein_start%in%359&alt_aa%in%"I"~T,
                                                         protein_start%in%355&alt_aa%in%"A"~T,
                                                         protein_start%in%459&alt_aa%in%"K"~T,
                                                         protein_start%in%276&alt_aa%in%"G"~T,
                                                         protein_start%in%299&alt_aa%in%"L"~T,
                                                         
                                                         T~F))





ggplot(scores_all%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494),!score.il3d2.d4%in%-6),aes(x=score.il3d0.d2,y=score.il3d2.d4))+geom_point()+geom_abline()
Warning: Removed 1261 rows containing missing values (geom_point).

ggplot(scores_all%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494),!score.il3d2.d4%in%-6),aes(x=score.il3d0.d2,y=score.il3d2.d4))+geom_point()+geom_abline()
Warning: Removed 1261 rows containing missing values (geom_point).

ggplot(scores_all%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494),!score.imatd2.d4%in%-6),aes(x=score.imatd0.d2,y=score.imatd0.d4))+geom_point()+geom_abline()
Warning: Removed 610 rows containing missing values (geom_point).

ggplot(scores_all%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494),!score.imatd2.d4%in%-6),aes(x=netgr_obs.imatd0.d2,y=netgr_obs.imatd0.d4))+geom_point()+geom_abline()
Warning: Removed 610 rows containing missing values (geom_point).

ggplot(scores_all%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494),!score.imatd2.d4%in%-6),aes(x=score.il3d0.d2,y=score.il3d0.d4))+geom_point()+geom_abline()
Warning: Removed 624 rows containing missing values (geom_point).

ggplot(scores_all%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494),!score.imatd2.d4%in%-6),aes(x=score.imatd0.d2,y=score.imatd2.d4))+geom_point()+geom_abline()
Warning: Removed 1790 rows containing missing values (geom_point).

ggplot(scores_all%>%filter(consequence_terms%in%"missense_variant",protein_start%in%c(242:494),!score.imatd2.d4%in%-6),aes(x=score.il3d0.d2,y=score.il3d2.d4))+geom_point()+geom_abline()
Warning: Removed 1261 rows containing missing values (geom_point).

ggplot(scores_all%>%filter(!score.imatd2.d4%in%-6),aes(x=score.imatd2.d4))+geom_histogram()
`stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
Warning: Removed 1964 rows containing non-finite values (stat_bin).

ggplot(scores_all%>%filter(!score.imatd0.d4%in%-6),aes(x=score.imatd0.d4))+geom_histogram()
`stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
Warning: Removed 1172 rows containing non-finite values (stat_bin).

ggplot(scores_all%>%filter(!score.imatd0.d2%in%-6),aes(x=score.imatd0.d2))+geom_histogram()
`stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
Warning: Removed 1212 rows containing non-finite values (stat_bin).

ggplot(scores_all%>%filter(!score.il3d0.d4%in%-6),aes(x=score.il3d0.d4))+geom_histogram()
`stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
Warning: Removed 1172 rows containing non-finite values (stat_bin).

ggplot(scores_all%>%filter(!score.il3d2.d4%in%-6),aes(x=score.il3d2.d4))+geom_histogram()
`stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
Warning: Removed 1001 rows containing non-finite values (stat_bin).

ggplot(scores_all%>%filter(!score.il3d0.d2%in%-6),aes(x=score.il3d0.d2))+geom_histogram()
`stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
Warning: Removed 1175 rows containing non-finite values (stat_bin).

ggplot(il3D0_simple,aes(x=maf))+geom_density()+scale_x_continuous(trans = "log10")

ggplot(il3D2_simple,aes(x=maf))+geom_density()+scale_x_continuous(trans = "log10")

ggplot(imatD2_simple,aes(x=maf))+geom_density()+scale_x_continuous(trans = "log10")

ggplot(imatD4_simple,aes(x=maf))+geom_density()+scale_x_continuous(trans = "log10")

a=imatD0.D4%>%filter(protein_start%in%c(253,252,459,276))

Plotting specific resistant mutants

resmuts=scores_all%>%filter(resmuts%in%T)%>%mutate(species=paste(ref_aa,protein_start,alt_aa,sep = ""))

ggplot(resmuts%>%filter(!protein_start%in%317),aes(x=score.imatd0.d2,y=score.imatd2.d4,label=species))+geom_text()+geom_abline()
Warning: Removed 4 rows containing missing values (geom_text).

Version Author Date
c1aa64b haiderinam 2022-11-12
# ggplot(resmuts%>%filter(!protein_start%in%317),aes(x=netgr_obs.imatd0.d2,y=netgr_obs.imatd2.d4,label=species))+geom_text()+geom_abline()


ic50data_all_sum=read.csv("output/ic50data_all_confidence_intervals_raw_data.csv",row.names = 1)
resmuts_merged=merge(resmuts,ic50data_all_sum,by="species")


#Plotting Imatinib D0 vs D2
ggplot(resmuts_merged,aes(x=netgr_pred_model,y=score.imatd0.d2,label=species))+geom_text()
Warning: Removed 2 rows containing missing values (geom_text).

Version Author Date
c1aa64b haiderinam 2022-11-12
ggplot(resmuts_merged,aes(x=netgr_pred_model,y=netgr_obs.imatd0.d2,label=species))+geom_text()
Warning: Removed 2 rows containing missing values (geom_text).

Version Author Date
c1aa64b haiderinam 2022-11-12
#Plotting Imatinib D2 vs D4
ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=netgr_pred_model,y=score.imatd2.d4,label=species))+geom_text()
Warning: Removed 1 rows containing missing values (geom_text).

Version Author Date
c1aa64b haiderinam 2022-11-12
#Plotting Imatinib D0 vs D4
ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=netgr_pred_model,y=score.imatd0.d4,label=species))+geom_text()
Warning: Removed 2 rows containing missing values (geom_text).

#Plotting Imatinib D0 vs D2 Adjusted
ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=netgr_pred_model,y=score.imatd0.d2-score.il3d0.d2,label=species))+geom_text()
Warning: Removed 2 rows containing missing values (geom_text).

#Plotting Imatinib D2 vs D4 Adjusted
ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=netgr_pred_model,y=score.imatd2.d4-score.il3d2.d4,label=species))+geom_text()
Warning: Removed 1 rows containing missing values (geom_text).

ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=netgr_pred_model,y=-netgr_obs.imatd2.d4+netgr_obs.il3d2.d4+.055,label=species))+geom_text()+geom_abline()
Warning: Removed 1 rows containing missing values (geom_text).

#Plotting Imatinib D0 vs D4 Adjusted
ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=netgr_pred_model,y=score.imatd0.d4-score.il3d0.d4,label=species))+geom_text()
Warning: Removed 2 rows containing missing values (geom_text).

ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=netgr_pred_model,y=netgr_obs.imatd0.d4-netgr_obs.il3d0.d4,label=species))+geom_text()+geom_abline()
Warning: Removed 2 rows containing missing values (geom_text).

# Also plot IL3 D4 D2 scores vs iL3 D2 D0 scores
# Also update imatininb scores by considering without drug (fitness in the absence of iL3). Do these scores match up better with the IC50 predictions?
# Also, when looking at the distribution of enrichment scores, color the multiple nucleotide variants

Looking at how well the observed and predicted growth rates match up

ic50data_all_sum2=read.csv("output/ic50data_all_conc.csv",row.names = 1)
        ic50data_all_sum2=ic50data_all_sum2%>%filter(conc%in%.7)%>%rename(species=mutant)%>%dplyr::select(species,drug_effect)
        resmuts_merged=merge(resmuts,ic50data_all_sum2,by="species")
        #Looking at D2 D4
        ggplot(resmuts_merged%>%filter(!protein_start%in%317,!species%in%"V299L"),aes(x=.055-drug_effect,y=.055-(-netgr_obs.imatd2.d4+netgr_obs.il3d2.d4),label=species))+geom_text()+geom_abline()
Warning: Removed 1 rows containing missing values (geom_text).

        ggplot(resmuts_merged%>%filter(!protein_start%in%317,!species%in%"V299L"),aes(x=.055-drug_effect,y=netgr_obs.imatd2.d4,label=species))+geom_text()+geom_abline()
Warning: Removed 1 rows containing missing values (geom_text).

        # ggplot(resmuts_merged%>%filter(!protein_start%in%317,!species%in%"V299L"),aes(x=netgr_obs.il3d0.d2-drug_effect,y=netgr_obs.imatd0.d2,label=species))+geom_text()+geom_abline()
        
        #Looking at D0 D4
        ggplot(resmuts_merged%>%filter(!protein_start%in%317,!species%in%"V299L"),aes(x=.055-drug_effect,y=.055-(-netgr_obs.imatd0.d4+netgr_obs.il3d0.d4),label=species))+geom_text()+geom_abline()
Warning: Removed 2 rows containing missing values (geom_text).

        ggplot(resmuts_merged%>%filter(!protein_start%in%317,!species%in%"V299L"),aes(x=.055-drug_effect,y=netgr_obs.imatd0.d4,label=species))+geom_text()+geom_abline()
Warning: Removed 2 rows containing missing values (geom_text).

        # resmuts_merged[netgr_obs.imat]=resmuts_merged%>%mutate(drugfit=)
        ggplot(resmuts_merged%>%filter(!protein_start%in%317,!species%in%"V299L"),aes(x=netgr_obs.il3d0.d4-drug_effect,y=netgr_obs.imatd0.d4,label=species))+geom_text()+geom_abline()
Warning: Removed 2 rows containing missing values (geom_text).

        # ggplot(resmuts_merged%>%filter(!protein_start%in%317),aes(x=.025-drug_effect,y=netgr_obs.imatd2.d4,label=species))+geom_text()+geom_abline()
        
        ggplot(resmuts,aes(x=species,y=netgr_obs.il3d0.d2))+geom_col()
Warning: Removed 3 rows containing missing values (position_stack).

        ggplot(resmuts,aes(x=species,y=netgr_obs.il3d2.d4))+geom_col()

        ggplot(resmuts,aes(x=species,y=netgr_obs.imatd0.d2))+geom_col()
Warning: Removed 3 rows containing missing values (position_stack).

        ggplot(resmuts%>%filter(!(protein_start%in%252&alt%in%"T")),aes(x=species,y=netgr_obs.imatd2.d4))+geom_col()
Warning: Removed 5 rows containing missing values (position_stack).

        ggplot(resmuts,aes(x=species,y=score.il3d0.d2))+geom_col()
Warning: Removed 3 rows containing missing values (position_stack).

        ggplot(resmuts,aes(x=species,y=score.il3d2.d4))+geom_col()

        ggplot(resmuts,aes(x=species,y=score.imatd0.d2))+geom_col()
Warning: Removed 3 rows containing missing values (position_stack).

        ggplot(resmuts%>%filter(!protein_start%in%317),aes(x=species,y=score.imatd2.d4))+geom_col()
Warning: Removed 3 rows containing missing values (position_stack).

a=resmuts_merged%>%filter(!netgr_obs.imatd0.d4%in%c(NA,"-Inf"),!netgr_obs.il3d0.d4%in%c(NA,"-Inf"))
a=a%>%mutate(netgr_pred_mean=.055-drug_effect,netgr_obs=.055-(netgr_obs.il3d0.d4-netgr_obs.imatd0.d4))
a=a%>%mutate(netgr_pred_mean=.055-drug_effect,netgr_obs=netgr_obs.imatd0.d4)
a=a%>%mutate(netgr_pred_mean=netgr_obs.il3d0.d4-drug_effect,netgr_obs=netgr_obs.imatd0.d4)
cor(a$netgr_pred_mean,a$netgr_obs)
[1] 0.7079809

How many unique mutants are there per residue in the IL3D0 library

calls_sum=il3D0%>%filter(consequence_terms%in%"missense_variant")%>%group_by(protein_start)%>%summarize(unique_mutants=n(),count=sum(ct))

calls_sum=calls_sum%>%mutate(region=case_when(protein_start<250&protein_start>=242~1,
                                              protein_start<258&protein_start>=250~2,
                                              protein_start<266&protein_start>=258~3,
                                              protein_start<274&protein_start>=266~4,
                                              protein_start<282&protein_start>=274~5,
                                              protein_start<290&protein_start>=282~6,
                                              protein_start<298&protein_start>=290~7,
                                              protein_start<306&protein_start>=298~8,
                                              protein_start<314&protein_start>=306~9,
                                              protein_start<322&protein_start>=314~10,
                                              protein_start<330&protein_start>=322~11,
                                              protein_start<338&protein_start>=330~12,
                                              protein_start<346&protein_start>=338~13,
                                              protein_start<354&protein_start>=346~14,
                                              protein_start<362&protein_start>=354~15,
                                              protein_start<370&protein_start>=362~16,
                                              protein_start<378&protein_start>=370~17,
                                              protein_start<386&protein_start>=378~18,
                                              protein_start<394&protein_start>=386~19,
                                              protein_start<402&protein_start>=394~20,
                                              protein_start<410&protein_start>=402~21,
                                              protein_start<418&protein_start>=410~22,
                                              protein_start<426&protein_start>=418~23,
                                              protein_start<434&protein_start>=426~24,
                                              protein_start<442&protein_start>=434~25,
                                              protein_start<450&protein_start>=442~26,
                                              protein_start<458&protein_start>=450~27,
                                              protein_start<466&protein_start>=458~28,
                                              protein_start<474&protein_start>=466~29,
                                              protein_start<482&protein_start>=474~30,
                                              protein_start<490&protein_start>=482~31,
                                              protein_start<498&protein_start>=490~32,
                                              T~0))
getPalette = colorRampPalette(brewer.pal(33, "Set2"))
Warning in brewer.pal(33, "Set2"): n too large, allowed maximum for palette Set2 is 8
Returning the palette you asked for with that many colors
plotly=ggplot(calls_sum%>%filter(protein_start>=242,protein_start<=494),aes(x=protein_start,y=unique_mutants))+geom_col(color="black",aes(fill=factor(region)))+cleanup+scale_fill_manual(values=getPalette(33))
ggplotly(plotly)
getPalette = colorRampPalette(brewer.pal(33, "Set2"))
Warning in brewer.pal(33, "Set2"): n too large, allowed maximum for palette Set2 is 8
Returning the palette you asked for with that many colors
plotly=ggplot(calls_sum%>%filter(protein_start>=242,protein_start<=494),aes(x=protein_start,y=count))+geom_col(color="black",aes(fill=factor(region)))+cleanup+scale_fill_manual(values=getPalette(33))
ggplotly(plotly)
il3D0=il3D0%>%mutate(region=case_when(protein_start<250&protein_start>=242~1,
                                              protein_start<258&protein_start>=250~2,
                                              protein_start<266&protein_start>=258~3,
                                              protein_start<274&protein_start>=266~4,
                                              protein_start<282&protein_start>=274~5,
                                              protein_start<290&protein_start>=282~6,
                                              protein_start<298&protein_start>=290~7,
                                              protein_start<306&protein_start>=298~8,
                                              protein_start<314&protein_start>=306~9,
                                              protein_start<322&protein_start>=314~10,
                                              protein_start<330&protein_start>=322~11,
                                              protein_start<338&protein_start>=330~12,
                                              protein_start<346&protein_start>=338~13,
                                              protein_start<354&protein_start>=346~14,
                                              protein_start<362&protein_start>=354~15,
                                              protein_start<370&protein_start>=362~16,
                                              protein_start<378&protein_start>=370~17,
                                              protein_start<386&protein_start>=378~18,
                                              protein_start<394&protein_start>=386~19,
                                              protein_start<402&protein_start>=394~20,
                                              protein_start<410&protein_start>=402~21,
                                              protein_start<418&protein_start>=410~22,
                                              protein_start<426&protein_start>=418~23,
                                              protein_start<434&protein_start>=426~24,
                                              protein_start<442&protein_start>=434~25,
                                              protein_start<450&protein_start>=442~26,
                                              protein_start<458&protein_start>=450~27,
                                              protein_start<466&protein_start>=458~28,
                                              protein_start<474&protein_start>=466~29,
                                              protein_start<482&protein_start>=474~30,
                                              protein_start<490&protein_start>=482~31,
                                              protein_start<498&protein_start>=490~32,
                                              T~0))

getPalette = colorRampPalette(brewer.pal(33, "Set2"))
Warning in brewer.pal(33, "Set2"): n too large, allowed maximum for palette Set2 is 8
Returning the palette you asked for with that many colors
plotly=ggplot(il3D0%>%filter(protein_start>=242,protein_start<=494),aes(x=protein_start,y=ct))+geom_col(color="black",aes(fill=factor(region)))+cleanup+scale_fill_manual(values=getPalette(33))
ggplotly(plotly)

#Next: plot iL3 D2 D4 scores #Correlate Il3 D2 D4 scores with il3 D0 D2 scores

Are any of the enriched mutants in the cosmic somatic database?

# rm(list=ls())
cosmic_data=read.table("data/Cosmic_ABL/ABL_Cosmic_Gene_mutations.tsv",sep="\t",header = T,stringsAsFactors = )
cosmic_data=cosmic_data%>%mutate(AA.Mutation=gsub("p.","",AA.Mutation))
cosmic_data=cosmic_data[!grepl("ins|del",cosmic_data$CDS.Mutation),]
cosmic_data=cosmic_data[grepl("Missense",cosmic_data$Type),]
cosmic_data=cosmic_data%>%filter(!Type%in%"Substitution - coding silent")
cosmic_data=cosmic_data%>%filter(Position<=500,Position>=64,Count>=2)
# write.csv(cosmic_data,"cosmic_abl.csv")
cosmic_simple=cosmic_data%>%dplyr::select(subs_name=AA.Mutation,cosmic_count=Count)
cosmic_simple=cosmic_simple%>%group_by(subs_name)%>%summarize(cosmic_count=sum(cosmic_count))
cosmic_simple$cosmic_present=T
source("code/merge_samples.R")
sample10=read.csv(file = "data/Consensus_Data/Novogene_lane14/sample10_combined/sscs/variant_caller_outputs/variants_unique_ann.csv",header=T,stringsAsFactors = F)

sample10=sample10%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
sample10=sample10%>%mutate(maf=ct/depth)
sample10_simple=sample10%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf)
sample10=il3D0
sample12=read.csv(file = "data/Consensus_Data/Novogene_lane14/sample12/sscs/variant_caller_outputs/variants_unique_ann.csv",header=T,stringsAsFactors = F)

sample12=sample12%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
sample12=sample12%>%mutate(maf=ct/depth)
sample12=imatD4
sample12_simple=sample12%>%dplyr::select(alt_start_pos,protein_start,ref,alt,ref_aa,alt_aa,consequence_terms,ct,depth,maf)

samples_10.12=merge(sample10_simple%>%filter(consequence_terms%in%"missense_variant"),sample12_simple%>%filter(consequence_terms%in%"missense_variant"),by=c("ref_aa","protein_start","alt_aa","ref","alt","alt_start_pos","consequence_terms"))

samples_10.12=samples_10.12%>%mutate(score=log2(maf.y/maf.x),score2=log2(ct.y/ct.x))
samples_10.12_simple=samples_10.12%>%dplyr::select(ref_aa,protein_start,alt_aa,consequence_terms,ct.x,score)

ggplot(samples_10.12,aes(x=score))+geom_density()

# ggplot(samples_14.16,aes(x=score))+geom_histogram(bins=100)

samples_10.12=samples_10.12%>%mutate(resmuts=case_when(protein_start%in%253&alt_aa%in%"H"~T,
                                                         protein_start%in%255&alt_aa%in%"V"~T,
                                                         protein_start%in%486&alt_aa%in%"S"~T,
                                                         protein_start%in%396&alt_aa%in%"P"~T,
                                                         protein_start%in%255&alt_aa%in%"K"~T,
                                                         protein_start%in%315&alt_aa%in%"I"~T,
                                                         protein_start%in%252&alt_aa%in%"H"~T,
                                                         protein_start%in%253&alt_aa%in%"F"~T,
                                                         protein_start%in%250&alt_aa%in%"E"~T,
                                                         protein_start%in%359&alt_aa%in%"C"~T,
                                                         protein_start%in%351&alt_aa%in%"T"~T,
                                                         protein_start%in%355&alt_aa%in%"G"~T,
                                                         protein_start%in%317&alt_aa%in%"L"~T,
                                                         protein_start%in%359&alt_aa%in%"I"~T,
                                                         protein_start%in%355&alt_aa%in%"A"~T,
                                                         protein_start%in%459&alt_aa%in%"K"~T,
                                                         protein_start%in%276&alt_aa%in%"G"~T,
                                                         protein_start%in%299&alt_aa%in%"L"~T,
                                                         
                                                         T~F))

samples_10.12=samples_10.12%>%mutate(resresids=case_when(protein_start%in%253~T,
                                                         protein_start%in%255~T,
                                                         protein_start%in%486~T,
                                                         protein_start%in%396~T,
                                                         protein_start%in%255~T,
                                                         protein_start%in%315~T,
                                                         protein_start%in%252~T,
                                                         protein_start%in%253~T,
                                                         protein_start%in%250~T,
                                                         protein_start%in%359~T,
                                                         protein_start%in%351~T,
                                                         protein_start%in%355~T,
                                                         protein_start%in%317~T,
                                                         protein_start%in%359~T,
                                                         protein_start%in%355~T,
                                                         protein_start%in%459~T,
                                                         protein_start%in%276~T,
                                                         protein_start%in%299~T,
                                                         
                                                         T~F))

highscore=samples_10.12%>%filter(!ct.x%in%1,protein_start>=242,protein_start<=494)
highscore=highscore%>%mutate(subs_name=paste(ref_aa,protein_start,alt_aa,sep = ""))
ggplot(highscore,aes(x=reorder(subs_name,-score),y=score,fill=resmuts))+geom_col()+theme(axis.text.x=element_text(angle=90, hjust=1))+scale_y_continuous(name="Enrithcment Score")+scale_x_discrete(name="Mutant")+guides(fill = guide_legend(title = "Clinically\n Observed \n Resmut"))+scale_fill_manual(values=c("gray90","red"))

highscore2=highscore%>%group_by(alt_aa,protein_start,subs_name,resmuts,resresids)%>%summarize(score=mean(score))
`summarise()` has grouped output by 'alt_aa', 'protein_start', 'subs_name', 'resmuts'. You can override using the `.groups` argument.
ggplot(highscore2,aes(x=reorder(subs_name,-score),y=score,fill=resmuts))+geom_col()+theme(axis.text.x=element_blank(),axis.ticks.x=element_blank())+scale_y_continuous(name="Enrithcment Score")+scale_x_discrete(name="Mutant")+guides(fill = guide_legend(title = "Clinically\n Observed \n Resistant Mutant"))+scale_fill_manual(values=c("gray90","red"))

# ggsave("BCRABL_Imatinib_Scores_Resmuts.pdf",height=4,width=8,units="in",useDingbats=F)

ggplot(highscore2,aes(x=reorder(subs_name,-score),y=score,fill=resresids))+geom_col()+theme(axis.text.x=element_blank(),axis.ticks.x=element_blank())+scale_y_continuous(name="Enrithcment Score")+scale_x_discrete(name="Mutant")+guides(fill = guide_legend(title = "Clinically\n Observed \n Resistant Residue"))+scale_fill_manual(values=c("gray90","red"))

# ggsave("BCRABL_Imatinib_Scores_Resresids.pdf",height=4,width=8,units="in",useDingbats=F)

###Merging cosmic data and highscore
# highscore$cosmic_present=F
highscore_cosmic=merge(highscore,cosmic_simple,by="subs_name",all.x = T)
highscore_cosmic[highscore_cosmic$cosmic_present%in%NA,"cosmic_present"]=F
highscore_cosmic[highscore_cosmic$cosmic_count%in%NA,"cosmic_count"]=0

plotly=ggplot(highscore_cosmic,aes(x=reorder(subs_name,-score),y=score,fill=cosmic_present))+geom_col()+theme(axis.text.x=element_text(angle=90, hjust=1))+scale_y_continuous(name="Enrichment Score")+scale_x_discrete(name="Mutant")+guides(fill = guide_legend(title = "Cosmic\n Observed"))
ggplotly(plotly)
a=cosmic_data%>%filter(AA.Mutation%in%"L248V")
a=highscore%>%filter(subs_name%in%"M388L")


plotly=ggplot(highscore_cosmic%>%filter(cosmic_present%in%T),aes(x=reorder(subs_name,-score),y=score,fill=cosmic_count))+geom_col()+theme_bw()
ggplotly(plotly)
# a=highscore_cosmic%>%filter(cosmic_present%in%T)
# a=highscore2%>%filter(resmuts%in%T)

Looking at the evenness of the K562 Library

k562=read.csv("data/Consensus_Data/Novogene_lane14/sample9/sscs/variant_caller_outputs/variants_unique_ann.csv")
k562$sample="k562"

k562=k562%>%
  rowwise()%>%
  mutate(ref_aa=strsplit(amino_acids,"/")[[1]][1],
         alt_aa=strsplit(amino_acids,"/")[[1]][2])
k562=k562%>%mutate(maf=ct/depth)

k562=k562%>%mutate(region=case_when(protein_start<250&protein_start>=242~1,
                                              protein_start<258&protein_start>=250~2,
                                              protein_start<266&protein_start>=258~3,
                                              protein_start<274&protein_start>=266~4,
                                              protein_start<282&protein_start>=274~5,
                                              protein_start<290&protein_start>=282~6,
                                              protein_start<298&protein_start>=290~7,
                                              protein_start<306&protein_start>=298~8,
                                              protein_start<314&protein_start>=306~9,
                                              protein_start<322&protein_start>=314~10,
                                              protein_start<330&protein_start>=322~11,
                                              protein_start<338&protein_start>=330~12,
                                              protein_start<346&protein_start>=338~13,
                                              protein_start<354&protein_start>=346~14,
                                              protein_start<362&protein_start>=354~15,
                                              protein_start<370&protein_start>=362~16,
                                              protein_start<378&protein_start>=370~17,
                                              protein_start<386&protein_start>=378~18,
                                              protein_start<394&protein_start>=386~19,
                                              protein_start<402&protein_start>=394~20,
                                              protein_start<410&protein_start>=402~21,
                                              protein_start<418&protein_start>=410~22,
                                              protein_start<426&protein_start>=418~23,
                                              protein_start<434&protein_start>=426~24,
                                              protein_start<442&protein_start>=434~25,
                                              protein_start<450&protein_start>=442~26,
                                              protein_start<458&protein_start>=450~27,
                                              protein_start<466&protein_start>=458~28,
                                              protein_start<474&protein_start>=466~29,
                                              protein_start<482&protein_start>=474~30,
                                              protein_start<490&protein_start>=482~31,
                                              protein_start<498&protein_start>=490~32,
                                              T~0))
library(RColorBrewer)
getPalette = colorRampPalette(brewer.pal(33, "Set2"))
Warning in brewer.pal(33, "Set2"): n too large, allowed maximum for palette Set2 is 8
Returning the palette you asked for with that many colors
k562=k562%>%rowwise()%>%mutate(ID=paste(protein_start,amino_acids,sep=""))
plotly=ggplot(k562%>%filter(consequence_terms%in%"missense_variant",protein_start>=242,protein_start<=494),aes(x=protein_start,y=ct))+geom_col(color="black",aes(fill=factor(region)))+scale_fill_manual(values=getPalette(33))
ggplotly(plotly)
library("pals")
Warning: package 'pals' was built under R version 4.0.2
ggplot(k562%>%filter(nchar(alt_aa)%in%1,!alt_aa%in%NA,consequence_terms%in%"missense_variant",protein_start>=242,protein_start<=494),aes(x=protein_start,y=ct,fill=factor(alt_aa)))+
  geom_bar(stat="identity",position="fill")+
  scale_x_continuous(expand = c(0,0),name="Position Along ABL Kinase",breaks=c(242,300,350,400,450,490))+
  scale_y_continuous(expand = c(0,0),name="%Variant AA")+theme(plot.title = element_text(hjust = 0.5))+
  scale_fill_manual(values=as.vector(stepped(21)))+
  cleanup+
  theme(legend.title = element_blank(),
  legend.position = "right")+
  guides(fill=guide_legend(ncol=2))

ggsave("k562_bcrabl_background.pdf",width=12,height=4,units="in",useDingbats=F)

# axis.text.x = element_blank(),
        # axis.ticks.x = element_blank(),

How many unique mutants are there per residue in the K562 library

calls_sum=k562%>%filter(consequence_terms%in%"missense_variant")%>%group_by(protein_start)%>%summarize(unique_mutants=n(),count=sum(ct))

calls_sum=calls_sum%>%mutate(region=case_when(protein_start<250&protein_start>=242~1,
                                              protein_start<258&protein_start>=250~2,
                                              protein_start<266&protein_start>=258~3,
                                              protein_start<274&protein_start>=266~4,
                                              protein_start<282&protein_start>=274~5,
                                              protein_start<290&protein_start>=282~6,
                                              protein_start<298&protein_start>=290~7,
                                              protein_start<306&protein_start>=298~8,
                                              protein_start<314&protein_start>=306~9,
                                              protein_start<322&protein_start>=314~10,
                                              protein_start<330&protein_start>=322~11,
                                              protein_start<338&protein_start>=330~12,
                                              protein_start<346&protein_start>=338~13,
                                              protein_start<354&protein_start>=346~14,
                                              protein_start<362&protein_start>=354~15,
                                              protein_start<370&protein_start>=362~16,
                                              protein_start<378&protein_start>=370~17,
                                              protein_start<386&protein_start>=378~18,
                                              protein_start<394&protein_start>=386~19,
                                              protein_start<402&protein_start>=394~20,
                                              protein_start<410&protein_start>=402~21,
                                              protein_start<418&protein_start>=410~22,
                                              protein_start<426&protein_start>=418~23,
                                              protein_start<434&protein_start>=426~24,
                                              protein_start<442&protein_start>=434~25,
                                              protein_start<450&protein_start>=442~26,
                                              protein_start<458&protein_start>=450~27,
                                              protein_start<466&protein_start>=458~28,
                                              protein_start<474&protein_start>=466~29,
                                              protein_start<482&protein_start>=474~30,
                                              protein_start<490&protein_start>=482~31,
                                              protein_start<498&protein_start>=490~32,
                                              T~0))
getPalette = colorRampPalette(brewer.pal(33, "Set2"))
Warning in brewer.pal(33, "Set2"): n too large, allowed maximum for palette Set2 is 8
Returning the palette you asked for with that many colors
plotly=ggplot(calls_sum%>%filter(protein_start>=242,protein_start<=494),aes(x=protein_start,y=unique_mutants))+geom_col(color="black",aes(fill=factor(region)))+cleanup+scale_fill_manual(values=getPalette(33))
ggplotly(plotly)
a=imatD0.D4.merge.filtered%>%dplyr::select(-ct.x,-depth.x,-"totalmutant.x",-"totalcells.x",-ct.y,-depth.y,-"totalmutant.y",-"totalcells.y",-wt)%>%filter(!ref%in%NA)

a=il3D0.D4.merge.filtered%>%dplyr::select(-ct.x,-depth.x,-"totalmutant.x",-"totalcells.x",-ct.y,-depth.y,-"totalmutant.y",-"totalcells.y",-wt)%>%filter(!ref%in%NA)
write.csv(a,"bcrabl_il3d0d4_scores.csv")

sessionInfo()
R version 4.0.0 (2020-04-24)
Platform: x86_64-apple-darwin17.0 (64-bit)
Running under: macOS  10.16

Matrix products: default
BLAS:   /Library/Frameworks/R.framework/Versions/4.0/Resources/lib/libRblas.dylib
LAPACK: /Library/Frameworks/R.framework/Versions/4.0/Resources/lib/libRlapack.dylib

locale:
[1] en_US.UTF-8/en_US.UTF-8/en_US.UTF-8/C/en_US.UTF-8/en_US.UTF-8

attached base packages:
[1] parallel  stats     graphics  grDevices utils     datasets  methods  
[8] base     

other attached packages:
 [1] pals_1.7           RColorBrewer_1.1-2 doParallel_1.0.15  iterators_1.0.12  
 [5] foreach_1.5.0      tictoc_1.0         plotly_4.9.2.1     ggplot2_3.3.3     
 [9] dplyr_1.0.6        stringr_1.4.0     

loaded via a namespace (and not attached):
 [1] tidyselect_1.1.0  xfun_0.31         bslib_0.3.1       purrr_0.3.4      
 [5] colorspace_1.4-1  vctrs_0.3.8       generics_0.0.2    htmltools_0.5.2  
 [9] viridisLite_0.3.0 yaml_2.2.1        utf8_1.1.4        rlang_0.4.11     
[13] jquerylib_0.1.4   later_1.0.0       pillar_1.6.1      glue_1.4.1       
[17] withr_2.4.2       DBI_1.1.0         lifecycle_1.0.0   munsell_0.5.0    
[21] gtable_0.3.0      workflowr_1.6.2   mapproj_1.2.8     htmlwidgets_1.5.1
[25] codetools_0.2-16  evaluate_0.14     labeling_0.3      knitr_1.28       
[29] fastmap_1.1.0     crosstalk_1.1.0.1 httpuv_1.5.2      fansi_0.4.1      
[33] Rcpp_1.0.4.6      promises_1.1.0    backports_1.1.7   scales_1.1.1     
[37] jsonlite_1.7.2    farver_2.0.3      fs_1.4.1          digest_0.6.25    
[41] stringi_1.7.5     rprojroot_1.3-2   grid_4.0.0        tools_4.0.0      
[45] maps_3.4.0        magrittr_2.0.1    sass_0.4.1        lazyeval_0.2.2   
[49] tibble_3.1.2      dichromat_2.0-0   crayon_1.4.1      whisker_0.4      
[53] tidyr_1.1.3       pkgconfig_2.0.3   ellipsis_0.3.2    data.table_1.12.8
[57] assertthat_0.2.1  rmarkdown_2.14    httr_1.4.2        R6_2.4.1         
[61] git2r_0.27.1      compiler_4.0.0