library(ithi.utils)
load_base_libs()

## grid graphics
library(grid)
library(gridExtra)
library(gridGraphics)
library(extrafont)
library(gridBase)
library(ape)
library(phylobase)
library(phytools)
library(OutbreakTools)
library(colorspace)
library(RColorBrewer)
library(igraph)

library(ithi.meta)
library(ithi.xcr)
library(ithi.clones)
library(ithi.expr)
library(ithi.figures)
library(ithi.seq)

Colour palettes

pal_patient <- select_palette("patient")

Parameters

db_path <- snakemake@params$db

ihc_table_path <- snakemake@input$ihc_table
xcr_table_path <- snakemake@input$xcr_table
nanostring_data_path <- snakemake@input$nanostring_data
nanostring_annotations_path <- snakemake@input$nanostring_annotations
master_variant_file <- snakemake@input$master_variant_file
trb_annotated_path <- snakemake@input$trb_annotated

# igpartition_outdir <- snakemake@input$igpartition_outdir
bcrphylo_figure <- snakemake@input$bcrphylo_png
mutsig_figure <- snakemake@input$mutsig_png
immune_cancer_figure <- snakemake@input$immune_cancer_png
immune_overview_figure <- snakemake@input$immune_overview_png
merged_figures_path <- snakemake@input$merged_figures

Metadata

db <- src_sqlite(db_path, create = FALSE)

samples <- collect(tbl(db, "samples"))

Data

ihc_table <- fread(ihc_table_path)
xcr_table <- read_clonotypes(xcr_table_path, duplicates = FALSE, db_path)

Read 19.7% of 304822 rows
Read 45.9% of 304822 rows
Read 88.6% of 304822 rows
Read 304822 rows and 18 (of 18) columns from 0.070 GB file in 00:00:06
exprs <- fread(nanostring_data_path)
labels <- fread(nanostring_annotations_path)
trb_annotated <- fread(trb_annotated_path)
master_variant_table <- read_variant_file(master_variant_file, db_path)

Figures

Will be updated as I work on more of these. Note: Fonts will always be ugly on here because genesis doesn’t have ANY truetype fonts :(

Figure 1

Landscape figure showing sample statistics. Base R graphics are very fast!

condensed_ids <- unique(subset(samples, project_code == "ITH" & !source %in% 
    c("blood", "normal"))$condensed_id)
condensed_ids <- as.character(sort(factor_id(condensed_ids, type = "condensed_id", 
    db_path)))

plot_landscape_figure(db_path, condensed_ids = condensed_ids, ihc_table = ihc_table, 
    xcr_table = xcr_table, variant_table = master_variant_table, separate_opt = "zebra")
WGS 
IHC 
TCR/BCR-seq 

plot_landscape_figure(db_path, condensed_ids = condensed_ids, ihc_table = ihc_table, 
    xcr_table = xcr_table, variant_table = master_variant_table, separate_opt = "line")
WGS 
IHC 
TCR/BCR-seq 

Plotted w/ zebra and line separators in case you like one better. Also added patient labels.

Figure 2

Immune overview figure. If you have any suggestions on what to include/remove please let me know!

Top to bottom:

  • Patient colour label legend
  • TCR (left) and BCR (right) clonotype sharing illustrated by Circos plots
  • Mean expression of certain pathways as indicated by Nanostring annotations
  • Intrapatient similarity in TCR repertoire
  • High correlation between TCR repertoire similarity and CD8+ TIL density (left), lower correlation with CD4+ TIL density (middle) and CD8+’s are more broadly distributed across tumour sites than CD4+’s (right)

Figure 3

B-cell phylogenetics.

Subfigures:

  • Evidence of either B-cell exchange or parallel affinity maturation across tumour sites
  • Evidence of lineage divergence by tumour site
  • Evidence of phylogenetic signal in readcounts (sequence-dependent expansion)
  • Correlations between GSI/phylosignal and CD20+ TIL densities
# plot_bcrphylo_figure(resultdir = igpartition_outdir, ihc_table, parts =
# list(A=list(patient=2,clust=7), B=list(patient=18, clust=10),
# C=list(patient=9, clust=14)))

Figure 4

Mutational signatures and immune activity.

Subfigures:

  • SNV signatures
  • SV signatures
  • Clustering by mutation signature proportions
  • Expression-derived immune covariates overlaid on mutation signature-based clusters
  • TCGA survival analysis

Figure 5

Immune-cancer interaction.

Figure 6

---
title: "Figure gallery"
output: 
  html_notebook:
    toc: true
    toc_depth: 5
    toc_float: true
params:
  rmd: "figures.Rmd"
---
                        ```{r, echo=FALSE, message=FALSE, warning=FALSE}

######## Snakemake header ########
library(methods)
Snakemake <- setClass(
    "Snakemake",
    slots = c(
        input = "list",
        output = "list",
        params = "list",
        wildcards = "list",
        threads = "numeric",
        log = "list",
        resources = "list",
        config = "list",
        rule = "character"
    )
)
snakemake <- Snakemake(
    input = list('/shahlab/amcpherson/projects/ith3/ith3/notebooks/bespoke/ith_snvs.tsv', '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/immune_cancer_figure.png', '/shahlab/alzhang/projects/ITH_Immune/paper/results/tables/run2/trb_table_annotated.tsv', '/shahlab/alzhang/projects/ITH_Immune/results/nanostring_results/ith_full/qc/limma_quantile/normalized_expression_voa_labels_filtered.tsv', '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/immune_overview_figure.png', 'Rmd/figures.Rmd', '/shahlab/alzhang/projects/ITH_Immune/paper/results/tables/run2/ihc_table.tsv', '/shahlab/alzhang/projects/ITH_Immune/paper/analysis/Rmd/_site.yml', '/shahlab/alzhang/projects/ITH_Immune/data/expression/nanostring/pancancer_annotations.tsv', '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/mutsig_figure.png', '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/figures_merged.pdf', '/shahlab/alzhang/projects/ITH_Immune/paper/results/tables/run2/xcr_table.tsv', '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/bcrphylo_figure.png', "master_variant_file" = '/shahlab/amcpherson/projects/ith3/ith3/notebooks/bespoke/ith_snvs.tsv', "immune_cancer_png" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/immune_cancer_figure.png', "trb_annotated" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/tables/run2/trb_table_annotated.tsv', "nanostring_data" = '/shahlab/alzhang/projects/ITH_Immune/results/nanostring_results/ith_full/qc/limma_quantile/normalized_expression_voa_labels_filtered.tsv', "immune_overview_png" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/immune_overview_figure.png', "notebook" = 'Rmd/figures.Rmd', "ihc_table" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/tables/run2/ihc_table.tsv', "site_file" = '/shahlab/alzhang/projects/ITH_Immune/paper/analysis/Rmd/_site.yml', "nanostring_annotations" = '/shahlab/alzhang/projects/ITH_Immune/data/expression/nanostring/pancancer_annotations.tsv', "mutsig_png" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/mutsig_figure.png', "merged_figures" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/figures_merged.pdf', "xcr_table" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/tables/run2/xcr_table.tsv', "bcrphylo_png" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/web/resources/bcrphylo_figure.png'),
    output = list('/shahlab/alzhang/projects/ITH_Immune/paper/results/web/figures.nb.html'),
    params = list('ithi-analysis-figure-gallery', '/shahlab/alzhang/projects/ITH_Immune/metadata/db/immune_project.sqlite3', "name" = 'ithi-analysis-figure-gallery', "db" = '/shahlab/alzhang/projects/ITH_Immune/metadata/db/immune_project.sqlite3'),
    wildcards = list(),
    threads = 1,
    log = list('/shahlab/alzhang/clusttmp/paperanalysis2/figure_gallery.log'),
    resources = list(),
    config = list("tcga_ov_annotations" = '/shahlab/alzhang/data/TCGA/tcga_ov_annotation_sup13.txt', "j_dictionary" = '/shahlab/alzhang/projects/ITH_Immune/subprojects/immtyper/metadata/imgt/Homo_sapiens_TRBJ.fasta', "sad_notebook" = 'Rmd/species_abundance_distributions.Rmd', "nanostring_signature_notebook" = 'Rmd/nanostring_signatures.Rmd', "ith_stat_types" = c('entropy', 'postprocessed_divergence', 'combined_ith_normalized', 'proportion_subclonal'), "ith_statistics_notebook" = 'Rmd/ith_statistics.Rmd', "icgc_specimen_file" = '/shahlab/alzhang/data/ICGC/specimen.tsv', "clone_prevalence_file" = '/shahlab/alzhang/projects/ITH_Immune/data/ith/complete/clone_data.tsv', "mmctm_patient_ancestral_descendant_result_dir" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-patient-ancestry/output', "PNG_QUALITY" = 300, "xcrmapscape_files" = c('/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/1.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/2.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/3.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/4.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/7.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/9.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/10.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/11.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/12.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/13.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/14.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/15.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/16.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/xcrmapscape/17.svg'), "smooth_type" = 'glm', "bcr_clonotypes" = '/shahlab/alzhang/pipeline_outputs/ith_immune/mixcr/mixcr_runs/ith_1_2_3/mixcr5/clonotypes/IGH_clonotypes_filtered.txt', "clonal_figure_template" = '/shahlab/alzhang/projects/ITH_Immune/paper/analysis/templates/clonal_figure_4by4.svg', "master_breakpoint_file" = '/shahlab/amcpherson/projects/ith3/ith3/notebooks/bespoke/ith_breakpoints.tsv', "mmctm_sample_sigplot" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-sample/plots/ith-by-sample_snv-sv_sigs_multipanel.pdf', "igpartition_outdir" = '/shahlab/alzhang/pipeline_outputs/ith_immune/igpartition/run22', "default_sampler" = 'HMC', "mvclust_nclust" = 3, "ihc_xcr_tiltypes" = c('E_CD8_density', 'E_CD4_density', 'E_CD20_density', 'E_Plasma_density', 'S_CD8_density', 'S_CD4_density', 'S_CD20_density', 'S_Plasma_density', 'T_CD8_density', 'T_CD4_density', 'T_CD20_density', 'T_Plasma_density'), "mmctm_ancestral_descendant_result_dir" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-ancestry-sample/output', "bcrmapscape_files" = c('/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/1.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/2.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/3.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/4.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/7.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/9.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/10.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/11.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/12.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/13.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/14.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/15.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/16.svg', '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2/bcrmapscape/17.svg'), "nanostring_annotations" = '/shahlab/alzhang/projects/ITH_Immune/data/expression/nanostring/pancancer_annotations.tsv', "clone_tree_file" = '/shahlab/alzhang/projects/ITH_Immune/data/ith/complete/tree_data.tsv', "figure_gallery_notebook" = 'Rmd/figures.Rmd', "bcrphylo_correlations_notebook" = 'Rmd/bcr_phylo_correlations.Rmd', "xcrmapscape_bcr_patient_order" = c(9, 4, 11, 14, 15, 12, 1, 10, 2, 3, 16, 17, 13, 7), "immtyper_models" = '/shahlab/alzhang/projects/ITH_Immune/results/immtyper_results/klarenbeek/aa_vj/gradboost', "neoantigen_editing_notebook" = 'Rmd/immunoediting.Rmd', "tcr_clonotypes" = '/shahlab/alzhang/pipeline_outputs/ith_immune/mixcr/mixcr_runs/ith_1_2_3/mixcr5/clonotypes/TRB_clonotypes_filtered.txt', "intermediate_dir" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/intermediates/run2', "ith_til_notebook" = 'Rmd/ith_til_densities.Rmd', "ihc_xcr_stats_notebook" = 'Rmd/ihc_xcr_stats.Rmd', "multiviewclustering_notebook" = 'Rmd/multiviewclustering.Rmd', "molsubtype_notebook" = 'Rmd/molecular_subtypes.Rmd', "example_msa_plot" = '/shahlab/alzhang/pipeline_outputs/ith_immune/igpartition/run13/old/alignment_plots/msa/ith2_2/clust9/indel_reversed.html', "immtyper_lengths" = '11 12 13 14 15 16 17 18', "mapscape_notebook" = 'Rmd/mapscape.Rmd', "bcrphylo_examples_notebook" = 'Rmd/bcr_phylo_examples.Rmd', "clonal_samplers" = c('HMC', 'NUTS'), "ith_stats_file" = '/shahlab/alzhang/projects/ITH_Immune/data/ith/complete/clonal_measures.tsv', "mutsig_tiltypes" = c('E_CD8_density', 'E_CD4_density', 'E_CD20_density', 'E_Plasma_density', 'S_CD8_density', 'S_CD4_density', 'S_CD20_density', 'S_Plasma_density', 'T_CD8_density', 'T_CD4_density', 'T_CD20_density', 'T_Plasma_density'), "ithi_clinical_file" = '/shahlab/alzhang/data/ithi/clinical_table_20170816_2.txt', "mapscape_patient_order" = c(1, 2, 3, 4, 7, 9, 10, 11, 12, 13, 14, 15, 16, 17), "mvclust_tiltypes" = c('E_CD8_density', 'E_CD4_density', 'E_CD20_density', 'E_Plasma_density', 'S_CD8_density', 'S_CD4_density', 'S_CD20_density', 'S_Plasma_density'), "ccsri_mapscape_notebook" = 'Rmd/mapscape_ccsri.Rmd', "wang_fbi_status" = '/shahlab/alzhang/data/ICGC/ng.3849-S12.txt', "mmctm_final_patient_sigplot" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-patient_with-ov/plots/ith-by-patient_snv-sv_sigs_multipanel.pdf', "bcr_diversity" = '/shahlab/alzhang/pipeline_outputs/ith_immune/mixcr/mixcr_runs/ith_1_2_3/mixcr5/postprocess/IGH/postfilter_diversity_stats/diversity.strict.resampled.txt', "driver_analysis_notebook" = 'Rmd/driver_analysis.Rmd', "xcrmapscape_notebook" = 'Rmd/xcrmapscape.Rmd', "immune_variability_notebook" = 'Rmd/immune_variability.Rmd', "ithi_neutrality_samples" = c('1_Om1', '1_ROv1', '1_ROv2', '1_ROv3', '1_ROv4', '1_SBwl1', '10_ROv1', '10_ROv2', '10_ROv3', '10_ROv4', '11_LOv1', '11_LOv3', '11_Pv1', '11_Rct1', '11_Rct2', '12_LOv1', '12_LOv2', '12_Om1', '12_Om2', '12_ROv1', '13_Om1', '13_RGrn1', '13_ROv1', '13_ROv2', '13_ROv3', '14_Bld1', '14_CDS1', '14_LOv1', '14_Om1', '14_ROv1', '15_CDS1', '15_LOv1', '15_ROv1', '15_ROv2', '15_SBwl1', '16_LOv1', '16_LOvSfc1', '16_Om1', '16_Ptn1', '16_ROv1', '17_Om1', '17_Om2', '17_Om3', '17_Ov1', '17_Ov2', '2_Om1', '2_Om2', '2_ROv1', '2_ROv2', '3_Adnx1', '3_Om1', '3_ROv1', '3_ROv2', '4_LPvSw1', '4_ROv1', '4_ROv2', '4_ROv3', '4_ROv4', '7_BrnM', '7_LOv1', '7_RPvM', '9_LOv1', '9_LOv2', '9_Om1', '9_Om2', '9_ROv1'), "spatial_result_dirs" = list("stromal" = '/shahlab/alzhang/pipeline_outputs/ith_immune/spatsim/ith5/abc', "epithelial" = '/shahlab/alzhang/pipeline_outputs/ith_immune/spatsim/ith3/abc'), "phenotype_threshold" = 0.85, "master_variant_file" = '/shahlab/amcpherson/projects/ith3/ith3/notebooks/bespoke/ith_snvs.tsv', "neoediting_outdir" = '/shahlab/alzhang/pipeline_outputs/ith_immune/neoediting/run4', "mmctm_sample_result_dir" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-sample/output', "logdir" = '/shahlab/alzhang/clusttmp/paperanalysis2', "icgc_normalized_reads_matrix" = '/shahlab/alzhang/data/ICGC/OVAU_expr_matrix.tsv', "tcr_diversity" = '/shahlab/alzhang/pipeline_outputs/ith_immune/mixcr/mixcr_runs/ith_1_2_3/mixcr5/postprocess/TRB/postfilter_diversity_stats/diversity.strict.resampled.txt', "prevalence_threshold" = 0.01, "library_sizes" = '/shahlab/alzhang/pipeline_outputs/ith_immune/mixcr/mixcr_runs/ith_1_2_3/mixcr5/library_sizes.tsv', "tils_for_variability" = c('E_CD8_density', 'E_CD4_density', 'E_CD20_density', 'E_Plasma_density', 'S_CD8_density', 'S_CD4_density', 'S_CD20_density', 'S_Plasma_density'), "known_subtype_file" = '/shahlab/alzhang/projects/ITH_Immune/data/expression/array/subtypes/known_subtypes.tsv', "proportion_subclonal_file" = '/shahlab/alzhang/projects/ITH_Immune/data/ith/complete/old_proportion_subclonal.tsv', "mmctm_ov_combined_result_dir" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/combined_ov_mmctm/output', "yinyin_image_summary" = '/shahlab/alzhang/data/ithi/yuan_hecr_image_results.csv', "master_copynumber_file" = '/shahlab/alzhang/data/ithi/master_copynumber_file.tsv', "subtype_marker_file" = '/shahlab/alzhang/projects/ITH_Immune/data/expression/nanostring/subtype_markers.tsv', "tcga_expr_matrix" = '/shahlab/alzhang/data/TCGA/expr_matrix_normalize_standardize_noduplicates.tsv', "variability_type" = 'stabilize', "xcr_mapping_notebook" = 'Rmd/xcr_mapping.Rmd', "xcr_qc_notebook" = 'Rmd/replicates.Rmd', "bcrphylo_tiltypes" = c('E_CD8_density', 'E_CD4_density', 'E_CD20_density', 'E_Plasma_density', 'S_CD8_density', 'S_CD4_density', 'S_CD20_density', 'S_Plasma_density', 'T_CD8_density', 'T_CD4_density', 'T_CD20_density', 'T_Plasma_density'), "bcr_clonal_figure_template" = '/shahlab/alzhang/projects/ITH_Immune/paper/analysis/templates/clonal_figure_4by4_nobottom.svg', "xcrmapscape_tcr_patient_order" = c(9, 2, 15, 1, 12, 14, 11, 17, 3, 4, 10, 13, 16, 7), "known_subtypes_merged" = '/shahlab/alzhang/projects/ITH_Immune/data/expression/known_subtypes_merged.tsv', "nanostring_data" = '/shahlab/alzhang/projects/ITH_Immune/results/nanostring_results/ith_full/qc/limma_quantile/normalized_expression_voa_labels_filtered.tsv', "nscatters" = 1, "icgc_clinical" = '/shahlab/alzhang/data/ICGC/donor.OV-AU.tsv', "mmctm_ov_combined_sigplot" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/combined_ov_mmctm/plots/ov_snv-sv_sigs_multipanel.pdf', "icgc_expr_melted" = '/shahlab/alzhang/data/ICGC/OVAU_expr_melted.tsv', "tex_resource_dir" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/tex_resources/run2', "image_analysis_notebook" = 'Rmd/image_analysis.Rmd', "mmctm_sample_ad_sigplot" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-ancestry-sample/plots/ith-by-ancestral-sample_snv-sv_sigs_multipanel.pdf', "mmctm_final_patient_dir" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-patient_with-ov', "table_dir" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/tables/run2', "index_notebook" = 'Rmd/index.Rmd', "nclusts" = 3, "driver_map" = '/shahlab/alzhang/projects/ITH_Immune/subprojects/drivers/data/gene_list_mapped.bed', "tils_for_cluster" = c('E_CD8_density', 'E_CD4_density', 'E_CD20_density', 'E_Plasma_density', 'S_CD8_density', 'S_CD4_density', 'S_CD20_density', 'S_Plasma_density'), "til_classifier_notebook" = 'Rmd/til_classifier.Rmd', "ihc_run2" = '/shahlab/alzhang/projects/ITH_Immune/data/ihc/cd79cd138cd68/validated_stats_weighted.rdata', "example_annotations" = '/shahlab/alzhang/pipeline_outputs/ith_immune/igpartition/run13/final_partitions/ith2_2/clust9/annotations_flagged.tsv', "mmctm_patient_ad_sigplot" = '/shahlab/alzhang/projects/ITH_Immune/results/mmctm_results/ith_by-patient-ancestry/plots/ith-by-patient-ancestry_snv-sv_sigs_multipanel.pdf', "xcr_distance_method" = 'horn', "tcga_clinical" = '/shahlab/alzhang/data/TCGA/synapse_clinAll_data.tsv', "mutation_signature_notebook" = 'Rmd/mutation_signatures.Rmd', "driver_patients" = c(1, 2, 3, 4, 7, 9, 10, 11, 12, 13, 14, 15, 16, 17), "benchmarkdir" = '/shahlab/alzhang/benchmarks/paperanalysis2', "xcr_clones_notebook" = 'Rmd/xcr_clones_analysis.Rmd', "PNG_DENSITY" = 300, "patients_for_clonal" = c(1, 2, 3, 4, 7, 9, 10, 11, 12, 13, 14, 15, 16, 17), "spatial_notebook" = 'Rmd/spatial_analysis.Rmd', "db" = '/shahlab/alzhang/projects/ITH_Immune/metadata/db/immune_project.sqlite3', "ihc_run1" = '/shahlab/alzhang/projects/ITH_Immune/data/ihc/cd8cd3cd20/validated_stats_weighted_new.rdata', "molsubtype_tiltypes" = c('E_CD8_density', 'E_CD4_density', 'E_CD20_density', 'E_Plasma_density', 'S_CD8_density', 'S_CD4_density', 'S_CD20_density', 'S_Plasma_density'), "classifier_type" = 'knn', "ith_project_results" = '/shahlab/alzhang/projects/ith3/data/results', "v_dictionary" = '/shahlab/alzhang/projects/ITH_Immune/subprojects/immtyper/metadata/imgt/Homo_sapiens_TRBV.fasta', "mapscape_template" = '/shahlab/alzhang/projects/ITH_Immune/paper/analysis/templates/clonal_figure_4by4_nobottom_tilcluster.svg', "clone_branch_length_file" = '/shahlab/alzhang/projects/ITH_Immune/data/ith/complete/branch_data.tsv', "ov133_fbi_status" = '/shahlab/alzhang/data/OV133/ov133_hgsc_fbi_class.tsv', "site_file" = '/shahlab/alzhang/projects/ITH_Immune/paper/analysis/Rmd/_site.yml', "icgc_molecular_subtypes" = '/shahlab/alzhang/data/ICGC/icgc_primary_tumour_subtypes.tsv', "neutral_options" = c('restrict', 'free'), "notebook_dir" = '/shahlab/alzhang/projects/ITH_Immune/paper/results/web'),
    rule = 'figure_gallery'
)
######## Original script #########

                        ```


```{r global_chunk_options, include=FALSE}
knitr::opts_chunk$set(echo = TRUE, tidy=TRUE, warning=FALSE, message=FALSE)
```


```{r}
library(ithi.utils)
load_base_libs()

## grid graphics
library(grid)
library(gridExtra)
library(gridGraphics)
library(extrafont)
library(gridBase)
library(ape)
library(phylobase)
library(phytools)
library(OutbreakTools)
library(colorspace)
library(RColorBrewer)
library(igraph)

library(ithi.meta)
library(ithi.xcr)
library(ithi.clones)
library(ithi.expr)
library(ithi.figures)
library(ithi.seq)
```

## Colour palettes

```{r}
pal_patient <- select_palette("patient")
```

## Parameters

```{r}
db_path <- snakemake@params$db

ihc_table_path <- snakemake@input$ihc_table
xcr_table_path <- snakemake@input$xcr_table
nanostring_data_path <- snakemake@input$nanostring_data
nanostring_annotations_path <- snakemake@input$nanostring_annotations
master_variant_file <- snakemake@input$master_variant_file
trb_annotated_path <- snakemake@input$trb_annotated

#igpartition_outdir <- snakemake@input$igpartition_outdir
bcrphylo_figure <- snakemake@input$bcrphylo_png
mutsig_figure <- snakemake@input$mutsig_png
immune_cancer_figure <- snakemake@input$immune_cancer_png
immune_overview_figure <- snakemake@input$immune_overview_png
merged_figures_path <- snakemake@input$merged_figures
```

## Metadata

```{r}
db <- src_sqlite(db_path, create=FALSE)

samples <- collect(tbl(db, "samples"))
```

## Data

```{r}
ihc_table <- fread(ihc_table_path)
xcr_table <- read_clonotypes(xcr_table_path, duplicates = FALSE, db_path)
exprs <- fread(nanostring_data_path)
labels <- fread(nanostring_annotations_path)
trb_annotated <- fread(trb_annotated_path)
master_variant_table <- read_variant_file(master_variant_file, db_path)
```

## Figures

Will be updated as I work on more of these. **Note**: Fonts will always be ugly on here because genesis doesn't have ANY truetype fonts :(

### Merged

[Link to merged figures](resources/figures_merged.pdf)

### Figure 1

Landscape figure showing sample statistics. Base R graphics are very fast! 

```{r, fig.width=7, fig.height=6}
condensed_ids <- unique(subset(samples, project_code == "ITH" & !source %in% c("blood", "normal"))$condensed_id)
condensed_ids <- as.character(sort(factor_id(condensed_ids, type = "condensed_id", db_path)))

plot_landscape_figure(db_path, condensed_ids = condensed_ids,
                      ihc_table = ihc_table, xcr_table = xcr_table,
                      variant_table = master_variant_table, separate_opt = "zebra")

plot_landscape_figure(db_path, condensed_ids = condensed_ids,
                      ihc_table = ihc_table, xcr_table = xcr_table,
                      variant_table = master_variant_table, separate_opt = "line")
```

Plotted w/ zebra and line separators in case you like one better. Also added patient labels. 

### Figure 2

Immune overview figure. If you have any suggestions on what to include/remove please let me know!

Top to bottom:

* Patient colour label legend
* TCR (left) and BCR (right) clonotype sharing illustrated by Circos plots
* Mean expression of certain pathways as indicated by Nanostring annotations
* Intrapatient similarity in TCR repertoire
* High correlation between TCR repertoire similarity and CD8+ TIL density (left), lower correlation with CD4+ TIL density (middle) and CD8+'s are more broadly distributed across tumour sites than CD4+'s (right)


![](`r immune_overview_figure`)


### Figure 3

B-cell phylogenetics. 

Subfigures:

* Evidence of either B-cell exchange or parallel affinity maturation across tumour sites
* Evidence of lineage divergence by tumour site
* Evidence of phylogenetic signal in readcounts (sequence-dependent expansion)
* Correlations between GSI/phylosignal and CD20+ TIL densities

![](`r bcrphylo_figure`)

```{r}
#plot_bcrphylo_figure(resultdir = igpartition_outdir, ihc_table, parts = 
#                       list(A=list(patient=2,clust=7),
#                            B=list(patient=18, clust=10),
#                            C=list(patient=9, clust=14)))
```



### Figure 4

Mutational signatures and immune activity. 

Subfigures:

* SNV signatures
* SV signatures
* Clustering by mutation signature proportions
* Expression-derived immune covariates overlaid on mutation signature-based clusters
* TCGA survival analysis

![](`r mutsig_figure`)


### Figure 5

Immune-cancer interaction. 

![](`r immune_cancer_figure`)

### Figure 6



