diff --git a/.Rbuildignore b/.Rbuildignore index 73cf68870ddb05c9774793c0deb178f3e64c4e66..449c296ce67c491697c5941fd99a3d3d955119c1 100644 --- a/.Rbuildignore +++ b/.Rbuildignore @@ -1,11 +1,11 @@ -^.*\.Rproj$ -^\.ci$ -^\.gitlab-ci\.yml$ -^\.Rproj\.user$ -^\.travis.yml$ -public -grA.png -grB.pgn -^_pkgdown\.yml$ -^public$ -^pkgdown$ +^.*\.Rproj$ +^\.ci$ +^\.gitlab-ci\.yml$ +^\.Rproj\.user$ +^\.travis.yml$ +public +grA.png +grB.pgn +^_pkgdown\.yml$ +^public$ +^pkgdown$ diff --git a/.ci/requirements.txt b/.ci/requirements.txt index 2be21407d30cc15b85dff115a422295acb701e9e..255f35ccaa0517cbb33f4ddf8edd25e69da731f8 100644 --- a/.ci/requirements.txt +++ b/.ci/requirements.txt @@ -1,31 +1,31 @@ -r-assertive -r-data.table -r-ggplot2 -r-magrittr -r-reticulate -r-stringi -r-tidyr -r-knitr -r-rmarkdown -r-testthat -bioconductor-annotationhub -bioconductor-biocgenerics -bioconductor-biostrings -bioconductor-bsgenome -bioconductor-crisprseek -bioconductor-genomeinfodb -bioconductor-genomicfeatures -bioconductor-genomicranges -bioconductor-karyoploter -bioconductor-plyranges -bioconductor-rbowtie -bioconductor-rtracklayer -bioconductor-biocstyle -bioconductor-bsgenome.hsapiens.ucsc.hg38 -bioconductor-bsgenome.mmusculus.ucsc.mm10 -bioconductor-bsgenome.scerevisiae.ucsc.saccer1 -bioconductor-ensembldb -bioconductor-iranges -bioconductor-txdb.mmusculus.ucsc.mm10.knowngene -qpdf +r-assertive +r-data.table +r-ggplot2 +r-magrittr +r-reticulate +r-stringi +r-tidyr +r-knitr +r-rmarkdown +r-testthat +bioconductor-annotationhub +bioconductor-biocgenerics +bioconductor-biostrings +bioconductor-bsgenome +bioconductor-crisprseek +bioconductor-genomeinfodb +bioconductor-genomicfeatures +bioconductor-genomicranges +bioconductor-karyoploter +bioconductor-plyranges +bioconductor-rbowtie +bioconductor-rtracklayer +bioconductor-biocstyle +bioconductor-bsgenome.hsapiens.ucsc.hg38 +bioconductor-bsgenome.mmusculus.ucsc.mm10 +bioconductor-bsgenome.scerevisiae.ucsc.saccer1 +bioconductor-ensembldb +bioconductor-iranges +bioconductor-txdb.mmusculus.ucsc.mm10.knowngene +qpdf zip \ No newline at end of file diff --git a/.ci/setup.sh b/.ci/setup.sh index be40e306d18657dd776d95a0e44d084a425b7a73..52a60c57bcf1c78f828fc6abf46895545f22d7ec 100644 --- a/.ci/setup.sh +++ b/.ci/setup.sh @@ -1,17 +1,17 @@ -#!/bin/bash - -set -eo pipefail - -# -# Set up correct channel order -# -conda config --system --add channels defaults -conda config --system --add channels bioconda -conda config --system --add channels conda-forge - -# -# Install packages from requirements -# -conda install -q -y --file .ci/requirements.txt - -conda clean -q -y --all +#!/bin/bash + +set -eo pipefail + +# +# Set up correct channel order +# +conda config --system --add channels defaults +conda config --system --add channels bioconda +conda config --system --add channels conda-forge + +# +# Install packages from requirements +# +conda install -q -y --file .ci/requirements.txt + +conda clean -q -y --all diff --git a/.gitignore b/.gitignore index c1c0705459ccce2081bd86695e964ebc16b440d9..0d06de8254bd5cca7f9162622f2d5402f0d342f2 100644 --- a/.gitignore +++ b/.gitignore @@ -1,5 +1,5 @@ -inst/doc -.Rproj.user -vignettes/*_cache -multicrispr.Rproj +inst/doc +.Rproj.user +vignettes/*_cache +multicrispr.Rproj .gitattributes \ No newline at end of file diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 57e92930f96a369e4c787fd221f9e300493dfaf8..ce2af2e920977674923bac49cab0315d5ed8f4ad 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,45 +1,45 @@ -image: continuumio/miniconda3:4.7.12 - -stages: - - build - - check - -before_script: - - chmod +x .ci/setup.sh - - .ci/setup.sh - -build: - stage: build - tags: - - docker - script: - - R CMD build . - artifacts: - paths: - - multicrispr_*.tar.gz - name: "$CI_COMMIT_REF_NAME-builds" - -check: - stage: check - tags: - - docker - variables: - http_proxy: http://www-proxy.t-online.de:80 - R_ZIPCMD: /opt/conda/bin/zip - _R_CHECK_FORCE_SUGGESTS_: 0 - script: - - R CMD check *tar.gz --as-cran --no-manual - artifacts: - expire_in: 1 week - paths: - - multicrispr.Rcheck/* - -pages: - stage: .post - script: - - touch public - artifacts: - paths: - - public - only: +image: continuumio/miniconda3:4.7.12 + +stages: + - build + - check + +before_script: + - chmod +x .ci/setup.sh + - .ci/setup.sh + +build: + stage: build + tags: + - docker + script: + - R CMD build . + artifacts: + paths: + - multicrispr_*.tar.gz + name: "$CI_COMMIT_REF_NAME-builds" + +check: + stage: check + tags: + - docker + variables: + http_proxy: http://www-proxy.t-online.de:80 + R_ZIPCMD: /opt/conda/bin/zip + _R_CHECK_FORCE_SUGGESTS_: 0 + script: + - R CMD check *tar.gz --as-cran --no-manual + artifacts: + expire_in: 1 week + paths: + - multicrispr.Rcheck/* + +pages: + stage: .post + script: + - touch public + artifacts: + paths: + - public + only: - master \ No newline at end of file diff --git a/.travis.yml b/.travis.yml index 1abf6ad4d28a03d64549ff42416c9ab0a905b11e..5b49b4fff63e1fc922de8d558181cd0f4ac71b19 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,4 +1,4 @@ -language: r -r: bioc-devel -apt_packages: +language: r +r: bioc-devel +apt_packages: - libmagick++-dev \ No newline at end of file diff --git a/DESCRIPTION b/DESCRIPTION index f116f3da64ae59841877f14f3c664f0fe31ef2c2..916ee6ce05bbfee52521f4a27ffa0e03a29a0dc5 100644 --- a/DESCRIPTION +++ b/DESCRIPTION @@ -1,6 +1,6 @@ Package: multicrispr Title: Multi-locus multi-purpose Crispr/Cas design -Version: 0.99.13 +Version: 0.99.14 Authors@R: c(person("Aditya", "Bhagwat", NULL, "aditya.bhagwat@mpi-bn.mpg.de", c("aut", "cre")), person( "Johannes", "Graumann", NULL, 'johannes.graumann@mpi-bn.mpg.de',c("sad", "ctb")), person( "Mette", "Bentsen", NULL, "mette.bentsen@mpi-bn.mpg.de", "ctb"), @@ -17,7 +17,7 @@ Description: This package is for designing Crispr/Cas9 and Prime Editing experim License: GPL-2 Encoding: UTF-8 LazyData: true -RoxygenNote: 7.1.0 +RoxygenNote: 7.1.1 Depends: R (>= 4.0) Imports: diff --git a/NAMESPACE b/NAMESPACE index 6880335047bf580467909308e2d636cfcccf1a71..eff48d1ccc8a7054cf66814102160d8c054fa206 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -1,126 +1,126 @@ -# Generated by roxygen2: do not edit by hand - -export(add_context) -export(add_efficiency) -export(add_genome_counts) -export(add_inverse_strand) -export(add_offtargets) -export(add_seq) -export(add_specificity) -export(add_target_counts) -export(bed_to_granges) -export(char_to_granges) -export(double_flank) -export(down_flank) -export(dt2gr) -export(extend) -export(extend_for_pe) -export(extend_pe_to_gg) -export(extract_matchranges) -export(extract_subranges) -export(filter_efficient) -export(find_gg) -export(find_pe_spacers) -export(find_spacers) -export(genefile_to_granges) -export(genes_to_granges) -export(gr2dt) -export(has_been_indexed) -export(index_genome) -export(index_targets) -export(match_seqs) -export(match_spacers) -export(plot_intervals) -export(plot_karyogram) -export(up_flank) -importFrom(BSgenome,getBSgenome) -importFrom(BSgenome,getSeq) -importFrom(BiocGenerics,"end<-") -importFrom(BiocGenerics,"start<-") -importFrom(BiocGenerics,"strand<-") -importFrom(BiocGenerics,end) -importFrom(BiocGenerics,invertStrand) -importFrom(BiocGenerics,start) -importFrom(BiocGenerics,strand) -importFrom(Biostrings,DNAStringSet) -importFrom(Biostrings,complement) -importFrom(Biostrings,vcountPDict) -importFrom(Biostrings,vmatchPattern) -importFrom(GenomeInfoDb,"seqinfo<-") -importFrom(GenomeInfoDb,"seqlevels<-") -importFrom(GenomeInfoDb,"seqlevelsStyle<-") -importFrom(GenomeInfoDb,"seqnames<-") -importFrom(GenomeInfoDb,genome) -importFrom(GenomeInfoDb,seqinfo) -importFrom(GenomeInfoDb,seqlevels) -importFrom(GenomeInfoDb,seqlevelsInUse) -importFrom(GenomeInfoDb,seqlevelsStyle) -importFrom(GenomeInfoDb,seqnames) -importFrom(GenomeInfoDb,sortSeqlevels) -importFrom(GenomeInfoDb,standardChromosomes) -importFrom(GenomicRanges,"mcols<-") -importFrom(GenomicRanges,GRanges) -importFrom(GenomicRanges,mcols) -importFrom(assertive,assert_all_are_dirs) -importFrom(assertive,assert_all_are_existing_files) -importFrom(assertive,assert_all_are_false) -importFrom(assertive,assert_all_are_less_than) -importFrom(assertive,assert_all_are_matching_regex) -importFrom(assertive,assert_all_are_true) -importFrom(assertive,assert_are_identical) -importFrom(assertive,assert_are_same_length) -importFrom(assertive,assert_has_names) -importFrom(assertive,assert_has_no_duplicates) -importFrom(assertive,assert_is_a_bool) -importFrom(assertive,assert_is_a_number) -importFrom(assertive,assert_is_a_string) -importFrom(assertive,assert_is_all_of) -importFrom(assertive,assert_is_any_of) -importFrom(assertive,assert_is_character) -importFrom(assertive,assert_is_scalar) -importFrom(assertive,assert_is_subset) -importFrom(assertive,has_names) -importFrom(assertive,is_identical_to_true) -importFrom(assertive,is_windows) -importFrom(data.table,":=") -importFrom(data.table,.SD) -importFrom(data.table,as.data.table) -importFrom(data.table,data.table) -importFrom(data.table,setnafill) -importFrom(data.table,setnames) -importFrom(data.table,setorderv) -importFrom(ggplot2,aes) -importFrom(ggplot2,aes_string) -importFrom(ggplot2,facet_wrap) -importFrom(ggplot2,geom_point) -importFrom(ggplot2,geom_segment) -importFrom(ggplot2,ggplot) -importFrom(ggplot2,ggtitle) -importFrom(ggplot2,scale_alpha_manual) -importFrom(ggplot2,scale_size_manual) -importFrom(ggplot2,scale_x_continuous) -importFrom(ggplot2,theme_bw) -importFrom(ggplot2,unit) -importFrom(ggplot2,xlab) -importFrom(ggplot2,ylab) -importFrom(grid,arrow) -importFrom(magrittr,"%<>%") -importFrom(magrittr,"%>%") -importFrom(magrittr,add) -importFrom(magrittr,and) -importFrom(magrittr,extract) -importFrom(magrittr,extract2) -importFrom(magrittr,set_names) -importFrom(methods,as) -importFrom(stringi,stri_detect_regex) -importFrom(stringi,stri_locate_all_fixed) -importFrom(stringi,stri_locate_all_regex) -importFrom(stringi,stri_replace_first_fixed) -importFrom(stringi,stri_startswith_fixed) -importFrom(tidyr,separate_rows) -importFrom(utils,download.file) -importFrom(utils,getFromNamespace) -importFrom(utils,head) -importFrom(utils,read.csv) -importFrom(utils,read.table) -importFrom(utils,tail) +# Generated by roxygen2: do not edit by hand + +export(add_context) +export(add_efficiency) +export(add_genome_counts) +export(add_inverse_strand) +export(add_offtargets) +export(add_seq) +export(add_specificity) +export(add_target_counts) +export(bed_to_granges) +export(char_to_granges) +export(double_flank) +export(down_flank) +export(dt2gr) +export(extend) +export(extend_for_pe) +export(extend_pe_to_gg) +export(extract_matchranges) +export(extract_subranges) +export(filter_efficient) +export(find_gg) +export(find_pe_spacers) +export(find_spacers) +export(genefile_to_granges) +export(genes_to_granges) +export(gr2dt) +export(has_been_indexed) +export(index_genome) +export(index_targets) +export(match_seqs) +export(match_spacers) +export(plot_intervals) +export(plot_karyogram) +export(up_flank) +importFrom(BSgenome,getBSgenome) +importFrom(BSgenome,getSeq) +importFrom(BiocGenerics,"end<-") +importFrom(BiocGenerics,"start<-") +importFrom(BiocGenerics,"strand<-") +importFrom(BiocGenerics,end) +importFrom(BiocGenerics,invertStrand) +importFrom(BiocGenerics,start) +importFrom(BiocGenerics,strand) +importFrom(Biostrings,DNAStringSet) +importFrom(Biostrings,complement) +importFrom(Biostrings,vcountPDict) +importFrom(Biostrings,vmatchPattern) +importFrom(GenomeInfoDb,"seqinfo<-") +importFrom(GenomeInfoDb,"seqlevels<-") +importFrom(GenomeInfoDb,"seqlevelsStyle<-") +importFrom(GenomeInfoDb,"seqnames<-") +importFrom(GenomeInfoDb,genome) +importFrom(GenomeInfoDb,seqinfo) +importFrom(GenomeInfoDb,seqlevels) +importFrom(GenomeInfoDb,seqlevelsInUse) +importFrom(GenomeInfoDb,seqlevelsStyle) +importFrom(GenomeInfoDb,seqnames) +importFrom(GenomeInfoDb,sortSeqlevels) +importFrom(GenomeInfoDb,standardChromosomes) +importFrom(GenomicRanges,"mcols<-") +importFrom(GenomicRanges,GRanges) +importFrom(GenomicRanges,mcols) +importFrom(assertive,assert_all_are_dirs) +importFrom(assertive,assert_all_are_existing_files) +importFrom(assertive,assert_all_are_false) +importFrom(assertive,assert_all_are_less_than) +importFrom(assertive,assert_all_are_matching_regex) +importFrom(assertive,assert_all_are_true) +importFrom(assertive,assert_are_identical) +importFrom(assertive,assert_are_same_length) +importFrom(assertive,assert_has_names) +importFrom(assertive,assert_has_no_duplicates) +importFrom(assertive,assert_is_a_bool) +importFrom(assertive,assert_is_a_number) +importFrom(assertive,assert_is_a_string) +importFrom(assertive,assert_is_all_of) +importFrom(assertive,assert_is_any_of) +importFrom(assertive,assert_is_character) +importFrom(assertive,assert_is_scalar) +importFrom(assertive,assert_is_subset) +importFrom(assertive,has_names) +importFrom(assertive,is_identical_to_true) +importFrom(assertive,is_windows) +importFrom(data.table,":=") +importFrom(data.table,.SD) +importFrom(data.table,as.data.table) +importFrom(data.table,data.table) +importFrom(data.table,setnafill) +importFrom(data.table,setnames) +importFrom(data.table,setorderv) +importFrom(ggplot2,aes) +importFrom(ggplot2,aes_string) +importFrom(ggplot2,facet_wrap) +importFrom(ggplot2,geom_point) +importFrom(ggplot2,geom_segment) +importFrom(ggplot2,ggplot) +importFrom(ggplot2,ggtitle) +importFrom(ggplot2,scale_alpha_manual) +importFrom(ggplot2,scale_size_manual) +importFrom(ggplot2,scale_x_continuous) +importFrom(ggplot2,theme_bw) +importFrom(ggplot2,unit) +importFrom(ggplot2,xlab) +importFrom(ggplot2,ylab) +importFrom(grid,arrow) +importFrom(magrittr,"%<>%") +importFrom(magrittr,"%>%") +importFrom(magrittr,add) +importFrom(magrittr,and) +importFrom(magrittr,extract) +importFrom(magrittr,extract2) +importFrom(magrittr,set_names) +importFrom(methods,as) +importFrom(stringi,stri_detect_regex) +importFrom(stringi,stri_locate_all_fixed) +importFrom(stringi,stri_locate_all_regex) +importFrom(stringi,stri_replace_first_fixed) +importFrom(stringi,stri_startswith_fixed) +importFrom(tidyr,separate_rows) +importFrom(utils,download.file) +importFrom(utils,getFromNamespace) +importFrom(utils,head) +importFrom(utils,read.csv) +importFrom(utils,read.table) +importFrom(utils,tail) diff --git a/NEWS b/NEWS index a9e50a29e1b847d11e10eca450342b607ebdc7c0..da0ad8f2c216558e141a6fd611ce1150dfada542 100644 --- a/NEWS +++ b/NEWS @@ -1,2 +1,2 @@ -Changes in version 0.99.0 (2020-04-24) +Changes in version 0.99.0 (2020-04-24) + Submitted to Bioconductor \ No newline at end of file diff --git a/R/00_imports.R b/R/00_imports.R index 25db962d552faa20c722beb53ae99ed5d4206e92..79fa5c6870f6807969331e922aef536e886760ec 100644 --- a/R/00_imports.R +++ b/R/00_imports.R @@ -1,44 +1,44 @@ -#' @importFrom assertive assert_all_are_true is_identical_to_true -#' @importFrom assertive assert_all_are_false -#' @importFrom assertive assert_all_are_existing_files -#' @importFrom assertive assert_all_are_less_than -#' @importFrom assertive assert_all_are_matching_regex -#' @importFrom assertive assert_are_identical assert_are_same_length -#' @importFrom assertive has_names assert_has_names -#' @importFrom assertive is_windows assert_all_are_dirs -#' @importFrom assertive assert_is_subset assert_has_no_duplicates -#' @importFrom assertive assert_is_all_of assert_is_any_of -#' @importFrom assertive assert_is_a_bool assert_is_a_number -#' @importFrom assertive assert_is_a_string assert_is_character -#' @importFrom assertive assert_is_scalar -#' @importFrom Biostrings complement DNAStringSet -#' @importFrom Biostrings vmatchPattern vcountPDict -#' @importFrom BiocGenerics end end<- invertStrand -#' @importFrom BiocGenerics start start<- strand strand<- -#' @importFrom BSgenome getSeq getBSgenome -#' @importFrom data.table := data.table as.data.table setnames -#' @importFrom data.table setnames setorderv setnafill .SD -#' @importFrom GenomeInfoDb genome -#' @importFrom GenomeInfoDb seqinfo seqinfo<- -#' @importFrom GenomeInfoDb seqlevels seqlevels<- seqlevelsInUse -#' @importFrom GenomeInfoDb seqlevelsStyle seqlevelsStyle<- -#' @importFrom GenomeInfoDb seqnames seqnames<- -#' @importFrom GenomeInfoDb sortSeqlevels standardChromosomes -#' @importFrom GenomicRanges GRanges mcols mcols<- -#' @importFrom ggplot2 aes aes_string -#' @importFrom ggplot2 facet_wrap geom_point geom_segment -#' @importFrom ggplot2 ggplot ggtitle scale_x_continuous -#' @importFrom ggplot2 scale_alpha_manual scale_size_manual -#' @importFrom ggplot2 theme_bw unit xlab ylab -#' @importFrom grid arrow -#' @importFrom magrittr %>% %<>% add and -#' @importFrom magrittr extract extract2 set_names -#' @importFrom methods as -#' @importFrom tidyr separate_rows -#' @importFrom utils download.file getFromNamespace head -#' @importFrom utils tail read.csv read.table -#' @importFrom stringi stri_detect_regex stri_locate_all_fixed -#' @importFrom stringi stri_locate_all_regex -#' @importFrom stringi stri_replace_first_fixed -#' @importFrom stringi stri_startswith_fixed -NULL +#' @importFrom assertive assert_all_are_true is_identical_to_true +#' @importFrom assertive assert_all_are_false +#' @importFrom assertive assert_all_are_existing_files +#' @importFrom assertive assert_all_are_less_than +#' @importFrom assertive assert_all_are_matching_regex +#' @importFrom assertive assert_are_identical assert_are_same_length +#' @importFrom assertive has_names assert_has_names +#' @importFrom assertive is_windows assert_all_are_dirs +#' @importFrom assertive assert_is_subset assert_has_no_duplicates +#' @importFrom assertive assert_is_all_of assert_is_any_of +#' @importFrom assertive assert_is_a_bool assert_is_a_number +#' @importFrom assertive assert_is_a_string assert_is_character +#' @importFrom assertive assert_is_scalar +#' @importFrom Biostrings complement DNAStringSet +#' @importFrom Biostrings vmatchPattern vcountPDict +#' @importFrom BiocGenerics end end<- invertStrand +#' @importFrom BiocGenerics start start<- strand strand<- +#' @importFrom BSgenome getSeq getBSgenome +#' @importFrom data.table := data.table as.data.table setnames +#' @importFrom data.table setnames setorderv setnafill .SD +#' @importFrom GenomeInfoDb genome +#' @importFrom GenomeInfoDb seqinfo seqinfo<- +#' @importFrom GenomeInfoDb seqlevels seqlevels<- seqlevelsInUse +#' @importFrom GenomeInfoDb seqlevelsStyle seqlevelsStyle<- +#' @importFrom GenomeInfoDb seqnames seqnames<- +#' @importFrom GenomeInfoDb sortSeqlevels standardChromosomes +#' @importFrom GenomicRanges GRanges mcols mcols<- +#' @importFrom ggplot2 aes aes_string +#' @importFrom ggplot2 facet_wrap geom_point geom_segment +#' @importFrom ggplot2 ggplot ggtitle scale_x_continuous +#' @importFrom ggplot2 scale_alpha_manual scale_size_manual +#' @importFrom ggplot2 theme_bw unit xlab ylab +#' @importFrom grid arrow +#' @importFrom magrittr %>% %<>% add and +#' @importFrom magrittr extract extract2 set_names +#' @importFrom methods as +#' @importFrom tidyr separate_rows +#' @importFrom utils download.file getFromNamespace head +#' @importFrom utils tail read.csv read.table +#' @importFrom stringi stri_detect_regex stri_locate_all_fixed +#' @importFrom stringi stri_locate_all_regex +#' @importFrom stringi stri_replace_first_fixed +#' @importFrom stringi stri_startswith_fixed +NULL diff --git a/R/02_utilities.R b/R/02_utilities.R index 894e7f36f19db3b5a30bbafa51786118ded856c1..bf05da0edfb3a4638836ec6cb8f69c4f33848db5 100644 --- a/R/02_utilities.R +++ b/R/02_utilities.R @@ -1,88 +1,88 @@ -cduplicated <- function(x) duplicated(x) | duplicated(x, fromLast = TRUE) - -cmessage <- function(...) message(sprintf(...)) - - -num2scalarstr <- function(x){ - if (length(unique(x))==1){ - x[1] - } else { - x %<>% extract(!is.na(x)) - x %<>% extract(is.finite(x)) - paste0(min(x), ' - ', max(x)) - } -} - -csign <- function(x) if (sign(x)==-1) '-' else '+' - -uniquify <- function(x){ - .N <- N <- suffix <- xunique <- NULL - dt <- data.table::data.table(x = x) - dt[, N := .N, by='x'] - dt[N==1, xunique := x] - dt[N>1, xunique := paste0(x, '_', seq_len(.N)), by = 'x'] - dt[, xunique] -} - -#' Make unique names -#' @param x vector -#' @param prefix string: prefix with which to start names -#' @return character vector with unique names -#' @noRd -make_unique_names <- function(x, prefix='T'){ - - if (has_names(x)){ - return(uniquify(names(x))) - } else { - y <- as.character(x) - assert_has_no_duplicates(y) - return(y) - } - - - #paste0(prefix, formatC(seq_along(x), - # digits = floor(log10(length(x))), - # flag = 0)) -} - -name_uniquely <- function(gr, prefix = 'x'){ - names(gr) <- make_unique_names(gr, prefix) - gr -} - -#' GRanges <-> data.table -#' -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param dt data.table -#' @param seqinfo \code{\link[GenomeInfoDb]{Seqinfo-class}} -#' @aliases dt2gr -#' @return data.table (gr2dt) or GRanges (dt2gr) -#' @examples -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' (dt <- gr2dt(gr)) -#' (gr <- dt2gr(dt, BSgenome::seqinfo(bsgenome))) -#' @export -gr2dt <- function(gr){ - dt <- as.data.table(gr) - if (has_names(gr)){ - dt[ , names := names(gr)] - } - dt[] -} - -#' @rdname gr2dt -#' @export -dt2gr <- function(dt, seqinfo){ - gr <- GRanges(dt, seqinfo = seqinfo) - if ('names' %in% names(mcols(gr))){ - names(gr) <- gr$names - gr$names <- NULL - } - gr -} - +cduplicated <- function(x) duplicated(x) | duplicated(x, fromLast = TRUE) + +cmessage <- function(...) message(sprintf(...)) + + +num2scalarstr <- function(x){ + if (length(unique(x))==1){ + x[1] + } else { + x %<>% extract(!is.na(x)) + x %<>% extract(is.finite(x)) + paste0(min(x), ' - ', max(x)) + } +} + +csign <- function(x) if (sign(x)==-1) '-' else '+' + +uniquify <- function(x){ + .N <- N <- suffix <- xunique <- NULL + dt <- data.table::data.table(x = x) + dt[, N := .N, by='x'] + dt[N==1, xunique := x] + dt[N>1, xunique := paste0(x, '_', seq_len(.N)), by = 'x'] + dt[, xunique] +} + +#' Make unique names +#' @param x vector +#' @param prefix string: prefix with which to start names +#' @return character vector with unique names +#' @noRd +make_unique_names <- function(x, prefix='T'){ + + if (has_names(x)){ + return(uniquify(names(x))) + } else { + y <- as.character(x) + assert_has_no_duplicates(y) + return(y) + } + + + #paste0(prefix, formatC(seq_along(x), + # digits = floor(log10(length(x))), + # flag = 0)) +} + +name_uniquely <- function(gr, prefix = 'x'){ + names(gr) <- make_unique_names(gr, prefix) + gr +} + +#' GRanges <-> data.table +#' +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param dt data.table +#' @param seqinfo \code{\link[GenomeInfoDb]{Seqinfo-class}} +#' @aliases dt2gr +#' @return data.table (gr2dt) or GRanges (dt2gr) +#' @examples +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' (dt <- gr2dt(gr)) +#' (gr <- dt2gr(dt, BSgenome::seqinfo(bsgenome))) +#' @export +gr2dt <- function(gr){ + dt <- as.data.table(gr) + if (has_names(gr)){ + dt[ , names := names(gr)] + } + dt[] +} + +#' @rdname gr2dt +#' @export +dt2gr <- function(dt, seqinfo){ + gr <- GRanges(dt, seqinfo = seqinfo) + if ('names' %in% names(mcols(gr))){ + names(gr) <- gr$names + gr$names <- NULL + } + gr +} + diff --git a/R/03_plot.R b/R/03_plot.R index 064695041dcf25a0ae15e8061c6cc6c5044723d0..bb648e17579001ad7a8ac697c483456e4683c36c 100644 --- a/R/03_plot.R +++ b/R/03_plot.R @@ -1,225 +1,225 @@ - -#' Karyo/Interval Plot GRanges(List) -#' @param grlist \code{\link[GenomicRanges]{GRanges-class}} -#' @param title plot title -#' @return list -#' @seealso \code{\link{plot_intervals}} -#' @examples -#' # Plot GRanges -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' gr <- bed_to_granges(bedfile, 'mm10', plot = FALSE) -#' plot_karyogram(gr) -#' -#' # Plot GRangesList -#' flanks <- up_flank(gr, stranded=FALSE) -#' grlist <- GenomicRanges::GRangesList(sites = gr, flanks = flanks) -#' plot_karyogram(grlist) -#' @export -plot_karyogram <- function( - grlist, - title = unique(genome(grlist)) -){ - - # Assert - . <- NULL - if (methods::is(grlist, 'GRanges')){ - grlist <- GenomicRanges::GRangesList(grlist) - } - assert_is_all_of(grlist, 'GRangesList') - - # Extract relevant chromosomes and order them - chroms <- union(seqlevelsInUse(grlist), standardChromosomes(grlist)) - stri_extract <- function(stri, pattern){ - stri %>% extract(stri_detect_regex(., pattern)) - } - chrs1 <- chroms %>% stri_extract('^(chr)?[0-9]$') %>% sort() - chrs2 <- chroms %>% stri_extract('^(chr)?[0-9]{2}$') %>% sort() - chrsXY <- chroms %>% stri_extract('^(chr)?[XY]$') %>% sort() - chrsM <- chroms %>% stri_extract('^(chr)?MT?$') - orderedchrs <- c(chrs1, chrs2, chrsXY, chrsM) %>% - c(sort(setdiff(chroms, .))) - genomeranges <- as(seqinfo(grlist)[orderedchrs], "GRanges") - - # Color - n <- length(grlist) - if (n>0){ - hues <- seq(15, 375, length = n + 1) - colors <- grDevices::hcl(h = hues, l = 65, c = 100)[seq_len(n)] - } - - # Plot - kp <- karyoploteR::plotKaryotype(genomeranges, main = title) - for (i in seq_len(n)){ - karyoploteR::kpPlotRegions(kp, grlist[[i]], col = colors[i]) - } - - # Add legend - if (has_names(grlist)){ - graphics::legend('right', fill = colors, legend = names(grlist)) - } - -} - - -to_megabase <- function(y){ - z <- vector('character', length(y)) - - i <- y>1e6 - z[i] <- paste0(round(y[i]*1e-6), ' M') - - i <- y>1e3 & y<=1e6 - z[i] <- paste0(round(y[i]*1e-3), ' K') - - i <- y<=1e3 - z[i] <- paste0(round(y[i]), 'b') - z %>% set_names(names(y)) -} - - -#' Interval plot GRanges -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param xref gr var used for scaling x axis -#' @param y 'names' (default) or name of gr variable -#' @param nperchrom number (default 1): n head (and n tail) targets -#' shown per chromosome -#' @param nchrom number (default 6) of chromosomes shown -#' @param color_var 'seqnames' (default) or other gr variable -#' @param linetype_var NULL (default) or gr variable mapped to linetype -#' @param size_var NULL (default) or gr variable mapped to size -#' @param facet_var NULL(default) or gr variable mapped to facet -#' @param alpha_var NULL or gr variable mapped to alpha -#' @param title NULL or string: plot title -#' @param scales 'free', 'fixed', etc -#' @return ggplot object -#' @seealso \code{\link{plot_karyogram}} -#' @examples -#' # SRF sites -#' require(magrittr) -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- bed_to_granges(bedfile, 'mm10', plot = FALSE) -#' plot_intervals(targets) -#' -#' # PE targets -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', -#' HBB = 'chr11:5227002:-', -#' HEXA = 'chr15:72346580-72346583:-', -#' CFTR = 'chr7:117559593-117559595:+'), -#' bsgenome) -#' spacers <- find_pe_spacers(gr, bsgenome) -#' plot_intervals(gr) -#' plot_intervals(extend_for_pe(gr)) -#' plot_intervals(spacers) -#' -#' @export -plot_intervals <- function( - gr, xref = 'targetname', y = 'names', nperchrom = 2, nchrom = 4, - color_var = 'targetname', facet_var = 'seqnames', linetype_var = NULL, - size_var = default_size_var(gr), alpha_var = default_alpha_var(gr), - title = NULL, scales= 'free' -){ -# Comply - edge <- targetname <- NULL -# Assert, Import, Comply - assert_is_all_of(gr, 'GRanges') - if (!is.null(color_var)) assert_is_a_string(color_var) - assert_is_subset(color_var, names(as.data.table(gr))) - contig <- .N <- .SD <- seqnames <- start <- NULL - strand <- tmp <- width <- xstart <- xend <- . <- NULL -# Prepare plotdt - plotdt <- prepare_plot_intervals( - gr, xref, y, nperchrom, nchrom, alpha_var, size_var) -# Core Ranges - p <-ggplot( plotdt, - aes_string(x = 'xstart', xend = 'xend', y = 'y', yend = 'y', - color = color_var, linetype = linetype_var, - size = size_var, alpha = alpha_var)) + - facet_wrap(facet_var, scales = scales) + - geom_segment(arrow = arrow(length = unit(0.1, "inches"))) - if (!is.null(alpha_var)) p <- p + - scale_alpha_manual(values = c(`0` = 1, `1+` = 0.3)) - if (!is.null(size_var)) p <- p + - scale_size_manual(values = c(`0+` = 0.1, `0.3+` = 1, `0.5+` = 2)) -# Targets - if (all(c('targetstart', 'targetend') %in% names(mcols(gr)))){ - p <-p + geom_point(aes_string( - x = 'xtargetstart', y = 'y'), shape = '|', size = 4) + - geom_point(aes_string( - x = 'xtargetend', y = 'y'), shape = '|', size = 4)} -# Extensions - if ('extension' %in% names(mcols(gr))){ - p <-p + geom_segment( - aes_string( x = 'extstart', xend = 'extend', size = NULL), - linetype = 'dotted', - arrow = arrow(length = unit(0.1, "inches")))} - p <- p + theme_bw() + xlab(NULL) + ylab(NULL) + ggtitle(title) -# Return - p # print(p) -} - - -default_alpha_var <- function(gr){ - if ('off' %in% names(mcols(gr))) 'off' else NULL -} - -default_size_var <- function(gr){ - if ('Doench2016' %in% names(mcols(gr))) 'Doench2016' else NULL -} - - -head_tail <- function(x, n){ - idx <- x %in% unique( c(head(x, ceiling(n/2)), tail(x, floor(n/2)))) - x[idx] -} - -prepare_plot_intervals <- function( - gr, xref, y, nperchrom, nchrom, alpha_var, size_var -){ -# Comply - edge <- targetname <- xstart <- xend <- width <- NULL - targetstart <- targetend <- xtargetstart <- xtargetend <- NULL - extstart <- primer <- revtranscript <- extension <- tmp <- NULL -# Prepare data.table. Select chromosomes/targets to plot. - plotdt <- data.table::as.data.table(gr) %>% cbind(names = names(gr)) - plotdt %<>% extract(order(seqnames, start)) - plotdt$seqnames %<>% droplevels() - headtailchroms <- head_tail(levels(plotdt$seqnames), nchrom) - plotdt %<>% extract(headtailchroms, on = 'seqnames') - plotdt$seqnames %<>% factor(headtailchroms) - plotdt %<>% extract( # targets - , .SD[targetname %in% head_tail(unique(targetname), nperchrom)], - by = 'seqnames') -# Main ranges - plotdt %>% extract(, y := min(start), by = y) - plotdt %>% extract(, y := factor(format(y, big.mark = " "))) - plotdt %>% extract(, xstart := start-min(start), by = xref) - plotdt %>% extract(, xend := xstart + width) -# Target marks - if (all(c('targetstart', 'targetend') %in% names(mcols(gr)))){ - plotdt %>% extract(, xtargetstart := xstart + targetstart-start) - plotdt %>% extract(, xtargetend := xend + targetend-end )} -# Extensions - if ('extension' %in% names(mcols(gr))){ - plotdt %>% extract(strand=='+', extstart := xstart+18-nchar(primer)[1]) - plotdt %>% extract(strand=='-', - extstart := xend-16-(nchar(revtranscript)[1]-1)) - plotdt %>% extract(, extend := extstart + nchar(extension)[1]-1)} -# Flip for arrow direction - plotdt %>% extract(strand=='-', tmp := xend) - plotdt %>% extract(strand=='-', xend := xstart) - plotdt %>% extract(strand=='-', xstart := tmp) - if ('extension' %in% names(mcols(gr))){ - plotdt %>% extract(strand=='+', tmp := extend) - plotdt %>% extract(strand=='+', extend := extstart) - plotdt %>% extract(strand=='+', extstart := tmp)} - plotdt %>% extract(, tmp := NULL) -# Alpha and Size - if (!is.null(alpha_var)) plotdt[[alpha_var]] %<>% cut( - c(-Inf, 0, Inf), c('0', '1+')) - if (!is.null(size_var)) plotdt[[size_var]] %<>% cut( - c(-Inf, 0.3, 0.5, Inf), - c('0+', '0.3+', '0.5+')) -# Return - plotdt -} + +#' Karyo/Interval Plot GRanges(List) +#' @param grlist \code{\link[GenomicRanges]{GRanges-class}} +#' @param title plot title +#' @return list +#' @seealso \code{\link{plot_intervals}} +#' @examples +#' # Plot GRanges +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' gr <- bed_to_granges(bedfile, 'mm10', plot = FALSE) +#' plot_karyogram(gr) +#' +#' # Plot GRangesList +#' flanks <- up_flank(gr, stranded=FALSE) +#' grlist <- GenomicRanges::GRangesList(sites = gr, flanks = flanks) +#' plot_karyogram(grlist) +#' @export +plot_karyogram <- function( + grlist, + title = unique(genome(grlist)) +){ + + # Assert + . <- NULL + if (methods::is(grlist, 'GRanges')){ + grlist <- GenomicRanges::GRangesList(grlist) + } + assert_is_all_of(grlist, 'GRangesList') + + # Extract relevant chromosomes and order them + chroms <- union(seqlevelsInUse(grlist), standardChromosomes(grlist)) + stri_extract <- function(stri, pattern){ + stri %>% extract(stri_detect_regex(., pattern)) + } + chrs1 <- chroms %>% stri_extract('^(chr)?[0-9]$') %>% sort() + chrs2 <- chroms %>% stri_extract('^(chr)?[0-9]{2}$') %>% sort() + chrsXY <- chroms %>% stri_extract('^(chr)?[XY]$') %>% sort() + chrsM <- chroms %>% stri_extract('^(chr)?MT?$') + orderedchrs <- c(chrs1, chrs2, chrsXY, chrsM) %>% + c(sort(setdiff(chroms, .))) + genomeranges <- as(seqinfo(grlist)[orderedchrs], "GRanges") + + # Color + n <- length(grlist) + if (n>0){ + hues <- seq(15, 375, length = n + 1) + colors <- grDevices::hcl(h = hues, l = 65, c = 100)[seq_len(n)] + } + + # Plot + kp <- karyoploteR::plotKaryotype(genomeranges, main = title) + for (i in seq_len(n)){ + karyoploteR::kpPlotRegions(kp, grlist[[i]], col = colors[i]) + } + + # Add legend + if (has_names(grlist)){ + graphics::legend('right', fill = colors, legend = names(grlist)) + } + +} + + +to_megabase <- function(y){ + z <- vector('character', length(y)) + + i <- y>1e6 + z[i] <- paste0(round(y[i]*1e-6), ' M') + + i <- y>1e3 & y<=1e6 + z[i] <- paste0(round(y[i]*1e-3), ' K') + + i <- y<=1e3 + z[i] <- paste0(round(y[i]), 'b') + z %>% set_names(names(y)) +} + + +#' Interval plot GRanges +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param xref gr var used for scaling x axis +#' @param y 'names' (default) or name of gr variable +#' @param nperchrom number (default 1): n head (and n tail) targets +#' shown per chromosome +#' @param nchrom number (default 6) of chromosomes shown +#' @param color_var 'seqnames' (default) or other gr variable +#' @param linetype_var NULL (default) or gr variable mapped to linetype +#' @param size_var NULL (default) or gr variable mapped to size +#' @param facet_var NULL(default) or gr variable mapped to facet +#' @param alpha_var NULL or gr variable mapped to alpha +#' @param title NULL or string: plot title +#' @param scales 'free', 'fixed', etc +#' @return ggplot object +#' @seealso \code{\link{plot_karyogram}} +#' @examples +#' # SRF sites +#' require(magrittr) +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- bed_to_granges(bedfile, 'mm10', plot = FALSE) +#' plot_intervals(targets) +#' +#' # PE targets +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', +#' HBB = 'chr11:5227002:-', +#' HEXA = 'chr15:72346580-72346583:-', +#' CFTR = 'chr7:117559593-117559595:+'), +#' bsgenome) +#' spacers <- find_pe_spacers(gr, bsgenome) +#' plot_intervals(gr) +#' plot_intervals(extend_for_pe(gr)) +#' plot_intervals(spacers) +#' +#' @export +plot_intervals <- function( + gr, xref = 'targetname', y = 'names', nperchrom = 2, nchrom = 4, + color_var = 'targetname', facet_var = 'seqnames', linetype_var = NULL, + size_var = default_size_var(gr), alpha_var = default_alpha_var(gr), + title = NULL, scales= 'free' +){ +# Comply + edge <- targetname <- NULL +# Assert, Import, Comply + assert_is_all_of(gr, 'GRanges') + if (!is.null(color_var)) assert_is_a_string(color_var) + assert_is_subset(color_var, names(as.data.table(gr))) + contig <- .N <- .SD <- seqnames <- start <- NULL + strand <- tmp <- width <- xstart <- xend <- . <- NULL +# Prepare plotdt + plotdt <- prepare_plot_intervals( + gr, xref, y, nperchrom, nchrom, alpha_var, size_var) +# Core Ranges + p <-ggplot( plotdt, + aes_string(x = 'xstart', xend = 'xend', y = 'y', yend = 'y', + color = color_var, linetype = linetype_var, + size = size_var, alpha = alpha_var)) + + facet_wrap(facet_var, scales = scales) + + geom_segment(arrow = arrow(length = unit(0.1, "inches"))) + if (!is.null(alpha_var)) p <- p + + scale_alpha_manual(values = c(`0` = 1, `1+` = 0.3)) + if (!is.null(size_var)) p <- p + + scale_size_manual(values = c(`0+` = 0.1, `0.3+` = 1, `0.5+` = 2)) +# Targets + if (all(c('targetstart', 'targetend') %in% names(mcols(gr)))){ + p <-p + geom_point(aes_string( + x = 'xtargetstart', y = 'y'), shape = '|', size = 4) + + geom_point(aes_string( + x = 'xtargetend', y = 'y'), shape = '|', size = 4)} +# Extensions + if ('extension' %in% names(mcols(gr))){ + p <-p + geom_segment( + aes_string( x = 'extstart', xend = 'extend', size = NULL), + linetype = 'dotted', + arrow = arrow(length = unit(0.1, "inches")))} + p <- p + theme_bw() + xlab(NULL) + ylab(NULL) + ggtitle(title) +# Return + p # print(p) +} + + +default_alpha_var <- function(gr){ + if ('off' %in% names(mcols(gr))) 'off' else NULL +} + +default_size_var <- function(gr){ + if ('Doench2016' %in% names(mcols(gr))) 'Doench2016' else NULL +} + + +head_tail <- function(x, n){ + idx <- x %in% unique( c(head(x, ceiling(n/2)), tail(x, floor(n/2)))) + x[idx] +} + +prepare_plot_intervals <- function( + gr, xref, y, nperchrom, nchrom, alpha_var, size_var +){ +# Comply + edge <- targetname <- xstart <- xend <- width <- NULL + targetstart <- targetend <- xtargetstart <- xtargetend <- NULL + extstart <- primer <- revtranscript <- extension <- tmp <- NULL +# Prepare data.table. Select chromosomes/targets to plot. + plotdt <- data.table::as.data.table(gr) %>% cbind(names = names(gr)) + plotdt %<>% extract(order(seqnames, start)) + plotdt$seqnames %<>% droplevels() + headtailchroms <- head_tail(levels(plotdt$seqnames), nchrom) + plotdt %<>% extract(headtailchroms, on = 'seqnames') + plotdt$seqnames %<>% factor(headtailchroms) + plotdt %<>% extract( # targets + , .SD[targetname %in% head_tail(unique(targetname), nperchrom)], + by = 'seqnames') +# Main ranges + plotdt %>% extract(, y := min(start), by = y) + plotdt %>% extract(, y := factor(format(y, big.mark = " "))) + plotdt %>% extract(, xstart := start-min(start), by = xref) + plotdt %>% extract(, xend := xstart + width) +# Target marks + if (all(c('targetstart', 'targetend') %in% names(mcols(gr)))){ + plotdt %>% extract(, xtargetstart := xstart + targetstart-start) + plotdt %>% extract(, xtargetend := xend + targetend-end )} +# Extensions + if ('extension' %in% names(mcols(gr))){ + plotdt %>% extract(strand=='+', extstart := xstart+18-nchar(primer)[1]) + plotdt %>% extract(strand=='-', + extstart := xend-16-(nchar(revtranscript)[1]-1)) + plotdt %>% extract(, extend := extstart + nchar(extension)[1]-1)} +# Flip for arrow direction + plotdt %>% extract(strand=='-', tmp := xend) + plotdt %>% extract(strand=='-', xend := xstart) + plotdt %>% extract(strand=='-', xstart := tmp) + if ('extension' %in% names(mcols(gr))){ + plotdt %>% extract(strand=='+', tmp := extend) + plotdt %>% extract(strand=='+', extend := extstart) + plotdt %>% extract(strand=='+', extstart := tmp)} + plotdt %>% extract(, tmp := NULL) +# Alpha and Size + if (!is.null(alpha_var)) plotdt[[alpha_var]] %<>% cut( + c(-Inf, 0, Inf), c('0', '1+')) + if (!is.null(size_var)) plotdt[[size_var]] %<>% cut( + c(-Inf, 0.3, 0.5, Inf), + c('0+', '0.3+', '0.5+')) +# Return + plotdt +} diff --git a/R/04_bed_to_granges.R b/R/04_bed_to_granges.R index bbdfb244acb4d7cd22403d35ad8b94fe72f70927..0e4f47cb27700b1a065beeefbb22952abac84f35 100644 --- a/R/04_bed_to_granges.R +++ b/R/04_bed_to_granges.R @@ -1,207 +1,207 @@ - -#============================================================================= -# bed_to_granges -#============================================================================= - - -annotate_granges <- function(gr, txdb){ - - # Assert. Import. Comply. - assert_is_all_of(gr, 'GRanges') - assert_is_all_of(txdb, 'TxDb') - gene_id <- NULL - - # Align seqlevelStyle if required - if (seqlevelsStyle(gr) != seqlevelsStyle(txdb)){ - message("Setting seqlevelsStyle(txdb) <- seqlevelsStyle(gr)") - seqlevelsStyle(txdb) <- seqlevelsStyle(gr) - } - - # Drop seqinfo (to overlap smoothly) - txranges <- GenomicFeatures::genes(txdb) %>% - as.data.table() %>% - extract(seqlevelsInUse(gr), on = 'seqnames') %>% - extract(, c('seqnames', 'start', 'end', 'strand', 'gene_id'), - with = FALSE) %>% - as('GRanges') - - # Overlap - granno <- as.data.table(gr) %>% - as('GRanges') %>% - plyranges::join_overlap_left(txranges) %>% - as.data.table() %>% - extract(!is.na(gene_id) , - gene_id := paste0(gene_id, collapse = ';'), - by = c('seqnames', 'start', 'end', 'strand')) %>% - unique() %>% - as('GRanges') - seqlevels(granno) %<>% setdiff('.') # patch plyranges bug - seqinfo(granno) <- seqinfo(gr) - granno -} - - - -#' Read bedfile into GRanges -#' @param bedfile file path -#' @param genome string: UCSC genome name (e.g. 'mm10') -#' @param txdb NULL (default) or \code{\link[GenomicFeatures]{TxDb-class}} -#' (used for gene annotation) -#' @param do_order TRUE (default) or FALSE: order on seqnames and star? -#' @param plot TRUE (default) or FALSE: plot karyogram? -#' @param verbose TRUE (default) or FALSE -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @seealso \code{\link{char_to_granges}}, \code{\link{genes_to_granges}} -#' @examples -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' (gr <- bed_to_granges(bedfile, genome='mm10')) -#' @export -bed_to_granges <- function( - bedfile, - genome, - txdb = NULL, - do_order = TRUE, - plot = TRUE, - verbose = TRUE -){ - . <- NULL - - # Assert - assert_all_are_existing_files(bedfile) - if (!is.null(txdb)) assert_is_all_of(txdb, 'TxDb') - assert_is_a_bool(do_order) - assert_is_a_bool(plot) - assert_is_a_bool(verbose) - - # Read - if (verbose) cmessage('\tRead %s into GRanges', basename(bedfile)) - gr <- rtracklayer::import.bed(bedfile, genome = genome) - if (verbose) cmessage('\t\t%d ranges on %d chromosomes', - length(gr), length(unique(seqnames(gr)))) - - # Annotate - if (!is.null(txdb)){ - cmessage('\t\tAnnotate with txdb') - gr %<>% annotate_granges(txdb) - } - - # Plot - genome1 <- unique(genome(gr)) - assert_is_scalar(genome1) - title <- paste0(genome1, ': ', basename(bedfile)) - if (plot) plot_karyogram(gr, title) - - # Order - if (do_order) gr %<>% sort(ignore.strand = TRUE) - #%<>% extract( order(seqnames(.), start(.))) - - # Record - names(gr) <- gr$targetname <- make_unique_names(gr, 'T') - gr$targetstart <- GenomicRanges::start(gr) - gr$targetend <- GenomicRanges::end(gr) - - # Return - gr -} - - -#' Convert character vector into GRanges -#' @param x character vector -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' x <- c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+') # ins -#' gr <- char_to_granges(x, bsgenome) -#' plot_intervals(gr, facet_var = c('targetname', 'seqnames')) -#' @seealso \code{\link{bed_to_granges}}, \code{\link{genes_to_granges}} -#' @export -char_to_granges <- function(x, bsgenome){ - gr <- GenomicRanges::GRanges(x, seqinfo = BSgenome::seqinfo(bsgenome)) - names(gr) <- gr$targetname <- make_unique_names(gr, 'T') - gr$targetstart <- GenomicRanges::start(gr) - gr$targetend <- GenomicRanges::end(gr) - gr -} - - - -#' Convert geneids into GRanges -#' @param file Gene identifier file (one per row) -#' @param geneids Gene identifier vector -#' @param complement TRUE (default) or FALSE: add complementary strand? -#' @param txdb \code{\link[GenomicFeatures]{TxDb-class}} or -#' \code{\link[ensembldb]{EnsDb-class}} -#' @param plot TRUE (default) or FALSE -#' @param verbose TRUE (default) or FALSE -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @seealso \code{\link{char_to_granges}}, \code{\link{bed_to_granges}} -#' @examples -#' # Entrez -#' #------- -#' genefile <- system.file('extdata/SRF.entrez', package='multicrispr') -#' geneids <- as.character(read.table(genefile)[[1]]) -#' txdb <- getFromNamespace('TxDb.Mmusculus.UCSC.mm10.knownGene', -#' 'TxDb.Mmusculus.UCSC.mm10.knownGene') -#' (gr <- genes_to_granges(geneids, txdb)) -#' (gr <- genefile_to_granges(genefile, txdb)) -#' -#' # Ensembl -#' #-------- -#' # txdb <- AnnotationHub::AnnotationHub()[["AH75036"]] -#' # genefile <- system.file('extdata/SRF.ensembl', package='multicrispr') -#' # geneids <- as.character(read.table(genefile)[[1]]) -#' # (gr <- genes_to_granges(geneids, txdb)) -#' # (gr <- genefile_to_granges(genefile, txdb)) -#' @export -genes_to_granges <- function( - geneids, - txdb, - complement = TRUE, - plot = TRUE, - verbose = TRUE -){ - - # Assert - assert_is_character(geneids) - assert_is_any_of(txdb, c('TxDb', 'EnsDb')) - assert_is_a_bool(complement) - assert_is_a_bool(plot) - - # Convert - gr <- GenomicFeatures::genes(txdb)[geneids] - if (verbose) cmessage('\t\tConvert %d genes to %d GRanges', - length(geneids), length(gr)) - - # Add complementary strand - if (complement){ - gr %<>% add_inverse_strand(plot = FALSE, verbose = verbose) - } - - # Plot - if (plot) plot_karyogram(gr) - - # Record - names(gr) <- gr$targetname <- make_unique_names(gr, 'T') - gr$targetstart <- GenomicRanges::start(gr) - gr$targetend <- GenomicRanges::end(gr) - - # Return - gr -} - - -#' @rdname genes_to_granges -#' @export -genefile_to_granges <- function(file, txdb, complement = TRUE, plot = TRUE){ - assert_all_are_existing_files(file) - geneids <- read.table(file)[[1]] %>% as.character() - genes_to_granges(geneids, txdb, complement = complement, plot = plot) -} - - + +#============================================================================= +# bed_to_granges +#============================================================================= + + +annotate_granges <- function(gr, txdb){ + + # Assert. Import. Comply. + assert_is_all_of(gr, 'GRanges') + assert_is_all_of(txdb, 'TxDb') + gene_id <- NULL + + # Align seqlevelStyle if required + if (seqlevelsStyle(gr) != seqlevelsStyle(txdb)){ + message("Setting seqlevelsStyle(txdb) <- seqlevelsStyle(gr)") + seqlevelsStyle(txdb) <- seqlevelsStyle(gr) + } + + # Drop seqinfo (to overlap smoothly) + txranges <- GenomicFeatures::genes(txdb) %>% + as.data.table() %>% + extract(seqlevelsInUse(gr), on = 'seqnames') %>% + extract(, c('seqnames', 'start', 'end', 'strand', 'gene_id'), + with = FALSE) %>% + as('GRanges') + + # Overlap + granno <- as.data.table(gr) %>% + as('GRanges') %>% + plyranges::join_overlap_left(txranges) %>% + as.data.table() %>% + extract(!is.na(gene_id) , + gene_id := paste0(gene_id, collapse = ';'), + by = c('seqnames', 'start', 'end', 'strand')) %>% + unique() %>% + as('GRanges') + seqlevels(granno) %<>% setdiff('.') # patch plyranges bug + seqinfo(granno) <- seqinfo(gr) + granno +} + + + +#' Read bedfile into GRanges +#' @param bedfile file path +#' @param genome string: UCSC genome name (e.g. 'mm10') +#' @param txdb NULL (default) or \code{\link[GenomicFeatures]{TxDb-class}} +#' (used for gene annotation) +#' @param do_order TRUE (default) or FALSE: order on seqnames and star? +#' @param plot TRUE (default) or FALSE: plot karyogram? +#' @param verbose TRUE (default) or FALSE +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @seealso \code{\link{char_to_granges}}, \code{\link{genes_to_granges}} +#' @examples +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' (gr <- bed_to_granges(bedfile, genome='mm10')) +#' @export +bed_to_granges <- function( + bedfile, + genome, + txdb = NULL, + do_order = TRUE, + plot = TRUE, + verbose = TRUE +){ + . <- NULL + + # Assert + assert_all_are_existing_files(bedfile) + if (!is.null(txdb)) assert_is_all_of(txdb, 'TxDb') + assert_is_a_bool(do_order) + assert_is_a_bool(plot) + assert_is_a_bool(verbose) + + # Read + if (verbose) cmessage('\tRead %s into GRanges', basename(bedfile)) + gr <- rtracklayer::import.bed(bedfile, genome = genome) + if (verbose) cmessage('\t\t%d ranges on %d chromosomes', + length(gr), length(unique(seqnames(gr)))) + + # Annotate + if (!is.null(txdb)){ + cmessage('\t\tAnnotate with txdb') + gr %<>% annotate_granges(txdb) + } + + # Plot + genome1 <- unique(genome(gr)) + assert_is_scalar(genome1) + title <- paste0(genome1, ': ', basename(bedfile)) + if (plot) plot_karyogram(gr, title) + + # Order + if (do_order) gr %<>% sort(ignore.strand = TRUE) + #%<>% extract( order(seqnames(.), start(.))) + + # Record + names(gr) <- gr$targetname <- make_unique_names(gr, 'T') + gr$targetstart <- GenomicRanges::start(gr) + gr$targetend <- GenomicRanges::end(gr) + + # Return + gr +} + + +#' Convert character vector into GRanges +#' @param x character vector +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' x <- c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+') # ins +#' gr <- char_to_granges(x, bsgenome) +#' plot_intervals(gr, facet_var = c('targetname', 'seqnames')) +#' @seealso \code{\link{bed_to_granges}}, \code{\link{genes_to_granges}} +#' @export +char_to_granges <- function(x, bsgenome){ + gr <- GenomicRanges::GRanges(x, seqinfo = BSgenome::seqinfo(bsgenome)) + names(gr) <- gr$targetname <- make_unique_names(gr, 'T') + gr$targetstart <- GenomicRanges::start(gr) + gr$targetend <- GenomicRanges::end(gr) + gr +} + + + +#' Convert geneids into GRanges +#' @param file Gene identifier file (one per row) +#' @param geneids Gene identifier vector +#' @param complement TRUE (default) or FALSE: add complementary strand? +#' @param txdb \code{\link[GenomicFeatures]{TxDb-class}} or +#' \code{\link[ensembldb]{EnsDb-class}} +#' @param plot TRUE (default) or FALSE +#' @param verbose TRUE (default) or FALSE +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @seealso \code{\link{char_to_granges}}, \code{\link{bed_to_granges}} +#' @examples +#' # Entrez +#' #------- +#' genefile <- system.file('extdata/SRF.entrez', package='multicrispr') +#' geneids <- as.character(read.table(genefile)[[1]]) +#' txdb <- getFromNamespace('TxDb.Mmusculus.UCSC.mm10.knownGene', +#' 'TxDb.Mmusculus.UCSC.mm10.knownGene') +#' (gr <- genes_to_granges(geneids, txdb)) +#' (gr <- genefile_to_granges(genefile, txdb)) +#' +#' # Ensembl +#' #-------- +#' # txdb <- AnnotationHub::AnnotationHub()[["AH75036"]] +#' # genefile <- system.file('extdata/SRF.ensembl', package='multicrispr') +#' # geneids <- as.character(read.table(genefile)[[1]]) +#' # (gr <- genes_to_granges(geneids, txdb)) +#' # (gr <- genefile_to_granges(genefile, txdb)) +#' @export +genes_to_granges <- function( + geneids, + txdb, + complement = TRUE, + plot = TRUE, + verbose = TRUE +){ + + # Assert + assert_is_character(geneids) + assert_is_any_of(txdb, c('TxDb', 'EnsDb')) + assert_is_a_bool(complement) + assert_is_a_bool(plot) + + # Convert + gr <- GenomicFeatures::genes(txdb)[geneids] + if (verbose) cmessage('\t\tConvert %d genes to %d GRanges', + length(geneids), length(gr)) + + # Add complementary strand + if (complement){ + gr %<>% add_inverse_strand(plot = FALSE, verbose = verbose) + } + + # Plot + if (plot) plot_karyogram(gr) + + # Record + names(gr) <- gr$targetname <- make_unique_names(gr, 'T') + gr$targetstart <- GenomicRanges::start(gr) + gr$targetend <- GenomicRanges::end(gr) + + # Return + gr +} + + +#' @rdname genes_to_granges +#' @export +genefile_to_granges <- function(file, txdb, complement = TRUE, plot = TRUE){ + assert_all_are_existing_files(file) + geneids <- read.table(file)[[1]] %>% as.character() + genes_to_granges(geneids, txdb, complement = complement, plot = plot) +} + + diff --git a/R/05_manipulate_ranges.R b/R/05_manipulate_ranges.R index 754e90efc6c430b7af4d9e17c47a60396f2670af..8b2fe81a1484c7a6f824c0c24e276a7d6a121ede 100644 --- a/R/05_manipulate_ranges.R +++ b/R/05_manipulate_ranges.R @@ -1,390 +1,390 @@ -#' Add sequence to GRanges -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param verbose TRUE or FALSE (default) -#' @param as.character TRUE (default) or FALSE -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' (gr %<>% add_seq(bsgenome)) -#' -#' # TFBS example -#' #------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -#' gr <- bed_to_granges(bedfile, 'mm10') -#' (gr %<>% add_seq(bsgenome)) -#' @export -add_seq <- function(gr, bsgenome, verbose = FALSE, as.character = TRUE){ - - # Assert - assert_is_all_of(gr, 'GRanges') - assert_is_all_of(bsgenome, 'BSgenome') - - # Message - if (verbose) cmessage('\tAdd seq') - - # Align seqlevelsStyle if required - if (seqlevelsStyle(bsgenome)[1] != seqlevelsStyle(gr)[1]){ - cmessage("\t\t\tSet seqlevelStyle(bsgenome) <- seqlevelStyle(gr)") - seqlevelsStyle(bsgenome)[1] <- seqlevelsStyle(gr)[1] - } - - # Add seq - gr$seq <- unname(BSgenome::getSeq( - bsgenome, - names = seqnames(gr), - start = start(gr), - end = end(gr), - strand = strand(gr), - as.character = as.character)) - - # Return - gr -} - - -summarize_loci <- function(gr){ - sprintf('%s:%s-%s', - as.character(seqnames(gr)), - start(gr), - end(gr)) -} - -#' Extend or Flank GRanges -#' -#' Returns extensions, upstream flanks, or downstream flanks -#' -#' \code{up_flank} returns upstream flanks, in relation to start(gr). -#' \code{down_flank} returns downstream flanks, in relation to end(gr). -#' \code{extend} returns extensions, in relation to start(gr) and end(gr) -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param start (pos or neg) number: relative start position (see details) -#' @param end (pos or neg) number: relative end position (see details) -#' @param strandaware TRUE (default) or FALSE: consider strand information? -#' @param bsgenome NULL (default) or \code{\link[BSgenome]{BSgenome-class}}. -#' Required to update gr$seq if present. -#' @param verbose TRUE or FALSE (default) -#' @param plot TRUE or FALSE (default) -#' @param linetype_var string: gr var mapped to linetype -#' @param ... passed to \code{\link{plot_intervals}} -#' @return a \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'),# ins -#' bsgenome = bsgenome) -#' gr %>% up_flank( -22, -1, plot=TRUE, facet_var=c('targetname', 'seqnames')) -#' gr %>% up_flank( -22, -1, plot=TRUE, strandaware=FALSE) -#' gr %>% down_flank(+1, +22, plot=TRUE) -#' gr %>% down_flank(+1, +22, plot=TRUE, strandaware=FALSE) -#' gr %>% extend( -10, +20, plot=TRUE) -#' gr %>% extend( -10, +20, plot=TRUE, strandaware=FALSE) -#' -#' # TFBS example -#' #------------- -#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -#' gr <- bed_to_granges(bedfile, genome = 'mm10') -#' gr %>% extend(plot = TRUE) -#' gr %>% up_flank(plot = TRUE) -#' gr %>% down_flank(plot = TRUE) -#' @export -up_flank <- function( - gr, start = -200, end = -1, strandaware = TRUE, bsgenome = NULL, - verbose = FALSE, plot = FALSE, linetype_var = 'set', ... -){ - # Assert - assert_is_all_of(gr, 'GRanges') - assert_is_a_number(start) - assert_is_a_number(end) - assert_is_a_bool(verbose) - - # Record - newgr <- gr - shift <- sprintf('(%s%d,%s%d)', - csign(start), abs(start), csign(end), abs(end)) - txt <- sprintf('\t\t%d%supstream %s flanks', - length(newgr), - ifelse(!strandaware, ' (strandagnostic) ', ' '), - shift) - - # Flank - GenomicRanges::start(newgr) <- GenomicRanges::start(gr) + start - GenomicRanges::end(newgr) <- GenomicRanges::start(gr) + end - if (strandaware){ - idx <- as.logical(strand(newgr)=='-') - # do not switch following lines to avoid integrity errors ! - GenomicRanges::end( newgr)[idx] <- GenomicRanges::end(gr)[idx] - start - GenomicRanges::start(newgr)[idx] <- GenomicRanges::end(gr)[idx] - end - } - - # Add seq - if ('seq' %in% names(mcols(gr))){ - assert_is_all_of(bsgenome, 'BSgenome') - newgr %<>% add_seq(bsgenome) - } - - # Plot, Message, Return - if (plot){ - gr$set <- 'original' - newgr$set <- 'upstream flanks' - allgr <- c(gr, newgr) - allgr$set %<>% factor(c('original', 'upstream flanks')) - print(plot_intervals( - allgr, linetype_var = linetype_var, ..., title = txt)) - newgr$set <- NULL - } - if (verbose) message(txt) - newgr -} - - -#' @rdname up_flank -#' @export -down_flank <- function( - gr, start = 1, end = 200, strandaware = TRUE, bsgenome = NULL, - verbose = FALSE, plot = FALSE, linetype_var = 'set', ... -){ - # Assert - assert_is_any_of(gr, 'GRanges') - assert_is_a_number(start) - assert_is_a_number(end) - assert_is_a_bool(verbose) - - # Record - newgr <- gr - shift <- sprintf('(%s%d,%s%d)', - csign(start), abs(start), csign(end), abs(end)) - txt <- sprintf('\t\t%d%sdownstream %s flanks', - length(newgr), - ifelse(!strandaware, ' (strandagnostic) ', ' '), - shift) - - # Flank - GenomicRanges::end(newgr) <- GenomicRanges::end(gr) + end - GenomicRanges::start(newgr) <- GenomicRanges::end(gr) + start - if (strandaware){ - idx <- as.logical(strand(newgr)=='-') - GenomicRanges::start(newgr)[idx] <- GenomicRanges::start(gr)[idx]-end - GenomicRanges::end( newgr)[idx] <- GenomicRanges::start(gr)[idx]-start - } - - # Add seq - if ('seq' %in% names(mcols(gr))){ - assert_is_all_of(bsgenome, 'BSgenome') - newgr %<>% add_seq(bsgenome) - } - - # Plot, Message, Return - if (plot){ - gr$set <- 'original' - newgr$set <- 'downstream flanks' - allgr <- c(gr, newgr) - allgr$set %<>% factor(c('original', 'downstream flanks')) - print(plot_intervals( - allgr, linetype_var = linetype_var, ..., title=txt)) - newgr$set <- NULL - } - if (verbose) message(txt) - newgr -} - - -#' @rdname up_flank -#' @export -extend <- function( - gr, start = -22, end = 22, strandaware = TRUE, bsgenome = NULL, - verbose = FALSE, plot = FALSE, linetype_var = 'set', ... -){ - - # Assert - assert_is_any_of(gr, 'GRanges') - assert_is_a_number(start) - assert_is_a_number(end) - assert_is_a_bool(verbose) - - # Record - newgr <- gr - shift <- sprintf('(%s%d,%s%d)', - csign(start), abs(start), csign(end), abs(end)) - txt <- sprintf('\t\t%d%sextensions %s', - length(newgr), - ifelse(!strandaware, ' (strandagnostic) ', ' '), - shift) - - # Extend - GenomicRanges::start(newgr) <- GenomicRanges::start(newgr) + start - GenomicRanges::end( newgr) <- GenomicRanges::end( newgr) + end - if (strandaware){ - idx <- as.logical(strand(newgr)=='-') - GenomicRanges::start(newgr)[idx] <- GenomicRanges::start(gr)[idx] - end - GenomicRanges::end( newgr)[idx] <- GenomicRanges::end(gr)[idx] - start - } - - # Add seq - if ('seq' %in% names(mcols(gr))){ - assert_is_all_of(bsgenome, 'BSgenome') - newgr %<>% add_seq(bsgenome) - } - - # Plot, Message, Return - if (plot){ - gr$set <- 'original' - newgr$set <- 'extensions' - allgr <- c(gr, newgr) - allgr$set %<>% factor(c('original', 'extensions')) - print(plot_intervals( - allgr, linetype_var = linetype_var, ..., title=txt)) - newgr$set <- NULL - } - if (verbose) message(txt) - newgr - -} - - - - -#' Add inverse strand -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param verbose TRUE or FALSE (default) -#' @param plot TRUE or FALSE (default) -#' @param ... \code{\link{plot_intervals}} arguments -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' add_inverse_strand(gr, plot = TRUE) -#' # TFBS example -#' #------------- -#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -#' gr <- bed_to_granges(bedfile, genome = 'mm10') -#' add_inverse_strand(gr) -#' @export -add_inverse_strand <- function(gr, verbose = FALSE, plot = FALSE, ...){ - - # Assert - assert_is_all_of(gr, 'GRanges') - - # Invert - revcomps <- invertStrand(gr) - if ('seq' %in% names(mcols(gr))){ - revcomps$seq <- as.character(Biostrings::reverseComplement( - DNAStringSet(gr$seq))) - } - - # Concatenate - newgr <- c(gr, revcomps) - newgr %<>% unique() - txt <- sprintf('\t\t%d ranges after adding inverse strands', length(newgr)) - - # Sort - newgr <- sortSeqlevels(newgr) - newgr <- GenomicRanges::sort(newgr, ignore.strand = TRUE) - names(newgr) %<>% paste0('_', - c('+'='f', '-'='r')[as.character(strand(newgr))]) - - # Plot - if (plot){ - gr$set <- 'original' - revcomps$set <- 'inverse' - print(plot_intervals( - c(gr, revcomps), - color_var = 'set', linetype_var = 'set', ..., title = txt)) - gr$set <- NULL - } - - # Message - if (verbose) cmessage(txt) - newgr -} - -#' Double flank -#' -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param upstart upstream flank start in relation to start(gr) -#' @param upend upstream flank end in relation to start(gr) -#' @param downstart downstream flank start in relation to end(gr) -#' @param downend downstream flank end in relation to end(gr) -#' @param strandaware TRUE (default) or FALSE -#' @param plot TRUE or FALSE (default) -#' @param linetype_var gr var mapped to linetype -#' @param ... passed to plot_intervals -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # Prime Editing example -#' #---------------------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' double_flank(gr, -10, -1, +1, +20, plot = TRUE) -#' -#' # TFBS example -#' #------------- -#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -#' gr <- bed_to_granges(bedfile, genome = 'mm10', plot = FALSE) -#' double_flank(gr, plot = TRUE) -#' @export -double_flank <- function( - gr, - upstart = -200, - upend = -1, - downstart = 1, - downend = 200, - strandaware = TRUE, - plot = FALSE, - linetype_var = 'set', - ... -){ - - # Up flank, down flank, concatenate - up <- up_flank(gr, upstart, upend, strandaware, verbose = FALSE) - dn <- down_flank(gr, downstart, downend, strandaware, verbose = FALSE) - names(up) %<>% paste0('_u') # ensure unique names - names(dn) %<>% paste0('_d') - newgr <- c(up, dn) - txt <- sprintf('\t\t%d flank ranges: %d up + %d down', - length(newgr), length(up), length(dn)) - - # Plot - if (plot){ - gr$set <- 'original' - up$set <- 'upstream flank' - dn$set <- 'downstream flank' - allgr <- c(gr, up, dn) - allgr$set %<>% factor( - c('original', 'upstream flank', 'downstream flank')) - print(plot_intervals(allgr, linetype_var = linetype_var, title = txt, - y = 'targetname', ...)) - } - - # Return - message(txt) - newgr -} - - +#' Add sequence to GRanges +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param verbose TRUE or FALSE (default) +#' @param as.character TRUE (default) or FALSE +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' (gr %<>% add_seq(bsgenome)) +#' +#' # TFBS example +#' #------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +#' gr <- bed_to_granges(bedfile, 'mm10') +#' (gr %<>% add_seq(bsgenome)) +#' @export +add_seq <- function(gr, bsgenome, verbose = FALSE, as.character = TRUE){ + + # Assert + assert_is_all_of(gr, 'GRanges') + assert_is_all_of(bsgenome, 'BSgenome') + + # Message + if (verbose) cmessage('\tAdd seq') + + # Align seqlevelsStyle if required + if (seqlevelsStyle(bsgenome)[1] != seqlevelsStyle(gr)[1]){ + cmessage("\t\t\tSet seqlevelStyle(bsgenome) <- seqlevelStyle(gr)") + seqlevelsStyle(bsgenome)[1] <- seqlevelsStyle(gr)[1] + } + + # Add seq + gr$seq <- unname(BSgenome::getSeq( + bsgenome, + names = seqnames(gr), + start = start(gr), + end = end(gr), + strand = strand(gr), + as.character = as.character)) + + # Return + gr +} + + +summarize_loci <- function(gr){ + sprintf('%s:%s-%s', + as.character(seqnames(gr)), + start(gr), + end(gr)) +} + +#' Extend or Flank GRanges +#' +#' Returns extensions, upstream flanks, or downstream flanks +#' +#' \code{up_flank} returns upstream flanks, in relation to start(gr). +#' \code{down_flank} returns downstream flanks, in relation to end(gr). +#' \code{extend} returns extensions, in relation to start(gr) and end(gr) +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param start (pos or neg) number: relative start position (see details) +#' @param end (pos or neg) number: relative end position (see details) +#' @param strandaware TRUE (default) or FALSE: consider strand information? +#' @param bsgenome NULL (default) or \code{\link[BSgenome]{BSgenome-class}}. +#' Required to update gr$seq if present. +#' @param verbose TRUE or FALSE (default) +#' @param plot TRUE or FALSE (default) +#' @param linetype_var string: gr var mapped to linetype +#' @param ... passed to \code{\link{plot_intervals}} +#' @return a \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'),# ins +#' bsgenome = bsgenome) +#' gr %>% up_flank( -22, -1, plot=TRUE, facet_var=c('targetname', 'seqnames')) +#' gr %>% up_flank( -22, -1, plot=TRUE, strandaware=FALSE) +#' gr %>% down_flank(+1, +22, plot=TRUE) +#' gr %>% down_flank(+1, +22, plot=TRUE, strandaware=FALSE) +#' gr %>% extend( -10, +20, plot=TRUE) +#' gr %>% extend( -10, +20, plot=TRUE, strandaware=FALSE) +#' +#' # TFBS example +#' #------------- +#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +#' gr <- bed_to_granges(bedfile, genome = 'mm10') +#' gr %>% extend(plot = TRUE) +#' gr %>% up_flank(plot = TRUE) +#' gr %>% down_flank(plot = TRUE) +#' @export +up_flank <- function( + gr, start = -200, end = -1, strandaware = TRUE, bsgenome = NULL, + verbose = FALSE, plot = FALSE, linetype_var = 'set', ... +){ + # Assert + assert_is_all_of(gr, 'GRanges') + assert_is_a_number(start) + assert_is_a_number(end) + assert_is_a_bool(verbose) + + # Record + newgr <- gr + shift <- sprintf('(%s%d,%s%d)', + csign(start), abs(start), csign(end), abs(end)) + txt <- sprintf('\t\t%d%supstream %s flanks', + length(newgr), + ifelse(!strandaware, ' (strandagnostic) ', ' '), + shift) + + # Flank + GenomicRanges::start(newgr) <- GenomicRanges::start(gr) + start + GenomicRanges::end(newgr) <- GenomicRanges::start(gr) + end + if (strandaware){ + idx <- as.logical(strand(newgr)=='-') + # do not switch following lines to avoid integrity errors ! + GenomicRanges::end( newgr)[idx] <- GenomicRanges::end(gr)[idx] - start + GenomicRanges::start(newgr)[idx] <- GenomicRanges::end(gr)[idx] - end + } + + # Add seq + if ('seq' %in% names(mcols(gr))){ + assert_is_all_of(bsgenome, 'BSgenome') + newgr %<>% add_seq(bsgenome) + } + + # Plot, Message, Return + if (plot){ + gr$set <- 'original' + newgr$set <- 'upstream flanks' + allgr <- c(gr, newgr) + allgr$set %<>% factor(c('original', 'upstream flanks')) + print(plot_intervals( + allgr, linetype_var = linetype_var, ..., title = txt)) + newgr$set <- NULL + } + if (verbose) message(txt) + newgr +} + + +#' @rdname up_flank +#' @export +down_flank <- function( + gr, start = 1, end = 200, strandaware = TRUE, bsgenome = NULL, + verbose = FALSE, plot = FALSE, linetype_var = 'set', ... +){ + # Assert + assert_is_any_of(gr, 'GRanges') + assert_is_a_number(start) + assert_is_a_number(end) + assert_is_a_bool(verbose) + + # Record + newgr <- gr + shift <- sprintf('(%s%d,%s%d)', + csign(start), abs(start), csign(end), abs(end)) + txt <- sprintf('\t\t%d%sdownstream %s flanks', + length(newgr), + ifelse(!strandaware, ' (strandagnostic) ', ' '), + shift) + + # Flank + GenomicRanges::end(newgr) <- GenomicRanges::end(gr) + end + GenomicRanges::start(newgr) <- GenomicRanges::end(gr) + start + if (strandaware){ + idx <- as.logical(strand(newgr)=='-') + GenomicRanges::start(newgr)[idx] <- GenomicRanges::start(gr)[idx]-end + GenomicRanges::end( newgr)[idx] <- GenomicRanges::start(gr)[idx]-start + } + + # Add seq + if ('seq' %in% names(mcols(gr))){ + assert_is_all_of(bsgenome, 'BSgenome') + newgr %<>% add_seq(bsgenome) + } + + # Plot, Message, Return + if (plot){ + gr$set <- 'original' + newgr$set <- 'downstream flanks' + allgr <- c(gr, newgr) + allgr$set %<>% factor(c('original', 'downstream flanks')) + print(plot_intervals( + allgr, linetype_var = linetype_var, ..., title=txt)) + newgr$set <- NULL + } + if (verbose) message(txt) + newgr +} + + +#' @rdname up_flank +#' @export +extend <- function( + gr, start = -22, end = 22, strandaware = TRUE, bsgenome = NULL, + verbose = FALSE, plot = FALSE, linetype_var = 'set', ... +){ + + # Assert + assert_is_any_of(gr, 'GRanges') + assert_is_a_number(start) + assert_is_a_number(end) + assert_is_a_bool(verbose) + + # Record + newgr <- gr + shift <- sprintf('(%s%d,%s%d)', + csign(start), abs(start), csign(end), abs(end)) + txt <- sprintf('\t\t%d%sextensions %s', + length(newgr), + ifelse(!strandaware, ' (strandagnostic) ', ' '), + shift) + + # Extend + GenomicRanges::start(newgr) <- GenomicRanges::start(newgr) + start + GenomicRanges::end( newgr) <- GenomicRanges::end( newgr) + end + if (strandaware){ + idx <- as.logical(strand(newgr)=='-') + GenomicRanges::start(newgr)[idx] <- GenomicRanges::start(gr)[idx] - end + GenomicRanges::end( newgr)[idx] <- GenomicRanges::end(gr)[idx] - start + } + + # Add seq + if ('seq' %in% names(mcols(gr))){ + assert_is_all_of(bsgenome, 'BSgenome') + newgr %<>% add_seq(bsgenome) + } + + # Plot, Message, Return + if (plot){ + gr$set <- 'original' + newgr$set <- 'extensions' + allgr <- c(gr, newgr) + allgr$set %<>% factor(c('original', 'extensions')) + print(plot_intervals( + allgr, linetype_var = linetype_var, ..., title=txt)) + newgr$set <- NULL + } + if (verbose) message(txt) + newgr + +} + + + + +#' Add inverse strand +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param verbose TRUE or FALSE (default) +#' @param plot TRUE or FALSE (default) +#' @param ... \code{\link{plot_intervals}} arguments +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' add_inverse_strand(gr, plot = TRUE) +#' # TFBS example +#' #------------- +#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +#' gr <- bed_to_granges(bedfile, genome = 'mm10') +#' add_inverse_strand(gr) +#' @export +add_inverse_strand <- function(gr, verbose = FALSE, plot = FALSE, ...){ + + # Assert + assert_is_all_of(gr, 'GRanges') + + # Invert + revcomps <- invertStrand(gr) + if ('seq' %in% names(mcols(gr))){ + revcomps$seq <- as.character(Biostrings::reverseComplement( + DNAStringSet(gr$seq))) + } + + # Concatenate + newgr <- c(gr, revcomps) + newgr %<>% unique() + txt <- sprintf('\t\t%d ranges after adding inverse strands', length(newgr)) + + # Sort + newgr <- sortSeqlevels(newgr) + newgr <- GenomicRanges::sort(newgr, ignore.strand = TRUE) + names(newgr) %<>% paste0('_', + c('+'='f', '-'='r')[as.character(strand(newgr))]) + + # Plot + if (plot){ + gr$set <- 'original' + revcomps$set <- 'inverse' + print(plot_intervals( + c(gr, revcomps), + color_var = 'set', linetype_var = 'set', ..., title = txt)) + gr$set <- NULL + } + + # Message + if (verbose) cmessage(txt) + newgr +} + +#' Double flank +#' +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param upstart upstream flank start in relation to start(gr) +#' @param upend upstream flank end in relation to start(gr) +#' @param downstart downstream flank start in relation to end(gr) +#' @param downend downstream flank end in relation to end(gr) +#' @param strandaware TRUE (default) or FALSE +#' @param plot TRUE or FALSE (default) +#' @param linetype_var gr var mapped to linetype +#' @param ... passed to plot_intervals +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # Prime Editing example +#' #---------------------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' double_flank(gr, -10, -1, +1, +20, plot = TRUE) +#' +#' # TFBS example +#' #------------- +#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +#' gr <- bed_to_granges(bedfile, genome = 'mm10', plot = FALSE) +#' double_flank(gr, plot = TRUE) +#' @export +double_flank <- function( + gr, + upstart = -200, + upend = -1, + downstart = 1, + downend = 200, + strandaware = TRUE, + plot = FALSE, + linetype_var = 'set', + ... +){ + + # Up flank, down flank, concatenate + up <- up_flank(gr, upstart, upend, strandaware, verbose = FALSE) + dn <- down_flank(gr, downstart, downend, strandaware, verbose = FALSE) + names(up) %<>% paste0('_u') # ensure unique names + names(dn) %<>% paste0('_d') + newgr <- c(up, dn) + txt <- sprintf('\t\t%d flank ranges: %d up + %d down', + length(newgr), length(up), length(dn)) + + # Plot + if (plot){ + gr$set <- 'original' + up$set <- 'upstream flank' + dn$set <- 'downstream flank' + allgr <- c(gr, up, dn) + allgr$set %<>% factor( + c('original', 'upstream flank', 'downstream flank')) + print(plot_intervals(allgr, linetype_var = linetype_var, title = txt, + y = 'targetname', ...)) + } + + # Return + message(txt) + newgr +} + + diff --git a/R/06_find_pe_spacers.R b/R/06_find_pe_spacers.R index 41f789e115120391eb7f0eb480470ab4caacd849..6f8b6b9113ec3b7a096ae477b3b395573fed87a0 100644 --- a/R/06_find_pe_spacers.R +++ b/R/06_find_pe_spacers.R @@ -1,247 +1,247 @@ - -cextract1 <- function(y) y[, 1] %>% paste0(collapse=';') -cextract2 <- function(y) y[, 2] %>% paste0(collapse=';') -vextract1 <- function(z) vapply(z, cextract1, character(1)) -vextract2 <- function(z) vapply(z, cextract2, character(1)) - -copy <- function( - gr, - start = GenomicRanges::start(gr), - end = GenomicRanges::end(gr), - strand = GenomicRanges::strand(gr), - ... -){ - newgr <- gr - GenomicRanges::start(gr) <- start - GenomicRanges::end(gr) <- end - strand(gr) <- strand - - dots_list <- list(...) - for (mvar in names(dots_list)) mcols(gr)[[mvar]] <- dots_list[[mvar]] - gr -} - -#' Extend prime editing target to find GG sites -#' -#' Extend prime editing target to find GG sites in accessible neighbourhood -#' -#' Extends each target range to the area in which to search for a prime editing -#' GG duplet, as shown in the sketch below. -#' -#' ===============> -#' ----GG---------> -#' ----GG---------> -#' ** -#' <---------GG--- -#' <---------GG---- -#' <=============== -#' -#' @param gr target \code{\link[GenomicRanges]{GRanges-class}} -#' @param nrt n RT nucleotides (default 16, recommended 10-16) -#' @param plot TRUE or FALSE (default) -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' extend_pe_to_gg(gr, plot = TRUE) -#' @export -extend_pe_to_gg <- function(gr, nrt=16, plot = FALSE){ - - # Extend - fw <- copy(gr, strand='+', start = end(gr) - nrt + 5, end = start(gr) + 5) - rv <- copy(gr, strand='-', start = end(gr) - 5, end = start(gr) + nrt - 5) - #fw$tstart <- rv$tstart <- start(gr) - #fw$tend <- rv$tend <- end(gr) - #fw$tstrand <- rv$tstrand <- strand(gr) - ext <- sort(c(fw, rv)) - - # Plot - if (plot){ - gr$set <- 'targets' - fw$set <- 'possible GG of fwd strand' - rv$set <- 'possible GG on rev strand' - plot_intervals(c(gr, fw, rv), color_var = 'set', y = 'set') - } - - # Return - ext -} - - -#' Find GG -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' gr %<>% extend_pe_to_gg(plot = TRUE) %>% add_seq(bsgenome) -#' find_gg(gr) -#' @export -find_gg <- function(gr){ - - substart <- subend <- windowstart <- windowend <- NULL - - res <- stri_locate_all_fixed(gr$seq, 'GG', overlap=TRUE) - gr$substart <- vextract1(res) - gr$subend <- vextract2(res) - - # Rm GG-free gr - idx <- gr$substart == 'NA' - if (sum(idx)>0) gr %<>% extract(!idx) - - # Identify GG sites - gg_dt <- as.data.table(gr) %>% - setnames(c('start', 'end'), c('windowstart', 'windowend')) %>% - separate_rows(substart, subend) %>% - data.table() %>% - extract(, substart := as.numeric(substart)) %>% - extract(, subend := as.numeric(subend)) %>% - # extract(, seq := substr(seq, substart, subend)) %>% - extract(strand=='+', start := windowstart + substart - 1) %>% - extract(strand=='+', end := windowstart + subend - 1) %>% - extract(strand=='-', end := windowend - substart + 1) %>% - extract(strand=='-', start := windowend - subend + 1) %>% - extract() - gg_dt %<>% setorderv(c('seqnames', 'start', 'strand')) - gg_dt[, c('windowstart', 'windowend', 'seq', 'substart', 'subend') := NULL] - gg_ranges <- GRanges(gg_dt, seqinfo = seqinfo(gr)) - #gg_ranges %<>% add_seq(bsgenome, verbose = FALSE) - return(gg_ranges) -} - - -#' Find prime editing spacers -#' -#' Find prime editing spacers around target ranges -#' -#' Below the architecture of a prime editing site. -#' Edits can be performed anywhere in the revtranscript area. -#' -#' spacer pam -#' --------------------=== -#' primer revtranscript -#' -------------================ -#' 1..............17....GG.......... -#' .....................CC.......... -#' ----------extension---------- -#' -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param edits character vector: desired edits on '+' strand. -#' If named, names should be identical to those of \code{gr} -#' @param nprimer n primer nucleotides (default 13, max 17) -#' @param nrt n rev transcr nucleotides (default 16, recomm. 10-16) -#' @param plot TRUE (default) or FALSE -#' @return \code{\link[GenomicRanges]{GRanges-class}} with PE spacer ranges -#' Each prime editing range is defined in terms of its N20NGG spacer. -#' Additionally, three sequence mcols are returned: -#' * spacer: N20 spacers -#' * pam: NGG PAMs -#' * 3pext: 3' extension of gRNA (RTtemplate + primerbindingsite) -#' @examples -#' # Find PE spacers for 4 clinically relevant loci (Anzalone et al, 2019) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c( -#' PRNP = 'chr20:4699600:+', # snp: prion disease -#' HBB = 'chr11:5227002:-', # snp: sickle cell anemia -#' HEXA = 'chr15:72346580-72346583:-', # del: tay sachs disease -#' CFTR = 'chr7:117559593-117559595:+'), # ins: cystic fibrosis -#' bsgenome) -#' find_pe_spacers(gr, bsgenome) -#' find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE) -#' -#' # Edit PRNP locus for resistance against prion disease (Anzalone et al, 2019) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges('chr20:4699600:+', bsgenome) -#' find_pe_spacers(gr, bsgenome) -#' find_pe_spacers(gr, bsgenome, edits = 'T') -#' @seealso \code{\link{find_spacers}} to find standard crispr sites -#' @export -find_pe_spacers <- function(gr, bsgenome, edits = get_plus_seq(bsgenome, gr), - nprimer = 13, nrt = 16, plot = TRUE){ - - # Assert - assert_is_all_of(gr, 'GRanges') - assert_is_all_of(bsgenome, 'BSgenome') - assert_is_character(edits) - assert_all_are_matching_regex(edits, '^[ACGTacgt]+$') - assert_are_same_length(gr, edits) - if (has_names(edits)) assert_are_identical(names(gr), names(edits)) - assert_is_a_number(nprimer) - assert_is_a_number(nrt) - assert_all_are_less_than(nprimer, 17) - - # Find GG in nrt window around target site - gr %<>% name_uniquely(); names(edits) <- names(gr) - gg <- gr %>% extend_pe_to_gg(nrt) %>% add_seq(bsgenome) %>% find_gg() - names(gg) <- gg$crisprname <- uniquify(gg$targetname) - - # Extract from these other components - bs <- bsgenome; invstr <- invertStrand - spacer <- up_flank(gg, -21, -2) %>% add_seq(bs) - pam <- up_flank(gg, -1, +1) %>% add_seq(bs) - primer <- up_flank(gg, -4-nprimer, -5) %>% add_seq(bs) - revtranscript<- up_flank(gg, -4, -5+nrt) %>% add_fixed_seqs(bs, edits) - ext <- up_flank(gg, -4-nprimer, -5+nrt) %>% invertStrand() %>% - add_fixed_seqs(bs, edits) # Revcomp for "-" seqs - # Plot - if (plot){ - spacer$part<-'spacer' - ext$part <- "3' extension" - allranges <- c(spacer, ext) - allranges$part %<>% factor((c("spacer", "3' extension"))) - print(plot_intervals(allranges, y = 'crisprname', linetype_var = 'part', - facet_var = c('seqnames', 'targetname'))) - spacer$part <- NULL - } - - # Add sequences and return - names(mcols(spacer)) %<>% stri_replace_first_fixed('seq', 'crisprspacer') - spacer$crisprpam <- pam$seq - spacer$primer <- primer$seq - spacer$revtranscript <- revtranscript$seq - spacer$extension <- ext$seq - spacer -} - -add_fixed_seqs <- function(gr, bsgenome, edits){ - # Get '+' seq - gr$seq <- get_plus_seq(bsgenome, gr) - substr(gr$seq, gr$targetstart - start(gr)+1, - gr$targetend - start(gr)+1) <- edits[gr$targetname] - gr$seq[as.logical(strand(gr)=='-')] %<>% revcomp() - gr -} - -get_plus_seq <- function(bsgenome, gr){ - seqs1 <- BSgenome::getSeq(bsgenome, - seqnames(gr), - start(gr), - end(gr), - strand = '+', - as.character = TRUE) - if (has_names(gr)) names(seqs1) <- names(gr) - seqs1 - -} - - -revcomp <- function(y) y %>% - Biostrings::DNAStringSet() %>% - Biostrings::reverseComplement() %>% - as.character() - + +cextract1 <- function(y) y[, 1] %>% paste0(collapse=';') +cextract2 <- function(y) y[, 2] %>% paste0(collapse=';') +vextract1 <- function(z) vapply(z, cextract1, character(1)) +vextract2 <- function(z) vapply(z, cextract2, character(1)) + +copy <- function( + gr, + start = GenomicRanges::start(gr), + end = GenomicRanges::end(gr), + strand = GenomicRanges::strand(gr), + ... +){ + newgr <- gr + GenomicRanges::start(gr) <- start + GenomicRanges::end(gr) <- end + strand(gr) <- strand + + dots_list <- list(...) + for (mvar in names(dots_list)) mcols(gr)[[mvar]] <- dots_list[[mvar]] + gr +} + +#' Extend prime editing target to find GG sites +#' +#' Extend prime editing target to find GG sites in accessible neighbourhood +#' +#' Extends each target range to the area in which to search for a prime editing +#' GG duplet, as shown in the sketch below. +#' +#' ===============> +#' ----GG---------> +#' ----GG---------> +#' ** +#' <---------GG--- +#' <---------GG---- +#' <=============== +#' +#' @param gr target \code{\link[GenomicRanges]{GRanges-class}} +#' @param nrt n RT nucleotides (default 16, recommended 10-16) +#' @param plot TRUE or FALSE (default) +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' extend_pe_to_gg(gr, plot = TRUE) +#' @export +extend_pe_to_gg <- function(gr, nrt=16, plot = FALSE){ + + # Extend + fw <- copy(gr, strand='+', start = end(gr) - nrt + 5, end = start(gr) + 5) + rv <- copy(gr, strand='-', start = end(gr) - 5, end = start(gr) + nrt - 5) + #fw$tstart <- rv$tstart <- start(gr) + #fw$tend <- rv$tend <- end(gr) + #fw$tstrand <- rv$tstrand <- strand(gr) + ext <- sort(c(fw, rv)) + + # Plot + if (plot){ + gr$set <- 'targets' + fw$set <- 'possible GG of fwd strand' + rv$set <- 'possible GG on rev strand' + plot_intervals(c(gr, fw, rv), color_var = 'set', y = 'set') + } + + # Return + ext +} + + +#' Find GG +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' gr %<>% extend_pe_to_gg(plot = TRUE) %>% add_seq(bsgenome) +#' find_gg(gr) +#' @export +find_gg <- function(gr){ + + substart <- subend <- windowstart <- windowend <- NULL + + res <- stri_locate_all_fixed(gr$seq, 'GG', overlap=TRUE) + gr$substart <- vextract1(res) + gr$subend <- vextract2(res) + + # Rm GG-free gr + idx <- gr$substart == 'NA' + if (sum(idx)>0) gr %<>% extract(!idx) + + # Identify GG sites + gg_dt <- as.data.table(gr) %>% + setnames(c('start', 'end'), c('windowstart', 'windowend')) %>% + separate_rows(substart, subend) %>% + data.table() %>% + extract(, substart := as.numeric(substart)) %>% + extract(, subend := as.numeric(subend)) %>% + # extract(, seq := substr(seq, substart, subend)) %>% + extract(strand=='+', start := windowstart + substart - 1) %>% + extract(strand=='+', end := windowstart + subend - 1) %>% + extract(strand=='-', end := windowend - substart + 1) %>% + extract(strand=='-', start := windowend - subend + 1) %>% + extract() + gg_dt %<>% setorderv(c('seqnames', 'start', 'strand')) + gg_dt[, c('windowstart', 'windowend', 'seq', 'substart', 'subend') := NULL] + gg_ranges <- GRanges(gg_dt, seqinfo = seqinfo(gr)) + #gg_ranges %<>% add_seq(bsgenome, verbose = FALSE) + return(gg_ranges) +} + + +#' Find prime editing spacers +#' +#' Find prime editing spacers around target ranges +#' +#' Below the architecture of a prime editing site. +#' Edits can be performed anywhere in the revtranscript area. +#' +#' spacer pam +#' --------------------=== +#' primer revtranscript +#' -------------================ +#' 1..............17....GG.......... +#' .....................CC.......... +#' ----------extension---------- +#' +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param edits character vector: desired edits on '+' strand. +#' If named, names should be identical to those of \code{gr} +#' @param nprimer n primer nucleotides (default 13, max 17) +#' @param nrt n rev transcr nucleotides (default 16, recomm. 10-16) +#' @param plot TRUE (default) or FALSE +#' @return \code{\link[GenomicRanges]{GRanges-class}} with PE spacer ranges +#' Each prime editing range is defined in terms of its N20NGG spacer. +#' Additionally, three sequence mcols are returned: +#' * spacer: N20 spacers +#' * pam: NGG PAMs +#' * 3pext: 3' extension of gRNA (RTtemplate + primerbindingsite) +#' @examples +#' # Find PE spacers for 4 clinically relevant loci (Anzalone et al, 2019) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c( +#' PRNP = 'chr20:4699600:+', # snp: prion disease +#' HBB = 'chr11:5227002:-', # snp: sickle cell anemia +#' HEXA = 'chr15:72346580-72346583:-', # del: tay sachs disease +#' CFTR = 'chr7:117559593-117559595:+'), # ins: cystic fibrosis +#' bsgenome) +#' find_pe_spacers(gr, bsgenome) +#' find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE) +#' +#' # Edit PRNP locus for resistance against prion disease (Anzalone et al, 2019) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges('chr20:4699600:+', bsgenome) +#' find_pe_spacers(gr, bsgenome) +#' find_pe_spacers(gr, bsgenome, edits = 'T') +#' @seealso \code{\link{find_spacers}} to find standard crispr sites +#' @export +find_pe_spacers <- function(gr, bsgenome, edits = get_plus_seq(bsgenome, gr), + nprimer = 13, nrt = 16, plot = TRUE){ + + # Assert + assert_is_all_of(gr, 'GRanges') + assert_is_all_of(bsgenome, 'BSgenome') + assert_is_character(edits) + assert_all_are_matching_regex(edits, '^[ACGTacgt]+$') + assert_are_same_length(gr, edits) + if (has_names(edits)) assert_are_identical(names(gr), names(edits)) + assert_is_a_number(nprimer) + assert_is_a_number(nrt) + assert_all_are_less_than(nprimer, 17) + + # Find GG in nrt window around target site + gr %<>% name_uniquely(); names(edits) <- names(gr) + gg <- gr %>% extend_pe_to_gg(nrt) %>% add_seq(bsgenome) %>% find_gg() + names(gg) <- gg$crisprname <- uniquify(gg$targetname) + + # Extract from these other components + bs <- bsgenome; invstr <- invertStrand + spacer <- up_flank(gg, -21, -2) %>% add_seq(bs) + pam <- up_flank(gg, -1, +1) %>% add_seq(bs) + primer <- up_flank(gg, -4-nprimer, -5) %>% add_seq(bs) + revtranscript<- up_flank(gg, -4, -5+nrt) %>% add_fixed_seqs(bs, edits) + ext <- up_flank(gg, -4-nprimer, -5+nrt) %>% invertStrand() %>% + add_fixed_seqs(bs, edits) # Revcomp for "-" seqs + # Plot + if (plot){ + spacer$part<-'spacer' + ext$part <- "3' extension" + allranges <- c(spacer, ext) + allranges$part %<>% factor((c("spacer", "3' extension"))) + print(plot_intervals(allranges, y = 'crisprname', linetype_var = 'part', + facet_var = c('seqnames', 'targetname'))) + spacer$part <- NULL + } + + # Add sequences and return + names(mcols(spacer)) %<>% stri_replace_first_fixed('seq', 'crisprspacer') + spacer$crisprpam <- pam$seq + spacer$primer <- primer$seq + spacer$revtranscript <- revtranscript$seq + spacer$extension <- ext$seq + spacer +} + +add_fixed_seqs <- function(gr, bsgenome, edits){ + # Get '+' seq + gr$seq <- get_plus_seq(bsgenome, gr) + substr(gr$seq, gr$targetstart - start(gr)+1, + gr$targetend - start(gr)+1) <- edits[gr$targetname] + gr$seq[as.logical(strand(gr)=='-')] %<>% revcomp() + gr +} + +get_plus_seq <- function(bsgenome, gr){ + seqs1 <- BSgenome::getSeq(bsgenome, + seqnames(gr), + start(gr), + end(gr), + strand = '+', + as.character = TRUE) + if (has_names(gr)) names(seqs1) <- names(gr) + seqs1 + +} + + +revcomp <- function(y) y %>% + Biostrings::DNAStringSet() %>% + Biostrings::reverseComplement() %>% + as.character() + diff --git a/R/06_find_spacers.R b/R/06_find_spacers.R index 27fd6d98e11689644af2d70ff72660549913b68b..55d315f1edc67188357e7c7a70a5a1ddf40d6562 100644 --- a/R/06_find_spacers.R +++ b/R/06_find_spacers.R @@ -1,284 +1,284 @@ -# Convert PAM into regex format -# @examples -# x <- 'NGG' -# pam_to_regex <- function(x){ -# assert_is_a_string(x) -# x %>% stringi::stri_replace_all_fixed('N', '[ACGT]') -# } - - -# This regex-based function fails to find all crispr spacers -# It is, therefore, no longer used, just kept for reference purposes. -# Example explanation of why it fails -# x <- Biostrings::DNAString('AGCAGCTGGGGCAGTGGTGGGGGGCCTTGGCGGCTACA') -# stringi::stri_locate_all_regex(as.character(x), '[ACGT]{21}GG') -# Biostrings::matchPattern('NNNNNNNNNNNNNNNNNNNNNGG', x, fixed = FALSE) -# regex_based_find_crispr_spacers <- function( -# gr, bsgenome, pam = 'NGG', plot = TRUE, verbose = TRUE){ -# -# # Assert. Import. Comply -# assert_is_all_of(gr, 'GRanges') -# assert_is_all_of(bsgenome, 'BSgenome') -# assert_is_a_bool(verbose) -# start <- substart <- crispr_start <- NULL -# end <- subend <- crispr_end <- strand <- seqnames <- NULL -# gr %<>% add_seq(bsgenome) -# gr %<>% name_uniquely() -# -# # Find crispr sites in targetranges -# pattern <- paste0('[ACGT]{20}', pam_to_regex(pam)) -# if (verbose) cmessage('\tFind %s crispr sites', pattern) -# targetdt <- as.data.table(gr) -# res <- targetdt$seq %>% stri_locate_all_regex(pattern) -# cextract1 <- function(y) y[, 1] %>% paste0(collapse=';') -# cextract2 <- function(y) y[, 2] %>% paste0(collapse=';') -# targetdt [ , substart := vapply( res, cextract1, character(1)) ] -# targetdt [ , subend := vapply( res, cextract2, character(1)) ] -# -# # Rm crispr-free targetranges -# idx <- targetdt[, substart == 'NA'] -# if (sum(idx)>0){ -# if (verbose) cmessage('\t\tRm %d ranges with no crispr site', -# sum(idx)) -# targetdt %<>% extract(!idx) -# } -# -# # Transform into crispr ranges -# targetdt[, targetstart := start] -# targetdt[, targetend := end ] -# -# sites_dt <- tidyr::separate_rows(targetdt, substart, subend) %>% -# data.table() %>% -# extract(, substart := as.numeric(substart)) %>% -# extract(, subend := as.numeric(subend)) %>% -# extract(, seq := substr(seq, substart, subend)) %>% -# extract( strand=='+', crispr_start := start + substart - 1) %>% -# extract( strand=='+', crispr_end := start + subend - 1) %>% -# extract( strand=='-', crispr_start := end - subend + 1) %>% -# extract( strand=='-', crispr_end := end - substart + 1) %>% -# extract(, -# list(seqnames = seqnames, start = crispr_start, -# end = crispr_end, strand = strand, seq = seq, -# targetname = targetname, targetstart = targetstart, -# targetend = targetend)) -# sites <- GRanges(unique(sites_dt), seqinfo = seqinfo(gr)) -# sites$site <- uniquify(sites$targetname) -# spacer <- sites %>% extend( 0, -3, stranded=TRUE, bsgenome=bsgenome) -# pam <- sites %>% down_flank(-2, 0, stranded=TRUE, bsgenome=bsgenome) -# spacer$spacer <- spacer$seq -# spacer$seq <- NULL -# spacer$pam <- pam$seq -# -# # Plot. Message. Return -# if (plot){ -# original <- copy(sites, start=sites$targetstart, end=sites$targetend) -# original$set <- 'target' -# spacer$set <- 'spacer' -# plot_intervals(c(original, spacer), color_var = 'set', -# size_var = 'set', y = 'site') -# sites$set <- NULL -# } -# if (verbose) cmessage('\t\t%d cas9 spacers across %d ranges', -# length(unique(spacer$spacer)), length(spacer)) -# return(sites) -# } - - - -#' Extract subranges -#' -#' Extract subranges from a \code{\link[GenomicRanges]{GRanges-class}} object -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param ir \code{\link[IRanges]{IRanges-class}}: subranges to be extracted -#' @param plot TRUE or FALSE (default) -#' @return \code{\link[GenomicRanges]{GRanges-class}}. -#' @examples -#' gr <- GenomicRanges::GRanges(c(A = 'chr1:1-100:+', B = 'chr1:1-100:-')) -#' gr$targetname <- 'AB' -#' ir <- IRanges::IRanges(c(A = '1-10', A = '11-20', B = '1-10', B = '11-20')) -#' extract_subranges(gr, ir, plot = TRUE) -#' @export -extract_subranges <- function(gr, ir, plot = FALSE){ - - # Comply / Assert - substart <- subwidth <- NULL - assert_is_all_of(gr, 'GRanges') - assert_is_all_of(ir, 'IRanges') - assert_has_names(gr) - assert_has_names(ir) - assert_is_subset(unique(names(ir)), names(gr)) - assert_is_a_bool(plot) - - # Convert and merge - idt <- data.table::as.data.table(ir) - gdt <- data.table::as.data.table(gr) %>% cbind(names = names(gr)) - gdt$width <- NULL - setnames(idt, c( 'start', 'end', 'width'), - c('substart', 'subend', 'subwidth')) - mdt <- merge(gdt, idt, by = 'names') - - # Extract - mdt[strand=='+', start := start-1+substart] - mdt[strand=='+', end := start-1+subwidth] - mdt[strand=='-', end := end+1-substart] - mdt[strand=='-', start := end+1-subwidth] - mdt[, c('substart', 'subend', 'subwidth') := NULL] - mr <- dt2gr(mdt, seqinfo = seqinfo(gr)) - names(mr) %<>% uniquify() - - # Plot - if (plot) print(plot_intervals(mr)) - - # Return - mr -} - -#' Extract matching subranges -#' -#' Extract subranges that match pattern -#' -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link{BSgenome}{BSgenome-class}} -#' @param pattern string: search pattern in extended IUPAC alphabet -#' @param plot TRUE or FALSE (default) -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #------------ -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' gr %<>% extend_for_pe() -#' pattern <- strrep('N',20) %>% paste0('NGG') -#' extract_matchranges(gr, bsgenome, pattern, plot = TRUE) -#' -#' # TFBS examples -#' #-------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -#' gr <- bed_to_granges(bedfile, 'mm10') %>% extend() -#' extract_matchranges(gr, bsgenome, pattern = strrep('N',20) %>% paste0('NGG')) -#' @export -extract_matchranges <- function(gr, bsgenome, pattern, plot = FALSE){ - - # Assert - assert_is_all_of(gr, 'GRanges') - assert_has_names(gr) - assert_is_all_of(bsgenome, 'BSgenome') - assert_is_a_string(pattern) - - # Extract - matches <- unlist(vmatchPattern(pattern, getSeq(bsgenome, gr), fixed=FALSE)) - extract_subranges(gr, matches, plot = plot) %>% sort(ignore.strand = TRUE) - -} - - -#' Find crispr spacers in targetranges -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param spacer string: spacer pattern in extended IUPAC alphabet -#' @param pam string: pam pattern in extended IUPAC alphabet -#' @param complement TRUE (default) or FALSE: also search in compl ranges? -#' @param plot TRUE (default) or FALSE -#' @param verbose TRUE (default) or FALSE -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' plot_intervals(gr) -#' find_pe_spacers(gr, bsgenome) -#' find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE) -#' # complement = FALSE because extend_for_pe already -#' # adds reverse complements and does so in a strand-specific -#' # manner -#' -#' # TFBS example -#' #------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -#' gr <- bed_to_granges(bedfile, 'mm10') %>% extend() -#' find_spacers(gr, bsgenome) -#' @seealso \code{\link{find_pe_spacers}} to find prime editing spacers -#' @export -find_spacers <- function( - gr, bsgenome, spacer = strrep('N', 20), pam = 'NGG', complement = TRUE, - verbose = TRUE, plot = TRUE -){ - - if (complement){ - gr %<>% add_inverse_strand(plot = FALSE, verbose = verbose) - } - sites <- extract_matchranges(gr, bsgenome, paste0(spacer, pam)) %>% unique() - spacers <- extend(sites, 0, -3, bsgenome = bsgenome) - pams <- down_flank(sites, -2, 0, bsgenome = bsgenome) - spacers$crisprname <- names(spacers) - spacers$crisprspacer <- getSeq(bsgenome, spacers, as.character=TRUE) - spacers$crisprpam <- getSeq(bsgenome, pams, as.character=TRUE) - spacers %>% sort(ignore.strand = TRUE) - if (plot){ - print(plot_intervals(spacers, y='crisprname')) - spacers$sitename <- NULL - } - spacers -} - -#' Extend ranges for prime editing -#' -#' Extend target ranges to span in which to look for spacer-pam seqs -#' -#' Extend target ranges to find nearby spacers for prime editing -#' @param gr \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param nrt number: reverse transcription length -#' @param spacer string: spacer pattern in extended IUPAC alphabet -#' @param pam string: pam pattern in extended IUPAC alphabet -#' @param plot TRUE (default) or FALSE -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c( PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome = bsgenome) -#' find_pe_spacers(gr, bsgenome) -#' (grext <- extend_for_pe(gr)) -#' find_spacers(grext, bsgenome, complement = FALSE) -#' @export -extend_for_pe <- function( - gr, - bsgenome, - nrt = 16, - spacer = strrep('N', 20), - pam = 'NGG', - plot = FALSE -){ - fw <- copy( gr, start=end(gr)+1-nrt-17, end=start(gr)-1+6, strand='+') - rv <- copy( gr, start=end(gr)+1-6, end=start(gr)-1+nrt+17, strand='-') - names(fw) %<>% paste0('_f') - names(rv) %<>% paste0('_r') - ext <- c(fw, rv) - if (plot){ - #gr$set <- 'PE target' - fw$set <- "potential '+' spacers" - rv$set <- "potential '-' spacers" - print(plot_intervals(c(fw, gr, rv), linetype_var = 'set', - y = 'targetname', color_var = 'targetname')) - } - ext -} - - +# Convert PAM into regex format +# @examples +# x <- 'NGG' +# pam_to_regex <- function(x){ +# assert_is_a_string(x) +# x %>% stringi::stri_replace_all_fixed('N', '[ACGT]') +# } + + +# This regex-based function fails to find all crispr spacers +# It is, therefore, no longer used, just kept for reference purposes. +# Example explanation of why it fails +# x <- Biostrings::DNAString('AGCAGCTGGGGCAGTGGTGGGGGGCCTTGGCGGCTACA') +# stringi::stri_locate_all_regex(as.character(x), '[ACGT]{21}GG') +# Biostrings::matchPattern('NNNNNNNNNNNNNNNNNNNNNGG', x, fixed = FALSE) +# regex_based_find_crispr_spacers <- function( +# gr, bsgenome, pam = 'NGG', plot = TRUE, verbose = TRUE){ +# +# # Assert. Import. Comply +# assert_is_all_of(gr, 'GRanges') +# assert_is_all_of(bsgenome, 'BSgenome') +# assert_is_a_bool(verbose) +# start <- substart <- crispr_start <- NULL +# end <- subend <- crispr_end <- strand <- seqnames <- NULL +# gr %<>% add_seq(bsgenome) +# gr %<>% name_uniquely() +# +# # Find crispr sites in targetranges +# pattern <- paste0('[ACGT]{20}', pam_to_regex(pam)) +# if (verbose) cmessage('\tFind %s crispr sites', pattern) +# targetdt <- as.data.table(gr) +# res <- targetdt$seq %>% stri_locate_all_regex(pattern) +# cextract1 <- function(y) y[, 1] %>% paste0(collapse=';') +# cextract2 <- function(y) y[, 2] %>% paste0(collapse=';') +# targetdt [ , substart := vapply( res, cextract1, character(1)) ] +# targetdt [ , subend := vapply( res, cextract2, character(1)) ] +# +# # Rm crispr-free targetranges +# idx <- targetdt[, substart == 'NA'] +# if (sum(idx)>0){ +# if (verbose) cmessage('\t\tRm %d ranges with no crispr site', +# sum(idx)) +# targetdt %<>% extract(!idx) +# } +# +# # Transform into crispr ranges +# targetdt[, targetstart := start] +# targetdt[, targetend := end ] +# +# sites_dt <- tidyr::separate_rows(targetdt, substart, subend) %>% +# data.table() %>% +# extract(, substart := as.numeric(substart)) %>% +# extract(, subend := as.numeric(subend)) %>% +# extract(, seq := substr(seq, substart, subend)) %>% +# extract( strand=='+', crispr_start := start + substart - 1) %>% +# extract( strand=='+', crispr_end := start + subend - 1) %>% +# extract( strand=='-', crispr_start := end - subend + 1) %>% +# extract( strand=='-', crispr_end := end - substart + 1) %>% +# extract(, +# list(seqnames = seqnames, start = crispr_start, +# end = crispr_end, strand = strand, seq = seq, +# targetname = targetname, targetstart = targetstart, +# targetend = targetend)) +# sites <- GRanges(unique(sites_dt), seqinfo = seqinfo(gr)) +# sites$site <- uniquify(sites$targetname) +# spacer <- sites %>% extend( 0, -3, stranded=TRUE, bsgenome=bsgenome) +# pam <- sites %>% down_flank(-2, 0, stranded=TRUE, bsgenome=bsgenome) +# spacer$spacer <- spacer$seq +# spacer$seq <- NULL +# spacer$pam <- pam$seq +# +# # Plot. Message. Return +# if (plot){ +# original <- copy(sites, start=sites$targetstart, end=sites$targetend) +# original$set <- 'target' +# spacer$set <- 'spacer' +# plot_intervals(c(original, spacer), color_var = 'set', +# size_var = 'set', y = 'site') +# sites$set <- NULL +# } +# if (verbose) cmessage('\t\t%d cas9 spacers across %d ranges', +# length(unique(spacer$spacer)), length(spacer)) +# return(sites) +# } + + + +#' Extract subranges +#' +#' Extract subranges from a \code{\link[GenomicRanges]{GRanges-class}} object +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param ir \code{\link[IRanges]{IRanges-class}}: subranges to be extracted +#' @param plot TRUE or FALSE (default) +#' @return \code{\link[GenomicRanges]{GRanges-class}}. +#' @examples +#' gr <- GenomicRanges::GRanges(c(A = 'chr1:1-100:+', B = 'chr1:1-100:-')) +#' gr$targetname <- 'AB' +#' ir <- IRanges::IRanges(c(A = '1-10', A = '11-20', B = '1-10', B = '11-20')) +#' extract_subranges(gr, ir, plot = TRUE) +#' @export +extract_subranges <- function(gr, ir, plot = FALSE){ + + # Comply / Assert + substart <- subwidth <- NULL + assert_is_all_of(gr, 'GRanges') + assert_is_all_of(ir, 'IRanges') + assert_has_names(gr) + assert_has_names(ir) + assert_is_subset(unique(names(ir)), names(gr)) + assert_is_a_bool(plot) + + # Convert and merge + idt <- data.table::as.data.table(ir) + gdt <- data.table::as.data.table(gr) %>% cbind(names = names(gr)) + gdt$width <- NULL + setnames(idt, c( 'start', 'end', 'width'), + c('substart', 'subend', 'subwidth')) + mdt <- merge(gdt, idt, by = 'names') + + # Extract + mdt[strand=='+', start := start-1+substart] + mdt[strand=='+', end := start-1+subwidth] + mdt[strand=='-', end := end+1-substart] + mdt[strand=='-', start := end+1-subwidth] + mdt[, c('substart', 'subend', 'subwidth') := NULL] + mr <- dt2gr(mdt, seqinfo = seqinfo(gr)) + names(mr) %<>% uniquify() + + # Plot + if (plot) print(plot_intervals(mr)) + + # Return + mr +} + +#' Extract matching subranges +#' +#' Extract subranges that match pattern +#' +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link{BSgenome}{BSgenome-class}} +#' @param pattern string: search pattern in extended IUPAC alphabet +#' @param plot TRUE or FALSE (default) +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #------------ +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' gr %<>% extend_for_pe() +#' pattern <- strrep('N',20) %>% paste0('NGG') +#' extract_matchranges(gr, bsgenome, pattern, plot = TRUE) +#' +#' # TFBS examples +#' #-------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +#' gr <- bed_to_granges(bedfile, 'mm10') %>% extend() +#' extract_matchranges(gr, bsgenome, pattern = strrep('N',20) %>% paste0('NGG')) +#' @export +extract_matchranges <- function(gr, bsgenome, pattern, plot = FALSE){ + + # Assert + assert_is_all_of(gr, 'GRanges') + assert_has_names(gr) + assert_is_all_of(bsgenome, 'BSgenome') + assert_is_a_string(pattern) + + # Extract + matches <- unlist(vmatchPattern(pattern, getSeq(bsgenome, gr), fixed=FALSE)) + extract_subranges(gr, matches, plot = plot) %>% sort(ignore.strand = TRUE) + +} + + +#' Find crispr spacers in targetranges +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param spacer string: spacer pattern in extended IUPAC alphabet +#' @param pam string: pam pattern in extended IUPAC alphabet +#' @param complement TRUE (default) or FALSE: also search in compl ranges? +#' @param plot TRUE (default) or FALSE +#' @param verbose TRUE (default) or FALSE +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' plot_intervals(gr) +#' find_pe_spacers(gr, bsgenome) +#' find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE) +#' # complement = FALSE because extend_for_pe already +#' # adds reverse complements and does so in a strand-specific +#' # manner +#' +#' # TFBS example +#' #------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +#' gr <- bed_to_granges(bedfile, 'mm10') %>% extend() +#' find_spacers(gr, bsgenome) +#' @seealso \code{\link{find_pe_spacers}} to find prime editing spacers +#' @export +find_spacers <- function( + gr, bsgenome, spacer = strrep('N', 20), pam = 'NGG', complement = TRUE, + verbose = TRUE, plot = TRUE +){ + + if (complement){ + gr %<>% add_inverse_strand(plot = FALSE, verbose = verbose) + } + sites <- extract_matchranges(gr, bsgenome, paste0(spacer, pam)) %>% unique() + spacers <- extend(sites, 0, -3, bsgenome = bsgenome) + pams <- down_flank(sites, -2, 0, bsgenome = bsgenome) + spacers$crisprname <- names(spacers) + spacers$crisprspacer <- getSeq(bsgenome, spacers, as.character=TRUE) + spacers$crisprpam <- getSeq(bsgenome, pams, as.character=TRUE) + spacers %>% sort(ignore.strand = TRUE) + if (plot){ + print(plot_intervals(spacers, y='crisprname')) + spacers$sitename <- NULL + } + spacers +} + +#' Extend ranges for prime editing +#' +#' Extend target ranges to span in which to look for spacer-pam seqs +#' +#' Extend target ranges to find nearby spacers for prime editing +#' @param gr \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param nrt number: reverse transcription length +#' @param spacer string: spacer pattern in extended IUPAC alphabet +#' @param pam string: pam pattern in extended IUPAC alphabet +#' @param plot TRUE (default) or FALSE +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c( PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome = bsgenome) +#' find_pe_spacers(gr, bsgenome) +#' (grext <- extend_for_pe(gr)) +#' find_spacers(grext, bsgenome, complement = FALSE) +#' @export +extend_for_pe <- function( + gr, + bsgenome, + nrt = 16, + spacer = strrep('N', 20), + pam = 'NGG', + plot = FALSE +){ + fw <- copy( gr, start=end(gr)+1-nrt-17, end=start(gr)-1+6, strand='+') + rv <- copy( gr, start=end(gr)+1-6, end=start(gr)-1+nrt+17, strand='-') + names(fw) %<>% paste0('_f') + names(rv) %<>% paste0('_r') + ext <- c(fw, rv) + if (plot){ + #gr$set <- 'PE target' + fw$set <- "potential '+' spacers" + rv$set <- "potential '-' spacers" + print(plot_intervals(c(fw, gr, rv), linetype_var = 'set', + y = 'targetname', color_var = 'targetname')) + } + ext +} + + diff --git a/R/07_add_offtargets.R b/R/07_add_offtargets.R index 3d738b898e9520f1b10486b59a9c4009a5593ad7..3011610b40389a2a2f622b63a97015efb5a4bcb7 100644 --- a/R/07_add_offtargets.R +++ b/R/07_add_offtargets.R @@ -1,727 +1,727 @@ -INDEXEDGENOMESDIR <- '~/multicrisprout/indexedgenomes' - genome_dir <- function(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome){ - paste0(indexedgenomesdir, '/', bsgenome@pkgname)} - - genome_fasta <- function(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome){ - paste0(indexedgenomesdir, '/', bsgenome@pkgname, '.fa')} - -OUTDIR <- '~/multicrisprout' - target_dir <- function(outdir = OUTDIR){ - paste0(outdir, '/targets') } - - target_fasta <- function(outdir = OUTDIR){ - paste0(outdir, '/targets.fa')} - - spacer_matchfile <- function(outdir = OUTDIR, indexdir){ - paste0(outdir, '/spacers/spacers_to_', basename(indexdir), '.txt')} - - spacer_fasta <- function(outdir = OUTDIR){ - paste0(outdir, '/spacers.fa') } - -#' Has been indexed? -#' @param bsgenome BSgenome -#' @param indexedgenomesdir directory with indexed genomes -#' @return TRUE or FALSE -#' @examples -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' has_been_indexed(bsgenome) -#' @export -has_been_indexed <- function(bsgenome, indexedgenomesdir = INDEXEDGENOMESDIR){ - dir.exists(genome_dir(indexedgenomesdir, bsgenome = bsgenome)) - # don't rm this function - is used in vignette -} - - -indexed_genomes_s3 <- c("BSgenome.Hsapiens.UCSC.hg38", - "BSgenome.Mmusculus.UCSC.mm10") - -#' Index genome -#' -#' Bowtie index genome -#' -#' Checks whether already available locally. If not, checks whether indexed -#' version can be downloaded from our s3 storage. If not, builds the -#' index with bowtie. This can take a few hours, but is a one-time operation. -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param indexedgenomesdir string: directory with bowtie-indexed genome -#' @param download TRUE (default) or FALSE: whether to download pre-indexed -#' version if available -#' @param overwrite TRUE or FALSE (default) -#' @return invisible(genomdir) -#' @examples -#' bsgenome <- BSgenome.Scerevisiae.UCSC.sacCer1::Scerevisiae -#' index_genome(bsgenome, indexedgenomesdir = tempdir()) -#' @export -index_genome <- function( - bsgenome, indexedgenomesdir = INDEXEDGENOMESDIR, - download = TRUE, overwrite = FALSE -){ - # Assert - assert_is_all_of(bsgenome, 'BSgenome') - bsname <- GenomeInfoDb::bsgenomeName(as(bsgenome, 'GenomeDescription')) - - # Return if already available - genomedir <- genome_dir( indexedgenomesdir, bsgenome) - message('\tIndex ', bsname) - if (!overwrite & - dir.exists(genomedir) & length(list.files(genomedir))!=0){ - message('\t\tNot required: ', genomedir, ' already exists', ' - Set overwrite=TRUE to overwrite') - return(invisible(genomedir)) - } - - # Download if present on s3 storage - if (download & (bsname %in% indexed_genomes_s3)){ - url <- paste0('https://s3.mpi-bn.mpg.de/data-multicrispr-2020/', - bsname, '.zip') - zipfile <- paste0(genomedir, '.zip') - message('\t\tDownload pre-indexed version - For a fresh build instead, set download = FALSE') - res <- tryCatch(download.file(url, zipfile), error = function(e) 1) - if (res==0){ - message('\t\tUnzip ') - utils::unzip(zipfile, exdir = dirname(genomedir)) - unlink(zipfile) - return(invisible(genomedir)) - } - message('\t\t\tfailed') - } - - # Index using Bowtie - dir.create(genomedir, showWarnings = FALSE, recursive = TRUE) - genomefasta <- genome_fasta(indexedgenomesdir, bsgenome) - BSgenome::writeBSgenomeToFasta(bsgenome, genomefasta) - Rbowtie::bowtie_build( - genomefasta, genomedir, prefix = basename(genomedir), force = TRUE) - return(invisible(genomedir)) - -} - -#' Index targets -#' -#' Bowtie index targets -#' @param targets \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param outdir string: output directory -#' @param verbose TRUE (default) or FALSE -#' @return invisible(targetdir) -#' @examples -#' require(magrittr) -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) -#' index_targets(targets, bsgenome) -#' @export -index_targets <- function( - targets, - bsgenome = getBSgenome(genome(targets)[1]), - outdir = OUTDIR, - verbose = TRUE -){ - # Assert - assert_is_all_of(targets, 'GRanges') - - # Add inverse strand - if (verbose) cmessage('\tIndex target sequences') - if (verbose) cmessage('\t\t%d target ranges', length(targets)) - targets %<>% add_inverse_strand(plot = FALSE, verbose = TRUE) - targets %<>% sort(ignore.strand = TRUE) - - # Reduce - targets %<>% GenomicRanges::reduce() - if (verbose) cmessage( - '\t\t%d ranges after merging overlaps', length(targets)) - - # Write to fasta - targetdir <- target_dir(outdir) - targetfasta <- target_fasta(outdir) - targetseqs <- BSgenome::getSeq(bsgenome, targets) - names(targetseqs) <- sprintf( - '%s:%s-%s:%s', - as.character(seqnames(targets)), start(targets), end(targets), - strand(targets)) - if (verbose) cmessage('\t\tWrite seqs to %s', targetfasta) - dir.create(dirname(targetfasta), showWarnings = FALSE, recursive = TRUE) - Biostrings::writeXStringSet(targetseqs, targetfasta) - - # Index targets - if (verbose) cmessage('\t\tWrite index to %s', targetdir) - Rbowtie::bowtie_build( targetfasta, - targetdir, - prefix = basename(targetdir), - force = TRUE) - return(invisible(targetdir)) - -} - - -run_bowtie <- function(spacerfasta, indexdir, outfile, norc, mismatches = 2){ - - assertive::assert_all_are_existing_files(spacerfasta) - assertive::assert_all_are_dirs(indexdir) - assertive::assert_is_a_bool(norc) - assertive::assert_is_a_number(mismatches) - assertive::assert_is_subset(mismatches, 0:3) - - dir.create(dirname(outfile), recursive = TRUE, showWarnings = FALSE) - - Rbowtie::bowtie( - sequences = spacerfasta, - index = file.path(indexdir, basename(indexdir)), - f = TRUE, # fasta input - #m = 10000, # ignore seqs with m+ alignments - a = TRUE, # report ALL alignments - v = mismatches, # up to 3 mismatches - norc = norc, # no reverse complement - outfile = outfile, - force = TRUE) -} - -read_bowtie_results <- function(outfile, mis){ - - .N <- . <- readname <- NULL - - assertive::assert_all_are_existing_files(outfile) - mismatch <- mismatches <- NULL - - dt <- data.table::fread( - outfile, - col.names = c( 'readname', 'strand', 'target', 'position', - 'readseq', 'quality', 'matches', 'mismatches')) - - pattern <- '20:[ACGT][>][ACGT]' - dt %<>% extract(!stri_detect_regex(mismatches, pattern)) - - dt[ is.na(mismatches), mismatch := 0] - dt[!is.na(mismatches), mismatch := stringi::stri_count_fixed( - mismatches, '>')] - dt %<>% extract(mismatch<=mis) - dt[, mismatch := factor(mismatch, c(seq(0, mis)))] - - results <- dt %>% - extract( , .N, keyby = .(readname, mismatch)) %>% - data.table::dcast(readname ~ mismatch, value.var='N', drop=FALSE) %>% - data.table::setnames(names(.)[-1], paste0('MM', names(.)[-1])) - - results <- cbind(results[, 1], setnafill(results[, -1], fill = 0)) - results -} - - -#' Match spacer sequences -#' -#' Count matches to indexed target/genome -#' -#' @param seqs character vector: sequences to match against indexed ref -#' @param indexdir string: dir containing indexed reference. -#' This can be an indexed genome( \code{\link{index_genome}} -#' It can also be indexed targets (\code{\link{index_targets}}) -#' @param norc TRUE or FALSE: whether to run bowtie also with revcompls -#' Generally TRUE for genome and FALSE for target matches, -#' because target ranges generally include both strands. -#' @param mismatches max number of mismatches to consider -#' @param outdir string: multicrispr output directory -#' @param verbose TRUE (default) or FALSE -#' @return data.table -#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' spacers <- find_pe_spacers(gr, bsgenome) -#' # indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome) -#' # match_seqs(spacers$crisprspacer, indexdir, norc=TRUE, mismatches = 1) -#' -#' # TFBS example -#' #------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) -#' indexdir <- index_targets(targets, bsgenome) -#' spacers <- find_spacers(targets, bsgenome) -#' seqs <- unique(paste0(spacers$crisprspacer, spacers$crisprpam)) -#' match_seqs(seqs, indexdir, norc=FALSE) -#' match_seqs(seqs, indexdir, norc=FALSE, mismatches=3) -#' @export -match_seqs <- function(seqs, indexdir, norc, mismatches = 2, - outdir = OUTDIR, verbose = TRUE -){ - - # Assert - assertive::assert_is_character(seqs) - assertive::assert_has_no_duplicates(seqs) - - # Write reads to fasta - reads <- Biostrings::DNAStringSet(unique(seqs)) - reads %<>% name_uniquely('read') - readfasta <- spacer_fasta(outdir) - dir.create(dirname(readfasta), recursive = TRUE, showWarnings = FALSE) - if (verbose) cmessage('\t\tWrite reads to %s', readfasta) - Biostrings::writeXStringSet(reads, readfasta) - - # Map reads and read results - outfile <- spacer_matchfile(outdir, indexdir) - if (verbose) cmessage('\t\tMap reads: %s', outfile) - run_bowtie(readfasta, indexdir, outfile, norc = norc, - mismatches = max(1, mismatches)) # 1-mismatch offtargets - if (verbose) cmessage('\t\tLoad results') # required for pam correction - matches <- read_bowtie_results(outfile, mismatches) - - # Count matches - if (verbose) cmessage('\t\tCount matches') - readdt <- data.table(readname = names(reads), - readseq = unname(as.character(reads))) - readdt %<>% merge(matches, by='readname', all=TRUE, sort=FALSE) - readdt <- cbind(readdt[, c(1, 2)], - data.table::setnafill(readdt[, -c(1, 2)], fill = 0)) - - # Return - readdt[, 'readname' := NULL] - readdt[seqs, on = 'readseq'] -} - -explode <- function(x) unlist(strsplit(x, character(0))) -paste_dtcols <- function(x) x [, do.call(paste0, .SD) ] -expand_iupac_ambiguities <- function(x){ - paste_dtcols( - as.data.table( - lapply(Biostrings::IUPAC_CODE_MAP[explode(x)], explode))) -} - -#' Match spacers -#' -#' Count matches to indexed target/genome and add to GRanges -#' -#' Expands iupac amgiguities in the pam sequence. -#' Matches all resulting sequences against (indexes) target and genome. -#' Adds match counts to GRanges object, and then returns it. -#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} -#' @param indexdir string: dir containing indexed reference. -#' This can be an indexed genome( \code{\link{index_genome}} -#' It can also be indexed targets (\code{\link{index_targets}}) -#' @param norc TRUE or FALSE: whether to run bowtie also with revcompls -#' Generally TRUE for genome and FALSE for target matches, -#' because target ranges generally include both strands. -#' @param mismatches number (default 2): max number of mismatches to consider -#' @param outdir string: file where to output bowtie results -#' @param pam string (default 'NGG') pam pattern to expand -#' @param verbose TRUE (default) or FALSE -#' @return data.table -#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' spacers <- find_pe_spacers(gr, bsgenome) -#' # indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome) -#' # match_spacers(spacers, indexdir, norc=TRUE, mismatches = 1) -#' -#' # TFBS example -#' #------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) -#' indexdir <- index_targets(targets, bsgenome) -#' spacers <- find_spacers(targets, bsgenome) -#' match_spacers(spacers, indexdir, norc=FALSE, mismatches = 1) -#' @export -match_spacers <- function( - spacers, indexdir, norc, mismatches = 2, - outdir = OUTDIR, pam = 'NGG', verbose = TRUE -){ - # Comply - crispr <- crisprspacer <- . <- NULL - - # Expand pams - if (verbose) cmessage('\t\tExpand iupac ambiguities in pam') - spacerseqs <- unique(spacers$crisprspacer) - pamseqs <- expand_iupac_ambiguities(pam) - crisprdt <- data.table( - crisprspacer = rep(spacerseqs, each=length(pamseqs)), - crisprpam = rep(pamseqs, times=length(spacerseqs))) %>% - extract(, crispr := paste0(crisprspacer, pamseqs)) - crisprseqs <- unique(crisprdt$crispr) - - # Count matches - matches <- match_seqs(crisprseqs, - indexdir, - norc = norc, - mismatches = mismatches, - outdir = outdir, - verbose = verbose) - matches %<>% merge(crisprdt, by.x = 'readseq', by.y = 'crispr', all = TRUE) - - # Aggregate per spacer - count_vars <- names(matches) %>% extract(stri_startswith_fixed(., 'MM')) - spacer_dt <- data.table(crisprspacer = unique(matches$crisprspacer)) - for (var in count_vars){ - spacer_dt %<>% merge(matches[ , list(counts = sum(get(var))), - by = 'crisprspacer'], - by = 'crisprspacer') - setnames(spacer_dt, 'counts', var) - } - - # Return - spacer_dt[spacerseqs, on = 'crisprspacer'] -} - -#' Add target counts -#' -#' Count spacer matches among targets -#' -#' Expands iupac amgiguities in the pam sequence. -#' Matches all resulting sequences against (indexes) target and genome. -#' Adds match counts to GRanges object, and then returns it. -#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} -#' @param targets target \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param mismatches number (default 2): max number of mismatches to consider -#' @param outdir dir where output is written to -#' @param pam string (default 'NGG') pam pattern to expand -#' @param verbose TRUE (default) or FALSE -#' @return updated spacer \code{\link[GenomicRanges]{GRanges-class}} -#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} -#' @examples -#' # TFBS example -#' #------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) -#' spacers <- find_spacers(targets, bsgenome) -#' add_target_counts(spacers, targets, bsgenome) -#' @export -add_target_counts <- function( - spacers, targets, bsgenome, mismatches = 2, - pam = 'NGG', outdir = OUTDIR, verbose = TRUE -){ - # Comply - . <- NULL - - # Index targets - targetdir <- target_dir(outdir) - dir.create(targetdir, showWarnings = FALSE, recursive = FALSE) - index_targets(targets, bsgenome, outdir) - - # Match spacers to targets - if (verbose) cmessage('\tAdd target counts') - matches <- match_spacers( - spacers, targetdir, norc = TRUE, - mismatches = mismatches, outdir = outdir, - pam = pam, verbose = verbose) - names(matches) %<>% stringi::stri_replace_first_regex('^MM', 'T') - - # Add counts to spacers - dt <- gr2dt(spacers) %>% - merge(matches, by = 'crisprspacer', sort = FALSE) - - # Organize columns and return - targetvars <- names(dt) %>% extract(stri_startswith_fixed(., 'target')) - crisprvars <- c('crisprname', 'crisprspacer', 'crisprpam', 'crisprext') %>% - intersect(names(dt)) - othervars <- setdiff(names(dt), c(targetvars, crisprvars)) - - dt %>% - extract(, c(targetvars, crisprvars, othervars), with = FALSE) %>% - dt2gr(seqinfo(spacers)) - -} -#' Add genome counts -#' -#' Count spacer matches to genome and add to GRanges -#' -#' Expands iupac amgiguities in the pam sequence. -#' Matches all resulting sequences against (indexes) target and genome. -#' Adds match counts to GRanges object, and then returns it. -#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param mismatches number (default 2): max number of mismatches to consider -#' @param pam string (default 'NGG') pam pattern to expand -#' @param outdir dir where output is written to -#' @param indexedgenomesdir string: dir with indexed genomes -#' @param plot FALSE (default) or TRUE -#' @param verbose TRUE (default) or FALSE -#' @return spacer GRanges with additional mcols -#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' spacers <- find_pe_spacers(gr, bsgenome) -#' # index_genome(bsgenome) -#' # add_genome_counts(spacers, bsgenome, mismatches=0, plot = TRUE) -#' -#' # TFBS example -#' #------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) -#' spacers <- find_spacers(targets, bsgenome) -#' # index_genome(bsgenome) -#' # add_genome_counts(spacers, bsgenome) -#' # add_genome_counts(spacers, bsgenome, mismatches=3) -#' @export -add_genome_counts <- function( - spacers, - bsgenome = getBSgenome(genome(spacers)[1]), - mismatches = 2, - pam = 'NGG', - outdir = OUTDIR, - indexedgenomesdir = INDEXEDGENOMESDIR, - plot = FALSE, - verbose = TRUE -){ - . <- NULL - - # Add genome matches - genomedir <- genome_dir(indexedgenomesdir, bsgenome) - if (verbose) message('\tAdd genome counts') - matches <- match_spacers(spacers, genomedir, norc = FALSE, - mismatches = mismatches, - outdir = outdir, pam = pam, verbose = verbose) - names(matches) %<>% stringi::stri_replace_first_regex('^MM', 'G') - dt <- gr2dt(spacers) %>% - merge(matches, by = 'crisprspacer', sort = FALSE) - - # Organize columns and return - targetvars <- names(dt) %>% extract(stri_startswith_fixed(., 'target')) - crisprvars <- c('crisprname', 'crisprspacer', 'crisprpam', 'crisprext') %>% - intersect(names(dt)) - othervars <- setdiff(names(dt), c(targetvars, crisprvars)) - spacers <- dt %>% - extract(, c(targetvars, crisprvars, othervars), with=FALSE) %>% - dt2gr(seqinfo(spacers)) - - # Plot - if (plot){ - grplot <- gr2dt(spacers) %>% - extract(, if(any(.$G0==1)) .SD, by = 'targetname') %>% - dt2gr(seqinfo(spacers)) - p <- plot_intervals(grplot, alpha_var = 'G0') + - ggplot2::scale_alpha(trans = 'reverse', range = c(0.3, 1), - breaks = c(0,1,max(grplot$G0))) - print(p) - } - - # Return - spacers -} - - -#' @export -#' @rdname add_offtargets -add_specificity <- function(...){ - #.Deprecated('add_offtargets') - add_offtargets(...) -} - - -#' Add offtarget counts -#' -#' Add mcols 'off' (offtargets), 'off0' (0-mismatch offtargets), etc. -#' -#' For NULL targets: offtarget counts = (G0- 1) + G1 + ... -#' Non-NULL targets: offtarget counts = (G0-T0) + (G1-T1) + ... -#' -#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} -#' @param targets NULL (default) or target -#' \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param mismatches number (default 2): max number of mismatches to consider -#' @param pam string (default 'NGG'): pam sequence -#' @param outdir directory where output is written to -#' @param indexedgenomesdir string: dir with indexed genomes -#' @param plot TRUE (default) or FALSE -#' @param alpha_var string: mapped to alpha in plot -#' @param size_var string: mapped to size in plot -#' @param verbose TRUE (default) or FALSE -#' @param ... to channel deprecated add_specificity to add_offtargets -#' @return filtered spacer \code{\link[GenomicRanges]{GRanges-class}} -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' spacers <- find_pe_spacers(gr, bsgenome) -#' # index_genome(bsgenome) -#' # add_offtargets(spacers, bsgenome, mismatches=0) -#' # add_offtargets(spacers, bsgenome, mismatches=2) -#' # TFBS example -#' #------------- -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) -#' spacers <- find_spacers(targets, bsgenome) -#' # index_genome(bsgenome) -#' # spacers %>% add_offtargets(bsgenome) # off = G - 1 -#' # spacers %>% add_offtargets(bsgenome, targets) # off = G - T -#' @export -add_offtargets <- function(spacers, bsgenome, targets = NULL, mismatches = 2, - pam = 'NGG', outdir = OUTDIR, indexedgenomesdir = INDEXEDGENOMESDIR, - plot = TRUE, size_var = default_size_var(spacers), alpha_var = 'off', - verbose= TRUE -){ -# First clear - offcols <- c(paste0('G', 0:3), paste0('T', 0:3), paste0('off', 0:3), 'off') - mcols(spacers) %<>% extract(, setdiff(names(.), offcols)) - . <- off <- NULL -# Add genome/target counts - spacers %<>% add_genome_counts( - bsgenome, mismatches = mismatches, outdir = outdir, - indexedgenomesdir = indexedgenomesdir, - pam = pam, verbose = verbose) - if (!is.null(targets)){ - spacers %<>% add_target_counts( - targets, bsgenome, mismatches = mismatches, - outdir = outdir, pam = pam, verbose = verbose) - for (mis in 0:mismatches){ - assert_all_are_true(mcols(spacers)[[paste0('T', mis)]] <= - mcols(spacers)[[paste0('G', mis)]])}} -# Add offtarget counts - digits <- ceiling(log10(length(spacers))) - if (verbose) cmessage('\tCalculate offtargets for %d spacers', - length(spacers)) - spacers$off <- spacers$G0 - (if (is.null(targets)) 1 else spacers$T0) - spacers$off0 <- spacers$off # don't switch order to keep off first - if (mismatches>0){ - for (mis in seq_len(mismatches)){ - Gx <- mcols(spacers)[[paste0('G', mis)]] - Tx <- if (is.null(targets)) 0 else mcols(spacers)[[paste0('T',mis)]] - offcounts <- Gx - Tx - offvar <- paste0('off', mis) - mcols(spacers)[[offvar]] <- offcounts - spacers$off %<>% add(offcounts) - if (verbose) cmessage('\t %s have no %d-mismatch offtargets', - format(sum(mcols(spacers)[[offvar]]==0), width = digits), mis)}} -# Plot and return - if (plot){ - grplot <- gr2dt(spacers) %>% # don't do that - what if no such exist? - #extract(, if(any(off==0)) .SD, by = 'targetname') %>% - dt2gr(seqinfo(spacers)) - p <- plot_intervals( - grplot, alpha_var = 'off', size_var = size_var) - print(p)} - spacers -} - - -#===================================================================== -# Following functions are no longer exported. -# I think better to leave final filtering as an explicit end user step -#===================================================================== - - -# @rdname add_offtargets -# @export -filter_target_specific <- function(...){ - .Deprecated('filter_offtarget_free') - filter_offtarget_free(...) -} - - -# @rdname add_offtargets -# @export -filter_offtarget_free <- function( - spacers, - targets = NULL, - bsgenome = getBSgenome(genome(spacers)[1]), - mismatches = 2, - pam = 'NGG', - outdir = OUTDIR, - indexedgenomesdir = INDEXEDGENOMESDIR, - plot = TRUE, - verbose = TRUE -){ - . <- NULL - # Add specificty info - spacers %<>% add_offtargets( - bsgenome = bsgenome, - targets = targets, - mismatches = mismatches, - pam = pam, - outdir = outdir, - indexedgenomesdir = indexedgenomesdir, - plot = plot, - verbose = verbose) - - # Subset - spacers %<>% subset(.$off==0) - - # Return - return(spacers) -} - - - -# Filter for specific prime editing spacers -# -# Filters spacers which are specific for prime editing site -# -# @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} -# @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -# @param outdir directory where output is written to -# @param pam string (default 'NGG'): pam sequence -# @param outdir string: dir to which output is written -# @param indexedgenomesdir dir with bowtie-indexed genomes -# @param verbose TRUE (default) or FALSE -# @return filtered spacer \code{\link[GenomicRanges]{GRanges-class}} -# @examples -# # PE example -# #----------- -# require(magrittr) -# bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -# gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -# HBB = 'chr11:5227002:-', # snp -# HEXA = 'chr15:72346580-72346583:-', # del -# CFTR = 'chr7:117559593-117559595:+'), # ins -# bsgenome) -# spacers <- find_pe_spacers(gr, bsgenome) -# # index_genome(bsgenome) # one time effort - takes few h -# # filter_prime_specific(spacers, bsgenome) -# @export -filter_prime_specific <- function( - spacers, - bsgenome = getBSgenome(genome(spacers)[1]), - pam = 'NGG', - outdir = OUTDIR, - indexedgenomesdir = INDEXEDGENOMESDIR, - verbose = TRUE -){ - # Add genome matches - spacers %<>% add_genome_counts( - bsgenome, mismatches = 1, outdir = outdir, - pam = pam, verbose = verbose) - - # Filter for specificity - digits <- ceiling(log10(length(spacers))) - if (verbose) cmessage('\tFilter %d spacers', length(spacers)) - idx <- spacers$G0==1 - spacers %<>% subset(idx) - if (verbose) cmessage('\t %s G0==1', format(sum(idx), width = digits)) - - # Return - spacers -} - +INDEXEDGENOMESDIR <- '~/multicrisprout/indexedgenomes' + genome_dir <- function(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome){ + paste0(indexedgenomesdir, '/', bsgenome@pkgname)} + + genome_fasta <- function(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome){ + paste0(indexedgenomesdir, '/', bsgenome@pkgname, '.fa')} + +OUTDIR <- '~/multicrisprout' + target_dir <- function(outdir = OUTDIR){ + paste0(outdir, '/targets') } + + target_fasta <- function(outdir = OUTDIR){ + paste0(outdir, '/targets.fa')} + + spacer_matchfile <- function(outdir = OUTDIR, indexdir){ + paste0(outdir, '/spacers/spacers_to_', basename(indexdir), '.txt')} + + spacer_fasta <- function(outdir = OUTDIR){ + paste0(outdir, '/spacers.fa') } + +#' Has been indexed? +#' @param bsgenome BSgenome +#' @param indexedgenomesdir directory with indexed genomes +#' @return TRUE or FALSE +#' @examples +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' has_been_indexed(bsgenome) +#' @export +has_been_indexed <- function(bsgenome, indexedgenomesdir = INDEXEDGENOMESDIR){ + dir.exists(genome_dir(indexedgenomesdir, bsgenome = bsgenome)) + # don't rm this function - is used in vignette +} + + +indexed_genomes_s3 <- c("BSgenome.Hsapiens.UCSC.hg38", + "BSgenome.Mmusculus.UCSC.mm10") + +#' Index genome +#' +#' Bowtie index genome +#' +#' Checks whether already available locally. If not, checks whether indexed +#' version can be downloaded from our s3 storage. If not, builds the +#' index with bowtie. This can take a few hours, but is a one-time operation. +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param indexedgenomesdir string: directory with bowtie-indexed genome +#' @param download TRUE (default) or FALSE: whether to download pre-indexed +#' version if available +#' @param overwrite TRUE or FALSE (default) +#' @return invisible(genomdir) +#' @examples +#' bsgenome <- BSgenome.Scerevisiae.UCSC.sacCer1::Scerevisiae +#' index_genome(bsgenome, indexedgenomesdir = tempdir()) +#' @export +index_genome <- function( + bsgenome, indexedgenomesdir = INDEXEDGENOMESDIR, + download = TRUE, overwrite = FALSE +){ + # Assert + assert_is_all_of(bsgenome, 'BSgenome') + bsname <- GenomeInfoDb::bsgenomeName(as(bsgenome, 'GenomeDescription')) + + # Return if already available + genomedir <- genome_dir( indexedgenomesdir, bsgenome) + message('\tIndex ', bsname) + if (!overwrite & + dir.exists(genomedir) & length(list.files(genomedir))!=0){ + message('\t\tNot required: ', genomedir, ' already exists', ' + Set overwrite=TRUE to overwrite') + return(invisible(genomedir)) + } + + # Download if present on s3 storage + if (download & (bsname %in% indexed_genomes_s3)){ + url <- paste0('https://s3.mpi-bn.mpg.de/data-multicrispr-2020/', + bsname, '.zip') + zipfile <- paste0(genomedir, '.zip') + message('\t\tDownload pre-indexed version + For a fresh build instead, set download = FALSE') + res <- tryCatch(download.file(url, zipfile), error = function(e) 1) + if (res==0){ + message('\t\tUnzip ') + utils::unzip(zipfile, exdir = dirname(genomedir)) + unlink(zipfile) + return(invisible(genomedir)) + } + message('\t\t\tfailed') + } + + # Index using Bowtie + dir.create(genomedir, showWarnings = FALSE, recursive = TRUE) + genomefasta <- genome_fasta(indexedgenomesdir, bsgenome) + BSgenome::writeBSgenomeToFasta(bsgenome, genomefasta) + Rbowtie::bowtie_build( + genomefasta, genomedir, prefix = basename(genomedir), force = TRUE) + return(invisible(genomedir)) + +} + +#' Index targets +#' +#' Bowtie index targets +#' @param targets \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param outdir string: output directory +#' @param verbose TRUE (default) or FALSE +#' @return invisible(targetdir) +#' @examples +#' require(magrittr) +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) +#' index_targets(targets, bsgenome) +#' @export +index_targets <- function( + targets, + bsgenome = getBSgenome(genome(targets)[1]), + outdir = OUTDIR, + verbose = TRUE +){ + # Assert + assert_is_all_of(targets, 'GRanges') + + # Add inverse strand + if (verbose) cmessage('\tIndex target sequences') + if (verbose) cmessage('\t\t%d target ranges', length(targets)) + targets %<>% add_inverse_strand(plot = FALSE, verbose = TRUE) + targets %<>% sort(ignore.strand = TRUE) + + # Reduce + targets %<>% GenomicRanges::reduce() + if (verbose) cmessage( + '\t\t%d ranges after merging overlaps', length(targets)) + + # Write to fasta + targetdir <- target_dir(outdir) + targetfasta <- target_fasta(outdir) + targetseqs <- BSgenome::getSeq(bsgenome, targets) + names(targetseqs) <- sprintf( + '%s:%s-%s:%s', + as.character(seqnames(targets)), start(targets), end(targets), + strand(targets)) + if (verbose) cmessage('\t\tWrite seqs to %s', targetfasta) + dir.create(dirname(targetfasta), showWarnings = FALSE, recursive = TRUE) + Biostrings::writeXStringSet(targetseqs, targetfasta) + + # Index targets + if (verbose) cmessage('\t\tWrite index to %s', targetdir) + Rbowtie::bowtie_build( targetfasta, + targetdir, + prefix = basename(targetdir), + force = TRUE) + return(invisible(targetdir)) + +} + + +run_bowtie <- function(spacerfasta, indexdir, outfile, norc, mismatches = 2){ + + assertive::assert_all_are_existing_files(spacerfasta) + assertive::assert_all_are_dirs(indexdir) + assertive::assert_is_a_bool(norc) + assertive::assert_is_a_number(mismatches) + assertive::assert_is_subset(mismatches, 0:3) + + dir.create(dirname(outfile), recursive = TRUE, showWarnings = FALSE) + + Rbowtie::bowtie( + sequences = spacerfasta, + index = file.path(indexdir, basename(indexdir)), + f = TRUE, # fasta input + #m = 10000, # ignore seqs with m+ alignments + a = TRUE, # report ALL alignments + v = mismatches, # up to 3 mismatches + norc = norc, # no reverse complement + outfile = outfile, + force = TRUE) +} + +read_bowtie_results <- function(outfile, mis){ + + .N <- . <- readname <- NULL + + assertive::assert_all_are_existing_files(outfile) + mismatch <- mismatches <- NULL + + dt <- data.table::fread( + outfile, + col.names = c( 'readname', 'strand', 'target', 'position', + 'readseq', 'quality', 'matches', 'mismatches')) + + pattern <- '20:[ACGT][>][ACGT]' + dt %<>% extract(!stri_detect_regex(mismatches, pattern)) + + dt[ is.na(mismatches), mismatch := 0] + dt[!is.na(mismatches), mismatch := stringi::stri_count_fixed( + mismatches, '>')] + dt %<>% extract(mismatch<=mis) + dt[, mismatch := factor(mismatch, c(seq(0, mis)))] + + results <- dt %>% + extract( , .N, keyby = .(readname, mismatch)) %>% + data.table::dcast(readname ~ mismatch, value.var='N', drop=FALSE) %>% + data.table::setnames(names(.)[-1], paste0('MM', names(.)[-1])) + + results <- cbind(results[, 1], setnafill(results[, -1], fill = 0)) + results +} + + +#' Match spacer sequences +#' +#' Count matches to indexed target/genome +#' +#' @param seqs character vector: sequences to match against indexed ref +#' @param indexdir string: dir containing indexed reference. +#' This can be an indexed genome( \code{\link{index_genome}} +#' It can also be indexed targets (\code{\link{index_targets}}) +#' @param norc TRUE or FALSE: whether to run bowtie also with revcompls +#' Generally TRUE for genome and FALSE for target matches, +#' because target ranges generally include both strands. +#' @param mismatches max number of mismatches to consider +#' @param outdir string: multicrispr output directory +#' @param verbose TRUE (default) or FALSE +#' @return data.table +#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' spacers <- find_pe_spacers(gr, bsgenome) +#' # indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome) +#' # match_seqs(spacers$crisprspacer, indexdir, norc=TRUE, mismatches = 1) +#' +#' # TFBS example +#' #------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) +#' indexdir <- index_targets(targets, bsgenome) +#' spacers <- find_spacers(targets, bsgenome) +#' seqs <- unique(paste0(spacers$crisprspacer, spacers$crisprpam)) +#' match_seqs(seqs, indexdir, norc=FALSE) +#' match_seqs(seqs, indexdir, norc=FALSE, mismatches=3) +#' @export +match_seqs <- function(seqs, indexdir, norc, mismatches = 2, + outdir = OUTDIR, verbose = TRUE +){ + + # Assert + assertive::assert_is_character(seqs) + assertive::assert_has_no_duplicates(seqs) + + # Write reads to fasta + reads <- Biostrings::DNAStringSet(unique(seqs)) + reads %<>% name_uniquely('read') + readfasta <- spacer_fasta(outdir) + dir.create(dirname(readfasta), recursive = TRUE, showWarnings = FALSE) + if (verbose) cmessage('\t\tWrite reads to %s', readfasta) + Biostrings::writeXStringSet(reads, readfasta) + + # Map reads and read results + outfile <- spacer_matchfile(outdir, indexdir) + if (verbose) cmessage('\t\tMap reads: %s', outfile) + run_bowtie(readfasta, indexdir, outfile, norc = norc, + mismatches = max(1, mismatches)) # 1-mismatch offtargets + if (verbose) cmessage('\t\tLoad results') # required for pam correction + matches <- read_bowtie_results(outfile, mismatches) + + # Count matches + if (verbose) cmessage('\t\tCount matches') + readdt <- data.table(readname = names(reads), + readseq = unname(as.character(reads))) + readdt %<>% merge(matches, by='readname', all=TRUE, sort=FALSE) + readdt <- cbind(readdt[, c(1, 2)], + data.table::setnafill(readdt[, -c(1, 2)], fill = 0)) + + # Return + readdt[, 'readname' := NULL] + readdt[seqs, on = 'readseq'] +} + +explode <- function(x) unlist(strsplit(x, character(0))) +paste_dtcols <- function(x) x [, do.call(paste0, .SD) ] +expand_iupac_ambiguities <- function(x){ + paste_dtcols( + as.data.table( + lapply(Biostrings::IUPAC_CODE_MAP[explode(x)], explode))) +} + +#' Match spacers +#' +#' Count matches to indexed target/genome and add to GRanges +#' +#' Expands iupac amgiguities in the pam sequence. +#' Matches all resulting sequences against (indexes) target and genome. +#' Adds match counts to GRanges object, and then returns it. +#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} +#' @param indexdir string: dir containing indexed reference. +#' This can be an indexed genome( \code{\link{index_genome}} +#' It can also be indexed targets (\code{\link{index_targets}}) +#' @param norc TRUE or FALSE: whether to run bowtie also with revcompls +#' Generally TRUE for genome and FALSE for target matches, +#' because target ranges generally include both strands. +#' @param mismatches number (default 2): max number of mismatches to consider +#' @param outdir string: file where to output bowtie results +#' @param pam string (default 'NGG') pam pattern to expand +#' @param verbose TRUE (default) or FALSE +#' @return data.table +#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' spacers <- find_pe_spacers(gr, bsgenome) +#' # indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome) +#' # match_spacers(spacers, indexdir, norc=TRUE, mismatches = 1) +#' +#' # TFBS example +#' #------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) +#' indexdir <- index_targets(targets, bsgenome) +#' spacers <- find_spacers(targets, bsgenome) +#' match_spacers(spacers, indexdir, norc=FALSE, mismatches = 1) +#' @export +match_spacers <- function( + spacers, indexdir, norc, mismatches = 2, + outdir = OUTDIR, pam = 'NGG', verbose = TRUE +){ + # Comply + crispr <- crisprspacer <- . <- NULL + + # Expand pams + if (verbose) cmessage('\t\tExpand iupac ambiguities in pam') + spacerseqs <- unique(spacers$crisprspacer) + pamseqs <- expand_iupac_ambiguities(pam) + crisprdt <- data.table( + crisprspacer = rep(spacerseqs, each=length(pamseqs)), + crisprpam = rep(pamseqs, times=length(spacerseqs))) %>% + extract(, crispr := paste0(crisprspacer, pamseqs)) + crisprseqs <- unique(crisprdt$crispr) + + # Count matches + matches <- match_seqs(crisprseqs, + indexdir, + norc = norc, + mismatches = mismatches, + outdir = outdir, + verbose = verbose) + matches %<>% merge(crisprdt, by.x = 'readseq', by.y = 'crispr', all = TRUE) + + # Aggregate per spacer + count_vars <- names(matches) %>% extract(stri_startswith_fixed(., 'MM')) + spacer_dt <- data.table(crisprspacer = unique(matches$crisprspacer)) + for (var in count_vars){ + spacer_dt %<>% merge(matches[ , list(counts = sum(get(var))), + by = 'crisprspacer'], + by = 'crisprspacer') + setnames(spacer_dt, 'counts', var) + } + + # Return + spacer_dt[spacerseqs, on = 'crisprspacer'] +} + +#' Add target counts +#' +#' Count spacer matches among targets +#' +#' Expands iupac amgiguities in the pam sequence. +#' Matches all resulting sequences against (indexes) target and genome. +#' Adds match counts to GRanges object, and then returns it. +#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} +#' @param targets target \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param mismatches number (default 2): max number of mismatches to consider +#' @param outdir dir where output is written to +#' @param pam string (default 'NGG') pam pattern to expand +#' @param verbose TRUE (default) or FALSE +#' @return updated spacer \code{\link[GenomicRanges]{GRanges-class}} +#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} +#' @examples +#' # TFBS example +#' #------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) +#' spacers <- find_spacers(targets, bsgenome) +#' add_target_counts(spacers, targets, bsgenome) +#' @export +add_target_counts <- function( + spacers, targets, bsgenome, mismatches = 2, + pam = 'NGG', outdir = OUTDIR, verbose = TRUE +){ + # Comply + . <- NULL + + # Index targets + targetdir <- target_dir(outdir) + dir.create(targetdir, showWarnings = FALSE, recursive = FALSE) + index_targets(targets, bsgenome, outdir) + + # Match spacers to targets + if (verbose) cmessage('\tAdd target counts') + matches <- match_spacers( + spacers, targetdir, norc = TRUE, + mismatches = mismatches, outdir = outdir, + pam = pam, verbose = verbose) + names(matches) %<>% stringi::stri_replace_first_regex('^MM', 'T') + + # Add counts to spacers + dt <- gr2dt(spacers) %>% + merge(matches, by = 'crisprspacer', sort = FALSE) + + # Organize columns and return + targetvars <- names(dt) %>% extract(stri_startswith_fixed(., 'target')) + crisprvars <- c('crisprname', 'crisprspacer', 'crisprpam', 'crisprext') %>% + intersect(names(dt)) + othervars <- setdiff(names(dt), c(targetvars, crisprvars)) + + dt %>% + extract(, c(targetvars, crisprvars, othervars), with = FALSE) %>% + dt2gr(seqinfo(spacers)) + +} +#' Add genome counts +#' +#' Count spacer matches to genome and add to GRanges +#' +#' Expands iupac amgiguities in the pam sequence. +#' Matches all resulting sequences against (indexes) target and genome. +#' Adds match counts to GRanges object, and then returns it. +#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param mismatches number (default 2): max number of mismatches to consider +#' @param pam string (default 'NGG') pam pattern to expand +#' @param outdir dir where output is written to +#' @param indexedgenomesdir string: dir with indexed genomes +#' @param plot FALSE (default) or TRUE +#' @param verbose TRUE (default) or FALSE +#' @return spacer GRanges with additional mcols +#' @seealso \code{\link{index_genome}}, \code{\link{index_targets}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' spacers <- find_pe_spacers(gr, bsgenome) +#' # index_genome(bsgenome) +#' # add_genome_counts(spacers, bsgenome, mismatches=0, plot = TRUE) +#' +#' # TFBS example +#' #------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) +#' spacers <- find_spacers(targets, bsgenome) +#' # index_genome(bsgenome) +#' # add_genome_counts(spacers, bsgenome) +#' # add_genome_counts(spacers, bsgenome, mismatches=3) +#' @export +add_genome_counts <- function( + spacers, + bsgenome = getBSgenome(genome(spacers)[1]), + mismatches = 2, + pam = 'NGG', + outdir = OUTDIR, + indexedgenomesdir = INDEXEDGENOMESDIR, + plot = FALSE, + verbose = TRUE +){ + . <- NULL + + # Add genome matches + genomedir <- genome_dir(indexedgenomesdir, bsgenome) + if (verbose) message('\tAdd genome counts') + matches <- match_spacers(spacers, genomedir, norc = FALSE, + mismatches = mismatches, + outdir = outdir, pam = pam, verbose = verbose) + names(matches) %<>% stringi::stri_replace_first_regex('^MM', 'G') + dt <- gr2dt(spacers) %>% + merge(matches, by = 'crisprspacer', sort = FALSE) + + # Organize columns and return + targetvars <- names(dt) %>% extract(stri_startswith_fixed(., 'target')) + crisprvars <- c('crisprname', 'crisprspacer', 'crisprpam', 'crisprext') %>% + intersect(names(dt)) + othervars <- setdiff(names(dt), c(targetvars, crisprvars)) + spacers <- dt %>% + extract(, c(targetvars, crisprvars, othervars), with=FALSE) %>% + dt2gr(seqinfo(spacers)) + + # Plot + if (plot){ + grplot <- gr2dt(spacers) %>% + extract(, if(any(.$G0==1)) .SD, by = 'targetname') %>% + dt2gr(seqinfo(spacers)) + p <- plot_intervals(grplot, alpha_var = 'G0') + + ggplot2::scale_alpha(trans = 'reverse', range = c(0.3, 1), + breaks = c(0,1,max(grplot$G0))) + print(p) + } + + # Return + spacers +} + + +#' @export +#' @rdname add_offtargets +add_specificity <- function(...){ + #.Deprecated('add_offtargets') + add_offtargets(...) +} + + +#' Add offtarget counts +#' +#' Add mcols 'off' (offtargets), 'off0' (0-mismatch offtargets), etc. +#' +#' For NULL targets: offtarget counts = (G0- 1) + G1 + ... +#' Non-NULL targets: offtarget counts = (G0-T0) + (G1-T1) + ... +#' +#' @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} +#' @param targets NULL (default) or target +#' \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param mismatches number (default 2): max number of mismatches to consider +#' @param pam string (default 'NGG'): pam sequence +#' @param outdir directory where output is written to +#' @param indexedgenomesdir string: dir with indexed genomes +#' @param plot TRUE (default) or FALSE +#' @param alpha_var string: mapped to alpha in plot +#' @param size_var string: mapped to size in plot +#' @param verbose TRUE (default) or FALSE +#' @param ... to channel deprecated add_specificity to add_offtargets +#' @return filtered spacer \code{\link[GenomicRanges]{GRanges-class}} +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' spacers <- find_pe_spacers(gr, bsgenome) +#' # index_genome(bsgenome) +#' # add_offtargets(spacers, bsgenome, mismatches=0) +#' # add_offtargets(spacers, bsgenome, mismatches=2) +#' # TFBS example +#' #------------- +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- extend(bed_to_granges(bedfile, genome = 'mm10')) +#' spacers <- find_spacers(targets, bsgenome) +#' # index_genome(bsgenome) +#' # spacers %>% add_offtargets(bsgenome) # off = G - 1 +#' # spacers %>% add_offtargets(bsgenome, targets) # off = G - T +#' @export +add_offtargets <- function(spacers, bsgenome, targets = NULL, mismatches = 2, + pam = 'NGG', outdir = OUTDIR, indexedgenomesdir = INDEXEDGENOMESDIR, + plot = TRUE, size_var = default_size_var(spacers), alpha_var = 'off', + verbose= TRUE +){ +# First clear + offcols <- c(paste0('G', 0:3), paste0('T', 0:3), paste0('off', 0:3), 'off') + mcols(spacers) %<>% extract(, setdiff(names(.), offcols)) + . <- off <- NULL +# Add genome/target counts + spacers %<>% add_genome_counts( + bsgenome, mismatches = mismatches, outdir = outdir, + indexedgenomesdir = indexedgenomesdir, + pam = pam, verbose = verbose) + if (!is.null(targets)){ + spacers %<>% add_target_counts( + targets, bsgenome, mismatches = mismatches, + outdir = outdir, pam = pam, verbose = verbose) + for (mis in 0:mismatches){ + assert_all_are_true(mcols(spacers)[[paste0('T', mis)]] <= + mcols(spacers)[[paste0('G', mis)]])}} +# Add offtarget counts + digits <- ceiling(log10(length(spacers))) + if (verbose) cmessage('\tCalculate offtargets for %d spacers', + length(spacers)) + spacers$off <- spacers$G0 - (if (is.null(targets)) 1 else spacers$T0) + spacers$off0 <- spacers$off # don't switch order to keep off first + if (mismatches>0){ + for (mis in seq_len(mismatches)){ + Gx <- mcols(spacers)[[paste0('G', mis)]] + Tx <- if (is.null(targets)) 0 else mcols(spacers)[[paste0('T',mis)]] + offcounts <- Gx - Tx + offvar <- paste0('off', mis) + mcols(spacers)[[offvar]] <- offcounts + spacers$off %<>% add(offcounts) + if (verbose) cmessage('\t %s have no %d-mismatch offtargets', + format(sum(mcols(spacers)[[offvar]]==0), width = digits), mis)}} +# Plot and return + if (plot){ + grplot <- gr2dt(spacers) %>% # don't do that - what if no such exist? + #extract(, if(any(off==0)) .SD, by = 'targetname') %>% + dt2gr(seqinfo(spacers)) + p <- plot_intervals( + grplot, alpha_var = 'off', size_var = size_var) + print(p)} + spacers +} + + +#===================================================================== +# Following functions are no longer exported. +# I think better to leave final filtering as an explicit end user step +#===================================================================== + + +# @rdname add_offtargets +# @export +filter_target_specific <- function(...){ + .Deprecated('filter_offtarget_free') + filter_offtarget_free(...) +} + + +# @rdname add_offtargets +# @export +filter_offtarget_free <- function( + spacers, + targets = NULL, + bsgenome = getBSgenome(genome(spacers)[1]), + mismatches = 2, + pam = 'NGG', + outdir = OUTDIR, + indexedgenomesdir = INDEXEDGENOMESDIR, + plot = TRUE, + verbose = TRUE +){ + . <- NULL + # Add specificty info + spacers %<>% add_offtargets( + bsgenome = bsgenome, + targets = targets, + mismatches = mismatches, + pam = pam, + outdir = outdir, + indexedgenomesdir = indexedgenomesdir, + plot = plot, + verbose = verbose) + + # Subset + spacers %<>% subset(.$off==0) + + # Return + return(spacers) +} + + + +# Filter for specific prime editing spacers +# +# Filters spacers which are specific for prime editing site +# +# @param spacers spacer \code{\link[GenomicRanges]{GRanges-class}} +# @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +# @param outdir directory where output is written to +# @param pam string (default 'NGG'): pam sequence +# @param outdir string: dir to which output is written +# @param indexedgenomesdir dir with bowtie-indexed genomes +# @param verbose TRUE (default) or FALSE +# @return filtered spacer \code{\link[GenomicRanges]{GRanges-class}} +# @examples +# # PE example +# #----------- +# require(magrittr) +# bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +# gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +# HBB = 'chr11:5227002:-', # snp +# HEXA = 'chr15:72346580-72346583:-', # del +# CFTR = 'chr7:117559593-117559595:+'), # ins +# bsgenome) +# spacers <- find_pe_spacers(gr, bsgenome) +# # index_genome(bsgenome) # one time effort - takes few h +# # filter_prime_specific(spacers, bsgenome) +# @export +filter_prime_specific <- function( + spacers, + bsgenome = getBSgenome(genome(spacers)[1]), + pam = 'NGG', + outdir = OUTDIR, + indexedgenomesdir = INDEXEDGENOMESDIR, + verbose = TRUE +){ + # Add genome matches + spacers %<>% add_genome_counts( + bsgenome, mismatches = 1, outdir = outdir, + pam = pam, verbose = verbose) + + # Filter for specificity + digits <- ceiling(log10(length(spacers))) + if (verbose) cmessage('\tFilter %d spacers', length(spacers)) + idx <- spacers$G0==1 + spacers %<>% subset(idx) + if (verbose) cmessage('\t %s G0==1', format(sum(idx), width = digits)) + + # Return + spacers +} + diff --git a/R/08_add_efficiency.R b/R/08_add_efficiency.R index eeaff7e934987dbcf230526240d011abefc63bf9..84e8968f5d39f93e92bb31686f34398df37bc085 100644 --- a/R/08_add_efficiency.R +++ b/R/08_add_efficiency.R @@ -1,263 +1,263 @@ - -#' Add [-4, +3] context -#' -#' Add context for Doench2016 scoring -#' -#' @param spacers \code{\link[GenomicRanges]{GRanges-class}}: spacer ranges -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param verbose logical(1) -#' @return character vector -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' spacers <- find_spacers(extend_for_pe(gr), bsgenome, complement=FALSE) -#' (add_context(spacers, bsgenome)) -#' -#' # TFBS example -#' #------------- -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' targets <- extend(bed_to_granges(bedfile, 'mm10')) -#' spacers <- find_spacers(targets, bsgenome) -#' (spacers %<>% add_context(bsgenome)) -#' @export -add_context <- function(spacers, bsgenome, verbose = TRUE){ - - # Prevent from stats::start from being used (leads to bug!) - contexts <- extend(spacers, -4, +6) - spacers$crisprcontext <- BSgenome::getSeq( - bsgenome, contexts, as.character = TRUE) - if (verbose) message('\t\tAdd (4-23-3) contextseqs') - spacers -} - - -doench2014 <- function( - contextseqs, - python = NULL, - virtualenv = NULL, - condaenv = NULL, - verbose -){ - - # Assert - assert_is_character(contextseqs) - assert_all_are_true(nchar(contextseqs)==30) - assert_is_a_bool(verbose) - - # Message - if (verbose) message('\t\tScore contextseqs with Doench2014') - - # Read featureWeightMatrix - fwfile <- system.file("extdata/DoenchNBT2014.csv", package = "CRISPRseek") - fwmatrix <- read.csv(fwfile, header = TRUE) - - # Score and return - CRISPRseek::calculategRNAEfficiency(contextseqs, - baseBeforegRNA = 4, - featureWeightMatrix = fwmatrix) %>% - magrittr::extract(, 1) -} - -# Note: mclapply vs. bplapply -# I first used BiocParallel::bplapply(). -# That works great on linux, but it fails on windows. -# support.bioconductor.org/p/92587/ explains likely why -# Windows doensn't allow forking (where a child process inherits parent env) -# Instead bplapply defaults to multithreading. -# In that scenario, the reticulation env is not correctly passed. -# mclapply seems like best choice: fork on linux - execute serially on win -doench2016 <- function( - contextseqs, - chunksize = 10000, - verbose = TRUE -){ - # Assert - is_identical_to_true(reticulate::py_module_available('azimuth')) - assert_is_character(contextseqs) - assert_all_are_true(nchar(contextseqs)==30) - assert_is_a_bool(verbose) - - # Message - if (verbose) message('\t\tScore contextseqs with Doench2016 (azimuth)') - start_time <- Sys.time() - - # Score - azi <- reticulate::import('azimuth.model_comparison', delay_load = TRUE) - nchunks <- ceiling(length(contextseqs) / chunksize) - contextchunks <- split( - contextseqs, ceiling(seq_along(contextseqs)/chunksize)) - txt <- paste0('\t\tRun Doench2016 %d times on %d-seq chunks ', - 'to preserve memory') - cmessage(txt, length(contextchunks), chunksize) - mc.cores <- if (is_windows()) 1 else max(1, parallel::detectCores()-2) - doench2016scores <- unlist(parallel::mclapply(contextchunks, - function(x){ - reticulate::py_suppress_warnings( - azi$predict( reticulate::np_array(x), - aa_cut = NULL, - percent_peptide = NULL, - model = NULL, - model_file = NULL, - pam_audit = TRUE, - length_audit = TRUE, - learn_options_override = NULL))}, - mc.cores = mc.cores)) - - # Return - end_time <- Sys.time() - if (verbose) cmessage('\t\tCompleted in %s', - format(end_time - start_time, digits = 2)) - doench2016scores -} - - -#' Add efficiency scores and filter -#' -#' Add Doench2014 or Doench2016 efficiency scores and filter on them -#' -#' \code{add_efficiency} adds efficiency scores -#' \code{filter_efficiency} adds efficiency scores and filters on them -#' -#' @param spacers \code{\link[GenomicRanges]{GRanges-class}}: spacers -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param method 'Doench2014' (default) or 'Doench2016' -#' (requires non-NULL argument python, virtualenv, or condaenv) -#' @param cutoff value to filter on -#' @param chunksize Doench2016 is executed in chunks of chunksize -#' @param verbose TRUE (default) or FALSE -#' @param plot TRUE (default) or FALSE -#' @param alpha_var NULL or string: var mapped to alpha in plot -#' @param size_var NULL or string: var mapped to size in plot -#' @return numeric vector -#' @examples -#' -#' # Install azimuth -#' #---------------- -#' ## With reticulate -#' # require(reticulate) -#' # conda_create('azienv', c('python=2.7')) -#' # use_condaenv('azienv') -#' # py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE) -#' -#' ## Directly -#' # conda create --name azienv python=2.7 -#' # conda activate azienv -#' # pip install azimuth -#' # pip install scikit-learn==0.17.1 -#' -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' targets <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -#' HBB = 'chr11:5227002:-', # snp -#' HEXA = 'chr15:72346580-72346583:-', # del -#' CFTR = 'chr7:117559593-117559595:+'), # ins -#' bsgenome) -#' spacers <- find_pe_spacers(targets, bsgenome) -#' #spacers <- find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE) -#' (spacers %<>% add_efficiency(bsgenome, 'Doench2014')) -#' # reticulate::use_condaenv('azienv') -#' # reticulate::import('azimuth') -#' # spacers %<>% add_efficiency(bsgenome, 'Doench2016') -#' # filter_efficient(spacers, bsgenome, 'Doench2016', 0.4) -#' -#' # TFBS example -#' #------------- -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' targets <- extend(bed_to_granges(bedfile, 'mm10')) -#' spacers <- find_spacers(targets, bsgenome) -#' # reticulate::use_condaenv('azienv') -#' # reticulate::import('azienv') -#' # (spacers %<>% add_offtargets(bsgenome, targets)) -#' # (spacers %>% add_efficiency(bsgenome, 'Doench2014')) -#' # (spacers %>% add_efficiency(bsgenome, 'Doench2016')) -#' @references -#' Doench 2014, Rational design of highly active sgRNAs for -#' CRISPR-Cas9-mediated gene inactivation. Nature Biotechnology, -#' doi: 10.1038/nbt.3026 -#' -#' Doench 2016, Optimized sgRNA design to maximize activity and minimize -#' off-target effects of CRISPR-Cas9. Nature Biotechnology, -#' doi: 10.1038/nbt.3437 -#' -#' Python module azimuth: github/MicrosoftResearch/azimuth -#' @export -add_efficiency <- function( - spacers, bsgenome, method= c('Doench2014', 'Doench2016')[1], - chunksize = 10000, verbose = TRUE, plot = TRUE, - alpha_var = default_alpha_var(spacers), size_var = method -){ - # Assert - assert_is_all_of(spacers, 'GRanges') - assert_is_a_string(method) - assert_is_subset(method, c('Doench2014', 'Doench2016')) - if (method %in% names(mcols(spacers))) mcols(spacers)[[method]] <- NULL - - # Add contextseq - if (verbose) cmessage('\tScore crispr spacers') - spacers %<>% add_context(bsgenome, verbose = verbose) - spacerdt <- gr2dt(spacers) - scoredt <- data.table(crisprcontext = unique(spacerdt$crisprcontext)) - - # Score - scores <- switch(method, - Doench2014 = doench2014(scoredt$crisprcontext, verbose=verbose), - Doench2016 = doench2016(scoredt$crisprcontext, chunksize=chunksize, - verbose=verbose)) - scoredt[ , (method) := scores ] - - # Merge back in - mergedt <- merge(spacerdt, scoredt, - by='crisprcontext', sort=FALSE, all.x=TRUE) - spacers <- dt2gr(mergedt, seqinfo = seqinfo(spacers)) - - # Plot - if (plot){ - p <- plot_intervals(spacers, alpha_var = alpha_var, size_var = size_var) - print(p) - } - - # Return - spacers -} - - -#' @rdname add_efficiency -#' @export -filter_efficient <- function( - spacers, - bsgenome, - method= c('Doench2014', 'Doench2016')[1], - cutoff, - verbose = TRUE, - plot = TRUE, - alpha_var = default_alpha_var(spacers) -){ - spacers %<>% add_efficiency( - bsgenome = bsgenome, method = method, - verbose = verbose, plot = plot, alpha_var = alpha_var) - - idx <- mcols(spacers)[[method]] > cutoff - if (verbose){ - width <- nchar(length(idx)) - cmessage('\t\t%s ranges', formatC(length(idx), width = width)) - cmessage('\t\t%s ranges after filtering for %s > %s', - formatC(sum(idx), width = width), method, as.character(cutoff)) - } - - spacers %>% extract(idx) -} - -default_alpha_var <- function(gr){ - if ('off' %in% names(mcols(gr))) 'off' else NULL + +#' Add [-4, +3] context +#' +#' Add context for Doench2016 scoring +#' +#' @param spacers \code{\link[GenomicRanges]{GRanges-class}}: spacer ranges +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param verbose logical(1) +#' @return character vector +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' spacers <- find_spacers(extend_for_pe(gr), bsgenome, complement=FALSE) +#' (add_context(spacers, bsgenome)) +#' +#' # TFBS example +#' #------------- +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' targets <- extend(bed_to_granges(bedfile, 'mm10')) +#' spacers <- find_spacers(targets, bsgenome) +#' (spacers %<>% add_context(bsgenome)) +#' @export +add_context <- function(spacers, bsgenome, verbose = TRUE){ + + # Prevent from stats::start from being used (leads to bug!) + contexts <- extend(spacers, -4, +6) + spacers$crisprcontext <- BSgenome::getSeq( + bsgenome, contexts, as.character = TRUE) + if (verbose) message('\t\tAdd (4-23-3) contextseqs') + spacers +} + + +doench2014 <- function( + contextseqs, + python = NULL, + virtualenv = NULL, + condaenv = NULL, + verbose +){ + + # Assert + assert_is_character(contextseqs) + assert_all_are_true(nchar(contextseqs)==30) + assert_is_a_bool(verbose) + + # Message + if (verbose) message('\t\tScore contextseqs with Doench2014') + + # Read featureWeightMatrix + fwfile <- system.file("extdata/DoenchNBT2014.csv", package = "CRISPRseek") + fwmatrix <- read.csv(fwfile, header = TRUE) + + # Score and return + CRISPRseek::calculategRNAEfficiency(contextseqs, + baseBeforegRNA = 4, + featureWeightMatrix = fwmatrix) %>% + magrittr::extract(, 1) +} + +# Note: mclapply vs. bplapply +# I first used BiocParallel::bplapply(). +# That works great on linux, but it fails on windows. +# support.bioconductor.org/p/92587/ explains likely why +# Windows doensn't allow forking (where a child process inherits parent env) +# Instead bplapply defaults to multithreading. +# In that scenario, the reticulation env is not correctly passed. +# mclapply seems like best choice: fork on linux - execute serially on win +doench2016 <- function( + contextseqs, + chunksize = 10000, + verbose = TRUE +){ + # Assert + is_identical_to_true(reticulate::py_module_available('azimuth')) + assert_is_character(contextseqs) + assert_all_are_true(nchar(contextseqs)==30) + assert_is_a_bool(verbose) + + # Message + if (verbose) message('\t\tScore contextseqs with Doench2016 (azimuth)') + start_time <- Sys.time() + + # Score + azi <- reticulate::import('azimuth.model_comparison', delay_load = TRUE) + nchunks <- ceiling(length(contextseqs) / chunksize) + contextchunks <- split( + contextseqs, ceiling(seq_along(contextseqs)/chunksize)) + txt <- paste0('\t\tRun Doench2016 %d times on %d-seq chunks ', + 'to preserve memory') + cmessage(txt, length(contextchunks), chunksize) + mc.cores <- if (is_windows()) 1 else max(1, parallel::detectCores()-2) + doench2016scores <- unlist(parallel::mclapply(contextchunks, + function(x){ + reticulate::py_suppress_warnings( + azi$predict( reticulate::np_array(x), + aa_cut = NULL, + percent_peptide = NULL, + model = NULL, + model_file = NULL, + pam_audit = TRUE, + length_audit = TRUE, + learn_options_override = NULL))}, + mc.cores = mc.cores)) + + # Return + end_time <- Sys.time() + if (verbose) cmessage('\t\tCompleted in %s', + format(end_time - start_time, digits = 2)) + doench2016scores +} + + +#' Add efficiency scores and filter +#' +#' Add Doench2014 or Doench2016 efficiency scores and filter on them +#' +#' \code{add_efficiency} adds efficiency scores +#' \code{filter_efficiency} adds efficiency scores and filters on them +#' +#' @param spacers \code{\link[GenomicRanges]{GRanges-class}}: spacers +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param method 'Doench2014' (default) or 'Doench2016' +#' (requires non-NULL argument python, virtualenv, or condaenv) +#' @param cutoff value to filter on +#' @param chunksize Doench2016 is executed in chunks of chunksize +#' @param verbose TRUE (default) or FALSE +#' @param plot TRUE (default) or FALSE +#' @param alpha_var NULL or string: var mapped to alpha in plot +#' @param size_var NULL or string: var mapped to size in plot +#' @return numeric vector +#' @examples +#' +#' # Install azimuth +#' #---------------- +#' ## With reticulate +#' # require(reticulate) +#' # conda_create('azienv', c('python=2.7')) +#' # use_condaenv('azienv') +#' # py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE) +#' +#' ## Directly +#' # conda create --name azienv python=2.7 +#' # conda activate azienv +#' # pip install azimuth +#' # pip install scikit-learn==0.17.1 +#' +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' targets <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +#' HBB = 'chr11:5227002:-', # snp +#' HEXA = 'chr15:72346580-72346583:-', # del +#' CFTR = 'chr7:117559593-117559595:+'), # ins +#' bsgenome) +#' spacers <- find_pe_spacers(targets, bsgenome) +#' #spacers <- find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE) +#' (spacers %<>% add_efficiency(bsgenome, 'Doench2014')) +#' # reticulate::use_condaenv('azienv') +#' # reticulate::import('azimuth') +#' # spacers %<>% add_efficiency(bsgenome, 'Doench2016') +#' # filter_efficient(spacers, bsgenome, 'Doench2016', 0.4) +#' +#' # TFBS example +#' #------------- +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' targets <- extend(bed_to_granges(bedfile, 'mm10')) +#' spacers <- find_spacers(targets, bsgenome) +#' # reticulate::use_condaenv('azienv') +#' # reticulate::import('azienv') +#' # (spacers %<>% add_offtargets(bsgenome, targets)) +#' # (spacers %>% add_efficiency(bsgenome, 'Doench2014')) +#' # (spacers %>% add_efficiency(bsgenome, 'Doench2016')) +#' @references +#' Doench 2014, Rational design of highly active sgRNAs for +#' CRISPR-Cas9-mediated gene inactivation. Nature Biotechnology, +#' doi: 10.1038/nbt.3026 +#' +#' Doench 2016, Optimized sgRNA design to maximize activity and minimize +#' off-target effects of CRISPR-Cas9. Nature Biotechnology, +#' doi: 10.1038/nbt.3437 +#' +#' Python module azimuth: github/MicrosoftResearch/azimuth +#' @export +add_efficiency <- function( + spacers, bsgenome, method= c('Doench2014', 'Doench2016')[1], + chunksize = 10000, verbose = TRUE, plot = TRUE, + alpha_var = default_alpha_var(spacers), size_var = method +){ + # Assert + assert_is_all_of(spacers, 'GRanges') + assert_is_a_string(method) + assert_is_subset(method, c('Doench2014', 'Doench2016')) + if (method %in% names(mcols(spacers))) mcols(spacers)[[method]] <- NULL + + # Add contextseq + if (verbose) cmessage('\tScore crispr spacers') + spacers %<>% add_context(bsgenome, verbose = verbose) + spacerdt <- gr2dt(spacers) + scoredt <- data.table(crisprcontext = unique(spacerdt$crisprcontext)) + + # Score + scores <- switch(method, + Doench2014 = doench2014(scoredt$crisprcontext, verbose=verbose), + Doench2016 = doench2016(scoredt$crisprcontext, chunksize=chunksize, + verbose=verbose)) + scoredt[ , (method) := scores ] + + # Merge back in + mergedt <- merge(spacerdt, scoredt, + by='crisprcontext', sort=FALSE, all.x=TRUE) + spacers <- dt2gr(mergedt, seqinfo = seqinfo(spacers)) + + # Plot + if (plot){ + p <- plot_intervals(spacers, alpha_var = alpha_var, size_var = size_var) + print(p) + } + + # Return + spacers +} + + +#' @rdname add_efficiency +#' @export +filter_efficient <- function( + spacers, + bsgenome, + method= c('Doench2014', 'Doench2016')[1], + cutoff, + verbose = TRUE, + plot = TRUE, + alpha_var = default_alpha_var(spacers) +){ + spacers %<>% add_efficiency( + bsgenome = bsgenome, method = method, + verbose = verbose, plot = plot, alpha_var = alpha_var) + + idx <- mcols(spacers)[[method]] > cutoff + if (verbose){ + width <- nchar(length(idx)) + cmessage('\t\t%s ranges', formatC(length(idx), width = width)) + cmessage('\t\t%s ranges after filtering for %s > %s', + formatC(sum(idx), width = width), method, as.character(cutoff)) + } + + spacers %>% extract(idx) +} + +default_alpha_var <- function(gr){ + if ('off' %in% names(mcols(gr))) 'off' else NULL } \ No newline at end of file diff --git a/README.md b/README.md index fe16b9ce6525e20ad24062b5c2b1b470cbc82014..1eaac084e3c75196adda707b1409a2836ec6cd94 100644 --- a/README.md +++ b/README.md @@ -1,19 +1,19 @@ -<center> <h1> multicrispr </h1> </center> - -[](https://travis-ci.com/bhagwataditya/multicrispr) - -### Installation - - # Install multicrispr - remotes::install_git('https://gitlab.gwdg.de/loosolab/software/multicrispr.git', - repos = BiocManager::repositories()) - # Install azimuth - install.packages('reticulate') - reticulate::conda_create('azienv', c('python=2.7')) - reticulate::use_condaenv('azienv') - reticulate::py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE) - # Index mm10 and hg38 - BiocManager::install('BSgenome.Mmusculus.UCSC.mm10') - BiocManager::install('BSgenome.Hsapiens.UCSC.hg38') - index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) +<center> <h1> multicrispr </h1> </center> + +[](https://travis-ci.com/bhagwataditya/multicrispr) + +### Installation + + # Install multicrispr + remotes::install_git('https://gitlab.gwdg.de/loosolab/software/multicrispr.git', + repos = BiocManager::repositories()) + # Install azimuth + install.packages('reticulate') + reticulate::conda_create('azienv', c('python=2.7')) + reticulate::use_condaenv('azienv') + reticulate::py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE) + # Index mm10 and hg38 + BiocManager::install('BSgenome.Mmusculus.UCSC.mm10') + BiocManager::install('BSgenome.Hsapiens.UCSC.hg38') + index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) index_genome(BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38) \ No newline at end of file diff --git a/_pkgdown.yml b/_pkgdown.yml index c2ea3c2c605d8e8cf32f01fd7bb1cce203825505..380d5b4f1e4cd4df5883f4770c47701304a66eea 100644 --- a/_pkgdown.yml +++ b/_pkgdown.yml @@ -1 +1 @@ -destination: public +destination: public diff --git a/inst/extdata/01_define_targets.png b/inst/extdata/01_define_targets.png index 062db963d5453ee3e985082a798d7c22b532de4b..41b1209e34340effb1040841fa717ce1fd8b0263 100644 Binary files a/inst/extdata/01_define_targets.png and b/inst/extdata/01_define_targets.png differ diff --git a/inst/extdata/02_transform.png b/inst/extdata/02_transform.png index 5db5e3e8b70b6dcd24d5f3067af7e5a57886b899..627a91b0553f3d497033412131e69487677c1ed5 100644 Binary files a/inst/extdata/02_transform.png and b/inst/extdata/02_transform.png differ diff --git a/inst/extdata/03_find.png b/inst/extdata/03_find.png index bfc9e0af82590bb2f3bc5ae56aab7648be91634d..e71a4b9244b8561bfc8b46e07988848a34ace12f 100644 Binary files a/inst/extdata/03_find.png and b/inst/extdata/03_find.png differ diff --git a/inst/extdata/04_offtargets.png b/inst/extdata/04_offtargets.png index 63fdd2f707d370b5b890a602da3c5787ffb4aee8..c89eeff2f3fcc03040c6033ce7c1c65b94182ed4 100644 Binary files a/inst/extdata/04_offtargets.png and b/inst/extdata/04_offtargets.png differ diff --git a/inst/extdata/05_efficiency.png b/inst/extdata/05_efficiency.png index c0002c07c42a6c321d8c2487db28074bd9598cf7..1c4d327c67d31490e8f0055cd9eb5f11a3b2756f 100644 Binary files a/inst/extdata/05_efficiency.png and b/inst/extdata/05_efficiency.png differ diff --git a/inst/extdata/SRF.ensembl b/inst/extdata/SRF.ensembl index bbcd26fc59b1b655213376f73ac335851b0eac5d..bb3858d2605dea7d38bf0eb77f0b04f9b283663b 100644 --- a/inst/extdata/SRF.ensembl +++ b/inst/extdata/SRF.ensembl @@ -1,10 +1,10 @@ -ENSMUSG00000038418 -ENSMUSG00000020564 -ENSMUSG00000052336 -ENSMUSG00000029111 -ENSMUSG00000024544 -ENSMUSG00000074813 -ENSMUSG00000036885 -ENSMUSG00000056536 -ENSMUSG00000055538 -ENSMUSG00000030760 +ENSMUSG00000038418 +ENSMUSG00000020564 +ENSMUSG00000052336 +ENSMUSG00000029111 +ENSMUSG00000024544 +ENSMUSG00000074813 +ENSMUSG00000036885 +ENSMUSG00000056536 +ENSMUSG00000055538 +ENSMUSG00000030760 diff --git a/inst/extdata/SRF.entrez b/inst/extdata/SRF.entrez index 749eba27728155a083b5757b24470a379e7af03e..6d74340929433b7cf6b538cb992991887d2d3288 100644 --- a/inst/extdata/SRF.entrez +++ b/inst/extdata/SRF.entrez @@ -1,10 +1,10 @@ -13653 -380753 -13051 -24116 -52662 -100043424 -622434 -27392 -71918 -66190 +13653 +380753 +13051 +24116 +52662 +100043424 +622434 +27392 +71918 +66190 diff --git a/inst/extdata/pe.png b/inst/extdata/pe.png index 4bc9bb3da80fd432d498ef3d738842f0aa8f0880..3d413015a9933f683bb0d0df5f770057c7bd5b0a 100644 Binary files a/inst/extdata/pe.png and b/inst/extdata/pe.png differ diff --git a/inst/extdata/readme_portrait.png b/inst/extdata/readme_portrait.png index 34a09e1c65feb87d50cd41ed745b67ac07dbaff7..96c4cd26606f3d0afed6487dbbddbdb9189a6021 100644 Binary files a/inst/extdata/readme_portrait.png and b/inst/extdata/readme_portrait.png differ diff --git a/inst/scipts/00_filter_offtargetfree_sites.R b/inst/scipts/00_filter_offtargetfree_sites.R index 0b8a57295b45fd935d5237c7b6f9b24de8a4c9fb..0131c41f73fcd4c4362f14e9b371b11fba4a4259 100644 --- a/inst/scipts/00_filter_offtargetfree_sites.R +++ b/inst/scipts/00_filter_offtargetfree_sites.R @@ -1,276 +1,276 @@ -#============================================================================ - -#' Count target/genome matches -#' @param spacerseqs character vector or -#' \code{\link[Biostrings]{XStringSet-class}} -#' @param targetseqs character vector or -#' \code{\link[Biostrings]{XStringSet-class}} -#' @param pam string (default 'NGG'): sequence following spacerseqs -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param mismatch number: number of allowed mismatches -#' @param include character vector: offtarget analysis chromosomes -#' @param verbose TRUE (default) or FALSE -#' @return numeric(length(spacerseqs)) -#' @examples -#' # PE example -#' #----------- -#' require(magrittr) -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' gr <- GenomicRanges::GRanges( -#' seqnames = c(PRNP = 'chr20:4699600', # snp -#' HBB = 'chr11:5227002', # snp -#' HEXA = 'chr15:72346580-72346583', # del -#' CFTR = 'chr7:117559593-117559595'), # ins -#' strand = c(PRNP = '+', HBB = '-', HEXA = '-', CFTR = '+'), -#' seqinfo = BSgenome::seqinfo(bsgenome)) -#' spacers <- find_spacers(extend_for_pe(gr), bsgenome) -#' spacerseqs <- spacers$spacer -#' # count_genome_matches(spacerseqs, bsgenome, mismatch=0) # 6 mins -#' # count_genome_matches(spacerseqs, bsgenome, mismatch=1) # 32 mins -#' # count_genome_matches(spacerseqs, bsgenome, mismatch=2) -#' # count_genome_matches(spacerseqs, bsgenome, mismatch=3) -#' -#' # TFBS example -#' #------------- -#' require(magrittr) -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- extend(bed_to_granges(bedfile, 'mm10')) -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' spacers <- find_spacers(targets, bsgenome) -#' spacerseqs <- spacers$spacer -#' count_genome_matches(spacerseqs, bsgenome, mismatch = 0, include = 'chrY') -#' -#' # Count matches -#' spacerseqs <- sites$seq[1:10] -#' targetseqs <- targets$seq -#' count_target_matches(spacerseqs, targetseqs, 0) -#' count_genome_matches(spacerseqs, bsgenome, 0, include = 'chrY') -#' @export -count_target_matches <- function( - spacerseqs, - targetseqs, - mismatch, - verbose = TRUE -){ - - # Assert - assert_is_any_of(spacerseqs, c('character', 'XStringSet')) - assert_is_any_of(targetseqs, c('character', 'XStringSet')) - assert_is_a_number(mismatch) - assert_is_subset(mismatch, 0:4) - assert_is_a_bool(verbose) - - # Count - unique_crisprseqs <- unique(spacerseqs) - starttime <- Sys.time() - matches <- rowSums(Biostrings::vcountPDict( - Biostrings::DNAStringSet(unique_crisprseqs), - Biostrings::DNAStringSet(targetseqs), - min.mismatch = mismatch, - max.mismatch = mismatch)) %>% - set_names(unique_crisprseqs) - - # Return - if (verbose) cmessage( '\t\t\tCount %d-mismatch hits in targets: %s', - mismatch, - format(signif(Sys.time() - starttime, 2))) - unname(matches[spacerseqs]) -} - - -#' Convert "included" into "excluded" seqnames -#' -#' @details Convert "included" into "excluded" seqnames. -#' Do this in regex format as required by -#' \code{\link[BSgenome]{BSgenome-utils}}) \code{vcountPDict} and -#' \code{vmatchPDict} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param include character vector with names of included chromosomes -#' @return character vector -#' @examples -#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#' include_to_exclude(bsgenome) -#' @export -include_to_exclude <- function( - bsgenome, - include = GenomeInfoDb::standardChromosomes(bsgenome) -){ - assert_is_all_of(bsgenome, 'BSgenome') - assert_is_character(include) - - # needs to be a regex: https://support.bioconductor.org/p/126593/ - sprintf('^%s$', setdiff(seqnames(bsgenome), include)) -} - - explode <- function(x) unlist(strsplit(x, character(0))) - paste_dtcols <- function(x) x [, do.call(paste0, .SD) ] - expand_iupac_ambiguities <- function(x){ - paste_dtcols( - as.data.table( - lapply(Biostrings::IUPAC_CODE_MAP[explode(x)], explode))) - } - - vsprintf <- function(fmt, ..., first_slowest = TRUE){ - . <- NULL - arguments <- list(...) - n <- arguments %>% vapply(length, integer(1)) %>% Reduce(max, .) - argdf <- arguments %>% - (function(x) if (first_slowest) rev(x) else x) %>% - expand.grid() %>% - (function(x) if (first_slowest) x %>% magrittr::extract(, ncol(.):1) else x) - fun <- function(...) sprintf(fmt, ...) - do.call(fun, argdf) - } - - -.match_genome <- function(seqs, bsgenome, exclude, mismatch){ - res <- vcountPDict(seqs, bsgenome, min.mismatch = mismatch, - max.mismatch = mismatch, exclude = exclude) - res %<>% data.table::as.data.table() - counts = res[, .(N = sum(count)), by = index]$N -} - - -.match_genome_slow <- function(seqs, bsgenome, exclude, mismatch){ - # Parallel R-loop equivalent to .match_genome (serial C loops) - # Is slower, more complicated, and more resource-consuming. - # So no longer used. - unlist(BiocParallel::bplapply( - seqs, - function(x, bsgenome, exclude, mismatch){ - sum(BSgenome::vcountPattern( - pattern = Biostrings::DNAString(x), - subject = bsgenome, - min.mismatch = mismatch, - max.mismatch = mismatch, - exclude = exclude)$count)}, - bsgenome = bsgenome, exclude = exclude, mismatch = mismatch)) -} - - -#' @rdname count_target_matches -#' @export -count_genome_matches <- function( - spacerseqs, - bsgenome, - mismatch = 0, - pam = 'NGG', - include = GenomeInfoDb::standardChromosomes(bsgenome), - verbose = TRUE, - joint = FALSE -){ - # Assert - assert_is_any_of(spacerseqs, c('character', 'XStringSet')) - assert_is_a_string(pam) - assert_is_any_of(bsgenome, 'BSgenome') - assert_is_subset(mismatch, 0:4) - assert_is_character(include) - assert_is_a_bool(verbose) - - # Comply - . <- count <- NULL - - # Count - pamseqs <- expand_iupac_ambiguities(pam) - sitedt <- data.table(spacer = rep(spacerseqs, each = length(pamseqs)), - pam = rep(pamseqs, times = length(spacerseqs))) %>% - extract(, crispr := paste0(spacer, pamseqs) ) - seqdt <- data.table(crispr = unique(sitedt$crispr)) - - starttime <- Sys.time() - excl <- include_to_exclude(bsgenome, include) - seqdt[ , nmatches := .match_genome(crispr, bsgenome, excl, mismatch) ] - - # Return - if (verbose) cmessage( '\t\t\tCount %d-mismatch hits in genome : %s', - mismatch, format(signif(Sys.time() - starttime, 2))) - sitedt %>% merge(seqdt, by = 'crispr') %>% - extract(, .(n = sum(nmatches)), by = 'spacer') %>% - extract(spacerseqs, n, on = 'spacer') -} - - -add_seqinfo <- function(gr, bsgenome){ - seqinfo(gr) <- seqinfo(bsgenome) - gr -} - - -#' Filter for offtarget-free crispr sites -#' @param sites \code{\link[GenomicRanges]{GRanges-class}}: crispr sites -#' @param targets \code{\link[GenomicRanges]{GRanges-class}} -#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} -#' @param mismatch number: max number of mismatches to consider -#' @param include character vector: offtarget analysis chromosomes -#' @param plot TRUE (default) or FALSE -#' @param verbose TRUE (default) or FALSE -#' @return \code{\link[GenomicRanges]{GRanges-class}} -#' mcols(GRanges) contains sequences and match counts: -#' matches0 = perfect match counts -#' matches1 = single mismatch counts -#' matches2 = double mismatch counts -#' @examples -#' # Read ranges, extend, and restrict to 'chrY' (to keep example fast) -#' require(magrittr) -#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -#' targets <- bed_to_granges(bedfile, 'mm10') -#' targets %<>% extend() -#' targets %<>% extract(seqnames(.)=='chrY') -#' -#' # Add seqs and find crispr sites -#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#' targets %<>% add_seq(bsgenome) -#' sites <- find_spacers(targets, bsgenome) -#' -#' # Filter for offtarget-free sites -#' filter_offtargetfree_sites( -#' sites, targets, bsgenome, 0, include = 'chrY') -#' @export -filter_offtargetfree_sites <- function(sites, targets, bsgenome, mismatch = 2, - include = standardChromosomes(targets), plot = TRUE, verbose = TRUE){ - - # Assert. Prepare - assert_is_all_of(sites, 'GRanges') - assert_is_all_of(targets, 'GRanges') - assert_is_all_of(bsgenome, 'BSgenome') - assert_is_a_number(mismatch) - assert_is_character(include) - assert_is_subset(include, seqnames(bsgenome)) - assert_is_subset('seq',names(mcols(sites))) - assert_is_subset('seq',names(mcols(targets))) - targetseqs <- targets$seq - crisprseq_dt <- data.table(seq = unique(sites$seq)) - - # Count-store-filter for 0-2 mismatches - if (verbose) message('\tFind crispr seq (mis)matches') - for (mis in 0:mismatch){ - if (verbose) cmessage('\t\twith %d mismatch(es)', mis) - # Count - target_matches <- count_target_matches(crisprseq_dt$seq, - targetseqs, mis, verbose = verbose) - genome_matches <- count_genome_matches(crisprseq_dt$seq, bsgenome, mis, - include = include, verbose = verbose) - # Store - crisprseq_dt [ , (sprintf('matches%d', mis)) := target_matches ] - - # Filter - assert_all_are_false(genome_matches < target_matches) - idx <- genome_matches == target_matches - if (verbose) cmessage('\t\t\tKeep %d/%d offtarget-free crispr seqs', - sum(idx), length(idx), mis) - crisprseq_dt %<>% extract(idx) - } - - # Filter for offtargetfree sites - offtargetfree <- crisprseq_dt %>% - merge(as.data.table(sites), by = 'seq') %>% - as('GRanges') %>% add_seqinfo(bsgenome) - # Plot/Report - if (plot) plot_karyogram(GenomicRanges::GRangesList( - target = targets, cas9 = sites, - offtargetfree = offtargetfree)) - if (verbose) cmessage('\tReturn %d crispr seqs across %d ranges', - length(unique(offtargetfree$seq)), length(offtargetfree)) - # Return - offtargetfree -} +#============================================================================ + +#' Count target/genome matches +#' @param spacerseqs character vector or +#' \code{\link[Biostrings]{XStringSet-class}} +#' @param targetseqs character vector or +#' \code{\link[Biostrings]{XStringSet-class}} +#' @param pam string (default 'NGG'): sequence following spacerseqs +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param mismatch number: number of allowed mismatches +#' @param include character vector: offtarget analysis chromosomes +#' @param verbose TRUE (default) or FALSE +#' @return numeric(length(spacerseqs)) +#' @examples +#' # PE example +#' #----------- +#' require(magrittr) +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' gr <- GenomicRanges::GRanges( +#' seqnames = c(PRNP = 'chr20:4699600', # snp +#' HBB = 'chr11:5227002', # snp +#' HEXA = 'chr15:72346580-72346583', # del +#' CFTR = 'chr7:117559593-117559595'), # ins +#' strand = c(PRNP = '+', HBB = '-', HEXA = '-', CFTR = '+'), +#' seqinfo = BSgenome::seqinfo(bsgenome)) +#' spacers <- find_spacers(extend_for_pe(gr), bsgenome) +#' spacerseqs <- spacers$spacer +#' # count_genome_matches(spacerseqs, bsgenome, mismatch=0) # 6 mins +#' # count_genome_matches(spacerseqs, bsgenome, mismatch=1) # 32 mins +#' # count_genome_matches(spacerseqs, bsgenome, mismatch=2) +#' # count_genome_matches(spacerseqs, bsgenome, mismatch=3) +#' +#' # TFBS example +#' #------------- +#' require(magrittr) +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- extend(bed_to_granges(bedfile, 'mm10')) +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' spacers <- find_spacers(targets, bsgenome) +#' spacerseqs <- spacers$spacer +#' count_genome_matches(spacerseqs, bsgenome, mismatch = 0, include = 'chrY') +#' +#' # Count matches +#' spacerseqs <- sites$seq[1:10] +#' targetseqs <- targets$seq +#' count_target_matches(spacerseqs, targetseqs, 0) +#' count_genome_matches(spacerseqs, bsgenome, 0, include = 'chrY') +#' @export +count_target_matches <- function( + spacerseqs, + targetseqs, + mismatch, + verbose = TRUE +){ + + # Assert + assert_is_any_of(spacerseqs, c('character', 'XStringSet')) + assert_is_any_of(targetseqs, c('character', 'XStringSet')) + assert_is_a_number(mismatch) + assert_is_subset(mismatch, 0:4) + assert_is_a_bool(verbose) + + # Count + unique_crisprseqs <- unique(spacerseqs) + starttime <- Sys.time() + matches <- rowSums(Biostrings::vcountPDict( + Biostrings::DNAStringSet(unique_crisprseqs), + Biostrings::DNAStringSet(targetseqs), + min.mismatch = mismatch, + max.mismatch = mismatch)) %>% + set_names(unique_crisprseqs) + + # Return + if (verbose) cmessage( '\t\t\tCount %d-mismatch hits in targets: %s', + mismatch, + format(signif(Sys.time() - starttime, 2))) + unname(matches[spacerseqs]) +} + + +#' Convert "included" into "excluded" seqnames +#' +#' @details Convert "included" into "excluded" seqnames. +#' Do this in regex format as required by +#' \code{\link[BSgenome]{BSgenome-utils}}) \code{vcountPDict} and +#' \code{vmatchPDict} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param include character vector with names of included chromosomes +#' @return character vector +#' @examples +#' bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#' include_to_exclude(bsgenome) +#' @export +include_to_exclude <- function( + bsgenome, + include = GenomeInfoDb::standardChromosomes(bsgenome) +){ + assert_is_all_of(bsgenome, 'BSgenome') + assert_is_character(include) + + # needs to be a regex: https://support.bioconductor.org/p/126593/ + sprintf('^%s$', setdiff(seqnames(bsgenome), include)) +} + + explode <- function(x) unlist(strsplit(x, character(0))) + paste_dtcols <- function(x) x [, do.call(paste0, .SD) ] + expand_iupac_ambiguities <- function(x){ + paste_dtcols( + as.data.table( + lapply(Biostrings::IUPAC_CODE_MAP[explode(x)], explode))) + } + + vsprintf <- function(fmt, ..., first_slowest = TRUE){ + . <- NULL + arguments <- list(...) + n <- arguments %>% vapply(length, integer(1)) %>% Reduce(max, .) + argdf <- arguments %>% + (function(x) if (first_slowest) rev(x) else x) %>% + expand.grid() %>% + (function(x) if (first_slowest) x %>% magrittr::extract(, ncol(.):1) else x) + fun <- function(...) sprintf(fmt, ...) + do.call(fun, argdf) + } + + +.match_genome <- function(seqs, bsgenome, exclude, mismatch){ + res <- vcountPDict(seqs, bsgenome, min.mismatch = mismatch, + max.mismatch = mismatch, exclude = exclude) + res %<>% data.table::as.data.table() + counts = res[, .(N = sum(count)), by = index]$N +} + + +.match_genome_slow <- function(seqs, bsgenome, exclude, mismatch){ + # Parallel R-loop equivalent to .match_genome (serial C loops) + # Is slower, more complicated, and more resource-consuming. + # So no longer used. + unlist(BiocParallel::bplapply( + seqs, + function(x, bsgenome, exclude, mismatch){ + sum(BSgenome::vcountPattern( + pattern = Biostrings::DNAString(x), + subject = bsgenome, + min.mismatch = mismatch, + max.mismatch = mismatch, + exclude = exclude)$count)}, + bsgenome = bsgenome, exclude = exclude, mismatch = mismatch)) +} + + +#' @rdname count_target_matches +#' @export +count_genome_matches <- function( + spacerseqs, + bsgenome, + mismatch = 0, + pam = 'NGG', + include = GenomeInfoDb::standardChromosomes(bsgenome), + verbose = TRUE, + joint = FALSE +){ + # Assert + assert_is_any_of(spacerseqs, c('character', 'XStringSet')) + assert_is_a_string(pam) + assert_is_any_of(bsgenome, 'BSgenome') + assert_is_subset(mismatch, 0:4) + assert_is_character(include) + assert_is_a_bool(verbose) + + # Comply + . <- count <- NULL + + # Count + pamseqs <- expand_iupac_ambiguities(pam) + sitedt <- data.table(spacer = rep(spacerseqs, each = length(pamseqs)), + pam = rep(pamseqs, times = length(spacerseqs))) %>% + extract(, crispr := paste0(spacer, pamseqs) ) + seqdt <- data.table(crispr = unique(sitedt$crispr)) + + starttime <- Sys.time() + excl <- include_to_exclude(bsgenome, include) + seqdt[ , nmatches := .match_genome(crispr, bsgenome, excl, mismatch) ] + + # Return + if (verbose) cmessage( '\t\t\tCount %d-mismatch hits in genome : %s', + mismatch, format(signif(Sys.time() - starttime, 2))) + sitedt %>% merge(seqdt, by = 'crispr') %>% + extract(, .(n = sum(nmatches)), by = 'spacer') %>% + extract(spacerseqs, n, on = 'spacer') +} + + +add_seqinfo <- function(gr, bsgenome){ + seqinfo(gr) <- seqinfo(bsgenome) + gr +} + + +#' Filter for offtarget-free crispr sites +#' @param sites \code{\link[GenomicRanges]{GRanges-class}}: crispr sites +#' @param targets \code{\link[GenomicRanges]{GRanges-class}} +#' @param bsgenome \code{\link[BSgenome]{BSgenome-class}} +#' @param mismatch number: max number of mismatches to consider +#' @param include character vector: offtarget analysis chromosomes +#' @param plot TRUE (default) or FALSE +#' @param verbose TRUE (default) or FALSE +#' @return \code{\link[GenomicRanges]{GRanges-class}} +#' mcols(GRanges) contains sequences and match counts: +#' matches0 = perfect match counts +#' matches1 = single mismatch counts +#' matches2 = double mismatch counts +#' @examples +#' # Read ranges, extend, and restrict to 'chrY' (to keep example fast) +#' require(magrittr) +#' bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +#' targets <- bed_to_granges(bedfile, 'mm10') +#' targets %<>% extend() +#' targets %<>% extract(seqnames(.)=='chrY') +#' +#' # Add seqs and find crispr sites +#' bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#' targets %<>% add_seq(bsgenome) +#' sites <- find_spacers(targets, bsgenome) +#' +#' # Filter for offtarget-free sites +#' filter_offtargetfree_sites( +#' sites, targets, bsgenome, 0, include = 'chrY') +#' @export +filter_offtargetfree_sites <- function(sites, targets, bsgenome, mismatch = 2, + include = standardChromosomes(targets), plot = TRUE, verbose = TRUE){ + + # Assert. Prepare + assert_is_all_of(sites, 'GRanges') + assert_is_all_of(targets, 'GRanges') + assert_is_all_of(bsgenome, 'BSgenome') + assert_is_a_number(mismatch) + assert_is_character(include) + assert_is_subset(include, seqnames(bsgenome)) + assert_is_subset('seq',names(mcols(sites))) + assert_is_subset('seq',names(mcols(targets))) + targetseqs <- targets$seq + crisprseq_dt <- data.table(seq = unique(sites$seq)) + + # Count-store-filter for 0-2 mismatches + if (verbose) message('\tFind crispr seq (mis)matches') + for (mis in 0:mismatch){ + if (verbose) cmessage('\t\twith %d mismatch(es)', mis) + # Count + target_matches <- count_target_matches(crisprseq_dt$seq, + targetseqs, mis, verbose = verbose) + genome_matches <- count_genome_matches(crisprseq_dt$seq, bsgenome, mis, + include = include, verbose = verbose) + # Store + crisprseq_dt [ , (sprintf('matches%d', mis)) := target_matches ] + + # Filter + assert_all_are_false(genome_matches < target_matches) + idx <- genome_matches == target_matches + if (verbose) cmessage('\t\t\tKeep %d/%d offtarget-free crispr seqs', + sum(idx), length(idx), mis) + crisprseq_dt %<>% extract(idx) + } + + # Filter for offtargetfree sites + offtargetfree <- crisprseq_dt %>% + merge(as.data.table(sites), by = 'seq') %>% + as('GRanges') %>% add_seqinfo(bsgenome) + # Plot/Report + if (plot) plot_karyogram(GenomicRanges::GRangesList( + target = targets, cas9 = sites, + offtargetfree = offtargetfree)) + if (verbose) cmessage('\tReturn %d crispr seqs across %d ranges', + length(unique(offtargetfree$seq)), length(offtargetfree)) + # Return + offtargetfree +} diff --git a/inst/scipts/01_annotationhub_resources.R b/inst/scipts/01_annotationhub_resources.R index da890966ff486f796f6ef8b70aaf1135c43fcd1a..3577648b99a4b3e984ea87071f8e5e183e6e337d 100644 --- a/inst/scipts/01_annotationhub_resources.R +++ b/inst/scipts/01_annotationhub_resources.R @@ -1,44 +1,44 @@ -# Annotation Mus musculus -require(AnnotationHub) -ah <- AnnotationHub() -names(ah)[1:10] -ah <- query(ah, 'Mus musculus') -ah <- query(ah, 'Homo sapiens') -table(ah$dataprovider) - -# UCSC -ucsc <- ah[ah$dataprovider=='UCSC'] # UCSC -table(ucsc$rdataclass) #----- - granges <- query(ucsc, 'GRanges') # 173 GRanges with UCSC tracks - table(granges$sourcetype) - - txdbs <- query(ucsc, 'TxDb') # 5 TxDb G/T/P models - table(txdbs) # mm9/10 - - twobitfiles <- query(ucsc, 'twoBitFile') # 4 TwoBitFiles seqs - twobitfiles # mm7, 8, 9, 10 - -# NCBI # NCBI -ncbi <- query(ah, 'NCBI') #----- - # 1 org.Mm.eg.db with gene annotations - -# Ensembl -ensembl <- ah[ah$dataprovider == 'Ensembl'] -table(ensembl$rdataclass) # Ensembl - #--------- - ensdbs <- query(ensembl, 'EnsDb') # 12 EnsDb: 87->98 - ensdbs$title - - twobitfiles <- query(ensembl, 'twoBitFile') # 815 TwoBitFile seqs - sort(table(twobitfiles$genome), decreasing=TRUE) - - twobitfiles <- query(twobitfiles,'GRCm38') # 75 GRCm38 (others: BALB_cJ_v1, C3H_HeJ_v1, ...) - data.frame(names(twobitfiles)[order(twobitfiles$title)], twobitfiles$title[order(twobitfiles$title)]) - twobitfiles['AH49772'] # Lots of data redundancy due to periodic automated builds - twobitfiles['AH50117'] # https://support.bioconductor.org/p/125690 - table(twobitfiles$title) # cdna, dna(_r|sm), ncrna - - granges <- query(ensembl, 'GRanges') # 556 GRanges GTFs - granges[1] - sort(granges$title) - +# Annotation Mus musculus +require(AnnotationHub) +ah <- AnnotationHub() +names(ah)[1:10] +ah <- query(ah, 'Mus musculus') +ah <- query(ah, 'Homo sapiens') +table(ah$dataprovider) + +# UCSC +ucsc <- ah[ah$dataprovider=='UCSC'] # UCSC +table(ucsc$rdataclass) #----- + granges <- query(ucsc, 'GRanges') # 173 GRanges with UCSC tracks + table(granges$sourcetype) + + txdbs <- query(ucsc, 'TxDb') # 5 TxDb G/T/P models + table(txdbs) # mm9/10 + + twobitfiles <- query(ucsc, 'twoBitFile') # 4 TwoBitFiles seqs + twobitfiles # mm7, 8, 9, 10 + +# NCBI # NCBI +ncbi <- query(ah, 'NCBI') #----- + # 1 org.Mm.eg.db with gene annotations + +# Ensembl +ensembl <- ah[ah$dataprovider == 'Ensembl'] +table(ensembl$rdataclass) # Ensembl + #--------- + ensdbs <- query(ensembl, 'EnsDb') # 12 EnsDb: 87->98 + ensdbs$title + + twobitfiles <- query(ensembl, 'twoBitFile') # 815 TwoBitFile seqs + sort(table(twobitfiles$genome), decreasing=TRUE) + + twobitfiles <- query(twobitfiles,'GRCm38') # 75 GRCm38 (others: BALB_cJ_v1, C3H_HeJ_v1, ...) + data.frame(names(twobitfiles)[order(twobitfiles$title)], twobitfiles$title[order(twobitfiles$title)]) + twobitfiles['AH49772'] # Lots of data redundancy due to periodic automated builds + twobitfiles['AH50117'] # https://support.bioconductor.org/p/125690 + table(twobitfiles$title) # cdna, dna(_r|sm), ncrna + + granges <- query(ensembl, 'GRanges') # 556 GRanges GTFs + granges[1] + sort(granges$title) + diff --git a/inst/scipts/02_pe_clinvar.R b/inst/scipts/02_pe_clinvar.R index 9bb62ce93c616aad31aa51729269c55b044d2719..89cd29bdf18ffd6ad020ed88596a1ea933b9cd92 100644 --- a/inst/scipts/02_pe_clinvar.R +++ b/inst/scipts/02_pe_clinvar.R @@ -1,101 +1,101 @@ -#============================================================================= -# Clinvar is available in VCF (highly formalized) and HGVS (less formalized). -# The VCF format is highly formalized and well suited for programming, -# The HGVS format is ambiguous and not well suited for programming -#============================================================================= - - -# Clinvar in VCF (preferred) -#--------------------------- -devtools::load_all() -localfile <- paste0('~/.multicrispr/clinvar.vcf') -if (!file.exists(localfile)){ - utils::download.file( - url = 'ftp://ftp.ncbi.nlm.nih.gov/pub/clinvar/vcf_GRCh38/clinvar.vcf.gz', - destfile = paste0(localfile, '.gz')) -} -bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 -#vcf <- VariantAnnotation::readVcf('~/.multicrispr/clinvar.vcf') -vr <- VariantAnnotation::readVcfAsVRanges('~/.multicrispr/clinvar.vcf') -vr %<>% extract(as.character(seqnames(vr)) %in% seqlevels(bsgenome)) -seqlevels(vr) <- seqlevelsInUse(vr) -seqinfo(vr) <- seqinfo(bsgenome)[seqlevels(vr)] -vr -show_sample <- function(clnvc, i=1){ - smallvr <- vr[vr$CLNVC == clnvc][i] - mcols(smallvr) <- NULL - print(smallvr) - BSgenome::getSeq(bsgenome, smallvr) -} -sort(table(vr$CLNVC)) -show_sample('single_nucleotide_variant') # 443 238 -show_sample('Deletion') # 31 472 -show_sample('Duplication') # 14 156 -show_sample('Microsatellite') # 8 506 -show_sample('Indel') # 3 923 -show_sample('Insertion') # 2 944 -show_sample('Inversion') # 226 -show_sample('copy_number_loss') # 13 -show_sample('Variation') # 6 -show_sample('copy_number_gain') # 2 - -# ClinVar in HGVS (not well suited for programming) -#-------------------------------------------------- -localfile <- '~/.multicrispr/variant_summary.txt.gz' -if (!file.exists(localfile)){ - utils::download.file( - url = paste0( - 'ftp://ftp.ncbi.nlm.nih.gov/pub/clinvar/tab_delimited/', - 'variant_summary.txt.gz'), - destfile = localfile) -} -clinvar <- data.table::fread(localfile) -clinvar %<>% extract(Assembly=='GRCh38') # 523 K -clinvar %<>% extract(OriginSimple == 'germline') # 481 K -clinvar[, sort(table(ClinicalSignificance))] -clinvar %<>% extract(ClinicalSignificance == 'Pathogenic') # 64 K -clinvar[, c('Assembly', - 'ClinicalSignificance', 'ClinSigSimple', - 'Origin', 'OriginSimple', - 'PhenotypeIDS', 'VariationID', 'SubmitterCategories', 'OtherIDs', - 'Guidelines', 'TestedInGTR', 'LastEvaluated', - 'RCVaccession', 'HGNC_ID', 'RS# (dbSNP)', - 'nsv/esv (dbVar)', 'ChromosomeAccession') := NULL ] -clinvar[, sort(table(Type))] -clinvar[, sort(table(ReviewStatus))] -clinvar[, length(unique(GeneID))] # 3 790 genes -clinvar[, .(nalleles = .N), by = 'GeneID'][, .(freq = .N), by = nalleles][order(freq)] -clinvar %<>% extract(Stop - Start) - -firstrecord <- function(dt, itype, igene=1){ - dt %>% - extract(Type==names(rev(sort(table(Type))))[itype]) %>% - extract(GeneSymbol==unique(GeneSymbol)[igene]) %>% - extract(1) -} -getSeq <- function(dt) dt %>% - extract(, BSgenome::getSeq( - bsgenome, - paste0('chr', Chromosome), Start, Stop)) -clinvar[, sort(table(Type))] -firstrecord(clinvar, 1) # 8 335 snvs -firstrecord(clinvar, 1) %>% getSeq() -firstrecord(clinvar, 2) # 1 950 indels -firstrecord(clinvar, 2, 2) -firstrecord(clinvar, 2, 2) %>% getSeq() -firstrecord(clinvar, 3) # 1 604 deletions -firstrecord(clinvar, 3) %>% getSeq() -firstrecord(clinvar, 4, 3) # 1 503 duplications -firstrecord(clinvar, 4, 3) %>% getSeq() -firstrecord(clinvar, 5) # 377 insertions -firstrecord(clinvar, 5) %>% getSeq() - - - -clinvar[Type==names(rev(sort(table(Type))))[1]][GeneSymbol==unique(GeneSymbol)[1]][1] - -clinvar[Type==names(rev(sort(table(Type))))[2]][GeneSymbol==unique(GeneSymbol)[1]][1] - -clinvar -clinvar[Type=='deletion'] -cli +#============================================================================= +# Clinvar is available in VCF (highly formalized) and HGVS (less formalized). +# The VCF format is highly formalized and well suited for programming, +# The HGVS format is ambiguous and not well suited for programming +#============================================================================= + + +# Clinvar in VCF (preferred) +#--------------------------- +devtools::load_all() +localfile <- paste0('~/.multicrispr/clinvar.vcf') +if (!file.exists(localfile)){ + utils::download.file( + url = 'ftp://ftp.ncbi.nlm.nih.gov/pub/clinvar/vcf_GRCh38/clinvar.vcf.gz', + destfile = paste0(localfile, '.gz')) +} +bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 +#vcf <- VariantAnnotation::readVcf('~/.multicrispr/clinvar.vcf') +vr <- VariantAnnotation::readVcfAsVRanges('~/.multicrispr/clinvar.vcf') +vr %<>% extract(as.character(seqnames(vr)) %in% seqlevels(bsgenome)) +seqlevels(vr) <- seqlevelsInUse(vr) +seqinfo(vr) <- seqinfo(bsgenome)[seqlevels(vr)] +vr +show_sample <- function(clnvc, i=1){ + smallvr <- vr[vr$CLNVC == clnvc][i] + mcols(smallvr) <- NULL + print(smallvr) + BSgenome::getSeq(bsgenome, smallvr) +} +sort(table(vr$CLNVC)) +show_sample('single_nucleotide_variant') # 443 238 +show_sample('Deletion') # 31 472 +show_sample('Duplication') # 14 156 +show_sample('Microsatellite') # 8 506 +show_sample('Indel') # 3 923 +show_sample('Insertion') # 2 944 +show_sample('Inversion') # 226 +show_sample('copy_number_loss') # 13 +show_sample('Variation') # 6 +show_sample('copy_number_gain') # 2 + +# ClinVar in HGVS (not well suited for programming) +#-------------------------------------------------- +localfile <- '~/.multicrispr/variant_summary.txt.gz' +if (!file.exists(localfile)){ + utils::download.file( + url = paste0( + 'ftp://ftp.ncbi.nlm.nih.gov/pub/clinvar/tab_delimited/', + 'variant_summary.txt.gz'), + destfile = localfile) +} +clinvar <- data.table::fread(localfile) +clinvar %<>% extract(Assembly=='GRCh38') # 523 K +clinvar %<>% extract(OriginSimple == 'germline') # 481 K +clinvar[, sort(table(ClinicalSignificance))] +clinvar %<>% extract(ClinicalSignificance == 'Pathogenic') # 64 K +clinvar[, c('Assembly', + 'ClinicalSignificance', 'ClinSigSimple', + 'Origin', 'OriginSimple', + 'PhenotypeIDS', 'VariationID', 'SubmitterCategories', 'OtherIDs', + 'Guidelines', 'TestedInGTR', 'LastEvaluated', + 'RCVaccession', 'HGNC_ID', 'RS# (dbSNP)', + 'nsv/esv (dbVar)', 'ChromosomeAccession') := NULL ] +clinvar[, sort(table(Type))] +clinvar[, sort(table(ReviewStatus))] +clinvar[, length(unique(GeneID))] # 3 790 genes +clinvar[, .(nalleles = .N), by = 'GeneID'][, .(freq = .N), by = nalleles][order(freq)] +clinvar %<>% extract(Stop - Start) + +firstrecord <- function(dt, itype, igene=1){ + dt %>% + extract(Type==names(rev(sort(table(Type))))[itype]) %>% + extract(GeneSymbol==unique(GeneSymbol)[igene]) %>% + extract(1) +} +getSeq <- function(dt) dt %>% + extract(, BSgenome::getSeq( + bsgenome, + paste0('chr', Chromosome), Start, Stop)) +clinvar[, sort(table(Type))] +firstrecord(clinvar, 1) # 8 335 snvs +firstrecord(clinvar, 1) %>% getSeq() +firstrecord(clinvar, 2) # 1 950 indels +firstrecord(clinvar, 2, 2) +firstrecord(clinvar, 2, 2) %>% getSeq() +firstrecord(clinvar, 3) # 1 604 deletions +firstrecord(clinvar, 3) %>% getSeq() +firstrecord(clinvar, 4, 3) # 1 503 duplications +firstrecord(clinvar, 4, 3) %>% getSeq() +firstrecord(clinvar, 5) # 377 insertions +firstrecord(clinvar, 5) %>% getSeq() + + + +clinvar[Type==names(rev(sort(table(Type))))[1]][GeneSymbol==unique(GeneSymbol)[1]][1] + +clinvar[Type==names(rev(sort(table(Type))))[2]][GeneSymbol==unique(GeneSymbol)[1]][1] + +clinvar +clinvar[Type=='deletion'] +cli diff --git a/inst/scipts/02_pe_coords_cftr.R b/inst/scipts/02_pe_coords_cftr.R index 3f08fc739b504f984a4c6de96cd91aa60c460a3e..73109f6a094f07ef51a2d895eae139ff7b497f39 100644 --- a/inst/scipts/02_pe_coords_cftr.R +++ b/inst/scipts/02_pe_coords_cftr.R @@ -1,34 +1,34 @@ -# Load functions - require(magrittr) - require(multicrispr) - filter <- ensembldb::filter - UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter - UniprotDbFilter <- ensembldb::UniprotDbFilter - - -# Map identifiers: CFTR - ensdb <- multicrispr::EnsDb.Hsapiens.v98() - ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) - ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) - ensembldb::columns(ensdb) - mycolumns <- c( - 'UNIPROTID', 'PROTEINID', 'TXID', - 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', - 'GENESEQSTART', 'GENESEQEND', - 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', - 'PROTEINSEQUENCE') - cftr <- ensembldb::select(ensdb, 'CFTR', mycolumns, 'SYMBOL') - cftr # Two transcripts - # Two distinct proteins - # ENSP00000003084 gold labeled - ensp <- 'ENSP00000003084' - cftr %<>% extract(.$PROTEINID == ensp, ) - cftr$PROTEINSEQUENCE %>% substr(507, 509) # DELTA F 508 - gr <- ensembldb::proteinToGenome( - IRanges::IRanges(start=508, end=508) %>% set_names(ensp), - ensdb) %>% - extract2(ensp) %>% - (function(y){seqlevelsStyle(y) <- 'UCSC'; y}) - bs <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 - BSgenome::getSeq( - bs, seqnames(gr), start = start(gr), end = end(gr), strand = '+') +# Load functions + require(magrittr) + require(multicrispr) + filter <- ensembldb::filter + UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter + UniprotDbFilter <- ensembldb::UniprotDbFilter + + +# Map identifiers: CFTR + ensdb <- multicrispr::EnsDb.Hsapiens.v98() + ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) + ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) + ensembldb::columns(ensdb) + mycolumns <- c( + 'UNIPROTID', 'PROTEINID', 'TXID', + 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', + 'GENESEQSTART', 'GENESEQEND', + 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', + 'PROTEINSEQUENCE') + cftr <- ensembldb::select(ensdb, 'CFTR', mycolumns, 'SYMBOL') + cftr # Two transcripts + # Two distinct proteins + # ENSP00000003084 gold labeled + ensp <- 'ENSP00000003084' + cftr %<>% extract(.$PROTEINID == ensp, ) + cftr$PROTEINSEQUENCE %>% substr(507, 509) # DELTA F 508 + gr <- ensembldb::proteinToGenome( + IRanges::IRanges(start=508, end=508) %>% set_names(ensp), + ensdb) %>% + extract2(ensp) %>% + (function(y){seqlevelsStyle(y) <- 'UCSC'; y}) + bs <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 + BSgenome::getSeq( + bs, seqnames(gr), start = start(gr), end = end(gr), strand = '+') diff --git a/inst/scipts/02_pe_coords_hbb.R b/inst/scipts/02_pe_coords_hbb.R index 3e714ac97019565c60dc506dffa48b7d5f3e0240..604e79bd6101fafe9c05dd87ada4279cde48601a 100644 --- a/inst/scipts/02_pe_coords_hbb.R +++ b/inst/scipts/02_pe_coords_hbb.R @@ -1,104 +1,104 @@ -#------------------------------------------------------------------------ -# Protein coordinates -> Genomic coordinates -# HBB: E6V : GGC>GTC : chr20:4699600 -#------------------------------------------------------------------------ - -# Load - require(magrittr) - require(multicrispr) - filter <- ensembldb::filter - UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter - UniprotDbFilter <- ensembldb::UniprotDbFilter - - bs <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 - ensdb <- multicrispr::EnsDb.Hsapiens.v98() - ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) - ensdb %<>% filter(UniprotDbFilter( 'SWISSPROT', condition = "==")) - -# Map identifiers: HBB -> ENST00000335295 - ensembldb::columns(ensdb) - mycolumns <- c( - 'UNIPROTID', 'PROTEINID', 'TXID', - 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', - 'GENESEQSTART', 'GENESEQEND', - 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', - 'PROTEINSEQUENCE') - hbb <- ensembldb::select(ensdb, 'HBB', mycolumns, 'SYMBOL') - # Two transcript isoforms: ENST00000335295 & ENST00000647020 - # Translate into single proteform, differences are in 3'UTR - # Both are gold labeled in ensembl browser, T*95 has a RefSeq match - # Let's use ENST00000335295, since it has a RefSeq match - # (For genomic mapping it actually doesnt matter) - hbb %<>% extract(.$TXID=='ENST00000335295', ) - -# Map coordinates: E6V -> GAG (codes for E) -> chr11:5227002 - ensp <- 'ENSP00000333994' - substr(hbb$PROTEINSEQUENCE[1], 1, 7) - # It's E7, not E6 - # Reason: initiator Methionine is cleaved off! - # Mature protein doesn't contain it. - # However, Uniprot Sequence does contain it! - gr <- ensembldb::proteinToGenome( - IRanges::IRanges(start=7, end=7) %>% set_names(ensp), - ensdb) %>% - extract2(ensp) %>% - (function(y){seqlevelsStyle(y) <- 'UCSC'; y}) - BSgenome::getSeq( - bs, seqnames(gr), start = start(gr), end = end(gr), strand = '-') - gr - -# Explore environment around this locus -bsgenome <- BSgenome.Hsapiens.UCSC.hg38.masked::BSgenome.Hsapiens.UCSC.hg38.masked -bsinfo <- seqinfo(bsgenome) -(fwd <- BSgenome::getSeq(bsgenome, names = 'chr11', start = 5227002-50, end = 5227002+50, strand = '+')) -(rev <- Biostrings::complement(fwd)) - -# Anzalone et al. (2019): two prime editing sites allowed fixing -# Retrieve sequences (pegspacer, pegext, and nickspacer) to reconstruct precision engineering topology - # excl needs to be a regex - https://support.bioconductor.org/p/126593/#126606 - excl <- seqnames(bsgenome) %>% setdiff('chr11') %>% paste0('^', ., '$') - - # 3.5 - (pegspacer3.5 <- BSgenome::vmatchPattern('GTAACGGCAGACTTCTCCAC', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) - (pegext3.5 <- BSgenome::vmatchPattern('ACCTGACTCCTGAGGAGAAGTCTGCC', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) - (nickspacer3.5 <- BSgenome::vmatchPattern('GGGCTGGGCATAAAAGTCA', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) - - # 3.7 - (pegspacer3.7 <- BSgenome::vmatchPattern('GCATGGTGCACCTGACTCCTG', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) - (pegext3.7 <- BSgenome::vmatchPattern('AGACTTCTCCTCAGGAGTCAGGTGCAC', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) - (nickspacer3.7 <- BSgenome::vmatchPattern('GCCTTGATACCAACCTGCCCA', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) - -# Reconstruct prime editing topology -# Note: GG is on the non-targeted strand -# H840A nickase used, which cleaves non-target strand. -# primer f RT -# bindingsite i template -# x C -# 3' CCGTCTGAAGAGGaGTCCTCAGTCTA 5'<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< -# :::::::::::: ^ 3' nicking spacer 5' -# GGCAGACTTCTC ^ ACTGAAAATACGGGTCGGGAC -# GTAAC CaC ^ -# 3.5 5' CTTCATCCACGTTCACCTTGCCCCACAGGGCA AGGAGTCAGATGCACCATGGTGTCTGTTTGAGGTTGCTAGTGAACACAG... ^ ...GCCCTGACTTTTATGCCCAGCCCTG 3' -# 3' GAAGTAGGTGCAAGTGGAACGGGGTGTCCCGT TCCTCAGTCTACGTGGTACCACAGACAAACTCCAACGATCACTTGTGTC... ^ ...CGGGACTGAAAATACGGGTCGGGAC 5' -# CATTGCCGTCTGAAGAGGtG ^ -# :::::::::::::::::::: ^ 5227089 5227111 -# 5' GTAACGGCAGACTTCTCCaC >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> -# -# pegRNAspacer -# -# -# pegRNAspacer -# pegRNA C G -# 3.7 V<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< 3' GTCCTCAGTCTACGTGGTACC 5' -# V -# V CAGGAGTCAGATGCACCATGG -# 5' ACCTTGATACCAACCTGCCCACCCG... V ..CTTCATCCACGTTCACCTTGCCCCACAGGGCAGTAACGGCAGACTTCTCCa TGTCTGTTTGAGGTTGCTAGTGAACACAG 3' -# 3' TGGAACTATGGTTGGACGGGTGGGC... V ..GAAGTAGGTGCAAGTGGAACGGGGTGTCCCGTCATTGCCGTCTGAAGAGGt ACAGACAAACTCCAACGATCACTTGTGTC 5' -# V GTC GTACC -# 5' ACCTTGATACCAACCTGCCCACCCG 3' V CTCAGTCTACGTG -# G V -# nickingspacer >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 5' AGACTTCTCCaCAGGAGTCAGGTGCAC 3' -# f -# RT i primer -# template x bindingsite -# +#------------------------------------------------------------------------ +# Protein coordinates -> Genomic coordinates +# HBB: E6V : GGC>GTC : chr20:4699600 +#------------------------------------------------------------------------ + +# Load + require(magrittr) + require(multicrispr) + filter <- ensembldb::filter + UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter + UniprotDbFilter <- ensembldb::UniprotDbFilter + + bs <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 + ensdb <- multicrispr::EnsDb.Hsapiens.v98() + ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) + ensdb %<>% filter(UniprotDbFilter( 'SWISSPROT', condition = "==")) + +# Map identifiers: HBB -> ENST00000335295 + ensembldb::columns(ensdb) + mycolumns <- c( + 'UNIPROTID', 'PROTEINID', 'TXID', + 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', + 'GENESEQSTART', 'GENESEQEND', + 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', + 'PROTEINSEQUENCE') + hbb <- ensembldb::select(ensdb, 'HBB', mycolumns, 'SYMBOL') + # Two transcript isoforms: ENST00000335295 & ENST00000647020 + # Translate into single proteform, differences are in 3'UTR + # Both are gold labeled in ensembl browser, T*95 has a RefSeq match + # Let's use ENST00000335295, since it has a RefSeq match + # (For genomic mapping it actually doesnt matter) + hbb %<>% extract(.$TXID=='ENST00000335295', ) + +# Map coordinates: E6V -> GAG (codes for E) -> chr11:5227002 + ensp <- 'ENSP00000333994' + substr(hbb$PROTEINSEQUENCE[1], 1, 7) + # It's E7, not E6 + # Reason: initiator Methionine is cleaved off! + # Mature protein doesn't contain it. + # However, Uniprot Sequence does contain it! + gr <- ensembldb::proteinToGenome( + IRanges::IRanges(start=7, end=7) %>% set_names(ensp), + ensdb) %>% + extract2(ensp) %>% + (function(y){seqlevelsStyle(y) <- 'UCSC'; y}) + BSgenome::getSeq( + bs, seqnames(gr), start = start(gr), end = end(gr), strand = '-') + gr + +# Explore environment around this locus +bsgenome <- BSgenome.Hsapiens.UCSC.hg38.masked::BSgenome.Hsapiens.UCSC.hg38.masked +bsinfo <- seqinfo(bsgenome) +(fwd <- BSgenome::getSeq(bsgenome, names = 'chr11', start = 5227002-50, end = 5227002+50, strand = '+')) +(rev <- Biostrings::complement(fwd)) + +# Anzalone et al. (2019): two prime editing sites allowed fixing +# Retrieve sequences (pegspacer, pegext, and nickspacer) to reconstruct precision engineering topology + # excl needs to be a regex - https://support.bioconductor.org/p/126593/#126606 + excl <- seqnames(bsgenome) %>% setdiff('chr11') %>% paste0('^', ., '$') + + # 3.5 + (pegspacer3.5 <- BSgenome::vmatchPattern('GTAACGGCAGACTTCTCCAC', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) + (pegext3.5 <- BSgenome::vmatchPattern('ACCTGACTCCTGAGGAGAAGTCTGCC', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) + (nickspacer3.5 <- BSgenome::vmatchPattern('GGGCTGGGCATAAAAGTCA', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) + + # 3.7 + (pegspacer3.7 <- BSgenome::vmatchPattern('GCATGGTGCACCTGACTCCTG', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) + (pegext3.7 <- BSgenome::vmatchPattern('AGACTTCTCCTCAGGAGTCAGGTGCAC', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) + (nickspacer3.7 <- BSgenome::vmatchPattern('GCCTTGATACCAACCTGCCCA', bsgenome, min.mismatch = 0, max.mismatch = 2, exclude = excl)) + +# Reconstruct prime editing topology +# Note: GG is on the non-targeted strand +# H840A nickase used, which cleaves non-target strand. +# primer f RT +# bindingsite i template +# x C +# 3' CCGTCTGAAGAGGaGTCCTCAGTCTA 5'<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< +# :::::::::::: ^ 3' nicking spacer 5' +# GGCAGACTTCTC ^ ACTGAAAATACGGGTCGGGAC +# GTAAC CaC ^ +# 3.5 5' CTTCATCCACGTTCACCTTGCCCCACAGGGCA AGGAGTCAGATGCACCATGGTGTCTGTTTGAGGTTGCTAGTGAACACAG... ^ ...GCCCTGACTTTTATGCCCAGCCCTG 3' +# 3' GAAGTAGGTGCAAGTGGAACGGGGTGTCCCGT TCCTCAGTCTACGTGGTACCACAGACAAACTCCAACGATCACTTGTGTC... ^ ...CGGGACTGAAAATACGGGTCGGGAC 5' +# CATTGCCGTCTGAAGAGGtG ^ +# :::::::::::::::::::: ^ 5227089 5227111 +# 5' GTAACGGCAGACTTCTCCaC >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> +# +# pegRNAspacer +# +# +# pegRNAspacer +# pegRNA C G +# 3.7 V<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< 3' GTCCTCAGTCTACGTGGTACC 5' +# V +# V CAGGAGTCAGATGCACCATGG +# 5' ACCTTGATACCAACCTGCCCACCCG... V ..CTTCATCCACGTTCACCTTGCCCCACAGGGCAGTAACGGCAGACTTCTCCa TGTCTGTTTGAGGTTGCTAGTGAACACAG 3' +# 3' TGGAACTATGGTTGGACGGGTGGGC... V ..GAAGTAGGTGCAAGTGGAACGGGGTGTCCCGTCATTGCCGTCTGAAGAGGt ACAGACAAACTCCAACGATCACTTGTGTC 5' +# V GTC GTACC +# 5' ACCTTGATACCAACCTGCCCACCCG 3' V CTCAGTCTACGTG +# G V +# nickingspacer >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 5' AGACTTCTCCaCAGGAGTCAGGTGCAC 3' +# f +# RT i primer +# template x bindingsite +# diff --git a/inst/scipts/02_pe_coords_hexa.R b/inst/scipts/02_pe_coords_hexa.R index 41a35b61eb94d528193bebb31ee2d6233c24ce26..3da091b2313f4d429a78af3362542a1eeac9a7b2 100644 --- a/inst/scipts/02_pe_coords_hexa.R +++ b/inst/scipts/02_pe_coords_hexa.R @@ -1,31 +1,31 @@ -#------------------------------------------------------------------------ -# Protein coordinates -> Genomic coordinates -# HEXA: -#------------------------------------------------------------------------ - -# Load functions - require(magrittr) - require(multicrispr) - filter <- ensembldb::filter - UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter - UniprotDbFilter <- ensembldb::UniprotDbFilter - - -# Map identifiers: PRNP -> ENST00000379440 - ensdb <- multicrispr::EnsDb.Hsapiens.v98() - ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) - ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) - ensembldb::columns(ensdb) - mycolumns <- c( - 'UNIPROTID', 'PROTEINID', 'TXID', - 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', - 'GENESEQSTART', 'GENESEQEND', - 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', - 'PROTEINSEQUENCE') - hexa <- ensembldb::select(ensdb, 'HEXA', mycolumns, 'SYMBOL') - # single ENST / ENSP - -# Google helped to locate Tay Sachs locus - gr <- GenomicRanges::GRanges('chr15:72346580-72346583', strand = '-', - seqinfo = seqinfo(bsgenome)) - BSgenome::getSeq(bsgenome, gr) +#------------------------------------------------------------------------ +# Protein coordinates -> Genomic coordinates +# HEXA: +#------------------------------------------------------------------------ + +# Load functions + require(magrittr) + require(multicrispr) + filter <- ensembldb::filter + UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter + UniprotDbFilter <- ensembldb::UniprotDbFilter + + +# Map identifiers: PRNP -> ENST00000379440 + ensdb <- multicrispr::EnsDb.Hsapiens.v98() + ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) + ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) + ensembldb::columns(ensdb) + mycolumns <- c( + 'UNIPROTID', 'PROTEINID', 'TXID', + 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', + 'GENESEQSTART', 'GENESEQEND', + 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', + 'PROTEINSEQUENCE') + hexa <- ensembldb::select(ensdb, 'HEXA', mycolumns, 'SYMBOL') + # single ENST / ENSP + +# Google helped to locate Tay Sachs locus + gr <- GenomicRanges::GRanges('chr15:72346580-72346583', strand = '-', + seqinfo = seqinfo(bsgenome)) + BSgenome::getSeq(bsgenome, gr) diff --git a/inst/scipts/02_pe_coords_prnp.R b/inst/scipts/02_pe_coords_prnp.R index 021c47af8ee4ef691d14a8279ada946d0d14168d..96ddf589a6703e5ef67d05d3c935fcb81642e682 100644 --- a/inst/scipts/02_pe_coords_prnp.R +++ b/inst/scipts/02_pe_coords_prnp.R @@ -1,62 +1,62 @@ -#------------------------------------------------------------------------ -# Protein coordinates -> Genomic coordinates -# PRNP: G127V : GGC>GTC : chr20:4699600 -#------------------------------------------------------------------------ - -# Load functions - require(magrittr) - require(multicrispr) - filter <- ensembldb::filter - UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter - UniprotDbFilter <- ensembldb::UniprotDbFilter - - EnsDb.Mmusculus <- function(){ - hub <- AnnotationHub::AnnotationHub() - #hub <- hub[hub$species == 'Mus musculus' & hub$rdataclass == 'EnsDb'] - #sort(hub$title) - #AnnotationHub::query(hub, '98') # 'AH75036' - hub[["AH75036"]] - } - - EnsDb.Hsapiens <- function(){ - hub <- AnnotationHub::AnnotationHub() - #hub <- hub[hub$species == 'Homo sapiens' & hub$rdataclass == 'EnsDb'] - #sort(hub$title) - #AnnotationHub::query(hub, '98') # 'AH75011' - #AnnotationHub::query(hub, '99') # 'AH78783' - hub[["AH78783"]] - } - - -# Map identifiers: PRNP -> ENST00000379440 - ensdb <- EnsDb.Hsapiens() - ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) - ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) - ensembldb::columns(ensdb) - mycolumns <- c( - 'UNIPROTID', 'PROTEINID', 'TXID', - 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', - 'GENESEQSTART', 'GENESEQEND', - 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', - 'PROTEINSEQUENCE') - prnp <- ensembldb::select(ensdb, 'PRNP', mycolumns, 'SYMBOL') - prnp$PROTEINSEQUENCE[[1]] == prnp$PROTEINSEQUENCE[[2]] # identical! - # Conclusion: ENST00000379440 & ENST00000430350 - # - differ in length of 3' UTR and 5'UTR - # - have identical codingtranscript and protein - # - # For protein coordinate -> genome coordinate mapping - # - both are equivalent - # - let's choose ENST00000379440, since it is gold colored in Ensembl - # genome browser (manual curation and automated annotation match) - - -# Map coordinates: G127V : GGC>GTC : chr20:4699600 - ensp <- 'ENSP00000368752' - gr <- ensembldb::proteinToGenome( - IRanges::IRanges(start=127, end=127) %>% set_names(ensp), - ensdb) %>% - extract2(ensp) %>% - (function(y){seqlevelsStyle(y) <- 'UCSC'; y}) - bs <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 - BSgenome::getSeq(bs, names = seqnames(gr), start = start(gr), end = end(gr)) +#------------------------------------------------------------------------ +# Protein coordinates -> Genomic coordinates +# PRNP: G127V : GGC>GTC : chr20:4699600 +#------------------------------------------------------------------------ + +# Load functions + require(magrittr) + require(multicrispr) + filter <- ensembldb::filter + UniprotMappingTypeFilter <- ensembldb::UniprotMappingTypeFilter + UniprotDbFilter <- ensembldb::UniprotDbFilter + + EnsDb.Mmusculus <- function(){ + hub <- AnnotationHub::AnnotationHub() + #hub <- hub[hub$species == 'Mus musculus' & hub$rdataclass == 'EnsDb'] + #sort(hub$title) + #AnnotationHub::query(hub, '98') # 'AH75036' + hub[["AH75036"]] + } + + EnsDb.Hsapiens <- function(){ + hub <- AnnotationHub::AnnotationHub() + #hub <- hub[hub$species == 'Homo sapiens' & hub$rdataclass == 'EnsDb'] + #sort(hub$title) + #AnnotationHub::query(hub, '98') # 'AH75011' + #AnnotationHub::query(hub, '99') # 'AH78783' + hub[["AH78783"]] + } + + +# Map identifiers: PRNP -> ENST00000379440 + ensdb <- EnsDb.Hsapiens() + ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) + ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) + ensembldb::columns(ensdb) + mycolumns <- c( + 'UNIPROTID', 'PROTEINID', 'TXID', + 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', + 'GENESEQSTART', 'GENESEQEND', + 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', + 'PROTEINSEQUENCE') + prnp <- ensembldb::select(ensdb, 'PRNP', mycolumns, 'SYMBOL') + prnp$PROTEINSEQUENCE[[1]] == prnp$PROTEINSEQUENCE[[2]] # identical! + # Conclusion: ENST00000379440 & ENST00000430350 + # - differ in length of 3' UTR and 5'UTR + # - have identical codingtranscript and protein + # + # For protein coordinate -> genome coordinate mapping + # - both are equivalent + # - let's choose ENST00000379440, since it is gold colored in Ensembl + # genome browser (manual curation and automated annotation match) + + +# Map coordinates: G127V : GGC>GTC : chr20:4699600 + ensp <- 'ENSP00000368752' + gr <- ensembldb::proteinToGenome( + IRanges::IRanges(start=127, end=127) %>% set_names(ensp), + ensdb) %>% + extract2(ensp) %>% + (function(y){seqlevelsStyle(y) <- 'UCSC'; y}) + bs <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 + BSgenome::getSeq(bs, names = seqnames(gr), start = start(gr), end = end(gr)) diff --git a/inst/scipts/03_save_srf_genes.R b/inst/scipts/03_save_srf_genes.R index 1d1b006c89ec00a22ec05a5a9c6eb80cb7920b6a..a6aa9c89ba4956ae0552dc4a987dce646bd5c083 100644 --- a/inst/scipts/03_save_srf_genes.R +++ b/inst/scipts/03_save_srf_genes.R @@ -1,35 +1,35 @@ -# Read - library(magrittr) - library(multicrispr) - bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') - gr <- bed_to_granges(bedfile, 'mm10') - -# Functions - write <- function(x, file){ - write.table(x, file, quote = FALSE, row.names = FALSE, col.names = FALSE) - } - -# Entrez - dbname <- 'TxDb.Mmusculus.UCSC.mm10.knownGene' - db <- utils::getFromNamespace(dbname, dbname) - entrez <- annotate_granges(gr, db) %>% - magrittr::extract(!is.na(.$gene_id)) %>% - data.table::as.data.table() %>% - magrittr::extract(, - list(seqnames, start, end, strand, entrez=gene_id)) - -# Ensembl - db <- AnnotationHub::AnnotationHub()[["AH75036"]] #EnsDb.Mmusculus.v98 - ensembl <- annotate_granges(gr, db) %>% - magrittr::extract(!is.na(.$gene_id)) %>% - data.table::as.data.table() %>% - magrittr::extract(, - list(seqnames, start, end, strand, ensembl=gene_id)) - -# Intersect - both <- merge(entrez, ensembl, by = c('seqnames', 'start', 'end', 'strand')) - set.seed(3) - idx <- sample(seq_len(nrow(both)), 10) - both$entrez[ idx] %>% write('inst/extdata/SRF.entrez') - both$ensembl[idx] %>% write('inst/extdata/SRF.ensembl') - +# Read + library(magrittr) + library(multicrispr) + bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') + gr <- bed_to_granges(bedfile, 'mm10') + +# Functions + write <- function(x, file){ + write.table(x, file, quote = FALSE, row.names = FALSE, col.names = FALSE) + } + +# Entrez + dbname <- 'TxDb.Mmusculus.UCSC.mm10.knownGene' + db <- utils::getFromNamespace(dbname, dbname) + entrez <- annotate_granges(gr, db) %>% + magrittr::extract(!is.na(.$gene_id)) %>% + data.table::as.data.table() %>% + magrittr::extract(, + list(seqnames, start, end, strand, entrez=gene_id)) + +# Ensembl + db <- AnnotationHub::AnnotationHub()[["AH75036"]] #EnsDb.Mmusculus.v98 + ensembl <- annotate_granges(gr, db) %>% + magrittr::extract(!is.na(.$gene_id)) %>% + data.table::as.data.table() %>% + magrittr::extract(, + list(seqnames, start, end, strand, ensembl=gene_id)) + +# Intersect + both <- merge(entrez, ensembl, by = c('seqnames', 'start', 'end', 'strand')) + set.seed(3) + idx <- sample(seq_len(nrow(both)), 10) + both$entrez[ idx] %>% write('inst/extdata/SRF.entrez') + both$ensembl[idx] %>% write('inst/extdata/SRF.ensembl') + diff --git a/inst/scipts/04_use_cases.R b/inst/scipts/04_use_cases.R index 814344a35c8fcd779085840063a9115d959d87ee..1cfa6d0d1b7f2b5a0f24f42da4508219dab1babc 100644 --- a/inst/scipts/04_use_cases.R +++ b/inst/scipts/04_use_cases.R @@ -1,272 +1,272 @@ -require(magrittr) -require(multicrispr) - -#============= -# TFBS -#============= - -# Decide which to keep -reticulate::use_condaenv('azienv') -bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -targets <- multicrispr::bed_to_granges(bedfile, genome='mm10', plot = FALSE) -#png('graphs/srf_karyogram.png') -#multicrispr::plot_karyogram(targets, title = NULL) -#dev.off() - -extended <- extend(targets, -22, +22) - -# targets['T0151'] %>% plot_intervals() -# targets['T0151'] %>% extend() %>% plot_intervals() -# targets['T0151'] %>% up_flank() %>% plot_intervals() -# targets['T0151'] %>% down_flank() %>% plot_intervals() - -spacers <- extended %>% find_spacers(bsgenome) -spacers %<>% add_offtargets(bsgenome, extended) -spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') - -spacers %>% subset(seqnames == 'chr1') %>% - subset(specific == TRUE) %>% - gr2dt() %>% - extract(,.SD[.N>2] ,by = 'targetname') %>% - dt2gr(seqinfo(spacers)) - -spacers2 <- spacers -spacers2 %<>% subset(specific==TRUE) -spacers2$score <- spacers2$name <- spacers2$crisprcontext <- spacers2$specific <- NULL -spacers2 - -targets %<>% subset(targetname %in% c('T0050')) # T0151 -extended%<>% subset(targetname %in% c('T0050')) -spacers %<>% subset(targetname %in% c('T0050')) -spacers %>% extract(c(length(.), 1)) - -# Create plots: original -p <- plot_intervals(targets, color_var = 'targetname') + - ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + - ggplot2::guides(color = FALSE, linetype = FALSE) -ggplot2::ggsave('graphs/srf01.pdf', p, width =2.2, height = 1.5, device = grDevices::cairo_pdf) -#ggplot2::ggsave('graphs/srf01.png', p, width = 2.2, height = 1.5) - - -p <- plot_intervals(extended) + - ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + - ggplot2::guides(color = FALSE, linetype = FALSE) -ggplot2::ggsave('graphs/srf02_extended.pdf', p, width =2.2, height = 1.5, device = grDevices::cairo_pdf) -#ggplot2::ggsave('graphs/srf02_extended.png', p, width = 2.2, height = 1.5) - -p <- plot_intervals(spacers) + - ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + - ggplot2::guides(color = FALSE) -ggplot2::ggsave('graphs/srf03_spacers.pdf', p, width =2.2, height = 1.5, device = grDevices::cairo_pdf) -#ggplot2::ggsave('graphs/srf03_spacers.png', p, width = 2.2, height = 1.5) - -p <- plot_intervals(spacers, alpha_var = 'specific') + - ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + - ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.20)) + - ggplot2::guides(color = FALSE, alpha = FALSE) -ggplot2::ggsave('graphs/srf04_specific.pdf', p, width = 2.2, height = 1.5, device = grDevices::cairo_pdf) -#ggplot2::ggsave('graphs/srf04_specific.png', p, width = 2.2, height = 1.5) - -quantiles <- round(quantile(spacers2$Doench2016, c(.33, .66, 1)), 2) -spacers$efficiency <- spacers$Doench2016 %>% cut(c(0, quantiles), labels = as.character(quantiles)) -p <- plot_intervals(spacers, size_var = 'efficiency', alpha_var = 'specific') + - ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + - ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + - ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.25)) + - ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) -ggplot2::ggsave('graphs/srf05_efficient.pdf', p, width = 2.2, height = 1.5, device = grDevices::cairo_pdf) -#ggplot2::ggsave('graphs/srf05_efficient.png', p, width = 2.2, height = 1.5) - -# PE -#===== -bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -# gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -# HBB = 'chr11:5227002:-', # snp -# HEXA = 'chr15:72346580-72346583:-', # del -# CFTR = 'chr7:117559593-117559595:+'), # ins -# bsgenome) -gr <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) -plot_intervals(gr, facet_var = c('seqnames', 'targetname')) - -spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) %>% add_genome_counts() -spacers$specific <- spacers$G0==1 -spacers %<>% add_efficiency(bsgenome, 'Doench2016') - # Select HBB - -gr %<>% extract('HBB') -p <- plot_intervals(gr, facet_var = c('seqnames', 'targetname')) + - ggplot2::guides(color = FALSE) -ggplot2::ggsave('graphs/hbb01.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - -extended <- extend_for_pe(gr, nrt = 48) -p <- plot_intervals(extended, facet_var = c('seqnames', 'targetname')) + - ggplot2::guides(color = FALSE) -ggplot2::ggsave('graphs/hbb02_extended.pdf', p, width=2.1, height=1.8, device = grDevices::cairo_pdf) - -spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) -p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname')) + - ggplot2::guides(color = FALSE, size = FALSE) -ggplot2::ggsave('graphs/hbb03_spacers.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - -spacers %<>% add_genome_counts() -spacers$specific <- spacers$G0==1 -p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), - alpha_var = 'specific') + - ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + - ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) -ggplot2::ggsave('graphs/hbb04_specific.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - -spacers %<>% add_efficiency(bsgenome, 'Doench2016') -quantiles <- round(quantile(spacers$Doench2016, c(0.33, 0.66, 1)), 2) -spacers$efficiency <- cut(spacers$Doench2016, c(0, quantiles), labels = quantiles) %>% - as.character() -p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), - alpha_var = 'specific', size_var = 'efficiency') + - ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + - ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + - ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) -ggplot2::ggsave('graphs/hbb05_efficient.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - - -gr %<>% extract('HBB') -plot_intervals(gr, facet_var = c('targetname', 'seqnames'), color_var = NULL) + - #ggplot2::guides(color=FALSE) + - ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + - ggplot2::scale_x_continuous(name = NULL, breaks = c(0, 1)) + - ggplot2::theme(panel.grid.major = ggplot2::element_blank(), - panel.grid.minor = ggplot2::element_blank()) - - -# Extend -find_spacers(extend_for_pe(gr, bsgenome), bsgenome, complement = FALSE) - -grplot <- c(gr, grext) -grplot$set <- c('target', '+', '-') -plot_intervals(grplot, facet_var = c('targetname', 'seqnames'), yby = 'set', color_var = NULL, linetype = 'set') + - ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + - #ggplot2::guides(color=FALSE) + - ggplot2::scale_linetype_manual(values = c(target = 'solid', `+` = 'longdash', `-` = 'longdash')) + - #ggplot2::scale_color_manual(values = c(target = '#F8766D', `+` = 'black' , `-` = 'black')) + - ggplot2::guides(linetype=FALSE) + - ggplot2::theme(panel.grid.major = ggplot2::element_blank(), - panel.grid.minor = ggplot2::element_blank()) -grDevices::hcl(h = seq(15, 375, length = n + 1), l = 65, c = 100)[1:3] - - #ggplot2::theme( legend.position = c(0.25,0.73), - # legend.title = ggplot2::element_blank(), - # legend.key = ggplot2::element_blank(), - # legend.background = ggplot2::element_blank()) - -# Find pe sites -spacers <- find_pe_spacers(gr, bsgenome, nrt = 26) - -# Filter for specificity -genomedir <- '~/.multicrispr/bowtie/genome/BSgenome.Hsapiens.UCSC.hg38' -outdir <- '~/.multicrispr/bowtie' -filter_prime_specific(spacers, genomedir, outdir) - - - -# quantiles <- round(quantile(spacers$Doench2016, c(.33, .66, 1)), 2) -# spacers$efficiency <- spacers$Doench2016 %>% cut(c(0, quantiles), labels = as.character(quantiles)) -# p <- plot_intervals(spacers, size_var = 'efficiency') + -# ggplot2::scale_size_manual(values = c(0.2, 1.5, 4) %>% set_names(quantiles)) + -# ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) -# ggplot2::ggsave('graphs/srf_efficient.png', p, width = 3, height = 2.5) - -p <- plot_intervals(spacers, size_var = 'efficiency', alpha_var = 'specific') + - ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + - ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.25)) + - ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) -ggplot2::ggsave('graphs/srf_efficient.png', p, width = 2.5, height = 2) - - -# Process -png('graphs/srf_extended.png') -targets %<>% extend(plot = TRUE) -dev.off() - - -targets %>% find_spacers(bsgenome) %>% filter_target_specific(targets, bsgenome) %>% filter_efficient() - -targets %<>% subset(targetname %in% c('T0018', 'T1042')) -plot_intervals(targets, yby = 'targetname') - -# Extend -grext <- extend(gr, plot = TRUE) -gr$set <- 'target' -grext$set <- 'extension' -grplot <- c(gr, grext) -grplot$set %<>% factor(c('target', 'extension')) -plot_intervals(grplot, color_var = 'targetname', linetype = 'set') - -# Find spacers -spacers <- find_spacers(grext, bsgenome) -spacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') - -# Filter for specificity -tdir <- index_targets(grext, bsgenome) -gdir <- '~/.multicrispr/bowtie/genome/BSgenome.Mmusculus.UCSC.mm10' -outdir <- '~/.multicrispr/bowtie' -specificspacers <- filter_target_specific(spacers, tdir, gdir, outdir) -specificspacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') - -# Filter for -specificspacers %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') -specificspacers %>% subset(targetname %in% c('T0018', 'T0151') & Doench2016 > 0.4) - - plot_intervals(specificspacers, yby = 'crisprname') - - - - - -targets <- extend(bed_to_granges(bedfile, genome='mm10', plot = FALSE)) -bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -spacers <- find_spacers(targets, bsgenome) -indexedgenome <- '~/.multicrispr/bowtie/BSgenome.Mmusculus.UCSC.mm10' -specific <- filter_target_specific(spacers, targets, bsgenome, indexedgenome) -specific %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') -efficient <- specific %<>% subset(Doench2016>0.4) - - -targets$set <- 'A' -spacers$set <- 'B' -specific$set <- 'C' -efficient$set <- 'D' - -plotgr <- c(targets, spacers, specific, efficient) - - plotgr %<>% sort(ignore.strand = TRUE) - #plotgr %<>% subset(seqnames == 'chr1') - plotdt <- data.table::as.data.table(plotgr) - plotdt[ , bin := cut(start, 10, labels = FALSE) ] - plotdt[ , y := scales::number(min(start), big.mark = ','), by = 'bin'] - plotdt$y %<>% factor(unique(.)) - - plotdt[strand=='+', x := start] - plotdt[strand=='+', xend := end] - plotdt[strand=='-', x := end] - plotdt[strand=='-', xend := start] - - # plotdt[strand=='+', x := start - min(start), by = 'y' ] - # plotdt[strand=='+', xend := end - min(start), by = 'y' ] - # plotdt[strand=='-', x := end - min(start), by = 'y' ] - # plotdt[strand=='-', xend := start - min(start), by = 'y' ] - - require(ggplot2) - ggplot(plotdt, aes_string(x = 'x', xend = 'xend', y = 'seqnames', yend = 'seqnames', color = 'set')) + - geom_segment(arrow = arrow(length = unit(0.1, "inches"))) + - scale_x_continuous(labels = scales::comma) + - xlab(NULL) + ylab(NULL) + theme_bw() + - scale_color_manual(values=c(A='lavenderblush', B='gray90', C='gray50', D='green4')) - #guides(color = FALSE) - - - - - - - - +require(magrittr) +require(multicrispr) + +#============= +# TFBS +#============= + +# Decide which to keep +reticulate::use_condaenv('azienv') +bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +targets <- multicrispr::bed_to_granges(bedfile, genome='mm10', plot = FALSE) +#png('graphs/srf_karyogram.png') +#multicrispr::plot_karyogram(targets, title = NULL) +#dev.off() + +extended <- extend(targets, -22, +22) + +# targets['T0151'] %>% plot_intervals() +# targets['T0151'] %>% extend() %>% plot_intervals() +# targets['T0151'] %>% up_flank() %>% plot_intervals() +# targets['T0151'] %>% down_flank() %>% plot_intervals() + +spacers <- extended %>% find_spacers(bsgenome) +spacers %<>% add_offtargets(bsgenome, extended) +spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') + +spacers %>% subset(seqnames == 'chr1') %>% + subset(specific == TRUE) %>% + gr2dt() %>% + extract(,.SD[.N>2] ,by = 'targetname') %>% + dt2gr(seqinfo(spacers)) + +spacers2 <- spacers +spacers2 %<>% subset(specific==TRUE) +spacers2$score <- spacers2$name <- spacers2$crisprcontext <- spacers2$specific <- NULL +spacers2 + +targets %<>% subset(targetname %in% c('T0050')) # T0151 +extended%<>% subset(targetname %in% c('T0050')) +spacers %<>% subset(targetname %in% c('T0050')) +spacers %>% extract(c(length(.), 1)) + +# Create plots: original +p <- plot_intervals(targets, color_var = 'targetname') + + ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + + ggplot2::guides(color = FALSE, linetype = FALSE) +ggplot2::ggsave('graphs/srf01.pdf', p, width =2.2, height = 1.5, device = grDevices::cairo_pdf) +#ggplot2::ggsave('graphs/srf01.png', p, width = 2.2, height = 1.5) + + +p <- plot_intervals(extended) + + ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + + ggplot2::guides(color = FALSE, linetype = FALSE) +ggplot2::ggsave('graphs/srf02_extended.pdf', p, width =2.2, height = 1.5, device = grDevices::cairo_pdf) +#ggplot2::ggsave('graphs/srf02_extended.png', p, width = 2.2, height = 1.5) + +p <- plot_intervals(spacers) + + ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + + ggplot2::guides(color = FALSE) +ggplot2::ggsave('graphs/srf03_spacers.pdf', p, width =2.2, height = 1.5, device = grDevices::cairo_pdf) +#ggplot2::ggsave('graphs/srf03_spacers.png', p, width = 2.2, height = 1.5) + +p <- plot_intervals(spacers, alpha_var = 'specific') + + ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + + ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.20)) + + ggplot2::guides(color = FALSE, alpha = FALSE) +ggplot2::ggsave('graphs/srf04_specific.pdf', p, width = 2.2, height = 1.5, device = grDevices::cairo_pdf) +#ggplot2::ggsave('graphs/srf04_specific.png', p, width = 2.2, height = 1.5) + +quantiles <- round(quantile(spacers2$Doench2016, c(.33, .66, 1)), 2) +spacers$efficiency <- spacers$Doench2016 %>% cut(c(0, quantiles), labels = as.character(quantiles)) +p <- plot_intervals(spacers, size_var = 'efficiency', alpha_var = 'specific') + + ggplot2::scale_color_manual(values = c(T0050 = "#00BFC4")) + + ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + + ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.25)) + + ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) +ggplot2::ggsave('graphs/srf05_efficient.pdf', p, width = 2.2, height = 1.5, device = grDevices::cairo_pdf) +#ggplot2::ggsave('graphs/srf05_efficient.png', p, width = 2.2, height = 1.5) + +# PE +#===== +bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +# gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +# HBB = 'chr11:5227002:-', # snp +# HEXA = 'chr15:72346580-72346583:-', # del +# CFTR = 'chr7:117559593-117559595:+'), # ins +# bsgenome) +gr <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) +plot_intervals(gr, facet_var = c('seqnames', 'targetname')) + +spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) %>% add_genome_counts() +spacers$specific <- spacers$G0==1 +spacers %<>% add_efficiency(bsgenome, 'Doench2016') + # Select HBB + +gr %<>% extract('HBB') +p <- plot_intervals(gr, facet_var = c('seqnames', 'targetname')) + + ggplot2::guides(color = FALSE) +ggplot2::ggsave('graphs/hbb01.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + +extended <- extend_for_pe(gr, nrt = 48) +p <- plot_intervals(extended, facet_var = c('seqnames', 'targetname')) + + ggplot2::guides(color = FALSE) +ggplot2::ggsave('graphs/hbb02_extended.pdf', p, width=2.1, height=1.8, device = grDevices::cairo_pdf) + +spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) +p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname')) + + ggplot2::guides(color = FALSE, size = FALSE) +ggplot2::ggsave('graphs/hbb03_spacers.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + +spacers %<>% add_genome_counts() +spacers$specific <- spacers$G0==1 +p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), + alpha_var = 'specific') + + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + + ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) +ggplot2::ggsave('graphs/hbb04_specific.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + +spacers %<>% add_efficiency(bsgenome, 'Doench2016') +quantiles <- round(quantile(spacers$Doench2016, c(0.33, 0.66, 1)), 2) +spacers$efficiency <- cut(spacers$Doench2016, c(0, quantiles), labels = quantiles) %>% + as.character() +p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), + alpha_var = 'specific', size_var = 'efficiency') + + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + + ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + + ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) +ggplot2::ggsave('graphs/hbb05_efficient.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + + +gr %<>% extract('HBB') +plot_intervals(gr, facet_var = c('targetname', 'seqnames'), color_var = NULL) + + #ggplot2::guides(color=FALSE) + + ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + + ggplot2::scale_x_continuous(name = NULL, breaks = c(0, 1)) + + ggplot2::theme(panel.grid.major = ggplot2::element_blank(), + panel.grid.minor = ggplot2::element_blank()) + + +# Extend +find_spacers(extend_for_pe(gr, bsgenome), bsgenome, complement = FALSE) + +grplot <- c(gr, grext) +grplot$set <- c('target', '+', '-') +plot_intervals(grplot, facet_var = c('targetname', 'seqnames'), yby = 'set', color_var = NULL, linetype = 'set') + + ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + + #ggplot2::guides(color=FALSE) + + ggplot2::scale_linetype_manual(values = c(target = 'solid', `+` = 'longdash', `-` = 'longdash')) + + #ggplot2::scale_color_manual(values = c(target = '#F8766D', `+` = 'black' , `-` = 'black')) + + ggplot2::guides(linetype=FALSE) + + ggplot2::theme(panel.grid.major = ggplot2::element_blank(), + panel.grid.minor = ggplot2::element_blank()) +grDevices::hcl(h = seq(15, 375, length = n + 1), l = 65, c = 100)[1:3] + + #ggplot2::theme( legend.position = c(0.25,0.73), + # legend.title = ggplot2::element_blank(), + # legend.key = ggplot2::element_blank(), + # legend.background = ggplot2::element_blank()) + +# Find pe sites +spacers <- find_pe_spacers(gr, bsgenome, nrt = 26) + +# Filter for specificity +genomedir <- '~/.multicrispr/bowtie/genome/BSgenome.Hsapiens.UCSC.hg38' +outdir <- '~/.multicrispr/bowtie' +filter_prime_specific(spacers, genomedir, outdir) + + + +# quantiles <- round(quantile(spacers$Doench2016, c(.33, .66, 1)), 2) +# spacers$efficiency <- spacers$Doench2016 %>% cut(c(0, quantiles), labels = as.character(quantiles)) +# p <- plot_intervals(spacers, size_var = 'efficiency') + +# ggplot2::scale_size_manual(values = c(0.2, 1.5, 4) %>% set_names(quantiles)) + +# ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) +# ggplot2::ggsave('graphs/srf_efficient.png', p, width = 3, height = 2.5) + +p <- plot_intervals(spacers, size_var = 'efficiency', alpha_var = 'specific') + + ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + + ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.25)) + + ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) +ggplot2::ggsave('graphs/srf_efficient.png', p, width = 2.5, height = 2) + + +# Process +png('graphs/srf_extended.png') +targets %<>% extend(plot = TRUE) +dev.off() + + +targets %>% find_spacers(bsgenome) %>% filter_target_specific(targets, bsgenome) %>% filter_efficient() + +targets %<>% subset(targetname %in% c('T0018', 'T1042')) +plot_intervals(targets, yby = 'targetname') + +# Extend +grext <- extend(gr, plot = TRUE) +gr$set <- 'target' +grext$set <- 'extension' +grplot <- c(gr, grext) +grplot$set %<>% factor(c('target', 'extension')) +plot_intervals(grplot, color_var = 'targetname', linetype = 'set') + +# Find spacers +spacers <- find_spacers(grext, bsgenome) +spacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') + +# Filter for specificity +tdir <- index_targets(grext, bsgenome) +gdir <- '~/.multicrispr/bowtie/genome/BSgenome.Mmusculus.UCSC.mm10' +outdir <- '~/.multicrispr/bowtie' +specificspacers <- filter_target_specific(spacers, tdir, gdir, outdir) +specificspacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') + +# Filter for +specificspacers %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') +specificspacers %>% subset(targetname %in% c('T0018', 'T0151') & Doench2016 > 0.4) + + plot_intervals(specificspacers, yby = 'crisprname') + + + + + +targets <- extend(bed_to_granges(bedfile, genome='mm10', plot = FALSE)) +bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +spacers <- find_spacers(targets, bsgenome) +indexedgenome <- '~/.multicrispr/bowtie/BSgenome.Mmusculus.UCSC.mm10' +specific <- filter_target_specific(spacers, targets, bsgenome, indexedgenome) +specific %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') +efficient <- specific %<>% subset(Doench2016>0.4) + + +targets$set <- 'A' +spacers$set <- 'B' +specific$set <- 'C' +efficient$set <- 'D' + +plotgr <- c(targets, spacers, specific, efficient) + + plotgr %<>% sort(ignore.strand = TRUE) + #plotgr %<>% subset(seqnames == 'chr1') + plotdt <- data.table::as.data.table(plotgr) + plotdt[ , bin := cut(start, 10, labels = FALSE) ] + plotdt[ , y := scales::number(min(start), big.mark = ','), by = 'bin'] + plotdt$y %<>% factor(unique(.)) + + plotdt[strand=='+', x := start] + plotdt[strand=='+', xend := end] + plotdt[strand=='-', x := end] + plotdt[strand=='-', xend := start] + + # plotdt[strand=='+', x := start - min(start), by = 'y' ] + # plotdt[strand=='+', xend := end - min(start), by = 'y' ] + # plotdt[strand=='-', x := end - min(start), by = 'y' ] + # plotdt[strand=='-', xend := start - min(start), by = 'y' ] + + require(ggplot2) + ggplot(plotdt, aes_string(x = 'x', xend = 'xend', y = 'seqnames', yend = 'seqnames', color = 'set')) + + geom_segment(arrow = arrow(length = unit(0.1, "inches"))) + + scale_x_continuous(labels = scales::comma) + + xlab(NULL) + ylab(NULL) + theme_bw() + + scale_color_manual(values=c(A='lavenderblush', B='gray90', C='gray50', D='green4')) + #guides(color = FALSE) + + + + + + + + diff --git a/inst/scipts/05_pipeline_for_becnhmarking.R b/inst/scipts/05_pipeline_for_becnhmarking.R index 62386bbfc1c6343f4ff79adbf34aae3db17753bd..7b60317a8f4db91e229b451c3cf30e6b8e868051 100644 --- a/inst/scipts/05_pipeline_for_becnhmarking.R +++ b/inst/scipts/05_pipeline_for_becnhmarking.R @@ -1,53 +1,53 @@ -# General -#======== - # Install azimuth for scoring - #---------------------------- - # require(reticulate) - # conda_create('azienv', c('python=2.7')) - # use_condaenv('azienv') - # py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE) - # reticulate::use_condaenv('azienv') - - # Index genome - #------------- - require(multicrispr) - index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) - index_genome(BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38) - - # Load packages - require(magrittr) - require(multicrispr) - reticulate::use_condaenv('azienv') - -# Parallel Targeting -#=================== - - # Define targets to block TFBS - bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') - targets <- bed_to_granges(bedfile, 'mm10') %>% - extend(-22, +22) - - # Find specific, efficient spacers - bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 - spacers <- find_spacers(targets, bsgenome) - spacers %<>% filter_target_specific(targets, bsgenome) - spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') - spacers - -# Prime Editing -#============== - - # Define target for editing - bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 - targets <- char_to_granges(c( PRNP = 'chr20:4699600:+', # snp - HBB = 'chr11:5227002:-', # snp - HEXA = 'chr15:72346580-72346583:-', # del - CFTR = 'chr7:117559593-117559595:+'), # ins - bsgenome) - - # Find specific, efficient spacers - spacers <- find_pe_spacers(targets, bsgenome) - spacers %<>% filter_prime_specific(bsgenome) - spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') - spacers - +# General +#======== + # Install azimuth for scoring + #---------------------------- + # require(reticulate) + # conda_create('azienv', c('python=2.7')) + # use_condaenv('azienv') + # py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE) + # reticulate::use_condaenv('azienv') + + # Index genome + #------------- + require(multicrispr) + index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) + index_genome(BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38) + + # Load packages + require(magrittr) + require(multicrispr) + reticulate::use_condaenv('azienv') + +# Parallel Targeting +#=================== + + # Define targets to block TFBS + bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') + targets <- bed_to_granges(bedfile, 'mm10') %>% + extend(-22, +22) + + # Find specific, efficient spacers + bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 + spacers <- find_spacers(targets, bsgenome) + spacers %<>% filter_target_specific(targets, bsgenome) + spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') + spacers + +# Prime Editing +#============== + + # Define target for editing + bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 + targets <- char_to_granges(c( PRNP = 'chr20:4699600:+', # snp + HBB = 'chr11:5227002:-', # snp + HEXA = 'chr15:72346580-72346583:-', # del + CFTR = 'chr7:117559593-117559595:+'), # ins + bsgenome) + + # Find specific, efficient spacers + spacers <- find_pe_spacers(targets, bsgenome) + spacers %<>% filter_prime_specific(bsgenome) + spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') + spacers + diff --git a/inst/scipts/06_validate_paralleltargeting.R b/inst/scipts/06_validate_paralleltargeting.R index 309ddd6e357551892d81d73337a18ea47587953c..13b995f788f20c038eb06fbfe7532eed5e1b6061 100644 --- a/inst/scipts/06_validate_paralleltargeting.R +++ b/inst/scipts/06_validate_paralleltargeting.R @@ -1,39 +1,39 @@ -# Shariati paper -# 1. Target oct4 binding site 137-151 nt upstream of Nanog TSS -# 2. Target Utf1 gene - -# Nanog: three isoforms, each with a different TSS -txdb <- TxDb.Mmusculus.UCSC.mm10.knownGene::TxDb.Mmusculus.UCSC.mm10.knownGene -AnnotationDbi::keytypes(txdb) -ensdb <- AnnotationHub::AnnotationHub()[["AH75036"]] #EnsDb.Mmusculus.v98 -ensembldb::keytypes(ensdb) -ensembldb::columns(ensdb) -ensembldb::select(ensdb, 'Nanog', keytype = 'GENENAME', columns = ensembldb::columns(ensdb)) -ensembldb::select(ensdb, 'Nanog', keytype = 'GENENAME', columns = c('SEQNAME', 'SEQSTRAND', 'TXID', 'TXSEQSTART', 'TXCDSSEQSTART', 'TXCDSSEQEND', 'TXSEQEND', 'GENESEQSTART', 'GENESEQEND')) - -# Find spacers in oct4 site upstream of nanog tss -targets <- multicrispr::char_to_granges(c(oct4_nanog='chr6:122707565:+'), bsgenome) %>% - multicrispr::up_flank(-151, -137) -targets$targetstart <- start(targets) -targets$targetend <- end(targets) -targets %<>% multicrispr::extend(-22, +22) -bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -pattern <- 'GGTCACCTTACAGCTTCTTTTGCATTACAATGTCCATGGTGG' -BSgenome::getSeq(bsgenome, targets, as.character=TRUE) %>% -stringi::stri_detect_fixed('GGTCACCTTACAGCTTCTTTTGCATTACAATGTCCATGGTGG') -spacers <- multicrispr::find_spacers(targets, bsgenome) -spacers %<>% multicrispr:::add_genome_counts(bsgenome) -reticulate::use_condaenv('azienv') -spacers %<>% multicrispr::add_efficiency(bsgenome, method = 'Doench2016') - -# Find spacers in oct4 site downstream of Utf1 -ensembldb::select(ensdb, 'Utf1', keytype = 'GENENAME', columns = c('SEQNAME', 'SEQSTRAND', 'TXID', 'TXSEQSTART', 'TXCDSSEQSTART', 'TXCDSSEQEND', 'TXSEQEND', 'GENESEQSTART', 'GENESEQEND')) -targets <- multicrispr::char_to_granges(c(oct4_utf1='chr7:139943789:+'), bsgenome) %>% - multicrispr::down_flank(+1825, +1825) -targets$targetstart <- start(targets) -targets$targetend <- end(targets) -targets %<>% multicrispr::extend(-100, +100) -BSgenome::getSeq(bsgenome, targets) %>% -#Biostrings::reverseComplement() %>% -as.character() %>% -stringi::stri_detect_fixed('GTTGTTATGCTAGTGAAGTGC') +# Shariati paper +# 1. Target oct4 binding site 137-151 nt upstream of Nanog TSS +# 2. Target Utf1 gene + +# Nanog: three isoforms, each with a different TSS +txdb <- TxDb.Mmusculus.UCSC.mm10.knownGene::TxDb.Mmusculus.UCSC.mm10.knownGene +AnnotationDbi::keytypes(txdb) +ensdb <- AnnotationHub::AnnotationHub()[["AH75036"]] #EnsDb.Mmusculus.v98 +ensembldb::keytypes(ensdb) +ensembldb::columns(ensdb) +ensembldb::select(ensdb, 'Nanog', keytype = 'GENENAME', columns = ensembldb::columns(ensdb)) +ensembldb::select(ensdb, 'Nanog', keytype = 'GENENAME', columns = c('SEQNAME', 'SEQSTRAND', 'TXID', 'TXSEQSTART', 'TXCDSSEQSTART', 'TXCDSSEQEND', 'TXSEQEND', 'GENESEQSTART', 'GENESEQEND')) + +# Find spacers in oct4 site upstream of nanog tss +targets <- multicrispr::char_to_granges(c(oct4_nanog='chr6:122707565:+'), bsgenome) %>% + multicrispr::up_flank(-151, -137) +targets$targetstart <- start(targets) +targets$targetend <- end(targets) +targets %<>% multicrispr::extend(-22, +22) +bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +pattern <- 'GGTCACCTTACAGCTTCTTTTGCATTACAATGTCCATGGTGG' +BSgenome::getSeq(bsgenome, targets, as.character=TRUE) %>% +stringi::stri_detect_fixed('GGTCACCTTACAGCTTCTTTTGCATTACAATGTCCATGGTGG') +spacers <- multicrispr::find_spacers(targets, bsgenome) +spacers %<>% multicrispr:::add_genome_counts(bsgenome) +reticulate::use_condaenv('azienv') +spacers %<>% multicrispr::add_efficiency(bsgenome, method = 'Doench2016') + +# Find spacers in oct4 site downstream of Utf1 +ensembldb::select(ensdb, 'Utf1', keytype = 'GENENAME', columns = c('SEQNAME', 'SEQSTRAND', 'TXID', 'TXSEQSTART', 'TXCDSSEQSTART', 'TXCDSSEQEND', 'TXSEQEND', 'GENESEQSTART', 'GENESEQEND')) +targets <- multicrispr::char_to_granges(c(oct4_utf1='chr7:139943789:+'), bsgenome) %>% + multicrispr::down_flank(+1825, +1825) +targets$targetstart <- start(targets) +targets$targetend <- end(targets) +targets %<>% multicrispr::extend(-100, +100) +BSgenome::getSeq(bsgenome, targets) %>% +#Biostrings::reverseComplement() %>% +as.character() %>% +stringi::stri_detect_fixed('GTTGTTATGCTAGTGAAGTGC') diff --git a/inst/scipts/06_validate_pe.R b/inst/scipts/06_validate_pe.R index 6d5485df2b5415d8d4e39000b40a064ee090cf3d..3b9755f706646bcfdfaa4a17599ea96f8c8881a4 100644 --- a/inst/scipts/06_validate_pe.R +++ b/inst/scipts/06_validate_pe.R @@ -1,129 +1,129 @@ -require(magrittr) -require(data.table) -require(multicrispr) - -bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -x <- multicrispr::char_to_granges( - c( PRNP = 'chr20:4699600:+', # snp - HBB = 'chr11:5227002:-', # snp - HEXA = 'chr15:72346579:-'), # ins - bsgenome = bsgenome) -spacers <- multicrispr::find_pe_spacers(x, bsgenome) -spacers['HBB_1'] - # CATGGTGCATCTGACTCCTG # HBB_1 C->T, extra nucleotide - # GCATGGTGCACCTGACTCCTG # Anzalone -spacers['HEXA_3'] - # TACCTGAACCGTATATCCTA # HEXA_3 - # GTACCTGAACCGTATATCCTA # Anzalone -spacers['PRNP_4'] - # GCAGTGGTGGGGGGCCTTGG # PRNP_4 - # GCAGTGGTGGGGGGCCTTGG # Anzalone - -spacers %<>% sort(ignore.strand=TRUE) -spacers$set <- ifelse(names(spacers) %in% c('HBB_1', 'HEXA_3', 'PRNP_4'), 'anzalone', 'multicrispr') - -x <- list(multicrispr = names(subset(spacers, targetname=='HBB')), - anzalone = names(subset(spacers, targetname=='HBB' & set=='anzalone'))) -plot_venn <- function(x, title=''){ - names(x) %<>% paste0(' (', vapply(x, length, integer(1)), ')') - p <- VennDiagram::venn.diagram( - x, - filename = NULL, - fill = c("#00BFC4", "#F8766D", "#00BA38")[seq_along(x)], - col = c("#00BFC4", "#F8766D", "#00BA38")[seq_along(x)], - cat.pos = rep( 0, length(x)), - cat.dist = rep(-0.1, length(x)), - #cat.col = c(multicrispr = "#00BFC4", anzalone = "#F8766D"), - scaled = FALSE, - main = title, - main.pos = c(0.5, 1.06)) - grid::grid.draw(p) - p -} - -do_plot_venn <- function(selectedtarget){ - grid::grobTree( - plot_venn( - list(multicrispr = names(subset(spacers, targetname==selectedtarget)), - Anzalone = names(subset(spacers, targetname==selectedtarget & set=='anzalone'))), - title = selectedtarget)) -} - -p1 <- grid::grobTree(do_plot_venn('HBB')) -p2 <- grid::grobTree(do_plot_venn('HEXA')) -p3 <- grid::grobTree(do_plot_venn('PRNP')) -p_pe_venn <- gridExtra::grid.arrange(p1, p2, p3, layout_matrix = matrix(1:3, nrow=1)) -grid::grid.draw(p_pe_venn) - -spacers$in_anzalone <- spacers$set=='anzalone' -multicrispr::plot_intervals(spacers, facet_var = c('seqnames','targetname'), - size_var = 'in_anzalone') - -spacers %<>% add_efficiency(bsgenome, 'Doench2016') -ggplot2::ggplot(as.data.table(spacers), ggplot2::aes(x=in_anzalone, y = Doench2016, color=set)) + -ggplot2::geom_point() + ggplot2::facet_wrap(~ targetname) + ggplot2::theme_bw() - - -spacers %<>% add_genome_counts(bsgenome) -p_pe_on <- ggplot2::ggplot(as.data.table(spacers), ggplot2::aes(y=as.factor(as.character(G0-1)), x = Doench2016, color=set)) + - ggplot2::geom_point(size = 4, shape = 15, alpha=0.6) + - ggplot2::facet_wrap(~ targetname) + - ggplot2::theme_bw() + - ggplot2::ylab('Offtarget matches') + - ggplot2::guides(color = FALSE) - -spacers$unique <- spacers$G0==1 -reticulate::use_condaenv('azienv') -spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') -p <- multicrispr::plot_intervals( - spacers, facet_var = c('seqnames', 'targetname'), - size_var = 'anzalone') - - -p + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.5)) - -p <- multicrispr::plot_intervals( - spacers, facet_var = c('seqnames', 'targetname'), - alpha_var = 'unique', - size_var = 'anzalone') -p + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.4)) - -# DNMT1 - ensdb <- multicrispr::EnsDb.Hsapiens.v98() - ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) - ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) - ensembldb::columns(ensdb) - mycolumns <- c( - 'UNIPROTID', 'PROTEINID', 'TXID', - 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', - 'GENESEQSTART', 'GENESEQEND', - 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', - 'PROTEINSEQUENCE') - dnmt1 <- ensembldb::select(ensdb, 'DNMT1', mycolumns, 'SYMBOL') - -x <- char_to_granges('chr19:10133346-10195135:-', bsgenome) -x %<>% multicrispr::add_seq(bsgenome) -x$seq %>% Biostrings::DNAString() %>% Biostrings::reverseComplement() %>% stringi::stri_detect_fixed('GCGGGCTGGAGCTGTTCGCGC') - -Biostrings::matchPattern(Biostrings::DNAString('GCGGGCTGGAGCTGTTCGCGC'), bsgenome$chr19, max.mismatch = 2) - - -x %<>% multicrispr::extend(-200, 200) -x %<>% multicrispr::add_seq(bsgenome) -x$seq %>% stringi::stri_locate_all_fixed('GTACCTGAACCGTATATCCTA') -char_to_granges( GenomicRanges::end(x)+1-187, - GenomicRanges::end(x)+1-207, - seqinfo = BSgenome::seqinfo(bsgenome)) -BSgenome::getSeq(bsgenome, 'chr15', 72346577, 72346597, strand='-') - -AnnotationDbi::select(org.Hs.eg.db::org.Hs.eg.db, 'HEXA', keytype = 'SYMBOL', columns = 'ENTREZID') # 3073 -txdb <- TxDb.Hsapiens.UCSC.hg38.knownGene::TxDb.Hsapiens.UCSC.hg38.knownGene -AnnotationDbi::keytypes(txbd) -AnnotationDbi::select(txdb, keys = '3073', keytype = 'GENEID', columns = AnnotationDbi::columns(txdb)) - - -GTACCTGAACCGTATATCCTA -ATCCTTCCAGTCAGGGCCAT - -BSgenome::getSeq(bsgenome, 'chr15', 72346580, 72346583, strand='+') -BSgenome::getSeq(bsgenome, 'chr15', 72346580, 72346583, strand='-') +require(magrittr) +require(data.table) +require(multicrispr) + +bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +x <- multicrispr::char_to_granges( + c( PRNP = 'chr20:4699600:+', # snp + HBB = 'chr11:5227002:-', # snp + HEXA = 'chr15:72346579:-'), # ins + bsgenome = bsgenome) +spacers <- multicrispr::find_pe_spacers(x, bsgenome) +spacers['HBB_1'] + # CATGGTGCATCTGACTCCTG # HBB_1 C->T, extra nucleotide + # GCATGGTGCACCTGACTCCTG # Anzalone +spacers['HEXA_3'] + # TACCTGAACCGTATATCCTA # HEXA_3 + # GTACCTGAACCGTATATCCTA # Anzalone +spacers['PRNP_4'] + # GCAGTGGTGGGGGGCCTTGG # PRNP_4 + # GCAGTGGTGGGGGGCCTTGG # Anzalone + +spacers %<>% sort(ignore.strand=TRUE) +spacers$set <- ifelse(names(spacers) %in% c('HBB_1', 'HEXA_3', 'PRNP_4'), 'anzalone', 'multicrispr') + +x <- list(multicrispr = names(subset(spacers, targetname=='HBB')), + anzalone = names(subset(spacers, targetname=='HBB' & set=='anzalone'))) +plot_venn <- function(x, title=''){ + names(x) %<>% paste0(' (', vapply(x, length, integer(1)), ')') + p <- VennDiagram::venn.diagram( + x, + filename = NULL, + fill = c("#00BFC4", "#F8766D", "#00BA38")[seq_along(x)], + col = c("#00BFC4", "#F8766D", "#00BA38")[seq_along(x)], + cat.pos = rep( 0, length(x)), + cat.dist = rep(-0.1, length(x)), + #cat.col = c(multicrispr = "#00BFC4", anzalone = "#F8766D"), + scaled = FALSE, + main = title, + main.pos = c(0.5, 1.06)) + grid::grid.draw(p) + p +} + +do_plot_venn <- function(selectedtarget){ + grid::grobTree( + plot_venn( + list(multicrispr = names(subset(spacers, targetname==selectedtarget)), + Anzalone = names(subset(spacers, targetname==selectedtarget & set=='anzalone'))), + title = selectedtarget)) +} + +p1 <- grid::grobTree(do_plot_venn('HBB')) +p2 <- grid::grobTree(do_plot_venn('HEXA')) +p3 <- grid::grobTree(do_plot_venn('PRNP')) +p_pe_venn <- gridExtra::grid.arrange(p1, p2, p3, layout_matrix = matrix(1:3, nrow=1)) +grid::grid.draw(p_pe_venn) + +spacers$in_anzalone <- spacers$set=='anzalone' +multicrispr::plot_intervals(spacers, facet_var = c('seqnames','targetname'), + size_var = 'in_anzalone') + +spacers %<>% add_efficiency(bsgenome, 'Doench2016') +ggplot2::ggplot(as.data.table(spacers), ggplot2::aes(x=in_anzalone, y = Doench2016, color=set)) + +ggplot2::geom_point() + ggplot2::facet_wrap(~ targetname) + ggplot2::theme_bw() + + +spacers %<>% add_genome_counts(bsgenome) +p_pe_on <- ggplot2::ggplot(as.data.table(spacers), ggplot2::aes(y=as.factor(as.character(G0-1)), x = Doench2016, color=set)) + + ggplot2::geom_point(size = 4, shape = 15, alpha=0.6) + + ggplot2::facet_wrap(~ targetname) + + ggplot2::theme_bw() + + ggplot2::ylab('Offtarget matches') + + ggplot2::guides(color = FALSE) + +spacers$unique <- spacers$G0==1 +reticulate::use_condaenv('azienv') +spacers %<>% add_efficiency(bsgenome, method = 'Doench2016') +p <- multicrispr::plot_intervals( + spacers, facet_var = c('seqnames', 'targetname'), + size_var = 'anzalone') + + +p + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.5)) + +p <- multicrispr::plot_intervals( + spacers, facet_var = c('seqnames', 'targetname'), + alpha_var = 'unique', + size_var = 'anzalone') +p + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.4)) + +# DNMT1 + ensdb <- multicrispr::EnsDb.Hsapiens.v98() + ensdb %<>% filter(UniprotMappingTypeFilter('DIRECT', condition = "==")) + ensdb %<>% filter(UniprotDbFilter('SWISSPROT', condition = "==")) + ensembldb::columns(ensdb) + mycolumns <- c( + 'UNIPROTID', 'PROTEINID', 'TXID', + 'SEQCOORDSYSTEM', 'SEQNAME', 'SEQSTRAND', + 'GENESEQSTART', 'GENESEQEND', + 'TXSEQSTART', 'TXSEQEND', 'TXCDSSEQSTART', 'TXCDSSEQEND', + 'PROTEINSEQUENCE') + dnmt1 <- ensembldb::select(ensdb, 'DNMT1', mycolumns, 'SYMBOL') + +x <- char_to_granges('chr19:10133346-10195135:-', bsgenome) +x %<>% multicrispr::add_seq(bsgenome) +x$seq %>% Biostrings::DNAString() %>% Biostrings::reverseComplement() %>% stringi::stri_detect_fixed('GCGGGCTGGAGCTGTTCGCGC') + +Biostrings::matchPattern(Biostrings::DNAString('GCGGGCTGGAGCTGTTCGCGC'), bsgenome$chr19, max.mismatch = 2) + + +x %<>% multicrispr::extend(-200, 200) +x %<>% multicrispr::add_seq(bsgenome) +x$seq %>% stringi::stri_locate_all_fixed('GTACCTGAACCGTATATCCTA') +char_to_granges( GenomicRanges::end(x)+1-187, + GenomicRanges::end(x)+1-207, + seqinfo = BSgenome::seqinfo(bsgenome)) +BSgenome::getSeq(bsgenome, 'chr15', 72346577, 72346597, strand='-') + +AnnotationDbi::select(org.Hs.eg.db::org.Hs.eg.db, 'HEXA', keytype = 'SYMBOL', columns = 'ENTREZID') # 3073 +txdb <- TxDb.Hsapiens.UCSC.hg38.knownGene::TxDb.Hsapiens.UCSC.hg38.knownGene +AnnotationDbi::keytypes(txbd) +AnnotationDbi::select(txdb, keys = '3073', keytype = 'GENEID', columns = AnnotationDbi::columns(txdb)) + + +GTACCTGAACCGTATATCCTA +ATCCTTCCAGTCAGGGCCAT + +BSgenome::getSeq(bsgenome, 'chr15', 72346580, 72346583, strand='+') +BSgenome::getSeq(bsgenome, 'chr15', 72346580, 72346583, strand='-') diff --git a/inst/scipts/07_validate_brunello.R b/inst/scipts/07_validate_brunello.R index 9dc9c3456f4287415be100f0b429f8a46c0ef863..20fc4b2052aea1b3858562c06f981dcbc14edbb5 100644 --- a/inst/scipts/07_validate_brunello.R +++ b/inst/scipts/07_validate_brunello.R @@ -1,327 +1,327 @@ -# Load functions -#=============== - require(magrittr) - require(reticulate) - use_condaenv('azienv') - import('azimuth') - # require(AnnotationDbi) - # require(BSgenome) - # require(multicrispr) - # require(magrittr) - # require(biomaRt) - # require(data.table) - # require(stringi) -cmessage<- multicrispr:::cmessage -csign <- multicrispr:::csign - -read_brunello_dt <- function(){ - - # Read file - local_brunello_file = '../multicrisprout/brunello/brunello.txt' - brunello_url <- paste0('https://www.addgene.org/static/cms/filer_public/', - '8b/4c/8b4c89d9-eac1-44b2-bb2f-8fea95672705/', - 'broadgpp-brunello-library-contents.txt') - if (!file.exists(local_brunello_file)){ - download.file(brunello_url, local_brunello_file)} - brunello <- data.table::fread(local_brunello_file) - cmessage('\t%d gRNAs described in Brunello txt file', nrow(brunello)) - - # Rm positive controls - n0 <- nrow(brunello) - brunello %<>% extract(!is.na(`Target Gene ID`)) - ntranscripts <- length(unique(brunello$`Target Transcript`)) - ngenes <- length(unique(brunello$`Target Gene Symbol`)) - n1 <- nrow(brunello) - cmessage(paste0('\t%d gRNAs targeting %d transcripts ', - '(%d genes), after removing positive controls'), - n1, ntranscripts, ngenes) - - # Add refseq mrna values - brunello[, refseq_mrna := `Target Transcript` %>% substr(1, nchar(.)-2) ] - - # Return - brunello -} - -load_ensmart <- function(){ - ensembl_dataset <- 'hsapiens_gene_ensembl' - ensembl_version <- 99 - cmessage('\t\tUse biomaRt: %s version %s', ensembl_dataset, ensembl_version) - ensmart <- biomaRt::useEnsembl( - 'ensembl', dataset=ensembl_dataset, version=ensembl_version) - ensmart -} - -add_brunello_seqnames <- function(brunello, ensmart){ - - chromdt <- suppressMessages( - biomaRt::getBM( attributes = c('refseq_mrna', 'chromosome_name'), - filters = 'refseq_mrna', - values = unique(brunello$refseq_mrna), - mart = ensmart)) %>% - data.table::as.data.table() - canonical_chromosomes <- GenomeInfoDb::standardChromosomes( - BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38) - chromdt %<>% extract(chromosome_name %in% canonical_chromosomes) - chromdt[, .SD[.N>1], by='refseq_mrna'] - chromdt %>% data.table::setnames('chromosome_name', 'seqnames') - - brunello %<>% data.table::merge.data.table(chromdt, by = 'refseq_mrna') - cmessage('\t%d gRNAs targeting %d transcripts, after adding canonical chromosome mappings', - nrow(brunello), brunello[, length(unique(refseq_mrna))]) - brunello -} - -add_brunello_strand <- function(brunello, ensmart){ - - # Get strand mappings - brunello %>% data.table::setnames('Strand', 'sense') - strandt <- suppressMessages( - biomaRt::getBM( attributes = c('refseq_mrna', 'strand'), - filters = 'refseq_mrna', - values = unique(brunello$refseq_mrna), - mart = ensmart)) %>% - data.table::as.data.table() - strandt %<>% extract(, .SD[.N==1], by = 'refseq_mrna') - strandt[, strand := vapply(strand, multicrispr::csign, character(1))] - brunello %<>% data.table::merge.data.table(strandt, by = 'refseq_mrna') - # 76 441 -> 75 463 -> 75 244 - cmessage('\t%d gRNAs targeting %d transcripts, after adding unique strand mappings', - nrow(brunello), brunello[, length(unique(refseq_mrna))]) - brunello[sense=='antisense', strand := ifelse(strand=='+', '-', '+')] - brunello$sense <- NULL - brunello -} - -forge_spacer_ranges <- function(brunello){ - - # Grange - brunello %>% data.table::setnames(c('Position of Base After Cut (1-based)'), c( 'start')) - brunello %>% extract(, end := start) - bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 - brunello <- dt2gr(brunello, BSgenome::seqinfo(bsgenome)[GenomeInfoDb::standardChromosomes(bsgenome)]) - - # Extend - brunello[GenomicRanges::strand(brunello)=='+'] %<>% extend(-17, +2) - brunello[GenomicRanges::strand(brunello)=='-'] %<>% extend(-16, +3) - brunello$crisprspacer <- BSgenome::getSeq(bsgenome, brunello, as.character=TRUE) - brunello %<>% subset(`sgRNA Target Sequence`==crisprspacer) - # Drop 12 non-matches (due to sequence changes). 75 244 -> 75 232 - brunello$`sgRNA Target Sequence` <- NULL - cmessage('\t%d gRNAs targeting %d transcripts, after removing non-matching spacers', - length(brunello), length(unique(brunello$refseq_mrna))) - - # Harmonize/drop names - names(mcols(brunello)) %<>% - stri_replace_first_fixed('Target Context Sequence', 'crisprcontext') %>% - stri_replace_first_fixed('PAM Sequence', 'crisprpam') %>% - stri_replace_first_fixed('Rule Set 2 score', 'Doench2016') - brunello$`Genomic Sequence` <- brunello$`Target Gene ID` <- NULL - brunello$`Exon Number` <- NULL - brunello$crisprname <- uniquify(brunello$refseq_mrna) - names(brunello) <- brunello$crisprname - - # Return - brunello -} - -reconstruct_brunello_spacers <- function(){ - brunello <- read_brunello_dt() - ensmart <- load_ensmart() - brunello %<>% add_brunello_seqnames(ensmart) - brunello %<>% add_brunello_strand(ensmart) - brunello <- forge_spacer_ranges(brunello) - # Are context seqs identical? Yes! - #all(brunello$crisprcontext == (brunello %>% extend(-4,+6) %>% getSeq(bsgenome, ., as.character=TRUE))) - brunello -} - -validate_brunello_spacers <- function(brunello){ - - # Find spacers - message('Find Brunello spacers') - bsgenome <- BSgenome::getBSgenome(genome = genome(brunello)[1]) - spacers <- extend(brunello, 0, +3) %>% - multicrispr::find_spacers(bsgenome, plot = FALSE) - # All brunello spacers are found - # 4 813 additional spacers are found on rev strands - - # Venn - spcoords <- unname(as.character(granges(spacers))) - brcoords <- unname(as.character(granges(brunello))) - autonomics.plot::plot_venn(list(multicrispr=spcoords, brunello=brcoords)) - spacers %<>% extract(spcoords %in% brcoords) # Limit to Brunello spacers - - # Doench score - message('Doench 2016 score') - names(mcols(spacers)) %<>% stringi::stri_replace_first_fixed('Doench2016', 'BrunelloDoench2016') - #brunello_spacers[1:10] %>% add_efficiency(bsgenome, 'Doench2016', plot = FALSE) - spacers %<>% add_efficiency(bsgenome, 'Doench2016', plot = FALSE, chunksize=10000) - plot(spacers$BrunelloDoench2016, spacers$Doench2016) - plot(density(spacers$Doench2016)) - - # Add genome counts - GenomeInfoDb::seqlevelsStyle(spacers) <- 'UCSC' - bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 - spacers %<>% add_genome_counts(bsgenome, mismatches=1) - table(spacers$G0) - spacers$unique <- spacers$G0==1 - autonomics.plot::plot_venn(list( - brunello = spacers$crisprname, - unique = subset(spacers, G0==1)$crisprname)) -} - -find_enclosing_exons <- function(spacers){ - - # Load canonical exons - ensdb <- AnnotationHub::AnnotationHub()[["AH78783"]] - exons <- ensembldb::exons(ensdb) - exons %<>% extract( as.character(seqnames(exons)) %in% - as.character(GenomicRanges::seqnames(spacers))) - - # Find overlaps - exons %<>% gr2dt() %>% dt2gr(seqinfo(exons )[seqlevelsInUse(exons )]) - spacers %<>% gr2dt() %>% dt2gr(seqinfo(spacers)[seqlevelsInUse(spacers)]) - res <- findOverlaps(exons, extend(spacers, 0, +3), ignore.strand = TRUE, minoverlap = 23) - - # Exon spacers - exonspacers <- spacers %>% extract(unique(subjectHits(res))) - cmessage('\t%d exon spacers', length(exonspacers)) - - # Spacer exons - spacerexons <- exons %>% extract(queryHits(res)) - spacerexons$targetname <- names(spacers)[subjectHits(res)] - spacerexons %<>% gr2dt() - spacerexons %<>% extract(, .SD[width == min(width)], by = 'targetname') # 75 229 / - spacerexons %<>% extract(, .SD[1], by = 'targetname') - spacerexons %<>% dt2gr(seqinfo(exons)) - cmessage('\t%d spacer exons', length(spacerexons)) - - # Return - return(spacerexons) - -} - -# Get Brunello exons -#=================== - brunello <- reconstruct_brunello_spacers() - brunello_spacers <- validate_brunello_spacers(brunello) - brunello_exons <- find_enclosing_exons(brunello) - brunello %<>% extract(brunello_exons$targetname) - -# Find exon spacers -#================== - bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 - exonspacers <- find_spacers(brunello_exons, bsgenome, plot = FALSE) # 2 583 378 - saveRDS(exonspacers, '../multicrisprout/brunello/exonspacers0.rds') - saveRDS(exonspacers, 'Z:/abhagwa/multicrisprout/brunello/exonspacers0.rds') - -# Score exon spacers -#=================== - require(reticulate) - use_condaenv('azienv') - import('azimuth') - require(multicrispr) - require(magrittr) - exonspacers <- readRDS('../multicrisprout/brunello/exonspacers0.rds') - bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 - exonspacers %<>% add_efficiency(bsgenome, 'Doench2016', chunksize=50000, plot = FALSE) - saveRDS(exonspacers, '../multicrisprout/brunello/exonspacers1.rds') - -# (Mis)match exon spacers. Execute in two disjunct chunks to save memory. -#======================================================================== - exonspacers <- readRDS('../multicrisprout/brunello/exonspacers1.rds') - exonspacers <- readRDS('Z:/abhagwa/multicrisprout/brunello/exonspacers1.rds') - bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 - GenomeInfoDb::seqlevelsStyle(exonspacers) <- 'UCSC' - outdir = '../multicrisprout/brunello' - exonspacers %<>% extract(order(.$crisprspacer)) - xsp1 <- exonspacers[seq(1,2583378/2)] - xsp2 <- exonspacers[seq(2583378/2+1, 2583378)] - autonomics.plot::plot_venn(list(xsp1=xsp1$crisprspacer, xsp2=xsp2$crisprspacer)) - xsp1 %<>% add_genome_counts(bsgenome, outdir = outdir, mismatches = 1, - indexedgenomesdir = '../multicrisprout/indexedgenomes') - xsp2 %<>% add_genome_counts(bsgenome, outdir = outdir, mismatches = 1, - indexedgenomesdir = '../multicrisprout/indexedgenomes') - exonspacers <- c(xsp1, xsp2) - GenomeInfoDb::seqlevelsStyle(exonspacers) <- 'NCBI' - #saveRDS(exonspacers, '../multicrisprout/brunello/exonspacers2.rds') - #exonspacers <- readRDS('../multicrisprout/brunello/exonspacers.rds') - -# Plot validation results -#======================== - # Venn - exonspacers <- readRDS('Z:/abhagwa/multicrisprout/brunello/exonspacers.rds') - brunellocoords <- unname(as.character(granges(brunello))) - exonspacercoords <- unname(as.character(granges(exonspacers))) - x <- list(multicrispr = exonspacercoords, Brunello = brunellocoords) - p_brunello_venn <- autonomics::plot_venn(x, title = 'Brunello spacer ranges') - x <- list(multicrispr = unique(exonspacers$crisprspacer), Brunello = unique(brunello$crisprspacer)) - p_brunello_venn2 <- autonomics::plot_venn(x, title = 'Brunello spacer seqs') - - # Densities - # multicrispr::plot_intervals(subset(exonspacers, seqnames==1)) - exonspacers$set <- ifelse(exonspacers$in_brunello, 'brunello', 'multicrispr') - p_brunello_on <- - ggplot2::ggplot() + - ggplot2::geom_density( data = data.table::as.data.table(exonspacers), - mapping = ggplot2::aes(x = Doench2016), - fill = "#00BFC4", alpha = 0.5) + - ggplot2::geom_density( data = data.table::as.data.table(subset(exonspacers, in_brunello==TRUE)), - mapping = ggplot2::aes(x = Doench2016), - fill = "#F8766D", alpha = 0.5) + - ggplot2::theme_bw() + - ggplot2::guides(color = FALSE) - - # Genome (mis)matches - color_values <- c(multicrispr = "#00BFC4", brunello = "#F8766D", unique = "#00BA38") - #autonomics.plot::make_gg_colors(c('brunello', 'multicrispr'), show=TRUE) - multioff <- table(exonspacers$G0) - names(multioff) %<>% as.numeric() %>% magrittr::subtract(1) %>% as.character() - total <- sum(multioff) - multioff[1] <- 100 * (sum(multioff[1:length(multioff)])) / total - multioff[2] <- 100 * (sum(multioff[2:length(multioff)])) / total - multioff[3] <- 100 * (sum(multioff[3:length(multioff)])) / total - multioff[4] <- 100 * (sum(multioff[4:length(multioff)])) / total - multioff %<>% extract(1:4) - - broff <- table(subset(exonspacers, in_brunello==TRUE)$G0) - names(broff) %<>% as.numeric() %>% magrittr::subtract(1) %>% as.character() - total <- sum(broff) - broff[1] <- 100 * (sum(broff[1:length(broff)])) / total - broff[2] <- 100 * (sum(broff[2:length(broff)])) / total - broff[3] <- 100 * (sum(broff[3:length(broff)])) / total - broff[4] <- 100 * (sum(broff[4:length(broff)])) / total - broff %<>% extract(1:4) - - dt <- data.table::data.table( - x = c('>=1', '>=2', '>=3', '>=1', '>=2', '>=3'), - y = c(multioff[-1], broff[-1]), - set = c(rep('multicrispr', each=3), rep('brunello', each=3))) - p_brunello_off<-ggplot2::ggplot(dt) + - ggplot2::geom_col(ggplot2::aes(x=x, y=y, fill =set), position = 'dodge') + - ggplot2::xlab('Offtarget matches') + - ggplot2::ylab('Percentage of spacers') + - ggplot2::theme_bw() + - ggplot2::guides(fill=FALSE) - -require(multipanelfigure) - -fig <- multi_panel_figure(columns = 10, rows = 3, width = 500, height = 250, row_spacing = 10, column_spacing = 10, panel_label_type = 'none') -fig <- fill_panel(fig, p_pe_venn, row = 1, column = 1:5 ) -fig <- fill_panel(fig, p_pe_on, row = 2, column = 1:5 ) -fig <- fill_panel(fig, p_parallel_venn, row = 1, column = 6:7 ) -fig <- fill_panel(fig, p_parallel_on, row = 2, column = 6:7 ) -fig <- fill_panel(fig, p_brunello_venn, row = 1, column = 8:10 ) -fig <- fill_panel(fig, p_brunello_on, row = 2, column = 8:10 ) -fig <- fill_panel(fig, p_brunello_off, row = 3, column = 8:10) -fig - -require(Cairo) -file_local <- '../multicrisprout/validation.pdf' -file_agnerds <- 'Z:\\abhagwa\\multicrisprmanuscript\\figures\\validation.pdf' -cairo_pdf(file_local, width = figure_width(fig, unit_to = 'inch'), height = figure_height(fig, unit_to = 'inch')) -#pdf(filename, width = figure_width(fig, unit_to = 'inch'), height = figure_height(fig, unit_to = 'inch')) -print(fig) -dev.off() - +# Load functions +#=============== + require(magrittr) + require(reticulate) + use_condaenv('azienv') + import('azimuth') + # require(AnnotationDbi) + # require(BSgenome) + # require(multicrispr) + # require(magrittr) + # require(biomaRt) + # require(data.table) + # require(stringi) +cmessage<- multicrispr:::cmessage +csign <- multicrispr:::csign + +read_brunello_dt <- function(){ + + # Read file + local_brunello_file = '../multicrisprout/brunello/brunello.txt' + brunello_url <- paste0('https://www.addgene.org/static/cms/filer_public/', + '8b/4c/8b4c89d9-eac1-44b2-bb2f-8fea95672705/', + 'broadgpp-brunello-library-contents.txt') + if (!file.exists(local_brunello_file)){ + download.file(brunello_url, local_brunello_file)} + brunello <- data.table::fread(local_brunello_file) + cmessage('\t%d gRNAs described in Brunello txt file', nrow(brunello)) + + # Rm positive controls + n0 <- nrow(brunello) + brunello %<>% extract(!is.na(`Target Gene ID`)) + ntranscripts <- length(unique(brunello$`Target Transcript`)) + ngenes <- length(unique(brunello$`Target Gene Symbol`)) + n1 <- nrow(brunello) + cmessage(paste0('\t%d gRNAs targeting %d transcripts ', + '(%d genes), after removing positive controls'), + n1, ntranscripts, ngenes) + + # Add refseq mrna values + brunello[, refseq_mrna := `Target Transcript` %>% substr(1, nchar(.)-2) ] + + # Return + brunello +} + +load_ensmart <- function(){ + ensembl_dataset <- 'hsapiens_gene_ensembl' + ensembl_version <- 99 + cmessage('\t\tUse biomaRt: %s version %s', ensembl_dataset, ensembl_version) + ensmart <- biomaRt::useEnsembl( + 'ensembl', dataset=ensembl_dataset, version=ensembl_version) + ensmart +} + +add_brunello_seqnames <- function(brunello, ensmart){ + + chromdt <- suppressMessages( + biomaRt::getBM( attributes = c('refseq_mrna', 'chromosome_name'), + filters = 'refseq_mrna', + values = unique(brunello$refseq_mrna), + mart = ensmart)) %>% + data.table::as.data.table() + canonical_chromosomes <- GenomeInfoDb::standardChromosomes( + BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38) + chromdt %<>% extract(chromosome_name %in% canonical_chromosomes) + chromdt[, .SD[.N>1], by='refseq_mrna'] + chromdt %>% data.table::setnames('chromosome_name', 'seqnames') + + brunello %<>% data.table::merge.data.table(chromdt, by = 'refseq_mrna') + cmessage('\t%d gRNAs targeting %d transcripts, after adding canonical chromosome mappings', + nrow(brunello), brunello[, length(unique(refseq_mrna))]) + brunello +} + +add_brunello_strand <- function(brunello, ensmart){ + + # Get strand mappings + brunello %>% data.table::setnames('Strand', 'sense') + strandt <- suppressMessages( + biomaRt::getBM( attributes = c('refseq_mrna', 'strand'), + filters = 'refseq_mrna', + values = unique(brunello$refseq_mrna), + mart = ensmart)) %>% + data.table::as.data.table() + strandt %<>% extract(, .SD[.N==1], by = 'refseq_mrna') + strandt[, strand := vapply(strand, multicrispr::csign, character(1))] + brunello %<>% data.table::merge.data.table(strandt, by = 'refseq_mrna') + # 76 441 -> 75 463 -> 75 244 + cmessage('\t%d gRNAs targeting %d transcripts, after adding unique strand mappings', + nrow(brunello), brunello[, length(unique(refseq_mrna))]) + brunello[sense=='antisense', strand := ifelse(strand=='+', '-', '+')] + brunello$sense <- NULL + brunello +} + +forge_spacer_ranges <- function(brunello){ + + # Grange + brunello %>% data.table::setnames(c('Position of Base After Cut (1-based)'), c( 'start')) + brunello %>% extract(, end := start) + bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 + brunello <- dt2gr(brunello, BSgenome::seqinfo(bsgenome)[GenomeInfoDb::standardChromosomes(bsgenome)]) + + # Extend + brunello[GenomicRanges::strand(brunello)=='+'] %<>% extend(-17, +2) + brunello[GenomicRanges::strand(brunello)=='-'] %<>% extend(-16, +3) + brunello$crisprspacer <- BSgenome::getSeq(bsgenome, brunello, as.character=TRUE) + brunello %<>% subset(`sgRNA Target Sequence`==crisprspacer) + # Drop 12 non-matches (due to sequence changes). 75 244 -> 75 232 + brunello$`sgRNA Target Sequence` <- NULL + cmessage('\t%d gRNAs targeting %d transcripts, after removing non-matching spacers', + length(brunello), length(unique(brunello$refseq_mrna))) + + # Harmonize/drop names + names(mcols(brunello)) %<>% + stri_replace_first_fixed('Target Context Sequence', 'crisprcontext') %>% + stri_replace_first_fixed('PAM Sequence', 'crisprpam') %>% + stri_replace_first_fixed('Rule Set 2 score', 'Doench2016') + brunello$`Genomic Sequence` <- brunello$`Target Gene ID` <- NULL + brunello$`Exon Number` <- NULL + brunello$crisprname <- uniquify(brunello$refseq_mrna) + names(brunello) <- brunello$crisprname + + # Return + brunello +} + +reconstruct_brunello_spacers <- function(){ + brunello <- read_brunello_dt() + ensmart <- load_ensmart() + brunello %<>% add_brunello_seqnames(ensmart) + brunello %<>% add_brunello_strand(ensmart) + brunello <- forge_spacer_ranges(brunello) + # Are context seqs identical? Yes! + #all(brunello$crisprcontext == (brunello %>% extend(-4,+6) %>% getSeq(bsgenome, ., as.character=TRUE))) + brunello +} + +validate_brunello_spacers <- function(brunello){ + + # Find spacers + message('Find Brunello spacers') + bsgenome <- BSgenome::getBSgenome(genome = genome(brunello)[1]) + spacers <- extend(brunello, 0, +3) %>% + multicrispr::find_spacers(bsgenome, plot = FALSE) + # All brunello spacers are found + # 4 813 additional spacers are found on rev strands + + # Venn + spcoords <- unname(as.character(granges(spacers))) + brcoords <- unname(as.character(granges(brunello))) + autonomics.plot::plot_venn(list(multicrispr=spcoords, brunello=brcoords)) + spacers %<>% extract(spcoords %in% brcoords) # Limit to Brunello spacers + + # Doench score + message('Doench 2016 score') + names(mcols(spacers)) %<>% stringi::stri_replace_first_fixed('Doench2016', 'BrunelloDoench2016') + #brunello_spacers[1:10] %>% add_efficiency(bsgenome, 'Doench2016', plot = FALSE) + spacers %<>% add_efficiency(bsgenome, 'Doench2016', plot = FALSE, chunksize=10000) + plot(spacers$BrunelloDoench2016, spacers$Doench2016) + plot(density(spacers$Doench2016)) + + # Add genome counts + GenomeInfoDb::seqlevelsStyle(spacers) <- 'UCSC' + bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 + spacers %<>% add_genome_counts(bsgenome, mismatches=1) + table(spacers$G0) + spacers$unique <- spacers$G0==1 + autonomics.plot::plot_venn(list( + brunello = spacers$crisprname, + unique = subset(spacers, G0==1)$crisprname)) +} + +find_enclosing_exons <- function(spacers){ + + # Load canonical exons + ensdb <- AnnotationHub::AnnotationHub()[["AH78783"]] + exons <- ensembldb::exons(ensdb) + exons %<>% extract( as.character(seqnames(exons)) %in% + as.character(GenomicRanges::seqnames(spacers))) + + # Find overlaps + exons %<>% gr2dt() %>% dt2gr(seqinfo(exons )[seqlevelsInUse(exons )]) + spacers %<>% gr2dt() %>% dt2gr(seqinfo(spacers)[seqlevelsInUse(spacers)]) + res <- findOverlaps(exons, extend(spacers, 0, +3), ignore.strand = TRUE, minoverlap = 23) + + # Exon spacers + exonspacers <- spacers %>% extract(unique(subjectHits(res))) + cmessage('\t%d exon spacers', length(exonspacers)) + + # Spacer exons + spacerexons <- exons %>% extract(queryHits(res)) + spacerexons$targetname <- names(spacers)[subjectHits(res)] + spacerexons %<>% gr2dt() + spacerexons %<>% extract(, .SD[width == min(width)], by = 'targetname') # 75 229 / + spacerexons %<>% extract(, .SD[1], by = 'targetname') + spacerexons %<>% dt2gr(seqinfo(exons)) + cmessage('\t%d spacer exons', length(spacerexons)) + + # Return + return(spacerexons) + +} + +# Get Brunello exons +#=================== + brunello <- reconstruct_brunello_spacers() + brunello_spacers <- validate_brunello_spacers(brunello) + brunello_exons <- find_enclosing_exons(brunello) + brunello %<>% extract(brunello_exons$targetname) + +# Find exon spacers +#================== + bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 + exonspacers <- find_spacers(brunello_exons, bsgenome, plot = FALSE) # 2 583 378 + saveRDS(exonspacers, '../multicrisprout/brunello/exonspacers0.rds') + saveRDS(exonspacers, 'Z:/abhagwa/multicrisprout/brunello/exonspacers0.rds') + +# Score exon spacers +#=================== + require(reticulate) + use_condaenv('azienv') + import('azimuth') + require(multicrispr) + require(magrittr) + exonspacers <- readRDS('../multicrisprout/brunello/exonspacers0.rds') + bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 + exonspacers %<>% add_efficiency(bsgenome, 'Doench2016', chunksize=50000, plot = FALSE) + saveRDS(exonspacers, '../multicrisprout/brunello/exonspacers1.rds') + +# (Mis)match exon spacers. Execute in two disjunct chunks to save memory. +#======================================================================== + exonspacers <- readRDS('../multicrisprout/brunello/exonspacers1.rds') + exonspacers <- readRDS('Z:/abhagwa/multicrisprout/brunello/exonspacers1.rds') + bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 + GenomeInfoDb::seqlevelsStyle(exonspacers) <- 'UCSC' + outdir = '../multicrisprout/brunello' + exonspacers %<>% extract(order(.$crisprspacer)) + xsp1 <- exonspacers[seq(1,2583378/2)] + xsp2 <- exonspacers[seq(2583378/2+1, 2583378)] + autonomics.plot::plot_venn(list(xsp1=xsp1$crisprspacer, xsp2=xsp2$crisprspacer)) + xsp1 %<>% add_genome_counts(bsgenome, outdir = outdir, mismatches = 1, + indexedgenomesdir = '../multicrisprout/indexedgenomes') + xsp2 %<>% add_genome_counts(bsgenome, outdir = outdir, mismatches = 1, + indexedgenomesdir = '../multicrisprout/indexedgenomes') + exonspacers <- c(xsp1, xsp2) + GenomeInfoDb::seqlevelsStyle(exonspacers) <- 'NCBI' + #saveRDS(exonspacers, '../multicrisprout/brunello/exonspacers2.rds') + #exonspacers <- readRDS('../multicrisprout/brunello/exonspacers.rds') + +# Plot validation results +#======================== + # Venn + exonspacers <- readRDS('Z:/abhagwa/multicrisprout/brunello/exonspacers.rds') + brunellocoords <- unname(as.character(granges(brunello))) + exonspacercoords <- unname(as.character(granges(exonspacers))) + x <- list(multicrispr = exonspacercoords, Brunello = brunellocoords) + p_brunello_venn <- autonomics::plot_venn(x, title = 'Brunello spacer ranges') + x <- list(multicrispr = unique(exonspacers$crisprspacer), Brunello = unique(brunello$crisprspacer)) + p_brunello_venn2 <- autonomics::plot_venn(x, title = 'Brunello spacer seqs') + + # Densities + # multicrispr::plot_intervals(subset(exonspacers, seqnames==1)) + exonspacers$set <- ifelse(exonspacers$in_brunello, 'brunello', 'multicrispr') + p_brunello_on <- + ggplot2::ggplot() + + ggplot2::geom_density( data = data.table::as.data.table(exonspacers), + mapping = ggplot2::aes(x = Doench2016), + fill = "#00BFC4", alpha = 0.5) + + ggplot2::geom_density( data = data.table::as.data.table(subset(exonspacers, in_brunello==TRUE)), + mapping = ggplot2::aes(x = Doench2016), + fill = "#F8766D", alpha = 0.5) + + ggplot2::theme_bw() + + ggplot2::guides(color = FALSE) + + # Genome (mis)matches + color_values <- c(multicrispr = "#00BFC4", brunello = "#F8766D", unique = "#00BA38") + #autonomics.plot::make_gg_colors(c('brunello', 'multicrispr'), show=TRUE) + multioff <- table(exonspacers$G0) + names(multioff) %<>% as.numeric() %>% magrittr::subtract(1) %>% as.character() + total <- sum(multioff) + multioff[1] <- 100 * (sum(multioff[1:length(multioff)])) / total + multioff[2] <- 100 * (sum(multioff[2:length(multioff)])) / total + multioff[3] <- 100 * (sum(multioff[3:length(multioff)])) / total + multioff[4] <- 100 * (sum(multioff[4:length(multioff)])) / total + multioff %<>% extract(1:4) + + broff <- table(subset(exonspacers, in_brunello==TRUE)$G0) + names(broff) %<>% as.numeric() %>% magrittr::subtract(1) %>% as.character() + total <- sum(broff) + broff[1] <- 100 * (sum(broff[1:length(broff)])) / total + broff[2] <- 100 * (sum(broff[2:length(broff)])) / total + broff[3] <- 100 * (sum(broff[3:length(broff)])) / total + broff[4] <- 100 * (sum(broff[4:length(broff)])) / total + broff %<>% extract(1:4) + + dt <- data.table::data.table( + x = c('>=1', '>=2', '>=3', '>=1', '>=2', '>=3'), + y = c(multioff[-1], broff[-1]), + set = c(rep('multicrispr', each=3), rep('brunello', each=3))) + p_brunello_off<-ggplot2::ggplot(dt) + + ggplot2::geom_col(ggplot2::aes(x=x, y=y, fill =set), position = 'dodge') + + ggplot2::xlab('Offtarget matches') + + ggplot2::ylab('Percentage of spacers') + + ggplot2::theme_bw() + + ggplot2::guides(fill=FALSE) + +require(multipanelfigure) + +fig <- multi_panel_figure(columns = 10, rows = 3, width = 500, height = 250, row_spacing = 10, column_spacing = 10, panel_label_type = 'none') +fig <- fill_panel(fig, p_pe_venn, row = 1, column = 1:5 ) +fig <- fill_panel(fig, p_pe_on, row = 2, column = 1:5 ) +fig <- fill_panel(fig, p_parallel_venn, row = 1, column = 6:7 ) +fig <- fill_panel(fig, p_parallel_on, row = 2, column = 6:7 ) +fig <- fill_panel(fig, p_brunello_venn, row = 1, column = 8:10 ) +fig <- fill_panel(fig, p_brunello_on, row = 2, column = 8:10 ) +fig <- fill_panel(fig, p_brunello_off, row = 3, column = 8:10) +fig + +require(Cairo) +file_local <- '../multicrisprout/validation.pdf' +file_agnerds <- 'Z:\\abhagwa\\multicrisprmanuscript\\figures\\validation.pdf' +cairo_pdf(file_local, width = figure_width(fig, unit_to = 'inch'), height = figure_height(fig, unit_to = 'inch')) +#pdf(filename, width = figure_width(fig, unit_to = 'inch'), height = figure_height(fig, unit_to = 'inch')) +print(fig) +dev.off() + diff --git a/inst/scipts/08_genome_arithmetics_figure.R b/inst/scipts/08_genome_arithmetics_figure.R index ea264cc260009831ad5f3e360f41cb865c8604c7..5841379934a429570f7cda06c9246aede02eaa50 100644 --- a/inst/scipts/08_genome_arithmetics_figure.R +++ b/inst/scipts/08_genome_arithmetics_figure.R @@ -1,40 +1,40 @@ -require(multipanelfigure) - -fig <- multi_panel_figure(columns = 4, rows = 2, width = 297, height = 210) - -filename <- '../multicrisprout/A_crispr.pdf' -file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/A_crispr.pdf', filename) -image <- magick::image_read_pdf(filename) -filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') -magick::image_write(image, filename) -fig <- fill_panel(fig, filename, row = 1, column = 1:2, scaling = 'shrink') - -filename <- '../multicrisprout/B_prime_editing.pdf' -file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/B_prime_editing.pdf', filename) -image <- magick::image_read_pdf(filename) -filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') -magick::image_write(image, filename) -fig <- fill_panel(fig, filename, row = 1, column = 3:4, scaling = 'shrink') -fig - -filename <- '../multicrisprout/C_grna_tools.pdf' -file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/C_grna_tools.pdf', filename) -image <- magick::image_read_pdf(filename) -filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') -magick::image_write(image, filename) -fig <- fill_panel(fig, filename, row = 2, column = 1, scaling = 'shrink') -fig - -filename <- '../multicrisprout/D_genome_arithmetics_wide.pdf' -file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/D_genome_arithmetics_wide.pdf', filename) -image <- magick::image_read_pdf(filename) -filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') -magick::image_write(image, filename) -fig <- fill_panel(fig, filename, row = 2, column = 2:4, scaling = 'shrink') -fig - -pdf('Z:/PaperInPrep/multicrispr/figures/fig1/fig1.pdf', - width = figure_width( fig, 'inch'), - height = figure_height(fig, 'inch')) -print(fig) -dev.off() +require(multipanelfigure) + +fig <- multi_panel_figure(columns = 4, rows = 2, width = 297, height = 210) + +filename <- '../multicrisprout/A_crispr.pdf' +file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/A_crispr.pdf', filename) +image <- magick::image_read_pdf(filename) +filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') +magick::image_write(image, filename) +fig <- fill_panel(fig, filename, row = 1, column = 1:2, scaling = 'shrink') + +filename <- '../multicrisprout/B_prime_editing.pdf' +file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/B_prime_editing.pdf', filename) +image <- magick::image_read_pdf(filename) +filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') +magick::image_write(image, filename) +fig <- fill_panel(fig, filename, row = 1, column = 3:4, scaling = 'shrink') +fig + +filename <- '../multicrisprout/C_grna_tools.pdf' +file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/C_grna_tools.pdf', filename) +image <- magick::image_read_pdf(filename) +filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') +magick::image_write(image, filename) +fig <- fill_panel(fig, filename, row = 2, column = 1, scaling = 'shrink') +fig + +filename <- '../multicrisprout/D_genome_arithmetics_wide.pdf' +file.copy('Z:/PaperInPrep/multicrispr/figures/fig1/D_genome_arithmetics_wide.pdf', filename) +image <- magick::image_read_pdf(filename) +filename %<>% stringi::stri_replace_first_fixed('pdf', 'png') +magick::image_write(image, filename) +fig <- fill_panel(fig, filename, row = 2, column = 2:4, scaling = 'shrink') +fig + +pdf('Z:/PaperInPrep/multicrispr/figures/fig1/fig1.pdf', + width = figure_width( fig, 'inch'), + height = figure_height(fig, 'inch')) +print(fig) +dev.off() diff --git a/inst/scipts/09_readme_fig.R b/inst/scipts/09_readme_fig.R index ef5e0ec239512441d627a7c8e13f820b47efca10..05d35a4958bf433d2970e7d43e350a63d2617c3d 100644 --- a/inst/scipts/09_readme_fig.R +++ b/inst/scipts/09_readme_fig.R @@ -1,224 +1,224 @@ -require(magrittr) -require(multicrispr) - -#============= -# TFBS -#============= - -tweaksave <- function(gr, fname, size_var = NULL, alpha_var = NULL){ - gr %<>% subset(targetname=='T0163') - g <- plot_intervals(gr, alpha_var = alpha_var, size_var = size_var) + - ggplot2::scale_color_manual(values = c(T0163="#00BFC4")) + - ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) - ggplot2::ggsave(paste0('../multicrisprout/graphs/', fname, '.png'), g, width=2.5, height=2) -} - -# Decide which to keep -reticulate::use_condaenv('azienv') -bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -bedfile <- system.file('extdata/SRF.bed', package='multicrispr') -targets <- multicrispr::bed_to_granges(bedfile, genome='mm10', plot = FALSE) -extended <- extend(targets, -22, +22) -spacers <- extended %>% find_spacers(bsgenome, plot = FALSE) -spacers %<>% add_offtargets(bsgenome, extended, plot = FALSE) -spacers %<>% add_efficiency(bsgenome, method = 'Doench2016', plot = FALSE) - -tweaksave(targets, fname = 'srf01') -tweaksave(extended, fname = 'srf02_extended') -tweaksave(spacers, fname = 'srf03_spacers') -tweaksave(spacers, fname = 'srf04_specific', alpha_var = 'specific') -tweaksave(spacers, fname = 'srf05_efficient', alpha_var = 'specific', size_var = 'Doench2016') - - -# PE -#===== -bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -# gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp -# HBB = 'chr11:5227002:-', # snp -# HEXA = 'chr15:72346580-72346583:-', # del -# CFTR = 'chr7:117559593-117559595:+'), # ins -# bsgenome) -gr <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) -plot_intervals(gr, facet_var = c('seqnames', 'targetname')) - -spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) %>% add_genome_counts() -spacers$specific <- spacers$G0==1 -spacers %<>% add_efficiency(bsgenome, 'Doench2016') - # Select HBB - -gr %<>% extract('HBB') -p <- plot_intervals(gr, facet_var = c('seqnames', 'targetname')) + - ggplot2::guides(color = FALSE) -ggplot2::ggsave('graphs/hbb01.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - -extended <- extend_for_pe(gr, nrt = 48) -p <- plot_intervals(extended, facet_var = c('seqnames', 'targetname')) + - ggplot2::guides(color = FALSE) -ggplot2::ggsave('graphs/hbb02_extended.pdf', p, width=2.1, height=1.8, device = grDevices::cairo_pdf) - -spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) -p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname')) + - ggplot2::guides(color = FALSE, size = FALSE) -ggplot2::ggsave('graphs/hbb03_spacers.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - -spacers %<>% add_genome_counts() -spacers$specific <- spacers$G0==1 -p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), - alpha_var = 'specific') + - ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + - ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) -ggplot2::ggsave('graphs/hbb04_specific.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - -spacers %<>% add_efficiency(bsgenome, 'Doench2016') -quantiles <- round(quantile(spacers$Doench2016, c(0.33, 0.66, 1)), 2) -spacers$efficiency <- cut(spacers$Doench2016, c(0, quantiles), labels = quantiles) %>% - as.character() -p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), - alpha_var = 'specific', size_var = 'efficiency') + - ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + - ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + - ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) -ggplot2::ggsave('graphs/hbb05_efficient.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) - - -gr %<>% extract('HBB') -plot_intervals(gr, facet_var = c('targetname', 'seqnames'), color_var = NULL) + - #ggplot2::guides(color=FALSE) + - ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + - ggplot2::scale_x_continuous(name = NULL, breaks = c(0, 1)) + - ggplot2::theme(panel.grid.major = ggplot2::element_blank(), - panel.grid.minor = ggplot2::element_blank()) - - -# Extend -find_spacers(extend_for_pe(gr, bsgenome), bsgenome, complement = FALSE) - -grplot <- c(gr, grext) -grplot$set <- c('target', '+', '-') -plot_intervals(grplot, facet_var = c('targetname', 'seqnames'), yby = 'set', color_var = NULL, linetype = 'set') + - ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + - #ggplot2::guides(color=FALSE) + - ggplot2::scale_linetype_manual(values = c(target = 'solid', `+` = 'longdash', `-` = 'longdash')) + - #ggplot2::scale_color_manual(values = c(target = '#F8766D', `+` = 'black' , `-` = 'black')) + - ggplot2::guides(linetype=FALSE) + - ggplot2::theme(panel.grid.major = ggplot2::element_blank(), - panel.grid.minor = ggplot2::element_blank()) -grDevices::hcl(h = seq(15, 375, length = n + 1), l = 65, c = 100)[1:3] - - #ggplot2::theme( legend.position = c(0.25,0.73), - # legend.title = ggplot2::element_blank(), - # legend.key = ggplot2::element_blank(), - # legend.background = ggplot2::element_blank()) - -# Find pe sites -spacers <- find_pe_spacers(gr, bsgenome, nrt = 26) - -# Filter for specificity -genomedir <- '~/.multicrispr/bowtie/genome/BSgenome.Hsapiens.UCSC.hg38' -outdir <- '~/.multicrispr/bowtie' -filter_prime_specific(spacers, genomedir, outdir) - - - -# quantiles <- round(quantile(spacers$Doench2016, c(.33, .66, 1)), 2) -# spacers$efficiency <- spacers$Doench2016 %>% cut(c(0, quantiles), labels = as.character(quantiles)) -# p <- plot_intervals(spacers, size_var = 'efficiency') + -# ggplot2::scale_size_manual(values = c(0.2, 1.5, 4) %>% set_names(quantiles)) + -# ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) -# ggplot2::ggsave('graphs/srf_efficient.png', p, width = 3, height = 2.5) - -p <- plot_intervals(spacers, size_var = 'efficiency', alpha_var = 'specific') + - ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + - ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.25)) + - ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) -ggplot2::ggsave('graphs/srf_efficient.png', p, width = 2.5, height = 2) - - -# Process -png('graphs/srf_extended.png') -targets %<>% extend(plot = TRUE) -dev.off() - - -targets %>% find_spacers(bsgenome) %>% filter_target_specific(targets, bsgenome) %>% filter_efficient() - -targets %<>% subset(targetname %in% c('T0018', 'T1042')) -plot_intervals(targets, yby = 'targetname') - -# Extend -grext <- extend(gr, plot = TRUE) -gr$set <- 'target' -grext$set <- 'extension' -grplot <- c(gr, grext) -grplot$set %<>% factor(c('target', 'extension')) -plot_intervals(grplot, color_var = 'targetname', linetype = 'set') - -# Find spacers -spacers <- find_spacers(grext, bsgenome) -spacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') - -# Filter for specificity -tdir <- index_targets(grext, bsgenome) -gdir <- '~/.multicrispr/bowtie/genome/BSgenome.Mmusculus.UCSC.mm10' -outdir <- '~/.multicrispr/bowtie' -specificspacers <- filter_target_specific(spacers, tdir, gdir, outdir) -specificspacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') - -# Filter for -specificspacers %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') -specificspacers %>% subset(targetname %in% c('T0018', 'T0151') & Doench2016 > 0.4) - - plot_intervals(specificspacers, yby = 'crisprname') - - - - - -targets <- extend(bed_to_granges(bedfile, genome='mm10', plot = FALSE)) -bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -spacers <- find_spacers(targets, bsgenome) -indexedgenome <- '~/.multicrispr/bowtie/BSgenome.Mmusculus.UCSC.mm10' -specific <- filter_target_specific(spacers, targets, bsgenome, indexedgenome) -specific %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') -efficient <- specific %<>% subset(Doench2016>0.4) - - -targets$set <- 'A' -spacers$set <- 'B' -specific$set <- 'C' -efficient$set <- 'D' - -plotgr <- c(targets, spacers, specific, efficient) - - plotgr %<>% sort(ignore.strand = TRUE) - #plotgr %<>% subset(seqnames == 'chr1') - plotdt <- data.table::as.data.table(plotgr) - plotdt[ , bin := cut(start, 10, labels = FALSE) ] - plotdt[ , y := scales::number(min(start), big.mark = ','), by = 'bin'] - plotdt$y %<>% factor(unique(.)) - - plotdt[strand=='+', x := start] - plotdt[strand=='+', xend := end] - plotdt[strand=='-', x := end] - plotdt[strand=='-', xend := start] - - # plotdt[strand=='+', x := start - min(start), by = 'y' ] - # plotdt[strand=='+', xend := end - min(start), by = 'y' ] - # plotdt[strand=='-', x := end - min(start), by = 'y' ] - # plotdt[strand=='-', xend := start - min(start), by = 'y' ] - - require(ggplot2) - ggplot(plotdt, aes_string(x = 'x', xend = 'xend', y = 'seqnames', yend = 'seqnames', color = 'set')) + - geom_segment(arrow = arrow(length = unit(0.1, "inches"))) + - scale_x_continuous(labels = scales::comma) + - xlab(NULL) + ylab(NULL) + theme_bw() + - scale_color_manual(values=c(A='lavenderblush', B='gray90', C='gray50', D='green4')) - #guides(color = FALSE) - - - - - - - - +require(magrittr) +require(multicrispr) + +#============= +# TFBS +#============= + +tweaksave <- function(gr, fname, size_var = NULL, alpha_var = NULL){ + gr %<>% subset(targetname=='T0163') + g <- plot_intervals(gr, alpha_var = alpha_var, size_var = size_var) + + ggplot2::scale_color_manual(values = c(T0163="#00BFC4")) + + ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) + ggplot2::ggsave(paste0('../multicrisprout/graphs/', fname, '.png'), g, width=2.5, height=2) +} + +# Decide which to keep +reticulate::use_condaenv('azienv') +bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +bedfile <- system.file('extdata/SRF.bed', package='multicrispr') +targets <- multicrispr::bed_to_granges(bedfile, genome='mm10', plot = FALSE) +extended <- extend(targets, -22, +22) +spacers <- extended %>% find_spacers(bsgenome, plot = FALSE) +spacers %<>% add_offtargets(bsgenome, extended, plot = FALSE) +spacers %<>% add_efficiency(bsgenome, method = 'Doench2016', plot = FALSE) + +tweaksave(targets, fname = 'srf01') +tweaksave(extended, fname = 'srf02_extended') +tweaksave(spacers, fname = 'srf03_spacers') +tweaksave(spacers, fname = 'srf04_specific', alpha_var = 'specific') +tweaksave(spacers, fname = 'srf05_efficient', alpha_var = 'specific', size_var = 'Doench2016') + + +# PE +#===== +bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +# gr <- char_to_granges(c(PRNP = 'chr20:4699600:+', # snp +# HBB = 'chr11:5227002:-', # snp +# HEXA = 'chr15:72346580-72346583:-', # del +# CFTR = 'chr7:117559593-117559595:+'), # ins +# bsgenome) +gr <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) +plot_intervals(gr, facet_var = c('seqnames', 'targetname')) + +spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) %>% add_genome_counts() +spacers$specific <- spacers$G0==1 +spacers %<>% add_efficiency(bsgenome, 'Doench2016') + # Select HBB + +gr %<>% extract('HBB') +p <- plot_intervals(gr, facet_var = c('seqnames', 'targetname')) + + ggplot2::guides(color = FALSE) +ggplot2::ggsave('graphs/hbb01.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + +extended <- extend_for_pe(gr, nrt = 48) +p <- plot_intervals(extended, facet_var = c('seqnames', 'targetname')) + + ggplot2::guides(color = FALSE) +ggplot2::ggsave('graphs/hbb02_extended.pdf', p, width=2.1, height=1.8, device = grDevices::cairo_pdf) + +spacers <- gr %>% find_pe_spacers(bsgenome, nrt=48) +p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname')) + + ggplot2::guides(color = FALSE, size = FALSE) +ggplot2::ggsave('graphs/hbb03_spacers.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + +spacers %<>% add_genome_counts() +spacers$specific <- spacers$G0==1 +p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), + alpha_var = 'specific') + + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + + ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) +ggplot2::ggsave('graphs/hbb04_specific.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + +spacers %<>% add_efficiency(bsgenome, 'Doench2016') +quantiles <- round(quantile(spacers$Doench2016, c(0.33, 0.66, 1)), 2) +spacers$efficiency <- cut(spacers$Doench2016, c(0, quantiles), labels = quantiles) %>% + as.character() +p <- plot_intervals(spacers, facet_var = c('seqnames', 'targetname'), + alpha_var = 'specific', size_var = 'efficiency') + + ggplot2::scale_alpha_manual(values = c(`TRUE` = 1, `FALSE` = 0.25)) + + ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + + ggplot2::guides(color = FALSE, size = FALSE, alpha = FALSE) +ggplot2::ggsave('graphs/hbb05_efficient.pdf', p, width=2.2, height=1.8, device = grDevices::cairo_pdf) + + +gr %<>% extract('HBB') +plot_intervals(gr, facet_var = c('targetname', 'seqnames'), color_var = NULL) + + #ggplot2::guides(color=FALSE) + + ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + + ggplot2::scale_x_continuous(name = NULL, breaks = c(0, 1)) + + ggplot2::theme(panel.grid.major = ggplot2::element_blank(), + panel.grid.minor = ggplot2::element_blank()) + + +# Extend +find_spacers(extend_for_pe(gr, bsgenome), bsgenome, complement = FALSE) + +grplot <- c(gr, grext) +grplot$set <- c('target', '+', '-') +plot_intervals(grplot, facet_var = c('targetname', 'seqnames'), yby = 'set', color_var = NULL, linetype = 'set') + + ggplot2::xlab(NULL) + ggplot2::ylab(NULL) + + #ggplot2::guides(color=FALSE) + + ggplot2::scale_linetype_manual(values = c(target = 'solid', `+` = 'longdash', `-` = 'longdash')) + + #ggplot2::scale_color_manual(values = c(target = '#F8766D', `+` = 'black' , `-` = 'black')) + + ggplot2::guides(linetype=FALSE) + + ggplot2::theme(panel.grid.major = ggplot2::element_blank(), + panel.grid.minor = ggplot2::element_blank()) +grDevices::hcl(h = seq(15, 375, length = n + 1), l = 65, c = 100)[1:3] + + #ggplot2::theme( legend.position = c(0.25,0.73), + # legend.title = ggplot2::element_blank(), + # legend.key = ggplot2::element_blank(), + # legend.background = ggplot2::element_blank()) + +# Find pe sites +spacers <- find_pe_spacers(gr, bsgenome, nrt = 26) + +# Filter for specificity +genomedir <- '~/.multicrispr/bowtie/genome/BSgenome.Hsapiens.UCSC.hg38' +outdir <- '~/.multicrispr/bowtie' +filter_prime_specific(spacers, genomedir, outdir) + + + +# quantiles <- round(quantile(spacers$Doench2016, c(.33, .66, 1)), 2) +# spacers$efficiency <- spacers$Doench2016 %>% cut(c(0, quantiles), labels = as.character(quantiles)) +# p <- plot_intervals(spacers, size_var = 'efficiency') + +# ggplot2::scale_size_manual(values = c(0.2, 1.5, 4) %>% set_names(quantiles)) + +# ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) +# ggplot2::ggsave('graphs/srf_efficient.png', p, width = 3, height = 2.5) + +p <- plot_intervals(spacers, size_var = 'efficiency', alpha_var = 'specific') + + ggplot2::scale_size_manual(values = c(0.2, 1.5, 3) %>% set_names(quantiles)) + + ggplot2::scale_alpha_manual(values = c(`TRUE`=1, `FALSE`=0.25)) + + ggplot2::guides(color = FALSE, alpha = FALSE, size = FALSE) +ggplot2::ggsave('graphs/srf_efficient.png', p, width = 2.5, height = 2) + + +# Process +png('graphs/srf_extended.png') +targets %<>% extend(plot = TRUE) +dev.off() + + +targets %>% find_spacers(bsgenome) %>% filter_target_specific(targets, bsgenome) %>% filter_efficient() + +targets %<>% subset(targetname %in% c('T0018', 'T1042')) +plot_intervals(targets, yby = 'targetname') + +# Extend +grext <- extend(gr, plot = TRUE) +gr$set <- 'target' +grext$set <- 'extension' +grplot <- c(gr, grext) +grplot$set %<>% factor(c('target', 'extension')) +plot_intervals(grplot, color_var = 'targetname', linetype = 'set') + +# Find spacers +spacers <- find_spacers(grext, bsgenome) +spacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') + +# Filter for specificity +tdir <- index_targets(grext, bsgenome) +gdir <- '~/.multicrispr/bowtie/genome/BSgenome.Mmusculus.UCSC.mm10' +outdir <- '~/.multicrispr/bowtie' +specificspacers <- filter_target_specific(spacers, tdir, gdir, outdir) +specificspacers %>% subset(targetname %in% c('T0018', 'T0151')) %>% plot_intervals(yby = 'crisprname', color_var = 'targetname') + +# Filter for +specificspacers %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') +specificspacers %>% subset(targetname %in% c('T0018', 'T0151') & Doench2016 > 0.4) + + plot_intervals(specificspacers, yby = 'crisprname') + + + + + +targets <- extend(bed_to_granges(bedfile, genome='mm10', plot = FALSE)) +bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +spacers <- find_spacers(targets, bsgenome) +indexedgenome <- '~/.multicrispr/bowtie/BSgenome.Mmusculus.UCSC.mm10' +specific <- filter_target_specific(spacers, targets, bsgenome, indexedgenome) +specific %<>% score_spacers(bsgenome, 'Doench2016', condaenv = 'azimuthenv') +efficient <- specific %<>% subset(Doench2016>0.4) + + +targets$set <- 'A' +spacers$set <- 'B' +specific$set <- 'C' +efficient$set <- 'D' + +plotgr <- c(targets, spacers, specific, efficient) + + plotgr %<>% sort(ignore.strand = TRUE) + #plotgr %<>% subset(seqnames == 'chr1') + plotdt <- data.table::as.data.table(plotgr) + plotdt[ , bin := cut(start, 10, labels = FALSE) ] + plotdt[ , y := scales::number(min(start), big.mark = ','), by = 'bin'] + plotdt$y %<>% factor(unique(.)) + + plotdt[strand=='+', x := start] + plotdt[strand=='+', xend := end] + plotdt[strand=='-', x := end] + plotdt[strand=='-', xend := start] + + # plotdt[strand=='+', x := start - min(start), by = 'y' ] + # plotdt[strand=='+', xend := end - min(start), by = 'y' ] + # plotdt[strand=='-', x := end - min(start), by = 'y' ] + # plotdt[strand=='-', xend := start - min(start), by = 'y' ] + + require(ggplot2) + ggplot(plotdt, aes_string(x = 'x', xend = 'xend', y = 'seqnames', yend = 'seqnames', color = 'set')) + + geom_segment(arrow = arrow(length = unit(0.1, "inches"))) + + scale_x_continuous(labels = scales::comma) + + xlab(NULL) + ylab(NULL) + theme_bw() + + scale_color_manual(values=c(A='lavenderblush', B='gray90', C='gray50', D='green4')) + #guides(color = FALSE) + + + + + + + + diff --git a/public/404.html b/public/404.html index e95861a5cfc70007c246237972eda77dc6cae85c..7863d5fb962730bc9cdd5ee68e8d46403e049f3c 100644 --- a/public/404.html +++ b/public/404.html @@ -1,142 +1,142 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Page not found (404) • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="pkgdown.css" rel="stylesheet"> -<script src="pkgdown.js"></script> - - - - -<meta property="og:title" content="Page not found (404)" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-title-body"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="contents col-md-9"> - <div class="page-header"> - <h1>Page not found (404)</h1> - </div> - -Content not found. Please use links in the navbar. - - </div> - -</div> - - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Page not found (404) • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="pkgdown.css" rel="stylesheet"> +<script src="pkgdown.js"></script> + + + + +<meta property="og:title" content="Page not found (404)" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-title-body"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="contents col-md-9"> + <div class="page-header"> + <h1>Page not found (404)</h1> + </div> + +Content not found. Please use links in the navbar. + + </div> + +</div> + + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/articles/designing_grna_libraries.html b/public/articles/designing_grna_libraries.html index 6b054c4b9e21925de88751d7b11679ce7b077767..246f070503398f15c426ea101be7482433dab0bc 100644 --- a/public/articles/designing_grna_libraries.html +++ b/public/articles/designing_grna_libraries.html @@ -1,925 +1,925 @@ -<!DOCTYPE html> - -<html> - -<head> - -<meta charset="utf-8" /> -<meta name="generator" content="pandoc" /> -<meta http-equiv="X-UA-Compatible" content="IE=EDGE" /> - - -<meta name="author" content="Aditya M Bhagwat" /> - -<meta name="date" content="2020-04-23" /> - -<title>Using multicrispr for gRNA design</title> - -<script>/*! jQuery v1.11.3 | (c) 2005, 2015 jQuery Foundation, Inc. | jquery.org/license */ -!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k={},l="1.11.3",m=function(a,b){return new m.fn.init(a,b)},n=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,o=/^-ms-/,p=/-([\da-z])/gi,q=function(a,b){return b.toUpperCase()};m.fn=m.prototype={jquery:l,constructor:m,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=m.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return m.each(this,a,b)},map:function(a){return this.pushStack(m.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},m.extend=m.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||m.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(e=arguments[h]))for(d in e)a=g[d],c=e[d],g!==c&&(j&&c&&(m.isPlainObject(c)||(b=m.isArray(c)))?(b?(b=!1,f=a&&m.isArray(a)?a:[]):f=a&&m.isPlainObject(a)?a:{},g[d]=m.extend(j,f,c)):void 0!==c&&(g[d]=c));return g},m.extend({expando:"jQuery"+(l+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===m.type(a)},isArray:Array.isArray||function(a){return"array"===m.type(a)},isWindow:function(a){return null!=a&&a==a.window},isNumeric:function(a){return!m.isArray(a)&&a-parseFloat(a)+1>=0},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},isPlainObject:function(a){var b;if(!a||"object"!==m.type(a)||a.nodeType||m.isWindow(a))return!1;try{if(a.constructor&&!j.call(a,"constructor")&&!j.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}if(k.ownLast)for(b in a)return j.call(a,b);for(b in a);return void 0===b||j.call(a,b)},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(b){b&&m.trim(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(o,"ms-").replace(p,q)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var d,e=0,f=a.length,g=r(a);if(c){if(g){for(;f>e;e++)if(d=b.apply(a[e],c),d===!1)break}else for(e in a)if(d=b.apply(a[e],c),d===!1)break}else if(g){for(;f>e;e++)if(d=b.call(a[e],e,a[e]),d===!1)break}else for(e in a)if(d=b.call(a[e],e,a[e]),d===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(n,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(r(Object(a))?m.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){var d;if(b){if(g)return g.call(b,a,c);for(d=b.length,c=c?0>c?Math.max(0,d+c):c:0;d>c;c++)if(c in b&&b[c]===a)return c}return-1},merge:function(a,b){var c=+b.length,d=0,e=a.length;while(c>d)a[e++]=b[d++];if(c!==c)while(void 0!==b[d])a[e++]=b[d++];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;g>f;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=r(a),i=[];if(h)for(;g>f;f++)d=b(a[f],f,c),null!=d&&i.push(d);else for(f in a)d=b(a[f],f,c),null!=d&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(f=a[b],b=a,a=f),m.isFunction(a)?(c=d.call(arguments,2),e=function(){return a.apply(b||this,c.concat(d.call(arguments)))},e.guid=a.guid=a.guid||m.guid++,e):void 0},now:function(){return+new Date},support:k}),m.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});function r(a){var b="length"in a&&a.length,c=m.type(a);return"function"===c||m.isWindow(a)?!1:1===a.nodeType&&b?!0:"array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a}var s=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ha(),z=ha(),A=ha(),B=function(a,b){return a===b&&(l=!0),0},C=1<<31,D={}.hasOwnProperty,E=[],F=E.pop,G=E.push,H=E.push,I=E.slice,J=function(a,b){for(var c=0,d=a.length;d>c;c++)if(a[c]===b)return c;return-1},K="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",L="[\\x20\\t\\r\\n\\f]",M="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",N=M.replace("w","w#"),O="\\["+L+"*("+M+")(?:"+L+"*([*^$|!~]?=)"+L+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+N+"))|)"+L+"*\\]",P=":("+M+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+O+")*)|.*)\\)|)",Q=new RegExp(L+"+","g"),R=new RegExp("^"+L+"+|((?:^|[^\\\\])(?:\\\\.)*)"+L+"+$","g"),S=new RegExp("^"+L+"*,"+L+"*"),T=new RegExp("^"+L+"*([>+~]|"+L+")"+L+"*"),U=new RegExp("="+L+"*([^\\]'\"]*?)"+L+"*\\]","g"),V=new RegExp(P),W=new RegExp("^"+N+"$"),X={ID:new RegExp("^#("+M+")"),CLASS:new RegExp("^\\.("+M+")"),TAG:new RegExp("^("+M.replace("w","w*")+")"),ATTR:new RegExp("^"+O),PSEUDO:new RegExp("^"+P),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+L+"*(even|odd|(([+-]|)(\\d*)n|)"+L+"*(?:([+-]|)"+L+"*(\\d+)|))"+L+"*\\)|)","i"),bool:new RegExp("^(?:"+K+")$","i"),needsContext:new RegExp("^"+L+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+L+"*((?:-\\d)?\\d*)"+L+"*\\)|)(?=[^-]|$)","i")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\d$/i,$=/^[^{]+\{\s*\[native \w/,_=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,aa=/[+~]/,ba=/'|\\/g,ca=new RegExp("\\\\([\\da-f]{1,6}"+L+"?|("+L+")|.)","ig"),da=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},ea=function(){m()};try{H.apply(E=I.call(v.childNodes),v.childNodes),E[v.childNodes.length].nodeType}catch(fa){H={apply:E.length?function(a,b){G.apply(a,I.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function ga(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],k=b.nodeType,"string"!=typeof a||!a||1!==k&&9!==k&&11!==k)return d;if(!e&&p){if(11!==k&&(f=_.exec(a)))if(j=f[1]){if(9===k){if(h=b.getElementById(j),!h||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return H.apply(d,b.getElementsByTagName(a)),d;if((j=f[3])&&c.getElementsByClassName)return H.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=1!==k&&a,1===k&&"object"!==b.nodeName.toLowerCase()){o=g(a),(r=b.getAttribute("id"))?s=r.replace(ba,"\\$&"):b.setAttribute("id",s),s="[id='"+s+"'] ",l=o.length;while(l--)o[l]=s+ra(o[l]);w=aa.test(a)&&pa(b.parentNode)||b,x=o.join(",")}if(x)try{return H.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute("id")}}}return i(a.replace(R,"$1"),b,d,e)}function ha(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ia(a){return a[u]=!0,a}function ja(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ka(a,b){var c=a.split("|"),e=a.length;while(e--)d.attrHandle[c[e]]=b}function la(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||C)-(~a.sourceIndex||C);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function na(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function oa(a){return ia(function(b){return b=+b,ia(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function pa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=ga.support={},f=ga.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?"HTML"!==b.nodeName:!1},m=ga.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=g.documentElement,e=g.defaultView,e&&e!==e.top&&(e.addEventListener?e.addEventListener("unload",ea,!1):e.attachEvent&&e.attachEvent("onunload",ea)),p=!f(g),c.attributes=ja(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ja(function(a){return a.appendChild(g.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=$.test(g.getElementsByClassName),c.getById=ja(function(a){return o.appendChild(a).id=u,!g.getElementsByName||!g.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(ca,da);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(ca,da);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(g.querySelectorAll))&&(ja(function(a){o.appendChild(a).innerHTML="<a id='"+u+"'></a><select id='"+u+"-\f]' msallowcapture=''><option selected=''></option></select>",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+L+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+L+"*(?:value|"+K+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ja(function(a){var b=g.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+L+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ja(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='']:x"),r.push("!=",P)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===g||a.ownerDocument===v&&t(v,a)?-1:b===g||b.ownerDocument===v&&t(v,b)?1:k?J(k,a)-J(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,h=[a],i=[b];if(!e||!f)return a===g?-1:b===g?1:e?-1:f?1:k?J(k,a)-J(k,b):0;if(e===f)return la(a,b);c=a;while(c=c.parentNode)h.unshift(c);c=b;while(c=c.parentNode)i.unshift(c);while(h[d]===i[d])d++;return d?la(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},g):n},ga.matches=function(a,b){return ga(a,null,null,b)},ga.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,"='$1']"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return ga(b,n,null,[a]).length>0},ga.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},ga.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&D.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},ga.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},ga.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=ga.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=ga.selectors={cacheLength:50,createPseudo:ia,match:X,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(ca,da),a[3]=(a[3]||a[4]||a[5]||"").replace(ca,da),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||ga.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&ga.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&V.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(ca,da).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+L+")"+a+"("+L+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=ga.attr(d,a);return null==e?"!="===b:b?(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(Q," ")+" ").indexOf(c)>-1:"|="===b?e===c||e.slice(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h;if(q){if(f){while(p){l=b;while(l=l[p])if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&j[2],l=n&&q.childNodes[n];while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if(1===l.nodeType&&++m&&l===b){k[a]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)m=j[1];else while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if((h?l.nodeName.toLowerCase()===r:1===l.nodeType)&&++m&&(s&&((l[u]||(l[u]={}))[a]=[w,m]),l===b))break;return m-=e,m===d||m%d===0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||ga.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ia(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=J(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ia(function(a){var b=[],c=[],d=h(a.replace(R,"$1"));return d[u]?ia(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ia(function(a){return function(b){return ga(a,b).length>0}}),contains:ia(function(a){return a=a.replace(ca,da),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ia(function(a){return W.test(a||"")||ga.error("unsupported lang: "+a),a=a.replace(ca,da).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Z.test(a.nodeName)},input:function(a){return Y.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:oa(function(){return[0]}),last:oa(function(a,b){return[b-1]}),eq:oa(function(a,b,c){return[0>c?c+b:c]}),even:oa(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:oa(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:oa(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:oa(function(a,b,c){for(var d=0>c?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=ma(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=na(b);function qa(){}qa.prototype=d.filters=d.pseudos,d.setFilters=new qa,g=ga.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){(!c||(e=S.exec(h)))&&(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=T.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(R," ")}),h=h.slice(c.length));for(g in d.filter)!(e=X[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?ga.error(a):z(a,i).slice(0)};function ra(a){for(var b=0,c=a.length,d="";c>b;b++)d+=a[b].value;return d}function sa(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){while(b=b[d])if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[w,f];if(g){while(b=b[d])if((1===b.nodeType||e)&&a(b,c,g))return!0}else while(b=b[d])if(1===b.nodeType||e){if(i=b[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function ta(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function ua(a,b,c){for(var d=0,e=b.length;e>d;d++)ga(a,b[d],c);return c}function va(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function wa(a,b,c,d,e,f){return d&&!d[u]&&(d=wa(d)),e&&!e[u]&&(e=wa(e,f)),ia(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||ua(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:va(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=va(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?J(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=va(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):H.apply(g,r)})}function xa(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=sa(function(a){return a===b},h,!0),l=sa(function(a){return J(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];f>i;i++)if(c=d.relative[a[i].type])m=[sa(ta(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e;e++)if(d.relative[a[e].type])break;return wa(i>1&&ta(m),i>1&&ra(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(R,"$1"),c,e>i&&xa(a.slice(i,e)),f>e&&xa(a=a.slice(e)),f>e&&ra(a))}m.push(c)}return ta(m)}function ya(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q="0",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG("*",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){m=0;while(o=a[m++])if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){m=0;while(o=b[m++])o(r,s,g,h);if(f){if(p>0)while(q--)r[q]||s[q]||(s[q]=F.call(i));s=va(s)}H.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&ga.uniqueSort(i)}return k&&(w=v,j=t),r};return c?ia(f):f}return h=ga.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=xa(b[c]),f[u]?d.push(f):e.push(f);f=A(a,ya(e,d)),f.selector=a}return f},i=ga.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(b=(d.find.ID(k.matches[0].replace(ca,da),b)||[])[0],!b)return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}i=X.needsContext.test(a)?0:j.length;while(i--){if(k=j[i],d.relative[l=k.type])break;if((m=d.find[l])&&(f=m(k.matches[0].replace(ca,da),aa.test(j[0].type)&&pa(b.parentNode)||b))){if(j.splice(i,1),a=f.length&&ra(j),!a)return H.apply(e,f),e;break}}}return(n||h(a,o))(f,b,!p,e,aa.test(a)&&pa(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ja(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ja(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||ka("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ja(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ka("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ja(function(a){return null==a.getAttribute("disabled")})||ka(K,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),ga}(a);m.find=s,m.expr=s.selectors,m.expr[":"]=m.expr.pseudos,m.unique=s.uniqueSort,m.text=s.getText,m.isXMLDoc=s.isXML,m.contains=s.contains;var t=m.expr.match.needsContext,u=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,v=/^.[^:#\[\.,]*$/;function w(a,b,c){if(m.isFunction(b))return m.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return m.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(v.test(b))return m.filter(b,a,c);b=m.filter(b,a)}return m.grep(a,function(a){return m.inArray(a,b)>=0!==c})}m.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?m.find.matchesSelector(d,a)?[d]:[]:m.find.matches(a,m.grep(b,function(a){return 1===a.nodeType}))},m.fn.extend({find:function(a){var b,c=[],d=this,e=d.length;if("string"!=typeof a)return this.pushStack(m(a).filter(function(){for(b=0;e>b;b++)if(m.contains(d[b],this))return!0}));for(b=0;e>b;b++)m.find(a,d[b],c);return c=this.pushStack(e>1?m.unique(c):c),c.selector=this.selector?this.selector+" "+a:a,c},filter:function(a){return this.pushStack(w(this,a||[],!1))},not:function(a){return this.pushStack(w(this,a||[],!0))},is:function(a){return!!w(this,"string"==typeof a&&t.test(a)?m(a):a||[],!1).length}});var x,y=a.document,z=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,A=m.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(c="<"===a.charAt(0)&&">"===a.charAt(a.length-1)&&a.length>=3?[null,a,null]:z.exec(a),!c||!c[1]&&b)return!b||b.jquery?(b||x).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof m?b[0]:b,m.merge(this,m.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:y,!0)),u.test(c[1])&&m.isPlainObject(b))for(c in b)m.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}if(d=y.getElementById(c[2]),d&&d.parentNode){if(d.id!==c[2])return x.find(a);this.length=1,this[0]=d}return this.context=y,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):m.isFunction(a)?"undefined"!=typeof x.ready?x.ready(a):a(m):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),m.makeArray(a,this))};A.prototype=m.fn,x=m(y);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};m.extend({dir:function(a,b,c){var d=[],e=a[b];while(e&&9!==e.nodeType&&(void 0===c||1!==e.nodeType||!m(e).is(c)))1===e.nodeType&&d.push(e),e=e[b];return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),m.fn.extend({has:function(a){var b,c=m(a,this),d=c.length;return this.filter(function(){for(b=0;d>b;b++)if(m.contains(this,c[b]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=t.test(a)||"string"!=typeof a?m(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&m.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?m.unique(f):f)},index:function(a){return a?"string"==typeof a?m.inArray(this[0],m(a)):m.inArray(a.jquery?a[0]:a,this):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(m.unique(m.merge(this.get(),m(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function D(a,b){do a=a[b];while(a&&1!==a.nodeType);return a}m.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return m.dir(a,"parentNode")},parentsUntil:function(a,b,c){return m.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return m.dir(a,"nextSibling")},prevAll:function(a){return m.dir(a,"previousSibling")},nextUntil:function(a,b,c){return m.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return m.dir(a,"previousSibling",c)},siblings:function(a){return m.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return m.sibling(a.firstChild)},contents:function(a){return m.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:m.merge([],a.childNodes)}},function(a,b){m.fn[a]=function(c,d){var e=m.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=m.filter(d,e)),this.length>1&&(C[a]||(e=m.unique(e)),B.test(a)&&(e=e.reverse())),this.pushStack(e)}});var E=/\S+/g,F={};function G(a){var b=F[a]={};return m.each(a.match(E)||[],function(a,c){b[c]=!0}),b}m.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):m.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(c=a.memory&&l,d=!0,f=g||0,g=0,e=h.length,b=!0;h&&e>f;f++)if(h[f].apply(l[0],l[1])===!1&&a.stopOnFalse){c=!1;break}b=!1,h&&(i?i.length&&j(i.shift()):c?h=[]:k.disable())},k={add:function(){if(h){var d=h.length;!function f(b){m.each(b,function(b,c){var d=m.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&f(c)})}(arguments),b?e=h.length:c&&(g=d,j(c))}return this},remove:function(){return h&&m.each(arguments,function(a,c){var d;while((d=m.inArray(c,h,d))>-1)h.splice(d,1),b&&(e>=d&&e--,f>=d&&f--)}),this},has:function(a){return a?m.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],e=0,this},disable:function(){return h=i=c=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,c||k.disable(),this},locked:function(){return!i},fireWith:function(a,c){return!h||d&&!i||(c=c||[],c=[a,c.slice?c.slice():c],b?i.push(c):j(c)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!d}};return k},m.extend({Deferred:function(a){var b=[["resolve","done",m.Callbacks("once memory"),"resolved"],["reject","fail",m.Callbacks("once memory"),"rejected"],["notify","progress",m.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return m.Deferred(function(c){m.each(b,function(b,f){var g=m.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&m.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?m.extend(a,d):d}},e={};return d.pipe=d.then,m.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&m.isFunction(a.promise)?e:0,g=1===f?a:m.Deferred(),h=function(a,b,c){return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}},i,j,k;if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&m.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;m.fn.ready=function(a){return m.ready.promise().done(a),this},m.extend({isReady:!1,readyWait:1,holdReady:function(a){a?m.readyWait++:m.ready(!0)},ready:function(a){if(a===!0?!--m.readyWait:!m.isReady){if(!y.body)return setTimeout(m.ready);m.isReady=!0,a!==!0&&--m.readyWait>0||(H.resolveWith(y,[m]),m.fn.triggerHandler&&(m(y).triggerHandler("ready"),m(y).off("ready")))}}});function I(){y.addEventListener?(y.removeEventListener("DOMContentLoaded",J,!1),a.removeEventListener("load",J,!1)):(y.detachEvent("onreadystatechange",J),a.detachEvent("onload",J))}function J(){(y.addEventListener||"load"===event.type||"complete"===y.readyState)&&(I(),m.ready())}m.ready.promise=function(b){if(!H)if(H=m.Deferred(),"complete"===y.readyState)setTimeout(m.ready);else if(y.addEventListener)y.addEventListener("DOMContentLoaded",J,!1),a.addEventListener("load",J,!1);else{y.attachEvent("onreadystatechange",J),a.attachEvent("onload",J);var c=!1;try{c=null==a.frameElement&&y.documentElement}catch(d){}c&&c.doScroll&&!function e(){if(!m.isReady){try{c.doScroll("left")}catch(a){return setTimeout(e,50)}I(),m.ready()}}()}return H.promise(b)};var K="undefined",L;for(L in m(k))break;k.ownLast="0"!==L,k.inlineBlockNeedsLayout=!1,m(function(){var a,b,c,d;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1",k.inlineBlockNeedsLayout=a=3===b.offsetWidth,a&&(c.style.zoom=1)),c.removeChild(d))}),function(){var a=y.createElement("div");if(null==k.deleteExpando){k.deleteExpando=!0;try{delete a.test}catch(b){k.deleteExpando=!1}}a=null}(),m.acceptData=function(a){var b=m.noData[(a.nodeName+" ").toLowerCase()],c=+a.nodeType||1;return 1!==c&&9!==c?!1:!b||b!==!0&&a.getAttribute("classid")===b};var M=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,N=/([A-Z])/g;function O(a,b,c){if(void 0===c&&1===a.nodeType){var d="data-"+b.replace(N,"-$1").toLowerCase();if(c=a.getAttribute(d),"string"==typeof c){try{c="true"===c?!0:"false"===c?!1:"null"===c?null:+c+""===c?+c:M.test(c)?m.parseJSON(c):c}catch(e){}m.data(a,b,c)}else c=void 0}return c}function P(a){var b;for(b in a)if(("data"!==b||!m.isEmptyObject(a[b]))&&"toJSON"!==b)return!1; - -return!0}function Q(a,b,d,e){if(m.acceptData(a)){var f,g,h=m.expando,i=a.nodeType,j=i?m.cache:a,k=i?a[h]:a[h]&&h;if(k&&j[k]&&(e||j[k].data)||void 0!==d||"string"!=typeof b)return k||(k=i?a[h]=c.pop()||m.guid++:h),j[k]||(j[k]=i?{}:{toJSON:m.noop}),("object"==typeof b||"function"==typeof b)&&(e?j[k]=m.extend(j[k],b):j[k].data=m.extend(j[k].data,b)),g=j[k],e||(g.data||(g.data={}),g=g.data),void 0!==d&&(g[m.camelCase(b)]=d),"string"==typeof b?(f=g[b],null==f&&(f=g[m.camelCase(b)])):f=g,f}}function R(a,b,c){if(m.acceptData(a)){var d,e,f=a.nodeType,g=f?m.cache:a,h=f?a[m.expando]:m.expando;if(g[h]){if(b&&(d=c?g[h]:g[h].data)){m.isArray(b)?b=b.concat(m.map(b,m.camelCase)):b in d?b=[b]:(b=m.camelCase(b),b=b in d?[b]:b.split(" ")),e=b.length;while(e--)delete d[b[e]];if(c?!P(d):!m.isEmptyObject(d))return}(c||(delete g[h].data,P(g[h])))&&(f?m.cleanData([a],!0):k.deleteExpando||g!=g.window?delete g[h]:g[h]=null)}}}m.extend({cache:{},noData:{"applet ":!0,"embed ":!0,"object ":"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"},hasData:function(a){return a=a.nodeType?m.cache[a[m.expando]]:a[m.expando],!!a&&!P(a)},data:function(a,b,c){return Q(a,b,c)},removeData:function(a,b){return R(a,b)},_data:function(a,b,c){return Q(a,b,c,!0)},_removeData:function(a,b){return R(a,b,!0)}}),m.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=m.data(f),1===f.nodeType&&!m._data(f,"parsedAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=m.camelCase(d.slice(5)),O(f,d,e[d])));m._data(f,"parsedAttrs",!0)}return e}return"object"==typeof a?this.each(function(){m.data(this,a)}):arguments.length>1?this.each(function(){m.data(this,a,b)}):f?O(f,a,m.data(f,a)):void 0},removeData:function(a){return this.each(function(){m.removeData(this,a)})}}),m.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=m._data(a,b),c&&(!d||m.isArray(c)?d=m._data(a,b,m.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=m.queue(a,b),d=c.length,e=c.shift(),f=m._queueHooks(a,b),g=function(){m.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return m._data(a,c)||m._data(a,c,{empty:m.Callbacks("once memory").add(function(){m._removeData(a,b+"queue"),m._removeData(a,c)})})}}),m.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?m.queue(this[0],a):void 0===b?this:this.each(function(){var c=m.queue(this,a,b);m._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&m.dequeue(this,a)})},dequeue:function(a){return this.each(function(){m.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=m.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};"string"!=typeof a&&(b=a,a=void 0),a=a||"fx";while(g--)c=m._data(f[g],a+"queueHooks"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var S=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,T=["Top","Right","Bottom","Left"],U=function(a,b){return a=b||a,"none"===m.css(a,"display")||!m.contains(a.ownerDocument,a)},V=m.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===m.type(c)){e=!0;for(h in c)m.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,m.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(m(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f},W=/^(?:checkbox|radio)$/i;!function(){var a=y.createElement("input"),b=y.createElement("div"),c=y.createDocumentFragment();if(b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",k.leadingWhitespace=3===b.firstChild.nodeType,k.tbody=!b.getElementsByTagName("tbody").length,k.htmlSerialize=!!b.getElementsByTagName("link").length,k.html5Clone="<:nav></:nav>"!==y.createElement("nav").cloneNode(!0).outerHTML,a.type="checkbox",a.checked=!0,c.appendChild(a),k.appendChecked=a.checked,b.innerHTML="<textarea>x</textarea>",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue,c.appendChild(b),b.innerHTML="<input type='radio' checked='checked' name='t'/>",k.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,k.noCloneEvent=!0,b.attachEvent&&(b.attachEvent("onclick",function(){k.noCloneEvent=!1}),b.cloneNode(!0).click()),null==k.deleteExpando){k.deleteExpando=!0;try{delete b.test}catch(d){k.deleteExpando=!1}}}(),function(){var b,c,d=y.createElement("div");for(b in{submit:!0,change:!0,focusin:!0})c="on"+b,(k[b+"Bubbles"]=c in a)||(d.setAttribute(c,"t"),k[b+"Bubbles"]=d.attributes[c].expando===!1);d=null}();var X=/^(?:input|select|textarea)$/i,Y=/^key/,Z=/^(?:mouse|pointer|contextmenu)|click/,$=/^(?:focusinfocus|focusoutblur)$/,_=/^([^.]*)(?:\.(.+)|)$/;function aa(){return!0}function ba(){return!1}function ca(){try{return y.activeElement}catch(a){}}m.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m._data(a);if(r){c.handler&&(i=c,c=i.handler,e=i.selector),c.guid||(c.guid=m.guid++),(g=r.events)||(g=r.events={}),(k=r.handle)||(k=r.handle=function(a){return typeof m===K||a&&m.event.triggered===a.type?void 0:m.event.dispatch.apply(k.elem,arguments)},k.elem=a),b=(b||"").match(E)||[""],h=b.length;while(h--)f=_.exec(b[h])||[],o=q=f[1],p=(f[2]||"").split(".").sort(),o&&(j=m.event.special[o]||{},o=(e?j.delegateType:j.bindType)||o,j=m.event.special[o]||{},l=m.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&m.expr.match.needsContext.test(e),namespace:p.join(".")},i),(n=g[o])||(n=g[o]=[],n.delegateCount=0,j.setup&&j.setup.call(a,d,p,k)!==!1||(a.addEventListener?a.addEventListener(o,k,!1):a.attachEvent&&a.attachEvent("on"+o,k))),j.add&&(j.add.call(a,l),l.handler.guid||(l.handler.guid=c.guid)),e?n.splice(n.delegateCount++,0,l):n.push(l),m.event.global[o]=!0);a=null}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m.hasData(a)&&m._data(a);if(r&&(k=r.events)){b=(b||"").match(E)||[""],j=b.length;while(j--)if(h=_.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){l=m.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,n=k[o]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),i=f=n.length;while(f--)g=n[f],!e&&q!==g.origType||c&&c.guid!==g.guid||h&&!h.test(g.namespace)||d&&d!==g.selector&&("**"!==d||!g.selector)||(n.splice(f,1),g.selector&&n.delegateCount--,l.remove&&l.remove.call(a,g));i&&!n.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||m.removeEvent(a,o,r.handle),delete k[o])}else for(o in k)m.event.remove(a,o+b[j],c,d,!0);m.isEmptyObject(k)&&(delete r.handle,m._removeData(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,l,n,o=[d||y],p=j.call(b,"type")?b.type:b,q=j.call(b,"namespace")?b.namespace.split("."):[];if(h=l=d=d||y,3!==d.nodeType&&8!==d.nodeType&&!$.test(p+m.event.triggered)&&(p.indexOf(".")>=0&&(q=p.split("."),p=q.shift(),q.sort()),g=p.indexOf(":")<0&&"on"+p,b=b[m.expando]?b:new m.Event(p,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=q.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\.)"+q.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:m.makeArray(c,[b]),k=m.event.special[p]||{},e||!k.trigger||k.trigger.apply(d,c)!==!1)){if(!e&&!k.noBubble&&!m.isWindow(d)){for(i=k.delegateType||p,$.test(i+p)||(h=h.parentNode);h;h=h.parentNode)o.push(h),l=h;l===(d.ownerDocument||y)&&o.push(l.defaultView||l.parentWindow||a)}n=0;while((h=o[n++])&&!b.isPropagationStopped())b.type=n>1?i:k.bindType||p,f=(m._data(h,"events")||{})[b.type]&&m._data(h,"handle"),f&&f.apply(h,c),f=g&&h[g],f&&f.apply&&m.acceptData(h)&&(b.result=f.apply(h,c),b.result===!1&&b.preventDefault());if(b.type=p,!e&&!b.isDefaultPrevented()&&(!k._default||k._default.apply(o.pop(),c)===!1)&&m.acceptData(d)&&g&&d[p]&&!m.isWindow(d)){l=d[g],l&&(d[g]=null),m.event.triggered=p;try{d[p]()}catch(r){}m.event.triggered=void 0,l&&(d[g]=l)}return b.result}},dispatch:function(a){a=m.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(m._data(this,"events")||{})[a.type]||[],k=m.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){h=m.event.handlers.call(this,a,j),b=0;while((f=h[b++])&&!a.isPropagationStopped()){a.currentTarget=f.elem,g=0;while((e=f.handlers[g++])&&!a.isImmediatePropagationStopped())(!a.namespace_re||a.namespace_re.test(e.namespace))&&(a.handleObj=e,a.data=e.data,c=((m.event.special[e.origType]||{}).handle||e.handler).apply(f.elem,i),void 0!==c&&(a.result=c)===!1&&(a.preventDefault(),a.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!=this;i=i.parentNode||this)if(1===i.nodeType&&(i.disabled!==!0||"click"!==a.type)){for(e=[],f=0;h>f;f++)d=b[f],c=d.selector+" ",void 0===e[c]&&(e[c]=d.needsContext?m(c,this).index(i)>=0:m.find(c,this,null,[i]).length),e[c]&&e.push(d);e.length&&g.push({elem:i,handlers:e})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},fix:function(a){if(a[m.expando])return a;var b,c,d,e=a.type,f=a,g=this.fixHooks[e];g||(this.fixHooks[e]=g=Z.test(e)?this.mouseHooks:Y.test(e)?this.keyHooks:{}),d=g.props?this.props.concat(g.props):this.props,a=new m.Event(f),b=d.length;while(b--)c=d[b],a[c]=f[c];return a.target||(a.target=f.srcElement||y),3===a.target.nodeType&&(a.target=a.target.parentNode),a.metaKey=!!a.metaKey,g.filter?g.filter(a,f):a},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(a,b){return null==a.which&&(a.which=null!=b.charCode?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,b){var c,d,e,f=b.button,g=b.fromElement;return null==a.pageX&&null!=b.clientX&&(d=a.target.ownerDocument||y,e=d.documentElement,c=d.body,a.pageX=b.clientX+(e&&e.scrollLeft||c&&c.scrollLeft||0)-(e&&e.clientLeft||c&&c.clientLeft||0),a.pageY=b.clientY+(e&&e.scrollTop||c&&c.scrollTop||0)-(e&&e.clientTop||c&&c.clientTop||0)),!a.relatedTarget&&g&&(a.relatedTarget=g===a.target?b.toElement:g),a.which||void 0===f||(a.which=1&f?1:2&f?3:4&f?2:0),a}},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==ca()&&this.focus)try{return this.focus(),!1}catch(a){}},delegateType:"focusin"},blur:{trigger:function(){return this===ca()&&this.blur?(this.blur(),!1):void 0},delegateType:"focusout"},click:{trigger:function(){return m.nodeName(this,"input")&&"checkbox"===this.type&&this.click?(this.click(),!1):void 0},_default:function(a){return m.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}},simulate:function(a,b,c,d){var e=m.extend(new m.Event,c,{type:a,isSimulated:!0,originalEvent:{}});d?m.event.trigger(e,null,b):m.event.dispatch.call(b,e),e.isDefaultPrevented()&&c.preventDefault()}},m.removeEvent=y.removeEventListener?function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)}:function(a,b,c){var d="on"+b;a.detachEvent&&(typeof a[d]===K&&(a[d]=null),a.detachEvent(d,c))},m.Event=function(a,b){return this instanceof m.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?aa:ba):this.type=a,b&&m.extend(this,b),this.timeStamp=a&&a.timeStamp||m.now(),void(this[m.expando]=!0)):new m.Event(a,b)},m.Event.prototype={isDefaultPrevented:ba,isPropagationStopped:ba,isImmediatePropagationStopped:ba,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=aa,a&&(a.preventDefault?a.preventDefault():a.returnValue=!1)},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=aa,a&&(a.stopPropagation&&a.stopPropagation(),a.cancelBubble=!0)},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=aa,a&&a.stopImmediatePropagation&&a.stopImmediatePropagation(),this.stopPropagation()}},m.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){m.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return(!e||e!==d&&!m.contains(d,e))&&(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),k.submitBubbles||(m.event.special.submit={setup:function(){return m.nodeName(this,"form")?!1:void m.event.add(this,"click._submit keypress._submit",function(a){var b=a.target,c=m.nodeName(b,"input")||m.nodeName(b,"button")?b.form:void 0;c&&!m._data(c,"submitBubbles")&&(m.event.add(c,"submit._submit",function(a){a._submit_bubble=!0}),m._data(c,"submitBubbles",!0))})},postDispatch:function(a){a._submit_bubble&&(delete a._submit_bubble,this.parentNode&&!a.isTrigger&&m.event.simulate("submit",this.parentNode,a,!0))},teardown:function(){return m.nodeName(this,"form")?!1:void m.event.remove(this,"._submit")}}),k.changeBubbles||(m.event.special.change={setup:function(){return X.test(this.nodeName)?(("checkbox"===this.type||"radio"===this.type)&&(m.event.add(this,"propertychange._change",function(a){"checked"===a.originalEvent.propertyName&&(this._just_changed=!0)}),m.event.add(this,"click._change",function(a){this._just_changed&&!a.isTrigger&&(this._just_changed=!1),m.event.simulate("change",this,a,!0)})),!1):void m.event.add(this,"beforeactivate._change",function(a){var b=a.target;X.test(b.nodeName)&&!m._data(b,"changeBubbles")&&(m.event.add(b,"change._change",function(a){!this.parentNode||a.isSimulated||a.isTrigger||m.event.simulate("change",this.parentNode,a,!0)}),m._data(b,"changeBubbles",!0))})},handle:function(a){var b=a.target;return this!==b||a.isSimulated||a.isTrigger||"radio"!==b.type&&"checkbox"!==b.type?a.handleObj.handler.apply(this,arguments):void 0},teardown:function(){return m.event.remove(this,"._change"),!X.test(this.nodeName)}}),k.focusinBubbles||m.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){m.event.simulate(b,a.target,m.event.fix(a),!0)};m.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=m._data(d,b);e||d.addEventListener(a,c,!0),m._data(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=m._data(d,b)-1;e?m._data(d,b,e):(d.removeEventListener(a,c,!0),m._removeData(d,b))}}}),m.fn.extend({on:function(a,b,c,d,e){var f,g;if("object"==typeof a){"string"!=typeof b&&(c=c||b,b=void 0);for(f in a)this.on(f,b,c,a[f],e);return this}if(null==c&&null==d?(d=b,c=b=void 0):null==d&&("string"==typeof b?(d=c,c=void 0):(d=c,c=b,b=void 0)),d===!1)d=ba;else if(!d)return this;return 1===e&&(g=d,d=function(a){return m().off(a),g.apply(this,arguments)},d.guid=g.guid||(g.guid=m.guid++)),this.each(function(){m.event.add(this,a,d,c,b)})},one:function(a,b,c,d){return this.on(a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,m(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return(b===!1||"function"==typeof b)&&(c=b,b=void 0),c===!1&&(c=ba),this.each(function(){m.event.remove(this,a,c,b)})},trigger:function(a,b){return this.each(function(){m.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];return c?m.event.trigger(a,b,c,!0):void 0}});function da(a){var b=ea.split("|"),c=a.createDocumentFragment();if(c.createElement)while(b.length)c.createElement(b.pop());return c}var ea="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",fa=/ jQuery\d+="(?:null|\d+)"/g,ga=new RegExp("<(?:"+ea+")[\\s/>]","i"),ha=/^\s+/,ia=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,ja=/<([\w:]+)/,ka=/<tbody/i,la=/<|&#?\w+;/,ma=/<(?:script|style|link)/i,na=/checked\s*(?:[^=]|=\s*.checked.)/i,oa=/^$|\/(?:java|ecma)script/i,pa=/^true\/(.*)/,qa=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,ra={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],area:[1,"<map>","</map>"],param:[1,"<object>","</object>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:k.htmlSerialize?[0,"",""]:[1,"X<div>","</div>"]},sa=da(y),ta=sa.appendChild(y.createElement("div"));ra.optgroup=ra.option,ra.tbody=ra.tfoot=ra.colgroup=ra.caption=ra.thead,ra.th=ra.td;function ua(a,b){var c,d,e=0,f=typeof a.getElementsByTagName!==K?a.getElementsByTagName(b||"*"):typeof a.querySelectorAll!==K?a.querySelectorAll(b||"*"):void 0;if(!f)for(f=[],c=a.childNodes||a;null!=(d=c[e]);e++)!b||m.nodeName(d,b)?f.push(d):m.merge(f,ua(d,b));return void 0===b||b&&m.nodeName(a,b)?m.merge([a],f):f}function va(a){W.test(a.type)&&(a.defaultChecked=a.checked)}function wa(a,b){return m.nodeName(a,"table")&&m.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function xa(a){return a.type=(null!==m.find.attr(a,"type"))+"/"+a.type,a}function ya(a){var b=pa.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function za(a,b){for(var c,d=0;null!=(c=a[d]);d++)m._data(c,"globalEval",!b||m._data(b[d],"globalEval"))}function Aa(a,b){if(1===b.nodeType&&m.hasData(a)){var c,d,e,f=m._data(a),g=m._data(b,f),h=f.events;if(h){delete g.handle,g.events={};for(c in h)for(d=0,e=h[c].length;e>d;d++)m.event.add(b,c,h[c][d])}g.data&&(g.data=m.extend({},g.data))}}function Ba(a,b){var c,d,e;if(1===b.nodeType){if(c=b.nodeName.toLowerCase(),!k.noCloneEvent&&b[m.expando]){e=m._data(b);for(d in e.events)m.removeEvent(b,d,e.handle);b.removeAttribute(m.expando)}"script"===c&&b.text!==a.text?(xa(b).text=a.text,ya(b)):"object"===c?(b.parentNode&&(b.outerHTML=a.outerHTML),k.html5Clone&&a.innerHTML&&!m.trim(b.innerHTML)&&(b.innerHTML=a.innerHTML)):"input"===c&&W.test(a.type)?(b.defaultChecked=b.checked=a.checked,b.value!==a.value&&(b.value=a.value)):"option"===c?b.defaultSelected=b.selected=a.defaultSelected:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}}m.extend({clone:function(a,b,c){var d,e,f,g,h,i=m.contains(a.ownerDocument,a);if(k.html5Clone||m.isXMLDoc(a)||!ga.test("<"+a.nodeName+">")?f=a.cloneNode(!0):(ta.innerHTML=a.outerHTML,ta.removeChild(f=ta.firstChild)),!(k.noCloneEvent&&k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||m.isXMLDoc(a)))for(d=ua(f),h=ua(a),g=0;null!=(e=h[g]);++g)d[g]&&Ba(e,d[g]);if(b)if(c)for(h=h||ua(a),d=d||ua(f),g=0;null!=(e=h[g]);g++)Aa(e,d[g]);else Aa(a,f);return d=ua(f,"script"),d.length>0&&za(d,!i&&ua(a,"script")),d=h=e=null,f},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,l,n=a.length,o=da(b),p=[],q=0;n>q;q++)if(f=a[q],f||0===f)if("object"===m.type(f))m.merge(p,f.nodeType?[f]:f);else if(la.test(f)){h=h||o.appendChild(b.createElement("div")),i=(ja.exec(f)||["",""])[1].toLowerCase(),l=ra[i]||ra._default,h.innerHTML=l[1]+f.replace(ia,"<$1></$2>")+l[2],e=l[0];while(e--)h=h.lastChild;if(!k.leadingWhitespace&&ha.test(f)&&p.push(b.createTextNode(ha.exec(f)[0])),!k.tbody){f="table"!==i||ka.test(f)?"<table>"!==l[1]||ka.test(f)?0:h:h.firstChild,e=f&&f.childNodes.length;while(e--)m.nodeName(j=f.childNodes[e],"tbody")&&!j.childNodes.length&&f.removeChild(j)}m.merge(p,h.childNodes),h.textContent="";while(h.firstChild)h.removeChild(h.firstChild);h=o.lastChild}else p.push(b.createTextNode(f));h&&o.removeChild(h),k.appendChecked||m.grep(ua(p,"input"),va),q=0;while(f=p[q++])if((!d||-1===m.inArray(f,d))&&(g=m.contains(f.ownerDocument,f),h=ua(o.appendChild(f),"script"),g&&za(h),c)){e=0;while(f=h[e++])oa.test(f.type||"")&&c.push(f)}return h=null,o},cleanData:function(a,b){for(var d,e,f,g,h=0,i=m.expando,j=m.cache,l=k.deleteExpando,n=m.event.special;null!=(d=a[h]);h++)if((b||m.acceptData(d))&&(f=d[i],g=f&&j[f])){if(g.events)for(e in g.events)n[e]?m.event.remove(d,e):m.removeEvent(d,e,g.handle);j[f]&&(delete j[f],l?delete d[i]:typeof d.removeAttribute!==K?d.removeAttribute(i):d[i]=null,c.push(f))}}}),m.fn.extend({text:function(a){return V(this,function(a){return void 0===a?m.text(this):this.empty().append((this[0]&&this[0].ownerDocument||y).createTextNode(a))},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wa(this,a);b.appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wa(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?m.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||m.cleanData(ua(c)),c.parentNode&&(b&&m.contains(c.ownerDocument,c)&&za(ua(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++){1===a.nodeType&&m.cleanData(ua(a,!1));while(a.firstChild)a.removeChild(a.firstChild);a.options&&m.nodeName(a,"select")&&(a.options.length=0)}return this},clone:function(a,b){return a=null==a?!1:a,b=null==b?a:b,this.map(function(){return m.clone(this,a,b)})},html:function(a){return V(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a)return 1===b.nodeType?b.innerHTML.replace(fa,""):void 0;if(!("string"!=typeof a||ma.test(a)||!k.htmlSerialize&&ga.test(a)||!k.leadingWhitespace&&ha.test(a)||ra[(ja.exec(a)||["",""])[1].toLowerCase()])){a=a.replace(ia,"<$1></$2>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(m.cleanData(ua(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];return this.domManip(arguments,function(b){a=this.parentNode,m.cleanData(ua(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,l=this.length,n=this,o=l-1,p=a[0],q=m.isFunction(p);if(q||l>1&&"string"==typeof p&&!k.checkClone&&na.test(p))return this.each(function(c){var d=n.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(l&&(i=m.buildFragment(a,this[0].ownerDocument,!1,this),c=i.firstChild,1===i.childNodes.length&&(i=c),c)){for(g=m.map(ua(i,"script"),xa),f=g.length;l>j;j++)d=i,j!==o&&(d=m.clone(d,!0,!0),f&&m.merge(g,ua(d,"script"))),b.call(this[j],d,j);if(f)for(h=g[g.length-1].ownerDocument,m.map(g,ya),j=0;f>j;j++)d=g[j],oa.test(d.type||"")&&!m._data(d,"globalEval")&&m.contains(h,d)&&(d.src?m._evalUrl&&m._evalUrl(d.src):m.globalEval((d.text||d.textContent||d.innerHTML||"").replace(qa,"")));i=c=null}return this}}),m.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){m.fn[a]=function(a){for(var c,d=0,e=[],g=m(a),h=g.length-1;h>=d;d++)c=d===h?this:this.clone(!0),m(g[d])[b](c),f.apply(e,c.get());return this.pushStack(e)}});var Ca,Da={};function Ea(b,c){var d,e=m(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:m.css(e[0],"display");return e.detach(),f}function Fa(a){var b=y,c=Da[a];return c||(c=Ea(a,b),"none"!==c&&c||(Ca=(Ca||m("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement),b=(Ca[0].contentWindow||Ca[0].contentDocument).document,b.write(),b.close(),c=Ea(a,b),Ca.detach()),Da[a]=c),c}!function(){var a;k.shrinkWrapBlocks=function(){if(null!=a)return a;a=!1;var b,c,d;return c=y.getElementsByTagName("body")[0],c&&c.style?(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:1px;width:1px;zoom:1",b.appendChild(y.createElement("div")).style.width="5px",a=3!==b.offsetWidth),c.removeChild(d),a):void 0}}();var Ga=/^margin/,Ha=new RegExp("^("+S+")(?!px)[a-z%]+$","i"),Ia,Ja,Ka=/^(top|right|bottom|left)$/;a.getComputedStyle?(Ia=function(b){return b.ownerDocument.defaultView.opener?b.ownerDocument.defaultView.getComputedStyle(b,null):a.getComputedStyle(b,null)},Ja=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ia(a),g=c?c.getPropertyValue(b)||c[b]:void 0,c&&(""!==g||m.contains(a.ownerDocument,a)||(g=m.style(a,b)),Ha.test(g)&&Ga.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0===g?g:g+""}):y.documentElement.currentStyle&&(Ia=function(a){return a.currentStyle},Ja=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ia(a),g=c?c[b]:void 0,null==g&&h&&h[b]&&(g=h[b]),Ha.test(g)&&!Ka.test(b)&&(d=h.left,e=a.runtimeStyle,f=e&&e.left,f&&(e.left=a.currentStyle.left),h.left="fontSize"===b?"1em":g,g=h.pixelLeft+"px",h.left=d,f&&(e.left=f)),void 0===g?g:g+""||"auto"});function La(a,b){return{get:function(){var c=a();if(null!=c)return c?void delete this.get:(this.get=b).apply(this,arguments)}}}!function(){var b,c,d,e,f,g,h;if(b=y.createElement("div"),b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",d=b.getElementsByTagName("a")[0],c=d&&d.style){c.cssText="float:left;opacity:.5",k.opacity="0.5"===c.opacity,k.cssFloat=!!c.cssFloat,b.style.backgroundClip="content-box",b.cloneNode(!0).style.backgroundClip="",k.clearCloneStyle="content-box"===b.style.backgroundClip,k.boxSizing=""===c.boxSizing||""===c.MozBoxSizing||""===c.WebkitBoxSizing,m.extend(k,{reliableHiddenOffsets:function(){return null==g&&i(),g},boxSizingReliable:function(){return null==f&&i(),f},pixelPosition:function(){return null==e&&i(),e},reliableMarginRight:function(){return null==h&&i(),h}});function i(){var b,c,d,i;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),b.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:block;margin-top:1%;top:1%;border:1px;padding:1px;width:4px;position:absolute",e=f=!1,h=!0,a.getComputedStyle&&(e="1%"!==(a.getComputedStyle(b,null)||{}).top,f="4px"===(a.getComputedStyle(b,null)||{width:"4px"}).width,i=b.appendChild(y.createElement("div")),i.style.cssText=b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",i.style.marginRight=i.style.width="0",b.style.width="1px",h=!parseFloat((a.getComputedStyle(i,null)||{}).marginRight),b.removeChild(i)),b.innerHTML="<table><tr><td></td><td>t</td></tr></table>",i=b.getElementsByTagName("td"),i[0].style.cssText="margin:0;border:0;padding:0;display:none",g=0===i[0].offsetHeight,g&&(i[0].style.display="",i[1].style.display="none",g=0===i[0].offsetHeight),c.removeChild(d))}}}(),m.swap=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};var Ma=/alpha\([^)]*\)/i,Na=/opacity\s*=\s*([^)]*)/,Oa=/^(none|table(?!-c[ea]).+)/,Pa=new RegExp("^("+S+")(.*)$","i"),Qa=new RegExp("^([+-])=("+S+")","i"),Ra={position:"absolute",visibility:"hidden",display:"block"},Sa={letterSpacing:"0",fontWeight:"400"},Ta=["Webkit","O","Moz","ms"];function Ua(a,b){if(b in a)return b;var c=b.charAt(0).toUpperCase()+b.slice(1),d=b,e=Ta.length;while(e--)if(b=Ta[e]+c,b in a)return b;return d}function Va(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=m._data(d,"olddisplay"),c=d.style.display,b?(f[g]||"none"!==c||(d.style.display=""),""===d.style.display&&U(d)&&(f[g]=m._data(d,"olddisplay",Fa(d.nodeName)))):(e=U(d),(c&&"none"!==c||!e)&&m._data(d,"olddisplay",e?c:m.css(d,"display"))));for(g=0;h>g;g++)d=a[g],d.style&&(b&&"none"!==d.style.display&&""!==d.style.display||(d.style.display=b?f[g]||"":"none"));return a}function Wa(a,b,c){var d=Pa.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||"px"):b}function Xa(a,b,c,d,e){for(var f=c===(d?"border":"content")?4:"width"===b?1:0,g=0;4>f;f+=2)"margin"===c&&(g+=m.css(a,c+T[f],!0,e)),d?("content"===c&&(g-=m.css(a,"padding"+T[f],!0,e)),"margin"!==c&&(g-=m.css(a,"border"+T[f]+"Width",!0,e))):(g+=m.css(a,"padding"+T[f],!0,e),"padding"!==c&&(g+=m.css(a,"border"+T[f]+"Width",!0,e)));return g}function Ya(a,b,c){var d=!0,e="width"===b?a.offsetWidth:a.offsetHeight,f=Ia(a),g=k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,f);if(0>=e||null==e){if(e=Ja(a,b,f),(0>e||null==e)&&(e=a.style[b]),Ha.test(e))return e;d=g&&(k.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Xa(a,b,c||(g?"border":"content"),d,f)+"px"}m.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=Ja(a,"opacity");return""===c?"1":c}}}},cssNumber:{columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":k.cssFloat?"cssFloat":"styleFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=m.camelCase(b),i=a.style;if(b=m.cssProps[h]||(m.cssProps[h]=Ua(i,h)),g=m.cssHooks[b]||m.cssHooks[h],void 0===c)return g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b];if(f=typeof c,"string"===f&&(e=Qa.exec(c))&&(c=(e[1]+1)*e[2]+parseFloat(m.css(a,b)),f="number"),null!=c&&c===c&&("number"!==f||m.cssNumber[h]||(c+="px"),k.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),!(g&&"set"in g&&void 0===(c=g.set(a,c,d)))))try{i[b]=c}catch(j){}}},css:function(a,b,c,d){var e,f,g,h=m.camelCase(b);return b=m.cssProps[h]||(m.cssProps[h]=Ua(a.style,h)),g=m.cssHooks[b]||m.cssHooks[h],g&&"get"in g&&(f=g.get(a,!0,c)),void 0===f&&(f=Ja(a,b,d)),"normal"===f&&b in Sa&&(f=Sa[b]),""===c||c?(e=parseFloat(f),c===!0||m.isNumeric(e)?e||0:f):f}}),m.each(["height","width"],function(a,b){m.cssHooks[b]={get:function(a,c,d){return c?Oa.test(m.css(a,"display"))&&0===a.offsetWidth?m.swap(a,Ra,function(){return Ya(a,b,d)}):Ya(a,b,d):void 0},set:function(a,c,d){var e=d&&Ia(a);return Wa(a,c,d?Xa(a,b,d,k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,e),e):0)}}}),k.opacity||(m.cssHooks.opacity={get:function(a,b){return Na.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=m.isNumeric(b)?"alpha(opacity="+100*b+")":"",f=d&&d.filter||c.filter||"";c.zoom=1,(b>=1||""===b)&&""===m.trim(f.replace(Ma,""))&&c.removeAttribute&&(c.removeAttribute("filter"),""===b||d&&!d.filter)||(c.filter=Ma.test(f)?f.replace(Ma,e):f+" "+e)}}),m.cssHooks.marginRight=La(k.reliableMarginRight,function(a,b){return b?m.swap(a,{display:"inline-block"},Ja,[a,"marginRight"]):void 0}),m.each({margin:"",padding:"",border:"Width"},function(a,b){m.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];4>d;d++)e[a+T[d]+b]=f[d]||f[d-2]||f[0];return e}},Ga.test(a)||(m.cssHooks[a+b].set=Wa)}),m.fn.extend({css:function(a,b){return V(this,function(a,b,c){var d,e,f={},g=0;if(m.isArray(b)){for(d=Ia(a),e=b.length;e>g;g++)f[b[g]]=m.css(a,b[g],!1,d);return f}return void 0!==c?m.style(a,b,c):m.css(a,b)},a,b,arguments.length>1)},show:function(){return Va(this,!0)},hide:function(){return Va(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){U(this)?m(this).show():m(this).hide()})}});function Za(a,b,c,d,e){ -return new Za.prototype.init(a,b,c,d,e)}m.Tween=Za,Za.prototype={constructor:Za,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||"swing",this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(m.cssNumber[c]?"":"px")},cur:function(){var a=Za.propHooks[this.prop];return a&&a.get?a.get(this):Za.propHooks._default.get(this)},run:function(a){var b,c=Za.propHooks[this.prop];return this.options.duration?this.pos=b=m.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):this.pos=b=a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Za.propHooks._default.set(this),this}},Za.prototype.init.prototype=Za.prototype,Za.propHooks={_default:{get:function(a){var b;return null==a.elem[a.prop]||a.elem.style&&null!=a.elem.style[a.prop]?(b=m.css(a.elem,a.prop,""),b&&"auto"!==b?b:0):a.elem[a.prop]},set:function(a){m.fx.step[a.prop]?m.fx.step[a.prop](a):a.elem.style&&(null!=a.elem.style[m.cssProps[a.prop]]||m.cssHooks[a.prop])?m.style(a.elem,a.prop,a.now+a.unit):a.elem[a.prop]=a.now}}},Za.propHooks.scrollTop=Za.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},m.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2}},m.fx=Za.prototype.init,m.fx.step={};var $a,_a,ab=/^(?:toggle|show|hide)$/,bb=new RegExp("^(?:([+-])=|)("+S+")([a-z%]*)$","i"),cb=/queueHooks$/,db=[ib],eb={"*":[function(a,b){var c=this.createTween(a,b),d=c.cur(),e=bb.exec(b),f=e&&e[3]||(m.cssNumber[a]?"":"px"),g=(m.cssNumber[a]||"px"!==f&&+d)&&bb.exec(m.css(c.elem,a)),h=1,i=20;if(g&&g[3]!==f){f=f||g[3],e=e||[],g=+d||1;do h=h||".5",g/=h,m.style(c.elem,a,g+f);while(h!==(h=c.cur()/d)&&1!==h&&--i)}return e&&(g=c.start=+g||+d||0,c.unit=f,c.end=e[1]?g+(e[1]+1)*e[2]:+e[2]),c}]};function fb(){return setTimeout(function(){$a=void 0}),$a=m.now()}function gb(a,b){var c,d={height:a},e=0;for(b=b?1:0;4>e;e+=2-b)c=T[e],d["margin"+c]=d["padding"+c]=a;return b&&(d.opacity=d.width=a),d}function hb(a,b,c){for(var d,e=(eb[b]||[]).concat(eb["*"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function ib(a,b,c){var d,e,f,g,h,i,j,l,n=this,o={},p=a.style,q=a.nodeType&&U(a),r=m._data(a,"fxshow");c.queue||(h=m._queueHooks(a,"fx"),null==h.unqueued&&(h.unqueued=0,i=h.empty.fire,h.empty.fire=function(){h.unqueued||i()}),h.unqueued++,n.always(function(){n.always(function(){h.unqueued--,m.queue(a,"fx").length||h.empty.fire()})})),1===a.nodeType&&("height"in b||"width"in b)&&(c.overflow=[p.overflow,p.overflowX,p.overflowY],j=m.css(a,"display"),l="none"===j?m._data(a,"olddisplay")||Fa(a.nodeName):j,"inline"===l&&"none"===m.css(a,"float")&&(k.inlineBlockNeedsLayout&&"inline"!==Fa(a.nodeName)?p.zoom=1:p.display="inline-block")),c.overflow&&(p.overflow="hidden",k.shrinkWrapBlocks()||n.always(function(){p.overflow=c.overflow[0],p.overflowX=c.overflow[1],p.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],ab.exec(e)){if(delete b[d],f=f||"toggle"===e,e===(q?"hide":"show")){if("show"!==e||!r||void 0===r[d])continue;q=!0}o[d]=r&&r[d]||m.style(a,d)}else j=void 0;if(m.isEmptyObject(o))"inline"===("none"===j?Fa(a.nodeName):j)&&(p.display=j);else{r?"hidden"in r&&(q=r.hidden):r=m._data(a,"fxshow",{}),f&&(r.hidden=!q),q?m(a).show():n.done(function(){m(a).hide()}),n.done(function(){var b;m._removeData(a,"fxshow");for(b in o)m.style(a,b,o[b])});for(d in o)g=hb(q?r[d]:0,d,n),d in r||(r[d]=g.start,q&&(g.end=g.start,g.start="width"===d||"height"===d?1:0))}}function jb(a,b){var c,d,e,f,g;for(c in a)if(d=m.camelCase(c),e=b[d],f=a[c],m.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=m.cssHooks[d],g&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function kb(a,b,c){var d,e,f=0,g=db.length,h=m.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=$a||fb(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;i>g;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),1>f&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:m.extend({},b),opts:m.extend(!0,{specialEasing:{}},c),originalProperties:b,originalOptions:c,startTime:$a||fb(),duration:c.duration,tweens:[],createTween:function(b,c){var d=m.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;d>c;c++)j.tweens[c].run(1);return b?h.resolveWith(a,[j,b]):h.rejectWith(a,[j,b]),this}}),k=j.props;for(jb(k,j.opts.specialEasing);g>f;f++)if(d=db[f].call(j,a,k,j.opts))return d;return m.map(k,hb,j),m.isFunction(j.opts.start)&&j.opts.start.call(a,j),m.fx.timer(m.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}m.Animation=m.extend(kb,{tweener:function(a,b){m.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");for(var c,d=0,e=a.length;e>d;d++)c=a[d],eb[c]=eb[c]||[],eb[c].unshift(b)},prefilter:function(a,b){b?db.unshift(a):db.push(a)}}),m.speed=function(a,b,c){var d=a&&"object"==typeof a?m.extend({},a):{complete:c||!c&&b||m.isFunction(a)&&a,duration:a,easing:c&&b||b&&!m.isFunction(b)&&b};return d.duration=m.fx.off?0:"number"==typeof d.duration?d.duration:d.duration in m.fx.speeds?m.fx.speeds[d.duration]:m.fx.speeds._default,(null==d.queue||d.queue===!0)&&(d.queue="fx"),d.old=d.complete,d.complete=function(){m.isFunction(d.old)&&d.old.call(this),d.queue&&m.dequeue(this,d.queue)},d},m.fn.extend({fadeTo:function(a,b,c,d){return this.filter(U).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=m.isEmptyObject(a),f=m.speed(b,c,d),g=function(){var b=kb(this,m.extend({},a),f);(e||m._data(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=m.timers,g=m._data(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&cb.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));(b||!c)&&m.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=m._data(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=m.timers,g=d?d.length:0;for(c.finish=!0,m.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;g>b;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}),m.each(["toggle","show","hide"],function(a,b){var c=m.fn[b];m.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(gb(b,!0),a,d,e)}}),m.each({slideDown:gb("show"),slideUp:gb("hide"),slideToggle:gb("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){m.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),m.timers=[],m.fx.tick=function(){var a,b=m.timers,c=0;for($a=m.now();c<b.length;c++)a=b[c],a()||b[c]!==a||b.splice(c--,1);b.length||m.fx.stop(),$a=void 0},m.fx.timer=function(a){m.timers.push(a),a()?m.fx.start():m.timers.pop()},m.fx.interval=13,m.fx.start=function(){_a||(_a=setInterval(m.fx.tick,m.fx.interval))},m.fx.stop=function(){clearInterval(_a),_a=null},m.fx.speeds={slow:600,fast:200,_default:400},m.fn.delay=function(a,b){return a=m.fx?m.fx.speeds[a]||a:a,b=b||"fx",this.queue(b,function(b,c){var d=setTimeout(b,a);c.stop=function(){clearTimeout(d)}})},function(){var a,b,c,d,e;b=y.createElement("div"),b.setAttribute("className","t"),b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",d=b.getElementsByTagName("a")[0],c=y.createElement("select"),e=c.appendChild(y.createElement("option")),a=b.getElementsByTagName("input")[0],d.style.cssText="top:1px",k.getSetAttribute="t"!==b.className,k.style=/top/.test(d.getAttribute("style")),k.hrefNormalized="/a"===d.getAttribute("href"),k.checkOn=!!a.value,k.optSelected=e.selected,k.enctype=!!y.createElement("form").enctype,c.disabled=!0,k.optDisabled=!e.disabled,a=y.createElement("input"),a.setAttribute("value",""),k.input=""===a.getAttribute("value"),a.value="t",a.setAttribute("type","radio"),k.radioValue="t"===a.value}();var lb=/\r/g;m.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=m.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,m(this).val()):a,null==e?e="":"number"==typeof e?e+="":m.isArray(e)&&(e=m.map(e,function(a){return null==a?"":a+""})),b=m.valHooks[this.type]||m.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=m.valHooks[e.type]||m.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(lb,""):null==c?"":c)}}}),m.extend({valHooks:{option:{get:function(a){var b=m.find.attr(a,"value");return null!=b?b:m.trim(m.text(a))}},select:{get:function(a){for(var b,c,d=a.options,e=a.selectedIndex,f="select-one"===a.type||0>e,g=f?null:[],h=f?e+1:d.length,i=0>e?h:f?e:0;h>i;i++)if(c=d[i],!(!c.selected&&i!==e||(k.optDisabled?c.disabled:null!==c.getAttribute("disabled"))||c.parentNode.disabled&&m.nodeName(c.parentNode,"optgroup"))){if(b=m(c).val(),f)return b;g.push(b)}return g},set:function(a,b){var c,d,e=a.options,f=m.makeArray(b),g=e.length;while(g--)if(d=e[g],m.inArray(m.valHooks.option.get(d),f)>=0)try{d.selected=c=!0}catch(h){d.scrollHeight}else d.selected=!1;return c||(a.selectedIndex=-1),e}}}}),m.each(["radio","checkbox"],function(){m.valHooks[this]={set:function(a,b){return m.isArray(b)?a.checked=m.inArray(m(a).val(),b)>=0:void 0}},k.checkOn||(m.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var mb,nb,ob=m.expr.attrHandle,pb=/^(?:checked|selected)$/i,qb=k.getSetAttribute,rb=k.input;m.fn.extend({attr:function(a,b){return V(this,m.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){m.removeAttr(this,a)})}}),m.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(a&&3!==f&&8!==f&&2!==f)return typeof a.getAttribute===K?m.prop(a,b,c):(1===f&&m.isXMLDoc(a)||(b=b.toLowerCase(),d=m.attrHooks[b]||(m.expr.match.bool.test(b)?nb:mb)),void 0===c?d&&"get"in d&&null!==(e=d.get(a,b))?e:(e=m.find.attr(a,b),null==e?void 0:e):null!==c?d&&"set"in d&&void 0!==(e=d.set(a,c,b))?e:(a.setAttribute(b,c+""),c):void m.removeAttr(a,b))},removeAttr:function(a,b){var c,d,e=0,f=b&&b.match(E);if(f&&1===a.nodeType)while(c=f[e++])d=m.propFix[c]||c,m.expr.match.bool.test(c)?rb&&qb||!pb.test(c)?a[d]=!1:a[m.camelCase("default-"+c)]=a[d]=!1:m.attr(a,c,""),a.removeAttribute(qb?c:d)},attrHooks:{type:{set:function(a,b){if(!k.radioValue&&"radio"===b&&m.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}}}),nb={set:function(a,b,c){return b===!1?m.removeAttr(a,c):rb&&qb||!pb.test(c)?a.setAttribute(!qb&&m.propFix[c]||c,c):a[m.camelCase("default-"+c)]=a[c]=!0,c}},m.each(m.expr.match.bool.source.match(/\w+/g),function(a,b){var c=ob[b]||m.find.attr;ob[b]=rb&&qb||!pb.test(b)?function(a,b,d){var e,f;return d||(f=ob[b],ob[b]=e,e=null!=c(a,b,d)?b.toLowerCase():null,ob[b]=f),e}:function(a,b,c){return c?void 0:a[m.camelCase("default-"+b)]?b.toLowerCase():null}}),rb&&qb||(m.attrHooks.value={set:function(a,b,c){return m.nodeName(a,"input")?void(a.defaultValue=b):mb&&mb.set(a,b,c)}}),qb||(mb={set:function(a,b,c){var d=a.getAttributeNode(c);return d||a.setAttributeNode(d=a.ownerDocument.createAttribute(c)),d.value=b+="","value"===c||b===a.getAttribute(c)?b:void 0}},ob.id=ob.name=ob.coords=function(a,b,c){var d;return c?void 0:(d=a.getAttributeNode(b))&&""!==d.value?d.value:null},m.valHooks.button={get:function(a,b){var c=a.getAttributeNode(b);return c&&c.specified?c.value:void 0},set:mb.set},m.attrHooks.contenteditable={set:function(a,b,c){mb.set(a,""===b?!1:b,c)}},m.each(["width","height"],function(a,b){m.attrHooks[b]={set:function(a,c){return""===c?(a.setAttribute(b,"auto"),c):void 0}}})),k.style||(m.attrHooks.style={get:function(a){return a.style.cssText||void 0},set:function(a,b){return a.style.cssText=b+""}});var sb=/^(?:input|select|textarea|button|object)$/i,tb=/^(?:a|area)$/i;m.fn.extend({prop:function(a,b){return V(this,m.prop,a,b,arguments.length>1)},removeProp:function(a){return a=m.propFix[a]||a,this.each(function(){try{this[a]=void 0,delete this[a]}catch(b){}})}}),m.extend({propFix:{"for":"htmlFor","class":"className"},prop:function(a,b,c){var d,e,f,g=a.nodeType;if(a&&3!==g&&8!==g&&2!==g)return f=1!==g||!m.isXMLDoc(a),f&&(b=m.propFix[b]||b,e=m.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=m.find.attr(a,"tabindex");return b?parseInt(b,10):sb.test(a.nodeName)||tb.test(a.nodeName)&&a.href?0:-1}}}}),k.hrefNormalized||m.each(["href","src"],function(a,b){m.propHooks[b]={get:function(a){return a.getAttribute(b,4)}}}),k.optSelected||(m.propHooks.selected={get:function(a){var b=a.parentNode;return b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex),null}}),m.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){m.propFix[this.toLowerCase()]=this}),k.enctype||(m.propFix.enctype="encoding");var ub=/[\t\r\n\f]/g;m.fn.extend({addClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j="string"==typeof a&&a;if(m.isFunction(a))return this.each(function(b){m(this).addClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(ub," "):" ")){f=0;while(e=b[f++])d.indexOf(" "+e+" ")<0&&(d+=e+" ");g=m.trim(d),c.className!==g&&(c.className=g)}return this},removeClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j=0===arguments.length||"string"==typeof a&&a;if(m.isFunction(a))return this.each(function(b){m(this).removeClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(ub," "):"")){f=0;while(e=b[f++])while(d.indexOf(" "+e+" ")>=0)d=d.replace(" "+e+" "," ");g=a?m.trim(d):"",c.className!==g&&(c.className=g)}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):this.each(m.isFunction(a)?function(c){m(this).toggleClass(a.call(this,c,this.className,b),b)}:function(){if("string"===c){var b,d=0,e=m(this),f=a.match(E)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else(c===K||"boolean"===c)&&(this.className&&m._data(this,"__className__",this.className),this.className=this.className||a===!1?"":m._data(this,"__className__")||"")})},hasClass:function(a){for(var b=" "+a+" ",c=0,d=this.length;d>c;c++)if(1===this[c].nodeType&&(" "+this[c].className+" ").replace(ub," ").indexOf(b)>=0)return!0;return!1}}),m.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(a,b){m.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),m.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)},bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)}});var vb=m.now(),wb=/\?/,xb=/(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g;m.parseJSON=function(b){if(a.JSON&&a.JSON.parse)return a.JSON.parse(b+"");var c,d=null,e=m.trim(b+"");return e&&!m.trim(e.replace(xb,function(a,b,e,f){return c&&b&&(d=0),0===d?a:(c=e||b,d+=!f-!e,"")}))?Function("return "+e)():m.error("Invalid JSON: "+b)},m.parseXML=function(b){var c,d;if(!b||"string"!=typeof b)return null;try{a.DOMParser?(d=new DOMParser,c=d.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b))}catch(e){c=void 0}return c&&c.documentElement&&!c.getElementsByTagName("parsererror").length||m.error("Invalid XML: "+b),c};var yb,zb,Ab=/#.*$/,Bb=/([?&])_=[^&]*/,Cb=/^(.*?):[ \t]*([^\r\n]*)\r?$/gm,Db=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Eb=/^(?:GET|HEAD)$/,Fb=/^\/\//,Gb=/^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,Hb={},Ib={},Jb="*/".concat("*");try{zb=location.href}catch(Kb){zb=y.createElement("a"),zb.href="",zb=zb.href}yb=Gb.exec(zb.toLowerCase())||[];function Lb(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(E)||[];if(m.isFunction(c))while(d=f[e++])"+"===d.charAt(0)?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function Mb(a,b,c,d){var e={},f=a===Ib;function g(h){var i;return e[h]=!0,m.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function Nb(a,b){var c,d,e=m.ajaxSettings.flatOptions||{};for(d in b)void 0!==b[d]&&((e[d]?a:c||(c={}))[d]=b[d]);return c&&m.extend(!0,a,c),a}function Ob(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===e&&(e=a.mimeType||b.getResponseHeader("Content-Type"));if(e)for(g in h)if(h[g]&&h[g].test(e)){i.unshift(g);break}if(i[0]in c)f=i[0];else{for(g in c){if(!i[0]||a.converters[g+" "+i[0]]){f=g;break}d||(d=g)}f=f||d}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function Pb(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}m.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:zb,type:"GET",isLocal:Db.test(yb[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Jb,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":m.parseJSON,"text xml":m.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?Nb(Nb(a,m.ajaxSettings),b):Nb(m.ajaxSettings,a)},ajaxPrefilter:Lb(Hb),ajaxTransport:Lb(Ib),ajax:function(a,b){"object"==typeof a&&(b=a,a=void 0),b=b||{};var c,d,e,f,g,h,i,j,k=m.ajaxSetup({},b),l=k.context||k,n=k.context&&(l.nodeType||l.jquery)?m(l):m.event,o=m.Deferred(),p=m.Callbacks("once memory"),q=k.statusCode||{},r={},s={},t=0,u="canceled",v={readyState:0,getResponseHeader:function(a){var b;if(2===t){if(!j){j={};while(b=Cb.exec(f))j[b[1].toLowerCase()]=b[2]}b=j[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return 2===t?f:null},setRequestHeader:function(a,b){var c=a.toLowerCase();return t||(a=s[c]=s[c]||a,r[a]=b),this},overrideMimeType:function(a){return t||(k.mimeType=a),this},statusCode:function(a){var b;if(a)if(2>t)for(b in a)q[b]=[q[b],a[b]];else v.always(a[v.status]);return this},abort:function(a){var b=a||u;return i&&i.abort(b),x(0,b),this}};if(o.promise(v).complete=p.add,v.success=v.done,v.error=v.fail,k.url=((a||k.url||zb)+"").replace(Ab,"").replace(Fb,yb[1]+"//"),k.type=b.method||b.type||k.method||k.type,k.dataTypes=m.trim(k.dataType||"*").toLowerCase().match(E)||[""],null==k.crossDomain&&(c=Gb.exec(k.url.toLowerCase()),k.crossDomain=!(!c||c[1]===yb[1]&&c[2]===yb[2]&&(c[3]||("http:"===c[1]?"80":"443"))===(yb[3]||("http:"===yb[1]?"80":"443")))),k.data&&k.processData&&"string"!=typeof k.data&&(k.data=m.param(k.data,k.traditional)),Mb(Hb,k,b,v),2===t)return v;h=m.event&&k.global,h&&0===m.active++&&m.event.trigger("ajaxStart"),k.type=k.type.toUpperCase(),k.hasContent=!Eb.test(k.type),e=k.url,k.hasContent||(k.data&&(e=k.url+=(wb.test(e)?"&":"?")+k.data,delete k.data),k.cache===!1&&(k.url=Bb.test(e)?e.replace(Bb,"$1_="+vb++):e+(wb.test(e)?"&":"?")+"_="+vb++)),k.ifModified&&(m.lastModified[e]&&v.setRequestHeader("If-Modified-Since",m.lastModified[e]),m.etag[e]&&v.setRequestHeader("If-None-Match",m.etag[e])),(k.data&&k.hasContent&&k.contentType!==!1||b.contentType)&&v.setRequestHeader("Content-Type",k.contentType),v.setRequestHeader("Accept",k.dataTypes[0]&&k.accepts[k.dataTypes[0]]?k.accepts[k.dataTypes[0]]+("*"!==k.dataTypes[0]?", "+Jb+"; q=0.01":""):k.accepts["*"]);for(d in k.headers)v.setRequestHeader(d,k.headers[d]);if(k.beforeSend&&(k.beforeSend.call(l,v,k)===!1||2===t))return v.abort();u="abort";for(d in{success:1,error:1,complete:1})v[d](k[d]);if(i=Mb(Ib,k,b,v)){v.readyState=1,h&&n.trigger("ajaxSend",[v,k]),k.async&&k.timeout>0&&(g=setTimeout(function(){v.abort("timeout")},k.timeout));try{t=1,i.send(r,x)}catch(w){if(!(2>t))throw w;x(-1,w)}}else x(-1,"No Transport");function x(a,b,c,d){var j,r,s,u,w,x=b;2!==t&&(t=2,g&&clearTimeout(g),i=void 0,f=d||"",v.readyState=a>0?4:0,j=a>=200&&300>a||304===a,c&&(u=Ob(k,v,c)),u=Pb(k,u,v,j),j?(k.ifModified&&(w=v.getResponseHeader("Last-Modified"),w&&(m.lastModified[e]=w),w=v.getResponseHeader("etag"),w&&(m.etag[e]=w)),204===a||"HEAD"===k.type?x="nocontent":304===a?x="notmodified":(x=u.state,r=u.data,s=u.error,j=!s)):(s=x,(a||!x)&&(x="error",0>a&&(a=0))),v.status=a,v.statusText=(b||x)+"",j?o.resolveWith(l,[r,x,v]):o.rejectWith(l,[v,x,s]),v.statusCode(q),q=void 0,h&&n.trigger(j?"ajaxSuccess":"ajaxError",[v,k,j?r:s]),p.fireWith(l,[v,x]),h&&(n.trigger("ajaxComplete",[v,k]),--m.active||m.event.trigger("ajaxStop")))}return v},getJSON:function(a,b,c){return m.get(a,b,c,"json")},getScript:function(a,b){return m.get(a,void 0,b,"script")}}),m.each(["get","post"],function(a,b){m[b]=function(a,c,d,e){return m.isFunction(c)&&(e=e||d,d=c,c=void 0),m.ajax({url:a,type:b,dataType:e,data:c,success:d})}}),m._evalUrl=function(a){return m.ajax({url:a,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})},m.fn.extend({wrapAll:function(a){if(m.isFunction(a))return this.each(function(b){m(this).wrapAll(a.call(this,b))});if(this[0]){var b=m(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&1===a.firstChild.nodeType)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){return this.each(m.isFunction(a)?function(b){m(this).wrapInner(a.call(this,b))}:function(){var b=m(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=m.isFunction(a);return this.each(function(c){m(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){m.nodeName(this,"body")||m(this).replaceWith(this.childNodes)}).end()}}),m.expr.filters.hidden=function(a){return a.offsetWidth<=0&&a.offsetHeight<=0||!k.reliableHiddenOffsets()&&"none"===(a.style&&a.style.display||m.css(a,"display"))},m.expr.filters.visible=function(a){return!m.expr.filters.hidden(a)};var Qb=/%20/g,Rb=/\[\]$/,Sb=/\r?\n/g,Tb=/^(?:submit|button|image|reset|file)$/i,Ub=/^(?:input|select|textarea|keygen)/i;function Vb(a,b,c,d){var e;if(m.isArray(b))m.each(b,function(b,e){c||Rb.test(a)?d(a,e):Vb(a+"["+("object"==typeof e?b:"")+"]",e,c,d)});else if(c||"object"!==m.type(b))d(a,b);else for(e in b)Vb(a+"["+e+"]",b[e],c,d)}m.param=function(a,b){var c,d=[],e=function(a,b){b=m.isFunction(b)?b():null==b?"":b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};if(void 0===b&&(b=m.ajaxSettings&&m.ajaxSettings.traditional),m.isArray(a)||a.jquery&&!m.isPlainObject(a))m.each(a,function(){e(this.name,this.value)});else for(c in a)Vb(c,a[c],b,e);return d.join("&").replace(Qb,"+")},m.fn.extend({serialize:function(){return m.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=m.prop(this,"elements");return a?m.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!m(this).is(":disabled")&&Ub.test(this.nodeName)&&!Tb.test(a)&&(this.checked||!W.test(a))}).map(function(a,b){var c=m(this).val();return null==c?null:m.isArray(c)?m.map(c,function(a){return{name:b.name,value:a.replace(Sb,"\r\n")}}):{name:b.name,value:c.replace(Sb,"\r\n")}}).get()}}),m.ajaxSettings.xhr=void 0!==a.ActiveXObject?function(){return!this.isLocal&&/^(get|post|head|put|delete|options)$/i.test(this.type)&&Zb()||$b()}:Zb;var Wb=0,Xb={},Yb=m.ajaxSettings.xhr();a.attachEvent&&a.attachEvent("onunload",function(){for(var a in Xb)Xb[a](void 0,!0)}),k.cors=!!Yb&&"withCredentials"in Yb,Yb=k.ajax=!!Yb,Yb&&m.ajaxTransport(function(a){if(!a.crossDomain||k.cors){var b;return{send:function(c,d){var e,f=a.xhr(),g=++Wb;if(f.open(a.type,a.url,a.async,a.username,a.password),a.xhrFields)for(e in a.xhrFields)f[e]=a.xhrFields[e];a.mimeType&&f.overrideMimeType&&f.overrideMimeType(a.mimeType),a.crossDomain||c["X-Requested-With"]||(c["X-Requested-With"]="XMLHttpRequest");for(e in c)void 0!==c[e]&&f.setRequestHeader(e,c[e]+"");f.send(a.hasContent&&a.data||null),b=function(c,e){var h,i,j;if(b&&(e||4===f.readyState))if(delete Xb[g],b=void 0,f.onreadystatechange=m.noop,e)4!==f.readyState&&f.abort();else{j={},h=f.status,"string"==typeof f.responseText&&(j.text=f.responseText);try{i=f.statusText}catch(k){i=""}h||!a.isLocal||a.crossDomain?1223===h&&(h=204):h=j.text?200:404}j&&d(h,i,j,f.getAllResponseHeaders())},a.async?4===f.readyState?setTimeout(b):f.onreadystatechange=Xb[g]=b:b()},abort:function(){b&&b(void 0,!0)}}}});function Zb(){try{return new a.XMLHttpRequest}catch(b){}}function $b(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}m.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(a){return m.globalEval(a),a}}}),m.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),m.ajaxTransport("script",function(a){if(a.crossDomain){var b,c=y.head||m("head")[0]||y.documentElement;return{send:function(d,e){b=y.createElement("script"),b.async=!0,a.scriptCharset&&(b.charset=a.scriptCharset),b.src=a.url,b.onload=b.onreadystatechange=function(a,c){(c||!b.readyState||/loaded|complete/.test(b.readyState))&&(b.onload=b.onreadystatechange=null,b.parentNode&&b.parentNode.removeChild(b),b=null,c||e(200,"success"))},c.insertBefore(b,c.firstChild)},abort:function(){b&&b.onload(void 0,!0)}}}});var _b=[],ac=/(=)\?(?=&|$)|\?\?/;m.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=_b.pop()||m.expando+"_"+vb++;return this[a]=!0,a}}),m.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(ac.test(b.url)?"url":"string"==typeof b.data&&!(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&ac.test(b.data)&&"data");return h||"jsonp"===b.dataTypes[0]?(e=b.jsonpCallback=m.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(ac,"$1"+e):b.jsonp!==!1&&(b.url+=(wb.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||m.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,_b.push(e)),g&&m.isFunction(f)&&f(g[0]),g=f=void 0}),"script"):void 0}),m.parseHTML=function(a,b,c){if(!a||"string"!=typeof a)return null;"boolean"==typeof b&&(c=b,b=!1),b=b||y;var d=u.exec(a),e=!c&&[];return d?[b.createElement(d[1])]:(d=m.buildFragment([a],b,e),e&&e.length&&m(e).remove(),m.merge([],d.childNodes))};var bc=m.fn.load;m.fn.load=function(a,b,c){if("string"!=typeof a&&bc)return bc.apply(this,arguments);var d,e,f,g=this,h=a.indexOf(" ");return h>=0&&(d=m.trim(a.slice(h,a.length)),a=a.slice(0,h)),m.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(f="POST"),g.length>0&&m.ajax({url:a,type:f,dataType:"html",data:b}).done(function(a){e=arguments,g.html(d?m("<div>").append(m.parseHTML(a)).find(d):a)}).complete(c&&function(a,b){g.each(c,e||[a.responseText,b,a])}),this},m.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){m.fn[b]=function(a){return this.on(b,a)}}),m.expr.filters.animated=function(a){return m.grep(m.timers,function(b){return a===b.elem}).length};var cc=a.document.documentElement;function dc(a){return m.isWindow(a)?a:9===a.nodeType?a.defaultView||a.parentWindow:!1}m.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=m.css(a,"position"),l=m(a),n={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=m.css(a,"top"),i=m.css(a,"left"),j=("absolute"===k||"fixed"===k)&&m.inArray("auto",[f,i])>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),m.isFunction(b)&&(b=b.call(a,c,h)),null!=b.top&&(n.top=b.top-h.top+g),null!=b.left&&(n.left=b.left-h.left+e),"using"in b?b.using.call(a,n):l.css(n)}},m.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){m.offset.setOffset(this,a,b)});var b,c,d={top:0,left:0},e=this[0],f=e&&e.ownerDocument;if(f)return b=f.documentElement,m.contains(b,e)?(typeof e.getBoundingClientRect!==K&&(d=e.getBoundingClientRect()),c=dc(f),{top:d.top+(c.pageYOffset||b.scrollTop)-(b.clientTop||0),left:d.left+(c.pageXOffset||b.scrollLeft)-(b.clientLeft||0)}):d},position:function(){if(this[0]){var a,b,c={top:0,left:0},d=this[0];return"fixed"===m.css(d,"position")?b=d.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),m.nodeName(a[0],"html")||(c=a.offset()),c.top+=m.css(a[0],"borderTopWidth",!0),c.left+=m.css(a[0],"borderLeftWidth",!0)),{top:b.top-c.top-m.css(d,"marginTop",!0),left:b.left-c.left-m.css(d,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||cc;while(a&&!m.nodeName(a,"html")&&"static"===m.css(a,"position"))a=a.offsetParent;return a||cc})}}),m.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,b){var c=/Y/.test(b);m.fn[a]=function(d){return V(this,function(a,d,e){var f=dc(a);return void 0===e?f?b in f?f[b]:f.document.documentElement[d]:a[d]:void(f?f.scrollTo(c?m(f).scrollLeft():e,c?e:m(f).scrollTop()):a[d]=e)},a,d,arguments.length,null)}}),m.each(["top","left"],function(a,b){m.cssHooks[b]=La(k.pixelPosition,function(a,c){return c?(c=Ja(a,b),Ha.test(c)?m(a).position()[b]+"px":c):void 0})}),m.each({Height:"height",Width:"width"},function(a,b){m.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){m.fn[d]=function(d,e){var f=arguments.length&&(c||"boolean"!=typeof d),g=c||(d===!0||e===!0?"margin":"border");return V(this,function(b,c,d){var e;return m.isWindow(b)?b.document.documentElement["client"+a]:9===b.nodeType?(e=b.documentElement,Math.max(b.body["scroll"+a],e["scroll"+a],b.body["offset"+a],e["offset"+a],e["client"+a])):void 0===d?m.css(b,c,g):m.style(b,c,d,g)},b,f?d:void 0,f,null)}})}),m.fn.size=function(){return this.length},m.fn.andSelf=m.fn.addBack,"function"==typeof define&&define.amd&&define("jquery",[],function(){return m});var ec=a.jQuery,fc=a.$;return m.noConflict=function(b){return a.$===m&&(a.$=fc),b&&a.jQuery===m&&(a.jQuery=ec),m},typeof b===K&&(a.jQuery=a.$=m),m}); -</script> -<meta name="viewport" content="width=device-width, initial-scale=1" /> -<style type="text/css">html{font-family:sans-serif;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}h1{margin:.67em 0;font-size:2em}mark{color:#000;background:#ff0}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{height:0;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{margin:0;font:inherit;color:inherit}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}input{line-height:normal}input[type=checkbox],input[type=radio]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}fieldset{padding:.35em .625em .75em;margin:0 2px;border:1px solid silver}legend{padding:0;border:0}textarea{overflow:auto}optgroup{font-weight:700}table{border-spacing:0;border-collapse:collapse}td,th{padding:0}@media print{*,:after,:before{color:#000!important;text-shadow:none!important;background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="javascript:"]:after,a[href^="#"]:after{content:""}blockquote,pre{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.navbar{display:none}.btn>.caret,.dropup>.btn>.caret{border-top-color:#000!important}.label{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #ddd!important}}@font-face{font-family:'Glyphicons Halflings';src:url(data:application/vnd.ms-fontobject;base64,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);src:url(data:application/vnd.ms-fontobject;base64,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) format('embedded-opentype'),url(data:application/font-woff;base64,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) format('woff'),url(data:application/x-font-truetype;base64,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JbwmFCZ+JuYnUCe8J/goNChwKKwpoCnMKiYqSiqEKworeiwILGgsuizsLRwtiC30LiguZi6iLtgvDi9GL34vsi/4MD4whDDSMRIxYDGuMegyJDJeMpoy3jMiMz4zaDO2NBg0YDSoNNI1LDWeNeg2PjZ8Ntw3GjdON5I31DgQOEI4hjjIOQo5SjmIOcw6HDpsOpo63jugO9w8GDxQPKI8+D0yPew+Oj6MPtQ/KD9uP6o/+kBIQIBAxkECQX5CGEKoQu5DGENCQ3ZDoEPKRBBEYESuRPZFWkW2RgZGdEa0RvZHNkd2R7ZH9kgWSDJITkhqSIZIzEkSSThJXkmESapKAkouSlIAAQAAARcApwARAAAAAAACAAAAAQABAAAAQAAuAAAAAAAAABAAxgABAAAAAAATABIAAAADAAEECQAAAGoAEgADAAEECQABACgAfAADAAEECQACAA4ApAADAAEECQADAEwAsgADAAEECQAEADgA/gADAAEECQAFAHgBNgADAAEECQAGADYBrgADAAEECQAIABYB5AADAAEECQAJABYB+gADAAEECQALACQCEAADAAEECQAMACQCNAADAAEECQATACQCWAADAAEECQDIABYCfAADAAEECQDJADACkgADAAEECdkDABoCwnd3dy5nbHlwaGljb25zLmNvbQBDAG8AcAB5AHIAaQBnAGgAdAAgAKkAIAAyADAAMQA0ACAAYgB5ACAASgBhAG4AIABLAG8AdgBhAHIAaQBrAC4AIABBAGwAbAAgAHIAaQBnAGgAdABzACAAcgBlAHMAZQByAHYAZQBkAC4ARwBMAFkAUABIAEkAQwBPAE4AUwAgAEgAYQBsAGYAbABpAG4AZwBzAFIAZQBnAHUAbABhAHIAMQAuADAAMAA5ADsAVQBLAFcATgA7AEcATABZAFAASABJAEMATwBOAFMASABhAGwAZgBsAGkAbgBnAHMALQBSAGUAZwB1AGwAYQByAEcATABZAFAASABJAEMATwBOAFMAIABIAGEAbABmAGwAaQBuAGcAcwAgAFIAZQBnAHUAbABhAHIAVgBlAHIAcwBpAG8AbgAgADEALgAwADAAOQA7AFAAUwAgADAAMAAxAC4AMAAwADkAOwBoAG8AdABjAG8AbgB2ACAAMQAuADAALgA3ADAAOwBtAGEAawBlAG8AdABmAC4AbABpAGIAMgAuADUALgA1ADgAMwAyADkARwBMAFkAUABIAEkAQwBPAE4AUwBIAGEAbABmAGwAaQBuAGcAcwAtAFIAZQBnAHUAbABhAHIASgBhAG4AIABLAG8AdgBhAHIAaQBrAEoAYQBuACAASwBvAHYAYQByAGkAawB3AHcAdwAuAGcAbAB5AHAAaABpAGMAbwBuAHMALgBjAG8AbQB3AHcAdwAuAGcAbAB5AHAAaABpAGMAbwBuAHMALgBjAG8AbQB3AHcAdwAuAGcAbAB5AHAAaABpAGMAbwBuAHMALgBjAG8AbQBXAGUAYgBmAG8AbgB0ACAAMQAuADAAVwBlAGQAIABPAGMAdAAgADIAOQAgADAANgA6ADMANgA6ADAANwAgADIAMAAxADQARgBvAG4AdAAgAFMAcQB1AGkAcgByAGUAbAAAAAIAAAAAAAD/tQAyAAAAAAAAAAAAAAAAAAAAAAAAAAABFwAAAQIBAwADAA0ADgEEAJYBBQEGAQcBCAEJAQoBCwEMAQ0BDgEPARABEQESARMA7wEUARUBFgEXARgBGQEaARsBHAEdAR4BHwEgASEBIgEjASQBJQEmAScBKAEpASoBKwEsAS0BLgEvATABMQEyATMBNAE1ATYBNwE4ATkBOgE7ATwBPQE+AT8BQAFBAUIBQwFEAUUBRgFHAUgBSQFKAUsBTAFNAU4BTwFQAVEBUgFTAVQBVQFWAVcBWAFZAVoBWwFcAV0BXgFfAWABYQFiAWMBZAFlAWYBZwFoAWkBagFrAWwBbQFuAW8BcAFxAXIBcwF0AXUBdgF3AXgBeQF6AXsBfAF9AX4BfwGAAYEBggGDAYQBhQGGAYcBiAGJAYoBiwGMAY0BjgGPAZABkQGSAZMBlAGVAZYBlwGYAZkBmgGbAZwBnQGeAZ8BoAGhAaIBowGkAaUBpgGnAagBqQGqAasBrAGtAa4BrwGwAbEBsgGzAbQBtQG2AbcBuAG5AboBuwG8Ab0BvgG/AcABwQHCAcMBxAHFAcYBxwHIAckBygHLAcwBzQHOAc8B0AHRAdIB0wHUAdUB1gHXAdgB2QHaAdsB3AHdAd4B3wHgAeEB4gHjAeQB5QHmAecB6AHpAeoB6wHsAe0B7gHvAfAB8QHyAfMB9AH1AfYB9wH4AfkB+gH7AfwB/QH+Af8CAAIBAgICAwIEAgUCBgIHAggCCQIKAgsCDAINAg4CDwIQAhECEgZnbHlwaDEGZ2x5cGgyB3VuaTAwQTAHdW5pMjAwMAd1bmkyMDAxB3VuaTIwMDIHdW5pMjAwMwd1bmkyMDA0B3VuaTIwMDUHdW5pMjAwNgd1bmkyMDA3B3VuaTIwMDgHdW5pMjAwOQd1bmkyMDBBB3VuaTIwMkYHdW5pMjA1RgRFdXJvB3VuaTIwQkQHdW5pMjMxQgd1bmkyNUZDB3VuaTI2MDEHdW5pMjZGQQd1bmkyNzA5B3VuaTI3MEYHdW5pRTAwMQd1bmlFMDAyB3VuaUUwMDMHdW5pRTAwNQd1bmlFMDA2B3VuaUUwMDcHdW5pRTAwOAd1bmlFMDA5B3VuaUUwMTAHdW5pRTAxMQd1bmlFMDEyB3VuaUUwMTMHdW5pRTAxNAd1bmlFMDE1B3VuaUUwMTYHdW5pRTAxNwd1bmlFMDE4B3VuaUUwMTkHdW5pRTAyMAd1bmlFMDIxB3VuaUUwMjIHdW5pRTAyMwd1bmlFMDI0B3VuaUUwMjUHdW5pRTAyNgd1bmlFMDI3B3VuaUUwMjgHdW5pRTAyOQd1bmlFMDMwB3VuaUUwMzEHdW5pRTAzMgd1bmlFMDMzB3VuaUUwMzQHdW5pRTAzNQd1bmlFMDM2B3VuaUUwMzcHdW5pRTAzOAd1bmlFMDM5B3VuaUUwNDAHdW5pRTA0MQd1bmlFMDQyB3VuaUUwNDMHdW5pRTA0NAd1bmlFMDQ1B3VuaUUwNDYHdW5pRTA0Nwd1bmlFMDQ4B3VuaUUwNDkHdW5pRTA1MAd1bmlFMDUxB3VuaUUwNTIHdW5pRTA1Mwd1bmlFMDU0B3VuaUUwNTUHdW5pRTA1Ngd1bmlFMDU3B3VuaUUwNTgHdW5pRTA1OQd1bmlFMDYwB3VuaUUwNjIHdW5pRTA2Mwd1bmlFMDY0B3VuaUUwNjUHdW5pRTA2Ngd1bmlFMDY3B3VuaUUwNjgHdW5pRTA2OQd1bmlFMDcwB3VuaUUwNzEHdW5pRTA3Mgd1bmlFMDczB3VuaUUwNzQHdW5pRTA3NQd1bmlFMDc2B3VuaUUwNzcHdW5pRTA3OAd1bmlFMDc5B3VuaUUwODAHdW5pRTA4MQd1bmlFMDgyB3VuaUUwODMHdW5pRTA4NAd1bmlFMDg1B3VuaUUwODYHdW5pRTA4Nwd1bmlFMDg4B3VuaUUwODkHdW5pRTA5MAd1bmlFMDkxB3VuaUUwOTIHdW5pRTA5Mwd1bmlFMDk0B3VuaUUwOTUHdW5pRTA5Ngd1bmlFMDk3B3VuaUUxMDEHdW5pRTEwMgd1bmlFMTAzB3VuaUUxMDQHdW5pRTEwNQd1bmlFMTA2B3VuaUUxMDcHdW5pRTEwOAd1bmlFMTA5B3VuaUUxMTAHdW5pRTExMQd1bmlFMTEyB3VuaUUxMTMHdW5pRTExNAd1bmlFMTE1B3VuaUUxMTYHdW5pRTExNwd1bmlFMTE4B3VuaUUxMTkHdW5pRTEyMAd1bmlFMTIxB3VuaUUxMjIHdW5pRTEyMwd1bmlFMTI0B3VuaUUxMjUHdW5pRTEyNgd1bmlFMTI3B3VuaUUxMjgHdW5pRTEyOQd1bmlFMTMwB3VuaUUxMzEHdW5pRTEzMgd1bmlFMTMzB3VuaUUxMzQHdW5pRTEzNQd1bmlFMTM2B3VuaUUxMzcHdW5pRTEzOAd1bmlFMTM5B3VuaUUxNDAHdW5pRTE0MQd1bmlFMTQyB3VuaUUxNDMHdW5pRTE0NAd1bmlFMTQ1B3VuaUUxNDYHdW5pRTE0OAd1bmlFMTQ5B3VuaUUxNTAHdW5pRTE1MQd1bmlFMTUyB3VuaUUxNTMHdW5pRTE1NAd1bmlFMTU1B3VuaUUxNTYHdW5pRTE1Nwd1bmlFMTU4B3VuaUUxNTkHdW5pRTE2MAd1bmlFMTYxB3VuaUUxNjIHdW5pRTE2Mwd1bmlFMTY0B3VuaUUxNjUHdW5pRTE2Ngd1bmlFMTY3B3VuaUUxNjgHdW5pRTE2OQd1bmlFMTcwB3VuaUUxNzEHdW5pRTE3Mgd1bmlFMTczB3VuaUUxNzQHdW5pRTE3NQd1bmlFMTc2B3VuaUUxNzcHdW5pRTE3OAd1bmlFMTc5B3VuaUUxODAHdW5pRTE4MQd1bmlFMTgyB3VuaUUxODMHdW5pRTE4NAd1bmlFMTg1B3VuaUUxODYHdW5pRTE4Nwd1bmlFMTg4B3VuaUUxODkHdW5pRTE5MAd1bmlFMTkxB3VuaUUxOTIHdW5pRTE5Mwd1bmlFMTk0B3VuaUUxOTUHdW5pRTE5Nwd1bmlFMTk4B3VuaUUxOTkHdW5pRTIwMAd1bmlFMjAxB3VuaUUyMDIHdW5pRTIwMwd1bmlFMjA0B3VuaUUyMDUHdW5pRTIwNgd1bmlFMjA5B3VuaUUyMTAHdW5pRTIxMQd1bmlFMjEyB3VuaUUyMTMHdW5pRTIxNAd1bmlFMjE1B3VuaUUyMTYHdW5pRTIxOAd1bmlFMjE5B3VuaUUyMjEHdW5pRTIyMwd1bmlFMjI0B3VuaUUyMjUHdW5pRTIyNgd1bmlFMjI3B3VuaUUyMzAHdW5pRTIzMQd1bmlFMjMyB3VuaUUyMzMHdW5pRTIzNAd1bmlFMjM1B3VuaUUyMzYHdW5pRTIzNwd1bmlFMjM4B3VuaUUyMzkHdW5pRTI0MAd1bmlFMjQxB3VuaUUyNDIHdW5pRTI0Mwd1bmlFMjQ0B3VuaUUyNDUHdW5pRTI0Ngd1bmlFMjQ3B3VuaUUyNDgHdW5pRTI0OQd1bmlFMjUwB3VuaUUyNTEHdW5pRTI1Mgd1bmlFMjUzB3VuaUUyNTQHdW5pRTI1NQd1bmlFMjU2B3VuaUUyNTcHdW5pRTI1OAd1bmlFMjU5B3VuaUUyNjAHdW5pRjhGRgZ1MUY1MTEGdTFGNkFBAAAAAAFUUMMXAAA=) format('truetype'),url() format('svg')}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';font-style:normal;font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\2a"}.glyphicon-plus:before{content:"\2b"}.glyphicon-eur:before,.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before{content:"\e227"}.glyphicon-btc:before{content:"\e227"}.glyphicon-xbt:before{content:"\e227"}.glyphicon-yen:before{content:"\00a5"}.glyphicon-jpy:before{content:"\00a5"}.glyphicon-ruble:before{content:"\20bd"}.glyphicon-rub:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}:after,:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:10px;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333;background-color:#fff}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}a{color:#337ab7;text-decoration:none}a:focus,a:hover{color:#23527c;text-decoration:underline}a:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}figure{margin:0}img{vertical-align:middle}.carousel-inner>.item>a>img,.carousel-inner>.item>img,.img-responsive,.thumbnail a>img,.thumbnail>img{display:block;max-width:100%;height:auto}.img-rounded{border-radius:6px}.img-thumbnail{display:inline-block;max-width:100%;height:auto;padding:4px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border:0;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}[role=button]{cursor:pointer}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-weight:400;line-height:1;color:#777}.h1,.h2,.h3,h1,h2,h3{margin-top:20px;margin-bottom:10px}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small{font-size:65%}.h4,.h5,.h6,h4,h5,h6{margin-top:10px;margin-bottom:10px}.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-size:75%}.h1,h1{font-size:36px}.h2,h2{font-size:30px}.h3,h3{font-size:24px}.h4,h4{font-size:18px}.h5,h5{font-size:14px}.h6,h6{font-size:12px}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16px;font-weight:300;line-height:1.4}@media (min-width:768px){.lead{font-size:21px}}.small,small{font-size:85%}.mark,mark{padding:.2em;background-color:#fcf8e3}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-muted{color:#777}.text-primary{color:#337ab7}a.text-primary:focus,a.text-primary:hover{color:#286090}.text-success{color:#3c763d}a.text-success:focus,a.text-success:hover{color:#2b542c}.text-info{color:#31708f}a.text-info:focus,a.text-info:hover{color:#245269}.text-warning{color:#8a6d3b}a.text-warning:focus,a.text-warning:hover{color:#66512c}.text-danger{color:#a94442}a.text-danger:focus,a.text-danger:hover{color:#843534}.bg-primary{color:#fff;background-color:#337ab7}a.bg-primary:focus,a.bg-primary:hover{background-color:#286090}.bg-success{background-color:#dff0d8}a.bg-success:focus,a.bg-success:hover{background-color:#c1e2b3}.bg-info{background-color:#d9edf7}a.bg-info:focus,a.bg-info:hover{background-color:#afd9ee}.bg-warning{background-color:#fcf8e3}a.bg-warning:focus,a.bg-warning:hover{background-color:#f7ecb5}.bg-danger{background-color:#f2dede}a.bg-danger:focus,a.bg-danger:hover{background-color:#e4b9b9}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}ol,ul{margin-top:0;margin-bottom:10px}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;margin-left:-5px;list-style:none}.list-inline>li{display:inline-block;padding-right:5px;padding-left:5px}dl{margin-top:0;margin-bottom:20px}dd,dt{line-height:1.42857143}dt{font-weight:700}dd{margin-left:0}@media (min-width:768px){.dl-horizontal dt{float:left;width:160px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}}abbr[data-original-title],abbr[title]{cursor:help;border-bottom:1px dotted #777}.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;font-size:17.5px;border-left:5px solid #eee}blockquote ol:last-child,blockquote p:last-child,blockquote ul:last-child{margin-bottom:0}blockquote .small,blockquote footer,blockquote small{display:block;font-size:80%;line-height:1.42857143;color:#777}blockquote .small:before,blockquote footer:before,blockquote small:before{content:'\2014 \00A0'}.blockquote-reverse,blockquote.pull-right{padding-right:15px;padding-left:0;text-align:right;border-right:5px solid #eee;border-left:0}.blockquote-reverse .small:before,.blockquote-reverse footer:before,.blockquote-reverse small:before,blockquote.pull-right .small:before,blockquote.pull-right footer:before,blockquote.pull-right small:before{content:''}.blockquote-reverse .small:after,.blockquote-reverse footer:after,.blockquote-reverse small:after,blockquote.pull-right .small:after,blockquote.pull-right footer:after,blockquote.pull-right small:after{content:'\00A0 \2014'}address{margin-bottom:20px;font-style:normal;line-height:1.42857143}code,kbd,pre,samp{font-family:monospace}code{padding:2px 4px;font-size:90%;color:#c7254e;background-color:#f9f2f4;border-radius:4px}kbd{padding:2px 4px;font-size:90%;color:#fff;background-color:#333;border-radius:3px;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.25);box-shadow:inset 0 -1px 0 rgba(0,0,0,.25)}kbd kbd{padding:0;font-size:100%;font-weight:700;-webkit-box-shadow:none;box-shadow:none}pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.42857143;color:#333;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;background-color:transparent;border-radius:0}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:768px){.container{width:750px}}@media (min-width:992px){.container{width:970px}}@media (min-width:1200px){.container{width:1170px}}.container-fluid{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{margin-right:-15px;margin-left:-15px}.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{position:relative;min-height:1px;padding-right:15px;padding-left:15px}.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{float:left}.col-xs-12{width:100%}.col-xs-11{width:91.66666667%}.col-xs-10{width:83.33333333%}.col-xs-9{width:75%}.col-xs-8{width:66.66666667%}.col-xs-7{width:58.33333333%}.col-xs-6{width:50%}.col-xs-5{width:41.66666667%}.col-xs-4{width:33.33333333%}.col-xs-3{width:25%}.col-xs-2{width:16.66666667%}.col-xs-1{width:8.33333333%}.col-xs-pull-12{right:100%}.col-xs-pull-11{right:91.66666667%}.col-xs-pull-10{right:83.33333333%}.col-xs-pull-9{right:75%}.col-xs-pull-8{right:66.66666667%}.col-xs-pull-7{right:58.33333333%}.col-xs-pull-6{right:50%}.col-xs-pull-5{right:41.66666667%}.col-xs-pull-4{right:33.33333333%}.col-xs-pull-3{right:25%}.col-xs-pull-2{right:16.66666667%}.col-xs-pull-1{right:8.33333333%}.col-xs-pull-0{right:auto}.col-xs-push-12{left:100%}.col-xs-push-11{left:91.66666667%}.col-xs-push-10{left:83.33333333%}.col-xs-push-9{left:75%}.col-xs-push-8{left:66.66666667%}.col-xs-push-7{left:58.33333333%}.col-xs-push-6{left:50%}.col-xs-push-5{left:41.66666667%}.col-xs-push-4{left:33.33333333%}.col-xs-push-3{left:25%}.col-xs-push-2{left:16.66666667%}.col-xs-push-1{left:8.33333333%}.col-xs-push-0{left:auto}.col-xs-offset-12{margin-left:100%}.col-xs-offset-11{margin-left:91.66666667%}.col-xs-offset-10{margin-left:83.33333333%}.col-xs-offset-9{margin-left:75%}.col-xs-offset-8{margin-left:66.66666667%}.col-xs-offset-7{margin-left:58.33333333%}.col-xs-offset-6{margin-left:50%}.col-xs-offset-5{margin-left:41.66666667%}.col-xs-offset-4{margin-left:33.33333333%}.col-xs-offset-3{margin-left:25%}.col-xs-offset-2{margin-left:16.66666667%}.col-xs-offset-1{margin-left:8.33333333%}.col-xs-offset-0{margin-left:0}@media (min-width:768px){.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9{float:left}.col-sm-12{width:100%}.col-sm-11{width:91.66666667%}.col-sm-10{width:83.33333333%}.col-sm-9{width:75%}.col-sm-8{width:66.66666667%}.col-sm-7{width:58.33333333%}.col-sm-6{width:50%}.col-sm-5{width:41.66666667%}.col-sm-4{width:33.33333333%}.col-sm-3{width:25%}.col-sm-2{width:16.66666667%}.col-sm-1{width:8.33333333%}.col-sm-pull-12{right:100%}.col-sm-pull-11{right:91.66666667%}.col-sm-pull-10{right:83.33333333%}.col-sm-pull-9{right:75%}.col-sm-pull-8{right:66.66666667%}.col-sm-pull-7{right:58.33333333%}.col-sm-pull-6{right:50%}.col-sm-pull-5{right:41.66666667%}.col-sm-pull-4{right:33.33333333%}.col-sm-pull-3{right:25%}.col-sm-pull-2{right:16.66666667%}.col-sm-pull-1{right:8.33333333%}.col-sm-pull-0{right:auto}.col-sm-push-12{left:100%}.col-sm-push-11{left:91.66666667%}.col-sm-push-10{left:83.33333333%}.col-sm-push-9{left:75%}.col-sm-push-8{left:66.66666667%}.col-sm-push-7{left:58.33333333%}.col-sm-push-6{left:50%}.col-sm-push-5{left:41.66666667%}.col-sm-push-4{left:33.33333333%}.col-sm-push-3{left:25%}.col-sm-push-2{left:16.66666667%}.col-sm-push-1{left:8.33333333%}.col-sm-push-0{left:auto}.col-sm-offset-12{margin-left:100%}.col-sm-offset-11{margin-left:91.66666667%}.col-sm-offset-10{margin-left:83.33333333%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-8{margin-left:66.66666667%}.col-sm-offset-7{margin-left:58.33333333%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-5{margin-left:41.66666667%}.col-sm-offset-4{margin-left:33.33333333%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-2{margin-left:16.66666667%}.col-sm-offset-1{margin-left:8.33333333%}.col-sm-offset-0{margin-left:0}}@media (min-width:992px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:left}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}.col-md-pull-12{right:100%}.col-md-pull-11{right:91.66666667%}.col-md-pull-10{right:83.33333333%}.col-md-pull-9{right:75%}.col-md-pull-8{right:66.66666667%}.col-md-pull-7{right:58.33333333%}.col-md-pull-6{right:50%}.col-md-pull-5{right:41.66666667%}.col-md-pull-4{right:33.33333333%}.col-md-pull-3{right:25%}.col-md-pull-2{right:16.66666667%}.col-md-pull-1{right:8.33333333%}.col-md-pull-0{right:auto}.col-md-push-12{left:100%}.col-md-push-11{left:91.66666667%}.col-md-push-10{left:83.33333333%}.col-md-push-9{left:75%}.col-md-push-8{left:66.66666667%}.col-md-push-7{left:58.33333333%}.col-md-push-6{left:50%}.col-md-push-5{left:41.66666667%}.col-md-push-4{left:33.33333333%}.col-md-push-3{left:25%}.col-md-push-2{left:16.66666667%}.col-md-push-1{left:8.33333333%}.col-md-push-0{left:auto}.col-md-offset-12{margin-left:100%}.col-md-offset-11{margin-left:91.66666667%}.col-md-offset-10{margin-left:83.33333333%}.col-md-offset-9{margin-left:75%}.col-md-offset-8{margin-left:66.66666667%}.col-md-offset-7{margin-left:58.33333333%}.col-md-offset-6{margin-left:50%}.col-md-offset-5{margin-left:41.66666667%}.col-md-offset-4{margin-left:33.33333333%}.col-md-offset-3{margin-left:25%}.col-md-offset-2{margin-left:16.66666667%}.col-md-offset-1{margin-left:8.33333333%}.col-md-offset-0{margin-left:0}}@media (min-width:1200px){.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9{float:left}.col-lg-12{width:100%}.col-lg-11{width:91.66666667%}.col-lg-10{width:83.33333333%}.col-lg-9{width:75%}.col-lg-8{width:66.66666667%}.col-lg-7{width:58.33333333%}.col-lg-6{width:50%}.col-lg-5{width:41.66666667%}.col-lg-4{width:33.33333333%}.col-lg-3{width:25%}.col-lg-2{width:16.66666667%}.col-lg-1{width:8.33333333%}.col-lg-pull-12{right:100%}.col-lg-pull-11{right:91.66666667%}.col-lg-pull-10{right:83.33333333%}.col-lg-pull-9{right:75%}.col-lg-pull-8{right:66.66666667%}.col-lg-pull-7{right:58.33333333%}.col-lg-pull-6{right:50%}.col-lg-pull-5{right:41.66666667%}.col-lg-pull-4{right:33.33333333%}.col-lg-pull-3{right:25%}.col-lg-pull-2{right:16.66666667%}.col-lg-pull-1{right:8.33333333%}.col-lg-pull-0{right:auto}.col-lg-push-12{left:100%}.col-lg-push-11{left:91.66666667%}.col-lg-push-10{left:83.33333333%}.col-lg-push-9{left:75%}.col-lg-push-8{left:66.66666667%}.col-lg-push-7{left:58.33333333%}.col-lg-push-6{left:50%}.col-lg-push-5{left:41.66666667%}.col-lg-push-4{left:33.33333333%}.col-lg-push-3{left:25%}.col-lg-push-2{left:16.66666667%}.col-lg-push-1{left:8.33333333%}.col-lg-push-0{left:auto}.col-lg-offset-12{margin-left:100%}.col-lg-offset-11{margin-left:91.66666667%}.col-lg-offset-10{margin-left:83.33333333%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-8{margin-left:66.66666667%}.col-lg-offset-7{margin-left:58.33333333%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-5{margin-left:41.66666667%}.col-lg-offset-4{margin-left:33.33333333%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-2{margin-left:16.66666667%}.col-lg-offset-1{margin-left:8.33333333%}.col-lg-offset-0{margin-left:0}}table{background-color:transparent}caption{padding-top:8px;padding-bottom:8px;color:#777;text-align:left}th{}.table{width:100%;max-width:100%;margin-bottom:20px}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th{border-top:0}.table>tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th{padding:5px}.table-bordered{border:1px solid #ddd}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border-bottom-width:2px}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}.table-hover>tbody>tr:hover{background-color:#f5f5f5}table col[class*=col-]{position:static;display:table-column;float:none}table td[class*=col-],table th[class*=col-]{position:static;display:table-cell;float:none}.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active{background-color:#f5f5f5}.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover{background-color:#e8e8e8}.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success{background-color:#dff0d8}.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover{background-color:#d0e9c6}.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info{background-color:#d9edf7}.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover{background-color:#c4e3f3}.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning{background-color:#fcf8e3}.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover{background-color:#faf2cc}.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger{background-color:#f2dede}.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover{background-color:#ebcccc}.table-responsive{min-height:.01%;overflow-x:auto}@media screen and (max-width:767px){.table-responsive{width:100%;margin-bottom:15px;overflow-y:hidden;-ms-overflow-style:-ms-autohiding-scrollbar;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0}.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:inherit;color:#333;border:0;border-bottom:1px solid #e5e5e5}label{display:inline-block;max-width:100%;margin-bottom:5px;font-weight:700}input[type=search]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}input[type=checkbox],input[type=radio]{margin:4px 0 0;margin-top:1px\9;line-height:normal}input[type=file]{display:block}input[type=range]{display:block;width:100%}select[multiple],select[size]{height:auto}input[type=file]:focus,input[type=checkbox]:focus,input[type=radio]:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}output{display:block;padding-top:7px;font-size:14px;line-height:1.42857143;color:#555}.form-control{display:block;width:100%;height:34px;padding:6px 12px;font-size:14px;line-height:1.42857143;color:#555;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075);-webkit-transition:border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;-o-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.form-control::-moz-placeholder{color:#999;opacity:1}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{background-color:#eee;opacity:1}.form-control[disabled],fieldset[disabled] .form-control{cursor:not-allowed}textarea.form-control{height:auto}input[type=search]{-webkit-appearance:none}@media screen and (-webkit-min-device-pixel-ratio:0){input[type=date].form-control,input[type=time].form-control,input[type=datetime-local].form-control,input[type=month].form-control{line-height:34px}.input-group-sm input[type=date],.input-group-sm input[type=time],.input-group-sm input[type=datetime-local],.input-group-sm input[type=month],input[type=date].input-sm,input[type=time].input-sm,input[type=datetime-local].input-sm,input[type=month].input-sm{line-height:30px}.input-group-lg input[type=date],.input-group-lg input[type=time],.input-group-lg input[type=datetime-local],.input-group-lg input[type=month],input[type=date].input-lg,input[type=time].input-lg,input[type=datetime-local].input-lg,input[type=month].input-lg{line-height:46px}}.form-group{margin-bottom:15px}.checkbox,.radio{position:relative;display:block;margin-top:10px;margin-bottom:10px}.checkbox label,.radio label{min-height:20px;padding-left:20px;margin-bottom:0;font-weight:400;cursor:pointer}.checkbox input[type=checkbox],.checkbox-inline input[type=checkbox],.radio input[type=radio],.radio-inline input[type=radio]{position:absolute;margin-top:4px\9;margin-left:-20px}.checkbox+.checkbox,.radio+.radio{margin-top:-5px}.checkbox-inline,.radio-inline{position:relative;display:inline-block;padding-left:20px;margin-bottom:0;font-weight:400;vertical-align:middle;cursor:pointer}.checkbox-inline+.checkbox-inline,.radio-inline+.radio-inline{margin-top:0;margin-left:10px}fieldset[disabled] input[type=checkbox],fieldset[disabled] input[type=radio],input[type=checkbox].disabled,input[type=checkbox][disabled],input[type=radio].disabled,input[type=radio][disabled]{cursor:not-allowed}.checkbox-inline.disabled,.radio-inline.disabled,fieldset[disabled] .checkbox-inline,fieldset[disabled] .radio-inline{cursor:not-allowed}.checkbox.disabled label,.radio.disabled label,fieldset[disabled] .checkbox label,fieldset[disabled] .radio label{cursor:not-allowed}.form-control-static{min-height:34px;padding-top:7px;padding-bottom:7px;margin-bottom:0}.form-control-static.input-lg,.form-control-static.input-sm{padding-right:0;padding-left:0}.input-sm{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-sm{height:30px;line-height:30px}select[multiple].input-sm,textarea.input-sm{height:auto}.form-group-sm .form-control{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.form-group-sm select.form-control{height:30px;line-height:30px}.form-group-sm select[multiple].form-control,.form-group-sm textarea.form-control{height:auto}.form-group-sm .form-control-static{height:30px;min-height:32px;padding:6px 10px;font-size:12px;line-height:1.5}.input-lg{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-lg{height:46px;line-height:46px}select[multiple].input-lg,textarea.input-lg{height:auto}.form-group-lg .form-control{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.form-group-lg select.form-control{height:46px;line-height:46px}.form-group-lg select[multiple].form-control,.form-group-lg textarea.form-control{height:auto}.form-group-lg .form-control-static{height:46px;min-height:38px;padding:11px 16px;font-size:18px;line-height:1.3333333}.has-feedback{position:relative}.has-feedback .form-control{padding-right:42.5px}.form-control-feedback{position:absolute;top:0;right:0;z-index:2;display:block;width:34px;height:34px;line-height:34px;text-align:center;pointer-events:none}.form-group-lg .form-control+.form-control-feedback,.input-group-lg+.form-control-feedback,.input-lg+.form-control-feedback{width:46px;height:46px;line-height:46px}.form-group-sm .form-control+.form-control-feedback,.input-group-sm+.form-control-feedback,.input-sm+.form-control-feedback{width:30px;height:30px;line-height:30px}.has-success .checkbox,.has-success .checkbox-inline,.has-success .control-label,.has-success .help-block,.has-success .radio,.has-success .radio-inline,.has-success.checkbox label,.has-success.checkbox-inline label,.has-success.radio label,.has-success.radio-inline label{color:#3c763d}.has-success .form-control{border-color:#3c763d;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-success .form-control:focus{border-color:#2b542c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168}.has-success .input-group-addon{color:#3c763d;background-color:#dff0d8;border-color:#3c763d}.has-success .form-control-feedback{color:#3c763d}.has-warning .checkbox,.has-warning .checkbox-inline,.has-warning .control-label,.has-warning .help-block,.has-warning .radio,.has-warning .radio-inline,.has-warning.checkbox label,.has-warning.checkbox-inline label,.has-warning.radio label,.has-warning.radio-inline label{color:#8a6d3b}.has-warning .form-control{border-color:#8a6d3b;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-warning .form-control:focus{border-color:#66512c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b}.has-warning .input-group-addon{color:#8a6d3b;background-color:#fcf8e3;border-color:#8a6d3b}.has-warning .form-control-feedback{color:#8a6d3b}.has-error .checkbox,.has-error .checkbox-inline,.has-error .control-label,.has-error .help-block,.has-error .radio,.has-error .radio-inline,.has-error.checkbox label,.has-error.checkbox-inline label,.has-error.radio label,.has-error.radio-inline label{color:#a94442}.has-error .form-control{border-color:#a94442;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-error .form-control:focus{border-color:#843534;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483}.has-error .input-group-addon{color:#a94442;background-color:#f2dede;border-color:#a94442}.has-error .form-control-feedback{color:#a94442}.has-feedback label~.form-control-feedback{top:25px}.has-feedback label.sr-only~.form-control-feedback{top:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media (min-width:768px){.form-inline .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-static{display:inline-block}.form-inline .input-group{display:inline-table;vertical-align:middle}.form-inline .input-group .form-control,.form-inline .input-group .input-group-addon,.form-inline .input-group .input-group-btn{width:auto}.form-inline .input-group>.form-control{width:100%}.form-inline .control-label{margin-bottom:0;vertical-align:middle}.form-inline .checkbox,.form-inline .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.form-inline .checkbox label,.form-inline .radio label{padding-left:0}.form-inline .checkbox input[type=checkbox],.form-inline .radio input[type=radio]{position:relative;margin-left:0}.form-inline .has-feedback .form-control-feedback{top:0}}.form-horizontal .checkbox,.form-horizontal .checkbox-inline,.form-horizontal .radio,.form-horizontal .radio-inline{padding-top:7px;margin-top:0;margin-bottom:0}.form-horizontal .checkbox,.form-horizontal .radio{min-height:27px}.form-horizontal .form-group{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.form-horizontal .control-label{padding-top:7px;margin-bottom:0;text-align:right}}.form-horizontal .has-feedback .form-control-feedback{right:15px}@media (min-width:768px){.form-horizontal .form-group-lg .control-label{padding-top:14.33px;font-size:18px}}@media (min-width:768px){.form-horizontal .form-group-sm .control-label{padding-top:6px;font-size:12px}}.btn{display:inline-block;padding:6px 12px;margin-bottom:0;font-size:14px;font-weight:400;line-height:1.42857143;text-align:center;white-space:nowrap;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-image:none;border:1px solid transparent;border-radius:4px}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{background-image:none;outline:0;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{cursor:not-allowed;filter:alpha(opacity=65);-webkit-box-shadow:none;box-shadow:none;opacity:.65}a.btn.disabled,fieldset[disabled] a.btn{pointer-events:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.focus,.btn-default:focus{color:#333;background-color:#e6e6e6;border-color:#8c8c8c}.btn-default:hover{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active,.btn-default:active,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active.focus,.btn-default.active:focus,.btn-default.active:hover,.btn-default:active.focus,.btn-default:active:focus,.btn-default:active:hover,.open>.dropdown-toggle.btn-default.focus,.open>.dropdown-toggle.btn-default:focus,.open>.dropdown-toggle.btn-default:hover{color:#333;background-color:#d4d4d4;border-color:#8c8c8c}.btn-default.active,.btn-default:active,.open>.dropdown-toggle.btn-default{background-image:none}.btn-default.disabled,.btn-default.disabled.active,.btn-default.disabled.focus,.btn-default.disabled:active,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled],.btn-default[disabled].active,.btn-default[disabled].focus,.btn-default[disabled]:active,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default,fieldset[disabled] .btn-default.active,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:active,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#337ab7;border-color:#2e6da4}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#286090;border-color:#122b40}.btn-primary:hover{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active,.btn-primary:active,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{color:#fff;background-color:#204d74;border-color:#122b40}.btn-primary.active,.btn-primary:active,.open>.dropdown-toggle.btn-primary{background-image:none}.btn-primary.disabled,.btn-primary.disabled.active,.btn-primary.disabled.focus,.btn-primary.disabled:active,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled],.btn-primary[disabled].active,.btn-primary[disabled].focus,.btn-primary[disabled]:active,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary,fieldset[disabled] .btn-primary.active,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:active,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#337ab7;border-color:#2e6da4}.btn-primary .badge{color:#337ab7;background-color:#fff}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#449d44;border-color:#255625}.btn-success:hover{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover{color:#fff;background-color:#398439;border-color:#255625}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{background-image:none}.btn-success.disabled,.btn-success.disabled.active,.btn-success.disabled.focus,.btn-success.disabled:active,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled],.btn-success[disabled].active,.btn-success[disabled].focus,.btn-success[disabled]:active,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success,fieldset[disabled] .btn-success.active,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:active,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#5cb85c;border-color:#4cae4c}.btn-success .badge{color:#5cb85c;background-color:#fff}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#31b0d5;border-color:#1b6d85}.btn-info:hover{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active,.btn-info:active,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active.focus,.btn-info.active:focus,.btn-info.active:hover,.btn-info:active.focus,.btn-info:active:focus,.btn-info:active:hover,.open>.dropdown-toggle.btn-info.focus,.open>.dropdown-toggle.btn-info:focus,.open>.dropdown-toggle.btn-info:hover{color:#fff;background-color:#269abc;border-color:#1b6d85}.btn-info.active,.btn-info:active,.open>.dropdown-toggle.btn-info{background-image:none}.btn-info.disabled,.btn-info.disabled.active,.btn-info.disabled.focus,.btn-info.disabled:active,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled],.btn-info[disabled].active,.btn-info[disabled].focus,.btn-info[disabled]:active,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info,fieldset[disabled] .btn-info.active,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:active,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#5bc0de;border-color:#46b8da}.btn-info .badge{color:#5bc0de;background-color:#fff}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning.focus,.btn-warning:focus{color:#fff;background-color:#ec971f;border-color:#985f0d}.btn-warning:hover{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active,.btn-warning:active,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover{color:#fff;background-color:#d58512;border-color:#985f0d}.btn-warning.active,.btn-warning:active,.open>.dropdown-toggle.btn-warning{background-image:none}.btn-warning.disabled,.btn-warning.disabled.active,.btn-warning.disabled.focus,.btn-warning.disabled:active,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled],.btn-warning[disabled].active,.btn-warning[disabled].focus,.btn-warning[disabled]:active,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning,fieldset[disabled] .btn-warning.active,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:active,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#f0ad4e;border-color:#eea236}.btn-warning .badge{color:#f0ad4e;background-color:#fff}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#c9302c;border-color:#761c19}.btn-danger:hover{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active,.btn-danger:active,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active.focus,.btn-danger.active:focus,.btn-danger.active:hover,.btn-danger:active.focus,.btn-danger:active:focus,.btn-danger:active:hover,.open>.dropdown-toggle.btn-danger.focus,.open>.dropdown-toggle.btn-danger:focus,.open>.dropdown-toggle.btn-danger:hover{color:#fff;background-color:#ac2925;border-color:#761c19}.btn-danger.active,.btn-danger:active,.open>.dropdown-toggle.btn-danger{background-image:none}.btn-danger.disabled,.btn-danger.disabled.active,.btn-danger.disabled.focus,.btn-danger.disabled:active,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled],.btn-danger[disabled].active,.btn-danger[disabled].focus,.btn-danger[disabled]:active,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger,fieldset[disabled] .btn-danger.active,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:active,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#d9534f;border-color:#d43f3a}.btn-danger .badge{color:#d9534f;background-color:#fff}.btn-link{font-weight:400;color:#337ab7;border-radius:0}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#23527c;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-group-lg>.btn,.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-group-sm>.btn,.btn-sm{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-xs>.btn,.btn-xs{padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:5px}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}tr.collapse.in{display:table-row}tbody.collapse.in{display:table-row-group}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition-timing-function:ease;-o-transition-timing-function:ease;transition-timing-function:ease;-webkit-transition-duration:.35s;-o-transition-duration:.35s;transition-duration:.35s;-webkit-transition-property:height,visibility;-o-transition-property:height,visibility;transition-property:height,visibility}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px dashed;border-top:4px solid\9;border-right:4px solid transparent;border-left:4px solid transparent}.dropdown,.dropup{position:relative}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;font-size:14px;text-align:left;list-style:none;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.15);border-radius:4px;-webkit-box-shadow:0 6px 12px rgba(0,0,0,.175);box-shadow:0 6px 12px rgba(0,0,0,.175)}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:400;line-height:1.42857143;color:#333;white-space:nowrap}.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{color:#262626;text-decoration:none;background-color:#f5f5f5}.dropdown-menu>.active>a,.dropdown-menu>.active>a:focus,.dropdown-menu>.active>a:hover{color:#fff;text-decoration:none;background-color:#337ab7;outline:0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{color:#777}.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{text-decoration:none;cursor:not-allowed;background-color:transparent;background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-menu-right{right:0;left:auto}.dropdown-menu-left{right:auto;left:0}.dropdown-header{display:block;padding:3px 20px;font-size:12px;line-height:1.42857143;color:#777;white-space:nowrap}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:990}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{content:"";border-top:0;border-bottom:4px dashed;border-bottom:4px solid\9}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:2px}@media (min-width:768px){.navbar-right .dropdown-menu{right:0;left:auto}.navbar-right .dropdown-menu-left{right:auto;left:0}}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;float:left}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:2}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{margin-left:-5px}.btn-toolbar .btn,.btn-toolbar .btn-group,.btn-toolbar .input-group{float:left}.btn-toolbar>.btn,.btn-toolbar>.btn-group,.btn-toolbar>.input-group{margin-left:5px}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.btn-group>.btn-group{float:left}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-bottom-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.btn+.dropdown-toggle{padding-right:8px;padding-left:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-right:12px;padding-left:12px}.btn-group.open .dropdown-toggle{-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn-group.open .dropdown-toggle.btn-link{-webkit-box-shadow:none;box-shadow:none}.btn .caret{margin-left:0}.btn-lg .caret{border-width:5px 5px 0;border-bottom-width:0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group,.btn-group-vertical>.btn-group>.btn{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:last-child:not(:first-child){border-top-left-radius:0;border-top-right-radius:0;border-bottom-left-radius:4px}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group-vertical>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-top-right-radius:0}.btn-group-justified{display:table;width:100%;table-layout:fixed;border-collapse:separate}.btn-group-justified>.btn,.btn-group-justified>.btn-group{display:table-cell;float:none;width:1%}.btn-group-justified>.btn-group .btn{width:100%}.btn-group-justified>.btn-group .dropdown-menu{left:auto}[data-toggle=buttons]>.btn input[type=checkbox],[data-toggle=buttons]>.btn input[type=radio],[data-toggle=buttons]>.btn-group>.btn input[type=checkbox],[data-toggle=buttons]>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group[class*=col-]{float:none;padding-right:0;padding-left:0}.input-group .form-control{position:relative;z-index:2;float:left;width:100%;margin-bottom:0}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:46px;line-height:46px}select[multiple].input-group-lg>.form-control,select[multiple].input-group-lg>.input-group-addon,select[multiple].input-group-lg>.input-group-btn>.btn,textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}select[multiple].input-group-sm>.form-control,select[multiple].input-group-sm>.input-group-addon,select[multiple].input-group-sm>.input-group-btn>.btn,textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group .form-control,.input-group-addon,.input-group-btn{display:table-cell}.input-group .form-control:not(:first-child):not(:last-child),.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:400;line-height:1;color:#555;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type=checkbox],.input-group-addon input[type=radio]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn-group:not(:last-child)>.btn,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:first-child>.btn-group:not(:first-child)>.btn,.input-group-btn:first-child>.btn:not(:first-child),.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group>.btn,.input-group-btn:last-child>.dropdown-toggle{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;font-size:0;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-1px}.input-group-btn>.btn:active,.input-group-btn>.btn:focus,.input-group-btn>.btn:hover{z-index:2}.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group{margin-right:-1px}.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group{z-index:2;margin-left:-1px}.nav{padding-left:0;margin-bottom:0;list-style:none}.nav>li{position:relative;display:block}.nav>li>a{position:relative;display:block;padding:10px 15px}.nav>li>a:focus,.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#777}.nav>li.disabled>a:focus,.nav>li.disabled>a:hover{color:#777;text-decoration:none;cursor:not-allowed;background-color:transparent}.nav .open>a,.nav .open>a:focus,.nav .open>a:hover{background-color:#eee;border-color:#337ab7}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.42857143;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:focus,.nav-tabs>li.active>a:hover{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-tabs.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}.nav-tabs.nav-justified>li>a{margin-bottom:0}}.nav-tabs.nav-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs.nav-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border-bottom-color:#fff}}.nav-pills>li{float:left}.nav-pills>li>a{border-radius:4px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:focus,.nav-pills>li.active>a:hover{color:#fff;background-color:#337ab7}.nav-stacked>li{float:none}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li{float:none}.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-justified>li{display:table-cell;width:1%}.nav-justified>li>a{margin-bottom:0}}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border-bottom-color:#fff}}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.navbar{position:relative;min-height:50px;margin-bottom:20px;border:1px solid transparent}@media (min-width:768px){.navbar{border-radius:4px}}@media (min-width:768px){.navbar-header{float:left}}.navbar-collapse{padding-right:15px;padding-left:15px;overflow-x:visible;-webkit-overflow-scrolling:touch;border-top:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}.navbar-collapse.in{overflow-y:auto}@media (min-width:768px){.navbar-collapse{width:auto;border-top:0;-webkit-box-shadow:none;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.navbar-static-top .navbar-collapse{padding-right:0;padding-left:0}}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:340px}@media (max-device-width:480px) and (orientation:landscape){.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:200px}}.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:0;margin-left:0}}.navbar-static-top{z-index:1000;border-width:0 0 1px}@media (min-width:768px){.navbar-static-top{border-radius:0}}.navbar-fixed-bottom,.navbar-fixed-top{position:fixed;right:0;left:0;z-index:1030}@media (min-width:768px){.navbar-fixed-bottom,.navbar-fixed-top{border-radius:0}}.navbar-fixed-top{top:0;border-width:0 0 1px}.navbar-fixed-bottom{bottom:0;margin-bottom:0;border-width:1px 0 0}.navbar-brand{float:left;height:50px;padding:15px 15px;font-size:18px;line-height:20px}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-brand>img{display:block}@media (min-width:768px){.navbar>.container .navbar-brand,.navbar>.container-fluid .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;padding:9px 10px;margin-top:8px;margin-right:15px;margin-bottom:8px;background-color:transparent;background-image:none;border:1px solid transparent;border-radius:4px}.navbar-toggle:focus{outline:0}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}@media (min-width:768px){.navbar-toggle{display:none}}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media (max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;-webkit-box-shadow:none;box-shadow:none}.navbar-nav .open .dropdown-menu .dropdown-header,.navbar-nav .open .dropdown-menu>li>a{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:focus,.navbar-nav .open .dropdown-menu>li>a:hover{background-image:none}}@media (min-width:768px){.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}.navbar-form{padding:10px 15px;margin-top:8px;margin-right:-15px;margin-bottom:8px;margin-left:-15px;border-top:1px solid transparent;border-bottom:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1)}@media (min-width:768px){.navbar-form .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block;width:auto;vertical-align:middle}.navbar-form .form-control-static{display:inline-block}.navbar-form .input-group{display:inline-table;vertical-align:middle}.navbar-form .input-group .form-control,.navbar-form .input-group .input-group-addon,.navbar-form .input-group .input-group-btn{width:auto}.navbar-form .input-group>.form-control{width:100%}.navbar-form .control-label{margin-bottom:0;vertical-align:middle}.navbar-form .checkbox,.navbar-form .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.navbar-form .checkbox label,.navbar-form .radio label{padding-left:0}.navbar-form .checkbox input[type=checkbox],.navbar-form .radio input[type=radio]{position:relative;margin-left:0}.navbar-form .has-feedback .form-control-feedback{top:0}}@media (max-width:767px){.navbar-form .form-group{margin-bottom:5px}.navbar-form .form-group:last-child{margin-bottom:0}}@media (min-width:768px){.navbar-form{width:auto;padding-top:0;padding-bottom:0;margin-right:0;margin-left:0;border:0;-webkit-box-shadow:none;box-shadow:none}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-left-radius:0;border-top-right-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{margin-bottom:0;border-top-left-radius:4px;border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-btn.btn-sm{margin-top:10px;margin-bottom:10px}.navbar-btn.btn-xs{margin-top:14px;margin-bottom:14px}.navbar-text{margin-top:15px;margin-bottom:15px}@media (min-width:768px){.navbar-text{float:left;margin-right:15px;margin-left:15px}}@media (min-width:768px){.navbar-left{float:left!important}.navbar-right{float:right!important;margin-right:-15px}.navbar-right~.navbar-right{margin-right:0}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:hover{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a{color:#777}.navbar-default .navbar-nav>li>a:focus,.navbar-default .navbar-nav>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:focus,.navbar-default .navbar-nav>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:focus,.navbar-default .navbar-nav>.disabled>a:hover{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:focus,.navbar-default .navbar-toggle:hover{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#888}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e7e7e7}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:focus,.navbar-default .navbar-nav>.open>a:hover{color:#555;background-color:#e7e7e7}@media (max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-default .btn-link{color:#777}.navbar-default .btn-link:focus,.navbar-default .btn-link:hover{color:#333}.navbar-default .btn-link[disabled]:focus,.navbar-default .btn-link[disabled]:hover,fieldset[disabled] .navbar-default .btn-link:focus,fieldset[disabled] .navbar-default .btn-link:hover{color:#ccc}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#9d9d9d}.navbar-inverse .navbar-brand:focus,.navbar-inverse .navbar-brand:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-text{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a:focus,.navbar-inverse .navbar-nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:focus,.navbar-inverse .navbar-nav>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:focus,.navbar-inverse .navbar-nav>.disabled>a:hover{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:focus,.navbar-inverse .navbar-toggle:hover{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:focus,.navbar-inverse .navbar-nav>.open>a:hover{color:#fff;background-color:#080808}@media (max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu .divider{background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#9d9d9d}.navbar-inverse .navbar-link:hover{color:#fff}.navbar-inverse .btn-link{color:#9d9d9d}.navbar-inverse .btn-link:focus,.navbar-inverse .btn-link:hover{color:#fff}.navbar-inverse .btn-link[disabled]:focus,.navbar-inverse .btn-link[disabled]:hover,fieldset[disabled] .navbar-inverse .btn-link:focus,fieldset[disabled] .navbar-inverse .btn-link:hover{color:#444}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li{display:inline-block}.breadcrumb>li+li:before{padding:0 5px;color:#ccc;content:"/\00a0"}.breadcrumb>.active{color:#777}.pagination{display:inline-block;padding-left:0;margin:20px 0;border-radius:4px}.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;margin-left:-1px;line-height:1.42857143;color:#337ab7;text-decoration:none;background-color:#fff;border:1px solid #ddd}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-top-left-radius:4px;border-bottom-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-top-right-radius:4px;border-bottom-right-radius:4px}.pagination>li>a:focus,.pagination>li>a:hover,.pagination>li>span:focus,.pagination>li>span:hover{z-index:3;color:#23527c;background-color:#eee;border-color:#ddd}.pagination>.active>a,.pagination>.active>a:focus,.pagination>.active>a:hover,.pagination>.active>span,.pagination>.active>span:focus,.pagination>.active>span:hover{z-index:2;color:#fff;cursor:default;background-color:#337ab7;border-color:#337ab7}.pagination>.disabled>a,.pagination>.disabled>a:focus,.pagination>.disabled>a:hover,.pagination>.disabled>span,.pagination>.disabled>span:focus,.pagination>.disabled>span:hover{color:#777;cursor:not-allowed;background-color:#fff;border-color:#ddd}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px;line-height:1.3333333}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-top-left-radius:6px;border-bottom-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-top-right-radius:6px;border-bottom-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px;line-height:1.5}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-top-left-radius:3px;border-bottom-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-top-right-radius:3px;border-bottom-right-radius:3px}.pager{padding-left:0;margin:20px 0;text-align:center;list-style:none}.pager li{display:inline}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:focus,.pager li>a:hover{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:focus,.pager .disabled>a:hover,.pager .disabled>span{color:#777;cursor:not-allowed;background-color:#fff}.label{display:inline;padding:.2em .6em .3em;font-size:75%;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25em}a.label:focus,a.label:hover{color:#fff;text-decoration:none;cursor:pointer}.label:empty{display:none}.btn .label{position:relative;top:-1px}.label-default{background-color:#777}.label-default[href]:focus,.label-default[href]:hover{background-color:#5e5e5e}.label-primary{background-color:#337ab7}.label-primary[href]:focus,.label-primary[href]:hover{background-color:#286090}.label-success{background-color:#5cb85c}.label-success[href]:focus,.label-success[href]:hover{background-color:#449d44}.label-info{background-color:#5bc0de}.label-info[href]:focus,.label-info[href]:hover{background-color:#31b0d5}.label-warning{background-color:#f0ad4e}.label-warning[href]:focus,.label-warning[href]:hover{background-color:#ec971f}.label-danger{background-color:#d9534f}.label-danger[href]:focus,.label-danger[href]:hover{background-color:#c9302c}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:middle;background-color:#777;border-radius:10px}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.btn-group-xs>.btn .badge,.btn-xs .badge{top:0;padding:1px 5px}a.badge:focus,a.badge:hover{color:#fff;text-decoration:none;cursor:pointer}.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#337ab7;background-color:#fff}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding-top:30px;padding-bottom:30px;margin-bottom:30px;color:inherit;background-color:#eee}.jumbotron .h1,.jumbotron h1{color:inherit}.jumbotron p{margin-bottom:15px;font-size:21px;font-weight:200}.jumbotron>hr{border-top-color:#d5d5d5}.container .jumbotron,.container-fluid .jumbotron{border-radius:6px}.jumbotron .container{max-width:100%}@media screen and (min-width:768px){.jumbotron{padding-top:48px;padding-bottom:48px}.container .jumbotron,.container-fluid .jumbotron{padding-right:60px;padding-left:60px}.jumbotron .h1,.jumbotron h1{font-size:63px}}.thumbnail{display:block;padding:4px;margin-bottom:20px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:border .2s ease-in-out;-o-transition:border .2s ease-in-out;transition:border .2s ease-in-out}.thumbnail a>img,.thumbnail>img{margin-right:auto;margin-left:auto}a.thumbnail.active,a.thumbnail:focus,a.thumbnail:hover{border-color:#337ab7}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert .alert-link{font-weight:700}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.alert-success{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,.1);box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.progress-bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;background-color:#337ab7;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.progress-bar-striped,.progress-striped .progress-bar{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);-webkit-background-size:40px 40px;background-size:40px 40px}.progress-bar.active,.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-bar-success{background-color:#5cb85c}.progress-striped .progress-bar-success{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-info{background-color:#5bc0de}.progress-striped .progress-bar-info{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#f0ad4e}.progress-striped .progress-bar-warning{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#d9534f}.progress-striped .progress-bar-danger{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.media{margin-top:15px}.media:first-child{margin-top:0}.media,.media-body{overflow:hidden;zoom:1}.media-body{width:10000px}.media-object{display:block}.media-object.img-thumbnail{max-width:none}.media-right,.media>.pull-right{padding-left:10px}.media-left,.media>.pull-left{padding-right:10px}.media-body,.media-left,.media-right{display:table-cell;vertical-align:top}.media-middle{vertical-align:middle}.media-bottom{vertical-align:bottom}.media-heading{margin-top:0;margin-bottom:5px}.media-list{padding-left:0;list-style:none}.list-group{padding-left:0;margin-bottom:20px}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}a.list-group-item,button.list-group-item{color:#555}a.list-group-item .list-group-item-heading,button.list-group-item .list-group-item-heading{color:#333}a.list-group-item:focus,a.list-group-item:hover,button.list-group-item:focus,button.list-group-item:hover{color:#555;text-decoration:none;background-color:#f5f5f5}button.list-group-item{width:100%;text-align:left}.list-group-item.disabled,.list-group-item.disabled:focus,.list-group-item.disabled:hover{color:#777;cursor:not-allowed;background-color:#eee}.list-group-item.disabled .list-group-item-heading,.list-group-item.disabled:focus .list-group-item-heading,.list-group-item.disabled:hover .list-group-item-heading{color:inherit}.list-group-item.disabled .list-group-item-text,.list-group-item.disabled:focus .list-group-item-text,.list-group-item.disabled:hover .list-group-item-text{color:#777}.list-group-item.active,.list-group-item.active:focus,.list-group-item.active:hover{z-index:2;color:#fff;background-color:#337ab7;border-color:#337ab7}.list-group-item.active .list-group-item-heading,.list-group-item.active .list-group-item-heading>.small,.list-group-item.active .list-group-item-heading>small,.list-group-item.active:focus .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading>.small,.list-group-item.active:focus .list-group-item-heading>small,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading>.small,.list-group-item.active:hover .list-group-item-heading>small{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:focus .list-group-item-text,.list-group-item.active:hover .list-group-item-text{color:#c7ddef}.list-group-item-success{color:#3c763d;background-color:#dff0d8}a.list-group-item-success,button.list-group-item-success{color:#3c763d}a.list-group-item-success .list-group-item-heading,button.list-group-item-success .list-group-item-heading{color:inherit}a.list-group-item-success:focus,a.list-group-item-success:hover,button.list-group-item-success:focus,button.list-group-item-success:hover{color:#3c763d;background-color:#d0e9c6}a.list-group-item-success.active,a.list-group-item-success.active:focus,a.list-group-item-success.active:hover,button.list-group-item-success.active,button.list-group-item-success.active:focus,button.list-group-item-success.active:hover{color:#fff;background-color:#3c763d;border-color:#3c763d}.list-group-item-info{color:#31708f;background-color:#d9edf7}a.list-group-item-info,button.list-group-item-info{color:#31708f}a.list-group-item-info .list-group-item-heading,button.list-group-item-info .list-group-item-heading{color:inherit}a.list-group-item-info:focus,a.list-group-item-info:hover,button.list-group-item-info:focus,button.list-group-item-info:hover{color:#31708f;background-color:#c4e3f3}a.list-group-item-info.active,a.list-group-item-info.active:focus,a.list-group-item-info.active:hover,button.list-group-item-info.active,button.list-group-item-info.active:focus,button.list-group-item-info.active:hover{color:#fff;background-color:#31708f;border-color:#31708f}.list-group-item-warning{color:#8a6d3b;background-color:#fcf8e3}a.list-group-item-warning,button.list-group-item-warning{color:#8a6d3b}a.list-group-item-warning .list-group-item-heading,button.list-group-item-warning .list-group-item-heading{color:inherit}a.list-group-item-warning:focus,a.list-group-item-warning:hover,button.list-group-item-warning:focus,button.list-group-item-warning:hover{color:#8a6d3b;background-color:#faf2cc}a.list-group-item-warning.active,a.list-group-item-warning.active:focus,a.list-group-item-warning.active:hover,button.list-group-item-warning.active,button.list-group-item-warning.active:focus,button.list-group-item-warning.active:hover{color:#fff;background-color:#8a6d3b;border-color:#8a6d3b}.list-group-item-danger{color:#a94442;background-color:#f2dede}a.list-group-item-danger,button.list-group-item-danger{color:#a94442}a.list-group-item-danger .list-group-item-heading,button.list-group-item-danger .list-group-item-heading{color:inherit}a.list-group-item-danger:focus,a.list-group-item-danger:hover,button.list-group-item-danger:focus,button.list-group-item-danger:hover{color:#a94442;background-color:#ebcccc}a.list-group-item-danger.active,a.list-group-item-danger.active:focus,a.list-group-item-danger.active:hover,button.list-group-item-danger.active,button.list-group-item-danger.active:focus,button.list-group-item-danger.active:hover{color:#fff;background-color:#a94442;border-color:#a94442}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,.05);box-shadow:0 1px 1px rgba(0,0,0,.05)}.panel-body{padding:15px}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-left-radius:3px;border-top-right-radius:3px}.panel-heading>.dropdown .dropdown-toggle{color:inherit}.panel-title{margin-top:0;margin-bottom:0;font-size:16px;color:inherit}.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.list-group,.panel>.panel-collapse>.list-group{margin-bottom:0}.panel>.list-group .list-group-item,.panel>.panel-collapse>.list-group .list-group-item{border-width:1px 0;border-radius:0}.panel>.list-group:first-child .list-group-item:first-child,.panel>.panel-collapse>.list-group:first-child .list-group-item:first-child{border-top:0;border-top-left-radius:3px;border-top-right-radius:3px}.panel>.list-group:last-child .list-group-item:last-child,.panel>.panel-collapse>.list-group:last-child .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.panel-heading+.panel-collapse>.list-group .list-group-item:first-child{border-top-left-radius:0;border-top-right-radius:0}.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.list-group+.panel-footer{border-top-width:0}.panel>.panel-collapse>.table,.panel>.table,.panel>.table-responsive>.table{margin-bottom:0}.panel>.panel-collapse>.table caption,.panel>.table caption,.panel>.table-responsive>.table caption{padding-right:15px;padding-left:15px}.panel>.table-responsive:first-child>.table:first-child,.panel>.table:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child,.panel>.table:first-child>thead:first-child>tr:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table:first-child>thead:first-child>tr:first-child th:first-child{border-top-left-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table:first-child>thead:first-child>tr:first-child th:last-child{border-top-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child,.panel>.table:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:first-child{border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:last-child{border-bottom-right-radius:3px}.panel>.panel-body+.table,.panel>.panel-body+.table-responsive,.panel>.table+.panel-body,.panel>.table-responsive+.panel-body{border-top:1px solid #ddd}.panel>.table>tbody:first-child>tr:first-child td,.panel>.table>tbody:first-child>tr:first-child th{border-top:0}.panel>.table-bordered,.panel>.table-responsive>.table-bordered{border:0}.panel>.table-bordered>tbody>tr>td:first-child,.panel>.table-bordered>tbody>tr>th:first-child,.panel>.table-bordered>tfoot>tr>td:first-child,.panel>.table-bordered>tfoot>tr>th:first-child,.panel>.table-bordered>thead>tr>td:first-child,.panel>.table-bordered>thead>tr>th:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:first-child,.panel>.table-responsive>.table-bordered>thead>tr>td:first-child,.panel>.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.panel>.table-bordered>tbody>tr>td:last-child,.panel>.table-bordered>tbody>tr>th:last-child,.panel>.table-bordered>tfoot>tr>td:last-child,.panel>.table-bordered>tfoot>tr>th:last-child,.panel>.table-bordered>thead>tr>td:last-child,.panel>.table-bordered>thead>tr>th:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:last-child,.panel>.table-responsive>.table-bordered>thead>tr>td:last-child,.panel>.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.panel>.table-bordered>tbody>tr:first-child>td,.panel>.table-bordered>tbody>tr:first-child>th,.panel>.table-bordered>thead>tr:first-child>td,.panel>.table-bordered>thead>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>th,.panel>.table-responsive>.table-bordered>thead>tr:first-child>td,.panel>.table-responsive>.table-bordered>thead>tr:first-child>th{border-bottom:0}.panel>.table-bordered>tbody>tr:last-child>td,.panel>.table-bordered>tbody>tr:last-child>th,.panel>.table-bordered>tfoot>tr:last-child>td,.panel>.table-bordered>tfoot>tr:last-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>th,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>td,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}.panel>.table-responsive{margin-bottom:0;border:0}.panel-group{margin-bottom:20px}.panel-group .panel{margin-bottom:0;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading{border-bottom:0}.panel-group .panel-heading+.panel-collapse>.list-group,.panel-group .panel-heading+.panel-collapse>.panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ddd}.panel-default>.panel-heading .badge{color:#f5f5f5;background-color:#333}.panel-default>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#337ab7}.panel-primary>.panel-heading{color:#fff;background-color:#337ab7;border-color:#337ab7}.panel-primary>.panel-heading+.panel-collapse>.panel-body{border-top-color:#337ab7}.panel-primary>.panel-heading .badge{color:#337ab7;background-color:#fff}.panel-primary>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#337ab7}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse>.panel-body{border-top-color:#d6e9c6}.panel-success>.panel-heading .badge{color:#dff0d8;background-color:#3c763d}.panel-success>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#d6e9c6}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse>.panel-body{border-top-color:#bce8f1}.panel-info>.panel-heading .badge{color:#d9edf7;background-color:#31708f}.panel-info>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#bce8f1}.panel-warning{border-color:#faebcc}.panel-warning>.panel-heading{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.panel-warning>.panel-heading+.panel-collapse>.panel-body{border-top-color:#faebcc}.panel-warning>.panel-heading .badge{color:#fcf8e3;background-color:#8a6d3b}.panel-warning>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#faebcc}.panel-danger{border-color:#ebccd1}.panel-danger>.panel-heading{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.panel-danger>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ebccd1}.panel-danger>.panel-heading .badge{color:#f2dede;background-color:#a94442}.panel-danger>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ebccd1}.embed-responsive{position:relative;display:block;height:0;padding:0;overflow:hidden}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-16by9{padding-bottom:56.25%}.embed-responsive-4by3{padding-bottom:75%}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.05);box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;filter:alpha(opacity=20);opacity:.2}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer;filter:alpha(opacity=50);opacity:.5}button.close{-webkit-appearance:none;padding:0;cursor:pointer;background:0 0;border:0}.modal-open{overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;-webkit-overflow-scrolling:touch;outline:0}.modal.fade .modal-dialog{-webkit-transition:-webkit-transform .3s ease-out;-o-transition:-o-transform .3s ease-out;transition:transform .3s ease-out;-webkit-transform:translate(0,-25%);-ms-transform:translate(0,-25%);-o-transform:translate(0,-25%);transform:translate(0,-25%)}.modal.in .modal-dialog{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);-o-transform:translate(0,0);transform:translate(0,0)}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:10px}.modal-content{position:relative;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #999;border:1px solid rgba(0,0,0,.2);border-radius:6px;outline:0;-webkit-box-shadow:0 3px 9px rgba(0,0,0,.5);box-shadow:0 3px 9px rgba(0,0,0,.5)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{filter:alpha(opacity=0);opacity:0}.modal-backdrop.in{filter:alpha(opacity=50);opacity:.5}.modal-header{min-height:16.43px;padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.42857143}.modal-body{position:relative;padding:15px}.modal-footer{padding:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:768px){.modal-dialog{width:600px;margin:30px auto}.modal-content{-webkit-box-shadow:0 5px 15px rgba(0,0,0,.5);box-shadow:0 5px 15px rgba(0,0,0,.5)}.modal-sm{width:300px}}@media (min-width:992px){.modal-lg{width:900px}}.tooltip{position:absolute;z-index:1070;display:block;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:12px;font-style:normal;font-weight:400;line-height:1.42857143;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;word-wrap:normal;white-space:normal;filter:alpha(opacity=0);opacity:0;line-break:auto}.tooltip.in{filter:alpha(opacity=90);opacity:.9}.tooltip.top{padding:5px 0;margin-top:-3px}.tooltip.right{padding:0 5px;margin-left:3px}.tooltip.bottom{padding:5px 0;margin-top:3px}.tooltip.left{padding:0 5px;margin-left:-3px}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-left .tooltip-arrow{right:5px;bottom:0;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-right .tooltip-arrow{bottom:0;left:5px;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-width:5px 5px 5px 0;border-right-color:#000}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-width:5px 0 5px 5px;border-left-color:#000}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-left .tooltip-arrow{top:0;right:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-right .tooltip-arrow{top:0;left:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.popover{position:absolute;top:0;left:0;z-index:1060;display:none;max-width:276px;padding:1px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;font-style:normal;font-weight:400;line-height:1.42857143;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;word-wrap:normal;white-space:normal;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,.2);box-shadow:0 5px 10px rgba(0,0,0,.2);line-break:auto}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{padding:8px 14px;margin:0;font-size:14px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.popover>.arrow,.popover>.arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.popover>.arrow{border-width:11px}.popover>.arrow:after{content:"";border-width:10px}.popover.top>.arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,.25);border-bottom-width:0}.popover.top>.arrow:after{bottom:1px;margin-left:-10px;content:" ";border-top-color:#fff;border-bottom-width:0}.popover.right>.arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,.25);border-left-width:0}.popover.right>.arrow:after{bottom:-10px;left:1px;content:" ";border-right-color:#fff;border-left-width:0}.popover.bottom>.arrow{top:-11px;left:50%;margin-left:-11px;border-top-width:0;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,.25)}.popover.bottom>.arrow:after{top:1px;margin-left:-10px;content:" ";border-top-width:0;border-bottom-color:#fff}.popover.left>.arrow{top:50%;right:-11px;margin-top:-11px;border-right-width:0;border-left-color:#999;border-left-color:rgba(0,0,0,.25)}.popover.left>.arrow:after{right:1px;bottom:-10px;content:" ";border-right-width:0;border-left-color:#fff}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;-o-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>a>img,.carousel-inner>.item>img{line-height:1}@media all and (transform-3d),(-webkit-transform-3d){.carousel-inner>.item{-webkit-transition:-webkit-transform .6s ease-in-out;-o-transition:-o-transform .6s ease-in-out;transition:transform .6s ease-in-out;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-inner>.item.active.right,.carousel-inner>.item.next{left:0;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}.carousel-inner>.item.active.left,.carousel-inner>.item.prev{left:0;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}.carousel-inner>.item.active,.carousel-inner>.item.next.left,.carousel-inner>.item.prev.right{left:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;bottom:0;left:0;width:15%;font-size:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6);filter:alpha(opacity=50);opacity:.5}.carousel-control.left{background-image:-webkit-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,.0001)));background-image:linear-gradient(to right,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);background-repeat:repeat-x}.carousel-control.right{right:0;left:auto;background-image:-webkit-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.0001)),to(rgba(0,0,0,.5)));background-image:linear-gradient(to right,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);background-repeat:repeat-x}.carousel-control:focus,.carousel-control:hover{color:#fff;text-decoration:none;filter:alpha(opacity=90);outline:0;opacity:.9}.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{position:absolute;top:50%;z-index:5;display:inline-block;margin-top:-10px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{left:50%;margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{right:50%;margin-right:-10px}.carousel-control .icon-next,.carousel-control .icon-prev{width:20px;height:20px;font-family:serif;line-height:1}.carousel-control .icon-prev:before{content:'\2039'}.carousel-control .icon-next:before{content:'\203a'}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;padding-left:0;margin-left:-30%;text-align:center;list-style:none}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;cursor:pointer;background-color:#000\9;background-color:rgba(0,0,0,0);border:1px solid #fff;border-radius:10px}.carousel-indicators .active{width:12px;height:12px;margin:0;background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6)}.carousel-caption .btn{text-shadow:none}@media screen and (min-width:768px){.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{width:30px;height:30px;margin-top:-15px;font-size:30px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{margin-left:-15px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{margin-right:-15px}.carousel-caption{right:20%;left:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.btn-group-vertical>.btn-group:after,.btn-group-vertical>.btn-group:before,.btn-toolbar:after,.btn-toolbar:before,.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.pager:after,.pager:before,.panel-body:after,.panel-body:before,.row:after,.row:before{display:table;content:" "}.btn-group-vertical>.btn-group:after,.btn-toolbar:after,.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.pager:after,.panel-body:after,.row:after{clear:both}.center-block{display:block;margin-right:auto;margin-left:auto}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.hidden{display:none!important}.affix{position:fixed}@-ms-viewport{width:device-width}.visible-lg,.visible-md,.visible-sm,.visible-xs{display:none!important}.visible-lg-block,.visible-lg-inline,.visible-lg-inline-block,.visible-md-block,.visible-md-inline,.visible-md-inline-block,.visible-sm-block,.visible-sm-inline,.visible-sm-inline-block,.visible-xs-block,.visible-xs-inline,.visible-xs-inline-block{display:none!important}@media (max-width:767px){.visible-xs{display:block!important}table.visible-xs{display:table!important}tr.visible-xs{display:table-row!important}td.visible-xs,th.visible-xs{display:table-cell!important}}@media (max-width:767px){.visible-xs-block{display:block!important}}@media (max-width:767px){.visible-xs-inline{display:inline!important}}@media (max-width:767px){.visible-xs-inline-block{display:inline-block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm{display:block!important}table.visible-sm{display:table!important}tr.visible-sm{display:table-row!important}td.visible-sm,th.visible-sm{display:table-cell!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-block{display:block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-inline{display:inline!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-inline-block{display:inline-block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md{display:block!important}table.visible-md{display:table!important}tr.visible-md{display:table-row!important}td.visible-md,th.visible-md{display:table-cell!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-block{display:block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-inline{display:inline!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-inline-block{display:inline-block!important}}@media (min-width:1200px){.visible-lg{display:block!important}table.visible-lg{display:table!important}tr.visible-lg{display:table-row!important}td.visible-lg,th.visible-lg{display:table-cell!important}}@media (min-width:1200px){.visible-lg-block{display:block!important}}@media (min-width:1200px){.visible-lg-inline{display:inline!important}}@media (min-width:1200px){.visible-lg-inline-block{display:inline-block!important}}@media (max-width:767px){.hidden-xs{display:none!important}}@media (min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}}@media (min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}}@media (min-width:1200px){.hidden-lg{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:block!important}table.visible-print{display:table!important}tr.visible-print{display:table-row!important}td.visible-print,th.visible-print{display:table-cell!important}}.visible-print-block{display:none!important}@media print{.visible-print-block{display:block!important}}.visible-print-inline{display:none!important}@media print{.visible-print-inline{display:inline!important}}.visible-print-inline-block{display:none!important}@media print{.visible-print-inline-block{display:inline-block!important}}@media print{.hidden-print{display:none!important}} -</style> -<script>/*! - * Bootstrap v3.3.5 (http://getbootstrap.com) - * Copyright 2011-2015 Twitter, Inc. - * Licensed under the MIT license - */ -if("undefined"==typeof jQuery)throw new Error("Bootstrap's JavaScript requires jQuery");+function(a){"use strict";var b=a.fn.jquery.split(" ")[0].split(".");if(b[0]<2&&b[1]<9||1==b[0]&&9==b[1]&&b[2]<1)throw new Error("Bootstrap's JavaScript requires jQuery version 1.9.1 or higher")}(jQuery),+function(a){"use strict";function b(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"};for(var c in b)if(void 0!==a.style[c])return{end:b[c]};return!1}a.fn.emulateTransitionEnd=function(b){var c=!1,d=this;a(this).one("bsTransitionEnd",function(){c=!0});var e=function(){c||a(d).trigger(a.support.transition.end)};return setTimeout(e,b),this},a(function(){a.support.transition=b(),a.support.transition&&(a.event.special.bsTransitionEnd={bindType:a.support.transition.end,delegateType:a.support.transition.end,handle:function(b){return a(b.target).is(this)?b.handleObj.handler.apply(this,arguments):void 0}})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var c=a(this),e=c.data("bs.alert");e||c.data("bs.alert",e=new d(this)),"string"==typeof b&&e[b].call(c)})}var c='[data-dismiss="alert"]',d=function(b){a(b).on("click",c,this.close)};d.VERSION="3.3.5",d.TRANSITION_DURATION=150,d.prototype.close=function(b){function c(){g.detach().trigger("closed.bs.alert").remove()}var e=a(this),f=e.attr("data-target");f||(f=e.attr("href"),f=f&&f.replace(/.*(?=#[^\s]*$)/,""));var g=a(f);b&&b.preventDefault(),g.length||(g=e.closest(".alert")),g.trigger(b=a.Event("close.bs.alert")),b.isDefaultPrevented()||(g.removeClass("in"),a.support.transition&&g.hasClass("fade")?g.one("bsTransitionEnd",c).emulateTransitionEnd(d.TRANSITION_DURATION):c())};var e=a.fn.alert;a.fn.alert=b,a.fn.alert.Constructor=d,a.fn.alert.noConflict=function(){return a.fn.alert=e,this},a(document).on("click.bs.alert.data-api",c,d.prototype.close)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.button"),f="object"==typeof b&&b;e||d.data("bs.button",e=new c(this,f)),"toggle"==b?e.toggle():b&&e.setState(b)})}var c=function(b,d){this.$element=a(b),this.options=a.extend({},c.DEFAULTS,d),this.isLoading=!1};c.VERSION="3.3.5",c.DEFAULTS={loadingText:"loading..."},c.prototype.setState=function(b){var c="disabled",d=this.$element,e=d.is("input")?"val":"html",f=d.data();b+="Text",null==f.resetText&&d.data("resetText",d[e]()),setTimeout(a.proxy(function(){d[e](null==f[b]?this.options[b]:f[b]),"loadingText"==b?(this.isLoading=!0,d.addClass(c).attr(c,c)):this.isLoading&&(this.isLoading=!1,d.removeClass(c).removeAttr(c))},this),0)},c.prototype.toggle=function(){var a=!0,b=this.$element.closest('[data-toggle="buttons"]');if(b.length){var c=this.$element.find("input");"radio"==c.prop("type")?(c.prop("checked")&&(a=!1),b.find(".active").removeClass("active"),this.$element.addClass("active")):"checkbox"==c.prop("type")&&(c.prop("checked")!==this.$element.hasClass("active")&&(a=!1),this.$element.toggleClass("active")),c.prop("checked",this.$element.hasClass("active")),a&&c.trigger("change")}else this.$element.attr("aria-pressed",!this.$element.hasClass("active")),this.$element.toggleClass("active")};var d=a.fn.button;a.fn.button=b,a.fn.button.Constructor=c,a.fn.button.noConflict=function(){return a.fn.button=d,this},a(document).on("click.bs.button.data-api",'[data-toggle^="button"]',function(c){var d=a(c.target);d.hasClass("btn")||(d=d.closest(".btn")),b.call(d,"toggle"),a(c.target).is('input[type="radio"]')||a(c.target).is('input[type="checkbox"]')||c.preventDefault()}).on("focus.bs.button.data-api blur.bs.button.data-api",'[data-toggle^="button"]',function(b){a(b.target).closest(".btn").toggleClass("focus",/^focus(in)?$/.test(b.type))})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.carousel"),f=a.extend({},c.DEFAULTS,d.data(),"object"==typeof b&&b),g="string"==typeof b?b:f.slide;e||d.data("bs.carousel",e=new c(this,f)),"number"==typeof b?e.to(b):g?e[g]():f.interval&&e.pause().cycle()})}var c=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.paused=null,this.sliding=null,this.interval=null,this.$active=null,this.$items=null,this.options.keyboard&&this.$element.on("keydown.bs.carousel",a.proxy(this.keydown,this)),"hover"==this.options.pause&&!("ontouchstart"in document.documentElement)&&this.$element.on("mouseenter.bs.carousel",a.proxy(this.pause,this)).on("mouseleave.bs.carousel",a.proxy(this.cycle,this))};c.VERSION="3.3.5",c.TRANSITION_DURATION=600,c.DEFAULTS={interval:5e3,pause:"hover",wrap:!0,keyboard:!0},c.prototype.keydown=function(a){if(!/input|textarea/i.test(a.target.tagName)){switch(a.which){case 37:this.prev();break;case 39:this.next();break;default:return}a.preventDefault()}},c.prototype.cycle=function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},c.prototype.getItemIndex=function(a){return this.$items=a.parent().children(".item"),this.$items.index(a||this.$active)},c.prototype.getItemForDirection=function(a,b){var c=this.getItemIndex(b),d="prev"==a&&0===c||"next"==a&&c==this.$items.length-1;if(d&&!this.options.wrap)return b;var e="prev"==a?-1:1,f=(c+e)%this.$items.length;return this.$items.eq(f)},c.prototype.to=function(a){var b=this,c=this.getItemIndex(this.$active=this.$element.find(".item.active"));return a>this.$items.length-1||0>a?void 0:this.sliding?this.$element.one("slid.bs.carousel",function(){b.to(a)}):c==a?this.pause().cycle():this.slide(a>c?"next":"prev",this.$items.eq(a))},c.prototype.pause=function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),this.interval=clearInterval(this.interval),this},c.prototype.next=function(){return this.sliding?void 0:this.slide("next")},c.prototype.prev=function(){return this.sliding?void 0:this.slide("prev")},c.prototype.slide=function(b,d){var e=this.$element.find(".item.active"),f=d||this.getItemForDirection(b,e),g=this.interval,h="next"==b?"left":"right",i=this;if(f.hasClass("active"))return this.sliding=!1;var j=f[0],k=a.Event("slide.bs.carousel",{relatedTarget:j,direction:h});if(this.$element.trigger(k),!k.isDefaultPrevented()){if(this.sliding=!0,g&&this.pause(),this.$indicators.length){this.$indicators.find(".active").removeClass("active");var l=a(this.$indicators.children()[this.getItemIndex(f)]);l&&l.addClass("active")}var m=a.Event("slid.bs.carousel",{relatedTarget:j,direction:h});return a.support.transition&&this.$element.hasClass("slide")?(f.addClass(b),f[0].offsetWidth,e.addClass(h),f.addClass(h),e.one("bsTransitionEnd",function(){f.removeClass([b,h].join(" ")).addClass("active"),e.removeClass(["active",h].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger(m)},0)}).emulateTransitionEnd(c.TRANSITION_DURATION)):(e.removeClass("active"),f.addClass("active"),this.sliding=!1,this.$element.trigger(m)),g&&this.cycle(),this}};var d=a.fn.carousel;a.fn.carousel=b,a.fn.carousel.Constructor=c,a.fn.carousel.noConflict=function(){return a.fn.carousel=d,this};var e=function(c){var d,e=a(this),f=a(e.attr("data-target")||(d=e.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""));if(f.hasClass("carousel")){var g=a.extend({},f.data(),e.data()),h=e.attr("data-slide-to");h&&(g.interval=!1),b.call(f,g),h&&f.data("bs.carousel").to(h),c.preventDefault()}};a(document).on("click.bs.carousel.data-api","[data-slide]",e).on("click.bs.carousel.data-api","[data-slide-to]",e),a(window).on("load",function(){a('[data-ride="carousel"]').each(function(){var c=a(this);b.call(c,c.data())})})}(jQuery),+function(a){"use strict";function b(b){var c,d=b.attr("data-target")||(c=b.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,"");return a(d)}function c(b){return this.each(function(){var c=a(this),e=c.data("bs.collapse"),f=a.extend({},d.DEFAULTS,c.data(),"object"==typeof b&&b);!e&&f.toggle&&/show|hide/.test(b)&&(f.toggle=!1),e||c.data("bs.collapse",e=new d(this,f)),"string"==typeof b&&e[b]()})}var d=function(b,c){this.$element=a(b),this.options=a.extend({},d.DEFAULTS,c),this.$trigger=a('[data-toggle="collapse"][href="#'+b.id+'"],[data-toggle="collapse"][data-target="#'+b.id+'"]'),this.transitioning=null,this.options.parent?this.$parent=this.getParent():this.addAriaAndCollapsedClass(this.$element,this.$trigger),this.options.toggle&&this.toggle()};d.VERSION="3.3.5",d.TRANSITION_DURATION=350,d.DEFAULTS={toggle:!0},d.prototype.dimension=function(){var a=this.$element.hasClass("width");return a?"width":"height"},d.prototype.show=function(){if(!this.transitioning&&!this.$element.hasClass("in")){var b,e=this.$parent&&this.$parent.children(".panel").children(".in, .collapsing");if(!(e&&e.length&&(b=e.data("bs.collapse"),b&&b.transitioning))){var f=a.Event("show.bs.collapse");if(this.$element.trigger(f),!f.isDefaultPrevented()){e&&e.length&&(c.call(e,"hide"),b||e.data("bs.collapse",null));var g=this.dimension();this.$element.removeClass("collapse").addClass("collapsing")[g](0).attr("aria-expanded",!0),this.$trigger.removeClass("collapsed").attr("aria-expanded",!0),this.transitioning=1;var h=function(){this.$element.removeClass("collapsing").addClass("collapse in")[g](""),this.transitioning=0,this.$element.trigger("shown.bs.collapse")};if(!a.support.transition)return h.call(this);var i=a.camelCase(["scroll",g].join("-"));this.$element.one("bsTransitionEnd",a.proxy(h,this)).emulateTransitionEnd(d.TRANSITION_DURATION)[g](this.$element[0][i])}}}},d.prototype.hide=function(){if(!this.transitioning&&this.$element.hasClass("in")){var b=a.Event("hide.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.dimension();this.$element[c](this.$element[c]())[0].offsetHeight,this.$element.addClass("collapsing").removeClass("collapse in").attr("aria-expanded",!1),this.$trigger.addClass("collapsed").attr("aria-expanded",!1),this.transitioning=1;var e=function(){this.transitioning=0,this.$element.removeClass("collapsing").addClass("collapse").trigger("hidden.bs.collapse")};return a.support.transition?void this.$element[c](0).one("bsTransitionEnd",a.proxy(e,this)).emulateTransitionEnd(d.TRANSITION_DURATION):e.call(this)}}},d.prototype.toggle=function(){this[this.$element.hasClass("in")?"hide":"show"]()},d.prototype.getParent=function(){return a(this.options.parent).find('[data-toggle="collapse"][data-parent="'+this.options.parent+'"]').each(a.proxy(function(c,d){var e=a(d);this.addAriaAndCollapsedClass(b(e),e)},this)).end()},d.prototype.addAriaAndCollapsedClass=function(a,b){var c=a.hasClass("in");a.attr("aria-expanded",c),b.toggleClass("collapsed",!c).attr("aria-expanded",c)};var e=a.fn.collapse;a.fn.collapse=c,a.fn.collapse.Constructor=d,a.fn.collapse.noConflict=function(){return a.fn.collapse=e,this},a(document).on("click.bs.collapse.data-api",'[data-toggle="collapse"]',function(d){var e=a(this);e.attr("data-target")||d.preventDefault();var f=b(e),g=f.data("bs.collapse"),h=g?"toggle":e.data();c.call(f,h)})}(jQuery),+function(a){"use strict";function b(b){var c=b.attr("data-target");c||(c=b.attr("href"),c=c&&/#[A-Za-z]/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,""));var d=c&&a(c);return d&&d.length?d:b.parent()}function c(c){c&&3===c.which||(a(e).remove(),a(f).each(function(){var d=a(this),e=b(d),f={relatedTarget:this};e.hasClass("open")&&(c&&"click"==c.type&&/input|textarea/i.test(c.target.tagName)&&a.contains(e[0],c.target)||(e.trigger(c=a.Event("hide.bs.dropdown",f)),c.isDefaultPrevented()||(d.attr("aria-expanded","false"),e.removeClass("open").trigger("hidden.bs.dropdown",f))))}))}function d(b){return this.each(function(){var c=a(this),d=c.data("bs.dropdown");d||c.data("bs.dropdown",d=new g(this)),"string"==typeof b&&d[b].call(c)})}var e=".dropdown-backdrop",f='[data-toggle="dropdown"]',g=function(b){a(b).on("click.bs.dropdown",this.toggle)};g.VERSION="3.3.5",g.prototype.toggle=function(d){var e=a(this);if(!e.is(".disabled, :disabled")){var f=b(e),g=f.hasClass("open");if(c(),!g){"ontouchstart"in document.documentElement&&!f.closest(".navbar-nav").length&&a(document.createElement("div")).addClass("dropdown-backdrop").insertAfter(a(this)).on("click",c);var h={relatedTarget:this};if(f.trigger(d=a.Event("show.bs.dropdown",h)),d.isDefaultPrevented())return;e.trigger("focus").attr("aria-expanded","true"),f.toggleClass("open").trigger("shown.bs.dropdown",h)}return!1}},g.prototype.keydown=function(c){if(/(38|40|27|32)/.test(c.which)&&!/input|textarea/i.test(c.target.tagName)){var d=a(this);if(c.preventDefault(),c.stopPropagation(),!d.is(".disabled, :disabled")){var e=b(d),g=e.hasClass("open");if(!g&&27!=c.which||g&&27==c.which)return 27==c.which&&e.find(f).trigger("focus"),d.trigger("click");var h=" li:not(.disabled):visible a",i=e.find(".dropdown-menu"+h);if(i.length){var j=i.index(c.target);38==c.which&&j>0&&j--,40==c.which&&j<i.length-1&&j++,~j||(j=0),i.eq(j).trigger("focus")}}}};var h=a.fn.dropdown;a.fn.dropdown=d,a.fn.dropdown.Constructor=g,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=h,this},a(document).on("click.bs.dropdown.data-api",c).on("click.bs.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.bs.dropdown.data-api",f,g.prototype.toggle).on("keydown.bs.dropdown.data-api",f,g.prototype.keydown).on("keydown.bs.dropdown.data-api",".dropdown-menu",g.prototype.keydown)}(jQuery),+function(a){"use strict";function b(b,d){return this.each(function(){var e=a(this),f=e.data("bs.modal"),g=a.extend({},c.DEFAULTS,e.data(),"object"==typeof b&&b);f||e.data("bs.modal",f=new c(this,g)),"string"==typeof b?f[b](d):g.show&&f.show(d)})}var c=function(b,c){this.options=c,this.$body=a(document.body),this.$element=a(b),this.$dialog=this.$element.find(".modal-dialog"),this.$backdrop=null,this.isShown=null,this.originalBodyPad=null,this.scrollbarWidth=0,this.ignoreBackdropClick=!1,this.options.remote&&this.$element.find(".modal-content").load(this.options.remote,a.proxy(function(){this.$element.trigger("loaded.bs.modal")},this))};c.VERSION="3.3.5",c.TRANSITION_DURATION=300,c.BACKDROP_TRANSITION_DURATION=150,c.DEFAULTS={backdrop:!0,keyboard:!0,show:!0},c.prototype.toggle=function(a){return this.isShown?this.hide():this.show(a)},c.prototype.show=function(b){var d=this,e=a.Event("show.bs.modal",{relatedTarget:b});this.$element.trigger(e),this.isShown||e.isDefaultPrevented()||(this.isShown=!0,this.checkScrollbar(),this.setScrollbar(),this.$body.addClass("modal-open"),this.escape(),this.resize(),this.$element.on("click.dismiss.bs.modal",'[data-dismiss="modal"]',a.proxy(this.hide,this)),this.$dialog.on("mousedown.dismiss.bs.modal",function(){d.$element.one("mouseup.dismiss.bs.modal",function(b){a(b.target).is(d.$element)&&(d.ignoreBackdropClick=!0)})}),this.backdrop(function(){var e=a.support.transition&&d.$element.hasClass("fade");d.$element.parent().length||d.$element.appendTo(d.$body),d.$element.show().scrollTop(0),d.adjustDialog(),e&&d.$element[0].offsetWidth,d.$element.addClass("in"),d.enforceFocus();var f=a.Event("shown.bs.modal",{relatedTarget:b});e?d.$dialog.one("bsTransitionEnd",function(){d.$element.trigger("focus").trigger(f)}).emulateTransitionEnd(c.TRANSITION_DURATION):d.$element.trigger("focus").trigger(f)}))},c.prototype.hide=function(b){b&&b.preventDefault(),b=a.Event("hide.bs.modal"),this.$element.trigger(b),this.isShown&&!b.isDefaultPrevented()&&(this.isShown=!1,this.escape(),this.resize(),a(document).off("focusin.bs.modal"),this.$element.removeClass("in").off("click.dismiss.bs.modal").off("mouseup.dismiss.bs.modal"),this.$dialog.off("mousedown.dismiss.bs.modal"),a.support.transition&&this.$element.hasClass("fade")?this.$element.one("bsTransitionEnd",a.proxy(this.hideModal,this)).emulateTransitionEnd(c.TRANSITION_DURATION):this.hideModal())},c.prototype.enforceFocus=function(){a(document).off("focusin.bs.modal").on("focusin.bs.modal",a.proxy(function(a){this.$element[0]===a.target||this.$element.has(a.target).length||this.$element.trigger("focus")},this))},c.prototype.escape=function(){this.isShown&&this.options.keyboard?this.$element.on("keydown.dismiss.bs.modal",a.proxy(function(a){27==a.which&&this.hide()},this)):this.isShown||this.$element.off("keydown.dismiss.bs.modal")},c.prototype.resize=function(){this.isShown?a(window).on("resize.bs.modal",a.proxy(this.handleUpdate,this)):a(window).off("resize.bs.modal")},c.prototype.hideModal=function(){var a=this;this.$element.hide(),this.backdrop(function(){a.$body.removeClass("modal-open"),a.resetAdjustments(),a.resetScrollbar(),a.$element.trigger("hidden.bs.modal")})},c.prototype.removeBackdrop=function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},c.prototype.backdrop=function(b){var d=this,e=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var f=a.support.transition&&e;if(this.$backdrop=a(document.createElement("div")).addClass("modal-backdrop "+e).appendTo(this.$body),this.$element.on("click.dismiss.bs.modal",a.proxy(function(a){return this.ignoreBackdropClick?void(this.ignoreBackdropClick=!1):void(a.target===a.currentTarget&&("static"==this.options.backdrop?this.$element[0].focus():this.hide()))},this)),f&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in"),!b)return;f?this.$backdrop.one("bsTransitionEnd",b).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):b()}else if(!this.isShown&&this.$backdrop){this.$backdrop.removeClass("in");var g=function(){d.removeBackdrop(),b&&b()};a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one("bsTransitionEnd",g).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):g()}else b&&b()},c.prototype.handleUpdate=function(){this.adjustDialog()},c.prototype.adjustDialog=function(){var a=this.$element[0].scrollHeight>document.documentElement.clientHeight;this.$element.css({paddingLeft:!this.bodyIsOverflowing&&a?this.scrollbarWidth:"",paddingRight:this.bodyIsOverflowing&&!a?this.scrollbarWidth:""})},c.prototype.resetAdjustments=function(){this.$element.css({paddingLeft:"",paddingRight:""})},c.prototype.checkScrollbar=function(){var a=window.innerWidth;if(!a){var b=document.documentElement.getBoundingClientRect();a=b.right-Math.abs(b.left)}this.bodyIsOverflowing=document.body.clientWidth<a,this.scrollbarWidth=this.measureScrollbar()},c.prototype.setScrollbar=function(){var a=parseInt(this.$body.css("padding-right")||0,10);this.originalBodyPad=document.body.style.paddingRight||"",this.bodyIsOverflowing&&this.$body.css("padding-right",a+this.scrollbarWidth)},c.prototype.resetScrollbar=function(){this.$body.css("padding-right",this.originalBodyPad)},c.prototype.measureScrollbar=function(){var a=document.createElement("div");a.className="modal-scrollbar-measure",this.$body.append(a);var b=a.offsetWidth-a.clientWidth;return this.$body[0].removeChild(a),b};var d=a.fn.modal;a.fn.modal=b,a.fn.modal.Constructor=c,a.fn.modal.noConflict=function(){return a.fn.modal=d,this},a(document).on("click.bs.modal.data-api",'[data-toggle="modal"]',function(c){var d=a(this),e=d.attr("href"),f=a(d.attr("data-target")||e&&e.replace(/.*(?=#[^\s]+$)/,"")),g=f.data("bs.modal")?"toggle":a.extend({remote:!/#/.test(e)&&e},f.data(),d.data());d.is("a")&&c.preventDefault(),f.one("show.bs.modal",function(a){a.isDefaultPrevented()||f.one("hidden.bs.modal",function(){d.is(":visible")&&d.trigger("focus")})}),b.call(f,g,this)})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tooltip"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.tooltip",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.type=null,this.options=null,this.enabled=null,this.timeout=null,this.hoverState=null,this.$element=null,this.inState=null,this.init("tooltip",a,b)};c.VERSION="3.3.5",c.TRANSITION_DURATION=150,c.DEFAULTS={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1,viewport:{selector:"body",padding:0}},c.prototype.init=function(b,c,d){if(this.enabled=!0,this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.$viewport=this.options.viewport&&a(a.isFunction(this.options.viewport)?this.options.viewport.call(this,this.$element):this.options.viewport.selector||this.options.viewport),this.inState={click:!1,hover:!1,focus:!1},this.$element[0]instanceof document.constructor&&!this.options.selector)throw new Error("`selector` option must be specified when initializing "+this.type+" on the window.document object!");for(var e=this.options.trigger.split(" "),f=e.length;f--;){var g=e[f];if("click"==g)this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this));else if("manual"!=g){var h="hover"==g?"mouseenter":"focusin",i="hover"==g?"mouseleave":"focusout";this.$element.on(h+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(i+"."+this.type,this.options.selector,a.proxy(this.leave,this))}}this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.getOptions=function(b){return b=a.extend({},this.getDefaults(),this.$element.data(),b),b.delay&&"number"==typeof b.delay&&(b.delay={show:b.delay,hide:b.delay}),b},c.prototype.getDelegateOptions=function(){var b={},c=this.getDefaults();return this._options&&a.each(this._options,function(a,d){c[a]!=d&&(b[a]=d)}),b},c.prototype.enter=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),b instanceof a.Event&&(c.inState["focusin"==b.type?"focus":"hover"]=!0),c.tip().hasClass("in")||"in"==c.hoverState?void(c.hoverState="in"):(clearTimeout(c.timeout),c.hoverState="in",c.options.delay&&c.options.delay.show?void(c.timeout=setTimeout(function(){"in"==c.hoverState&&c.show()},c.options.delay.show)):c.show())},c.prototype.isInStateTrue=function(){for(var a in this.inState)if(this.inState[a])return!0;return!1},c.prototype.leave=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),b instanceof a.Event&&(c.inState["focusout"==b.type?"focus":"hover"]=!1),c.isInStateTrue()?void 0:(clearTimeout(c.timeout),c.hoverState="out",c.options.delay&&c.options.delay.hide?void(c.timeout=setTimeout(function(){"out"==c.hoverState&&c.hide()},c.options.delay.hide)):c.hide())},c.prototype.show=function(){var b=a.Event("show.bs."+this.type);if(this.hasContent()&&this.enabled){this.$element.trigger(b);var d=a.contains(this.$element[0].ownerDocument.documentElement,this.$element[0]);if(b.isDefaultPrevented()||!d)return;var e=this,f=this.tip(),g=this.getUID(this.type);this.setContent(),f.attr("id",g),this.$element.attr("aria-describedby",g),this.options.animation&&f.addClass("fade");var h="function"==typeof this.options.placement?this.options.placement.call(this,f[0],this.$element[0]):this.options.placement,i=/\s?auto?\s?/i,j=i.test(h);j&&(h=h.replace(i,"")||"top"),f.detach().css({top:0,left:0,display:"block"}).addClass(h).data("bs."+this.type,this),this.options.container?f.appendTo(this.options.container):f.insertAfter(this.$element),this.$element.trigger("inserted.bs."+this.type);var k=this.getPosition(),l=f[0].offsetWidth,m=f[0].offsetHeight;if(j){var n=h,o=this.getPosition(this.$viewport);h="bottom"==h&&k.bottom+m>o.bottom?"top":"top"==h&&k.top-m<o.top?"bottom":"right"==h&&k.right+l>o.width?"left":"left"==h&&k.left-l<o.left?"right":h,f.removeClass(n).addClass(h)}var p=this.getCalculatedOffset(h,k,l,m);this.applyPlacement(p,h);var q=function(){var a=e.hoverState;e.$element.trigger("shown.bs."+e.type),e.hoverState=null,"out"==a&&e.leave(e)};a.support.transition&&this.$tip.hasClass("fade")?f.one("bsTransitionEnd",q).emulateTransitionEnd(c.TRANSITION_DURATION):q()}},c.prototype.applyPlacement=function(b,c){var d=this.tip(),e=d[0].offsetWidth,f=d[0].offsetHeight,g=parseInt(d.css("margin-top"),10),h=parseInt(d.css("margin-left"),10);isNaN(g)&&(g=0),isNaN(h)&&(h=0),b.top+=g,b.left+=h,a.offset.setOffset(d[0],a.extend({using:function(a){d.css({top:Math.round(a.top),left:Math.round(a.left)})}},b),0),d.addClass("in");var i=d[0].offsetWidth,j=d[0].offsetHeight;"top"==c&&j!=f&&(b.top=b.top+f-j);var k=this.getViewportAdjustedDelta(c,b,i,j);k.left?b.left+=k.left:b.top+=k.top;var l=/top|bottom/.test(c),m=l?2*k.left-e+i:2*k.top-f+j,n=l?"offsetWidth":"offsetHeight";d.offset(b),this.replaceArrow(m,d[0][n],l)},c.prototype.replaceArrow=function(a,b,c){this.arrow().css(c?"left":"top",50*(1-a/b)+"%").css(c?"top":"left","")},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},c.prototype.hide=function(b){function d(){"in"!=e.hoverState&&f.detach(),e.$element.removeAttr("aria-describedby").trigger("hidden.bs."+e.type),b&&b()}var e=this,f=a(this.$tip),g=a.Event("hide.bs."+this.type);return this.$element.trigger(g),g.isDefaultPrevented()?void 0:(f.removeClass("in"),a.support.transition&&f.hasClass("fade")?f.one("bsTransitionEnd",d).emulateTransitionEnd(c.TRANSITION_DURATION):d(),this.hoverState=null,this)},c.prototype.fixTitle=function(){var a=this.$element;(a.attr("title")||"string"!=typeof a.attr("data-original-title"))&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},c.prototype.hasContent=function(){return this.getTitle()},c.prototype.getPosition=function(b){b=b||this.$element;var c=b[0],d="BODY"==c.tagName,e=c.getBoundingClientRect();null==e.width&&(e=a.extend({},e,{width:e.right-e.left,height:e.bottom-e.top}));var f=d?{top:0,left:0}:b.offset(),g={scroll:d?document.documentElement.scrollTop||document.body.scrollTop:b.scrollTop()},h=d?{width:a(window).width(),height:a(window).height()}:null;return a.extend({},e,g,h,f)},c.prototype.getCalculatedOffset=function(a,b,c,d){return"bottom"==a?{top:b.top+b.height,left:b.left+b.width/2-c/2}:"top"==a?{top:b.top-d,left:b.left+b.width/2-c/2}:"left"==a?{top:b.top+b.height/2-d/2,left:b.left-c}:{top:b.top+b.height/2-d/2,left:b.left+b.width}},c.prototype.getViewportAdjustedDelta=function(a,b,c,d){var e={top:0,left:0};if(!this.$viewport)return e;var f=this.options.viewport&&this.options.viewport.padding||0,g=this.getPosition(this.$viewport);if(/right|left/.test(a)){var h=b.top-f-g.scroll,i=b.top+f-g.scroll+d;h<g.top?e.top=g.top-h:i>g.top+g.height&&(e.top=g.top+g.height-i)}else{var j=b.left-f,k=b.left+f+c;j<g.left?e.left=g.left-j:k>g.right&&(e.left=g.left+g.width-k)}return e},c.prototype.getTitle=function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||("function"==typeof c.title?c.title.call(b[0]):c.title)},c.prototype.getUID=function(a){do a+=~~(1e6*Math.random());while(document.getElementById(a));return a},c.prototype.tip=function(){if(!this.$tip&&(this.$tip=a(this.options.template),1!=this.$tip.length))throw new Error(this.type+" `template` option must consist of exactly 1 top-level element!");return this.$tip},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},c.prototype.enable=function(){this.enabled=!0},c.prototype.disable=function(){this.enabled=!1},c.prototype.toggleEnabled=function(){this.enabled=!this.enabled},c.prototype.toggle=function(b){var c=this;b&&(c=a(b.currentTarget).data("bs."+this.type),c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c))),b?(c.inState.click=!c.inState.click,c.isInStateTrue()?c.enter(c):c.leave(c)):c.tip().hasClass("in")?c.leave(c):c.enter(c)},c.prototype.destroy=function(){var a=this;clearTimeout(this.timeout),this.hide(function(){a.$element.off("."+a.type).removeData("bs."+a.type),a.$tip&&a.$tip.detach(),a.$tip=null,a.$arrow=null,a.$viewport=null})};var d=a.fn.tooltip;a.fn.tooltip=b,a.fn.tooltip.Constructor=c,a.fn.tooltip.noConflict=function(){return a.fn.tooltip=d,this}}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.popover"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.popover",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.init("popover",a,b)};if(!a.fn.tooltip)throw new Error("Popover requires tooltip.js");c.VERSION="3.3.5",c.DEFAULTS=a.extend({},a.fn.tooltip.Constructor.DEFAULTS,{placement:"right",trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),c.prototype=a.extend({},a.fn.tooltip.Constructor.prototype),c.prototype.constructor=c,c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content").children().detach().end()[this.options.html?"string"==typeof c?"html":"append":"text"](c),a.removeClass("fade top bottom left right in"),a.find(".popover-title").html()||a.find(".popover-title").hide()},c.prototype.hasContent=function(){return this.getTitle()||this.getContent()},c.prototype.getContent=function(){var a=this.$element,b=this.options;return a.attr("data-content")||("function"==typeof b.content?b.content.call(a[0]):b.content)},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".arrow")};var d=a.fn.popover;a.fn.popover=b,a.fn.popover.Constructor=c,a.fn.popover.noConflict=function(){return a.fn.popover=d,this}}(jQuery),+function(a){"use strict";function b(c,d){this.$body=a(document.body),this.$scrollElement=a(a(c).is(document.body)?window:c),this.options=a.extend({},b.DEFAULTS,d),this.selector=(this.options.target||"")+" .nav li > a",this.offsets=[],this.targets=[],this.activeTarget=null,this.scrollHeight=0,this.$scrollElement.on("scroll.bs.scrollspy",a.proxy(this.process,this)),this.refresh(),this.process()}function c(c){return this.each(function(){var d=a(this),e=d.data("bs.scrollspy"),f="object"==typeof c&&c;e||d.data("bs.scrollspy",e=new b(this,f)),"string"==typeof c&&e[c]()})}b.VERSION="3.3.5",b.DEFAULTS={offset:10},b.prototype.getScrollHeight=function(){return this.$scrollElement[0].scrollHeight||Math.max(this.$body[0].scrollHeight,document.documentElement.scrollHeight)},b.prototype.refresh=function(){var b=this,c="offset",d=0;this.offsets=[],this.targets=[],this.scrollHeight=this.getScrollHeight(),a.isWindow(this.$scrollElement[0])||(c="position",d=this.$scrollElement.scrollTop()),this.$body.find(this.selector).map(function(){var b=a(this),e=b.data("target")||b.attr("href"),f=/^#./.test(e)&&a(e);return f&&f.length&&f.is(":visible")&&[[f[c]().top+d,e]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},b.prototype.process=function(){var a,b=this.$scrollElement.scrollTop()+this.options.offset,c=this.getScrollHeight(),d=this.options.offset+c-this.$scrollElement.height(),e=this.offsets,f=this.targets,g=this.activeTarget;if(this.scrollHeight!=c&&this.refresh(),b>=d)return g!=(a=f[f.length-1])&&this.activate(a);if(g&&b<e[0])return this.activeTarget=null,this.clear();for(a=e.length;a--;)g!=f[a]&&b>=e[a]&&(void 0===e[a+1]||b<e[a+1])&&this.activate(f[a])},b.prototype.activate=function(b){this.activeTarget=b,this.clear();var c=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',d=a(c).parents("li").addClass("active");d.parent(".dropdown-menu").length&&(d=d.closest("li.dropdown").addClass("active")), -d.trigger("activate.bs.scrollspy")},b.prototype.clear=function(){a(this.selector).parentsUntil(this.options.target,".active").removeClass("active")};var d=a.fn.scrollspy;a.fn.scrollspy=c,a.fn.scrollspy.Constructor=b,a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=d,this},a(window).on("load.bs.scrollspy.data-api",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);c.call(b,b.data())})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tab");e||d.data("bs.tab",e=new c(this)),"string"==typeof b&&e[b]()})}var c=function(b){this.element=a(b)};c.VERSION="3.3.5",c.TRANSITION_DURATION=150,c.prototype.show=function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.data("target");if(d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),!b.parent("li").hasClass("active")){var e=c.find(".active:last a"),f=a.Event("hide.bs.tab",{relatedTarget:b[0]}),g=a.Event("show.bs.tab",{relatedTarget:e[0]});if(e.trigger(f),b.trigger(g),!g.isDefaultPrevented()&&!f.isDefaultPrevented()){var h=a(d);this.activate(b.closest("li"),c),this.activate(h,h.parent(),function(){e.trigger({type:"hidden.bs.tab",relatedTarget:b[0]}),b.trigger({type:"shown.bs.tab",relatedTarget:e[0]})})}}},c.prototype.activate=function(b,d,e){function f(){g.removeClass("active").find("> .dropdown-menu > .active").removeClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!1),b.addClass("active").find('[data-toggle="tab"]').attr("aria-expanded",!0),h?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu").length&&b.closest("li.dropdown").addClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!0),e&&e()}var g=d.find("> .active"),h=e&&a.support.transition&&(g.length&&g.hasClass("fade")||!!d.find("> .fade").length);g.length&&h?g.one("bsTransitionEnd",f).emulateTransitionEnd(c.TRANSITION_DURATION):f(),g.removeClass("in")};var d=a.fn.tab;a.fn.tab=b,a.fn.tab.Constructor=c,a.fn.tab.noConflict=function(){return a.fn.tab=d,this};var e=function(c){c.preventDefault(),b.call(a(this),"show")};a(document).on("click.bs.tab.data-api",'[data-toggle="tab"]',e).on("click.bs.tab.data-api",'[data-toggle="pill"]',e)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.affix"),f="object"==typeof b&&b;e||d.data("bs.affix",e=new c(this,f)),"string"==typeof b&&e[b]()})}var c=function(b,d){this.options=a.extend({},c.DEFAULTS,d),this.$target=a(this.options.target).on("scroll.bs.affix.data-api",a.proxy(this.checkPosition,this)).on("click.bs.affix.data-api",a.proxy(this.checkPositionWithEventLoop,this)),this.$element=a(b),this.affixed=null,this.unpin=null,this.pinnedOffset=null,this.checkPosition()};c.VERSION="3.3.5",c.RESET="affix affix-top affix-bottom",c.DEFAULTS={offset:0,target:window},c.prototype.getState=function(a,b,c,d){var e=this.$target.scrollTop(),f=this.$element.offset(),g=this.$target.height();if(null!=c&&"top"==this.affixed)return c>e?"top":!1;if("bottom"==this.affixed)return null!=c?e+this.unpin<=f.top?!1:"bottom":a-d>=e+g?!1:"bottom";var h=null==this.affixed,i=h?e:f.top,j=h?g:b;return null!=c&&c>=e?"top":null!=d&&i+j>=a-d?"bottom":!1},c.prototype.getPinnedOffset=function(){if(this.pinnedOffset)return this.pinnedOffset;this.$element.removeClass(c.RESET).addClass("affix");var a=this.$target.scrollTop(),b=this.$element.offset();return this.pinnedOffset=b.top-a},c.prototype.checkPositionWithEventLoop=function(){setTimeout(a.proxy(this.checkPosition,this),1)},c.prototype.checkPosition=function(){if(this.$element.is(":visible")){var b=this.$element.height(),d=this.options.offset,e=d.top,f=d.bottom,g=Math.max(a(document).height(),a(document.body).height());"object"!=typeof d&&(f=e=d),"function"==typeof e&&(e=d.top(this.$element)),"function"==typeof f&&(f=d.bottom(this.$element));var h=this.getState(g,b,e,f);if(this.affixed!=h){null!=this.unpin&&this.$element.css("top","");var i="affix"+(h?"-"+h:""),j=a.Event(i+".bs.affix");if(this.$element.trigger(j),j.isDefaultPrevented())return;this.affixed=h,this.unpin="bottom"==h?this.getPinnedOffset():null,this.$element.removeClass(c.RESET).addClass(i).trigger(i.replace("affix","affixed")+".bs.affix")}"bottom"==h&&this.$element.offset({top:g-b-f})}};var d=a.fn.affix;a.fn.affix=b,a.fn.affix.Constructor=c,a.fn.affix.noConflict=function(){return a.fn.affix=d,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var c=a(this),d=c.data();d.offset=d.offset||{},null!=d.offsetBottom&&(d.offset.bottom=d.offsetBottom),null!=d.offsetTop&&(d.offset.top=d.offsetTop),b.call(c,d)})})}(jQuery);</script> -<script>/** -* @preserve HTML5 Shiv 3.7.2 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed -*/ -// Only run this code in IE 8 -if (!!window.navigator.userAgent.match("MSIE 8")) { -!function(a,b){function c(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function d(){var a=t.elements;return"string"==typeof a?a.split(" "):a}function e(a,b){var c=t.elements;"string"!=typeof c&&(c=c.join(" ")),"string"!=typeof a&&(a=a.join(" ")),t.elements=c+" "+a,j(b)}function f(a){var b=s[a[q]];return b||(b={},r++,a[q]=r,s[r]=b),b}function g(a,c,d){if(c||(c=b),l)return c.createElement(a);d||(d=f(c));var e;return e=d.cache[a]?d.cache[a].cloneNode():p.test(a)?(d.cache[a]=d.createElem(a)).cloneNode():d.createElem(a),!e.canHaveChildren||o.test(a)||e.tagUrn?e:d.frag.appendChild(e)}function h(a,c){if(a||(a=b),l)return a.createDocumentFragment();c=c||f(a);for(var e=c.frag.cloneNode(),g=0,h=d(),i=h.length;i>g;g++)e.createElement(h[g]);return e}function i(a,b){b.cache||(b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag()),a.createElement=function(c){return t.shivMethods?g(c,a,b):b.createElem(c)},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+d().join().replace(/[\w\-:]+/g,function(a){return b.createElem(a),b.frag.createElement(a),'c("'+a+'")'})+");return n}")(t,b.frag)}function j(a){a||(a=b);var d=f(a);return!t.shivCSS||k||d.hasCSS||(d.hasCSS=!!c(a,"article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}")),l||i(a,d),a}var k,l,m="3.7.2",n=a.html5||{},o=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,p=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,q="_html5shiv",r=0,s={};!function(){try{var a=b.createElement("a");a.innerHTML="<xyz></xyz>",k="hidden"in a,l=1==a.childNodes.length||function(){b.createElement("a");var a=b.createDocumentFragment();return"undefined"==typeof a.cloneNode||"undefined"==typeof a.createDocumentFragment||"undefined"==typeof a.createElement}()}catch(c){k=!0,l=!0}}();var t={elements:n.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output picture progress section summary template time video",version:m,shivCSS:n.shivCSS!==!1,supportsUnknownElements:l,shivMethods:n.shivMethods!==!1,type:"default",shivDocument:j,createElement:g,createDocumentFragment:h,addElements:e};a.html5=t,j(b)}(this,document); -}; -</script> -<script>/*! Respond.js v1.4.2: min/max-width media query polyfill * Copyright 2013 Scott Jehl - * Licensed under https://github.com/scottjehl/Respond/blob/master/LICENSE-MIT - * */ - -// Only run this code in IE 8 -if (!!window.navigator.userAgent.match("MSIE 8")) { -!function(a){"use strict";a.matchMedia=a.matchMedia||function(a){var b,c=a.documentElement,d=c.firstElementChild||c.firstChild,e=a.createElement("body"),f=a.createElement("div");return f.id="mq-test-1",f.style.cssText="position:absolute;top:-100em",e.style.background="none",e.appendChild(f),function(a){return f.innerHTML='­<style media="'+a+'"> #mq-test-1 { width: 42px; }</style>',c.insertBefore(e,d),b=42===f.offsetWidth,c.removeChild(e),{matches:b,media:a}}}(a.document)}(this),function(a){"use strict";function b(){u(!0)}var c={};a.respond=c,c.update=function(){};var d=[],e=function(){var b=!1;try{b=new a.XMLHttpRequest}catch(c){b=new a.ActiveXObject("Microsoft.XMLHTTP")}return function(){return b}}(),f=function(a,b){var c=e();c&&(c.open("GET",a,!0),c.onreadystatechange=function(){4!==c.readyState||200!==c.status&&304!==c.status||b(c.responseText)},4!==c.readyState&&c.send(null))};if(c.ajax=f,c.queue=d,c.regex={media:/@media[^\{]+\{([^\{\}]*\{[^\}\{]*\})+/gi,keyframes:/@(?:\-(?:o|moz|webkit)\-)?keyframes[^\{]+\{(?:[^\{\}]*\{[^\}\{]*\})+[^\}]*\}/gi,urls:/(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g,findStyles:/@media *([^\{]+)\{([\S\s]+?)$/,only:/(only\s+)?([a-zA-Z]+)\s?/,minw:/\([\s]*min\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/,maxw:/\([\s]*max\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/},c.mediaQueriesSupported=a.matchMedia&&null!==a.matchMedia("only all")&&a.matchMedia("only all").matches,!c.mediaQueriesSupported){var g,h,i,j=a.document,k=j.documentElement,l=[],m=[],n=[],o={},p=30,q=j.getElementsByTagName("head")[0]||k,r=j.getElementsByTagName("base")[0],s=q.getElementsByTagName("link"),t=function(){var a,b=j.createElement("div"),c=j.body,d=k.style.fontSize,e=c&&c.style.fontSize,f=!1;return b.style.cssText="position:absolute;font-size:1em;width:1em",c||(c=f=j.createElement("body"),c.style.background="none"),k.style.fontSize="100%",c.style.fontSize="100%",c.appendChild(b),f&&k.insertBefore(c,k.firstChild),a=b.offsetWidth,f?k.removeChild(c):c.removeChild(b),k.style.fontSize=d,e&&(c.style.fontSize=e),a=i=parseFloat(a)},u=function(b){var c="clientWidth",d=k[c],e="CSS1Compat"===j.compatMode&&d||j.body[c]||d,f={},o=s[s.length-1],r=(new Date).getTime();if(b&&g&&p>r-g)return a.clearTimeout(h),h=a.setTimeout(u,p),void 0;g=r;for(var v in l)if(l.hasOwnProperty(v)){var w=l[v],x=w.minw,y=w.maxw,z=null===x,A=null===y,B="em";x&&(x=parseFloat(x)*(x.indexOf(B)>-1?i||t():1)),y&&(y=parseFloat(y)*(y.indexOf(B)>-1?i||t():1)),w.hasquery&&(z&&A||!(z||e>=x)||!(A||y>=e))||(f[w.media]||(f[w.media]=[]),f[w.media].push(m[w.rules]))}for(var C in n)n.hasOwnProperty(C)&&n[C]&&n[C].parentNode===q&&q.removeChild(n[C]);n.length=0;for(var D in f)if(f.hasOwnProperty(D)){var E=j.createElement("style"),F=f[D].join("\n");E.type="text/css",E.media=D,q.insertBefore(E,o.nextSibling),E.styleSheet?E.styleSheet.cssText=F:E.appendChild(j.createTextNode(F)),n.push(E)}},v=function(a,b,d){var e=a.replace(c.regex.keyframes,"").match(c.regex.media),f=e&&e.length||0;b=b.substring(0,b.lastIndexOf("/"));var g=function(a){return a.replace(c.regex.urls,"$1"+b+"$2$3")},h=!f&&d;b.length&&(b+="/"),h&&(f=1);for(var i=0;f>i;i++){var j,k,n,o;h?(j=d,m.push(g(a))):(j=e[i].match(c.regex.findStyles)&&RegExp.$1,m.push(RegExp.$2&&g(RegExp.$2))),n=j.split(","),o=n.length;for(var p=0;o>p;p++)k=n[p],l.push({media:k.split("(")[0].match(c.regex.only)&&RegExp.$2||"all",rules:m.length-1,hasquery:k.indexOf("(")>-1,minw:k.match(c.regex.minw)&&parseFloat(RegExp.$1)+(RegExp.$2||""),maxw:k.match(c.regex.maxw)&&parseFloat(RegExp.$1)+(RegExp.$2||"")})}u()},w=function(){if(d.length){var b=d.shift();f(b.href,function(c){v(c,b.href,b.media),o[b.href]=!0,a.setTimeout(function(){w()},0)})}},x=function(){for(var b=0;b<s.length;b++){var c=s[b],e=c.href,f=c.media,g=c.rel&&"stylesheet"===c.rel.toLowerCase();e&&g&&!o[e]&&(c.styleSheet&&c.styleSheet.rawCssText?(v(c.styleSheet.rawCssText,e,f),o[e]=!0):(!/^([a-zA-Z:]*\/\/)/.test(e)&&!r||e.replace(RegExp.$1,"").split("/")[0]===a.location.host)&&("//"===e.substring(0,2)&&(e=a.location.protocol+e),d.push({href:e,media:f})))}w()};x(),c.update=x,c.getEmValue=t,a.addEventListener?a.addEventListener("resize",b,!1):a.attachEvent&&a.attachEvent("onresize",b)}}(this); -}; -</script> -<script> - -/** - * jQuery Plugin: Sticky Tabs - * - * @author Aidan Lister <aidan@php.net> - * adapted by Ruben Arslan to activate parent tabs too - * http://www.aidanlister.com/2014/03/persisting-the-tab-state-in-bootstrap/ - */ -(function($) { - "use strict"; - $.fn.rmarkdownStickyTabs = function() { - var context = this; - // Show the tab corresponding with the hash in the URL, or the first tab - var showStuffFromHash = function() { - var hash = window.location.hash; - var selector = hash ? 'a[href="' + hash + '"]' : 'li.active > a'; - var $selector = $(selector, context); - if($selector.data('toggle') === "tab") { - $selector.tab('show'); - // walk up the ancestors of this element, show any hidden tabs - $selector.parents('.section.tabset').each(function(i, elm) { - var link = $('a[href="#' + $(elm).attr('id') + '"]'); - if(link.data('toggle') === "tab") { - link.tab("show"); - } - }); - } - }; - - - // Set the correct tab when the page loads - showStuffFromHash(context); - - // Set the correct tab when a user uses their back/forward button - $(window).on('hashchange', function() { - showStuffFromHash(context); - }); - - // Change the URL when tabs are clicked - $('a', context).on('click', function(e) { - history.pushState(null, null, this.href); - showStuffFromHash(context); - }); - - return this; - }; -}(jQuery)); - -window.buildTabsets = function(tocID) { - - // build a tabset from a section div with the .tabset class - function buildTabset(tabset) { - - // check for fade and pills options - var fade = tabset.hasClass("tabset-fade"); - var pills = tabset.hasClass("tabset-pills"); - var navClass = pills ? "nav-pills" : "nav-tabs"; - - // determine the heading level of the tabset and tabs - var match = tabset.attr('class').match(/level(\d) /); - if (match === null) - return; - var tabsetLevel = Number(match[1]); - var tabLevel = tabsetLevel + 1; - - // find all subheadings immediately below - var tabs = tabset.find("div.section.level" + tabLevel); - if (!tabs.length) - return; - - // create tablist and tab-content elements - var tabList = $('<ul class="nav ' + navClass + '" role="tablist"></ul>'); - $(tabs[0]).before(tabList); - var tabContent = $('<div class="tab-content"></div>'); - $(tabs[0]).before(tabContent); - - // build the tabset - var activeTab = 0; - tabs.each(function(i) { - - // get the tab div - var tab = $(tabs[i]); - - // get the id then sanitize it for use with bootstrap tabs - var id = tab.attr('id'); - - // see if this is marked as the active tab - if (tab.hasClass('active')) - activeTab = i; - - // remove any table of contents entries associated with - // this ID (since we'll be removing the heading element) - $("div#" + tocID + " li a[href='#" + id + "']").parent().remove(); - - // sanitize the id for use with bootstrap tabs - id = id.replace(/[.\/?&!#<>]/g, '').replace(/\s/g, '_'); - tab.attr('id', id); - - // get the heading element within it, grab it's text, then remove it - var heading = tab.find('h' + tabLevel + ':first'); - var headingText = heading.html(); - heading.remove(); - - // build and append the tab list item - var a = $('<a role="tab" data-toggle="tab">' + headingText + '</a>'); - a.attr('href', '#' + id); - a.attr('aria-controls', id); - var li = $('<li role="presentation"></li>'); - li.append(a); - tabList.append(li); - - // set it's attributes - tab.attr('role', 'tabpanel'); - tab.addClass('tab-pane'); - tab.addClass('tabbed-pane'); - if (fade) - tab.addClass('fade'); - - // move it into the tab content div - tab.detach().appendTo(tabContent); - }); - - // set active tab - $(tabList.children('li')[activeTab]).addClass('active'); - var active = $(tabContent.children('div.section')[activeTab]); - active.addClass('active'); - if (fade) - active.addClass('in'); - - if (tabset.hasClass("tabset-sticky")) - tabset.rmarkdownStickyTabs(); - } - - // convert section divs with the .tabset class to tabsets - var tabsets = $("div.section.tabset"); - tabsets.each(function(i) { - buildTabset($(tabsets[i])); - }); -}; - -</script> -<style type="text/css">.hljs-literal { -color: #990073; -} -.hljs-number { -color: #099; -} -.hljs-comment { -color: #998; -font-style: italic; -} -.hljs-keyword { -color: #900; -font-weight: bold; -} -.hljs-string { -color: #d14; -} -</style> -<script src="data:application/javascript;base64,LyohIGhpZ2hsaWdodC5qcyB2OS4xMi4wIHwgQlNEMyBMaWNlbnNlIHwgZ2l0LmlvL2hsanNsaWNlbnNlICovCiFmdW5jdGlvbihlKXt2YXIgbj0ib2JqZWN0Ij09dHlwZW9mIHdpbmRvdyYmd2luZG93fHwib2JqZWN0Ij09dHlwZW9mIHNlbGYmJnNlbGY7InVuZGVmaW5lZCIhPXR5cGVvZiBleHBvcnRzP2UoZXhwb3J0cyk6biYmKG4uaGxqcz1lKHt9KSwiZnVuY3Rpb24iPT10eXBlb2YgZGVmaW5lJiZkZWZpbmUuYW1kJiZkZWZpbmUoW10sZnVuY3Rpb24oKXtyZXR1cm4gbi5obGpzfSkpfShmdW5jdGlvbihlKXtmdW5jdGlvbiBuKGUpe3JldHVybiBlLnJlcGxhY2UoLyYvZywiJmFtcDsiKS5yZXBsYWNlKC88L2csIiZsdDsiKS5yZXBsYWNlKC8+L2csIiZndDsiKX1mdW5jdGlvbiB0KGUpe3JldHVybiBlLm5vZGVOYW1lLnRvTG93ZXJDYXNlKCl9ZnVuY3Rpb24gcihlLG4pe3ZhciB0PWUmJmUuZXhlYyhuKTtyZXR1cm4gdCYmMD09PXQuaW5kZXh9ZnVuY3Rpb24gYShlKXtyZXR1cm4gay50ZXN0KGUpfWZ1bmN0aW9uIGkoZSl7dmFyIG4sdCxyLGksbz1lLmNsYXNzTmFtZSsiICI7aWYobys9ZS5wYXJlbnROb2RlP2UucGFyZW50Tm9kZS5jbGFzc05hbWU6IiIsdD1CLmV4ZWMobykpcmV0dXJuIHcodFsxXSk/dFsxXToibm8taGlnaGxpZ2h0Ijtmb3Iobz1vLnNwbGl0KC9ccysvKSxuPTAscj1vLmxlbmd0aDtyPm47bisrKWlmKGk9b1tuXSxhKGkpfHx3KGkpKXJldHVybiBpfWZ1bmN0aW9uIG8oZSl7dmFyIG4sdD17fSxyPUFycmF5LnByb3RvdHlwZS5zbGljZS5jYWxsKGFyZ3VtZW50cywxKTtmb3IobiBpbiBlKXRbbl09ZVtuXTtyZXR1cm4gci5mb3JFYWNoKGZ1bmN0aW9uKGUpe2ZvcihuIGluIGUpdFtuXT1lW25dfSksdH1mdW5jdGlvbiB1KGUpe3ZhciBuPVtdO3JldHVybiBmdW5jdGlvbiByKGUsYSl7Zm9yKHZhciBpPWUuZmlyc3RDaGlsZDtpO2k9aS5uZXh0U2libGluZykzPT09aS5ub2RlVHlwZT9hKz1pLm5vZGVWYWx1ZS5sZW5ndGg6MT09PWkubm9kZVR5cGUmJihuLnB1c2goe2V2ZW50OiJzdGFydCIsb2Zmc2V0OmEsbm9kZTppfSksYT1yKGksYSksdChpKS5tYXRjaCgvYnJ8aHJ8aW1nfGlucHV0Lyl8fG4ucHVzaCh7ZXZlbnQ6InN0b3AiLG9mZnNldDphLG5vZGU6aX0pKTtyZXR1cm4gYX0oZSwwKSxufWZ1bmN0aW9uIGMoZSxyLGEpe2Z1bmN0aW9uIGkoKXtyZXR1cm4gZS5sZW5ndGgmJnIubGVuZ3RoP2VbMF0ub2Zmc2V0IT09clswXS5vZmZzZXQ/ZVswXS5vZmZzZXQ8clswXS5vZmZzZXQ/ZTpyOiJzdGFydCI9PT1yWzBdLmV2ZW50P2U6cjplLmxlbmd0aD9lOnJ9ZnVuY3Rpb24gbyhlKXtmdW5jdGlvbiByKGUpe3JldHVybiIgIitlLm5vZGVOYW1lKyc9IicrbihlLnZhbHVlKS5yZXBsYWNlKCciJywiJnF1b3Q7IikrJyInfXMrPSI8Iit0KGUpK0UubWFwLmNhbGwoZS5hdHRyaWJ1dGVzLHIpLmpvaW4oIiIpKyI+In1mdW5jdGlvbiB1KGUpe3MrPSI8LyIrdChlKSsiPiJ9ZnVuY3Rpb24gYyhlKXsoInN0YXJ0Ij09PWUuZXZlbnQ/bzp1KShlLm5vZGUpfWZvcih2YXIgbD0wLHM9IiIsZj1bXTtlLmxlbmd0aHx8ci5sZW5ndGg7KXt2YXIgZz1pKCk7aWYocys9bihhLnN1YnN0cmluZyhsLGdbMF0ub2Zmc2V0KSksbD1nWzBdLm9mZnNldCxnPT09ZSl7Zi5yZXZlcnNlKCkuZm9yRWFjaCh1KTtkbyBjKGcuc3BsaWNlKDAsMSlbMF0pLGc9aSgpO3doaWxlKGc9PT1lJiZnLmxlbmd0aCYmZ1swXS5vZmZzZXQ9PT1sKTtmLnJldmVyc2UoKS5mb3JFYWNoKG8pfWVsc2Uic3RhcnQiPT09Z1swXS5ldmVudD9mLnB1c2goZ1swXS5ub2RlKTpmLnBvcCgpLGMoZy5zcGxpY2UoMCwxKVswXSl9cmV0dXJuIHMrbihhLnN1YnN0cihsKSl9ZnVuY3Rpb24gbChlKXtyZXR1cm4gZS52JiYhZS5jYWNoZWRfdmFyaWFudHMmJihlLmNhY2hlZF92YXJpYW50cz1lLnYubWFwKGZ1bmN0aW9uKG4pe3JldHVybiBvKGUse3Y6bnVsbH0sbil9KSksZS5jYWNoZWRfdmFyaWFudHN8fGUuZVcmJltvKGUpXXx8W2VdfWZ1bmN0aW9uIHMoZSl7ZnVuY3Rpb24gbihlKXtyZXR1cm4gZSYmZS5zb3VyY2V8fGV9ZnVuY3Rpb24gdCh0LHIpe3JldHVybiBuZXcgUmVnRXhwKG4odCksIm0iKyhlLmNJPyJpIjoiIikrKHI/ImciOiIiKSl9ZnVuY3Rpb24gcihhLGkpe2lmKCFhLmNvbXBpbGVkKXtpZihhLmNvbXBpbGVkPSEwLGEuaz1hLmt8fGEuYkssYS5rKXt2YXIgbz17fSx1PWZ1bmN0aW9uKG4sdCl7ZS5jSSYmKHQ9dC50b0xvd2VyQ2FzZSgpKSx0LnNwbGl0KCIgIikuZm9yRWFjaChmdW5jdGlvbihlKXt2YXIgdD1lLnNwbGl0KCJ8Iik7b1t0WzBdXT1bbix0WzFdP051bWJlcih0WzFdKToxXX0pfTsic3RyaW5nIj09dHlwZW9mIGEuaz91KCJrZXl3b3JkIixhLmspOngoYS5rKS5mb3JFYWNoKGZ1bmN0aW9uKGUpe3UoZSxhLmtbZV0pfSksYS5rPW99YS5sUj10KGEubHx8L1x3Ky8sITApLGkmJihhLmJLJiYoYS5iPSJcXGIoIithLmJLLnNwbGl0KCIgIikuam9pbigifCIpKyIpXFxiIiksYS5ifHwoYS5iPS9cQnxcYi8pLGEuYlI9dChhLmIpLGEuZXx8YS5lV3x8KGEuZT0vXEJ8XGIvKSxhLmUmJihhLmVSPXQoYS5lKSksYS50RT1uKGEuZSl8fCIiLGEuZVcmJmkudEUmJihhLnRFKz0oYS5lPyJ8IjoiIikraS50RSkpLGEuaSYmKGEuaVI9dChhLmkpKSxudWxsPT1hLnImJihhLnI9MSksYS5jfHwoYS5jPVtdKSxhLmM9QXJyYXkucHJvdG90eXBlLmNvbmNhdC5hcHBseShbXSxhLmMubWFwKGZ1bmN0aW9uKGUpe3JldHVybiBsKCJzZWxmIj09PWU/YTplKX0pKSxhLmMuZm9yRWFjaChmdW5jdGlvbihlKXtyKGUsYSl9KSxhLnN0YXJ0cyYmcihhLnN0YXJ0cyxpKTt2YXIgYz1hLmMubWFwKGZ1bmN0aW9uKGUpe3JldHVybiBlLmJLPyJcXC4/KCIrZS5iKyIpXFwuPyI6ZS5ifSkuY29uY2F0KFthLnRFLGEuaV0pLm1hcChuKS5maWx0ZXIoQm9vbGVhbik7YS50PWMubGVuZ3RoP3QoYy5qb2luKCJ8IiksITApOntleGVjOmZ1bmN0aW9uKCl7cmV0dXJuIG51bGx9fX19cihlKX1mdW5jdGlvbiBmKGUsdCxhLGkpe2Z1bmN0aW9uIG8oZSxuKXt2YXIgdCxhO2Zvcih0PTAsYT1uLmMubGVuZ3RoO2E+dDt0KyspaWYocihuLmNbdF0uYlIsZSkpcmV0dXJuIG4uY1t0XX1mdW5jdGlvbiB1KGUsbil7aWYocihlLmVSLG4pKXtmb3IoO2UuZW5kc1BhcmVudCYmZS5wYXJlbnQ7KWU9ZS5wYXJlbnQ7cmV0dXJuIGV9cmV0dXJuIGUuZVc/dShlLnBhcmVudCxuKTp2b2lkIDB9ZnVuY3Rpb24gYyhlLG4pe3JldHVybiFhJiZyKG4uaVIsZSl9ZnVuY3Rpb24gbChlLG4pe3ZhciB0PU4uY0k/blswXS50b0xvd2VyQ2FzZSgpOm5bMF07cmV0dXJuIGUuay5oYXNPd25Qcm9wZXJ0eSh0KSYmZS5rW3RdfWZ1bmN0aW9uIHAoZSxuLHQscil7dmFyIGE9cj8iIjpJLmNsYXNzUHJlZml4LGk9JzxzcGFuIGNsYXNzPSInK2Esbz10PyIiOkM7cmV0dXJuIGkrPWUrJyI+JyxpK24rb31mdW5jdGlvbiBoKCl7dmFyIGUsdCxyLGE7aWYoIUUuaylyZXR1cm4gbihrKTtmb3IoYT0iIix0PTAsRS5sUi5sYXN0SW5kZXg9MCxyPUUubFIuZXhlYyhrKTtyOylhKz1uKGsuc3Vic3RyaW5nKHQsci5pbmRleCkpLGU9bChFLHIpLGU/KEIrPWVbMV0sYSs9cChlWzBdLG4oclswXSkpKTphKz1uKHJbMF0pLHQ9RS5sUi5sYXN0SW5kZXgscj1FLmxSLmV4ZWMoayk7cmV0dXJuIGErbihrLnN1YnN0cih0KSl9ZnVuY3Rpb24gZCgpe3ZhciBlPSJzdHJpbmciPT10eXBlb2YgRS5zTDtpZihlJiYheVtFLnNMXSlyZXR1cm4gbihrKTt2YXIgdD1lP2YoRS5zTCxrLCEwLHhbRS5zTF0pOmcoayxFLnNMLmxlbmd0aD9FLnNMOnZvaWQgMCk7cmV0dXJuIEUucj4wJiYoQis9dC5yKSxlJiYoeFtFLnNMXT10LnRvcCkscCh0Lmxhbmd1YWdlLHQudmFsdWUsITEsITApfWZ1bmN0aW9uIGIoKXtMKz1udWxsIT1FLnNMP2QoKTpoKCksaz0iIn1mdW5jdGlvbiB2KGUpe0wrPWUuY04/cChlLmNOLCIiLCEwKToiIixFPU9iamVjdC5jcmVhdGUoZSx7cGFyZW50Ont2YWx1ZTpFfX0pfWZ1bmN0aW9uIG0oZSxuKXtpZihrKz1lLG51bGw9PW4pcmV0dXJuIGIoKSwwO3ZhciB0PW8obixFKTtpZih0KXJldHVybiB0LnNraXA/ays9bjoodC5lQiYmKGsrPW4pLGIoKSx0LnJCfHx0LmVCfHwoaz1uKSksdih0LG4pLHQuckI/MDpuLmxlbmd0aDt2YXIgcj11KEUsbik7aWYocil7dmFyIGE9RTthLnNraXA/ays9bjooYS5yRXx8YS5lRXx8KGsrPW4pLGIoKSxhLmVFJiYoaz1uKSk7ZG8gRS5jTiYmKEwrPUMpLEUuc2tpcHx8KEIrPUUuciksRT1FLnBhcmVudDt3aGlsZShFIT09ci5wYXJlbnQpO3JldHVybiByLnN0YXJ0cyYmdihyLnN0YXJ0cywiIiksYS5yRT8wOm4ubGVuZ3RofWlmKGMobixFKSl0aHJvdyBuZXcgRXJyb3IoJ0lsbGVnYWwgbGV4ZW1lICInK24rJyIgZm9yIG1vZGUgIicrKEUuY058fCI8dW5uYW1lZD4iKSsnIicpO3JldHVybiBrKz1uLG4ubGVuZ3RofHwxfXZhciBOPXcoZSk7aWYoIU4pdGhyb3cgbmV3IEVycm9yKCdVbmtub3duIGxhbmd1YWdlOiAiJytlKyciJyk7cyhOKTt2YXIgUixFPWl8fE4seD17fSxMPSIiO2ZvcihSPUU7UiE9PU47Uj1SLnBhcmVudClSLmNOJiYoTD1wKFIuY04sIiIsITApK0wpO3ZhciBrPSIiLEI9MDt0cnl7Zm9yKHZhciBNLGosTz0wOzspe2lmKEUudC5sYXN0SW5kZXg9TyxNPUUudC5leGVjKHQpLCFNKWJyZWFrO2o9bSh0LnN1YnN0cmluZyhPLE0uaW5kZXgpLE1bMF0pLE89TS5pbmRleCtqfWZvcihtKHQuc3Vic3RyKE8pKSxSPUU7Ui5wYXJlbnQ7Uj1SLnBhcmVudClSLmNOJiYoTCs9Qyk7cmV0dXJue3I6Qix2YWx1ZTpMLGxhbmd1YWdlOmUsdG9wOkV9fWNhdGNoKFQpe2lmKFQubWVzc2FnZSYmLTEhPT1ULm1lc3NhZ2UuaW5kZXhPZigiSWxsZWdhbCIpKXJldHVybntyOjAsdmFsdWU6bih0KX07dGhyb3cgVH19ZnVuY3Rpb24gZyhlLHQpe3Q9dHx8SS5sYW5ndWFnZXN8fHgoeSk7dmFyIHI9e3I6MCx2YWx1ZTpuKGUpfSxhPXI7cmV0dXJuIHQuZmlsdGVyKHcpLmZvckVhY2goZnVuY3Rpb24obil7dmFyIHQ9ZihuLGUsITEpO3QubGFuZ3VhZ2U9bix0LnI+YS5yJiYoYT10KSx0LnI+ci5yJiYoYT1yLHI9dCl9KSxhLmxhbmd1YWdlJiYoci5zZWNvbmRfYmVzdD1hKSxyfWZ1bmN0aW9uIHAoZSl7cmV0dXJuIEkudGFiUmVwbGFjZXx8SS51c2VCUj9lLnJlcGxhY2UoTSxmdW5jdGlvbihlLG4pe3JldHVybiBJLnVzZUJSJiYiXG4iPT09ZT8iPGJyPiI6SS50YWJSZXBsYWNlP24ucmVwbGFjZSgvXHQvZyxJLnRhYlJlcGxhY2UpOiIifSk6ZX1mdW5jdGlvbiBoKGUsbix0KXt2YXIgcj1uP0xbbl06dCxhPVtlLnRyaW0oKV07cmV0dXJuIGUubWF0Y2goL1xiaGxqc1xiLyl8fGEucHVzaCgiaGxqcyIpLC0xPT09ZS5pbmRleE9mKHIpJiZhLnB1c2gociksYS5qb2luKCIgIikudHJpbSgpfWZ1bmN0aW9uIGQoZSl7dmFyIG4sdCxyLG8sbCxzPWkoZSk7YShzKXx8KEkudXNlQlI/KG49ZG9jdW1lbnQuY3JlYXRlRWxlbWVudE5TKCJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIiwiZGl2Iiksbi5pbm5lckhUTUw9ZS5pbm5lckhUTUwucmVwbGFjZSgvXG4vZywiIikucmVwbGFjZSgvPGJyWyBcL10qPi9nLCJcbiIpKTpuPWUsbD1uLnRleHRDb250ZW50LHI9cz9mKHMsbCwhMCk6ZyhsKSx0PXUobiksdC5sZW5ndGgmJihvPWRvY3VtZW50LmNyZWF0ZUVsZW1lbnROUygiaHR0cDovL3d3dy53My5vcmcvMTk5OS94aHRtbCIsImRpdiIpLG8uaW5uZXJIVE1MPXIudmFsdWUsci52YWx1ZT1jKHQsdShvKSxsKSksci52YWx1ZT1wKHIudmFsdWUpLGUuaW5uZXJIVE1MPXIudmFsdWUsZS5jbGFzc05hbWU9aChlLmNsYXNzTmFtZSxzLHIubGFuZ3VhZ2UpLGUucmVzdWx0PXtsYW5ndWFnZTpyLmxhbmd1YWdlLHJlOnIucn0sci5zZWNvbmRfYmVzdCYmKGUuc2Vjb25kX2Jlc3Q9e2xhbmd1YWdlOnIuc2Vjb25kX2Jlc3QubGFuZ3VhZ2UscmU6ci5zZWNvbmRfYmVzdC5yfSkpfWZ1bmN0aW9uIGIoZSl7ST1vKEksZSl9ZnVuY3Rpb24gdigpe2lmKCF2LmNhbGxlZCl7di5jYWxsZWQ9ITA7dmFyIGU9ZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgicHJlIGNvZGUiKTtFLmZvckVhY2guY2FsbChlLGQpfX1mdW5jdGlvbiBtKCl7YWRkRXZlbnRMaXN0ZW5lcigiRE9NQ29udGVudExvYWRlZCIsdiwhMSksYWRkRXZlbnRMaXN0ZW5lcigibG9hZCIsdiwhMSl9ZnVuY3Rpb24gTihuLHQpe3ZhciByPXlbbl09dChlKTtyLmFsaWFzZXMmJnIuYWxpYXNlcy5mb3JFYWNoKGZ1bmN0aW9uKGUpe0xbZV09bn0pfWZ1bmN0aW9uIFIoKXtyZXR1cm4geCh5KX1mdW5jdGlvbiB3KGUpe3JldHVybiBlPShlfHwiIikudG9Mb3dlckNhc2UoKSx5W2VdfHx5W0xbZV1dfXZhciBFPVtdLHg9T2JqZWN0LmtleXMseT17fSxMPXt9LGs9L14obm8tP2hpZ2hsaWdodHxwbGFpbnx0ZXh0KSQvaSxCPS9cYmxhbmcoPzp1YWdlKT8tKFtcdy1dKylcYi9pLE09LygoXig8W14+XSs+fFx0fCkrfCg/OlxuKSkpL2dtLEM9Ijwvc3Bhbj4iLEk9e2NsYXNzUHJlZml4OiJobGpzLSIsdGFiUmVwbGFjZTpudWxsLHVzZUJSOiExLGxhbmd1YWdlczp2b2lkIDB9O3JldHVybiBlLmhpZ2hsaWdodD1mLGUuaGlnaGxpZ2h0QXV0bz1nLGUuZml4TWFya3VwPXAsZS5oaWdobGlnaHRCbG9jaz1kLGUuY29uZmlndXJlPWIsZS5pbml0SGlnaGxpZ2h0aW5nPXYsZS5pbml0SGlnaGxpZ2h0aW5nT25Mb2FkPW0sZS5yZWdpc3Rlckxhbmd1YWdlPU4sZS5saXN0TGFuZ3VhZ2VzPVIsZS5nZXRMYW5ndWFnZT13LGUuaW5oZXJpdD1vLGUuSVI9IlthLXpBLVpdXFx3KiIsZS5VSVI9IlthLXpBLVpfXVxcdyoiLGUuTlI9IlxcYlxcZCsoXFwuXFxkKyk/IixlLkNOUj0iKC0/KShcXGIwW3hYXVthLWZBLUYwLTldK3woXFxiXFxkKyhcXC5cXGQqKT98XFwuXFxkKykoW2VFXVstK10/XFxkKyk/KSIsZS5CTlI9IlxcYigwYlswMV0rKSIsZS5SU1I9IiF8IT18IT09fCV8JT18JnwmJnwmPXxcXCp8XFwqPXxcXCt8XFwrPXwsfC18LT18Lz18L3w6fDt8PDx8PDw9fDw9fDx8PT09fD09fD18Pj4+PXw+Pj18Pj18Pj4+fD4+fD58XFw/fFxcW3xcXHt8XFwofFxcXnxcXF49fFxcfHxcXHw9fFxcfFxcfHx+IixlLkJFPXtiOiJcXFxcW1xcc1xcU10iLHI6MH0sZS5BU009e2NOOiJzdHJpbmciLGI6IiciLGU6IiciLGk6IlxcbiIsYzpbZS5CRV19LGUuUVNNPXtjTjoic3RyaW5nIixiOiciJyxlOiciJyxpOiJcXG4iLGM6W2UuQkVdfSxlLlBXTT17YjovXGIoYXxhbnx0aGV8YXJlfEknbXxpc24ndHxkb24ndHxkb2Vzbid0fHdvbid0fGJ1dHxqdXN0fHNob3VsZHxwcmV0dHl8c2ltcGx5fGVub3VnaHxnb25uYXxnb2luZ3x3dGZ8c298c3VjaHx3aWxsfHlvdXx5b3VyfHRoZXl8bGlrZXxtb3JlKVxiL30sZS5DPWZ1bmN0aW9uKG4sdCxyKXt2YXIgYT1lLmluaGVyaXQoe2NOOiJjb21tZW50IixiOm4sZTp0LGM6W119LHJ8fHt9KTtyZXR1cm4gYS5jLnB1c2goZS5QV00pLGEuYy5wdXNoKHtjTjoiZG9jdGFnIixiOiIoPzpUT0RPfEZJWE1FfE5PVEV8QlVHfFhYWCk6IixyOjB9KSxhfSxlLkNMQ009ZS5DKCIvLyIsIiQiKSxlLkNCQ009ZS5DKCIvXFwqIiwiXFwqLyIpLGUuSENNPWUuQygiIyIsIiQiKSxlLk5NPXtjTjoibnVtYmVyIixiOmUuTlIscjowfSxlLkNOTT17Y046Im51bWJlciIsYjplLkNOUixyOjB9LGUuQk5NPXtjTjoibnVtYmVyIixiOmUuQk5SLHI6MH0sZS5DU1NOTT17Y046Im51bWJlciIsYjplLk5SKyIoJXxlbXxleHxjaHxyZW18dnd8dmh8dm1pbnx2bWF4fGNtfG1tfGlufHB0fHBjfHB4fGRlZ3xncmFkfHJhZHx0dXJufHN8bXN8SHp8a0h6fGRwaXxkcGNtfGRwcHgpPyIscjowfSxlLlJNPXtjTjoicmVnZXhwIixiOi9cLy8sZTovXC9bZ2ltdXldKi8saTovXG4vLGM6W2UuQkUse2I6L1xbLyxlOi9cXS8scjowLGM6W2UuQkVdfV19LGUuVE09e2NOOiJ0aXRsZSIsYjplLklSLHI6MH0sZS5VVE09e2NOOiJ0aXRsZSIsYjplLlVJUixyOjB9LGUuTUVUSE9EX0dVQVJEPXtiOiJcXC5cXHMqIitlLlVJUixyOjB9LGV9KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInNxbCIsZnVuY3Rpb24oZSl7dmFyIHQ9ZS5DKCItLSIsIiQiKTtyZXR1cm57Y0k6ITAsaTovWzw+e30qI10vLGM6W3tiSzoiYmVnaW4gZW5kIHN0YXJ0IGNvbW1pdCByb2xsYmFjayBzYXZlcG9pbnQgbG9jayBhbHRlciBjcmVhdGUgZHJvcCByZW5hbWUgY2FsbCBkZWxldGUgZG8gaGFuZGxlciBpbnNlcnQgbG9hZCByZXBsYWNlIHNlbGVjdCB0cnVuY2F0ZSB1cGRhdGUgc2V0IHNob3cgcHJhZ21hIGdyYW50IG1lcmdlIGRlc2NyaWJlIHVzZSBleHBsYWluIGhlbHAgZGVjbGFyZSBwcmVwYXJlIGV4ZWN1dGUgZGVhbGxvY2F0ZSByZWxlYXNlIHVubG9jayBwdXJnZSByZXNldCBjaGFuZ2Ugc3RvcCBhbmFseXplIGNhY2hlIGZsdXNoIG9wdGltaXplIHJlcGFpciBraWxsIGluc3RhbGwgdW5pbnN0YWxsIGNoZWNrc3VtIHJlc3RvcmUgY2hlY2sgYmFja3VwIHJldm9rZSBjb21tZW50IixlOi87LyxlVzohMCxsOi9bXHdcLl0rLyxrOntrZXl3b3JkOiJhYm9ydCBhYnMgYWJzb2x1dGUgYWNjIGFjY2UgYWNjZXAgYWNjZXB0IGFjY2VzcyBhY2Nlc3NlZCBhY2Nlc3NpYmxlIGFjY291bnQgYWNvcyBhY3Rpb24gYWN0aXZhdGUgYWRkIGFkZHRpbWUgYWRtaW4gYWRtaW5pc3RlciBhZHZhbmNlZCBhZHZpc2UgYWVzX2RlY3J5cHQgYWVzX2VuY3J5cHQgYWZ0ZXIgYWdlbnQgYWdncmVnYXRlIGFsaSBhbGlhIGFsaWFzIGFsbG9jYXRlIGFsbG93IGFsdGVyIGFsd2F5cyBhbmFseXplIGFuY2lsbGFyeSBhbmQgYW55IGFueWRhdGEgYW55ZGF0YXNldCBhbnlzY2hlbWEgYW55dHlwZSBhcHBseSBhcmNoaXZlIGFyY2hpdmVkIGFyY2hpdmVsb2cgYXJlIGFzIGFzYyBhc2NpaSBhc2luIGFzc2VtYmx5IGFzc2VydGlvbiBhc3NvY2lhdGUgYXN5bmNocm9ub3VzIGF0IGF0YW4gYXRuMiBhdHRyIGF0dHJpIGF0dHJpYiBhdHRyaWJ1IGF0dHJpYnV0IGF0dHJpYnV0ZSBhdHRyaWJ1dGVzIGF1ZGl0IGF1dGhlbnRpY2F0ZWQgYXV0aGVudGljYXRpb24gYXV0aGlkIGF1dGhvcnMgYXV0byBhdXRvYWxsb2NhdGUgYXV0b2RibGluayBhdXRvZXh0ZW5kIGF1dG9tYXRpYyBhdmFpbGFiaWxpdHkgYXZnIGJhY2t1cCBiYWRmaWxlIGJhc2ljZmlsZSBiZWZvcmUgYmVnaW4gYmVnaW5uaW5nIGJlbmNobWFyayBiZXR3ZWVuIGJmaWxlIGJmaWxlX2Jhc2UgYmlnIGJpZ2ZpbGUgYmluIGJpbmFyeV9kb3VibGUgYmluYXJ5X2Zsb2F0IGJpbmxvZyBiaXRfYW5kIGJpdF9jb3VudCBiaXRfbGVuZ3RoIGJpdF9vciBiaXRfeG9yIGJpdG1hcCBibG9iX2Jhc2UgYmxvY2sgYmxvY2tzaXplIGJvZHkgYm90aCBib3VuZCBidWZmZXJfY2FjaGUgYnVmZmVyX3Bvb2wgYnVpbGQgYnVsayBieSBieXRlIGJ5dGVvcmRlcm1hcmsgYnl0ZXMgY2FjaGUgY2FjaGluZyBjYWxsIGNhbGxpbmcgY2FuY2VsIGNhcGFjaXR5IGNhc2NhZGUgY2FzY2FkZWQgY2FzZSBjYXN0IGNhdGFsb2cgY2F0ZWdvcnkgY2VpbCBjZWlsaW5nIGNoYWluIGNoYW5nZSBjaGFuZ2VkIGNoYXJfYmFzZSBjaGFyX2xlbmd0aCBjaGFyYWN0ZXJfbGVuZ3RoIGNoYXJhY3RlcnMgY2hhcmFjdGVyc2V0IGNoYXJpbmRleCBjaGFyc2V0IGNoYXJzZXRmb3JtIGNoYXJzZXRpZCBjaGVjayBjaGVja3N1bSBjaGVja3N1bV9hZ2cgY2hpbGQgY2hvb3NlIGNociBjaHVuayBjbGFzcyBjbGVhbnVwIGNsZWFyIGNsaWVudCBjbG9iIGNsb2JfYmFzZSBjbG9uZSBjbG9zZSBjbHVzdGVyX2lkIGNsdXN0ZXJfcHJvYmFiaWxpdHkgY2x1c3Rlcl9zZXQgY2x1c3RlcmluZyBjb2FsZXNjZSBjb2VyY2liaWxpdHkgY29sIGNvbGxhdGUgY29sbGF0aW9uIGNvbGxlY3QgY29sdSBjb2x1bSBjb2x1bW4gY29sdW1uX3ZhbHVlIGNvbHVtbnMgY29sdW1uc191cGRhdGVkIGNvbW1lbnQgY29tbWl0IGNvbXBhY3QgY29tcGF0aWJpbGl0eSBjb21waWxlZCBjb21wbGV0ZSBjb21wb3NpdGVfbGltaXQgY29tcG91bmQgY29tcHJlc3MgY29tcHV0ZSBjb25jYXQgY29uY2F0X3dzIGNvbmN1cnJlbnQgY29uZmlybSBjb25uIGNvbm5lYyBjb25uZWN0IGNvbm5lY3RfYnlfaXNjeWNsZSBjb25uZWN0X2J5X2lzbGVhZiBjb25uZWN0X2J5X3Jvb3QgY29ubmVjdF90aW1lIGNvbm5lY3Rpb24gY29uc2lkZXIgY29uc2lzdGVudCBjb25zdGFudCBjb25zdHJhaW50IGNvbnN0cmFpbnRzIGNvbnN0cnVjdG9yIGNvbnRhaW5lciBjb250ZW50IGNvbnRlbnRzIGNvbnRleHQgY29udHJpYnV0b3JzIGNvbnRyb2xmaWxlIGNvbnYgY29udmVydCBjb252ZXJ0X3R6IGNvcnIgY29ycl9rIGNvcnJfcyBjb3JyZXNwb25kaW5nIGNvcnJ1cHRpb24gY29zIGNvc3QgY291bnQgY291bnRfYmlnIGNvdW50ZWQgY292YXJfcG9wIGNvdmFyX3NhbXAgY3B1X3Blcl9jYWxsIGNwdV9wZXJfc2Vzc2lvbiBjcmMzMiBjcmVhdGUgY3JlYXRpb24gY3JpdGljYWwgY3Jvc3MgY3ViZSBjdW1lX2Rpc3QgY3VyZGF0ZSBjdXJyZW50IGN1cnJlbnRfZGF0ZSBjdXJyZW50X3RpbWUgY3VycmVudF90aW1lc3RhbXAgY3VycmVudF91c2VyIGN1cnNvciBjdXJ0aW1lIGN1c3RvbWRhdHVtIGN5Y2xlIGRhdGEgZGF0YWJhc2UgZGF0YWJhc2VzIGRhdGFmaWxlIGRhdGFmaWxlcyBkYXRhbGVuZ3RoIGRhdGVfYWRkIGRhdGVfY2FjaGUgZGF0ZV9mb3JtYXQgZGF0ZV9zdWIgZGF0ZWFkZCBkYXRlZGlmZiBkYXRlZnJvbXBhcnRzIGRhdGVuYW1lIGRhdGVwYXJ0IGRhdGV0aW1lMmZyb21wYXJ0cyBkYXkgZGF5X3RvX3NlY29uZCBkYXluYW1lIGRheW9mbW9udGggZGF5b2Z3ZWVrIGRheW9meWVhciBkYXlzIGRiX3JvbGVfY2hhbmdlIGRidGltZXpvbmUgZGRsIGRlYWxsb2NhdGUgZGVjbGFyZSBkZWNvZGUgZGVjb21wb3NlIGRlY3JlbWVudCBkZWNyeXB0IGRlZHVwbGljYXRlIGRlZiBkZWZhIGRlZmF1IGRlZmF1bCBkZWZhdWx0IGRlZmF1bHRzIGRlZmVycmVkIGRlZmkgZGVmaW4gZGVmaW5lIGRlZ3JlZXMgZGVsYXllZCBkZWxlZ2F0ZSBkZWxldGUgZGVsZXRlX2FsbCBkZWxpbWl0ZWQgZGVtYW5kIGRlbnNlX3JhbmsgZGVwdGggZGVxdWV1ZSBkZXNfZGVjcnlwdCBkZXNfZW5jcnlwdCBkZXNfa2V5X2ZpbGUgZGVzYyBkZXNjciBkZXNjcmkgZGVzY3JpYiBkZXNjcmliZSBkZXNjcmlwdG9yIGRldGVybWluaXN0aWMgZGlhZ25vc3RpY3MgZGlmZmVyZW5jZSBkaW1lbnNpb24gZGlyZWN0X2xvYWQgZGlyZWN0b3J5IGRpc2FibGUgZGlzYWJsZV9hbGwgZGlzYWxsb3cgZGlzYXNzb2NpYXRlIGRpc2NhcmRmaWxlIGRpc2Nvbm5lY3QgZGlza2dyb3VwIGRpc3RpbmN0IGRpc3RpbmN0cm93IGRpc3RyaWJ1dGUgZGlzdHJpYnV0ZWQgZGl2IGRvIGRvY3VtZW50IGRvbWFpbiBkb3RuZXQgZG91YmxlIGRvd25ncmFkZSBkcm9wIGR1bXBmaWxlIGR1cGxpY2F0ZSBkdXJhdGlvbiBlYWNoIGVkaXRpb24gZWRpdGlvbmFibGUgZWRpdGlvbnMgZWxlbWVudCBlbGxpcHNpcyBlbHNlIGVsc2lmIGVsdCBlbXB0eSBlbmFibGUgZW5hYmxlX2FsbCBlbmNsb3NlZCBlbmNvZGUgZW5jb2RpbmcgZW5jcnlwdCBlbmQgZW5kLWV4ZWMgZW5kaWFuIGVuZm9yY2VkIGVuZ2luZSBlbmdpbmVzIGVucXVldWUgZW50ZXJwcmlzZSBlbnRpdHllc2NhcGluZyBlb21vbnRoIGVycm9yIGVycm9ycyBlc2NhcGVkIGV2YWxuYW1lIGV2YWx1YXRlIGV2ZW50IGV2ZW50ZGF0YSBldmVudHMgZXhjZXB0IGV4Y2VwdGlvbiBleGNlcHRpb25zIGV4Y2hhbmdlIGV4Y2x1ZGUgZXhjbHVkaW5nIGV4ZWN1IGV4ZWN1dCBleGVjdXRlIGV4ZW1wdCBleGlzdHMgZXhpdCBleHAgZXhwaXJlIGV4cGxhaW4gZXhwb3J0IGV4cG9ydF9zZXQgZXh0ZW5kZWQgZXh0ZW50IGV4dGVybmFsIGV4dGVybmFsXzEgZXh0ZXJuYWxfMiBleHRlcm5hbGx5IGV4dHJhY3QgZmFpbGVkIGZhaWxlZF9sb2dpbl9hdHRlbXB0cyBmYWlsb3ZlciBmYWlsdXJlIGZhciBmYXN0IGZlYXR1cmVfc2V0IGZlYXR1cmVfdmFsdWUgZmV0Y2ggZmllbGQgZmllbGRzIGZpbGUgZmlsZV9uYW1lX2NvbnZlcnQgZmlsZXN5c3RlbV9saWtlX2xvZ2dpbmcgZmluYWwgZmluaXNoIGZpcnN0IGZpcnN0X3ZhbHVlIGZpeGVkIGZsYXNoX2NhY2hlIGZsYXNoYmFjayBmbG9vciBmbHVzaCBmb2xsb3dpbmcgZm9sbG93cyBmb3IgZm9yYWxsIGZvcmNlIGZvcm0gZm9ybWEgZm9ybWF0IGZvdW5kIGZvdW5kX3Jvd3MgZnJlZWxpc3QgZnJlZWxpc3RzIGZyZWVwb29scyBmcmVzaCBmcm9tIGZyb21fYmFzZTY0IGZyb21fZGF5cyBmdHAgZnVsbCBmdW5jdGlvbiBnZW5lcmFsIGdlbmVyYXRlZCBnZXQgZ2V0X2Zvcm1hdCBnZXRfbG9jayBnZXRkYXRlIGdldHV0Y2RhdGUgZ2xvYmFsIGdsb2JhbF9uYW1lIGdsb2JhbGx5IGdvIGdvdG8gZ3JhbnQgZ3JhbnRzIGdyZWF0ZXN0IGdyb3VwIGdyb3VwX2NvbmNhdCBncm91cF9pZCBncm91cGluZyBncm91cGluZ19pZCBncm91cHMgZ3RpZF9zdWJ0cmFjdCBndWFyYW50ZWUgZ3VhcmQgaGFuZGxlciBoYXNoIGhhc2hrZXlzIGhhdmluZyBoZWEgaGVhZCBoZWFkaSBoZWFkaW4gaGVhZGluZyBoZWFwIGhlbHAgaGV4IGhpZXJhcmNoeSBoaWdoIGhpZ2hfcHJpb3JpdHkgaG9zdHMgaG91ciBodHRwIGlkIGlkZW50X2N1cnJlbnQgaWRlbnRfaW5jciBpZGVudF9zZWVkIGlkZW50aWZpZWQgaWRlbnRpdHkgaWRsZV90aW1lIGlmIGlmbnVsbCBpZ25vcmUgaWlmIGlsaWtlIGlsbSBpbW1lZGlhdGUgaW1wb3J0IGluIGluY2x1ZGUgaW5jbHVkaW5nIGluY3JlbWVudCBpbmRleCBpbmRleGVzIGluZGV4aW5nIGluZGV4dHlwZSBpbmRpY2F0b3IgaW5kaWNlcyBpbmV0Nl9hdG9uIGluZXQ2X250b2EgaW5ldF9hdG9uIGluZXRfbnRvYSBpbmZpbGUgaW5pdGlhbCBpbml0aWFsaXplZCBpbml0aWFsbHkgaW5pdHJhbnMgaW5tZW1vcnkgaW5uZXIgaW5ub2RiIGlucHV0IGluc2VydCBpbnN0YWxsIGluc3RhbmNlIGluc3RhbnRpYWJsZSBpbnN0ciBpbnRlcmZhY2UgaW50ZXJsZWF2ZWQgaW50ZXJzZWN0IGludG8gaW52YWxpZGF0ZSBpbnZpc2libGUgaXMgaXNfZnJlZV9sb2NrIGlzX2lwdjQgaXNfaXB2NF9jb21wYXQgaXNfbm90IGlzX25vdF9udWxsIGlzX3VzZWRfbG9jayBpc2RhdGUgaXNudWxsIGlzb2xhdGlvbiBpdGVyYXRlIGphdmEgam9pbiBqc29uIGpzb25fZXhpc3RzIGtlZXAga2VlcF9kdXBsaWNhdGVzIGtleSBrZXlzIGtpbGwgbGFuZ3VhZ2UgbGFyZ2UgbGFzdCBsYXN0X2RheSBsYXN0X2luc2VydF9pZCBsYXN0X3ZhbHVlIGxheCBsY2FzZSBsZWFkIGxlYWRpbmcgbGVhc3QgbGVhdmVzIGxlZnQgbGVuIGxlbmdodCBsZW5ndGggbGVzcyBsZXZlbCBsZXZlbHMgbGlicmFyeSBsaWtlIGxpa2UyIGxpa2U0IGxpa2VjIGxpbWl0IGxpbmVzIGxpbmsgbGlzdCBsaXN0YWdnIGxpdHRsZSBsbiBsb2FkIGxvYWRfZmlsZSBsb2IgbG9icyBsb2NhbCBsb2NhbHRpbWUgbG9jYWx0aW1lc3RhbXAgbG9jYXRlIGxvY2F0b3IgbG9jayBsb2NrZWQgbG9nIGxvZzEwIGxvZzIgbG9nZmlsZSBsb2dmaWxlcyBsb2dnaW5nIGxvZ2ljYWwgbG9naWNhbF9yZWFkc19wZXJfY2FsbCBsb2dvZmYgbG9nb24gbG9ncyBsb25nIGxvb3AgbG93IGxvd19wcmlvcml0eSBsb3dlciBscGFkIGxydHJpbSBsdHJpbSBtYWluIG1ha2Vfc2V0IG1ha2VkYXRlIG1ha2V0aW1lIG1hbmFnZWQgbWFuYWdlbWVudCBtYW51YWwgbWFwIG1hcHBpbmcgbWFzayBtYXN0ZXIgbWFzdGVyX3Bvc193YWl0IG1hdGNoIG1hdGNoZWQgbWF0ZXJpYWxpemVkIG1heCBtYXhleHRlbnRzIG1heGltaXplIG1heGluc3RhbmNlcyBtYXhsZW4gbWF4bG9nZmlsZXMgbWF4bG9naGlzdG9yeSBtYXhsb2dtZW1iZXJzIG1heHNpemUgbWF4dHJhbnMgbWQ1IG1lYXN1cmVzIG1lZGlhbiBtZWRpdW0gbWVtYmVyIG1lbWNvbXByZXNzIG1lbW9yeSBtZXJnZSBtaWNyb3NlY29uZCBtaWQgbWlncmF0aW9uIG1pbiBtaW5leHRlbnRzIG1pbmltdW0gbWluaW5nIG1pbnVzIG1pbnV0ZSBtaW52YWx1ZSBtaXNzaW5nIG1vZCBtb2RlIG1vZGVsIG1vZGlmaWNhdGlvbiBtb2RpZnkgbW9kdWxlIG1vbml0b3JpbmcgbW9udGggbW9udGhzIG1vdW50IG1vdmUgbW92ZW1lbnQgbXVsdGlzZXQgbXV0ZXggbmFtZSBuYW1lX2NvbnN0IG5hbWVzIG5hbiBuYXRpb25hbCBuYXRpdmUgbmF0dXJhbCBuYXYgbmNoYXIgbmNsb2IgbmVzdGVkIG5ldmVyIG5ldyBuZXdsaW5lIG5leHQgbmV4dHZhbCBubyBub193cml0ZV90b19iaW5sb2cgbm9hcmNoaXZlbG9nIG5vYXVkaXQgbm9iYWRmaWxlIG5vY2hlY2sgbm9jb21wcmVzcyBub2NvcHkgbm9jeWNsZSBub2RlbGF5IG5vZGlzY2FyZGZpbGUgbm9lbnRpdHllc2NhcGluZyBub2d1YXJhbnRlZSBub2tlZXAgbm9sb2dmaWxlIG5vbWFwcGluZyBub21heHZhbHVlIG5vbWluaW1pemUgbm9taW52YWx1ZSBub21vbml0b3Jpbmcgbm9uZSBub25lZGl0aW9uYWJsZSBub25zY2hlbWEgbm9vcmRlciBub3ByIG5vcHJvIG5vcHJvbSBub3Byb21wIG5vcHJvbXB0IG5vcmVseSBub3Jlc2V0bG9ncyBub3JldmVyc2Ugbm9ybWFsIG5vcm93ZGVwZW5kZW5jaWVzIG5vc2NoZW1hY2hlY2sgbm9zd2l0Y2ggbm90IG5vdGhpbmcgbm90aWNlIG5vdHJpbSBub3ZhbGlkYXRlIG5vdyBub3dhaXQgbnRoX3ZhbHVlIG51bGxpZiBudWxscyBudW0gbnVtYiBudW1iZSBudmFyY2hhciBudmFyY2hhcjIgb2JqZWN0IG9jaWNvbGwgb2NpZGF0ZSBvY2lkYXRldGltZSBvY2lkdXJhdGlvbiBvY2lpbnRlcnZhbCBvY2lsb2Jsb2NhdG9yIG9jaW51bWJlciBvY2lyZWYgb2NpcmVmY3Vyc29yIG9jaXJvd2lkIG9jaXN0cmluZyBvY2l0eXBlIG9jdCBvY3RldF9sZW5ndGggb2Ygb2ZmIG9mZmxpbmUgb2Zmc2V0IG9pZCBvaWRpbmRleCBvbGQgb24gb25saW5lIG9ubHkgb3BhcXVlIG9wZW4gb3BlcmF0aW9ucyBvcGVyYXRvciBvcHRpbWFsIG9wdGltaXplIG9wdGlvbiBvcHRpb25hbGx5IG9yIG9yYWNsZSBvcmFjbGVfZGF0ZSBvcmFkYXRhIG9yZCBvcmRhdWRpbyBvcmRkaWNvbSBvcmRkb2Mgb3JkZXIgb3JkaW1hZ2Ugb3JkaW5hbGl0eSBvcmR2aWRlbyBvcmdhbml6YXRpb24gb3JsYW55IG9ybHZhcnkgb3V0IG91dGVyIG91dGZpbGUgb3V0bGluZSBvdXRwdXQgb3ZlciBvdmVyZmxvdyBvdmVycmlkaW5nIHBhY2thZ2UgcGFkIHBhcmFsbGVsIHBhcmFsbGVsX2VuYWJsZSBwYXJhbWV0ZXJzIHBhcmVudCBwYXJzZSBwYXJ0aWFsIHBhcnRpdGlvbiBwYXJ0aXRpb25zIHBhc2NhbCBwYXNzaW5nIHBhc3N3b3JkIHBhc3N3b3JkX2dyYWNlX3RpbWUgcGFzc3dvcmRfbG9ja190aW1lIHBhc3N3b3JkX3JldXNlX21heCBwYXNzd29yZF9yZXVzZV90aW1lIHBhc3N3b3JkX3ZlcmlmeV9mdW5jdGlvbiBwYXRjaCBwYXRoIHBhdGluZGV4IHBjdGluY3JlYXNlIHBjdHRocmVzaG9sZCBwY3R1c2VkIHBjdHZlcnNpb24gcGVyY2VudCBwZXJjZW50X3JhbmsgcGVyY2VudGlsZV9jb250IHBlcmNlbnRpbGVfZGlzYyBwZXJmb3JtYW5jZSBwZXJpb2QgcGVyaW9kX2FkZCBwZXJpb2RfZGlmZiBwZXJtYW5lbnQgcGh5c2ljYWwgcGkgcGlwZSBwaXBlbGluZWQgcGl2b3QgcGx1Z2dhYmxlIHBsdWdpbiBwb2xpY3kgcG9zaXRpb24gcG9zdF90cmFuc2FjdGlvbiBwb3cgcG93ZXIgcHJhZ21hIHByZWJ1aWx0IHByZWNlZGVzIHByZWNlZGluZyBwcmVjaXNpb24gcHJlZGljdGlvbiBwcmVkaWN0aW9uX2Nvc3QgcHJlZGljdGlvbl9kZXRhaWxzIHByZWRpY3Rpb25fcHJvYmFiaWxpdHkgcHJlZGljdGlvbl9zZXQgcHJlcGFyZSBwcmVzZW50IHByZXNlcnZlIHByaW9yIHByaW9yaXR5IHByaXZhdGUgcHJpdmF0ZV9zZ2EgcHJpdmlsZWdlcyBwcm9jZWR1cmFsIHByb2NlZHVyZSBwcm9jZWR1cmVfYW5hbHl6ZSBwcm9jZXNzbGlzdCBwcm9maWxlcyBwcm9qZWN0IHByb21wdCBwcm90ZWN0aW9uIHB1YmxpYyBwdWJsaXNoaW5nc2VydmVybmFtZSBwdXJnZSBxdWFydGVyIHF1ZXJ5IHF1aWNrIHF1aWVzY2UgcXVvdGEgcXVvdGVuYW1lIHJhZGlhbnMgcmFpc2UgcmFuZCByYW5nZSByYW5rIHJhdyByZWFkIHJlYWRzIHJlYWRzaXplIHJlYnVpbGQgcmVjb3JkIHJlY29yZHMgcmVjb3ZlciByZWNvdmVyeSByZWN1cnNpdmUgcmVjeWNsZSByZWRvIHJlZHVjZWQgcmVmIHJlZmVyZW5jZSByZWZlcmVuY2VkIHJlZmVyZW5jZXMgcmVmZXJlbmNpbmcgcmVmcmVzaCByZWdleHBfbGlrZSByZWdpc3RlciByZWdyX2F2Z3ggcmVncl9hdmd5IHJlZ3JfY291bnQgcmVncl9pbnRlcmNlcHQgcmVncl9yMiByZWdyX3Nsb3BlIHJlZ3Jfc3h4IHJlZ3Jfc3h5IHJlamVjdCByZWtleSByZWxhdGlvbmFsIHJlbGF0aXZlIHJlbGF5bG9nIHJlbGVhc2UgcmVsZWFzZV9sb2NrIHJlbGllc19vbiByZWxvY2F0ZSByZWx5IHJlbSByZW1haW5kZXIgcmVuYW1lIHJlcGFpciByZXBlYXQgcmVwbGFjZSByZXBsaWNhdGUgcmVwbGljYXRpb24gcmVxdWlyZWQgcmVzZXQgcmVzZXRsb2dzIHJlc2l6ZSByZXNvdXJjZSByZXNwZWN0IHJlc3RvcmUgcmVzdHJpY3RlZCByZXN1bHQgcmVzdWx0X2NhY2hlIHJlc3VtYWJsZSByZXN1bWUgcmV0ZW50aW9uIHJldHVybiByZXR1cm5pbmcgcmV0dXJucyByZXVzZSByZXZlcnNlIHJldm9rZSByaWdodCBybGlrZSByb2xlIHJvbGVzIHJvbGxiYWNrIHJvbGxpbmcgcm9sbHVwIHJvdW5kIHJvdyByb3dfY291bnQgcm93ZGVwZW5kZW5jaWVzIHJvd2lkIHJvd251bSByb3dzIHJ0cmltIHJ1bGVzIHNhZmUgc2FsdCBzYW1wbGUgc2F2ZSBzYXZlcG9pbnQgc2IxIHNiMiBzYjQgc2NhbiBzY2hlbWEgc2NoZW1hY2hlY2sgc2NuIHNjb3BlIHNjcm9sbCBzZG9fZ2VvcmFzdGVyIHNkb190b3BvX2dlb21ldHJ5IHNlYXJjaCBzZWNfdG9fdGltZSBzZWNvbmQgc2VjdGlvbiBzZWN1cmVmaWxlIHNlY3VyaXR5IHNlZWQgc2VnbWVudCBzZWxlY3Qgc2VsZiBzZXF1ZW5jZSBzZXF1ZW50aWFsIHNlcmlhbGl6YWJsZSBzZXJ2ZXIgc2VydmVyZXJyb3Igc2Vzc2lvbiBzZXNzaW9uX3VzZXIgc2Vzc2lvbnNfcGVyX3VzZXIgc2V0IHNldHMgc2V0dGluZ3Mgc2hhIHNoYTEgc2hhMiBzaGFyZSBzaGFyZWQgc2hhcmVkX3Bvb2wgc2hvcnQgc2hvdyBzaHJpbmsgc2h1dGRvd24gc2lfYXZlcmFnZWNvbG9yIHNpX2NvbG9yaGlzdG9ncmFtIHNpX2ZlYXR1cmVsaXN0IHNpX3Bvc2l0aW9uYWxjb2xvciBzaV9zdGlsbGltYWdlIHNpX3RleHR1cmUgc2libGluZ3Mgc2lkIHNpZ24gc2luIHNpemUgc2l6ZV90IHNpemVzIHNraXAgc2xhdmUgc2xlZXAgc21hbGxkYXRldGltZWZyb21wYXJ0cyBzbWFsbGZpbGUgc25hcHNob3Qgc29tZSBzb25hbWUgc29ydCBzb3VuZGV4IHNvdXJjZSBzcGFjZSBzcGFyc2Ugc3BmaWxlIHNwbGl0IHNxbCBzcWxfYmlnX3Jlc3VsdCBzcWxfYnVmZmVyX3Jlc3VsdCBzcWxfY2FjaGUgc3FsX2NhbGNfZm91bmRfcm93cyBzcWxfc21hbGxfcmVzdWx0IHNxbF92YXJpYW50X3Byb3BlcnR5IHNxbGNvZGUgc3FsZGF0YSBzcWxlcnJvciBzcWxuYW1lIHNxbHN0YXRlIHNxcnQgc3F1YXJlIHN0YW5kYWxvbmUgc3RhbmRieSBzdGFydCBzdGFydGluZyBzdGFydHVwIHN0YXRlbWVudCBzdGF0aWMgc3RhdGlzdGljcyBzdGF0c19iaW5vbWlhbF90ZXN0IHN0YXRzX2Nyb3NzdGFiIHN0YXRzX2tzX3Rlc3Qgc3RhdHNfbW9kZSBzdGF0c19td190ZXN0IHN0YXRzX29uZV93YXlfYW5vdmEgc3RhdHNfdF90ZXN0XyBzdGF0c190X3Rlc3RfaW5kZXAgc3RhdHNfdF90ZXN0X29uZSBzdGF0c190X3Rlc3RfcGFpcmVkIHN0YXRzX3dzcl90ZXN0IHN0YXR1cyBzdGQgc3RkZGV2IHN0ZGRldl9wb3Agc3RkZGV2X3NhbXAgc3RkZXYgc3RvcCBzdG9yYWdlIHN0b3JlIHN0b3JlZCBzdHIgc3RyX3RvX2RhdGUgc3RyYWlnaHRfam9pbiBzdHJjbXAgc3RyaWN0IHN0cmluZyBzdHJ1Y3Qgc3R1ZmYgc3R5bGUgc3ViZGF0ZSBzdWJwYXJ0aXRpb24gc3VicGFydGl0aW9ucyBzdWJzdGl0dXRhYmxlIHN1YnN0ciBzdWJzdHJpbmcgc3VidGltZSBzdWJ0cmluZ19pbmRleCBzdWJ0eXBlIHN1Y2Nlc3Mgc3VtIHN1c3BlbmQgc3dpdGNoIHN3aXRjaG9mZnNldCBzd2l0Y2hvdmVyIHN5bmMgc3luY2hyb25vdXMgc3lub255bSBzeXMgc3lzX3htbGFnZyBzeXNhc20gc3lzYXV4IHN5c2RhdGUgc3lzZGF0ZXRpbWVvZmZzZXQgc3lzZGJhIHN5c29wZXIgc3lzdGVtIHN5c3RlbV91c2VyIHN5c3V0Y2RhdGV0aW1lIHRhYmxlIHRhYmxlcyB0YWJsZXNwYWNlIHRhbiB0ZG8gdGVtcGxhdGUgdGVtcG9yYXJ5IHRlcm1pbmF0ZWQgdGVydGlhcnlfd2VpZ2h0cyB0ZXN0IHRoYW4gdGhlbiB0aHJlYWQgdGhyb3VnaCB0aWVyIHRpZXMgdGltZSB0aW1lX2Zvcm1hdCB0aW1lX3pvbmUgdGltZWRpZmYgdGltZWZyb21wYXJ0cyB0aW1lb3V0IHRpbWVzdGFtcCB0aW1lc3RhbXBhZGQgdGltZXN0YW1wZGlmZiB0aW1lem9uZV9hYmJyIHRpbWV6b25lX21pbnV0ZSB0aW1lem9uZV9yZWdpb24gdG8gdG9fYmFzZTY0IHRvX2RhdGUgdG9fZGF5cyB0b19zZWNvbmRzIHRvZGF0ZXRpbWVvZmZzZXQgdHJhY2UgdHJhY2tpbmcgdHJhbnNhY3Rpb24gdHJhbnNhY3Rpb25hbCB0cmFuc2xhdGUgdHJhbnNsYXRpb24gdHJlYXQgdHJpZ2dlciB0cmlnZ2VyX25lc3RsZXZlbCB0cmlnZ2VycyB0cmltIHRydW5jYXRlIHRyeV9jYXN0IHRyeV9jb252ZXJ0IHRyeV9wYXJzZSB0eXBlIHViMSB1YjIgdWI0IHVjYXNlIHVuYXJjaGl2ZWQgdW5ib3VuZGVkIHVuY29tcHJlc3MgdW5kZXIgdW5kbyB1bmhleCB1bmljb2RlIHVuaWZvcm0gdW5pbnN0YWxsIHVuaW9uIHVuaXF1ZSB1bml4X3RpbWVzdGFtcCB1bmtub3duIHVubGltaXRlZCB1bmxvY2sgdW5waXZvdCB1bnJlY292ZXJhYmxlIHVuc2FmZSB1bnNpZ25lZCB1bnRpbCB1bnRydXN0ZWQgdW51c2FibGUgdW51c2VkIHVwZGF0ZSB1cGRhdGVkIHVwZ3JhZGUgdXBwZWQgdXBwZXIgdXBzZXJ0IHVybCB1cm93aWQgdXNhYmxlIHVzYWdlIHVzZSB1c2Vfc3RvcmVkX291dGxpbmVzIHVzZXIgdXNlcl9kYXRhIHVzZXJfcmVzb3VyY2VzIHVzZXJzIHVzaW5nIHV0Y19kYXRlIHV0Y190aW1lc3RhbXAgdXVpZCB1dWlkX3Nob3J0IHZhbGlkYXRlIHZhbGlkYXRlX3Bhc3N3b3JkX3N0cmVuZ3RoIHZhbGlkYXRpb24gdmFsaXN0IHZhbHVlIHZhbHVlcyB2YXIgdmFyX3NhbXAgdmFyY2hhcmMgdmFyaSB2YXJpYSB2YXJpYWIgdmFyaWFibCB2YXJpYWJsZSB2YXJpYWJsZXMgdmFyaWFuY2UgdmFycCB2YXJyYXcgdmFycmF3YyB2YXJyYXkgdmVyaWZ5IHZlcnNpb24gdmVyc2lvbnMgdmlldyB2aXJ0dWFsIHZpc2libGUgdm9pZCB3YWl0IHdhbGxldCB3YXJuaW5nIHdhcm5pbmdzIHdlZWsgd2Vla2RheSB3ZWVrb2Z5ZWFyIHdlbGxmb3JtZWQgd2hlbiB3aGVuZSB3aGVuZXYgd2hlbmV2ZSB3aGVuZXZlciB3aGVyZSB3aGlsZSB3aGl0ZXNwYWNlIHdpdGggd2l0aGluIHdpdGhvdXQgd29yayB3cmFwcGVkIHhkYiB4bWwgeG1sYWdnIHhtbGF0dHJpYnV0ZXMgeG1sY2FzdCB4bWxjb2xhdHR2YWwgeG1sZWxlbWVudCB4bWxleGlzdHMgeG1sZm9yZXN0IHhtbGluZGV4IHhtbG5hbWVzcGFjZXMgeG1scGkgeG1scXVlcnkgeG1scm9vdCB4bWxzY2hlbWEgeG1sc2VyaWFsaXplIHhtbHRhYmxlIHhtbHR5cGUgeG9yIHllYXIgeWVhcl90b19tb250aCB5ZWFycyB5ZWFyd2VlayIsbGl0ZXJhbDoidHJ1ZSBmYWxzZSBudWxsIixidWlsdF9pbjoiYXJyYXkgYmlnaW50IGJpbmFyeSBiaXQgYmxvYiBib29sZWFuIGNoYXIgY2hhcmFjdGVyIGRhdGUgZGVjIGRlY2ltYWwgZmxvYXQgaW50IGludDggaW50ZWdlciBpbnRlcnZhbCBudW1iZXIgbnVtZXJpYyByZWFsIHJlY29yZCBzZXJpYWwgc2VyaWFsOCBzbWFsbGludCB0ZXh0IHZhcmNoYXIgdmFyeWluZyB2b2lkIn0sYzpbe2NOOiJzdHJpbmciLGI6IiciLGU6IiciLGM6W2UuQkUse2I6IicnIn1dfSx7Y046InN0cmluZyIsYjonIicsZTonIicsYzpbZS5CRSx7YjonIiInfV19LHtjTjoic3RyaW5nIixiOiJgIixlOiJgIixjOltlLkJFXX0sZS5DTk0sZS5DQkNNLHRdfSxlLkNCQ00sdF19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJyIixmdW5jdGlvbihlKXt2YXIgcj0iKFthLXpBLVpdfFxcLlthLXpBLVouXSlbYS16QS1aMC05Ll9dKiI7cmV0dXJue2M6W2UuSENNLHtiOnIsbDpyLGs6e2tleXdvcmQ6ImZ1bmN0aW9uIGlmIGluIGJyZWFrIG5leHQgcmVwZWF0IGVsc2UgZm9yIHJldHVybiBzd2l0Y2ggd2hpbGUgdHJ5IHRyeUNhdGNoIHN0b3Agd2FybmluZyByZXF1aXJlIGxpYnJhcnkgYXR0YWNoIGRldGFjaCBzb3VyY2Ugc2V0TWV0aG9kIHNldEdlbmVyaWMgc2V0R3JvdXBHZW5lcmljIHNldENsYXNzIC4uLiIsbGl0ZXJhbDoiTlVMTCBOQSBUUlVFIEZBTFNFIFQgRiBJbmYgTmFOIE5BX2ludGVnZXJffDEwIE5BX3JlYWxffDEwIE5BX2NoYXJhY3Rlcl98MTAgTkFfY29tcGxleF98MTAifSxyOjB9LHtjTjoibnVtYmVyIixiOiIwW3hYXVswLTlhLWZBLUZdK1tMaV0/XFxiIixyOjB9LHtjTjoibnVtYmVyIixiOiJcXGQrKD86W2VFXVsrXFwtXT9cXGQqKT9MXFxiIixyOjB9LHtjTjoibnVtYmVyIixiOiJcXGQrXFwuKD8hXFxkKSg/OmlcXGIpPyIscjowfSx7Y046Im51bWJlciIsYjoiXFxkKyg/OlxcLlxcZCopPyg/OltlRV1bK1xcLV0/XFxkKik/aT9cXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IlxcLlxcZCsoPzpbZUVdWytcXC1dP1xcZCopP2k/XFxiIixyOjB9LHtiOiJgIixlOiJgIixyOjB9LHtjTjoic3RyaW5nIixjOltlLkJFXSx2Olt7YjonIicsZTonIid9LHtiOiInIixlOiInIn1dfV19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJwZXJsIixmdW5jdGlvbihlKXt2YXIgdD0iZ2V0cHdlbnQgZ2V0c2VydmVudCBxdW90ZW1ldGEgbXNncmN2IHNjYWxhciBraWxsIGRibWNsb3NlIHVuZGVmIGxjIG1hIHN5c3dyaXRlIHRyIHNlbmQgdW1hc2sgc3lzb3BlbiBzaG13cml0ZSB2ZWMgcXggdXRpbWUgbG9jYWwgb2N0IHNlbWN0bCBsb2NhbHRpbWUgcmVhZHBpcGUgZG8gcmV0dXJuIGZvcm1hdCByZWFkIHNwcmludGYgZGJtb3BlbiBwb3AgZ2V0cGdycCBub3QgZ2V0cHduYW0gcmV3aW5kZGlyIHFxZmlsZW5vIHF3IGVuZHByb3RvZW50IHdhaXQgc2V0aG9zdGVudCBibGVzcyBzfDAgb3BlbmRpciBjb250aW51ZSBlYWNoIHNsZWVwIGVuZGdyZW50IHNodXRkb3duIGR1bXAgY2hvbXAgY29ubmVjdCBnZXRzb2NrbmFtZSBkaWUgc29ja2V0cGFpciBjbG9zZSBmbG9jayBleGlzdHMgaW5kZXggc2htZ2V0c3ViIGZvciBlbmRwd2VudCByZWRvIGxzdGF0IG1zZ2N0bCBzZXRwZ3JwIGFicyBleGl0IHNlbGVjdCBwcmludCByZWYgZ2V0aG9zdGJ5YWRkciB1bnNoaWZ0IGZjbnRsIHN5c2NhbGwgZ290byBnZXRuZXRieWFkZHIgam9pbiBnbXRpbWUgc3ltbGluayBzZW1nZXQgc3BsaWNlIHh8MCBnZXRwZWVybmFtZSByZWN2IGxvZyBzZXRzb2Nrb3B0IGNvcyBsYXN0IHJldmVyc2UgZ2V0aG9zdGJ5bmFtZSBnZXRncm5hbSBzdHVkeSBmb3JtbGluZSBlbmRob3N0ZW50IHRpbWVzIGNob3AgbGVuZ3RoIGdldGhvc3RlbnQgZ2V0bmV0ZW50IHBhY2sgZ2V0cHJvdG9lbnQgZ2V0c2VydmJ5bmFtZSByYW5kIG1rZGlyIHBvcyBjaG1vZCB5fDAgc3Vic3RyIGVuZG5ldGVudCBwcmludGYgbmV4dCBvcGVuIG1zZ3NuZCByZWFkZGlyIHVzZSB1bmxpbmsgZ2V0c29ja29wdCBnZXRwcmlvcml0eSByaW5kZXggd2FudGFycmF5IGhleCBzeXN0ZW0gZ2V0c2VydmJ5cG9ydCBlbmRzZXJ2ZW50IGludCBjaHIgdW50aWUgcm1kaXIgcHJvdG90eXBlIHRlbGwgbGlzdGVuIGZvcmsgc2htcmVhZCB1Y2ZpcnN0IHNldHByb3RvZW50IGVsc2Ugc3lzc2VlayBsaW5rIGdldGdyZ2lkIHNobWN0bCB3YWl0cGlkIHVucGFjayBnZXRuZXRieW5hbWUgcmVzZXQgY2hkaXIgZ3JlcCBzcGxpdCByZXF1aXJlIGNhbGxlciBsY2ZpcnN0IHVudGlsIHdhcm4gd2hpbGUgdmFsdWVzIHNoaWZ0IHRlbGxkaXIgZ2V0cHd1aWQgbXkgZ2V0cHJvdG9ieW51bWJlciBkZWxldGUgYW5kIHNvcnQgdWMgZGVmaW5lZCBzcmFuZCBhY2NlcHQgcGFja2FnZSBzZWVrZGlyIGdldHByb3RvYnluYW1lIHNlbW9wIG91ciByZW5hbWUgc2VlayBpZiBxfDAgY2hyb290IHN5c3JlYWQgc2V0cHdlbnQgbm8gY3J5cHQgZ2V0YyBjaG93biBzcXJ0IHdyaXRlIHNldG5ldGVudCBzZXRwcmlvcml0eSBmb3JlYWNoIHRpZSBzaW4gbXNnZ2V0IG1hcCBzdGF0IGdldGxvZ2luIHVubGVzcyBlbHNpZiB0cnVuY2F0ZSBleGVjIGtleXMgZ2xvYiB0aWVkIGNsb3NlZGlyaW9jdGwgc29ja2V0IHJlYWRsaW5rIGV2YWwgeG9yIHJlYWRsaW5lIGJpbm1vZGUgc2V0c2VydmVudCBlb2Ygb3JkIGJpbmQgYWxhcm0gcGlwZSBhdGFuMiBnZXRncmVudCBleHAgdGltZSBwdXNoIHNldGdyZW50IGd0IGx0IG9yIG5lIG18MCBicmVhayBnaXZlbiBzYXkgc3RhdGUgd2hlbiIscj17Y046InN1YnN0IixiOiJbJEBdXFx7IixlOiJcXH0iLGs6dH0scz17YjoiLT57IixlOiJ9In0sbj17djpbe2I6L1wkXGQvfSx7YjovW1wkJUBdKFxeXHdcYnwjXHcrKDo6XHcrKSp8e1x3K318XHcrKDo6XHcqKSopL30se2I6L1tcJCVAXVteXHNcd3tdLyxyOjB9XX0saT1bZS5CRSxyLG5dLG89W24sZS5IQ00sZS5DKCJeXFw9XFx3IiwiXFw9Y3V0Iix7ZVc6ITB9KSxzLHtjTjoic3RyaW5nIixjOmksdjpbe2I6InFbcXd4cl0/XFxzKlxcKCIsZToiXFwpIixyOjV9LHtiOiJxW3F3eHJdP1xccypcXFsiLGU6IlxcXSIscjo1fSx7YjoicVtxd3hyXT9cXHMqXFx7IixlOiJcXH0iLHI6NX0se2I6InFbcXd4cl0/XFxzKlxcfCIsZToiXFx8IixyOjV9LHtiOiJxW3F3eHJdP1xccypcXDwiLGU6IlxcPiIscjo1fSx7YjoicXdcXHMrcSIsZToicSIscjo1fSx7YjoiJyIsZToiJyIsYzpbZS5CRV19LHtiOiciJyxlOiciJ30se2I6ImAiLGU6ImAiLGM6W2UuQkVdfSx7Yjoie1xcdyt9IixjOltdLHI6MH0se2I6Ii0/XFx3K1xccypcXD1cXD4iLGM6W10scjowfV19LHtjTjoibnVtYmVyIixiOiIoXFxiMFswLTdfXSspfChcXGIweFswLTlhLWZBLUZfXSspfChcXGJbMS05XVswLTlfXSooXFwuWzAtOV9dKyk/KXxbMF9dXFxiIixyOjB9LHtiOiIoXFwvXFwvfCIrZS5SU1IrInxcXGIoc3BsaXR8cmV0dXJufHByaW50fHJldmVyc2V8Z3JlcClcXGIpXFxzKiIsazoic3BsaXQgcmV0dXJuIHByaW50IHJldmVyc2UgZ3JlcCIscjowLGM6W2UuSENNLHtjTjoicmVnZXhwIixiOiIoc3x0cnx5KS8oXFxcXC58W14vXSkqLyhcXFxcLnxbXi9dKSovW2Etel0qIixyOjEwfSx7Y046InJlZ2V4cCIsYjoiKG18cXIpPy8iLGU6Ii9bYS16XSoiLGM6W2UuQkVdLHI6MH1dfSx7Y046ImZ1bmN0aW9uIixiSzoic3ViIixlOiIoXFxzKlxcKC4qP1xcKSk/Wzt7XSIsZUU6ITAscjo1LGM6W2UuVE1dfSx7YjoiLVxcd1xcYiIscjowfSx7YjoiXl9fREFUQV9fJCIsZToiXl9fRU5EX18kIixzTDoibW9qb2xpY2lvdXMiLGM6W3tiOiJeQEAuKiIsZToiJCIsY046ImNvbW1lbnQifV19XTtyZXR1cm4gci5jPW8scy5jPW8se2FsaWFzZXM6WyJwbCIsInBtIl0sbDovW1x3XC5dKy8sazp0LGM6b319KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoImluaSIsZnVuY3Rpb24oZSl7dmFyIGI9e2NOOiJzdHJpbmciLGM6W2UuQkVdLHY6W3tiOiInJyciLGU6IicnJyIscjoxMH0se2I6JyIiIicsZTonIiIiJyxyOjEwfSx7YjonIicsZTonIid9LHtiOiInIixlOiInIn1dfTtyZXR1cm57YWxpYXNlczpbInRvbWwiXSxjSTohMCxpOi9cUy8sYzpbZS5DKCI7IiwiJCIpLGUuSENNLHtjTjoic2VjdGlvbiIsYjovXlxzKlxbKy8sZTovXF0rL30se2I6L15bYS16MC05XFtcXV8tXStccyo9XHMqLyxlOiIkIixyQjohMCxjOlt7Y046ImF0dHIiLGI6L1thLXowLTlcW1xdXy1dKy99LHtiOi89LyxlVzohMCxyOjAsYzpbe2NOOiJsaXRlcmFsIixiOi9cYm9ufG9mZnx0cnVlfGZhbHNlfHllc3xub1xiL30se2NOOiJ2YXJpYWJsZSIsdjpbe2I6L1wkW1x3XGQiXVtcd1xkX10qL30se2I6L1wkXHsoLio/KX0vfV19LGIse2NOOiJudW1iZXIiLGI6LyhbXCtcLV0rKT9bXGRdK19bXGRfXSsvfSxlLk5NXX1dfV19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJkaWZmIixmdW5jdGlvbihlKXtyZXR1cm57YWxpYXNlczpbInBhdGNoIl0sYzpbe2NOOiJtZXRhIixyOjEwLHY6W3tiOi9eQEAgK1wtXGQrLFxkKyArXCtcZCssXGQrICtAQCQvfSx7YjovXlwqXCpcKiArXGQrLFxkKyArXCpcKlwqXCokL30se2I6L15cLVwtXC0gK1xkKyxcZCsgK1wtXC1cLVwtJC99XX0se2NOOiJjb21tZW50Iix2Olt7YjovSW5kZXg6IC8sZTovJC99LHtiOi89ezMsfS8sZTovJC99LHtiOi9eXC17M30vLGU6LyQvfSx7YjovXlwqezN9IC8sZTovJC99LHtiOi9eXCt7M30vLGU6LyQvfSx7YjovXCp7NX0vLGU6L1wqezV9JC99XX0se2NOOiJhZGRpdGlvbiIsYjoiXlxcKyIsZToiJCJ9LHtjTjoiZGVsZXRpb24iLGI6Il5cXC0iLGU6IiQifSx7Y046ImFkZGl0aW9uIixiOiJeXFwhIixlOiIkIn1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiZ28iLGZ1bmN0aW9uKGUpe3ZhciB0PXtrZXl3b3JkOiJicmVhayBkZWZhdWx0IGZ1bmMgaW50ZXJmYWNlIHNlbGVjdCBjYXNlIG1hcCBzdHJ1Y3QgY2hhbiBlbHNlIGdvdG8gcGFja2FnZSBzd2l0Y2ggY29uc3QgZmFsbHRocm91Z2ggaWYgcmFuZ2UgdHlwZSBjb250aW51ZSBmb3IgaW1wb3J0IHJldHVybiB2YXIgZ28gZGVmZXIgYm9vbCBieXRlIGNvbXBsZXg2NCBjb21wbGV4MTI4IGZsb2F0MzIgZmxvYXQ2NCBpbnQ4IGludDE2IGludDMyIGludDY0IHN0cmluZyB1aW50OCB1aW50MTYgdWludDMyIHVpbnQ2NCBpbnQgdWludCB1aW50cHRyIHJ1bmUiLGxpdGVyYWw6InRydWUgZmFsc2UgaW90YSBuaWwiLGJ1aWx0X2luOiJhcHBlbmQgY2FwIGNsb3NlIGNvbXBsZXggY29weSBpbWFnIGxlbiBtYWtlIG5ldyBwYW5pYyBwcmludCBwcmludGxuIHJlYWwgcmVjb3ZlciBkZWxldGUifTtyZXR1cm57YWxpYXNlczpbImdvbGFuZyJdLGs6dCxpOiI8LyIsYzpbZS5DTENNLGUuQ0JDTSx7Y046InN0cmluZyIsdjpbZS5RU00se2I6IiciLGU6IlteXFxcXF0nIn0se2I6ImAiLGU6ImAifV19LHtjTjoibnVtYmVyIix2Olt7YjplLkNOUisiW2RmbHNpXSIscjoxfSxlLkNOTV19LHtiOi86PS99LHtjTjoiZnVuY3Rpb24iLGJLOiJmdW5jIixlOi9ccypcey8sZUU6ITAsYzpbZS5UTSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxrOnQsaTovWyInXS99XX1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiYmFzaCIsZnVuY3Rpb24oZSl7dmFyIHQ9e2NOOiJ2YXJpYWJsZSIsdjpbe2I6L1wkW1x3XGQjQF1bXHdcZF9dKi99LHtiOi9cJFx7KC4qPyl9L31dfSxzPXtjTjoic3RyaW5nIixiOi8iLyxlOi8iLyxjOltlLkJFLHQse2NOOiJ2YXJpYWJsZSIsYjovXCRcKC8sZTovXCkvLGM6W2UuQkVdfV19LGE9e2NOOiJzdHJpbmciLGI6LycvLGU6LycvfTtyZXR1cm57YWxpYXNlczpbInNoIiwienNoIl0sbDovXGItP1thLXpcLl9dK1xiLyxrOntrZXl3b3JkOiJpZiB0aGVuIGVsc2UgZWxpZiBmaSBmb3Igd2hpbGUgaW4gZG8gZG9uZSBjYXNlIGVzYWMgZnVuY3Rpb24iLGxpdGVyYWw6InRydWUgZmFsc2UiLGJ1aWx0X2luOiJicmVhayBjZCBjb250aW51ZSBldmFsIGV4ZWMgZXhpdCBleHBvcnQgZ2V0b3B0cyBoYXNoIHB3ZCByZWFkb25seSByZXR1cm4gc2hpZnQgdGVzdCB0aW1lcyB0cmFwIHVtYXNrIHVuc2V0IGFsaWFzIGJpbmQgYnVpbHRpbiBjYWxsZXIgY29tbWFuZCBkZWNsYXJlIGVjaG8gZW5hYmxlIGhlbHAgbGV0IGxvY2FsIGxvZ291dCBtYXBmaWxlIHByaW50ZiByZWFkIHJlYWRhcnJheSBzb3VyY2UgdHlwZSB0eXBlc2V0IHVsaW1pdCB1bmFsaWFzIHNldCBzaG9wdCBhdXRvbG9hZCBiZyBiaW5ka2V5IGJ5ZSBjYXAgY2hkaXIgY2xvbmUgY29tcGFyZ3VtZW50cyBjb21wY2FsbCBjb21wY3RsIGNvbXBkZXNjcmliZSBjb21wZmlsZXMgY29tcGdyb3VwcyBjb21wcXVvdGUgY29tcHRhZ3MgY29tcHRyeSBjb21wdmFsdWVzIGRpcnMgZGlzYWJsZSBkaXNvd24gZWNob3RjIGVjaG90aSBlbXVsYXRlIGZjIGZnIGZsb2F0IGZ1bmN0aW9ucyBnZXRjYXAgZ2V0bG4gaGlzdG9yeSBpbnRlZ2VyIGpvYnMga2lsbCBsaW1pdCBsb2cgbm9nbG9iIHBvcGQgcHJpbnQgcHVzaGQgcHVzaGxuIHJlaGFzaCBzY2hlZCBzZXRjYXAgc2V0b3B0IHN0YXQgc3VzcGVuZCB0dHljdGwgdW5mdW5jdGlvbiB1bmhhc2ggdW5saW1pdCB1bnNldG9wdCB2YXJlZCB3YWl0IHdoZW5jZSB3aGVyZSB3aGljaCB6Y29tcGlsZSB6Zm9ybWF0IHpmdHAgemxlIHptb2Rsb2FkIHpwYXJzZW9wdHMgenByb2YgenB0eSB6cmVnZXhwYXJzZSB6c29ja2V0IHpzdHlsZSB6dGNwIixfOiItbmUgLWVxIC1sdCAtZ3QgLWYgLWQgLWUgLXMgLWwgLWEifSxjOlt7Y046Im1ldGEiLGI6L14jIVteXG5dK3NoXHMqJC8scjoxMH0se2NOOiJmdW5jdGlvbiIsYjovXHdbXHdcZF9dKlxzKlwoXHMqXClccypcey8sckI6ITAsYzpbZS5pbmhlcml0KGUuVE0se2I6L1x3W1x3XGRfXSovfSldLHI6MH0sZS5IQ00scyxhLHRdfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgicHl0aG9uIixmdW5jdGlvbihlKXt2YXIgcj17a2V5d29yZDoiYW5kIGVsaWYgaXMgZ2xvYmFsIGFzIGluIGlmIGZyb20gcmFpc2UgZm9yIGV4Y2VwdCBmaW5hbGx5IHByaW50IGltcG9ydCBwYXNzIHJldHVybiBleGVjIGVsc2UgYnJlYWsgbm90IHdpdGggY2xhc3MgYXNzZXJ0IHlpZWxkIHRyeSB3aGlsZSBjb250aW51ZSBkZWwgb3IgZGVmIGxhbWJkYSBhc3luYyBhd2FpdCBub25sb2NhbHwxMCBOb25lIFRydWUgRmFsc2UiLGJ1aWx0X2luOiJFbGxpcHNpcyBOb3RJbXBsZW1lbnRlZCJ9LGI9e2NOOiJtZXRhIixiOi9eKD4+PnxcLlwuXC4pIC99LGM9e2NOOiJzdWJzdCIsYjovXHsvLGU6L1x9LyxrOnIsaTovIy99LGE9e2NOOiJzdHJpbmciLGM6W2UuQkVdLHY6W3tiOi8odXxiKT9yPycnJy8sZTovJycnLyxjOltiXSxyOjEwfSx7YjovKHV8Yik/cj8iIiIvLGU6LyIiIi8sYzpbYl0scjoxMH0se2I6LyhmcnxyZnxmKScnJy8sZTovJycnLyxjOltiLGNdfSx7YjovKGZyfHJmfGYpIiIiLyxlOi8iIiIvLGM6W2IsY119LHtiOi8odXxyfHVyKScvLGU6LycvLHI6MTB9LHtiOi8odXxyfHVyKSIvLGU6LyIvLHI6MTB9LHtiOi8oYnxiciknLyxlOi8nL30se2I6LyhifGJyKSIvLGU6LyIvfSx7YjovKGZyfHJmfGYpJy8sZTovJy8sYzpbY119LHtiOi8oZnJ8cmZ8ZikiLyxlOi8iLyxjOltjXX0sZS5BU00sZS5RU01dfSxzPXtjTjoibnVtYmVyIixyOjAsdjpbe2I6ZS5CTlIrIltsTGpKXT8ifSx7YjoiXFxiKDBvWzAtN10rKVtsTGpKXT8ifSx7YjplLkNOUisiW2xMakpdPyJ9XX0saT17Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxjOlsic2VsZiIsYixzLGFdfTtyZXR1cm4gYy5jPVthLHMsYl0se2FsaWFzZXM6WyJweSIsImd5cCJdLGs6cixpOi8oPFwvfC0+fFw/KXw9Pi8sYzpbYixzLGEsZS5IQ00se3Y6W3tjTjoiZnVuY3Rpb24iLGJLOiJkZWYifSx7Y046ImNsYXNzIixiSzoiY2xhc3MifV0sZTovOi8saTovWyR7PTtcbixdLyxjOltlLlVUTSxpLHtiOi8tPi8sZVc6ITAsazoiTm9uZSJ9XX0se2NOOiJtZXRhIixiOi9eW1x0IF0qQC8sZTovJC99LHtiOi9cYihwcmludHxleGVjKVwoL31dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgianVsaWEiLGZ1bmN0aW9uKGUpe3ZhciByPXtrZXl3b3JkOiJpbiBpc2Egd2hlcmUgYmFyZW1vZHVsZSBiZWdpbiBicmVhayBjYXRjaCBjY2FsbCBjb25zdCBjb250aW51ZSBkbyBlbHNlIGVsc2VpZiBlbmQgZXhwb3J0IGZhbHNlIGZpbmFsbHkgZm9yIGZ1bmN0aW9uIGdsb2JhbCBpZiBpbXBvcnQgaW1wb3J0YWxsIGxldCBsb2NhbCBtYWNybyBtb2R1bGUgcXVvdGUgcmV0dXJuIHRydWUgdHJ5IHVzaW5nIHdoaWxlIHR5cGUgaW1tdXRhYmxlIGFic3RyYWN0IGJpdHN0eXBlIHR5cGVhbGlhcyAiLGxpdGVyYWw6InRydWUgZmFsc2UgQVJHUyBDX05VTEwgRGV2TnVsbCBFTkRJQU5fQk9NIEVOViBJIEluZiBJbmYxNiBJbmYzMiBJbmY2NCBJbnNlcnRpb25Tb3J0IEpVTElBX0hPTUUgTE9BRF9QQVRIIE1lcmdlU29ydCBOYU4gTmFOMTYgTmFOMzIgTmFONjQgUFJPR1JBTV9GSUxFIFF1aWNrU29ydCBSb3VuZERvd24gUm91bmRGcm9tWmVybyBSb3VuZE5lYXJlc3QgUm91bmROZWFyZXN0VGllc0F3YXkgUm91bmROZWFyZXN0VGllc1VwIFJvdW5kVG9aZXJvIFJvdW5kVXAgU1RERVJSIFNURElOIFNURE9VVCBWRVJTSU9OIGNhdGFsYW4gZXwwIGV1fDAgZXVsZXJnYW1tYSBnb2xkZW4gaW0gbm90aGluZyBwaSDOsyDPgCDPhiAiLGJ1aWx0X2luOiJBTlkgQWJzdHJhY3RBcnJheSBBYnN0cmFjdENoYW5uZWwgQWJzdHJhY3RGbG9hdCBBYnN0cmFjdE1hdHJpeCBBYnN0cmFjdFJORyBBYnN0cmFjdFNlcmlhbGl6ZXIgQWJzdHJhY3RTZXQgQWJzdHJhY3RTcGFyc2VBcnJheSBBYnN0cmFjdFNwYXJzZU1hdHJpeCBBYnN0cmFjdFNwYXJzZVZlY3RvciBBYnN0cmFjdFN0cmluZyBBYnN0cmFjdFVuaXRSYW5nZSBBYnN0cmFjdFZlY09yTWF0IEFic3RyYWN0VmVjdG9yIEFueSBBcmd1bWVudEVycm9yIEFycmF5IEFzc2VydGlvbkVycm9yIEFzc29jaWF0aXZlIEJhc2U2NERlY29kZVBpcGUgQmFzZTY0RW5jb2RlUGlwZSBCaWRpYWdvbmFsIEJpZ0Zsb2F0IEJpZ0ludCBCaXRBcnJheSBCaXRNYXRyaXggQml0VmVjdG9yIEJvb2wgQm91bmRzRXJyb3IgQnVmZmVyU3RyZWFtIENhY2hpbmdQb29sIENhcHR1cmVkRXhjZXB0aW9uIENhcnRlc2lhbkluZGV4IENhcnRlc2lhblJhbmdlIENjaGFyIENkb3VibGUgQ2Zsb2F0IENoYW5uZWwgQ2hhciBDaW50IENpbnRtYXhfdCBDbG9uZyBDbG9uZ2xvbmcgQ2x1c3Rlck1hbmFnZXIgQ21kIENvZGVJbmZvIENvbG9uIENvbXBsZXggQ29tcGxleDEyOCBDb21wbGV4MzIgQ29tcGxleDY0IENvbXBvc2l0ZUV4Y2VwdGlvbiBDb25kaXRpb24gQ29uakFycmF5IENvbmpNYXRyaXggQ29ualZlY3RvciBDcHRyZGlmZl90IENzaG9ydCBDc2l6ZV90IENzc2l6ZV90IENzdHJpbmcgQ3VjaGFyIEN1aW50IEN1aW50bWF4X3QgQ3Vsb25nIEN1bG9uZ2xvbmcgQ3VzaG9ydCBDd2NoYXJfdCBDd3N0cmluZyBEYXRhVHlwZSBEYXRlIERhdGVGb3JtYXQgRGF0ZVRpbWUgRGVuc2VBcnJheSBEZW5zZU1hdHJpeCBEZW5zZVZlY09yTWF0IERlbnNlVmVjdG9yIERpYWdvbmFsIERpY3QgRGltZW5zaW9uTWlzbWF0Y2ggRGltcyBEaXJlY3RJbmRleFN0cmluZyBEaXNwbGF5IERpdmlkZUVycm9yIERvbWFpbkVycm9yIEVPRkVycm9yIEVhY2hMaW5lIEVudW0gRW51bWVyYXRlIEVycm9yRXhjZXB0aW9uIEV4Y2VwdGlvbiBFeHBvbmVudGlhbEJhY2tPZmYgRXhwciBGYWN0b3JpemF0aW9uIEZpbGVNb25pdG9yIEZsb2F0MTYgRmxvYXQzMiBGbG9hdDY0IEZ1bmN0aW9uIEZ1dHVyZSBHbG9iYWxSZWYgR290b05vZGUgSFRNTCBIZXJtaXRpYW4gSU8gSU9CdWZmZXIgSU9Db250ZXh0IElPU3RyZWFtIElQQWRkciBJUHY0IElQdjYgSW5kZXhDYXJ0ZXNpYW4gSW5kZXhMaW5lYXIgSW5kZXhTdHlsZSBJbmV4YWN0RXJyb3IgSW5pdEVycm9yIEludCBJbnQxMjggSW50MTYgSW50MzIgSW50NjQgSW50OCBJbnRTZXQgSW50ZWdlciBJbnRlcnJ1cHRFeGNlcHRpb24gSW52YWxpZFN0YXRlRXhjZXB0aW9uIElycmF0aW9uYWwgS2V5RXJyb3IgTGFiZWxOb2RlIExpblNwYWNlIExpbmVOdW1iZXJOb2RlIExvYWRFcnJvciBMb3dlclRyaWFuZ3VsYXIgTUlNRSBNYXRyaXggTWVyc2VubmVUd2lzdGVyIE1ldGhvZCBNZXRob2RFcnJvciBNZXRob2RUYWJsZSBNb2R1bGUgTlR1cGxlIE5ld3Zhck5vZGUgTnVsbEV4Y2VwdGlvbiBOdWxsYWJsZSBOdW1iZXIgT2JqZWN0SWREaWN0IE9yZGluYWxSYW5nZSBPdXRPZk1lbW9yeUVycm9yIE92ZXJmbG93RXJyb3IgUGFpciBQYXJzZUVycm9yIFBhcnRpYWxRdWlja1NvcnQgUGVybXV0ZWREaW1zQXJyYXkgUGlwZSBQb2xsaW5nRmlsZVdhdGNoZXIgUHJvY2Vzc0V4aXRlZEV4Y2VwdGlvbiBQdHIgUXVvdGVOb2RlIFJhbmRvbURldmljZSBSYW5nZSBSYW5nZUluZGV4IFJhdGlvbmFsIFJhd0ZEIFJlYWRPbmx5TWVtb3J5RXJyb3IgUmVhbCBSZWVudHJhbnRMb2NrIFJlZiBSZWdleCBSZWdleE1hdGNoIFJlbW90ZUNoYW5uZWwgUmVtb3RlRXhjZXB0aW9uIFJldlN0cmluZyBSb3VuZGluZ01vZGUgUm93VmVjdG9yIFNTQVZhbHVlIFNlZ21lbnRhdGlvbkZhdWx0IFNlcmlhbGl6YXRpb25TdGF0ZSBTZXQgU2hhcmVkQXJyYXkgU2hhcmVkTWF0cml4IFNoYXJlZFZlY3RvciBTaWduZWQgU2ltcGxlVmVjdG9yIFNsb3QgU2xvdE51bWJlciBTcGFyc2VNYXRyaXhDU0MgU3BhcnNlVmVjdG9yIFN0YWNrRnJhbWUgU3RhY2tPdmVyZmxvd0Vycm9yIFN0YWNrVHJhY2UgU3RlcFJhbmdlIFN0ZXBSYW5nZUxlbiBTdHJpZGVkQXJyYXkgU3RyaWRlZE1hdHJpeCBTdHJpZGVkVmVjT3JNYXQgU3RyaWRlZFZlY3RvciBTdHJpbmcgU3ViQXJyYXkgU3ViU3RyaW5nIFN5bVRyaWRpYWdvbmFsIFN5bWJvbCBTeW1tZXRyaWMgU3lzdGVtRXJyb3IgVENQU29ja2V0IFRhc2sgVGV4dCBUZXh0RGlzcGxheSBUaW1lciBUcmlkaWFnb25hbCBUdXBsZSBUeXBlIFR5cGVFcnJvciBUeXBlTWFwRW50cnkgVHlwZU1hcExldmVsIFR5cGVOYW1lIFR5cGVWYXIgVHlwZWRTbG90IFVEUFNvY2tldCBVSW50IFVJbnQxMjggVUludDE2IFVJbnQzMiBVSW50NjQgVUludDggVW5kZWZSZWZFcnJvciBVbmRlZlZhckVycm9yIFVuaWNvZGVFcnJvciBVbmlmb3JtU2NhbGluZyBVbmlvbiBVbmlvbkFsbCBVbml0UmFuZ2UgVW5zaWduZWQgVXBwZXJUcmlhbmd1bGFyIFZhbCBWYXJhcmcgVmVjRWxlbWVudCBWZWNPck1hdCBWZWN0b3IgVmVyc2lvbk51bWJlciBWb2lkIFdlYWtLZXlEaWN0IFdlYWtSZWYgV29ya2VyQ29uZmlnIFdvcmtlclBvb2wgIn0sdD0iW0EtWmEtel9cXHUwMEExLVxcdUZGRkZdW0EtWmEtel8wLTlcXHUwMEExLVxcdUZGRkZdKiIsYT17bDp0LGs6cixpOi88XC8vfSxuPXtjTjoibnVtYmVyIixiOi8oXGIweFtcZF9dKihcLltcZF9dKik/fDB4XC5cZFtcZF9dKilwWy0rXT9cZCt8XGIwW2JveF1bYS1mQS1GMC05XVthLWZBLUYwLTlfXSp8KFxiXGRbXGRfXSooXC5bXGRfXSopP3xcLlxkW1xkX10qKShbZUVmRl1bLStdP1xkKyk/LyxyOjB9LG89e2NOOiJzdHJpbmciLGI6LycoLnxcXFt4WHVVXVthLXpBLVowLTldKyknL30saT17Y046InN1YnN0IixiOi9cJFwoLyxlOi9cKS8sazpyfSxsPXtjTjoidmFyaWFibGUiLGI6IlxcJCIrdH0sYz17Y046InN0cmluZyIsYzpbZS5CRSxpLGxdLHY6W3tiOi9cdyoiIiIvLGU6LyIiIlx3Ki8scjoxMH0se2I6L1x3KiIvLGU6LyJcdyovfV19LHM9e2NOOiJzdHJpbmciLGM6W2UuQkUsaSxsXSxiOiJgIixlOiJgIn0sZD17Y046Im1ldGEiLGI6IkAiK3R9LHU9e2NOOiJjb21tZW50Iix2Olt7YjoiIz0iLGU6Ij0jIixyOjEwfSx7YjoiIyIsZToiJCJ9XX07cmV0dXJuIGEuYz1bbixvLGMscyxkLHUsZS5IQ00se2NOOiJrZXl3b3JkIixiOiJcXGIoKChhYnN0cmFjdHxwcmltaXRpdmUpXFxzKyl0eXBlfChtdXRhYmxlXFxzKyk/c3RydWN0KVxcYiJ9LHtiOi88Oi99XSxpLmM9YS5jLGF9KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoImNvZmZlZXNjcmlwdCIsZnVuY3Rpb24oZSl7dmFyIGM9e2tleXdvcmQ6ImluIGlmIGZvciB3aGlsZSBmaW5hbGx5IG5ldyBkbyByZXR1cm4gZWxzZSBicmVhayBjYXRjaCBpbnN0YW5jZW9mIHRocm93IHRyeSB0aGlzIHN3aXRjaCBjb250aW51ZSB0eXBlb2YgZGVsZXRlIGRlYnVnZ2VyIHN1cGVyIHlpZWxkIGltcG9ydCBleHBvcnQgZnJvbSBhcyBkZWZhdWx0IGF3YWl0IHRoZW4gdW5sZXNzIHVudGlsIGxvb3Agb2YgYnkgd2hlbiBhbmQgb3IgaXMgaXNudCBub3QiLGxpdGVyYWw6InRydWUgZmFsc2UgbnVsbCB1bmRlZmluZWQgeWVzIG5vIG9uIG9mZiIsYnVpbHRfaW46Im5wbSByZXF1aXJlIGNvbnNvbGUgcHJpbnQgbW9kdWxlIGdsb2JhbCB3aW5kb3cgZG9jdW1lbnQifSxuPSJbQS1aYS16JF9dWzAtOUEtWmEteiRfXSoiLHI9e2NOOiJzdWJzdCIsYjovI1x7LyxlOi99LyxrOmN9LGk9W2UuQk5NLGUuaW5oZXJpdChlLkNOTSx7c3RhcnRzOntlOiIoXFxzKi8pPyIscjowfX0pLHtjTjoic3RyaW5nIix2Olt7YjovJycnLyxlOi8nJycvLGM6W2UuQkVdfSx7YjovJy8sZTovJy8sYzpbZS5CRV19LHtiOi8iIiIvLGU6LyIiIi8sYzpbZS5CRSxyXX0se2I6LyIvLGU6LyIvLGM6W2UuQkUscl19XX0se2NOOiJyZWdleHAiLHY6W3tiOiIvLy8iLGU6Ii8vLyIsYzpbcixlLkhDTV19LHtiOiIvL1tnaW1dKiIscjowfSx7YjovXC8oPyFbICpdKShcXFwvfC4pKj9cL1tnaW1dKig/PVxXfCQpL31dfSx7YjoiQCIrbn0se3NMOiJqYXZhc2NyaXB0IixlQjohMCxlRTohMCx2Olt7YjoiYGBgIixlOiJgYGAifSx7YjoiYCIsZToiYCJ9XX1dO3IuYz1pO3ZhciBzPWUuaW5oZXJpdChlLlRNLHtiOm59KSx0PSIoXFwoLipcXCkpP1xccypcXEJbLT1dPiIsbz17Y046InBhcmFtcyIsYjoiXFwoW15cXChdIixyQjohMCxjOlt7YjovXCgvLGU6L1wpLyxrOmMsYzpbInNlbGYiXS5jb25jYXQoaSl9XX07cmV0dXJue2FsaWFzZXM6WyJjb2ZmZWUiLCJjc29uIiwiaWNlZCJdLGs6YyxpOi9cL1wqLyxjOmkuY29uY2F0KFtlLkMoIiMjIyIsIiMjIyIpLGUuSENNLHtjTjoiZnVuY3Rpb24iLGI6Il5cXHMqIituKyJcXHMqPVxccyoiK3QsZToiWy09XT4iLHJCOiEwLGM6W3Msb119LHtiOi9bOlwoLD1dXHMqLyxyOjAsYzpbe2NOOiJmdW5jdGlvbiIsYjp0LGU6IlstPV0+IixyQjohMCxjOltvXX1dfSx7Y046ImNsYXNzIixiSzoiY2xhc3MiLGU6IiQiLGk6L1s6PSJcW1xdXS8sYzpbe2JLOiJleHRlbmRzIixlVzohMCxpOi9bOj0iXFtcXV0vLGM6W3NdfSxzXX0se2I6bisiOiIsZToiOiIsckI6ITAsckU6ITAscjowfV0pfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiY3BwIixmdW5jdGlvbih0KXt2YXIgZT17Y046ImtleXdvcmQiLGI6IlxcYlthLXpcXGRfXSpfdFxcYiJ9LHI9e2NOOiJzdHJpbmciLHY6W3tiOicodTg/fFUpP0w/IicsZTonIicsaToiXFxuIixjOlt0LkJFXX0se2I6Jyh1OD98VSk/UiInLGU6JyInLGM6W3QuQkVdfSx7YjoiJ1xcXFw/LiIsZToiJyIsaToiLiJ9XX0scz17Y046Im51bWJlciIsdjpbe2I6IlxcYigwYlswMSddKykifSx7YjoiKC0/KVxcYihbXFxkJ10rKFxcLltcXGQnXSopP3xcXC5bXFxkJ10rKSh1fFV8bHxMfHVsfFVMfGZ8RnxifEIpIn0se2I6IigtPykoXFxiMFt4WF1bYS1mQS1GMC05J10rfChcXGJbXFxkJ10rKFxcLltcXGQnXSopP3xcXC5bXFxkJ10rKShbZUVdWy0rXT9bXFxkJ10rKT8pIn1dLHI6MH0saT17Y046Im1ldGEiLGI6LyNccypbYS16XStcYi8sZTovJC8sazp7Im1ldGEta2V5d29yZCI6ImlmIGVsc2UgZWxpZiBlbmRpZiBkZWZpbmUgdW5kZWYgd2FybmluZyBlcnJvciBsaW5lIHByYWdtYSBpZmRlZiBpZm5kZWYgaW5jbHVkZSJ9LGM6W3tiOi9cXFxuLyxyOjB9LHQuaW5oZXJpdChyLHtjTjoibWV0YS1zdHJpbmcifSkse2NOOiJtZXRhLXN0cmluZyIsYjovPFteXG4+XSo+LyxlOi8kLyxpOiJcXG4ifSx0LkNMQ00sdC5DQkNNXX0sYT10LklSKyJcXHMqXFwoIixjPXtrZXl3b3JkOiJpbnQgZmxvYXQgd2hpbGUgcHJpdmF0ZSBjaGFyIGNhdGNoIGltcG9ydCBtb2R1bGUgZXhwb3J0IHZpcnR1YWwgb3BlcmF0b3Igc2l6ZW9mIGR5bmFtaWNfY2FzdHwxMCB0eXBlZGVmIGNvbnN0X2Nhc3R8MTAgY29uc3QgZm9yIHN0YXRpY19jYXN0fDEwIHVuaW9uIG5hbWVzcGFjZSB1bnNpZ25lZCBsb25nIHZvbGF0aWxlIHN0YXRpYyBwcm90ZWN0ZWQgYm9vbCB0ZW1wbGF0ZSBtdXRhYmxlIGlmIHB1YmxpYyBmcmllbmQgZG8gZ290byBhdXRvIHZvaWQgZW51bSBlbHNlIGJyZWFrIGV4dGVybiB1c2luZyBhc20gY2FzZSB0eXBlaWQgc2hvcnQgcmVpbnRlcnByZXRfY2FzdHwxMCBkZWZhdWx0IGRvdWJsZSByZWdpc3RlciBleHBsaWNpdCBzaWduZWQgdHlwZW5hbWUgdHJ5IHRoaXMgc3dpdGNoIGNvbnRpbnVlIGlubGluZSBkZWxldGUgYWxpZ25vZiBjb25zdGV4cHIgZGVjbHR5cGUgbm9leGNlcHQgc3RhdGljX2Fzc2VydCB0aHJlYWRfbG9jYWwgcmVzdHJpY3QgX0Jvb2wgY29tcGxleCBfQ29tcGxleCBfSW1hZ2luYXJ5IGF0b21pY19ib29sIGF0b21pY19jaGFyIGF0b21pY19zY2hhciBhdG9taWNfdWNoYXIgYXRvbWljX3Nob3J0IGF0b21pY191c2hvcnQgYXRvbWljX2ludCBhdG9taWNfdWludCBhdG9taWNfbG9uZyBhdG9taWNfdWxvbmcgYXRvbWljX2xsb25nIGF0b21pY191bGxvbmcgbmV3IHRocm93IHJldHVybiBhbmQgb3Igbm90IixidWlsdF9pbjoic3RkIHN0cmluZyBjaW4gY291dCBjZXJyIGNsb2cgc3RkaW4gc3Rkb3V0IHN0ZGVyciBzdHJpbmdzdHJlYW0gaXN0cmluZ3N0cmVhbSBvc3RyaW5nc3RyZWFtIGF1dG9fcHRyIGRlcXVlIGxpc3QgcXVldWUgc3RhY2sgdmVjdG9yIG1hcCBzZXQgYml0c2V0IG11bHRpc2V0IG11bHRpbWFwIHVub3JkZXJlZF9zZXQgdW5vcmRlcmVkX21hcCB1bm9yZGVyZWRfbXVsdGlzZXQgdW5vcmRlcmVkX211bHRpbWFwIGFycmF5IHNoYXJlZF9wdHIgYWJvcnQgYWJzIGFjb3MgYXNpbiBhdGFuMiBhdGFuIGNhbGxvYyBjZWlsIGNvc2ggY29zIGV4aXQgZXhwIGZhYnMgZmxvb3IgZm1vZCBmcHJpbnRmIGZwdXRzIGZyZWUgZnJleHAgZnNjYW5mIGlzYWxudW0gaXNhbHBoYSBpc2NudHJsIGlzZGlnaXQgaXNncmFwaCBpc2xvd2VyIGlzcHJpbnQgaXNwdW5jdCBpc3NwYWNlIGlzdXBwZXIgaXN4ZGlnaXQgdG9sb3dlciB0b3VwcGVyIGxhYnMgbGRleHAgbG9nMTAgbG9nIG1hbGxvYyByZWFsbG9jIG1lbWNociBtZW1jbXAgbWVtY3B5IG1lbXNldCBtb2RmIHBvdyBwcmludGYgcHV0Y2hhciBwdXRzIHNjYW5mIHNpbmggc2luIHNucHJpbnRmIHNwcmludGYgc3FydCBzc2NhbmYgc3RyY2F0IHN0cmNociBzdHJjbXAgc3RyY3B5IHN0cmNzcG4gc3RybGVuIHN0cm5jYXQgc3RybmNtcCBzdHJuY3B5IHN0cnBicmsgc3RycmNociBzdHJzcG4gc3Ryc3RyIHRhbmggdGFuIHZmcHJpbnRmIHZwcmludGYgdnNwcmludGYgZW5kbCBpbml0aWFsaXplcl9saXN0IHVuaXF1ZV9wdHIiLGxpdGVyYWw6InRydWUgZmFsc2UgbnVsbHB0ciBOVUxMIn0sbj1bZSx0LkNMQ00sdC5DQkNNLHMscl07cmV0dXJue2FsaWFzZXM6WyJjIiwiY2MiLCJoIiwiYysrIiwiaCsrIiwiaHBwIl0sazpjLGk6IjwvIixjOm4uY29uY2F0KFtpLHtiOiJcXGIoZGVxdWV8bGlzdHxxdWV1ZXxzdGFja3x2ZWN0b3J8bWFwfHNldHxiaXRzZXR8bXVsdGlzZXR8bXVsdGltYXB8dW5vcmRlcmVkX21hcHx1bm9yZGVyZWRfc2V0fHVub3JkZXJlZF9tdWx0aXNldHx1bm9yZGVyZWRfbXVsdGltYXB8YXJyYXkpXFxzKjwiLGU6Ij4iLGs6YyxjOlsic2VsZiIsZV19LHtiOnQuSVIrIjo6IixrOmN9LHt2Olt7YjovPS8sZTovOy99LHtiOi9cKC8sZTovXCkvfSx7Yks6Im5ldyB0aHJvdyByZXR1cm4gZWxzZSIsZTovOy99XSxrOmMsYzpuLmNvbmNhdChbe2I6L1woLyxlOi9cKS8sazpjLGM6bi5jb25jYXQoWyJzZWxmIl0pLHI6MH1dKSxyOjB9LHtjTjoiZnVuY3Rpb24iLGI6IigiK3QuSVIrIltcXComXFxzXSspKyIrYSxyQjohMCxlOi9bezs9XS8sZUU6ITAsazpjLGk6L1teXHdcc1wqJl0vLGM6W3tiOmEsckI6ITAsYzpbdC5UTV0scjowfSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxrOmMscjowLGM6W3QuQ0xDTSx0LkNCQ00scixzLGVdfSx0LkNMQ00sdC5DQkNNLGldfSx7Y046ImNsYXNzIixiSzoiY2xhc3Mgc3RydWN0IixlOi9bezs6XS8sYzpbe2I6LzwvLGU6Lz4vLGM6WyJzZWxmIl19LHQuVE1dfV0pLGV4cG9ydHM6e3ByZXByb2Nlc3NvcjppLHN0cmluZ3M6cixrOmN9fX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgicnVieSIsZnVuY3Rpb24oZSl7dmFyIGI9IlthLXpBLVpfXVxcdypbIT89XT98Wy0rfl1cXEB8PDx8Pj58PX58PT09P3w8PT58Wzw+XT0/fFxcKlxcKnxbLS8rJV4mKn5gfF18XFxbXFxdPT8iLHI9e2tleXdvcmQ6ImFuZCB0aGVuIGRlZmluZWQgbW9kdWxlIGluIHJldHVybiByZWRvIGlmIEJFR0lOIHJldHJ5IGVuZCBmb3Igc2VsZiB3aGVuIG5leHQgdW50aWwgZG8gYmVnaW4gdW5sZXNzIEVORCByZXNjdWUgZWxzZSBicmVhayB1bmRlZiBub3Qgc3VwZXIgY2xhc3MgY2FzZSByZXF1aXJlIHlpZWxkIGFsaWFzIHdoaWxlIGVuc3VyZSBlbHNpZiBvciBpbmNsdWRlIGF0dHJfcmVhZGVyIGF0dHJfd3JpdGVyIGF0dHJfYWNjZXNzb3IiLGxpdGVyYWw6InRydWUgZmFsc2UgbmlsIn0sYz17Y046ImRvY3RhZyIsYjoiQFtBLVphLXpdKyJ9LGE9e2I6IiM8IixlOiI+In0scz1bZS5DKCIjIiwiJCIse2M6W2NdfSksZS5DKCJeXFw9YmVnaW4iLCJeXFw9ZW5kIix7YzpbY10scjoxMH0pLGUuQygiXl9fRU5EX18iLCJcXG4kIildLG49e2NOOiJzdWJzdCIsYjoiI1xceyIsZToifSIsazpyfSx0PXtjTjoic3RyaW5nIixjOltlLkJFLG5dLHY6W3tiOi8nLyxlOi8nL30se2I6LyIvLGU6LyIvfSx7YjovYC8sZTovYC99LHtiOiIlW3FRd1d4XT9cXCgiLGU6IlxcKSJ9LHtiOiIlW3FRd1d4XT9cXFsiLGU6IlxcXSJ9LHtiOiIlW3FRd1d4XT97IixlOiJ9In0se2I6IiVbcVF3V3hdPzwiLGU6Ij4ifSx7YjoiJVtxUXdXeF0/LyIsZToiLyJ9LHtiOiIlW3FRd1d4XT8lIixlOiIlIn0se2I6IiVbcVF3V3hdPy0iLGU6Ii0ifSx7YjoiJVtxUXdXeF0/XFx8IixlOiJcXHwifSx7YjovXEJcPyhcXFxkezEsM318XFx4W0EtRmEtZjAtOV17MSwyfXxcXHVbQS1GYS1mMC05XXs0fXxcXD9cUylcYi99LHtiOi88PCgtPylcdyskLyxlOi9eXHMqXHcrJC99XX0saT17Y046InBhcmFtcyIsYjoiXFwoIixlOiJcXCkiLGVuZHNQYXJlbnQ6ITAsazpyfSxkPVt0LGEse2NOOiJjbGFzcyIsYks6ImNsYXNzIG1vZHVsZSIsZToiJHw7IixpOi89LyxjOltlLmluaGVyaXQoZS5UTSx7YjoiW0EtWmEtel9dXFx3Kig6OlxcdyspKihcXD98XFwhKT8ifSkse2I6IjxcXHMqIixjOlt7YjoiKCIrZS5JUisiOjopPyIrZS5JUn1dfV0uY29uY2F0KHMpfSx7Y046ImZ1bmN0aW9uIixiSzoiZGVmIixlOiIkfDsiLGM6W2UuaW5oZXJpdChlLlRNLHtiOmJ9KSxpXS5jb25jYXQocyl9LHtiOmUuSVIrIjo6In0se2NOOiJzeW1ib2wiLGI6ZS5VSVIrIihcXCF8XFw/KT86IixyOjB9LHtjTjoic3ltYm9sIixiOiI6KD8hXFxzKSIsYzpbdCx7YjpifV0scjowfSx7Y046Im51bWJlciIsYjoiKFxcYjBbMC03X10rKXwoXFxiMHhbMC05YS1mQS1GX10rKXwoXFxiWzEtOV1bMC05X10qKFxcLlswLTlfXSspPyl8WzBfXVxcYiIscjowfSx7YjoiKFxcJFxcVyl8KChcXCR8XFxAXFxAPykoXFx3KykpIn0se2NOOiJwYXJhbXMiLGI6L1x8LyxlOi9cfC8sazpyfSx7YjoiKCIrZS5SU1IrInx1bmxlc3MpXFxzKiIsazoidW5sZXNzIixjOlthLHtjTjoicmVnZXhwIixjOltlLkJFLG5dLGk6L1xuLyx2Olt7YjoiLyIsZToiL1thLXpdKiJ9LHtiOiIlcnsiLGU6In1bYS16XSoifSx7YjoiJXJcXCgiLGU6IlxcKVthLXpdKiJ9LHtiOiIlciEiLGU6IiFbYS16XSoifSx7YjoiJXJcXFsiLGU6IlxcXVthLXpdKiJ9XX1dLmNvbmNhdChzKSxyOjB9XS5jb25jYXQocyk7bi5jPWQsaS5jPWQ7dmFyIGw9Ils+P10+IixvPSJbXFx3I10rXFwoXFx3K1xcKTpcXGQrOlxcZCs+Iix1PSIoXFx3Ky0pP1xcZCtcXC5cXGQrXFwuXFxkKHBcXGQrKT9bXj5dKz4iLHc9W3tiOi9eXHMqPT4vLHN0YXJ0czp7ZToiJCIsYzpkfX0se2NOOiJtZXRhIixiOiJeKCIrbCsifCIrbysifCIrdSsiKSIsc3RhcnRzOntlOiIkIixjOmR9fV07cmV0dXJue2FsaWFzZXM6WyJyYiIsImdlbXNwZWMiLCJwb2RzcGVjIiwidGhvciIsImlyYiJdLGs6cixpOi9cL1wqLyxjOnMuY29uY2F0KHcpLmNvbmNhdChkKX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInlhbWwiLGZ1bmN0aW9uKGUpe3ZhciBiPSJ0cnVlIGZhbHNlIHllcyBubyBudWxsIixhPSJeWyBcXC1dKiIscj0iW2EtekEtWl9dW1xcd1xcLV0qIix0PXtjTjoiYXR0ciIsdjpbe2I6YStyKyI6In0se2I6YSsnIicrcisnIjonfSx7YjphKyInIityKyInOiJ9XX0sYz17Y046InRlbXBsYXRlLXZhcmlhYmxlIix2Olt7Yjoie3siLGU6In19In0se2I6IiV7IixlOiJ9In1dfSxsPXtjTjoic3RyaW5nIixyOjAsdjpbe2I6LycvLGU6LycvfSx7YjovIi8sZTovIi99LHtiOi9cUysvfV0sYzpbZS5CRSxjXX07cmV0dXJue2NJOiEwLGFsaWFzZXM6WyJ5bWwiLCJZQU1MIiwieWFtbCJdLGM6W3Qse2NOOiJtZXRhIixiOiJeLS0tcyokIixyOjEwfSx7Y046InN0cmluZyIsYjoiW1xcfD5dICokIixyRTohMCxjOmwuYyxlOnQudlswXS5ifSx7YjoiPCVbJT0tXT8iLGU6IlslLV0/JT4iLHNMOiJydWJ5IixlQjohMCxlRTohMCxyOjB9LHtjTjoidHlwZSIsYjoiISEiK2UuVUlSfSx7Y046Im1ldGEiLGI6IiYiK2UuVUlSKyIkIn0se2NOOiJtZXRhIixiOiJcXCoiK2UuVUlSKyIkIn0se2NOOiJidWxsZXQiLGI6Il4gKi0iLHI6MH0sZS5IQ00se2JLOmIsazp7bGl0ZXJhbDpifX0sZS5DTk0sbF19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJjc3MiLGZ1bmN0aW9uKGUpe3ZhciBjPSJbYS16QS1aLV1bYS16QS1aMC05Xy1dKiIsdD17YjovW0EtWlxfXC5cLV0rXHMqOi8sckI6ITAsZToiOyIsZVc6ITAsYzpbe2NOOiJhdHRyaWJ1dGUiLGI6L1xTLyxlOiI6IixlRTohMCxzdGFydHM6e2VXOiEwLGVFOiEwLGM6W3tiOi9bXHctXStcKC8sckI6ITAsYzpbe2NOOiJidWlsdF9pbiIsYjovW1x3LV0rL30se2I6L1woLyxlOi9cKS8sYzpbZS5BU00sZS5RU01dfV19LGUuQ1NTTk0sZS5RU00sZS5BU00sZS5DQkNNLHtjTjoibnVtYmVyIixiOiIjWzAtOUEtRmEtZl0rIn0se2NOOiJtZXRhIixiOiIhaW1wb3J0YW50In1dfX1dfTtyZXR1cm57Y0k6ITAsaTovWz1cL3wnXCRdLyxjOltlLkNCQ00se2NOOiJzZWxlY3Rvci1pZCIsYjovI1tBLVphLXowLTlfLV0rL30se2NOOiJzZWxlY3Rvci1jbGFzcyIsYjovXC5bQS1aYS16MC05Xy1dKy99LHtjTjoic2VsZWN0b3ItYXR0ciIsYjovXFsvLGU6L1xdLyxpOiIkIn0se2NOOiJzZWxlY3Rvci1wc2V1ZG8iLGI6LzooOik/W2EtekEtWjAtOVxfXC1cK1woXCkiJy5dKy99LHtiOiJAKGZvbnQtZmFjZXxwYWdlKSIsbDoiW2Etei1dKyIsazoiZm9udC1mYWNlIHBhZ2UifSx7YjoiQCIsZToiW3s7XSIsaTovOi8sYzpbe2NOOiJrZXl3b3JkIixiOi9cdysvfSx7YjovXHMvLGVXOiEwLGVFOiEwLHI6MCxjOltlLkFTTSxlLlFTTSxlLkNTU05NXX1dfSx7Y046InNlbGVjdG9yLXRhZyIsYjpjLHI6MH0se2I6InsiLGU6In0iLGk6L1xTLyxjOltlLkNCQ00sdF19XX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoImZvcnRyYW4iLGZ1bmN0aW9uKGUpe3ZhciB0PXtjTjoicGFyYW1zIixiOiJcXCgiLGU6IlxcKSJ9LG49e2xpdGVyYWw6Ii5GYWxzZS4gLlRydWUuIixrZXl3b3JkOiJraW5kIGRvIHdoaWxlIHByaXZhdGUgY2FsbCBpbnRyaW5zaWMgd2hlcmUgZWxzZXdoZXJlIHR5cGUgZW5kdHlwZSBlbmRtb2R1bGUgZW5kc2VsZWN0IGVuZGludGVyZmFjZSBlbmQgZW5kZG8gZW5kaWYgaWYgZm9yYWxsIGVuZGZvcmFsbCBvbmx5IGNvbnRhaW5zIGRlZmF1bHQgcmV0dXJuIHN0b3AgdGhlbiBwdWJsaWMgc3Vicm91dGluZXwxMCBmdW5jdGlvbiBwcm9ncmFtIC5hbmQuIC5vci4gLm5vdC4gLmxlLiAuZXEuIC5nZS4gLmd0LiAubHQuIGdvdG8gc2F2ZSBlbHNlIHVzZSBtb2R1bGUgc2VsZWN0IGNhc2UgYWNjZXNzIGJsYW5rIGRpcmVjdCBleGlzdCBmaWxlIGZtdCBmb3JtIGZvcm1hdHRlZCBpb3N0YXQgbmFtZSBuYW1lZCBuZXh0cmVjIG51bWJlciBvcGVuZWQgcmVjIHJlY2wgc2VxdWVudGlhbCBzdGF0dXMgdW5mb3JtYXR0ZWQgdW5pdCBjb250aW51ZSBmb3JtYXQgcGF1c2UgY3ljbGUgZXhpdCBjX251bGxfY2hhciBjX2FsZXJ0IGNfYmFja3NwYWNlIGNfZm9ybV9mZWVkIGZsdXNoIHdhaXQgZGVjaW1hbCByb3VuZCBpb21zZyBzeW5jaHJvbm91cyBub3Bhc3Mgbm9uX292ZXJyaWRhYmxlIHBhc3MgcHJvdGVjdGVkIHZvbGF0aWxlIGFic3RyYWN0IGV4dGVuZHMgaW1wb3J0IG5vbl9pbnRyaW5zaWMgdmFsdWUgZGVmZXJyZWQgZ2VuZXJpYyBmaW5hbCBlbnVtZXJhdG9yIGNsYXNzIGFzc29jaWF0ZSBiaW5kIGVudW0gY19pbnQgY19zaG9ydCBjX2xvbmcgY19sb25nX2xvbmcgY19zaWduZWRfY2hhciBjX3NpemVfdCBjX2ludDhfdCBjX2ludDE2X3QgY19pbnQzMl90IGNfaW50NjRfdCBjX2ludF9sZWFzdDhfdCBjX2ludF9sZWFzdDE2X3QgY19pbnRfbGVhc3QzMl90IGNfaW50X2xlYXN0NjRfdCBjX2ludF9mYXN0OF90IGNfaW50X2Zhc3QxNl90IGNfaW50X2Zhc3QzMl90IGNfaW50X2Zhc3Q2NF90IGNfaW50bWF4X3QgQ19pbnRwdHJfdCBjX2Zsb2F0IGNfZG91YmxlIGNfbG9uZ19kb3VibGUgY19mbG9hdF9jb21wbGV4IGNfZG91YmxlX2NvbXBsZXggY19sb25nX2RvdWJsZV9jb21wbGV4IGNfYm9vbCBjX2NoYXIgY19udWxsX3B0ciBjX251bGxfZnVucHRyIGNfbmV3X2xpbmUgY19jYXJyaWFnZV9yZXR1cm4gY19ob3Jpem9udGFsX3RhYiBjX3ZlcnRpY2FsX3RhYiBpc29fY19iaW5kaW5nIGNfbG9jIGNfZnVubG9jIGNfYXNzb2NpYXRlZCAgY19mX3BvaW50ZXIgY19wdHIgY19mdW5wdHIgaXNvX2ZvcnRyYW5fZW52IGNoYXJhY3Rlcl9zdG9yYWdlX3NpemUgZXJyb3JfdW5pdCBmaWxlX3N0b3JhZ2Vfc2l6ZSBpbnB1dF91bml0IGlvc3RhdF9lbmQgaW9zdGF0X2VvciBudW1lcmljX3N0b3JhZ2Vfc2l6ZSBvdXRwdXRfdW5pdCBjX2ZfcHJvY3BvaW50ZXIgaWVlZV9hcml0aG1ldGljIGllZWVfc3VwcG9ydF91bmRlcmZsb3dfY29udHJvbCBpZWVlX2dldF91bmRlcmZsb3dfbW9kZSBpZWVlX3NldF91bmRlcmZsb3dfbW9kZSBuZXd1bml0IGNvbnRpZ3VvdXMgcmVjdXJzaXZlIHBhZCBwb3NpdGlvbiBhY3Rpb24gZGVsaW0gcmVhZHdyaXRlIGVvciBhZHZhbmNlIG5tbCBpbnRlcmZhY2UgcHJvY2VkdXJlIG5hbWVsaXN0IGluY2x1ZGUgc2VxdWVuY2UgZWxlbWVudGFsIHB1cmUgaW50ZWdlciByZWFsIGNoYXJhY3RlciBjb21wbGV4IGxvZ2ljYWwgZGltZW5zaW9uIGFsbG9jYXRhYmxlfDEwIHBhcmFtZXRlciBleHRlcm5hbCBpbXBsaWNpdHwxMCBub25lIGRvdWJsZSBwcmVjaXNpb24gYXNzaWduIGludGVudCBvcHRpb25hbCBwb2ludGVyIHRhcmdldCBpbiBvdXQgY29tbW9uIGVxdWl2YWxlbmNlIGRhdGEiLGJ1aWx0X2luOiJhbG9nIGFsb2cxMCBhbWF4MCBhbWF4MSBhbWluMCBhbWluMSBhbW9kIGNhYnMgY2NvcyBjZXhwIGNsb2cgY3NpbiBjc3FydCBkYWJzIGRhY29zIGRhc2luIGRhdGFuIGRhdGFuMiBkY29zIGRjb3NoIGRkaW0gZGV4cCBkaW50IGRsb2cgZGxvZzEwIGRtYXgxIGRtaW4xIGRtb2QgZG5pbnQgZHNpZ24gZHNpbiBkc2luaCBkc3FydCBkdGFuIGR0YW5oIGZsb2F0IGlhYnMgaWRpbSBpZGludCBpZG5pbnQgaWZpeCBpc2lnbiBtYXgwIG1heDEgbWluMCBtaW4xIHNuZ2wgYWxnYW1hIGNkYWJzIGNkY29zIGNkZXhwIGNkbG9nIGNkc2luIGNkc3FydCBjcWFicyBjcWNvcyBjcWV4cCBjcWxvZyBjcXNpbiBjcXNxcnQgZGNtcGx4IGRjb25qZyBkZXJmIGRlcmZjIGRmbG9hdCBkZ2FtbWEgZGltYWcgZGxnYW1hIGlxaW50IHFhYnMgcWFjb3MgcWFzaW4gcWF0YW4gcWF0YW4yIHFjbXBseCBxY29uamcgcWNvcyBxY29zaCBxZGltIHFlcmYgcWVyZmMgcWV4cCBxZ2FtbWEgcWltYWcgcWxnYW1hIHFsb2cgcWxvZzEwIHFtYXgxIHFtaW4xIHFtb2QgcW5pbnQgcXNpZ24gcXNpbiBxc2luaCBxc3FydCBxdGFuIHF0YW5oIGFicyBhY29zIGFpbWFnIGFpbnQgYW5pbnQgYXNpbiBhdGFuIGF0YW4yIGNoYXIgY21wbHggY29uamcgY29zIGNvc2ggZXhwIGljaGFyIGluZGV4IGludCBsb2cgbG9nMTAgbWF4IG1pbiBuaW50IHNpZ24gc2luIHNpbmggc3FydCB0YW4gdGFuaCBwcmludCB3cml0ZSBkaW0gbGdlIGxndCBsbGUgbGx0IG1vZCBudWxsaWZ5IGFsbG9jYXRlIGRlYWxsb2NhdGUgYWRqdXN0bCBhZGp1c3RyIGFsbCBhbGxvY2F0ZWQgYW55IGFzc29jaWF0ZWQgYml0X3NpemUgYnRlc3QgY2VpbGluZyBjb3VudCBjc2hpZnQgZGF0ZV9hbmRfdGltZSBkaWdpdHMgZG90X3Byb2R1Y3QgZW9zaGlmdCBlcHNpbG9uIGV4cG9uZW50IGZsb29yIGZyYWN0aW9uIGh1Z2UgaWFuZCBpYmNsciBpYml0cyBpYnNldCBpZW9yIGlvciBpc2hmdCBpc2hmdGMgbGJvdW5kIGxlbl90cmltIG1hdG11bCBtYXhleHBvbmVudCBtYXhsb2MgbWF4dmFsIG1lcmdlIG1pbmV4cG9uZW50IG1pbmxvYyBtaW52YWwgbW9kdWxvIG12Yml0cyBuZWFyZXN0IHBhY2sgcHJlc2VudCBwcm9kdWN0IHJhZGl4IHJhbmRvbV9udW1iZXIgcmFuZG9tX3NlZWQgcmFuZ2UgcmVwZWF0IHJlc2hhcGUgcnJzcGFjaW5nIHNjYWxlIHNjYW4gc2VsZWN0ZWRfaW50X2tpbmQgc2VsZWN0ZWRfcmVhbF9raW5kIHNldF9leHBvbmVudCBzaGFwZSBzaXplIHNwYWNpbmcgc3ByZWFkIHN1bSBzeXN0ZW1fY2xvY2sgdGlueSB0cmFuc3Bvc2UgdHJpbSB1Ym91bmQgdW5wYWNrIHZlcmlmeSBhY2hhciBpYWNoYXIgdHJhbnNmZXIgZGJsZSBlbnRyeSBkcHJvZCBjcHVfdGltZSBjb21tYW5kX2FyZ3VtZW50X2NvdW50IGdldF9jb21tYW5kIGdldF9jb21tYW5kX2FyZ3VtZW50IGdldF9lbnZpcm9ubWVudF92YXJpYWJsZSBpc19pb3N0YXRfZW5kIGllZWVfYXJpdGhtZXRpYyBpZWVlX3N1cHBvcnRfdW5kZXJmbG93X2NvbnRyb2wgaWVlZV9nZXRfdW5kZXJmbG93X21vZGUgaWVlZV9zZXRfdW5kZXJmbG93X21vZGUgaXNfaW9zdGF0X2VvciBtb3ZlX2FsbG9jIG5ld19saW5lIHNlbGVjdGVkX2NoYXJfa2luZCBzYW1lX3R5cGVfYXMgZXh0ZW5kc190eXBlX29mYWNvc2ggYXNpbmggYXRhbmggYmVzc2VsX2owIGJlc3NlbF9qMSBiZXNzZWxfam4gYmVzc2VsX3kwIGJlc3NlbF95MSBiZXNzZWxfeW4gZXJmIGVyZmMgZXJmY19zY2FsZWQgZ2FtbWEgbG9nX2dhbW1hIGh5cG90IG5vcm0yIGF0b21pY19kZWZpbmUgYXRvbWljX3JlZiBleGVjdXRlX2NvbW1hbmRfbGluZSBsZWFkeiB0cmFpbHogc3RvcmFnZV9zaXplIG1lcmdlX2JpdHMgYmdlIGJndCBibGUgYmx0IGRzaGlmdGwgZHNoaWZ0ciBmaW5kbG9jIGlhbGwgaWFueSBpcGFyaXR5IGltYWdlX2luZGV4IGxjb2JvdW5kIHVjb2JvdW5kIG1hc2tsIG1hc2tyIG51bV9pbWFnZXMgcGFyaXR5IHBvcGNudCBwb3BwYXIgc2hpZnRhIHNoaWZ0bCBzaGlmdHIgdGhpc19pbWFnZSJ9O3JldHVybntjSTohMCxhbGlhc2VzOlsiZjkwIiwiZjk1Il0sazpuLGk6L1wvXCovLGM6W2UuaW5oZXJpdChlLkFTTSx7Y046InN0cmluZyIscjowfSksZS5pbmhlcml0KGUuUVNNLHtjTjoic3RyaW5nIixyOjB9KSx7Y046ImZ1bmN0aW9uIixiSzoic3Vicm91dGluZSBmdW5jdGlvbiBwcm9ncmFtIixpOiJbJHs9XFxuXSIsYzpbZS5VVE0sdF19LGUuQygiISIsIiQiLHtyOjB9KSx7Y046Im51bWJlciIsYjoiKD89XFxifFxcK3xcXC18XFwuKSg/PVxcLlxcZHxcXGQpKD86XFxkKyk/KD86XFwuP1xcZCopKD86W2RlXVsrLV0/XFxkKyk/XFxiXFwuPyIscjowfV19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJhd2siLGZ1bmN0aW9uKGUpe3ZhciByPXtjTjoidmFyaWFibGUiLHY6W3tiOi9cJFtcd1xkI0BdW1x3XGRfXSovfSx7YjovXCRceyguKj8pfS99XX0sYj0iQkVHSU4gRU5EIGlmIGVsc2Ugd2hpbGUgZG8gZm9yIGluIGJyZWFrIGNvbnRpbnVlIGRlbGV0ZSBuZXh0IG5leHRmaWxlIGZ1bmN0aW9uIGZ1bmMgZXhpdHwxMCIsbj17Y046InN0cmluZyIsYzpbZS5CRV0sdjpbe2I6Lyh1fGIpP3I/JycnLyxlOi8nJycvLHI6MTB9LHtiOi8odXxiKT9yPyIiIi8sZTovIiIiLyxyOjEwfSx7YjovKHV8cnx1ciknLyxlOi8nLyxyOjEwfSx7YjovKHV8cnx1cikiLyxlOi8iLyxyOjEwfSx7YjovKGJ8YnIpJy8sZTovJy99LHtiOi8oYnxicikiLyxlOi8iL30sZS5BU00sZS5RU01dfTtyZXR1cm57azp7a2V5d29yZDpifSxjOltyLG4sZS5STSxlLkhDTSxlLk5NXX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoIm1ha2VmaWxlIixmdW5jdGlvbihlKXt2YXIgaT17Y046InZhcmlhYmxlIix2Olt7YjoiXFwkXFwoIitlLlVJUisiXFwpIixjOltlLkJFXX0se2I6L1wkW0AlPD9cXlwrXCpdL31dfSxyPXtjTjoic3RyaW5nIixiOi8iLyxlOi8iLyxjOltlLkJFLGldfSxhPXtjTjoidmFyaWFibGUiLGI6L1wkXChbXHctXStccy8sZTovXCkvLGs6e2J1aWx0X2luOiJzdWJzdCBwYXRzdWJzdCBzdHJpcCBmaW5kc3RyaW5nIGZpbHRlciBmaWx0ZXItb3V0IHNvcnQgd29yZCB3b3JkbGlzdCBmaXJzdHdvcmQgbGFzdHdvcmQgZGlyIG5vdGRpciBzdWZmaXggYmFzZW5hbWUgYWRkc3VmZml4IGFkZHByZWZpeCBqb2luIHdpbGRjYXJkIHJlYWxwYXRoIGFic3BhdGggZXJyb3Igd2FybmluZyBzaGVsbCBvcmlnaW4gZmxhdm9yIGZvcmVhY2ggaWYgb3IgYW5kIGNhbGwgZXZhbCBmaWxlIHZhbHVlIn0sYzpbaV19LG49e2I6Il4iK2UuVUlSKyJcXHMqWzorP10/PSIsaToiXFxuIixyQjohMCxjOlt7YjoiXiIrZS5VSVIsZToiWzorP10/PSIsZUU6ITB9XX0sdD17Y046Im1ldGEiLGI6L15cLlBIT05ZOi8sZTovJC8sazp7Im1ldGEta2V5d29yZCI6Ii5QSE9OWSJ9LGw6L1tcLlx3XSsvfSxsPXtjTjoic2VjdGlvbiIsYjovXlteXHNdKzovLGU6LyQvLGM6W2ldfTtyZXR1cm57YWxpYXNlczpbIm1rIiwibWFrIl0sazoiZGVmaW5lIGVuZGVmIHVuZGVmaW5lIGlmZGVmIGlmbmRlZiBpZmVxIGlmbmVxIGVsc2UgZW5kaWYgaW5jbHVkZSAtaW5jbHVkZSBzaW5jbHVkZSBvdmVycmlkZSBleHBvcnQgdW5leHBvcnQgcHJpdmF0ZSB2cGF0aCIsbDovW1x3LV0rLyxjOltlLkhDTSxpLHIsYSxuLHQsbF19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJqYXZhIixmdW5jdGlvbihlKXt2YXIgYT0iW8OALcq4YS16QS1aXyRdW8OALcq4YS16QS1aXyQwLTldKiIsdD1hKyIoPCIrYSsiKFxccyosXFxzKiIrYSsiKSo+KT8iLHI9ImZhbHNlIHN5bmNocm9uaXplZCBpbnQgYWJzdHJhY3QgZmxvYXQgcHJpdmF0ZSBjaGFyIGJvb2xlYW4gc3RhdGljIG51bGwgaWYgY29uc3QgZm9yIHRydWUgd2hpbGUgbG9uZyBzdHJpY3RmcCBmaW5hbGx5IHByb3RlY3RlZCBpbXBvcnQgbmF0aXZlIGZpbmFsIHZvaWQgZW51bSBlbHNlIGJyZWFrIHRyYW5zaWVudCBjYXRjaCBpbnN0YW5jZW9mIGJ5dGUgc3VwZXIgdm9sYXRpbGUgY2FzZSBhc3NlcnQgc2hvcnQgcGFja2FnZSBkZWZhdWx0IGRvdWJsZSBwdWJsaWMgdHJ5IHRoaXMgc3dpdGNoIGNvbnRpbnVlIHRocm93cyBwcm90ZWN0ZWQgcHVibGljIHByaXZhdGUgbW9kdWxlIHJlcXVpcmVzIGV4cG9ydHMgZG8iLHM9IlxcYigwW2JCXShbMDFdK1swMV9dK1swMV0rfFswMV0rKXwwW3hYXShbYS1mQS1GMC05XStbYS1mQS1GMC05X10rW2EtZkEtRjAtOV0rfFthLWZBLUYwLTldKyl8KChbXFxkXStbXFxkX10rW1xcZF0rfFtcXGRdKykoXFwuKFtcXGRdK1tcXGRfXStbXFxkXSt8W1xcZF0rKSk/fFxcLihbXFxkXStbXFxkX10rW1xcZF0rfFtcXGRdKykpKFtlRV1bLStdP1xcZCspPylbbExmRl0/IixjPXtjTjoibnVtYmVyIixiOnMscjowfTtyZXR1cm57YWxpYXNlczpbImpzcCJdLGs6cixpOi88XC98Iy8sYzpbZS5DKCIvXFwqXFwqIiwiXFwqLyIse3I6MCxjOlt7YjovXHcrQC8scjowfSx7Y046ImRvY3RhZyIsYjoiQFtBLVphLXpdKyJ9XX0pLGUuQ0xDTSxlLkNCQ00sZS5BU00sZS5RU00se2NOOiJjbGFzcyIsYks6ImNsYXNzIGludGVyZmFjZSIsZTovW3s7PV0vLGVFOiEwLGs6ImNsYXNzIGludGVyZmFjZSIsaTovWzoiXFtcXV0vLGM6W3tiSzoiZXh0ZW5kcyBpbXBsZW1lbnRzIn0sZS5VVE1dfSx7Yks6Im5ldyB0aHJvdyByZXR1cm4gZWxzZSIscjowfSx7Y046ImZ1bmN0aW9uIixiOiIoIit0KyJcXHMrKSsiK2UuVUlSKyJcXHMqXFwoIixyQjohMCxlOi9bezs9XS8sZUU6ITAsazpyLGM6W3tiOmUuVUlSKyJcXHMqXFwoIixyQjohMCxyOjAsYzpbZS5VVE1dfSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxrOnIscjowLGM6W2UuQVNNLGUuUVNNLGUuQ05NLGUuQ0JDTV19LGUuQ0xDTSxlLkNCQ01dfSxjLHtjTjoibWV0YSIsYjoiQFtBLVphLXpdKyJ9XX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInN0YW4iLGZ1bmN0aW9uKGUpe3JldHVybntjOltlLkhDTSxlLkNMQ00sZS5DQkNNLHtiOmUuVUlSLGw6ZS5VSVIsazp7bmFtZToiZm9yIGluIHdoaWxlIHJlcGVhdCB1bnRpbCBpZiB0aGVuIGVsc2UiLHN5bWJvbDoiYmVybm91bGxpIGJlcm5vdWxsaV9sb2dpdCBiaW5vbWlhbCBiaW5vbWlhbF9sb2dpdCBiZXRhX2Jpbm9taWFsIGh5cGVyZ2VvbWV0cmljIGNhdGVnb3JpY2FsIGNhdGVnb3JpY2FsX2xvZ2l0IG9yZGVyZWRfbG9naXN0aWMgbmVnX2Jpbm9taWFsIG5lZ19iaW5vbWlhbF8yIG5lZ19iaW5vbWlhbF8yX2xvZyBwb2lzc29uIHBvaXNzb25fbG9nIG11bHRpbm9taWFsIG5vcm1hbCBleHBfbW9kX25vcm1hbCBza2V3X25vcm1hbCBzdHVkZW50X3QgY2F1Y2h5IGRvdWJsZV9leHBvbmVudGlhbCBsb2dpc3RpYyBndW1iZWwgbG9nbm9ybWFsIGNoaV9zcXVhcmUgaW52X2NoaV9zcXVhcmUgc2NhbGVkX2ludl9jaGlfc3F1YXJlIGV4cG9uZW50aWFsIGludl9nYW1tYSB3ZWlidWxsIGZyZWNoZXQgcmF5bGVpZ2ggd2llbmVyIHBhcmV0byBwYXJldG9fdHlwZV8yIHZvbl9taXNlcyB1bmlmb3JtIG11bHRpX25vcm1hbCBtdWx0aV9ub3JtYWxfcHJlYyBtdWx0aV9ub3JtYWxfY2hvbGVza3kgbXVsdGlfZ3AgbXVsdGlfZ3BfY2hvbGVza3kgbXVsdGlfc3R1ZGVudF90IGdhdXNzaWFuX2RsbV9vYnMgZGlyaWNobGV0IGxral9jb3JyIGxral9jb3JyX2Nob2xlc2t5IHdpc2hhcnQgaW52X3dpc2hhcnQiLCJzZWxlY3Rvci10YWciOiJpbnQgcmVhbCB2ZWN0b3Igc2ltcGxleCB1bml0X3ZlY3RvciBvcmRlcmVkIHBvc2l0aXZlX29yZGVyZWQgcm93X3ZlY3RvciBtYXRyaXggY2hvbGVza3lfZmFjdG9yX2NvcnIgY2hvbGVza3lfZmFjdG9yX2NvdiBjb3JyX21hdHJpeCBjb3ZfbWF0cml4Iix0aXRsZToiZnVuY3Rpb25zIG1vZGVsIGRhdGEgcGFyYW1ldGVycyBxdWFudGl0aWVzIHRyYW5zZm9ybWVkIGdlbmVyYXRlZCIsbGl0ZXJhbDoidHJ1ZSBmYWxzZSJ9LHI6MH0se2NOOiJudW1iZXIiLGI6IjBbeFhdWzAtOWEtZkEtRl0rW0xpXT9cXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IjBbeFhdWzAtOWEtZkEtRl0rW0xpXT9cXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IlxcZCsoPzpbZUVdWytcXC1dP1xcZCopP0xcXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IlxcZCtcXC4oPyFcXGQpKD86aVxcYik/IixyOjB9LHtjTjoibnVtYmVyIixiOiJcXGQrKD86XFwuXFxkKik/KD86W2VFXVsrXFwtXT9cXGQqKT9pP1xcYiIscjowfSx7Y046Im51bWJlciIsYjoiXFwuXFxkKyg/OltlRV1bK1xcLV0/XFxkKik/aT9cXGIiLHI6MH1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiamF2YXNjcmlwdCIsZnVuY3Rpb24oZSl7dmFyIHI9IltBLVphLXokX11bMC05QS1aYS16JF9dKiIsdD17a2V5d29yZDoiaW4gb2YgaWYgZm9yIHdoaWxlIGZpbmFsbHkgdmFyIG5ldyBmdW5jdGlvbiBkbyByZXR1cm4gdm9pZCBlbHNlIGJyZWFrIGNhdGNoIGluc3RhbmNlb2Ygd2l0aCB0aHJvdyBjYXNlIGRlZmF1bHQgdHJ5IHRoaXMgc3dpdGNoIGNvbnRpbnVlIHR5cGVvZiBkZWxldGUgbGV0IHlpZWxkIGNvbnN0IGV4cG9ydCBzdXBlciBkZWJ1Z2dlciBhcyBhc3luYyBhd2FpdCBzdGF0aWMgaW1wb3J0IGZyb20gYXMiLGxpdGVyYWw6InRydWUgZmFsc2UgbnVsbCB1bmRlZmluZWQgTmFOIEluZmluaXR5IixidWlsdF9pbjoiZXZhbCBpc0Zpbml0ZSBpc05hTiBwYXJzZUZsb2F0IHBhcnNlSW50IGRlY29kZVVSSSBkZWNvZGVVUklDb21wb25lbnQgZW5jb2RlVVJJIGVuY29kZVVSSUNvbXBvbmVudCBlc2NhcGUgdW5lc2NhcGUgT2JqZWN0IEZ1bmN0aW9uIEJvb2xlYW4gRXJyb3IgRXZhbEVycm9yIEludGVybmFsRXJyb3IgUmFuZ2VFcnJvciBSZWZlcmVuY2VFcnJvciBTdG9wSXRlcmF0aW9uIFN5bnRheEVycm9yIFR5cGVFcnJvciBVUklFcnJvciBOdW1iZXIgTWF0aCBEYXRlIFN0cmluZyBSZWdFeHAgQXJyYXkgRmxvYXQzMkFycmF5IEZsb2F0NjRBcnJheSBJbnQxNkFycmF5IEludDMyQXJyYXkgSW50OEFycmF5IFVpbnQxNkFycmF5IFVpbnQzMkFycmF5IFVpbnQ4QXJyYXkgVWludDhDbGFtcGVkQXJyYXkgQXJyYXlCdWZmZXIgRGF0YVZpZXcgSlNPTiBJbnRsIGFyZ3VtZW50cyByZXF1aXJlIG1vZHVsZSBjb25zb2xlIHdpbmRvdyBkb2N1bWVudCBTeW1ib2wgU2V0IE1hcCBXZWFrU2V0IFdlYWtNYXAgUHJveHkgUmVmbGVjdCBQcm9taXNlIn0sYT17Y046Im51bWJlciIsdjpbe2I6IlxcYigwW2JCXVswMV0rKSJ9LHtiOiJcXGIoMFtvT11bMC03XSspIn0se2I6ZS5DTlJ9XSxyOjB9LG49e2NOOiJzdWJzdCIsYjoiXFwkXFx7IixlOiJcXH0iLGs6dCxjOltdfSxjPXtjTjoic3RyaW5nIixiOiJgIixlOiJgIixjOltlLkJFLG5dfTtuLmM9W2UuQVNNLGUuUVNNLGMsYSxlLlJNXTt2YXIgcz1uLmMuY29uY2F0KFtlLkNCQ00sZS5DTENNXSk7cmV0dXJue2FsaWFzZXM6WyJqcyIsImpzeCJdLGs6dCxjOlt7Y046Im1ldGEiLHI6MTAsYjovXlxzKlsnIl11c2UgKHN0cmljdHxhc20pWyciXS99LHtjTjoibWV0YSIsYjovXiMhLyxlOi8kL30sZS5BU00sZS5RU00sYyxlLkNMQ00sZS5DQkNNLGEse2I6L1t7LF1ccyovLHI6MCxjOlt7YjpyKyJcXHMqOiIsckI6ITAscjowLGM6W3tjTjoiYXR0ciIsYjpyLHI6MH1dfV19LHtiOiIoIitlLlJTUisifFxcYihjYXNlfHJldHVybnx0aHJvdylcXGIpXFxzKiIsazoicmV0dXJuIHRocm93IGNhc2UiLGM6W2UuQ0xDTSxlLkNCQ00sZS5STSx7Y046ImZ1bmN0aW9uIixiOiIoXFwoLio/XFwpfCIrcisiKVxccyo9PiIsckI6ITAsZToiXFxzKj0+IixjOlt7Y046InBhcmFtcyIsdjpbe2I6cn0se2I6L1woXHMqXCkvfSx7YjovXCgvLGU6L1wpLyxlQjohMCxlRTohMCxrOnQsYzpzfV19XX0se2I6LzwvLGU6LyhcL1x3K3xcdytcLyk+LyxzTDoieG1sIixjOlt7YjovPFx3K1xzKlwvPi8sc2tpcDohMH0se2I6LzxcdysvLGU6LyhcL1x3K3xcdytcLyk+Lyxza2lwOiEwLGM6W3tiOi88XHcrXHMqXC8+Lyxza2lwOiEwfSwic2VsZiJdfV19XSxyOjB9LHtjTjoiZnVuY3Rpb24iLGJLOiJmdW5jdGlvbiIsZTovXHsvLGVFOiEwLGM6W2UuaW5oZXJpdChlLlRNLHtiOnJ9KSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxlQjohMCxlRTohMCxjOnN9XSxpOi9cW3wlL30se2I6L1wkWyguXS99LGUuTUVUSE9EX0dVQVJELHtjTjoiY2xhc3MiLGJLOiJjbGFzcyIsZTovW3s7PV0vLGVFOiEwLGk6L1s6IlxbXF1dLyxjOlt7Yks6ImV4dGVuZHMifSxlLlVUTV19LHtiSzoiY29uc3RydWN0b3IiLGU6L1x7LyxlRTohMH1dLGk6LyMoPyEhKS99fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJ0ZXgiLGZ1bmN0aW9uKGMpe3ZhciBlPXtjTjoidGFnIixiOi9cXC8scjowLGM6W3tjTjoibmFtZSIsdjpbe2I6L1thLXpBLVrQsC3Rj9CQLdGPXStbKl0/L30se2I6L1teYS16QS1a0LAt0Y/QkC3RjzAtOV0vfV0sc3RhcnRzOntlVzohMCxyOjAsYzpbe2NOOiJzdHJpbmciLHY6W3tiOi9cWy8sZTovXF0vfSx7YjovXHsvLGU6L1x9L31dfSx7YjovXHMqPVxzKi8sZVc6ITAscjowLGM6W3tjTjoibnVtYmVyIixiOi8tP1xkKlwuP1xkKyhwdHxwY3xtbXxjbXxpbnxkZHxjY3xleHxlbSk/L31dfV19fV19O3JldHVybntjOltlLHtjTjoiZm9ybXVsYSIsYzpbZV0scjowLHY6W3tiOi9cJFwkLyxlOi9cJFwkL30se2I6L1wkLyxlOi9cJC99XX0sYy5DKCIlIiwiJCIse3I6MH0pXX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInhtbCIsZnVuY3Rpb24ocyl7dmFyIGU9IltBLVphLXowLTlcXC5fOi1dKyIsdD17ZVc6ITAsaTovPC8scjowLGM6W3tjTjoiYXR0ciIsYjplLHI6MH0se2I6Lz1ccyovLHI6MCxjOlt7Y046InN0cmluZyIsZW5kc1BhcmVudDohMCx2Olt7YjovIi8sZTovIi99LHtiOi8nLyxlOi8nL30se2I6L1teXHMiJz08PmBdKy99XX1dfV19O3JldHVybnthbGlhc2VzOlsiaHRtbCIsInhodG1sIiwicnNzIiwiYXRvbSIsInhqYiIsInhzZCIsInhzbCIsInBsaXN0Il0sY0k6ITAsYzpbe2NOOiJtZXRhIixiOiI8IURPQ1RZUEUiLGU6Ij4iLHI6MTAsYzpbe2I6IlxcWyIsZToiXFxdIn1dfSxzLkMoIjwhLS0iLCItLT4iLHtyOjEwfSkse2I6IjxcXCFcXFtDREFUQVxcWyIsZToiXFxdXFxdPiIscjoxMH0se2I6LzxcPyhwaHApPy8sZTovXD8+LyxzTDoicGhwIixjOlt7YjoiL1xcKiIsZToiXFwqLyIsc2tpcDohMH1dfSx7Y046InRhZyIsYjoiPHN0eWxlKD89XFxzfD58JCkiLGU6Ij4iLGs6e25hbWU6InN0eWxlIn0sYzpbdF0sc3RhcnRzOntlOiI8L3N0eWxlPiIsckU6ITAsc0w6WyJjc3MiLCJ4bWwiXX19LHtjTjoidGFnIixiOiI8c2NyaXB0KD89XFxzfD58JCkiLGU6Ij4iLGs6e25hbWU6InNjcmlwdCJ9LGM6W3RdLHN0YXJ0czp7ZToiPC9zY3JpcHQ+IixyRTohMCxzTDpbImFjdGlvbnNjcmlwdCIsImphdmFzY3JpcHQiLCJoYW5kbGViYXJzIiwieG1sIl19fSx7Y046Im1ldGEiLHY6W3tiOi88XD94bWwvLGU6L1w/Pi8scjoxMH0se2I6LzxcP1x3Ky8sZTovXD8+L31dfSx7Y046InRhZyIsYjoiPC8/IixlOiIvPz4iLGM6W3tjTjoibmFtZSIsYjovW15cLz48XHNdKy8scjowfSx0XX1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgibWFya2Rvd24iLGZ1bmN0aW9uKGUpe3JldHVybnthbGlhc2VzOlsibWQiLCJta2Rvd24iLCJta2QiXSxjOlt7Y046InNlY3Rpb24iLHY6W3tiOiJeI3sxLDZ9IixlOiIkIn0se2I6Il4uKz9cXG5bPS1dezIsfSQifV19LHtiOiI8IixlOiI+IixzTDoieG1sIixyOjB9LHtjTjoiYnVsbGV0IixiOiJeKFsqKy1dfChcXGQrXFwuKSlcXHMrIn0se2NOOiJzdHJvbmciLGI6IlsqX117Mn0uKz9bKl9dezJ9In0se2NOOiJlbXBoYXNpcyIsdjpbe2I6IlxcKi4rP1xcKiJ9LHtiOiJfLis/XyIscjowfV19LHtjTjoicXVvdGUiLGI6Il4+XFxzKyIsZToiJCJ9LHtjTjoiY29kZSIsdjpbe2I6Il5gYGB3KnMqJCIsZToiXmBgYHMqJCJ9LHtiOiJgLis/YCJ9LHtiOiJeKCB7NH18CSkiLGU6IiQiLHI6MH1dfSx7YjoiXlstXFwqXXszLH0iLGU6IiQifSx7YjoiXFxbLis/XFxdW1xcKFxcW10uKj9bXFwpXFxdXSIsckI6ITAsYzpbe2NOOiJzdHJpbmciLGI6IlxcWyIsZToiXFxdIixlQjohMCxyRTohMCxyOjB9LHtjTjoibGluayIsYjoiXFxdXFwoIixlOiJcXCkiLGVCOiEwLGVFOiEwfSx7Y046InN5bWJvbCIsYjoiXFxdXFxbIixlOiJcXF0iLGVCOiEwLGVFOiEwfV0scjoxMH0se2I6L15cW1teXG5dK1xdOi8sckI6ITAsYzpbe2NOOiJzeW1ib2wiLGI6L1xbLyxlOi9cXS8sZUI6ITAsZUU6ITB9LHtjTjoibGluayIsYjovOlxzKi8sZTovJC8sZUI6ITB9XX1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgianNvbiIsZnVuY3Rpb24oZSl7dmFyIGk9e2xpdGVyYWw6InRydWUgZmFsc2UgbnVsbCJ9LG49W2UuUVNNLGUuQ05NXSxyPXtlOiIsIixlVzohMCxlRTohMCxjOm4sazppfSx0PXtiOiJ7IixlOiJ9IixjOlt7Y046ImF0dHIiLGI6LyIvLGU6LyIvLGM6W2UuQkVdLGk6IlxcbiJ9LGUuaW5oZXJpdChyLHtiOi86L30pXSxpOiJcXFMifSxjPXtiOiJcXFsiLGU6IlxcXSIsYzpbZS5pbmhlcml0KHIpXSxpOiJcXFMifTtyZXR1cm4gbi5zcGxpY2Uobi5sZW5ndGgsMCx0LGMpLHtjOm4sazppLGk6IlxcUyJ9fSk7"></script> - -<style type="text/css">code{white-space: pre;}</style> -<style type="text/css"> - -</style> -<script type="text/javascript"> -if (window.hljs) { - hljs.configure({languages: []}); - hljs.initHighlightingOnLoad(); - if (document.readyState && document.readyState === "complete") { - window.setTimeout(function() { hljs.initHighlighting(); }, 0); - } -} -</script> - - - -<style type="text/css"> -h1 { - font-size: 34px; -} -h1.title { - font-size: 38px; -} -h2 { - font-size: 30px; -} -h3 { - font-size: 24px; -} -h4 { - font-size: 18px; -} -h5 { - font-size: 16px; -} -h6 { - font-size: 12px; -} -.table th:not([align]) { - text-align: left; -} -</style> - -<style type="text/css">body { -margin: 0px auto; -max-width: 1134px; -font-family: sans-serif; -font-size: 10pt; -} - -div#TOC ul { -padding: 0px 0px 0px 45px; -list-style: none; -background-image: none; -background-repeat: none; -background-position: 0; -font-size: 10pt; -font-family: Helvetica, Arial, sans-serif; -} -div#TOC > ul { -padding: 0px 150px 0px 65px; -font-size: 12pt; -} -div#TOC > ul > li { -padding: 5px 0px 0px 0px; -} -div#TOC ul ul { -font-size: 11pt; -} -div#TOC.tocify ul { -padding: 0px; -font-size: inherit; -font-family: inherit; -} -div#TOC.tocify li { -padding: 5px; -font-size: inherit; -font-family: inherit; -} -p, dl { -padding: 0px 150px 0px 65px; -text-align: justify; -} - -p, img, table { -margin-top: 10px; -margin-bottom: 10px; -} - -ol, ul { -padding: 0px 150px 0px 100px; -list-style: square; -} -li ol, li ul { -padding: 0px 0px 0px 35px; -} -li p { -padding: 0; -} -pre { -margin: 0em 150px 0.5em 0em; -padding: 0px 0px 0px 65px; -border: 0px none; -background-color: #f0f0f0; -white-space: pre; -overflow-x: auto; -font-size: 90%; -} -li pre { -margin: 0em 0px 0.5em -65px; -padding: 0px 0px 0px 65px; -} -pre code { -background-color: inherit; -display: block; -padding: 10px 10px 10px 0px; -overflow-x: inherit; -font-size: 100%; -} - -pre code[class] { -background-color: inherit; -} - -pre[class] code { -background-color: inherit; -} -tt, code, pre { -font-family: 'DejaVu Sans Mono', 'Droid Sans Mono', 'Lucida Console', Consolas, Monaco, monospace; -} -h1, h2, h3, h4, h5, h6 { -font-family: Helvetica, Arial, sans-serif; -margin: 1.2em 150px 0.6em 0em; - -padding-left: 65px; -text-indent: -65px; -} -h1.title { -color: #87b13f; -line-height: 1.1em; -margin-top: 25px; -border-bottom: 0px; -} -h1 { -line-height: 1.4em; -border-bottom: 1px #1a81c2 solid; -} -h1, h2, h3 { -color: #1a81c2; -} -h1 { -font-size: 18.0pt; -} -h2 { -font-size: 14.5pt; -} -h3, h4 { -font-size: 12pt; -} -span.header-section-number { -float: left; -width: 65px; -} - -p.author-name { -font-size: 14.5pt; -font-weight: bold; -font-style: italic; -text-align: left; -} -.date { -text-indent: 0px; -font-weight: bold; -} -.abstract, .package { -font-weight: bold; -} - -code { -background-color: #f0f0f0; -color: #404040; -font-size: 90%; -} - -.figure { -margin: 0em 0px 0.5em; -} -img { -max-width: 100%; -display: block; -padding: 0px 150px 0px 130px; -} -p > img { -padding-left: 65px; -padding-right: 0px; -} -td > img { -padding: 0px; -max-width: 100%; -display: inline; -} -img.smallfigure { -padding-left: 195px; -padding-right: 280px; -} -p > img.smallfigure { -padding-left: 130px; -padding-right: 130px; -} -img.widefigure { -padding-left: 65px; -padding-right: 85px; -margin-right: -65px; -} -p > img.widefigure { -padding-left: 0px; -padding-right: 0px; -margin-right: -65px; -} -p.caption, caption { -color: inherit; -font-size: 8pt; -} -p.caption { -padding-left: 130px; -padding-right: 85px; -margin-bottom: 20px; -} -caption { -padding: 0px; -margin-bottom: 10px; -min-width: 583; -} -span.caption-title { -color: #1a81c2; -font-weight: bold; -} -span.caption-label { -font-weight: bold; -} - -table { -margin-left: 130px; -margin-right: 85px; -} -.table { -max-width: 518px; -} - -dd { -margin-left: 65px; -margin-bottom: 10px; -} - -.code-folding-btn { -position: relative; -margin-top: -26px; -top: 26px; -} -.col-md-12 { -min-height: 0px; -} - -.sidenote { -float: right; -clear: right; -margin-right: -150px; -width: 130px; -margin-top: 0; -margin-bottom: 1rem; -font-size: 8pt; -line-height: 1.3; -vertical-align: baseline; -position: relative; -text-align: left; -} -.sidenote-number, .affil-mark { -position: relative; -vertical-align: super; -font-size: 7.5pt; -font-weight: normal; -font-style: normal; -line-height: normal; -} -input.margin-toggle { display: none; } -label.sidenote-number { display: inline; } -label.margin-toggle:not(.sidenote-number) { display: none; } - -code > span.kw { color: #E07020; } -code > span.dt { color: #404040; } -code > span.dv { color: #D02070; } -code > span.bn { color: #d14; } -code > span.fl { color: #D02070; } -code > span.ch { color: #40A040; } -code > span.st { color: #40A040; } -code > span.co { color: #808080; font-style: italic; } -code > span.ot { color: #2020F0; } -code > span.al { color: #ff0000; font-weight: bold; } -code > span.fu { color: #E07020; } -code > span.er { color: #FF0000; } -code > span.identifier { color: #404040; } -code > span.number { color: #D02070; } -code > span.string { color: #40A040; } -code > span.comment { color: #808080; font-style: italic; } -code > span.keyword { color: #2020F0; } -code > span.literal { color: #2020F0; } -code > span.operator { color: #000000;} -code > span.paren { color: #000000;} - -.js-plotly-plot .plotly { -padding-left: 65px; -} -</style> - - - -<style type="text/css"> -.main-container { - max-width: 828px; - margin-left: auto; - margin-right: auto; -} - -img { - max-width:100%; -} -.tabbed-pane { - padding-top: 12px; -} -.html-widget { - margin-bottom: 20px; -} -button.code-folding-btn:focus { - outline: none; -} -summary { - display: list-item; -} -</style> - - - -<!-- tabsets --> - -<style type="text/css"> -.tabset-dropdown > .nav-tabs { - display: inline-table; - max-height: 500px; - min-height: 44px; - overflow-y: auto; - background: white; - border: 1px solid #ddd; - border-radius: 4px; -} - -.tabset-dropdown > .nav-tabs > li.active:before { - content: ""; - font-family: 'Glyphicons Halflings'; - display: inline-block; - padding: 10px; - border-right: 1px solid #ddd; -} - -.tabset-dropdown > .nav-tabs.nav-tabs-open > li.active:before { - content: ""; - border: none; -} - -.tabset-dropdown > .nav-tabs.nav-tabs-open:before { - content: ""; - font-family: 'Glyphicons Halflings'; - display: inline-block; - padding: 10px; - border-right: 1px solid #ddd; -} - -.tabset-dropdown > .nav-tabs > li.active { - display: block; -} - -.tabset-dropdown > .nav-tabs > li > a, -.tabset-dropdown > .nav-tabs > li > a:focus, -.tabset-dropdown > .nav-tabs > li > a:hover { - border: none; - display: inline-block; - border-radius: 4px; - background-color: transparent; -} - -.tabset-dropdown > .nav-tabs.nav-tabs-open > li { - display: block; - float: none; -} - -.tabset-dropdown > .nav-tabs > li { - display: none; -} -</style> - -<!-- code folding --> - - - - -</head> - -<body> - - -<div class="container-fluid main-container"> - - - - -<div class="fluid-row" id="header"> - - - -<h1 class="title toc-ignore">Using multicrispr for gRNA design</h1> -<p class="author-name">Aditya M Bhagwat</p> -<h4 class="date">2020-04-23</h4> - -</div> - -<h1>Contents</h1> -<div id="TOC"> -<ul> -<li><a href="#background"><span class="toc-section-number">1</span> Background</a><ul> -<li><a href="#crisprcas9-and-prime-editing"><span class="toc-section-number">1.1</span> Crispr/Cas9 and Prime Editing</a></li> -<li><a href="#guide-rna-design"><span class="toc-section-number">1.2</span> Guide RNA design</a></li> -</ul></li> -<li><a href="#multicrispr"><span class="toc-section-number">2</span> Multicrispr</a><ul> -<li><a href="#install"><span class="toc-section-number">2.1</span> Install</a></li> -<li><a href="#define-targets"><span class="toc-section-number">2.2</span> Define targets</a></li> -<li><a href="#transform-targets"><span class="toc-section-number">2.3</span> Transform targets</a></li> -<li><a href="#find-spacers"><span class="toc-section-number">2.4</span> Find spacers</a></li> -<li><a href="#add-offtargets"><span class="toc-section-number">2.5</span> Add offtargets</a></li> -<li><a href="#add-efficiency"><span class="toc-section-number">2.6</span> Add efficiency</a></li> -<li><a href="#return-spacer-granges"><span class="toc-section-number">2.7</span> Return spacer GRanges</a></li> -</ul></li> -<li><a href="#references">References</a></li> -</ul> -</div> - -<!--  --> -<div id="background" class="section level1"> -<h1><span class="header-section-number">1</span> Background</h1> -<div id="crisprcas9-and-prime-editing" class="section level2"> -<h2><span class="header-section-number">1.1</span> Crispr/Cas9 and Prime Editing</h2> -<p><strong>Crispr/Cas9</strong> is a prokaryotic immune system turned into a genome engineering tool, with a Cas9/gRNA complex at the heart of its functioning. The <strong>gRNA</strong> (guide RNA) contains a 20 nucleotide (proto)<strong>spacer</strong> which guides the complex to a genomic locus with identical sequence, but only when followed by an <em>NGG</em> <strong>PAM</strong> (protospacer adjacent motif (see Figure 1A). The <strong>Cas9</strong> enzyme performs some effector action at that locus: <em>wildtype Cas9</em> cuts both strands after spacer nucleotide 17, <em>Cas9Nickase</em> cuts only a single strand (two variants exist, cutting respectively each of the strands), while catalytically dead <em>dCas9</em>, fused to some effector domain (KRAB, VPR, APEX) performs some alternative action (e.g. KRAB represses, VPR activates, APEX biotinylates).</p> -<p><strong>Prime Editing</strong> extends this further, by coupling Cas9 to a Reverse Transcriptase (RT). As shown in Figure 1, the guide RNA is extended with a 3’ extension that contains primer binding site (binding a complementary DNA region that acts as a primer for reverse transcription) and reverse transcription template (the template used for reverse transcription). The spacer still acts as targeting agent, guiding the Cas9/RT complex to targeted genomic locus.</p> -<div class="figure"><span id="fig:unnamed-chunk-2"></span> -<img src="" alt="gRNAs for Crispr/Cas9 (A) and Prime Editing" width="100%" class="smallfigure" /> -<p class="caption"> -Figure 1: <span class="caption-title">gRNAs for Crispr/Cas9 (A) and Prime Editing</span><br> -</p> -</div> -</div> -<div id="guide-rna-design" class="section level2"> -<h2><span class="header-section-number">1.2</span> Guide RNA design</h2> -<p><strong>Guide RNA design</strong> involves finding good guide RNAs to hit the targets of interest. Plasmids with guide RNA scaffolds, ready for cloning desired spacers into, can be readily ordered from AddGene. The actual task, therefore, boils down to finding good spacers for the targets of interest. For prime editing, it additionally involves finding appropriate primer binding site and reverse transcription template to edit the target site of interest.</p> -<p>A <strong>good spacer</strong> needs to fulfill two requirements.</p> -<ol style="list-style-type: decimal"> -<li><p><strong>Minimal off-target</strong> (mis)matches, so that only intended targets are hit.</p> -<ul> -<li>Crispr gRNAs can hit exact (with identical and alternate NGG pam), as well as (up-to 2) mismatch offtargets.</li> -<li>Prime Editing is much more specific, hitting only exact offtargets.</li> -</ul></li> -<li><p><strong>Maximal on-target</strong> efficiency. Over the years, several sequence-to-efficiency prediction models have been developed, of which the Doench 2016 score has currently become the community standard. The score is not perfect, and examples can be found where the prediction and the actual outcome differ. Yet, to-date it is the best heuristic to predict on-target efficiency, worth making use of.</p></li> -</ol> -</div> -</div> -<div id="multicrispr" class="section level1"> -<h1><span class="header-section-number">2</span> Multicrispr</h1> -<p>Multicrispr was developed to make guide RNA design easier. As shown below, it contains functions to <strong>define</strong> and <strong>transform</strong> targets, <strong>find spacers</strong>, compute/add <strong>offtarget counts</strong> and <strong>efficiency scores</strong> (Doench 2016), and finally return all of this as a <strong>GRanges</strong> object.</p> -<p><img src="" width="80%" class="widefigure" /></p> -<div id="install" class="section level2"> -<h2><span class="header-section-number">2.1</span> Install</h2> -<p>Installing <strong>multicrispr</strong> is simple:</p> -<pre class="r"><code>url <- 'https://gitlab.gwdg.de/loosolab/software/multicrispr.git' -remotes::install_git(url, repos = BiocManager::repositories())</code></pre> -<p>Doench et al. (2016) ’s python package <strong>azimuth</strong> for on-target efficiency prediction using their method can be easily installed and activated using reticulate:</p> -<pre class="r"><code># Install - run R(Studio) with admin privileges for this to work! - reticulate::conda_create('azienv', 'python=2.7') - reticulate::conda_install('azienv', 'azimuth', pip = TRUE) - reticulate::conda_install('azienv', 'scikit-learn==0.17.1', pip = TRUE)</code></pre> -<pre class="r"><code># Activate - reticulate::use_condaenv('azienv')</code></pre> -<p>Bowtie-indexed genomes for quick offtarget analysis can be installed using <code>index_genome</code>. For the two genomes used in the examples, mm10 and hg38, the functions downloads pre-build indexes from our data server, allowing a quick exploration (set <code>download=FALSE</code> to build index anew):</p> -<pre class="r"><code>index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) -index_genome(BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 )</code></pre> -<!-- 1. Install conda for python 2.7 --> -<!-- 2. Create a new conda environment: `conda create --name azimuthenv python=2.7` --> -<!-- 3. Activate conda environment: `conda activate azimuthenv` --> -<!-- 4. Install module azimuth: `pip install azimuth` --> -<!-- 5. Install scikit-learn: `pip install scikit-learn==0.17.1` --> -</div> -<div id="define-targets" class="section level2"> -<h2><span class="header-section-number">2.2</span> Define targets</h2> -<p><img src="" width="70%" class="smallfigure" /></p> -<p><code>bed_to_granges</code> converts a (0-based) BED coordinate file into a (1-based) GRanges.<br /> -An example is loading the 1974 binding sites of the transcription factor SRF:</p> -<pre class="r"><code>require(magrittr) -require(multicrispr) -bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -tfbs0 <- bed_to_granges(bedfile, genome = 'mm10') -## Read SRF.bed into GRanges -## 1974 ranges on 21 chromosomes</code></pre> -<p><img src="" width="100%" /></p> -<p><code>genes_to_granges</code> and <code>genefile_to_granges</code> convert entrez/ensembl gene identifiers into GRanges using <code>txdb</code> gene models. -An example that loads of a small subset of the 1974 SRF binding sites:</p> -<pre class="r"><code>require(multicrispr) -entrezfile <- system.file('extdata/SRF.entrez', package = 'multicrispr') -txdb <- TxDb.Mmusculus.UCSC.mm10.knownGene::TxDb.Mmusculus.UCSC.mm10.knownGene -sometfbs0 <- genefile_to_granges(entrezfile, txdb, complement = TRUE) -## Convert 10 genes to 10 GRanges -## 20 ranges after adding inverse strands</code></pre> -<p><img src="" width="100%" /></p> -<p><code>char_to_granges</code> uses a 1-based coordinate vector to specify the GRanges.<br /> -It can be used to define four prime editing sites mentioned by Anzalone et al. (2019):</p> -<pre class="r"><code># char_to_granges: Anzalone et al. (2019) prime editing targets -bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -pe0 <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) -plot_intervals(pe0)</code></pre> -<p><img src="" width="336" /></p> -</div> -<div id="transform-targets" class="section level2"> -<h2><span class="header-section-number">2.3</span> Transform targets</h2> -<p><img src="" width="70%" class="smallfigure" /></p> -<p>As a second step, the original targets may require transformation. The functions <code>extend</code>, <code>up_flank</code> (upstream flanks), <code>down_flank</code> (downstream flanks), and <code>double_flank</code> (double flanks) can be used to update the target ranges as required.</p> -<pre class="r"><code># Extend -targets <- pe0 -invisible(extend(targets, -22, 22, plot = TRUE))</code></pre> -<p><img src="" width="65%" /></p> -<pre class="r"><code># Up flank -invisible(up_flank( targets, -200, -1, plot = TRUE))</code></pre> -<p><img src="" width="65%" /></p> -<pre class="r"><code># Down flank -invisible(down_flank( targets, 1, 200, plot = TRUE))</code></pre> -<p><img src="" width="65%" /></p> -<pre class="r"><code># Double flank -invisible(double_flank(targets, -200, -1, +1, +200, plot = TRUE)) -## 2 flank ranges: 1 up + 1 down</code></pre> -<p><img src="" width="65%" /></p> -</div> -<div id="find-spacers" class="section level2"> -<h2><span class="header-section-number">2.4</span> Find spacers</h2> -<p><img src="" width="70%" class="smallfigure" /></p> -<p>The next step is to find N20 spacers followed by NGG pam sites. -This can be done with <code>find_spacers</code>, after extending target range(s) to prime editing neighbourhood(s):</p> -<pre class="r"><code>bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -neighbourhood <- extend_for_pe(targets, bsgenome) -spacers <- find_spacers(neighbourhood, bsgenome, complement = FALSE)</code></pre> -<p><img src="" width="288" /></p> -<p>For prime editing, however, it is better to use <code>find_pe_spacers</code>, which performs target to neighbourhood extension implicitly, and also adds 3’ extension (Fig 1) to returned spacer GRanges.</p> -<pre class="r"><code>spacers <- find_pe_spacers(targets, bsgenome=bsgenome) </code></pre> -<p><img src="" width="316.8" /></p> -<p>This finds prime editing sites that follow Anzalone et al. (2019)’s recommended default settings: a 13-nucleotide primer and a 16-nucleotide reverse transcription template. These settings can be easily altered (e.g. Anzalone et al. report success with reverse transcription templates of up to 48 nucleotides) by:</p> -<pre class="r"><code>spacers <- find_pe_spacers(targets, bsgenome=bsgenome, nrt = 48) </code></pre> -<p><img src="" width="345.6" /></p> -</div> -<div id="add-offtargets" class="section level2"> -<h2><span class="header-section-number">2.5</span> Add offtargets</h2> -<p><img src="" width="70%" class="smallfigure" /></p> -<pre class="r"><code>if (has_been_indexed(bsgenome)){ - spacers %<>% add_offtargets(bsgenome, mismatch = 0, plot = TRUE) -} -## Add genome counts -## Expand iupac ambiguities in pam -## Write reads to ~/multicrisprout/spacers.fa -## Map reads: ~/multicrisprout/spacers/spacers_to_BSgenome.Hsapiens.UCSC.hg38.txt -## Load results -## Count matches -## Calculate offtargets for 6 spacers</code></pre> -<p><img src="" width="345.6" /></p> -</div> -<div id="add-efficiency" class="section level2"> -<h2><span class="header-section-number">2.6</span> Add efficiency</h2> -<p><img src="" width="70%" class="smallfigure" /></p> -<p>Not all N<sub>20</sub>NGG gRNA sequences target equally well (even when matching sequence perfectly). For each position in the 23-bp gRNA sequence, the nucleotide present in current, previous and next position has an effect on targeting efficiency. The current community standard for on-target efficiency prediction is that of Doench et al. (2016), which can be computed and added with <code>add_efficiency</code>:</p> -<pre class="r"><code>if (reticulate::py_module_available('azimuth')){ - spacers %<>% add_efficiency(bsgenome, 'Doench2016') -} -## Score crispr spacers -## Add (4-23-3) contextseqs -## Score contextseqs with Doench2016 (azimuth) -## Run Doench2016 1 times on 10000-seq chunks to preserve memory -## No model file specified, using V3_model_nopos -## Completed in 1.2 secs</code></pre> -<p><img src="" width="345.6" /></p> -</div> -<div id="return-spacer-granges" class="section level2"> -<h2><span class="header-section-number">2.7</span> Return spacer GRanges</h2> -<pre class="r"><code> spacers -## GRanges object with 6 ranges and 14 metadata columns: -## seqnames ranges strand | crisprcontext -## <Rle> <IRanges> <Rle> | <character> -## HBB_1 chr11 5226958-5226977 + | TCATCCACGTTCACCTTGCCCCACAGGGCA -## HBB_2 chr11 5226959-5226978 + | CATCCACGTTCACCTTGCCCCACAGGGCAG -## HBB_3 chr11 5226968-5226987 + | TCACCTTGCCCCACAGGGCAGTAACGGCAG -## HBB_4 chr11 5227003-5227022 - | ACACCATGGTGCATCTGACTCCTGAGGAGA -## HBB_5 chr11 5226984-5227003 + | GGCAGTAACGGCAGACTTCTCCTCAGGAGT -## HBB_6 chr11 5227021-5227040 - | ACTAGCAACCTCAAACAGACACCATGGTGC -## targetname targetstart targetend crisprname crisprspacer -## <character> <integer> <integer> <character> <character> -## HBB_1 HBB 5227002 5227002 HBB_1 CCACGTTCACCTTGCCCCAC -## HBB_2 HBB 5227002 5227002 HBB_2 CACGTTCACCTTGCCCCACA -## HBB_3 HBB 5227002 5227002 HBB_3 CTTGCCCCACAGGGCAGTAA -## HBB_4 HBB 5227002 5227002 HBB_4 CATGGTGCATCTGACTCCTG -## HBB_5 HBB 5227002 5227002 HBB_5 GTAACGGCAGACTTCTCCTC -## HBB_6 HBB 5227002 5227002 HBB_6 GCAACCTCAAACAGACACCA -## crisprpam primer -## <character> <character> -## HBB_1 AGG GTTCACCTTGCCC -## HBB_2 GGG TTCACCTTGCCCC -## HBB_3 CGG CCCCACAGGGCAG -## HBB_4 AGG GTGCATCTGACTC -## HBB_5 AGG CGGCAGACTTCTC -## HBB_6 TGG CCTCAAACAGACA -## revtranscript -## <character> -## HBB_1 CACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATG -## HBB_2 ACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATGG -## HBB_3 TAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATGGTGTCTGTTT -## HBB_4 CTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGGCAAGGTGAACGTGG -## HBB_5 CTCAGGAGTCAGATGCACCATGGTGTCTGTTTGAGGTTGCTAGTGAAC -## HBB_6 CCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGT -## extension G0 -## <character> <integer> -## HBB_1 CATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGGCAAGGTGAAC 1 -## HBB_2 CCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGGCAAGGTGAA 1 -## HBB_3 AAACAGACACCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGG 1 -## HBB_4 CCACGTTCACCTTGCCCCACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCAC 2 -## HBB_5 GTTCACTAGCAACCTCAAACAGACACCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCG 1 -## HBB_6 ACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATGGTGTCTGTTTGAGG 2 -## off off0 Doench2016 -## <numeric> <numeric> <numeric> -## HBB_1 0 0 0.462600534483403 -## HBB_2 0 0 0.611140169152868 -## HBB_3 0 0 0.485226524206282 -## HBB_4 1 1 0.666241339730174 -## HBB_5 0 0 0.517610901468318 -## HBB_6 1 1 0.68921726226521 -## ------- -## seqinfo: 455 sequences (1 circular) from hg38 genome</code></pre> -</div> -</div> -<div id="references" class="section level1 unnumbered"> -<h1>References</h1> -<p>Anzalone, A.V., Randolph, P.B., Davis, J.R. et al. Search-and-replace genome editing without double-strand breaks or donor DNA. Nature 576, 149–157 (2019). <a href="https://doi.org/10.1038/s41586-019-1711-4" class="uri">https://doi.org/10.1038/s41586-019-1711-4</a></p> -<p>Doench et al. (2016). Optimized sgRNA design to maximize activity and minimize off-target effects of CRISPR-Cas9. Nature Biotechnology, 34(7), <a href="doi:10.1038/nbt.3437" class="uri">doi:10.1038/nbt.3437</a></p> -</div> - - - - -</div> - -<script> - -// add bootstrap table styles to pandoc tables -function bootstrapStylePandocTables() { - $('tr.header').parent('thead').parent('table').addClass('table table-condensed'); -} -$(document).ready(function () { - bootstrapStylePandocTables(); -}); - - -</script> - -<!-- tabsets --> - -<script> -$(document).ready(function () { - window.buildTabsets("TOC"); -}); - -$(document).ready(function () { - $('.tabset-dropdown > .nav-tabs > li').click(function () { - $(this).parent().toggleClass('nav-tabs-open') - }); -}); -</script> - -<!-- code folding --> - - -<script type="text/x-mathjax-config"> - MathJax.Hub.Config({ - "HTML-CSS": { - styles: { - ".MathJax_Display": { - "text-align": "center", - padding: "0px 150px 0px 65px", - margin: "0px 0px 0.5em" - }, - } - } - }); -</script> -<!-- dynamically load mathjax for compatibility with self-contained --> -<script> - (function () { - var script = document.createElement("script"); - script.type = "text/javascript"; - script.src = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML"; - document.getElementsByTagName("head")[0].appendChild(script); - })(); -</script> - -</body> -</html> +<!DOCTYPE html> + +<html> + +<head> + +<meta charset="utf-8" /> +<meta name="generator" content="pandoc" /> +<meta http-equiv="X-UA-Compatible" content="IE=EDGE" /> + + +<meta name="author" content="Aditya M Bhagwat" /> + +<meta name="date" content="2020-04-23" /> + +<title>Using multicrispr for gRNA design</title> + +<script>/*! jQuery v1.11.3 | (c) 2005, 2015 jQuery Foundation, Inc. | jquery.org/license */ +!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k={},l="1.11.3",m=function(a,b){return new m.fn.init(a,b)},n=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,o=/^-ms-/,p=/-([\da-z])/gi,q=function(a,b){return b.toUpperCase()};m.fn=m.prototype={jquery:l,constructor:m,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=m.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return m.each(this,a,b)},map:function(a){return this.pushStack(m.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},m.extend=m.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||m.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(e=arguments[h]))for(d in e)a=g[d],c=e[d],g!==c&&(j&&c&&(m.isPlainObject(c)||(b=m.isArray(c)))?(b?(b=!1,f=a&&m.isArray(a)?a:[]):f=a&&m.isPlainObject(a)?a:{},g[d]=m.extend(j,f,c)):void 0!==c&&(g[d]=c));return g},m.extend({expando:"jQuery"+(l+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===m.type(a)},isArray:Array.isArray||function(a){return"array"===m.type(a)},isWindow:function(a){return null!=a&&a==a.window},isNumeric:function(a){return!m.isArray(a)&&a-parseFloat(a)+1>=0},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},isPlainObject:function(a){var b;if(!a||"object"!==m.type(a)||a.nodeType||m.isWindow(a))return!1;try{if(a.constructor&&!j.call(a,"constructor")&&!j.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}if(k.ownLast)for(b in a)return j.call(a,b);for(b in a);return void 0===b||j.call(a,b)},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(b){b&&m.trim(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(o,"ms-").replace(p,q)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var d,e=0,f=a.length,g=r(a);if(c){if(g){for(;f>e;e++)if(d=b.apply(a[e],c),d===!1)break}else for(e in a)if(d=b.apply(a[e],c),d===!1)break}else if(g){for(;f>e;e++)if(d=b.call(a[e],e,a[e]),d===!1)break}else for(e in a)if(d=b.call(a[e],e,a[e]),d===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(n,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(r(Object(a))?m.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){var d;if(b){if(g)return g.call(b,a,c);for(d=b.length,c=c?0>c?Math.max(0,d+c):c:0;d>c;c++)if(c in b&&b[c]===a)return c}return-1},merge:function(a,b){var c=+b.length,d=0,e=a.length;while(c>d)a[e++]=b[d++];if(c!==c)while(void 0!==b[d])a[e++]=b[d++];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;g>f;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=r(a),i=[];if(h)for(;g>f;f++)d=b(a[f],f,c),null!=d&&i.push(d);else for(f in a)d=b(a[f],f,c),null!=d&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(f=a[b],b=a,a=f),m.isFunction(a)?(c=d.call(arguments,2),e=function(){return a.apply(b||this,c.concat(d.call(arguments)))},e.guid=a.guid=a.guid||m.guid++,e):void 0},now:function(){return+new Date},support:k}),m.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});function r(a){var b="length"in a&&a.length,c=m.type(a);return"function"===c||m.isWindow(a)?!1:1===a.nodeType&&b?!0:"array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a}var s=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ha(),z=ha(),A=ha(),B=function(a,b){return a===b&&(l=!0),0},C=1<<31,D={}.hasOwnProperty,E=[],F=E.pop,G=E.push,H=E.push,I=E.slice,J=function(a,b){for(var c=0,d=a.length;d>c;c++)if(a[c]===b)return c;return-1},K="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",L="[\\x20\\t\\r\\n\\f]",M="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",N=M.replace("w","w#"),O="\\["+L+"*("+M+")(?:"+L+"*([*^$|!~]?=)"+L+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+N+"))|)"+L+"*\\]",P=":("+M+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+O+")*)|.*)\\)|)",Q=new RegExp(L+"+","g"),R=new RegExp("^"+L+"+|((?:^|[^\\\\])(?:\\\\.)*)"+L+"+$","g"),S=new RegExp("^"+L+"*,"+L+"*"),T=new RegExp("^"+L+"*([>+~]|"+L+")"+L+"*"),U=new RegExp("="+L+"*([^\\]'\"]*?)"+L+"*\\]","g"),V=new RegExp(P),W=new RegExp("^"+N+"$"),X={ID:new RegExp("^#("+M+")"),CLASS:new RegExp("^\\.("+M+")"),TAG:new RegExp("^("+M.replace("w","w*")+")"),ATTR:new RegExp("^"+O),PSEUDO:new RegExp("^"+P),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+L+"*(even|odd|(([+-]|)(\\d*)n|)"+L+"*(?:([+-]|)"+L+"*(\\d+)|))"+L+"*\\)|)","i"),bool:new RegExp("^(?:"+K+")$","i"),needsContext:new RegExp("^"+L+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+L+"*((?:-\\d)?\\d*)"+L+"*\\)|)(?=[^-]|$)","i")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\d$/i,$=/^[^{]+\{\s*\[native \w/,_=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,aa=/[+~]/,ba=/'|\\/g,ca=new RegExp("\\\\([\\da-f]{1,6}"+L+"?|("+L+")|.)","ig"),da=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},ea=function(){m()};try{H.apply(E=I.call(v.childNodes),v.childNodes),E[v.childNodes.length].nodeType}catch(fa){H={apply:E.length?function(a,b){G.apply(a,I.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function ga(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],k=b.nodeType,"string"!=typeof a||!a||1!==k&&9!==k&&11!==k)return d;if(!e&&p){if(11!==k&&(f=_.exec(a)))if(j=f[1]){if(9===k){if(h=b.getElementById(j),!h||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return H.apply(d,b.getElementsByTagName(a)),d;if((j=f[3])&&c.getElementsByClassName)return H.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=1!==k&&a,1===k&&"object"!==b.nodeName.toLowerCase()){o=g(a),(r=b.getAttribute("id"))?s=r.replace(ba,"\\$&"):b.setAttribute("id",s),s="[id='"+s+"'] ",l=o.length;while(l--)o[l]=s+ra(o[l]);w=aa.test(a)&&pa(b.parentNode)||b,x=o.join(",")}if(x)try{return H.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute("id")}}}return i(a.replace(R,"$1"),b,d,e)}function ha(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ia(a){return a[u]=!0,a}function ja(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ka(a,b){var c=a.split("|"),e=a.length;while(e--)d.attrHandle[c[e]]=b}function la(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||C)-(~a.sourceIndex||C);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function na(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function oa(a){return ia(function(b){return b=+b,ia(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function pa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=ga.support={},f=ga.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?"HTML"!==b.nodeName:!1},m=ga.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=g.documentElement,e=g.defaultView,e&&e!==e.top&&(e.addEventListener?e.addEventListener("unload",ea,!1):e.attachEvent&&e.attachEvent("onunload",ea)),p=!f(g),c.attributes=ja(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ja(function(a){return a.appendChild(g.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=$.test(g.getElementsByClassName),c.getById=ja(function(a){return o.appendChild(a).id=u,!g.getElementsByName||!g.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(ca,da);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(ca,da);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(g.querySelectorAll))&&(ja(function(a){o.appendChild(a).innerHTML="<a id='"+u+"'></a><select id='"+u+"-\f]' msallowcapture=''><option selected=''></option></select>",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+L+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+L+"*(?:value|"+K+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ja(function(a){var b=g.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+L+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ja(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='']:x"),r.push("!=",P)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===g||a.ownerDocument===v&&t(v,a)?-1:b===g||b.ownerDocument===v&&t(v,b)?1:k?J(k,a)-J(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,h=[a],i=[b];if(!e||!f)return a===g?-1:b===g?1:e?-1:f?1:k?J(k,a)-J(k,b):0;if(e===f)return la(a,b);c=a;while(c=c.parentNode)h.unshift(c);c=b;while(c=c.parentNode)i.unshift(c);while(h[d]===i[d])d++;return d?la(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},g):n},ga.matches=function(a,b){return ga(a,null,null,b)},ga.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,"='$1']"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return ga(b,n,null,[a]).length>0},ga.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},ga.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&D.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},ga.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},ga.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=ga.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=ga.selectors={cacheLength:50,createPseudo:ia,match:X,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(ca,da),a[3]=(a[3]||a[4]||a[5]||"").replace(ca,da),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||ga.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&ga.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&V.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(ca,da).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+L+")"+a+"("+L+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=ga.attr(d,a);return null==e?"!="===b:b?(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(Q," ")+" ").indexOf(c)>-1:"|="===b?e===c||e.slice(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h;if(q){if(f){while(p){l=b;while(l=l[p])if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&j[2],l=n&&q.childNodes[n];while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if(1===l.nodeType&&++m&&l===b){k[a]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)m=j[1];else while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if((h?l.nodeName.toLowerCase()===r:1===l.nodeType)&&++m&&(s&&((l[u]||(l[u]={}))[a]=[w,m]),l===b))break;return m-=e,m===d||m%d===0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||ga.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ia(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=J(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ia(function(a){var b=[],c=[],d=h(a.replace(R,"$1"));return d[u]?ia(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ia(function(a){return function(b){return ga(a,b).length>0}}),contains:ia(function(a){return a=a.replace(ca,da),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ia(function(a){return W.test(a||"")||ga.error("unsupported lang: "+a),a=a.replace(ca,da).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Z.test(a.nodeName)},input:function(a){return Y.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:oa(function(){return[0]}),last:oa(function(a,b){return[b-1]}),eq:oa(function(a,b,c){return[0>c?c+b:c]}),even:oa(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:oa(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:oa(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:oa(function(a,b,c){for(var d=0>c?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=ma(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=na(b);function qa(){}qa.prototype=d.filters=d.pseudos,d.setFilters=new qa,g=ga.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){(!c||(e=S.exec(h)))&&(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=T.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(R," ")}),h=h.slice(c.length));for(g in d.filter)!(e=X[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?ga.error(a):z(a,i).slice(0)};function ra(a){for(var b=0,c=a.length,d="";c>b;b++)d+=a[b].value;return d}function sa(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){while(b=b[d])if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[w,f];if(g){while(b=b[d])if((1===b.nodeType||e)&&a(b,c,g))return!0}else while(b=b[d])if(1===b.nodeType||e){if(i=b[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function ta(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function ua(a,b,c){for(var d=0,e=b.length;e>d;d++)ga(a,b[d],c);return c}function va(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function wa(a,b,c,d,e,f){return d&&!d[u]&&(d=wa(d)),e&&!e[u]&&(e=wa(e,f)),ia(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||ua(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:va(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=va(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?J(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=va(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):H.apply(g,r)})}function xa(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=sa(function(a){return a===b},h,!0),l=sa(function(a){return J(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];f>i;i++)if(c=d.relative[a[i].type])m=[sa(ta(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e;e++)if(d.relative[a[e].type])break;return wa(i>1&&ta(m),i>1&&ra(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(R,"$1"),c,e>i&&xa(a.slice(i,e)),f>e&&xa(a=a.slice(e)),f>e&&ra(a))}m.push(c)}return ta(m)}function ya(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q="0",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG("*",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){m=0;while(o=a[m++])if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){m=0;while(o=b[m++])o(r,s,g,h);if(f){if(p>0)while(q--)r[q]||s[q]||(s[q]=F.call(i));s=va(s)}H.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&ga.uniqueSort(i)}return k&&(w=v,j=t),r};return c?ia(f):f}return h=ga.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=xa(b[c]),f[u]?d.push(f):e.push(f);f=A(a,ya(e,d)),f.selector=a}return f},i=ga.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(b=(d.find.ID(k.matches[0].replace(ca,da),b)||[])[0],!b)return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}i=X.needsContext.test(a)?0:j.length;while(i--){if(k=j[i],d.relative[l=k.type])break;if((m=d.find[l])&&(f=m(k.matches[0].replace(ca,da),aa.test(j[0].type)&&pa(b.parentNode)||b))){if(j.splice(i,1),a=f.length&&ra(j),!a)return H.apply(e,f),e;break}}}return(n||h(a,o))(f,b,!p,e,aa.test(a)&&pa(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ja(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ja(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||ka("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ja(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ka("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ja(function(a){return null==a.getAttribute("disabled")})||ka(K,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),ga}(a);m.find=s,m.expr=s.selectors,m.expr[":"]=m.expr.pseudos,m.unique=s.uniqueSort,m.text=s.getText,m.isXMLDoc=s.isXML,m.contains=s.contains;var t=m.expr.match.needsContext,u=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,v=/^.[^:#\[\.,]*$/;function w(a,b,c){if(m.isFunction(b))return m.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return m.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(v.test(b))return m.filter(b,a,c);b=m.filter(b,a)}return m.grep(a,function(a){return m.inArray(a,b)>=0!==c})}m.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?m.find.matchesSelector(d,a)?[d]:[]:m.find.matches(a,m.grep(b,function(a){return 1===a.nodeType}))},m.fn.extend({find:function(a){var b,c=[],d=this,e=d.length;if("string"!=typeof a)return this.pushStack(m(a).filter(function(){for(b=0;e>b;b++)if(m.contains(d[b],this))return!0}));for(b=0;e>b;b++)m.find(a,d[b],c);return c=this.pushStack(e>1?m.unique(c):c),c.selector=this.selector?this.selector+" "+a:a,c},filter:function(a){return this.pushStack(w(this,a||[],!1))},not:function(a){return this.pushStack(w(this,a||[],!0))},is:function(a){return!!w(this,"string"==typeof a&&t.test(a)?m(a):a||[],!1).length}});var x,y=a.document,z=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,A=m.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(c="<"===a.charAt(0)&&">"===a.charAt(a.length-1)&&a.length>=3?[null,a,null]:z.exec(a),!c||!c[1]&&b)return!b||b.jquery?(b||x).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof m?b[0]:b,m.merge(this,m.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:y,!0)),u.test(c[1])&&m.isPlainObject(b))for(c in b)m.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}if(d=y.getElementById(c[2]),d&&d.parentNode){if(d.id!==c[2])return x.find(a);this.length=1,this[0]=d}return this.context=y,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):m.isFunction(a)?"undefined"!=typeof x.ready?x.ready(a):a(m):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),m.makeArray(a,this))};A.prototype=m.fn,x=m(y);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};m.extend({dir:function(a,b,c){var d=[],e=a[b];while(e&&9!==e.nodeType&&(void 0===c||1!==e.nodeType||!m(e).is(c)))1===e.nodeType&&d.push(e),e=e[b];return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),m.fn.extend({has:function(a){var b,c=m(a,this),d=c.length;return this.filter(function(){for(b=0;d>b;b++)if(m.contains(this,c[b]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=t.test(a)||"string"!=typeof a?m(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&m.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?m.unique(f):f)},index:function(a){return a?"string"==typeof a?m.inArray(this[0],m(a)):m.inArray(a.jquery?a[0]:a,this):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(m.unique(m.merge(this.get(),m(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function D(a,b){do a=a[b];while(a&&1!==a.nodeType);return a}m.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return m.dir(a,"parentNode")},parentsUntil:function(a,b,c){return m.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return m.dir(a,"nextSibling")},prevAll:function(a){return m.dir(a,"previousSibling")},nextUntil:function(a,b,c){return m.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return m.dir(a,"previousSibling",c)},siblings:function(a){return m.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return m.sibling(a.firstChild)},contents:function(a){return m.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:m.merge([],a.childNodes)}},function(a,b){m.fn[a]=function(c,d){var e=m.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=m.filter(d,e)),this.length>1&&(C[a]||(e=m.unique(e)),B.test(a)&&(e=e.reverse())),this.pushStack(e)}});var E=/\S+/g,F={};function G(a){var b=F[a]={};return m.each(a.match(E)||[],function(a,c){b[c]=!0}),b}m.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):m.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(c=a.memory&&l,d=!0,f=g||0,g=0,e=h.length,b=!0;h&&e>f;f++)if(h[f].apply(l[0],l[1])===!1&&a.stopOnFalse){c=!1;break}b=!1,h&&(i?i.length&&j(i.shift()):c?h=[]:k.disable())},k={add:function(){if(h){var d=h.length;!function f(b){m.each(b,function(b,c){var d=m.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&f(c)})}(arguments),b?e=h.length:c&&(g=d,j(c))}return this},remove:function(){return h&&m.each(arguments,function(a,c){var d;while((d=m.inArray(c,h,d))>-1)h.splice(d,1),b&&(e>=d&&e--,f>=d&&f--)}),this},has:function(a){return a?m.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],e=0,this},disable:function(){return h=i=c=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,c||k.disable(),this},locked:function(){return!i},fireWith:function(a,c){return!h||d&&!i||(c=c||[],c=[a,c.slice?c.slice():c],b?i.push(c):j(c)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!d}};return k},m.extend({Deferred:function(a){var b=[["resolve","done",m.Callbacks("once memory"),"resolved"],["reject","fail",m.Callbacks("once memory"),"rejected"],["notify","progress",m.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return m.Deferred(function(c){m.each(b,function(b,f){var g=m.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&m.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?m.extend(a,d):d}},e={};return d.pipe=d.then,m.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&m.isFunction(a.promise)?e:0,g=1===f?a:m.Deferred(),h=function(a,b,c){return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}},i,j,k;if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&m.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;m.fn.ready=function(a){return m.ready.promise().done(a),this},m.extend({isReady:!1,readyWait:1,holdReady:function(a){a?m.readyWait++:m.ready(!0)},ready:function(a){if(a===!0?!--m.readyWait:!m.isReady){if(!y.body)return setTimeout(m.ready);m.isReady=!0,a!==!0&&--m.readyWait>0||(H.resolveWith(y,[m]),m.fn.triggerHandler&&(m(y).triggerHandler("ready"),m(y).off("ready")))}}});function I(){y.addEventListener?(y.removeEventListener("DOMContentLoaded",J,!1),a.removeEventListener("load",J,!1)):(y.detachEvent("onreadystatechange",J),a.detachEvent("onload",J))}function J(){(y.addEventListener||"load"===event.type||"complete"===y.readyState)&&(I(),m.ready())}m.ready.promise=function(b){if(!H)if(H=m.Deferred(),"complete"===y.readyState)setTimeout(m.ready);else if(y.addEventListener)y.addEventListener("DOMContentLoaded",J,!1),a.addEventListener("load",J,!1);else{y.attachEvent("onreadystatechange",J),a.attachEvent("onload",J);var c=!1;try{c=null==a.frameElement&&y.documentElement}catch(d){}c&&c.doScroll&&!function e(){if(!m.isReady){try{c.doScroll("left")}catch(a){return setTimeout(e,50)}I(),m.ready()}}()}return H.promise(b)};var K="undefined",L;for(L in m(k))break;k.ownLast="0"!==L,k.inlineBlockNeedsLayout=!1,m(function(){var a,b,c,d;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1",k.inlineBlockNeedsLayout=a=3===b.offsetWidth,a&&(c.style.zoom=1)),c.removeChild(d))}),function(){var a=y.createElement("div");if(null==k.deleteExpando){k.deleteExpando=!0;try{delete a.test}catch(b){k.deleteExpando=!1}}a=null}(),m.acceptData=function(a){var b=m.noData[(a.nodeName+" ").toLowerCase()],c=+a.nodeType||1;return 1!==c&&9!==c?!1:!b||b!==!0&&a.getAttribute("classid")===b};var M=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,N=/([A-Z])/g;function O(a,b,c){if(void 0===c&&1===a.nodeType){var d="data-"+b.replace(N,"-$1").toLowerCase();if(c=a.getAttribute(d),"string"==typeof c){try{c="true"===c?!0:"false"===c?!1:"null"===c?null:+c+""===c?+c:M.test(c)?m.parseJSON(c):c}catch(e){}m.data(a,b,c)}else c=void 0}return c}function P(a){var b;for(b in a)if(("data"!==b||!m.isEmptyObject(a[b]))&&"toJSON"!==b)return!1; + +return!0}function Q(a,b,d,e){if(m.acceptData(a)){var f,g,h=m.expando,i=a.nodeType,j=i?m.cache:a,k=i?a[h]:a[h]&&h;if(k&&j[k]&&(e||j[k].data)||void 0!==d||"string"!=typeof b)return k||(k=i?a[h]=c.pop()||m.guid++:h),j[k]||(j[k]=i?{}:{toJSON:m.noop}),("object"==typeof b||"function"==typeof b)&&(e?j[k]=m.extend(j[k],b):j[k].data=m.extend(j[k].data,b)),g=j[k],e||(g.data||(g.data={}),g=g.data),void 0!==d&&(g[m.camelCase(b)]=d),"string"==typeof b?(f=g[b],null==f&&(f=g[m.camelCase(b)])):f=g,f}}function R(a,b,c){if(m.acceptData(a)){var d,e,f=a.nodeType,g=f?m.cache:a,h=f?a[m.expando]:m.expando;if(g[h]){if(b&&(d=c?g[h]:g[h].data)){m.isArray(b)?b=b.concat(m.map(b,m.camelCase)):b in d?b=[b]:(b=m.camelCase(b),b=b in d?[b]:b.split(" ")),e=b.length;while(e--)delete d[b[e]];if(c?!P(d):!m.isEmptyObject(d))return}(c||(delete g[h].data,P(g[h])))&&(f?m.cleanData([a],!0):k.deleteExpando||g!=g.window?delete g[h]:g[h]=null)}}}m.extend({cache:{},noData:{"applet ":!0,"embed ":!0,"object ":"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"},hasData:function(a){return a=a.nodeType?m.cache[a[m.expando]]:a[m.expando],!!a&&!P(a)},data:function(a,b,c){return Q(a,b,c)},removeData:function(a,b){return R(a,b)},_data:function(a,b,c){return Q(a,b,c,!0)},_removeData:function(a,b){return R(a,b,!0)}}),m.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=m.data(f),1===f.nodeType&&!m._data(f,"parsedAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=m.camelCase(d.slice(5)),O(f,d,e[d])));m._data(f,"parsedAttrs",!0)}return e}return"object"==typeof a?this.each(function(){m.data(this,a)}):arguments.length>1?this.each(function(){m.data(this,a,b)}):f?O(f,a,m.data(f,a)):void 0},removeData:function(a){return this.each(function(){m.removeData(this,a)})}}),m.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=m._data(a,b),c&&(!d||m.isArray(c)?d=m._data(a,b,m.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=m.queue(a,b),d=c.length,e=c.shift(),f=m._queueHooks(a,b),g=function(){m.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return m._data(a,c)||m._data(a,c,{empty:m.Callbacks("once memory").add(function(){m._removeData(a,b+"queue"),m._removeData(a,c)})})}}),m.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?m.queue(this[0],a):void 0===b?this:this.each(function(){var c=m.queue(this,a,b);m._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&m.dequeue(this,a)})},dequeue:function(a){return this.each(function(){m.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=m.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};"string"!=typeof a&&(b=a,a=void 0),a=a||"fx";while(g--)c=m._data(f[g],a+"queueHooks"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var S=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,T=["Top","Right","Bottom","Left"],U=function(a,b){return a=b||a,"none"===m.css(a,"display")||!m.contains(a.ownerDocument,a)},V=m.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===m.type(c)){e=!0;for(h in c)m.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,m.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(m(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f},W=/^(?:checkbox|radio)$/i;!function(){var a=y.createElement("input"),b=y.createElement("div"),c=y.createDocumentFragment();if(b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",k.leadingWhitespace=3===b.firstChild.nodeType,k.tbody=!b.getElementsByTagName("tbody").length,k.htmlSerialize=!!b.getElementsByTagName("link").length,k.html5Clone="<:nav></:nav>"!==y.createElement("nav").cloneNode(!0).outerHTML,a.type="checkbox",a.checked=!0,c.appendChild(a),k.appendChecked=a.checked,b.innerHTML="<textarea>x</textarea>",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue,c.appendChild(b),b.innerHTML="<input type='radio' checked='checked' name='t'/>",k.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,k.noCloneEvent=!0,b.attachEvent&&(b.attachEvent("onclick",function(){k.noCloneEvent=!1}),b.cloneNode(!0).click()),null==k.deleteExpando){k.deleteExpando=!0;try{delete b.test}catch(d){k.deleteExpando=!1}}}(),function(){var b,c,d=y.createElement("div");for(b in{submit:!0,change:!0,focusin:!0})c="on"+b,(k[b+"Bubbles"]=c in a)||(d.setAttribute(c,"t"),k[b+"Bubbles"]=d.attributes[c].expando===!1);d=null}();var X=/^(?:input|select|textarea)$/i,Y=/^key/,Z=/^(?:mouse|pointer|contextmenu)|click/,$=/^(?:focusinfocus|focusoutblur)$/,_=/^([^.]*)(?:\.(.+)|)$/;function aa(){return!0}function ba(){return!1}function ca(){try{return y.activeElement}catch(a){}}m.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m._data(a);if(r){c.handler&&(i=c,c=i.handler,e=i.selector),c.guid||(c.guid=m.guid++),(g=r.events)||(g=r.events={}),(k=r.handle)||(k=r.handle=function(a){return typeof m===K||a&&m.event.triggered===a.type?void 0:m.event.dispatch.apply(k.elem,arguments)},k.elem=a),b=(b||"").match(E)||[""],h=b.length;while(h--)f=_.exec(b[h])||[],o=q=f[1],p=(f[2]||"").split(".").sort(),o&&(j=m.event.special[o]||{},o=(e?j.delegateType:j.bindType)||o,j=m.event.special[o]||{},l=m.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&m.expr.match.needsContext.test(e),namespace:p.join(".")},i),(n=g[o])||(n=g[o]=[],n.delegateCount=0,j.setup&&j.setup.call(a,d,p,k)!==!1||(a.addEventListener?a.addEventListener(o,k,!1):a.attachEvent&&a.attachEvent("on"+o,k))),j.add&&(j.add.call(a,l),l.handler.guid||(l.handler.guid=c.guid)),e?n.splice(n.delegateCount++,0,l):n.push(l),m.event.global[o]=!0);a=null}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m.hasData(a)&&m._data(a);if(r&&(k=r.events)){b=(b||"").match(E)||[""],j=b.length;while(j--)if(h=_.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){l=m.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,n=k[o]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),i=f=n.length;while(f--)g=n[f],!e&&q!==g.origType||c&&c.guid!==g.guid||h&&!h.test(g.namespace)||d&&d!==g.selector&&("**"!==d||!g.selector)||(n.splice(f,1),g.selector&&n.delegateCount--,l.remove&&l.remove.call(a,g));i&&!n.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||m.removeEvent(a,o,r.handle),delete k[o])}else for(o in k)m.event.remove(a,o+b[j],c,d,!0);m.isEmptyObject(k)&&(delete r.handle,m._removeData(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,l,n,o=[d||y],p=j.call(b,"type")?b.type:b,q=j.call(b,"namespace")?b.namespace.split("."):[];if(h=l=d=d||y,3!==d.nodeType&&8!==d.nodeType&&!$.test(p+m.event.triggered)&&(p.indexOf(".")>=0&&(q=p.split("."),p=q.shift(),q.sort()),g=p.indexOf(":")<0&&"on"+p,b=b[m.expando]?b:new m.Event(p,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=q.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\.)"+q.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:m.makeArray(c,[b]),k=m.event.special[p]||{},e||!k.trigger||k.trigger.apply(d,c)!==!1)){if(!e&&!k.noBubble&&!m.isWindow(d)){for(i=k.delegateType||p,$.test(i+p)||(h=h.parentNode);h;h=h.parentNode)o.push(h),l=h;l===(d.ownerDocument||y)&&o.push(l.defaultView||l.parentWindow||a)}n=0;while((h=o[n++])&&!b.isPropagationStopped())b.type=n>1?i:k.bindType||p,f=(m._data(h,"events")||{})[b.type]&&m._data(h,"handle"),f&&f.apply(h,c),f=g&&h[g],f&&f.apply&&m.acceptData(h)&&(b.result=f.apply(h,c),b.result===!1&&b.preventDefault());if(b.type=p,!e&&!b.isDefaultPrevented()&&(!k._default||k._default.apply(o.pop(),c)===!1)&&m.acceptData(d)&&g&&d[p]&&!m.isWindow(d)){l=d[g],l&&(d[g]=null),m.event.triggered=p;try{d[p]()}catch(r){}m.event.triggered=void 0,l&&(d[g]=l)}return b.result}},dispatch:function(a){a=m.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(m._data(this,"events")||{})[a.type]||[],k=m.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){h=m.event.handlers.call(this,a,j),b=0;while((f=h[b++])&&!a.isPropagationStopped()){a.currentTarget=f.elem,g=0;while((e=f.handlers[g++])&&!a.isImmediatePropagationStopped())(!a.namespace_re||a.namespace_re.test(e.namespace))&&(a.handleObj=e,a.data=e.data,c=((m.event.special[e.origType]||{}).handle||e.handler).apply(f.elem,i),void 0!==c&&(a.result=c)===!1&&(a.preventDefault(),a.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!=this;i=i.parentNode||this)if(1===i.nodeType&&(i.disabled!==!0||"click"!==a.type)){for(e=[],f=0;h>f;f++)d=b[f],c=d.selector+" ",void 0===e[c]&&(e[c]=d.needsContext?m(c,this).index(i)>=0:m.find(c,this,null,[i]).length),e[c]&&e.push(d);e.length&&g.push({elem:i,handlers:e})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},fix:function(a){if(a[m.expando])return a;var b,c,d,e=a.type,f=a,g=this.fixHooks[e];g||(this.fixHooks[e]=g=Z.test(e)?this.mouseHooks:Y.test(e)?this.keyHooks:{}),d=g.props?this.props.concat(g.props):this.props,a=new m.Event(f),b=d.length;while(b--)c=d[b],a[c]=f[c];return a.target||(a.target=f.srcElement||y),3===a.target.nodeType&&(a.target=a.target.parentNode),a.metaKey=!!a.metaKey,g.filter?g.filter(a,f):a},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(a,b){return null==a.which&&(a.which=null!=b.charCode?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,b){var c,d,e,f=b.button,g=b.fromElement;return null==a.pageX&&null!=b.clientX&&(d=a.target.ownerDocument||y,e=d.documentElement,c=d.body,a.pageX=b.clientX+(e&&e.scrollLeft||c&&c.scrollLeft||0)-(e&&e.clientLeft||c&&c.clientLeft||0),a.pageY=b.clientY+(e&&e.scrollTop||c&&c.scrollTop||0)-(e&&e.clientTop||c&&c.clientTop||0)),!a.relatedTarget&&g&&(a.relatedTarget=g===a.target?b.toElement:g),a.which||void 0===f||(a.which=1&f?1:2&f?3:4&f?2:0),a}},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==ca()&&this.focus)try{return this.focus(),!1}catch(a){}},delegateType:"focusin"},blur:{trigger:function(){return this===ca()&&this.blur?(this.blur(),!1):void 0},delegateType:"focusout"},click:{trigger:function(){return m.nodeName(this,"input")&&"checkbox"===this.type&&this.click?(this.click(),!1):void 0},_default:function(a){return m.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}},simulate:function(a,b,c,d){var e=m.extend(new m.Event,c,{type:a,isSimulated:!0,originalEvent:{}});d?m.event.trigger(e,null,b):m.event.dispatch.call(b,e),e.isDefaultPrevented()&&c.preventDefault()}},m.removeEvent=y.removeEventListener?function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)}:function(a,b,c){var d="on"+b;a.detachEvent&&(typeof a[d]===K&&(a[d]=null),a.detachEvent(d,c))},m.Event=function(a,b){return this instanceof m.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?aa:ba):this.type=a,b&&m.extend(this,b),this.timeStamp=a&&a.timeStamp||m.now(),void(this[m.expando]=!0)):new m.Event(a,b)},m.Event.prototype={isDefaultPrevented:ba,isPropagationStopped:ba,isImmediatePropagationStopped:ba,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=aa,a&&(a.preventDefault?a.preventDefault():a.returnValue=!1)},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=aa,a&&(a.stopPropagation&&a.stopPropagation(),a.cancelBubble=!0)},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=aa,a&&a.stopImmediatePropagation&&a.stopImmediatePropagation(),this.stopPropagation()}},m.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){m.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return(!e||e!==d&&!m.contains(d,e))&&(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),k.submitBubbles||(m.event.special.submit={setup:function(){return m.nodeName(this,"form")?!1:void m.event.add(this,"click._submit keypress._submit",function(a){var b=a.target,c=m.nodeName(b,"input")||m.nodeName(b,"button")?b.form:void 0;c&&!m._data(c,"submitBubbles")&&(m.event.add(c,"submit._submit",function(a){a._submit_bubble=!0}),m._data(c,"submitBubbles",!0))})},postDispatch:function(a){a._submit_bubble&&(delete a._submit_bubble,this.parentNode&&!a.isTrigger&&m.event.simulate("submit",this.parentNode,a,!0))},teardown:function(){return m.nodeName(this,"form")?!1:void m.event.remove(this,"._submit")}}),k.changeBubbles||(m.event.special.change={setup:function(){return X.test(this.nodeName)?(("checkbox"===this.type||"radio"===this.type)&&(m.event.add(this,"propertychange._change",function(a){"checked"===a.originalEvent.propertyName&&(this._just_changed=!0)}),m.event.add(this,"click._change",function(a){this._just_changed&&!a.isTrigger&&(this._just_changed=!1),m.event.simulate("change",this,a,!0)})),!1):void m.event.add(this,"beforeactivate._change",function(a){var b=a.target;X.test(b.nodeName)&&!m._data(b,"changeBubbles")&&(m.event.add(b,"change._change",function(a){!this.parentNode||a.isSimulated||a.isTrigger||m.event.simulate("change",this.parentNode,a,!0)}),m._data(b,"changeBubbles",!0))})},handle:function(a){var b=a.target;return this!==b||a.isSimulated||a.isTrigger||"radio"!==b.type&&"checkbox"!==b.type?a.handleObj.handler.apply(this,arguments):void 0},teardown:function(){return m.event.remove(this,"._change"),!X.test(this.nodeName)}}),k.focusinBubbles||m.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){m.event.simulate(b,a.target,m.event.fix(a),!0)};m.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=m._data(d,b);e||d.addEventListener(a,c,!0),m._data(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=m._data(d,b)-1;e?m._data(d,b,e):(d.removeEventListener(a,c,!0),m._removeData(d,b))}}}),m.fn.extend({on:function(a,b,c,d,e){var f,g;if("object"==typeof a){"string"!=typeof b&&(c=c||b,b=void 0);for(f in a)this.on(f,b,c,a[f],e);return this}if(null==c&&null==d?(d=b,c=b=void 0):null==d&&("string"==typeof b?(d=c,c=void 0):(d=c,c=b,b=void 0)),d===!1)d=ba;else if(!d)return this;return 1===e&&(g=d,d=function(a){return m().off(a),g.apply(this,arguments)},d.guid=g.guid||(g.guid=m.guid++)),this.each(function(){m.event.add(this,a,d,c,b)})},one:function(a,b,c,d){return this.on(a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,m(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return(b===!1||"function"==typeof b)&&(c=b,b=void 0),c===!1&&(c=ba),this.each(function(){m.event.remove(this,a,c,b)})},trigger:function(a,b){return this.each(function(){m.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];return c?m.event.trigger(a,b,c,!0):void 0}});function da(a){var b=ea.split("|"),c=a.createDocumentFragment();if(c.createElement)while(b.length)c.createElement(b.pop());return c}var ea="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",fa=/ jQuery\d+="(?:null|\d+)"/g,ga=new RegExp("<(?:"+ea+")[\\s/>]","i"),ha=/^\s+/,ia=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,ja=/<([\w:]+)/,ka=/<tbody/i,la=/<|&#?\w+;/,ma=/<(?:script|style|link)/i,na=/checked\s*(?:[^=]|=\s*.checked.)/i,oa=/^$|\/(?:java|ecma)script/i,pa=/^true\/(.*)/,qa=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,ra={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],area:[1,"<map>","</map>"],param:[1,"<object>","</object>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:k.htmlSerialize?[0,"",""]:[1,"X<div>","</div>"]},sa=da(y),ta=sa.appendChild(y.createElement("div"));ra.optgroup=ra.option,ra.tbody=ra.tfoot=ra.colgroup=ra.caption=ra.thead,ra.th=ra.td;function ua(a,b){var c,d,e=0,f=typeof a.getElementsByTagName!==K?a.getElementsByTagName(b||"*"):typeof a.querySelectorAll!==K?a.querySelectorAll(b||"*"):void 0;if(!f)for(f=[],c=a.childNodes||a;null!=(d=c[e]);e++)!b||m.nodeName(d,b)?f.push(d):m.merge(f,ua(d,b));return void 0===b||b&&m.nodeName(a,b)?m.merge([a],f):f}function va(a){W.test(a.type)&&(a.defaultChecked=a.checked)}function wa(a,b){return m.nodeName(a,"table")&&m.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function xa(a){return a.type=(null!==m.find.attr(a,"type"))+"/"+a.type,a}function ya(a){var b=pa.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function za(a,b){for(var c,d=0;null!=(c=a[d]);d++)m._data(c,"globalEval",!b||m._data(b[d],"globalEval"))}function Aa(a,b){if(1===b.nodeType&&m.hasData(a)){var c,d,e,f=m._data(a),g=m._data(b,f),h=f.events;if(h){delete g.handle,g.events={};for(c in h)for(d=0,e=h[c].length;e>d;d++)m.event.add(b,c,h[c][d])}g.data&&(g.data=m.extend({},g.data))}}function Ba(a,b){var c,d,e;if(1===b.nodeType){if(c=b.nodeName.toLowerCase(),!k.noCloneEvent&&b[m.expando]){e=m._data(b);for(d in e.events)m.removeEvent(b,d,e.handle);b.removeAttribute(m.expando)}"script"===c&&b.text!==a.text?(xa(b).text=a.text,ya(b)):"object"===c?(b.parentNode&&(b.outerHTML=a.outerHTML),k.html5Clone&&a.innerHTML&&!m.trim(b.innerHTML)&&(b.innerHTML=a.innerHTML)):"input"===c&&W.test(a.type)?(b.defaultChecked=b.checked=a.checked,b.value!==a.value&&(b.value=a.value)):"option"===c?b.defaultSelected=b.selected=a.defaultSelected:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}}m.extend({clone:function(a,b,c){var d,e,f,g,h,i=m.contains(a.ownerDocument,a);if(k.html5Clone||m.isXMLDoc(a)||!ga.test("<"+a.nodeName+">")?f=a.cloneNode(!0):(ta.innerHTML=a.outerHTML,ta.removeChild(f=ta.firstChild)),!(k.noCloneEvent&&k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||m.isXMLDoc(a)))for(d=ua(f),h=ua(a),g=0;null!=(e=h[g]);++g)d[g]&&Ba(e,d[g]);if(b)if(c)for(h=h||ua(a),d=d||ua(f),g=0;null!=(e=h[g]);g++)Aa(e,d[g]);else Aa(a,f);return d=ua(f,"script"),d.length>0&&za(d,!i&&ua(a,"script")),d=h=e=null,f},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,l,n=a.length,o=da(b),p=[],q=0;n>q;q++)if(f=a[q],f||0===f)if("object"===m.type(f))m.merge(p,f.nodeType?[f]:f);else if(la.test(f)){h=h||o.appendChild(b.createElement("div")),i=(ja.exec(f)||["",""])[1].toLowerCase(),l=ra[i]||ra._default,h.innerHTML=l[1]+f.replace(ia,"<$1></$2>")+l[2],e=l[0];while(e--)h=h.lastChild;if(!k.leadingWhitespace&&ha.test(f)&&p.push(b.createTextNode(ha.exec(f)[0])),!k.tbody){f="table"!==i||ka.test(f)?"<table>"!==l[1]||ka.test(f)?0:h:h.firstChild,e=f&&f.childNodes.length;while(e--)m.nodeName(j=f.childNodes[e],"tbody")&&!j.childNodes.length&&f.removeChild(j)}m.merge(p,h.childNodes),h.textContent="";while(h.firstChild)h.removeChild(h.firstChild);h=o.lastChild}else p.push(b.createTextNode(f));h&&o.removeChild(h),k.appendChecked||m.grep(ua(p,"input"),va),q=0;while(f=p[q++])if((!d||-1===m.inArray(f,d))&&(g=m.contains(f.ownerDocument,f),h=ua(o.appendChild(f),"script"),g&&za(h),c)){e=0;while(f=h[e++])oa.test(f.type||"")&&c.push(f)}return h=null,o},cleanData:function(a,b){for(var d,e,f,g,h=0,i=m.expando,j=m.cache,l=k.deleteExpando,n=m.event.special;null!=(d=a[h]);h++)if((b||m.acceptData(d))&&(f=d[i],g=f&&j[f])){if(g.events)for(e in g.events)n[e]?m.event.remove(d,e):m.removeEvent(d,e,g.handle);j[f]&&(delete j[f],l?delete d[i]:typeof d.removeAttribute!==K?d.removeAttribute(i):d[i]=null,c.push(f))}}}),m.fn.extend({text:function(a){return V(this,function(a){return void 0===a?m.text(this):this.empty().append((this[0]&&this[0].ownerDocument||y).createTextNode(a))},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wa(this,a);b.appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wa(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?m.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||m.cleanData(ua(c)),c.parentNode&&(b&&m.contains(c.ownerDocument,c)&&za(ua(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++){1===a.nodeType&&m.cleanData(ua(a,!1));while(a.firstChild)a.removeChild(a.firstChild);a.options&&m.nodeName(a,"select")&&(a.options.length=0)}return this},clone:function(a,b){return a=null==a?!1:a,b=null==b?a:b,this.map(function(){return m.clone(this,a,b)})},html:function(a){return V(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a)return 1===b.nodeType?b.innerHTML.replace(fa,""):void 0;if(!("string"!=typeof a||ma.test(a)||!k.htmlSerialize&&ga.test(a)||!k.leadingWhitespace&&ha.test(a)||ra[(ja.exec(a)||["",""])[1].toLowerCase()])){a=a.replace(ia,"<$1></$2>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(m.cleanData(ua(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];return this.domManip(arguments,function(b){a=this.parentNode,m.cleanData(ua(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,l=this.length,n=this,o=l-1,p=a[0],q=m.isFunction(p);if(q||l>1&&"string"==typeof p&&!k.checkClone&&na.test(p))return this.each(function(c){var d=n.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(l&&(i=m.buildFragment(a,this[0].ownerDocument,!1,this),c=i.firstChild,1===i.childNodes.length&&(i=c),c)){for(g=m.map(ua(i,"script"),xa),f=g.length;l>j;j++)d=i,j!==o&&(d=m.clone(d,!0,!0),f&&m.merge(g,ua(d,"script"))),b.call(this[j],d,j);if(f)for(h=g[g.length-1].ownerDocument,m.map(g,ya),j=0;f>j;j++)d=g[j],oa.test(d.type||"")&&!m._data(d,"globalEval")&&m.contains(h,d)&&(d.src?m._evalUrl&&m._evalUrl(d.src):m.globalEval((d.text||d.textContent||d.innerHTML||"").replace(qa,"")));i=c=null}return this}}),m.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){m.fn[a]=function(a){for(var c,d=0,e=[],g=m(a),h=g.length-1;h>=d;d++)c=d===h?this:this.clone(!0),m(g[d])[b](c),f.apply(e,c.get());return this.pushStack(e)}});var Ca,Da={};function Ea(b,c){var d,e=m(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:m.css(e[0],"display");return e.detach(),f}function Fa(a){var b=y,c=Da[a];return c||(c=Ea(a,b),"none"!==c&&c||(Ca=(Ca||m("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement),b=(Ca[0].contentWindow||Ca[0].contentDocument).document,b.write(),b.close(),c=Ea(a,b),Ca.detach()),Da[a]=c),c}!function(){var a;k.shrinkWrapBlocks=function(){if(null!=a)return a;a=!1;var b,c,d;return c=y.getElementsByTagName("body")[0],c&&c.style?(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:1px;width:1px;zoom:1",b.appendChild(y.createElement("div")).style.width="5px",a=3!==b.offsetWidth),c.removeChild(d),a):void 0}}();var Ga=/^margin/,Ha=new RegExp("^("+S+")(?!px)[a-z%]+$","i"),Ia,Ja,Ka=/^(top|right|bottom|left)$/;a.getComputedStyle?(Ia=function(b){return b.ownerDocument.defaultView.opener?b.ownerDocument.defaultView.getComputedStyle(b,null):a.getComputedStyle(b,null)},Ja=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ia(a),g=c?c.getPropertyValue(b)||c[b]:void 0,c&&(""!==g||m.contains(a.ownerDocument,a)||(g=m.style(a,b)),Ha.test(g)&&Ga.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0===g?g:g+""}):y.documentElement.currentStyle&&(Ia=function(a){return a.currentStyle},Ja=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ia(a),g=c?c[b]:void 0,null==g&&h&&h[b]&&(g=h[b]),Ha.test(g)&&!Ka.test(b)&&(d=h.left,e=a.runtimeStyle,f=e&&e.left,f&&(e.left=a.currentStyle.left),h.left="fontSize"===b?"1em":g,g=h.pixelLeft+"px",h.left=d,f&&(e.left=f)),void 0===g?g:g+""||"auto"});function La(a,b){return{get:function(){var c=a();if(null!=c)return c?void delete this.get:(this.get=b).apply(this,arguments)}}}!function(){var b,c,d,e,f,g,h;if(b=y.createElement("div"),b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",d=b.getElementsByTagName("a")[0],c=d&&d.style){c.cssText="float:left;opacity:.5",k.opacity="0.5"===c.opacity,k.cssFloat=!!c.cssFloat,b.style.backgroundClip="content-box",b.cloneNode(!0).style.backgroundClip="",k.clearCloneStyle="content-box"===b.style.backgroundClip,k.boxSizing=""===c.boxSizing||""===c.MozBoxSizing||""===c.WebkitBoxSizing,m.extend(k,{reliableHiddenOffsets:function(){return null==g&&i(),g},boxSizingReliable:function(){return null==f&&i(),f},pixelPosition:function(){return null==e&&i(),e},reliableMarginRight:function(){return null==h&&i(),h}});function i(){var b,c,d,i;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),b.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:block;margin-top:1%;top:1%;border:1px;padding:1px;width:4px;position:absolute",e=f=!1,h=!0,a.getComputedStyle&&(e="1%"!==(a.getComputedStyle(b,null)||{}).top,f="4px"===(a.getComputedStyle(b,null)||{width:"4px"}).width,i=b.appendChild(y.createElement("div")),i.style.cssText=b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",i.style.marginRight=i.style.width="0",b.style.width="1px",h=!parseFloat((a.getComputedStyle(i,null)||{}).marginRight),b.removeChild(i)),b.innerHTML="<table><tr><td></td><td>t</td></tr></table>",i=b.getElementsByTagName("td"),i[0].style.cssText="margin:0;border:0;padding:0;display:none",g=0===i[0].offsetHeight,g&&(i[0].style.display="",i[1].style.display="none",g=0===i[0].offsetHeight),c.removeChild(d))}}}(),m.swap=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};var Ma=/alpha\([^)]*\)/i,Na=/opacity\s*=\s*([^)]*)/,Oa=/^(none|table(?!-c[ea]).+)/,Pa=new RegExp("^("+S+")(.*)$","i"),Qa=new RegExp("^([+-])=("+S+")","i"),Ra={position:"absolute",visibility:"hidden",display:"block"},Sa={letterSpacing:"0",fontWeight:"400"},Ta=["Webkit","O","Moz","ms"];function Ua(a,b){if(b in a)return b;var c=b.charAt(0).toUpperCase()+b.slice(1),d=b,e=Ta.length;while(e--)if(b=Ta[e]+c,b in a)return b;return d}function Va(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=m._data(d,"olddisplay"),c=d.style.display,b?(f[g]||"none"!==c||(d.style.display=""),""===d.style.display&&U(d)&&(f[g]=m._data(d,"olddisplay",Fa(d.nodeName)))):(e=U(d),(c&&"none"!==c||!e)&&m._data(d,"olddisplay",e?c:m.css(d,"display"))));for(g=0;h>g;g++)d=a[g],d.style&&(b&&"none"!==d.style.display&&""!==d.style.display||(d.style.display=b?f[g]||"":"none"));return a}function Wa(a,b,c){var d=Pa.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||"px"):b}function Xa(a,b,c,d,e){for(var f=c===(d?"border":"content")?4:"width"===b?1:0,g=0;4>f;f+=2)"margin"===c&&(g+=m.css(a,c+T[f],!0,e)),d?("content"===c&&(g-=m.css(a,"padding"+T[f],!0,e)),"margin"!==c&&(g-=m.css(a,"border"+T[f]+"Width",!0,e))):(g+=m.css(a,"padding"+T[f],!0,e),"padding"!==c&&(g+=m.css(a,"border"+T[f]+"Width",!0,e)));return g}function Ya(a,b,c){var d=!0,e="width"===b?a.offsetWidth:a.offsetHeight,f=Ia(a),g=k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,f);if(0>=e||null==e){if(e=Ja(a,b,f),(0>e||null==e)&&(e=a.style[b]),Ha.test(e))return e;d=g&&(k.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Xa(a,b,c||(g?"border":"content"),d,f)+"px"}m.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=Ja(a,"opacity");return""===c?"1":c}}}},cssNumber:{columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":k.cssFloat?"cssFloat":"styleFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=m.camelCase(b),i=a.style;if(b=m.cssProps[h]||(m.cssProps[h]=Ua(i,h)),g=m.cssHooks[b]||m.cssHooks[h],void 0===c)return g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b];if(f=typeof c,"string"===f&&(e=Qa.exec(c))&&(c=(e[1]+1)*e[2]+parseFloat(m.css(a,b)),f="number"),null!=c&&c===c&&("number"!==f||m.cssNumber[h]||(c+="px"),k.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),!(g&&"set"in g&&void 0===(c=g.set(a,c,d)))))try{i[b]=c}catch(j){}}},css:function(a,b,c,d){var e,f,g,h=m.camelCase(b);return b=m.cssProps[h]||(m.cssProps[h]=Ua(a.style,h)),g=m.cssHooks[b]||m.cssHooks[h],g&&"get"in g&&(f=g.get(a,!0,c)),void 0===f&&(f=Ja(a,b,d)),"normal"===f&&b in Sa&&(f=Sa[b]),""===c||c?(e=parseFloat(f),c===!0||m.isNumeric(e)?e||0:f):f}}),m.each(["height","width"],function(a,b){m.cssHooks[b]={get:function(a,c,d){return c?Oa.test(m.css(a,"display"))&&0===a.offsetWidth?m.swap(a,Ra,function(){return Ya(a,b,d)}):Ya(a,b,d):void 0},set:function(a,c,d){var e=d&&Ia(a);return Wa(a,c,d?Xa(a,b,d,k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,e),e):0)}}}),k.opacity||(m.cssHooks.opacity={get:function(a,b){return Na.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=m.isNumeric(b)?"alpha(opacity="+100*b+")":"",f=d&&d.filter||c.filter||"";c.zoom=1,(b>=1||""===b)&&""===m.trim(f.replace(Ma,""))&&c.removeAttribute&&(c.removeAttribute("filter"),""===b||d&&!d.filter)||(c.filter=Ma.test(f)?f.replace(Ma,e):f+" "+e)}}),m.cssHooks.marginRight=La(k.reliableMarginRight,function(a,b){return b?m.swap(a,{display:"inline-block"},Ja,[a,"marginRight"]):void 0}),m.each({margin:"",padding:"",border:"Width"},function(a,b){m.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];4>d;d++)e[a+T[d]+b]=f[d]||f[d-2]||f[0];return e}},Ga.test(a)||(m.cssHooks[a+b].set=Wa)}),m.fn.extend({css:function(a,b){return V(this,function(a,b,c){var d,e,f={},g=0;if(m.isArray(b)){for(d=Ia(a),e=b.length;e>g;g++)f[b[g]]=m.css(a,b[g],!1,d);return f}return void 0!==c?m.style(a,b,c):m.css(a,b)},a,b,arguments.length>1)},show:function(){return Va(this,!0)},hide:function(){return Va(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){U(this)?m(this).show():m(this).hide()})}});function Za(a,b,c,d,e){ +return new Za.prototype.init(a,b,c,d,e)}m.Tween=Za,Za.prototype={constructor:Za,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||"swing",this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(m.cssNumber[c]?"":"px")},cur:function(){var a=Za.propHooks[this.prop];return a&&a.get?a.get(this):Za.propHooks._default.get(this)},run:function(a){var b,c=Za.propHooks[this.prop];return this.options.duration?this.pos=b=m.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):this.pos=b=a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Za.propHooks._default.set(this),this}},Za.prototype.init.prototype=Za.prototype,Za.propHooks={_default:{get:function(a){var b;return null==a.elem[a.prop]||a.elem.style&&null!=a.elem.style[a.prop]?(b=m.css(a.elem,a.prop,""),b&&"auto"!==b?b:0):a.elem[a.prop]},set:function(a){m.fx.step[a.prop]?m.fx.step[a.prop](a):a.elem.style&&(null!=a.elem.style[m.cssProps[a.prop]]||m.cssHooks[a.prop])?m.style(a.elem,a.prop,a.now+a.unit):a.elem[a.prop]=a.now}}},Za.propHooks.scrollTop=Za.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},m.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2}},m.fx=Za.prototype.init,m.fx.step={};var $a,_a,ab=/^(?:toggle|show|hide)$/,bb=new RegExp("^(?:([+-])=|)("+S+")([a-z%]*)$","i"),cb=/queueHooks$/,db=[ib],eb={"*":[function(a,b){var c=this.createTween(a,b),d=c.cur(),e=bb.exec(b),f=e&&e[3]||(m.cssNumber[a]?"":"px"),g=(m.cssNumber[a]||"px"!==f&&+d)&&bb.exec(m.css(c.elem,a)),h=1,i=20;if(g&&g[3]!==f){f=f||g[3],e=e||[],g=+d||1;do h=h||".5",g/=h,m.style(c.elem,a,g+f);while(h!==(h=c.cur()/d)&&1!==h&&--i)}return e&&(g=c.start=+g||+d||0,c.unit=f,c.end=e[1]?g+(e[1]+1)*e[2]:+e[2]),c}]};function fb(){return setTimeout(function(){$a=void 0}),$a=m.now()}function gb(a,b){var c,d={height:a},e=0;for(b=b?1:0;4>e;e+=2-b)c=T[e],d["margin"+c]=d["padding"+c]=a;return b&&(d.opacity=d.width=a),d}function hb(a,b,c){for(var d,e=(eb[b]||[]).concat(eb["*"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function ib(a,b,c){var d,e,f,g,h,i,j,l,n=this,o={},p=a.style,q=a.nodeType&&U(a),r=m._data(a,"fxshow");c.queue||(h=m._queueHooks(a,"fx"),null==h.unqueued&&(h.unqueued=0,i=h.empty.fire,h.empty.fire=function(){h.unqueued||i()}),h.unqueued++,n.always(function(){n.always(function(){h.unqueued--,m.queue(a,"fx").length||h.empty.fire()})})),1===a.nodeType&&("height"in b||"width"in b)&&(c.overflow=[p.overflow,p.overflowX,p.overflowY],j=m.css(a,"display"),l="none"===j?m._data(a,"olddisplay")||Fa(a.nodeName):j,"inline"===l&&"none"===m.css(a,"float")&&(k.inlineBlockNeedsLayout&&"inline"!==Fa(a.nodeName)?p.zoom=1:p.display="inline-block")),c.overflow&&(p.overflow="hidden",k.shrinkWrapBlocks()||n.always(function(){p.overflow=c.overflow[0],p.overflowX=c.overflow[1],p.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],ab.exec(e)){if(delete b[d],f=f||"toggle"===e,e===(q?"hide":"show")){if("show"!==e||!r||void 0===r[d])continue;q=!0}o[d]=r&&r[d]||m.style(a,d)}else j=void 0;if(m.isEmptyObject(o))"inline"===("none"===j?Fa(a.nodeName):j)&&(p.display=j);else{r?"hidden"in r&&(q=r.hidden):r=m._data(a,"fxshow",{}),f&&(r.hidden=!q),q?m(a).show():n.done(function(){m(a).hide()}),n.done(function(){var b;m._removeData(a,"fxshow");for(b in o)m.style(a,b,o[b])});for(d in o)g=hb(q?r[d]:0,d,n),d in r||(r[d]=g.start,q&&(g.end=g.start,g.start="width"===d||"height"===d?1:0))}}function jb(a,b){var c,d,e,f,g;for(c in a)if(d=m.camelCase(c),e=b[d],f=a[c],m.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=m.cssHooks[d],g&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function kb(a,b,c){var d,e,f=0,g=db.length,h=m.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=$a||fb(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;i>g;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),1>f&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:m.extend({},b),opts:m.extend(!0,{specialEasing:{}},c),originalProperties:b,originalOptions:c,startTime:$a||fb(),duration:c.duration,tweens:[],createTween:function(b,c){var d=m.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;d>c;c++)j.tweens[c].run(1);return b?h.resolveWith(a,[j,b]):h.rejectWith(a,[j,b]),this}}),k=j.props;for(jb(k,j.opts.specialEasing);g>f;f++)if(d=db[f].call(j,a,k,j.opts))return d;return m.map(k,hb,j),m.isFunction(j.opts.start)&&j.opts.start.call(a,j),m.fx.timer(m.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}m.Animation=m.extend(kb,{tweener:function(a,b){m.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");for(var c,d=0,e=a.length;e>d;d++)c=a[d],eb[c]=eb[c]||[],eb[c].unshift(b)},prefilter:function(a,b){b?db.unshift(a):db.push(a)}}),m.speed=function(a,b,c){var d=a&&"object"==typeof a?m.extend({},a):{complete:c||!c&&b||m.isFunction(a)&&a,duration:a,easing:c&&b||b&&!m.isFunction(b)&&b};return d.duration=m.fx.off?0:"number"==typeof d.duration?d.duration:d.duration in m.fx.speeds?m.fx.speeds[d.duration]:m.fx.speeds._default,(null==d.queue||d.queue===!0)&&(d.queue="fx"),d.old=d.complete,d.complete=function(){m.isFunction(d.old)&&d.old.call(this),d.queue&&m.dequeue(this,d.queue)},d},m.fn.extend({fadeTo:function(a,b,c,d){return this.filter(U).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=m.isEmptyObject(a),f=m.speed(b,c,d),g=function(){var b=kb(this,m.extend({},a),f);(e||m._data(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=m.timers,g=m._data(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&cb.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));(b||!c)&&m.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=m._data(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=m.timers,g=d?d.length:0;for(c.finish=!0,m.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;g>b;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}),m.each(["toggle","show","hide"],function(a,b){var c=m.fn[b];m.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(gb(b,!0),a,d,e)}}),m.each({slideDown:gb("show"),slideUp:gb("hide"),slideToggle:gb("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){m.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),m.timers=[],m.fx.tick=function(){var a,b=m.timers,c=0;for($a=m.now();c<b.length;c++)a=b[c],a()||b[c]!==a||b.splice(c--,1);b.length||m.fx.stop(),$a=void 0},m.fx.timer=function(a){m.timers.push(a),a()?m.fx.start():m.timers.pop()},m.fx.interval=13,m.fx.start=function(){_a||(_a=setInterval(m.fx.tick,m.fx.interval))},m.fx.stop=function(){clearInterval(_a),_a=null},m.fx.speeds={slow:600,fast:200,_default:400},m.fn.delay=function(a,b){return a=m.fx?m.fx.speeds[a]||a:a,b=b||"fx",this.queue(b,function(b,c){var d=setTimeout(b,a);c.stop=function(){clearTimeout(d)}})},function(){var a,b,c,d,e;b=y.createElement("div"),b.setAttribute("className","t"),b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",d=b.getElementsByTagName("a")[0],c=y.createElement("select"),e=c.appendChild(y.createElement("option")),a=b.getElementsByTagName("input")[0],d.style.cssText="top:1px",k.getSetAttribute="t"!==b.className,k.style=/top/.test(d.getAttribute("style")),k.hrefNormalized="/a"===d.getAttribute("href"),k.checkOn=!!a.value,k.optSelected=e.selected,k.enctype=!!y.createElement("form").enctype,c.disabled=!0,k.optDisabled=!e.disabled,a=y.createElement("input"),a.setAttribute("value",""),k.input=""===a.getAttribute("value"),a.value="t",a.setAttribute("type","radio"),k.radioValue="t"===a.value}();var lb=/\r/g;m.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=m.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,m(this).val()):a,null==e?e="":"number"==typeof e?e+="":m.isArray(e)&&(e=m.map(e,function(a){return null==a?"":a+""})),b=m.valHooks[this.type]||m.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=m.valHooks[e.type]||m.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(lb,""):null==c?"":c)}}}),m.extend({valHooks:{option:{get:function(a){var b=m.find.attr(a,"value");return null!=b?b:m.trim(m.text(a))}},select:{get:function(a){for(var b,c,d=a.options,e=a.selectedIndex,f="select-one"===a.type||0>e,g=f?null:[],h=f?e+1:d.length,i=0>e?h:f?e:0;h>i;i++)if(c=d[i],!(!c.selected&&i!==e||(k.optDisabled?c.disabled:null!==c.getAttribute("disabled"))||c.parentNode.disabled&&m.nodeName(c.parentNode,"optgroup"))){if(b=m(c).val(),f)return b;g.push(b)}return g},set:function(a,b){var c,d,e=a.options,f=m.makeArray(b),g=e.length;while(g--)if(d=e[g],m.inArray(m.valHooks.option.get(d),f)>=0)try{d.selected=c=!0}catch(h){d.scrollHeight}else d.selected=!1;return c||(a.selectedIndex=-1),e}}}}),m.each(["radio","checkbox"],function(){m.valHooks[this]={set:function(a,b){return m.isArray(b)?a.checked=m.inArray(m(a).val(),b)>=0:void 0}},k.checkOn||(m.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var mb,nb,ob=m.expr.attrHandle,pb=/^(?:checked|selected)$/i,qb=k.getSetAttribute,rb=k.input;m.fn.extend({attr:function(a,b){return V(this,m.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){m.removeAttr(this,a)})}}),m.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(a&&3!==f&&8!==f&&2!==f)return typeof a.getAttribute===K?m.prop(a,b,c):(1===f&&m.isXMLDoc(a)||(b=b.toLowerCase(),d=m.attrHooks[b]||(m.expr.match.bool.test(b)?nb:mb)),void 0===c?d&&"get"in d&&null!==(e=d.get(a,b))?e:(e=m.find.attr(a,b),null==e?void 0:e):null!==c?d&&"set"in d&&void 0!==(e=d.set(a,c,b))?e:(a.setAttribute(b,c+""),c):void m.removeAttr(a,b))},removeAttr:function(a,b){var c,d,e=0,f=b&&b.match(E);if(f&&1===a.nodeType)while(c=f[e++])d=m.propFix[c]||c,m.expr.match.bool.test(c)?rb&&qb||!pb.test(c)?a[d]=!1:a[m.camelCase("default-"+c)]=a[d]=!1:m.attr(a,c,""),a.removeAttribute(qb?c:d)},attrHooks:{type:{set:function(a,b){if(!k.radioValue&&"radio"===b&&m.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}}}),nb={set:function(a,b,c){return b===!1?m.removeAttr(a,c):rb&&qb||!pb.test(c)?a.setAttribute(!qb&&m.propFix[c]||c,c):a[m.camelCase("default-"+c)]=a[c]=!0,c}},m.each(m.expr.match.bool.source.match(/\w+/g),function(a,b){var c=ob[b]||m.find.attr;ob[b]=rb&&qb||!pb.test(b)?function(a,b,d){var e,f;return d||(f=ob[b],ob[b]=e,e=null!=c(a,b,d)?b.toLowerCase():null,ob[b]=f),e}:function(a,b,c){return c?void 0:a[m.camelCase("default-"+b)]?b.toLowerCase():null}}),rb&&qb||(m.attrHooks.value={set:function(a,b,c){return m.nodeName(a,"input")?void(a.defaultValue=b):mb&&mb.set(a,b,c)}}),qb||(mb={set:function(a,b,c){var d=a.getAttributeNode(c);return d||a.setAttributeNode(d=a.ownerDocument.createAttribute(c)),d.value=b+="","value"===c||b===a.getAttribute(c)?b:void 0}},ob.id=ob.name=ob.coords=function(a,b,c){var d;return c?void 0:(d=a.getAttributeNode(b))&&""!==d.value?d.value:null},m.valHooks.button={get:function(a,b){var c=a.getAttributeNode(b);return c&&c.specified?c.value:void 0},set:mb.set},m.attrHooks.contenteditable={set:function(a,b,c){mb.set(a,""===b?!1:b,c)}},m.each(["width","height"],function(a,b){m.attrHooks[b]={set:function(a,c){return""===c?(a.setAttribute(b,"auto"),c):void 0}}})),k.style||(m.attrHooks.style={get:function(a){return a.style.cssText||void 0},set:function(a,b){return a.style.cssText=b+""}});var sb=/^(?:input|select|textarea|button|object)$/i,tb=/^(?:a|area)$/i;m.fn.extend({prop:function(a,b){return V(this,m.prop,a,b,arguments.length>1)},removeProp:function(a){return a=m.propFix[a]||a,this.each(function(){try{this[a]=void 0,delete this[a]}catch(b){}})}}),m.extend({propFix:{"for":"htmlFor","class":"className"},prop:function(a,b,c){var d,e,f,g=a.nodeType;if(a&&3!==g&&8!==g&&2!==g)return f=1!==g||!m.isXMLDoc(a),f&&(b=m.propFix[b]||b,e=m.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=m.find.attr(a,"tabindex");return b?parseInt(b,10):sb.test(a.nodeName)||tb.test(a.nodeName)&&a.href?0:-1}}}}),k.hrefNormalized||m.each(["href","src"],function(a,b){m.propHooks[b]={get:function(a){return a.getAttribute(b,4)}}}),k.optSelected||(m.propHooks.selected={get:function(a){var b=a.parentNode;return b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex),null}}),m.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){m.propFix[this.toLowerCase()]=this}),k.enctype||(m.propFix.enctype="encoding");var ub=/[\t\r\n\f]/g;m.fn.extend({addClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j="string"==typeof a&&a;if(m.isFunction(a))return this.each(function(b){m(this).addClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(ub," "):" ")){f=0;while(e=b[f++])d.indexOf(" "+e+" ")<0&&(d+=e+" ");g=m.trim(d),c.className!==g&&(c.className=g)}return this},removeClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j=0===arguments.length||"string"==typeof a&&a;if(m.isFunction(a))return this.each(function(b){m(this).removeClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(ub," "):"")){f=0;while(e=b[f++])while(d.indexOf(" "+e+" ")>=0)d=d.replace(" "+e+" "," ");g=a?m.trim(d):"",c.className!==g&&(c.className=g)}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):this.each(m.isFunction(a)?function(c){m(this).toggleClass(a.call(this,c,this.className,b),b)}:function(){if("string"===c){var b,d=0,e=m(this),f=a.match(E)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else(c===K||"boolean"===c)&&(this.className&&m._data(this,"__className__",this.className),this.className=this.className||a===!1?"":m._data(this,"__className__")||"")})},hasClass:function(a){for(var b=" "+a+" ",c=0,d=this.length;d>c;c++)if(1===this[c].nodeType&&(" "+this[c].className+" ").replace(ub," ").indexOf(b)>=0)return!0;return!1}}),m.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(a,b){m.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),m.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)},bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)}});var vb=m.now(),wb=/\?/,xb=/(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g;m.parseJSON=function(b){if(a.JSON&&a.JSON.parse)return a.JSON.parse(b+"");var c,d=null,e=m.trim(b+"");return e&&!m.trim(e.replace(xb,function(a,b,e,f){return c&&b&&(d=0),0===d?a:(c=e||b,d+=!f-!e,"")}))?Function("return "+e)():m.error("Invalid JSON: "+b)},m.parseXML=function(b){var c,d;if(!b||"string"!=typeof b)return null;try{a.DOMParser?(d=new DOMParser,c=d.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b))}catch(e){c=void 0}return c&&c.documentElement&&!c.getElementsByTagName("parsererror").length||m.error("Invalid XML: "+b),c};var yb,zb,Ab=/#.*$/,Bb=/([?&])_=[^&]*/,Cb=/^(.*?):[ \t]*([^\r\n]*)\r?$/gm,Db=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Eb=/^(?:GET|HEAD)$/,Fb=/^\/\//,Gb=/^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,Hb={},Ib={},Jb="*/".concat("*");try{zb=location.href}catch(Kb){zb=y.createElement("a"),zb.href="",zb=zb.href}yb=Gb.exec(zb.toLowerCase())||[];function Lb(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(E)||[];if(m.isFunction(c))while(d=f[e++])"+"===d.charAt(0)?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function Mb(a,b,c,d){var e={},f=a===Ib;function g(h){var i;return e[h]=!0,m.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function Nb(a,b){var c,d,e=m.ajaxSettings.flatOptions||{};for(d in b)void 0!==b[d]&&((e[d]?a:c||(c={}))[d]=b[d]);return c&&m.extend(!0,a,c),a}function Ob(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===e&&(e=a.mimeType||b.getResponseHeader("Content-Type"));if(e)for(g in h)if(h[g]&&h[g].test(e)){i.unshift(g);break}if(i[0]in c)f=i[0];else{for(g in c){if(!i[0]||a.converters[g+" "+i[0]]){f=g;break}d||(d=g)}f=f||d}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function Pb(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}m.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:zb,type:"GET",isLocal:Db.test(yb[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Jb,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":m.parseJSON,"text xml":m.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?Nb(Nb(a,m.ajaxSettings),b):Nb(m.ajaxSettings,a)},ajaxPrefilter:Lb(Hb),ajaxTransport:Lb(Ib),ajax:function(a,b){"object"==typeof a&&(b=a,a=void 0),b=b||{};var c,d,e,f,g,h,i,j,k=m.ajaxSetup({},b),l=k.context||k,n=k.context&&(l.nodeType||l.jquery)?m(l):m.event,o=m.Deferred(),p=m.Callbacks("once memory"),q=k.statusCode||{},r={},s={},t=0,u="canceled",v={readyState:0,getResponseHeader:function(a){var b;if(2===t){if(!j){j={};while(b=Cb.exec(f))j[b[1].toLowerCase()]=b[2]}b=j[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return 2===t?f:null},setRequestHeader:function(a,b){var c=a.toLowerCase();return t||(a=s[c]=s[c]||a,r[a]=b),this},overrideMimeType:function(a){return t||(k.mimeType=a),this},statusCode:function(a){var b;if(a)if(2>t)for(b in a)q[b]=[q[b],a[b]];else v.always(a[v.status]);return this},abort:function(a){var b=a||u;return i&&i.abort(b),x(0,b),this}};if(o.promise(v).complete=p.add,v.success=v.done,v.error=v.fail,k.url=((a||k.url||zb)+"").replace(Ab,"").replace(Fb,yb[1]+"//"),k.type=b.method||b.type||k.method||k.type,k.dataTypes=m.trim(k.dataType||"*").toLowerCase().match(E)||[""],null==k.crossDomain&&(c=Gb.exec(k.url.toLowerCase()),k.crossDomain=!(!c||c[1]===yb[1]&&c[2]===yb[2]&&(c[3]||("http:"===c[1]?"80":"443"))===(yb[3]||("http:"===yb[1]?"80":"443")))),k.data&&k.processData&&"string"!=typeof k.data&&(k.data=m.param(k.data,k.traditional)),Mb(Hb,k,b,v),2===t)return v;h=m.event&&k.global,h&&0===m.active++&&m.event.trigger("ajaxStart"),k.type=k.type.toUpperCase(),k.hasContent=!Eb.test(k.type),e=k.url,k.hasContent||(k.data&&(e=k.url+=(wb.test(e)?"&":"?")+k.data,delete k.data),k.cache===!1&&(k.url=Bb.test(e)?e.replace(Bb,"$1_="+vb++):e+(wb.test(e)?"&":"?")+"_="+vb++)),k.ifModified&&(m.lastModified[e]&&v.setRequestHeader("If-Modified-Since",m.lastModified[e]),m.etag[e]&&v.setRequestHeader("If-None-Match",m.etag[e])),(k.data&&k.hasContent&&k.contentType!==!1||b.contentType)&&v.setRequestHeader("Content-Type",k.contentType),v.setRequestHeader("Accept",k.dataTypes[0]&&k.accepts[k.dataTypes[0]]?k.accepts[k.dataTypes[0]]+("*"!==k.dataTypes[0]?", "+Jb+"; q=0.01":""):k.accepts["*"]);for(d in k.headers)v.setRequestHeader(d,k.headers[d]);if(k.beforeSend&&(k.beforeSend.call(l,v,k)===!1||2===t))return v.abort();u="abort";for(d in{success:1,error:1,complete:1})v[d](k[d]);if(i=Mb(Ib,k,b,v)){v.readyState=1,h&&n.trigger("ajaxSend",[v,k]),k.async&&k.timeout>0&&(g=setTimeout(function(){v.abort("timeout")},k.timeout));try{t=1,i.send(r,x)}catch(w){if(!(2>t))throw w;x(-1,w)}}else x(-1,"No Transport");function x(a,b,c,d){var j,r,s,u,w,x=b;2!==t&&(t=2,g&&clearTimeout(g),i=void 0,f=d||"",v.readyState=a>0?4:0,j=a>=200&&300>a||304===a,c&&(u=Ob(k,v,c)),u=Pb(k,u,v,j),j?(k.ifModified&&(w=v.getResponseHeader("Last-Modified"),w&&(m.lastModified[e]=w),w=v.getResponseHeader("etag"),w&&(m.etag[e]=w)),204===a||"HEAD"===k.type?x="nocontent":304===a?x="notmodified":(x=u.state,r=u.data,s=u.error,j=!s)):(s=x,(a||!x)&&(x="error",0>a&&(a=0))),v.status=a,v.statusText=(b||x)+"",j?o.resolveWith(l,[r,x,v]):o.rejectWith(l,[v,x,s]),v.statusCode(q),q=void 0,h&&n.trigger(j?"ajaxSuccess":"ajaxError",[v,k,j?r:s]),p.fireWith(l,[v,x]),h&&(n.trigger("ajaxComplete",[v,k]),--m.active||m.event.trigger("ajaxStop")))}return v},getJSON:function(a,b,c){return m.get(a,b,c,"json")},getScript:function(a,b){return m.get(a,void 0,b,"script")}}),m.each(["get","post"],function(a,b){m[b]=function(a,c,d,e){return m.isFunction(c)&&(e=e||d,d=c,c=void 0),m.ajax({url:a,type:b,dataType:e,data:c,success:d})}}),m._evalUrl=function(a){return m.ajax({url:a,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})},m.fn.extend({wrapAll:function(a){if(m.isFunction(a))return this.each(function(b){m(this).wrapAll(a.call(this,b))});if(this[0]){var b=m(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&1===a.firstChild.nodeType)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){return this.each(m.isFunction(a)?function(b){m(this).wrapInner(a.call(this,b))}:function(){var b=m(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=m.isFunction(a);return this.each(function(c){m(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){m.nodeName(this,"body")||m(this).replaceWith(this.childNodes)}).end()}}),m.expr.filters.hidden=function(a){return a.offsetWidth<=0&&a.offsetHeight<=0||!k.reliableHiddenOffsets()&&"none"===(a.style&&a.style.display||m.css(a,"display"))},m.expr.filters.visible=function(a){return!m.expr.filters.hidden(a)};var Qb=/%20/g,Rb=/\[\]$/,Sb=/\r?\n/g,Tb=/^(?:submit|button|image|reset|file)$/i,Ub=/^(?:input|select|textarea|keygen)/i;function Vb(a,b,c,d){var e;if(m.isArray(b))m.each(b,function(b,e){c||Rb.test(a)?d(a,e):Vb(a+"["+("object"==typeof e?b:"")+"]",e,c,d)});else if(c||"object"!==m.type(b))d(a,b);else for(e in b)Vb(a+"["+e+"]",b[e],c,d)}m.param=function(a,b){var c,d=[],e=function(a,b){b=m.isFunction(b)?b():null==b?"":b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};if(void 0===b&&(b=m.ajaxSettings&&m.ajaxSettings.traditional),m.isArray(a)||a.jquery&&!m.isPlainObject(a))m.each(a,function(){e(this.name,this.value)});else for(c in a)Vb(c,a[c],b,e);return d.join("&").replace(Qb,"+")},m.fn.extend({serialize:function(){return m.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=m.prop(this,"elements");return a?m.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!m(this).is(":disabled")&&Ub.test(this.nodeName)&&!Tb.test(a)&&(this.checked||!W.test(a))}).map(function(a,b){var c=m(this).val();return null==c?null:m.isArray(c)?m.map(c,function(a){return{name:b.name,value:a.replace(Sb,"\r\n")}}):{name:b.name,value:c.replace(Sb,"\r\n")}}).get()}}),m.ajaxSettings.xhr=void 0!==a.ActiveXObject?function(){return!this.isLocal&&/^(get|post|head|put|delete|options)$/i.test(this.type)&&Zb()||$b()}:Zb;var Wb=0,Xb={},Yb=m.ajaxSettings.xhr();a.attachEvent&&a.attachEvent("onunload",function(){for(var a in Xb)Xb[a](void 0,!0)}),k.cors=!!Yb&&"withCredentials"in Yb,Yb=k.ajax=!!Yb,Yb&&m.ajaxTransport(function(a){if(!a.crossDomain||k.cors){var b;return{send:function(c,d){var e,f=a.xhr(),g=++Wb;if(f.open(a.type,a.url,a.async,a.username,a.password),a.xhrFields)for(e in a.xhrFields)f[e]=a.xhrFields[e];a.mimeType&&f.overrideMimeType&&f.overrideMimeType(a.mimeType),a.crossDomain||c["X-Requested-With"]||(c["X-Requested-With"]="XMLHttpRequest");for(e in c)void 0!==c[e]&&f.setRequestHeader(e,c[e]+"");f.send(a.hasContent&&a.data||null),b=function(c,e){var h,i,j;if(b&&(e||4===f.readyState))if(delete Xb[g],b=void 0,f.onreadystatechange=m.noop,e)4!==f.readyState&&f.abort();else{j={},h=f.status,"string"==typeof f.responseText&&(j.text=f.responseText);try{i=f.statusText}catch(k){i=""}h||!a.isLocal||a.crossDomain?1223===h&&(h=204):h=j.text?200:404}j&&d(h,i,j,f.getAllResponseHeaders())},a.async?4===f.readyState?setTimeout(b):f.onreadystatechange=Xb[g]=b:b()},abort:function(){b&&b(void 0,!0)}}}});function Zb(){try{return new a.XMLHttpRequest}catch(b){}}function $b(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}m.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(a){return m.globalEval(a),a}}}),m.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),m.ajaxTransport("script",function(a){if(a.crossDomain){var b,c=y.head||m("head")[0]||y.documentElement;return{send:function(d,e){b=y.createElement("script"),b.async=!0,a.scriptCharset&&(b.charset=a.scriptCharset),b.src=a.url,b.onload=b.onreadystatechange=function(a,c){(c||!b.readyState||/loaded|complete/.test(b.readyState))&&(b.onload=b.onreadystatechange=null,b.parentNode&&b.parentNode.removeChild(b),b=null,c||e(200,"success"))},c.insertBefore(b,c.firstChild)},abort:function(){b&&b.onload(void 0,!0)}}}});var _b=[],ac=/(=)\?(?=&|$)|\?\?/;m.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=_b.pop()||m.expando+"_"+vb++;return this[a]=!0,a}}),m.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(ac.test(b.url)?"url":"string"==typeof b.data&&!(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&ac.test(b.data)&&"data");return h||"jsonp"===b.dataTypes[0]?(e=b.jsonpCallback=m.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(ac,"$1"+e):b.jsonp!==!1&&(b.url+=(wb.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||m.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,_b.push(e)),g&&m.isFunction(f)&&f(g[0]),g=f=void 0}),"script"):void 0}),m.parseHTML=function(a,b,c){if(!a||"string"!=typeof a)return null;"boolean"==typeof b&&(c=b,b=!1),b=b||y;var d=u.exec(a),e=!c&&[];return d?[b.createElement(d[1])]:(d=m.buildFragment([a],b,e),e&&e.length&&m(e).remove(),m.merge([],d.childNodes))};var bc=m.fn.load;m.fn.load=function(a,b,c){if("string"!=typeof a&&bc)return bc.apply(this,arguments);var d,e,f,g=this,h=a.indexOf(" ");return h>=0&&(d=m.trim(a.slice(h,a.length)),a=a.slice(0,h)),m.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(f="POST"),g.length>0&&m.ajax({url:a,type:f,dataType:"html",data:b}).done(function(a){e=arguments,g.html(d?m("<div>").append(m.parseHTML(a)).find(d):a)}).complete(c&&function(a,b){g.each(c,e||[a.responseText,b,a])}),this},m.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){m.fn[b]=function(a){return this.on(b,a)}}),m.expr.filters.animated=function(a){return m.grep(m.timers,function(b){return a===b.elem}).length};var cc=a.document.documentElement;function dc(a){return m.isWindow(a)?a:9===a.nodeType?a.defaultView||a.parentWindow:!1}m.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=m.css(a,"position"),l=m(a),n={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=m.css(a,"top"),i=m.css(a,"left"),j=("absolute"===k||"fixed"===k)&&m.inArray("auto",[f,i])>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),m.isFunction(b)&&(b=b.call(a,c,h)),null!=b.top&&(n.top=b.top-h.top+g),null!=b.left&&(n.left=b.left-h.left+e),"using"in b?b.using.call(a,n):l.css(n)}},m.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){m.offset.setOffset(this,a,b)});var b,c,d={top:0,left:0},e=this[0],f=e&&e.ownerDocument;if(f)return b=f.documentElement,m.contains(b,e)?(typeof e.getBoundingClientRect!==K&&(d=e.getBoundingClientRect()),c=dc(f),{top:d.top+(c.pageYOffset||b.scrollTop)-(b.clientTop||0),left:d.left+(c.pageXOffset||b.scrollLeft)-(b.clientLeft||0)}):d},position:function(){if(this[0]){var a,b,c={top:0,left:0},d=this[0];return"fixed"===m.css(d,"position")?b=d.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),m.nodeName(a[0],"html")||(c=a.offset()),c.top+=m.css(a[0],"borderTopWidth",!0),c.left+=m.css(a[0],"borderLeftWidth",!0)),{top:b.top-c.top-m.css(d,"marginTop",!0),left:b.left-c.left-m.css(d,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||cc;while(a&&!m.nodeName(a,"html")&&"static"===m.css(a,"position"))a=a.offsetParent;return a||cc})}}),m.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,b){var c=/Y/.test(b);m.fn[a]=function(d){return V(this,function(a,d,e){var f=dc(a);return void 0===e?f?b in f?f[b]:f.document.documentElement[d]:a[d]:void(f?f.scrollTo(c?m(f).scrollLeft():e,c?e:m(f).scrollTop()):a[d]=e)},a,d,arguments.length,null)}}),m.each(["top","left"],function(a,b){m.cssHooks[b]=La(k.pixelPosition,function(a,c){return c?(c=Ja(a,b),Ha.test(c)?m(a).position()[b]+"px":c):void 0})}),m.each({Height:"height",Width:"width"},function(a,b){m.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){m.fn[d]=function(d,e){var f=arguments.length&&(c||"boolean"!=typeof d),g=c||(d===!0||e===!0?"margin":"border");return V(this,function(b,c,d){var e;return m.isWindow(b)?b.document.documentElement["client"+a]:9===b.nodeType?(e=b.documentElement,Math.max(b.body["scroll"+a],e["scroll"+a],b.body["offset"+a],e["offset"+a],e["client"+a])):void 0===d?m.css(b,c,g):m.style(b,c,d,g)},b,f?d:void 0,f,null)}})}),m.fn.size=function(){return this.length},m.fn.andSelf=m.fn.addBack,"function"==typeof define&&define.amd&&define("jquery",[],function(){return m});var ec=a.jQuery,fc=a.$;return m.noConflict=function(b){return a.$===m&&(a.$=fc),b&&a.jQuery===m&&(a.jQuery=ec),m},typeof b===K&&(a.jQuery=a.$=m),m}); +</script> +<meta name="viewport" content="width=device-width, initial-scale=1" /> +<style type="text/css">html{font-family:sans-serif;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}h1{margin:.67em 0;font-size:2em}mark{color:#000;background:#ff0}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{height:0;-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{margin:0;font:inherit;color:inherit}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}input{line-height:normal}input[type=checkbox],input[type=radio]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}fieldset{padding:.35em .625em .75em;margin:0 2px;border:1px solid silver}legend{padding:0;border:0}textarea{overflow:auto}optgroup{font-weight:700}table{border-spacing:0;border-collapse:collapse}td,th{padding:0}@media print{*,:after,:before{color:#000!important;text-shadow:none!important;background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}abbr[title]:after{content:" (" attr(title) ")"}a[href^="javascript:"]:after,a[href^="#"]:after{content:""}blockquote,pre{border:1px solid #999;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.navbar{display:none}.btn>.caret,.dropup>.btn>.caret{border-top-color:#000!important}.label{border:1px solid #000}.table{border-collapse:collapse!important}.table td,.table th{background-color:#fff!important}.table-bordered td,.table-bordered th{border:1px solid #ddd!important}}@font-face{font-family:'Glyphicons Halflings';src:url(data:application/vnd.ms-fontobject;base64,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);src:url(data:application/vnd.ms-fontobject;base64,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) format('embedded-opentype'),url(data:application/font-woff;base64,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) format('woff'),url(data:application/x-font-truetype;base64,AAEAAAAPAIAAAwBwRkZUTW0ql9wAAAD8AAAAHEdERUYBRAAEAAABGAAAACBPUy8yZ7lriQAAATgAAABgY21hcNqt44EAAAGYAAAGcmN2dCAAKAL4AAAIDAAAAARnYXNw//8AAwAACBAAAAAIZ2x5Zn1dwm8AAAgYAACUpGhlYWQFTS/YAACcvAAAADZoaGVhCkQEEQAAnPQAAAAkaG10eNLHIGAAAJ0YAAADdGxvY2Fv+5XOAACgjAAAAjBtYXhwAWoA2AAAorwAAAAgbmFtZbMsoJsAAKLcAAADonBvc3S6o+U1AACmgAAACtF3ZWJmwxhUUAAAsVQAAAAGAAAAAQAAAADMPaLPAAAAANB2gXUAAAAA0HZzlwABAAAADgAAABgAAAAAAAIAAQABARYAAQAEAAAAAgAAAAMEiwGQAAUABAMMAtAAAABaAwwC0AAAAaQAMgK4AAAAAAUAAAAAAAAAAAAAAAIAAAAAAAAAAAAAAFVLV04AQAAg//8DwP8QAAAFFAB7AAAAAQAAAAAAAAAAAAAAIAABAAAABQAAAAMAAAAsAAAACgAAAdwAAQAAAAAEaAADAAEAAAAsAAMACgAAAdwABAGwAAAAaABAAAUAKAAgACsAoAClIAogLyBfIKwgvSISIxsl/CYBJvonCScP4APgCeAZ4CngOeBJ4FngYOBp4HngieCX4QnhGeEp4TnhRuFJ4VnhaeF54YnhleGZ4gbiCeIW4hniIeIn4jniSeJZ4mD4////AAAAIAAqAKAApSAAIC8gXyCsIL0iEiMbJfwmASb6JwknD+AB4AXgEOAg4DDgQOBQ4GDgYuBw4IDgkOEB4RDhIOEw4UDhSOFQ4WDhcOGA4ZDhl+IA4gniEOIY4iHiI+Iw4kDiUOJg+P/////j/9r/Zv9i4Ajf5N+132nfWd4F3P3aHdoZ2SHZE9kOIB0gHCAWIBAgCiAEH/4f+B/3H/Ef6x/lH3wfdh9wH2ofZB9jH10fVx9RH0sfRR9EHt4e3B7WHtUezh7NHsUevx65HrMIFQABAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADAAAAAACjAAAAAAAAAA1AAAAIAAAACAAAAADAAAAKgAAACsAAAAEAAAAoAAAAKAAAAAGAAAApQAAAKUAAAAHAAAgAAAAIAoAAAAIAAAgLwAAIC8AAAATAAAgXwAAIF8AAAAUAAAgrAAAIKwAAAAVAAAgvQAAIL0AAAAWAAAiEgAAIhIAAAAXAAAjGwAAIxsAAAAYAAAl/AAAJfwAAAAZAAAmAQAAJgEAAAAaAAAm+gAAJvoAAAAbAAAnCQAAJwkAAAAcAAAnDwAAJw8AAAAdAADgAQAA4AMAAAAeAADgBQAA4AkAAAAhAADgEAAA4BkAAAAmAADgIAAA4CkAAAAwAADgMAAA4DkAAAA6AADgQAAA4EkAAABEAADgUAAA4FkAAABOAADgYAAA4GAAAABYAADgYgAA4GkAAABZAADgcAAA4HkAAABhAADggAAA4IkAAABrAADgkAAA4JcAAAB1AADhAQAA4QkAAAB9AADhEAAA4RkAAACGAADhIAAA4SkAAACQAADhMAAA4TkAAACaAADhQAAA4UYAAACkAADhSAAA4UkAAACrAADhUAAA4VkAAACtAADhYAAA4WkAAAC3AADhcAAA4XkAAADBAADhgAAA4YkAAADLAADhkAAA4ZUAAADVAADhlwAA4ZkAAADbAADiAAAA4gYAAADeAADiCQAA4gkAAADlAADiEAAA4hYAAADmAADiGAAA4hkAAADtAADiIQAA4iEAAADvAADiIwAA4icAAADwAADiMAAA4jkAAAD1AADiQAAA4kkAAAD/AADiUAAA4lkAAAEJAADiYAAA4mAAAAETAAD4/wAA+P8AAAEUAAH1EQAB9REAAAEVAAH2qgAB9qoAAAEWAAYCCgAAAAABAAABAAAAAAAAAAAAAAAAAAAAAQACAAAAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAwAAAAAAAAAAAAAAAAAAAAAAAAAEAAUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAYAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAVAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAKAL4AAAAAf//AAIAAgAoAAABaAMgAAMABwAusQEALzyyBwQA7TKxBgXcPLIDAgDtMgCxAwAvPLIFBADtMrIHBgH8PLIBAgDtMjMRIRElMxEjKAFA/ujw8AMg/OAoAtAAAQBkAGQETARMAFsAAAEyFh8BHgEdATc+AR8BFgYPATMyFhcWFRQGDwEOASsBFx4BDwEGJi8BFRQGBwYjIiYvAS4BPQEHDgEvASY2PwEjIiYnJjU0Nj8BPgE7AScuAT8BNhYfATU0Njc2AlgPJgsLCg+eBxYIagcCB57gChECBgMCAQIRCuCeBwIHaggWB54PCikiDyYLCwoPngcWCGoHAgee4AoRAgYDAgECEQrgngcCB2oIFgeeDwopBEwDAgECEQrgngcCB2oIFgeeDwopIg8mCwsKD54HFghqBwIHnuAKEQIGAwIBAhEK4J4HAgdqCBYHng8KKSIPJgsLCg+eBxYIagcCB57gChECBgAAAAABAAAAAARMBEwAIwAAATMyFhURITIWHQEUBiMhERQGKwEiJjURISImPQE0NjMhETQ2AcLIFR0BXhUdHRX+oh0VyBUd/qIVHR0VAV4dBEwdFf6iHRXIFR3+ohUdHRUBXh0VyBUdAV4VHQAAAAABAHAAAARABEwARQAAATMyFgcBBgchMhYPAQ4BKwEVITIWDwEOASsBFRQGKwEiJj0BISImPwE+ATsBNSEiJj8BPgE7ASYnASY2OwEyHwEWMj8BNgM5+goFCP6UBgUBDAoGBngGGAp9ARMKBgZ4BhgKfQ8LlAsP/u0KBgZ4BhgKff7tCgYGeAYYCnYFBv6UCAUK+hkSpAgUCKQSBEwKCP6UBgwMCKAIDGQMCKAIDK4LDw8LrgwIoAgMZAwIoAgMDAYBbAgKEqQICKQSAAABAGQABQSMBK4AOwAAATIXFhcjNC4DIyIOAwchByEGFSEHIR4EMzI+AzUzBgcGIyInLgEnIzczNjcjNzM+ATc2AujycDwGtSM0QDkXEys4MjAPAXtk/tQGAZZk/tQJMDlCNBUWOUA0I64eYmunznYkQgzZZHABBdpkhhQ+H3UErr1oaS1LMCEPCx4uTzJkMjJkSnRCKw8PIjBKK6trdZ4wqndkLzVkV4UljQAAAgB7AAAETASwAD4ARwAAASEyHgUVHAEVFA4FKwEHITIWDwEOASsBFRQGKwEiJj0BISImPwE+ATsBNSEiJj8BPgE7ARE0NhcRMzI2NTQmIwGsAV5DakIwFgwBAQwWMEJqQ7ICASAKBgZ4BhgKigsKlQoP/vUKBgZ4BhgKdf71CgYGeAYYCnUPtstALS1ABLAaJD8yTyokCwsLJCpQMkAlGmQMCKAIDK8LDg8KrwwIoAgMZAwIoAgMAdsKD8j+1EJWVEAAAAEAyAGQBEwCvAAPAAATITIWHQEUBiMhIiY9ATQ2+gMgFR0dFfzgFR0dArwdFcgVHR0VyBUdAAAAAgDIAAAD6ASwACUAQQAAARUUBisBFRQGBx4BHQEzMhYdASE1NDY7ATU0NjcuAT0BIyImPQEXFRQWFx4BFAYHDgEdASE1NCYnLgE0Njc+AT0BA+gdFTJjUVFjMhUd/OAdFTJjUVFjMhUdyEE3HCAgHDdBAZBBNxwgIBw3QQSwlhUdZFuVIyOVW5YdFZaWFR2WW5UjI5VbZB0VlshkPGMYDDI8MgwYYzyWljxjGAwyPDIMGGM8ZAAAAAEAAAAAAAAAAAAAAAAxAAAB//IBLATCBEEAFgAAATIWFzYzMhYVFAYjISImNTQ2NyY1NDYB9261LCwueKqqeP0ST3FVQgLYBEF3YQ6teHmtclBFaw4MGZnXAAAAAgAAAGQEsASvABoAHgAAAB4BDwEBMzIWHQEhNTQ2OwEBJyY+ARYfATc2AyEnAwL2IAkKiAHTHhQe+1AeFB4B1IcKCSAkCm9wCXoBebbDBLMTIxC7/RYlFSoqFSUC6rcQJBQJEJSWEPwecAIWAAAAAAQAAABkBLAETAALABcAIwA3AAATITIWBwEGIicBJjYXARYUBwEGJjURNDYJATYWFREUBicBJjQHARYGIyEiJjcBNjIfARYyPwE2MhkEfgoFCP3MCBQI/cwIBQMBCAgI/vgICgoDjAEICAoKCP74CFwBbAgFCvuCCgUIAWwIFAikCBQIpAgUBEwKCP3JCAgCNwgK2v74CBQI/vgIBQoCJgoF/vABCAgFCv3aCgUIAQgIFID+lAgKCggBbAgIpAgIpAgAAAAD//D/8AS6BLoACQANABAAAAAyHwEWFA8BJzcTAScJAQUTA+AmDpkNDWPWXyL9mdYCZv4f/rNuBLoNmQ4mDlzWYP50/ZrWAmb8anABTwAAAAEAAAAABLAEsAAPAAABETMyFh0BITU0NjsBEQEhArz6FR384B0V+v4MBLACiv3aHRUyMhUdAiYCJgAAAAEADgAIBEwEnAAfAAABJTYWFREUBgcGLgE2NzYXEQURFAYHBi4BNjc2FxE0NgFwAoUnMFNGT4gkV09IQv2oWEFPiCRXT0hCHQP5ow8eIvzBN1EXGSltchkYEAIJm/2iKmAVGilucRoYEQJ/JioAAAACAAn/+AS7BKcAHQApAAAAMh4CFQcXFAcBFgYPAQYiJwEGIycHIi4CND4BBCIOARQeATI+ATQmAZDItoNOAQFOARMXARY7GikT/u13jgUCZLaDTk6DAXKwlFZWlLCUVlYEp06DtmQCBY15/u4aJRg6FBQBEk0BAU6Dtsi2g1tWlLCUVlaUsJQAAQBkAFgErwREABkAAAE+Ah4CFRQOAwcuBDU0PgIeAQKJMHt4dVg2Q3mEqD4+p4V4Qzhadnh5A7VESAUtU3ZAOXmAf7JVVbJ/gHk5QHZTLQVIAAAAAf/TAF4EewSUABgAAAETNjIXEyEyFgcFExYGJyUFBiY3EyUmNjMBl4MHFQeBAaUVBhH+qoIHDxH+qf6qEQ8Hgv6lEQYUAyABYRMT/p8RDPn+bxQLDPb3DAsUAZD7DBEAAv/TAF4EewSUABgAIgAAARM2MhcTITIWBwUTFgYnJQUGJjcTJSY2MwUjFwc3Fyc3IycBl4MHFQeBAaUVBhH+qoIHDxH+qf6qEQ8Hgv6lEQYUAfPwxUrBw0rA6k4DIAFhExP+nxEM+f5vFAsM9vcMCxQBkPsMEWSO4ouM5YzTAAABAAAAAASwBLAAJgAAATIWHQEUBiMVFBYXBR4BHQEUBiMhIiY9ATQ2NyU+AT0BIiY9ATQ2Alh8sD4mDAkBZgkMDwr7ggoPDAkBZgkMJj6wBLCwfPouaEsKFwbmBRcKXQoPDwpdChcF5gYXCktoLvp8sAAAAA0AAAAABLAETAAPABMAIwAnACsALwAzADcARwBLAE8AUwBXAAATITIWFREUBiMhIiY1ETQ2FxUzNSkBIgYVERQWMyEyNjURNCYzFTM1BRUzNSEVMzUFFTM1IRUzNQchIgYVERQWMyEyNjURNCYFFTM1IRUzNQUVMzUhFTM1GQR+Cg8PCvuCCg8PVWQCo/3aCg8PCgImCg8Pc2T8GGQDIGT8GGQDIGTh/doKDw8KAiYKDw/872QDIGT8GGQDIGQETA8K++YKDw8KBBoKD2RkZA8K/qIKDw8KAV4KD2RkyGRkZGTIZGRkZGQPCv6iCg8PCgFeCg9kZGRkZMhkZGRkAAAEAAAAAARMBEwADwAfAC8APwAAEyEyFhURFAYjISImNRE0NikBMhYVERQGIyEiJjURNDYBITIWFREUBiMhIiY1ETQ2KQEyFhURFAYjISImNRE0NjIBkBUdHRX+cBUdHQJtAZAVHR0V/nAVHR39vQGQFR0dFf5wFR0dAm0BkBUdHRX+cBUdHQRMHRX+cBUdHRUBkBUdHRX+cBUdHRUBkBUd/agdFf5wFR0dFQGQFR0dFf5wFR0dFQGQFR0AAAkAAAAABEwETAAPAB8ALwA/AE8AXwBvAH8AjwAAEzMyFh0BFAYrASImPQE0NiEzMhYdARQGKwEiJj0BNDYhMzIWHQEUBisBIiY9ATQ2ATMyFh0BFAYrASImPQE0NiEzMhYdARQGKwEiJj0BNDYhMzIWHQEUBisBIiY9ATQ2ATMyFh0BFAYrASImPQE0NiEzMhYdARQGKwEiJj0BNDYhMzIWHQEUBisBIiY9ATQ2MsgVHR0VyBUdHQGlyBUdHRXIFR0dAaXIFR0dFcgVHR389cgVHR0VyBUdHQGlyBUdHRXIFR0dAaXIFR0dFcgVHR389cgVHR0VyBUdHQGlyBUdHRXIFR0dAaXIFR0dFcgVHR0ETB0VyBUdHRXIFR0dFcgVHR0VyBUdHRXIFR0dFcgVHf5wHRXIFR0dFcgVHR0VyBUdHRXIFR0dFcgVHR0VyBUd/nAdFcgVHR0VyBUdHRXIFR0dFcgVHR0VyBUdHRXIFR0ABgAAAAAEsARMAA8AHwAvAD8ATwBfAAATMzIWHQEUBisBIiY9ATQ2KQEyFh0BFAYjISImPQE0NgEzMhYdARQGKwEiJj0BNDYpATIWHQEUBiMhIiY9ATQ2ATMyFh0BFAYrASImPQE0NikBMhYdARQGIyEiJj0BNDYyyBUdHRXIFR0dAaUCvBUdHRX9RBUdHf6FyBUdHRXIFR0dAaUCvBUdHRX9RBUdHf6FyBUdHRXIFR0dAaUCvBUdHRX9RBUdHQRMHRXIFR0dFcgVHR0VyBUdHRXIFR3+cB0VyBUdHRXIFR0dFcgVHR0VyBUd/nAdFcgVHR0VyBUdHRXIFR0dFcgVHQAAAAABACYALAToBCAAFwAACQE2Mh8BFhQHAQYiJwEmND8BNjIfARYyAdECOwgUB7EICPzxBxUH/oAICLEHFAirBxYB3QI7CAixBxQI/PAICAGACBQHsQgIqwcAAQBuAG4EQgRCACMAAAEXFhQHCQEWFA8BBiInCQEGIi8BJjQ3CQEmND8BNjIXCQE2MgOIsggI/vUBCwgIsggVB/70/vQHFQiyCAgBC/71CAiyCBUHAQwBDAcVBDuzCBUH/vT+9AcVCLIICAEL/vUICLIIFQcBDAEMBxUIsggI/vUBDAcAAwAX/+sExQSZABkAJQBJAAAAMh4CFRQHARYUDwEGIicBBiMiLgI0PgEEIg4BFB4BMj4BNCYFMzIWHQEzMhYdARQGKwEVFAYrASImPQEjIiY9ATQ2OwE1NDYBmcSzgk1OASwICG0HFQj+1HeOYrSBTU2BAW+zmFhYmLOZWFj+vJYKD0sKDw8KSw8KlgoPSwoPDwpLDwSZTYKzYo15/tUIFQhsCAgBK01NgbTEs4JNWJmzmFhYmLOZIw8KSw8KlgoPSwoPDwpLDwqWCg9LCg8AAAMAF//rBMUEmQAZACUANQAAADIeAhUUBwEWFA8BBiInAQYjIi4CND4BBCIOARQeATI+ATQmBSEyFh0BFAYjISImPQE0NgGZxLOCTU4BLAgIbQcVCP7Ud45itIFNTYEBb7OYWFiYs5lYWP5YAV4KDw8K/qIKDw8EmU2Cs2KNef7VCBUIbAgIAStNTYG0xLOCTViZs5hYWJizmYcPCpYKDw8KlgoPAAAAAAIAFwAXBJkEsAAPAC0AAAEzMhYVERQGKwEiJjURNDYFNRYSFRQOAiIuAjU0EjcVDgEVFB4BMj4BNTQmAiZkFR0dFWQVHR0BD6fSW5vW6tabW9KnZ3xyxejFcnwEsB0V/nAVHR0VAZAVHeGmPv7ZuHXWm1tbm9Z1uAEnPqY3yHh0xXJyxXR4yAAEAGQAAASwBLAADwAfAC8APwAAATMyFhURFAYrASImNRE0NgEzMhYVERQGKwEiJjURNDYBMzIWFREUBisBIiY1ETQ2BTMyFh0BFAYrASImPQE0NgQBlgoPDwqWCg8P/t6WCg8PCpYKDw/+3pYKDw8KlgoPD/7elgoPDwqWCg8PBLAPCvuCCg8PCgR+Cg/+cA8K/RIKDw8KAu4KD/7UDwr+PgoPDwoBwgoPyA8K+goPDwr6Cg8AAAAAAgAaABsElgSWAEcATwAAATIfAhYfATcWFwcXFh8CFhUUDwIGDwEXBgcnBwYPAgYjIi8CJi8BByYnNycmLwImNTQ/AjY/ASc2Nxc3Nj8CNhIiBhQWMjY0AlghKSYFMS0Fhj0rUAMZDgGYBQWYAQ8YA1AwOIYFLDIFJisfISkmBTEtBYY8LFADGQ0ClwYGlwINGQNQLzqFBS0xBSYreLJ+frJ+BJYFmAEOGQJQMDmGBSwxBiYrHiIoJgYxLAWGPSxRAxkOApcFBZcCDhkDUTA5hgUtMAYmKiAhKCYGMC0Fhj0sUAIZDgGYBf6ZfrF+frEABwBkAAAEsAUUABMAFwAhACUAKQAtADEAAAEhMhYdASEyFh0BITU0NjMhNTQ2FxUhNQERFAYjISImNREXETMRMxEzETMRMxEzETMRAfQBLCk7ARMKD/u0DwoBEzspASwBLDsp/UQpO2RkZGRkZGRkBRQ7KWQPCktLCg9kKTtkZGT+1PzgKTs7KQMgZP1EArz9RAK8/UQCvP1EArwAAQAMAAAFCATRAB8AABMBNjIXARYGKwERFAYrASImNREhERQGKwEiJjURIyImEgJsCBUHAmAIBQqvDwr6Cg/+1A8K+goPrwoFAmoCYAcH/aAICv3BCg8PCgF3/okKDw8KAj8KAAIAZAAAA+gEsAARABcAAAERFBYzIREUBiMhIiY1ETQ2MwEjIiY9AQJYOykBLB0V/OAVHR0VA1L6FR0EsP5wKTv9dhUdHRUETBUd/nAdFfoAAwAXABcEmQSZAA8AGwAwAAAAMh4CFA4CIi4CND4BBCIOARQeATI+ATQmBTMyFhURMzIWHQEUBisBIiY1ETQ2AePq1ptbW5vW6tabW1ubAb/oxXJyxejFcnL+fDIKD68KDw8K+goPDwSZW5vW6tabW1ub1urWmztyxejFcnLF6MUNDwr+7Q8KMgoPDwoBXgoPAAAAAAL/nAAABRQEsAALAA8AACkBAyMDIQEzAzMDMwEDMwMFFP3mKfIp/eYBr9EVohTQ/p4b4BsBkP5wBLD+1AEs/nD+1AEsAAAAAAIAZAAABLAEsAAVAC8AAAEzMhYVETMyFgcBBiInASY2OwERNDYBMzIWFREUBiMhIiY1ETQ2OwEyFh0BITU0NgImyBUdvxQLDf65DSYN/rkNCxS/HQJUMgoPDwr75goPDwoyCg8DhA8EsB0V/j4XEP5wEBABkBAXAcIVHfzgDwr+ogoPDwoBXgoPDwqvrwoPAAMAFwAXBJkEmQAPABsAMQAAADIeAhQOAiIuAjQ+AQQiDgEUHgEyPgE0JgUzMhYVETMyFgcDBiInAyY2OwERNDYB4+rWm1tbm9bq1ptbW5sBv+jFcnLF6MVycv58lgoPiRUKDd8NJg3fDQoViQ8EmVub1urWm1tbm9bq1ps7csXoxXJyxejFDQ8K/u0XEP7tEBABExAXARMKDwAAAAMAFwAXBJkEmQAPABsAMQAAADIeAhQOAiIuAjQ+AQQiDgEUHgEyPgE0JiUTFgYrAREUBisBIiY1ESMiJjcTNjIB4+rWm1tbm9bq1ptbW5sBv+jFcnLF6MVycv7n3w0KFYkPCpYKD4kVCg3fDSYEmVub1urWm1tbm9bq1ps7csXoxXJyxejFAf7tEBf+7QoPDwoBExcQARMQAAAAAAIAAAAABLAEsAAZADkAABMhMhYXExYVERQGBwYjISImJyY1EzQ3Ez4BBSEiBgcDBhY7ATIWHwEeATsBMjY/AT4BOwEyNicDLgHhAu4KEwO6BwgFDBn7tAweAgYBB7kDEwKX/dQKEgJXAgwKlgoTAiYCEwr6ChMCJgITCpYKDAJXAhIEsA4K/XQYGf5XDB4CBggEDRkBqRkYAowKDsgOC/4+Cw4OCpgKDg4KmAoODgsBwgsOAAMAFwAXBJkEmQAPABsAJwAAADIeAhQOAiIuAjQ+AQQiDgEUHgEyPgE0JgUXFhQPAQYmNRE0NgHj6tabW1ub1urWm1tbmwG/6MVycsXoxXJy/ov9ERH9EBgYBJlbm9bq1ptbW5vW6tabO3LF6MVycsXoxV2+DCQMvgwLFQGQFQsAAQAXABcEmQSwACgAAAE3NhYVERQGIyEiJj8BJiMiDgEUHgEyPgE1MxQOAiIuAjQ+AjMyA7OHBwsPCv6WCwQHhW2BdMVycsXoxXKWW5vW6tabW1ub1nXABCSHBwQL/pYKDwsHhUxyxejFcnLFdHXWm1tbm9bq1ptbAAAAAAIAFwABBJkEsAAaADUAAAE3NhYVERQGIyEiJj8BJiMiDgEVIzQ+AjMyEzMUDgIjIicHBiY1ETQ2MyEyFg8BFjMyPgEDs4cHCw8L/pcLBAeGboF0xXKWW5vWdcDrllub1nXAnIYHCw8LAWgKBQiFboJ0xXIEJIcHBAv+lwsPCweGS3LFdHXWm1v9v3XWm1t2hggFCgFoCw8LB4VMcsUAAAAKAGQAAASwBLAADwAfAC8APwBPAF8AbwB/AI8AnwAAEyEyFhURFAYjISImNRE0NgUhIgYVERQWMyEyNjURNCYFMzIWHQEUBisBIiY9ATQ2MyEyFh0BFAYjISImPQE0NgczMhYdARQGKwEiJj0BNDYzITIWHQEUBiMhIiY9ATQ2BzMyFh0BFAYrASImPQE0NjMhMhYdARQGIyEiJj0BNDYHMzIWHQEUBisBIiY9ATQ2MyEyFh0BFAYjISImPQE0Nn0EGgoPDwr75goPDwPA/K4KDw8KA1IKDw/9CDIKDw8KMgoPD9IBwgoPDwr+PgoPD74yCg8PCjIKDw/SAcIKDw8K/j4KDw++MgoPDwoyCg8P0gHCCg8PCv4+Cg8PvjIKDw8KMgoPD9IBwgoPDwr+PgoPDwSwDwr7ggoPDwoEfgoPyA8K/K4KDw8KA1IKD2QPCjIKDw8KMgoPDwoyCg8PCjIKD8gPCjIKDw8KMgoPDwoyCg8PCjIKD8gPCjIKDw8KMgoPDwoyCg8PCjIKD8gPCjIKDw8KMgoPDwoyCg8PCjIKDwAAAAACAAAAAARMBLAAGQAjAAABNTQmIyEiBh0BIyIGFREUFjMhMjY1ETQmIyE1NDY7ATIWHQEDhHVT/tRSdmQpOzspA4QpOzsp/ageFMgUHgMgyFN1dlLIOyn9qCk7OykCWCk7lhUdHRWWAAIAZAAABEwETAAJADcAABMzMhYVESMRNDYFMhcWFREUBw4DIyIuAScuAiMiBwYjIicmNRE+ATc2HgMXHgIzMjc2fTIKD2QPA8AEBRADIUNAMRwaPyonKSxHHlVLBwgGBQ4WeDsXKC4TOQQpLUUdZ1AHBEwPCvvNBDMKDzACBhH+WwYGO1AkDQ0ODg8PDzkFAwcPAbY3VwMCAwsGFAEODg5XCAAAAwAAAAAEsASXACEAMQBBAAAAMh4CFREUBisBIiY1ETQuASAOARURFAYrASImNRE0PgEDMzIWFREUBisBIiY1ETQ2ITMyFhURFAYrASImNRE0NgHk6N6jYw8KMgoPjeT++uSNDwoyCg9joyqgCAwMCKAIDAwCYKAIDAwIoAgMDASXY6PedP7UCg8PCgEsf9FyctF//tQKDw8KASx03qP9wAwI/jQIDAwIAcwIDAwI/jQIDAwIAcwIDAAAAAACAAAA0wRHA90AFQA5AAABJTYWFREUBiclJisBIiY1ETQ2OwEyBTc2Mh8BFhQPARcWFA8BBiIvAQcGIi8BJjQ/AScmND8BNjIXAUEBAgkMDAn+/hUZ+goPDwr6GQJYeAcUByIHB3h4BwciBxQHeHgHFAciBwd3dwcHIgcUBwMurAYHCv0SCgcGrA4PCgFeCg+EeAcHIgcUB3h4BxQHIgcHd3cHByIHFAd4eAcUByIICAAAAAACAAAA0wNyA90AFQAvAAABJTYWFREUBiclJisBIiY1ETQ2OwEyJTMWFxYVFAcGDwEiLwEuATc2NTQnJjY/ATYBQQECCQwMCf7+FRn6Cg8PCvoZAdIECgZgWgYLAwkHHQcDBkhOBgMIHQcDLqwGBwr9EgoHBqwODwoBXgoPZAEJgaGafwkBAQYXBxMIZ36EaggUBxYFAAAAAAMAAADEBGID7AAbADEASwAAATMWFxYVFAYHBgcjIi8BLgE3NjU0JicmNj8BNgUlNhYVERQGJyUmKwEiJjURNDY7ATIlMxYXFhUUBwYPASIvAS4BNzY1NCcmNj8BNgPHAwsGh0RABwoDCQcqCAIGbzs3BgIJKgf9ggECCQwMCf7+FRn6Cg8PCvoZAdIECgZgWgYLAwkHHQcDBkhOBgMIHQcD7AEJs9lpy1QJAQYiBhQIlrJarEcJFAYhBb6sBgcK/RIKBwasDg8KAV4KD2QBCYGhmn8JAQEGFwcTCGd+hGoIFQYWBQAAAAANAAAAAASwBLAACQAVABkAHQAhACUALQA7AD8AQwBHAEsATwAAATMVIxUhFSMRIQEjFTMVIREjESM1IQURIREhESERBSM1MwUjNTMBMxEhETM1MwEzFSMVIzUjNTM1IzUhBREhEQcjNTMFIzUzASM1MwUhNSEB9GRk/nBkAfQCvMjI/tTIZAJY+7QBLAGQASz84GRkArxkZP1EyP4MyGQB9MhkyGRkyAEs/UQBLGRkZAOEZGT+DGRkAfT+1AEsA4RkZGQCWP4MZMgBLAEsyGT+1AEs/tQBLMhkZGT+DP4MAfRk/tRkZGRkyGTI/tQBLMhkZGT+1GRkZAAAAAAJAAAAAASwBLAAAwAHAAsADwATABcAGwAfACMAADcjETMTIxEzASMRMxMjETMBIxEzASE1IRcjNTMXIzUzBSM1M2RkZMhkZAGQyMjIZGQBLMjI/OD+1AEsyGRkyGRkASzIyMgD6PwYA+j8GAPo/BgD6PwYA+j7UGRkW1tbW1sAAAIAAAAKBKYEsAANABUAAAkBFhQHAQYiJwETNDYzBCYiBhQWMjYB9AKqCAj+MAgUCP1WAQ8KAUM7Uzs7UzsEsP1WCBQI/jAICAKqAdsKD807O1Q7OwAAAAADAAAACgXSBLAADQAZACEAAAkBFhQHAQYiJwETNDYzIQEWFAcBBiIvAQkBBCYiBhQWMjYB9AKqCAj+MAgUCP1WAQ8KAwYCqggI/jAIFAg4Aaj9RP7TO1M7O1M7BLD9VggUCP4wCAgCqgHbCg/9VggUCP4wCAg4AaoCvM07O1Q7OwAAAAABAGQAAASwBLAAJgAAASEyFREUDwEGJjURNCYjISIPAQYWMyEyFhURFAYjISImNRE0PwE2ASwDOUsSQAgKDwr9RBkSQAgFCgK8Cg8PCvyuCg8SixIEsEv8fBkSQAgFCgO2Cg8SQAgKDwr8SgoPDwoDzxkSixIAAAABAMj//wRMBLAACgAAEyEyFhURCQERNDb6AyAVHf4+/j4dBLAdFfuCAbz+QwR/FR0AAAAAAwAAAAAEsASwABUARQBVAAABISIGBwMGHwEeATMhMjY/ATYnAy4BASMiBg8BDgEjISImLwEuASsBIgYVERQWOwEyNj0BNDYzITIWHQEUFjsBMjY1ETQmASEiBg8BBhYzITI2LwEuAQM2/kQLEAFOBw45BhcKAcIKFwY+DgdTARABVpYKFgROBBYK/doKFgROBBYKlgoPDwqWCg8PCgLuCg8PCpYKDw/+sf4MChMCJgILCgJYCgsCJgITBLAPCv7TGBVsCQwMCWwVGAEtCg/+cA0JnAkNDQmcCQ0PCv12Cg8PCpYKDw8KlgoPDwoCigoP/agOCpgKDg4KmAoOAAAAAAQAAABkBLAETAAdACEAKQAxAAABMzIeAh8BMzIWFREUBiMhIiY1ETQ2OwE+BAEVMzUEIgYUFjI2NCQyFhQGIiY0AfTIOF00JAcGlik7Oyn8GCk7OymWAgknM10ByGT+z76Hh76H/u9WPDxWPARMKTs7FRQ7Kf2oKTs7KQJYKTsIG0U1K/7UZGRGh76Hh74IPFY8PFYAAAAAAgA1AAAEsASvACAAIwAACQEWFx4BHwEVITUyNi8BIQYHBh4CMxUhNTY3PgE/AQEDIQMCqQGBFCgSJQkK/l81LBFS/nk6IgsJKjIe/pM4HAwaBwcBj6wBVKIEr/waMioTFQECQkJXLd6RWSIuHAxCQhgcDCUNDQPu/VoByQAAAAADAGQAAAPwBLAAJwAyADsAAAEeBhUUDgMjITU+ATURNC4EJzUFMh4CFRQOAgclMzI2NTQuAisBETMyNjU0JisBAvEFEzUwOyodN1htbDD+DCk7AQYLFyEaAdc5dWM+Hy0tEP6Pi05pESpTPnbYUFJ9Xp8CgQEHGB0zOlIuQ3VONxpZBzMoAzsYFBwLEAkHRwEpSXNDM1s6KwkxYUopOzQb/K5lUFqBAAABAMgAAANvBLAAGQAAARcOAQcDBhYXFSE1NjcTNjQuBCcmJzUDbQJTQgeECSxK/gy6Dq0DAw8MHxUXDQYEsDkTNSj8uTEoBmFhEFIDQBEaExAJCwYHAwI5AAAAAAL/tQAABRQEsAAlAC8AAAEjNC4FKwERFBYfARUhNTI+AzURIyIOBRUjESEFIxEzByczESM3BRQyCAsZEyYYGcgyGRn+cAQOIhoWyBkYJhMZCwgyA+j7m0tLfX1LS30DhBUgFQ4IAwH8rhYZAQJkZAEFCRUOA1IBAwgOFSAVASzI/OCnpwMgpwACACH/tQSPBLAAJQAvAAABIzQuBSsBERQWHwEVITUyPgM1ESMiDgUVIxEhEwc1IRUnNxUhNQRMMggLGRMmGBnIMhkZ/nAEDiIaFsgZGCYTGQsIMgPoQ6f84KenAyADhBUgFQ4IAwH9dhYZAQJkZAEFCRUOAooBAwgOFSAVASz7gn1LS319S0sABAAAAAAEsARMAA8AHwAvAD8AABMhMhYdARQGIyEiJj0BNDYTITIWHQEUBiMhIiY9ATQ2EyEyFh0BFAYjISImPQE0NhMhMhYdARQGIyEiJj0BNDYyAlgVHR0V/agVHR0VA+gVHR0V/BgVHR0VAyAVHR0V/OAVHR0VBEwVHR0V+7QVHR0ETB0VZBUdHRVkFR3+1B0VZBUdHRVkFR3+1B0VZBUdHRVkFR3+1B0VZBUdHRVkFR0ABAAAAAAEsARMAA8AHwAvAD8AABMhMhYdARQGIyEiJj0BNDYDITIWHQEUBiMhIiY9ATQ2EyEyFh0BFAYjISImPQE0NgMhMhYdARQGIyEiJj0BNDb6ArwVHR0V/UQVHR2zBEwVHR0V+7QVHR3dArwVHR0V/UQVHR2zBEwVHR0V+7QVHR0ETB0VZBUdHRVkFR3+1B0VZBUdHRVkFR3+1B0VZBUdHRVkFR3+1B0VZBUdHRVkFR0ABAAAAAAEsARMAA8AHwAvAD8AAAE1NDYzITIWHQEUBiMhIiYBNTQ2MyEyFh0BFAYjISImEzU0NjMhMhYdARQGIyEiJgE1NDYzITIWHQEUBiMhIiYB9B0VAlgVHR0V/agVHf5wHRUD6BUdHRX8GBUdyB0VAyAVHR0V/OAVHf7UHRUETBUdHRX7tBUdA7ZkFR0dFWQVHR3+6WQVHR0VZBUdHf7pZBUdHRVkFR0d/ulkFR0dFWQVHR0AAAQAAAAABLAETAAPAB8ALwA/AAATITIWHQEUBiMhIiY9ATQ2EyEyFh0BFAYjISImPQE0NhMhMhYdARQGIyEiJj0BNDYTITIWHQEUBiMhIiY9ATQ2MgRMFR0dFfu0FR0dFQRMFR0dFfu0FR0dFQRMFR0dFfu0FR0dFQRMFR0dFfu0FR0dBEwdFWQVHR0VZBUd/tQdFWQVHR0VZBUd/tQdFWQVHR0VZBUd/tQdFWQVHR0VZBUdAAgAAAAABLAETAAPAB8ALwA/AE8AXwBvAH8AABMzMhYdARQGKwEiJj0BNDYpATIWHQEUBiMhIiY9ATQ2ATMyFh0BFAYrASImPQE0NikBMhYdARQGIyEiJj0BNDYBMzIWHQEUBisBIiY9ATQ2KQEyFh0BFAYjISImPQE0NgEzMhYdARQGKwEiJj0BNDYpATIWHQEUBiMhIiY9ATQ2MmQVHR0VZBUdHQFBAyAVHR0V/OAVHR3+6WQVHR0VZBUdHQFBAyAVHR0V/OAVHR3+6WQVHR0VZBUdHQFBAyAVHR0V/OAVHR3+6WQVHR0VZBUdHQFBAyAVHR0V/OAVHR0ETB0VZBUdHRVkFR0dFWQVHR0VZBUd/tQdFWQVHR0VZBUdHRVkFR0dFWQVHf7UHRVkFR0dFWQVHR0VZBUdHRVkFR3+1B0VZBUdHRVkFR0dFWQVHR0VZBUdAAAG/5wAAASwBEwAAwATACMAKgA6AEoAACEjETsCMhYdARQGKwEiJj0BNDYTITIWHQEUBiMhIiY9ATQ2BQc1IzUzNQUhMhYdARQGIyEiJj0BNDYTITIWHQEUBiMhIiY9ATQ2AZBkZJZkFR0dFWQVHR0VAfQVHR0V/gwVHR3++qfIyAHCASwVHR0V/tQVHR0VAlgVHR0V/agVHR0ETB0VZBUdHRVkFR3+1B0VZBUdHRVkFR36fUtkS68dFWQVHR0VZBUd/tQdFWQVHR0VZBUdAAAABgAAAAAFFARMAA8AEwAjACoAOgBKAAATMzIWHQEUBisBIiY9ATQ2ASMRMwEhMhYdARQGIyEiJj0BNDYFMxUjFSc3BSEyFh0BFAYjISImPQE0NhMhMhYdARQGIyEiJj0BNDYyZBUdHRVkFR0dA2dkZPyuAfQVHR0V/gwVHR0EL8jIp6f75gEsFR0dFf7UFR0dFQJYFR0dFf2oFR0dBEwdFWQVHR0VZBUd+7QETP7UHRVkFR0dFWQVHchkS319rx0VZBUdHRVkFR3+1B0VZBUdHRVkFR0AAAAAAgAAAMgEsAPoAA8AEgAAEyEyFhURFAYjISImNRE0NgkCSwLuHywsH/0SHywsBIT+1AEsA+gsH/12HywsHwKKHyz9RAEsASwAAwAAAAAEsARMAA8AFwAfAAATITIWFREUBiMhIiY1ETQ2FxE3BScBExEEMhYUBiImNCwEWBIaGhL7qBIaGkr3ASpKASXs/NJwTk5wTgRMGhL8DBIaGhID9BIaZP0ftoOcAT7+4AH0dE5vT09vAAAAAAIA2wAFBDYEkQAWAB4AAAEyHgEVFAcOAQ8BLgQnJjU0PgIWIgYUFjI2NAKIdcZzRkWyNjYJIV5YbSk8RHOft7eCgreCBJF4ynVzj23pPz4IIWZomEiEdVijeUjDgriBgbgAAAACABcAFwSZBJkADwAXAAAAMh4CFA4CIi4CND4BAREiDgEUHgEB4+rWm1tbm9bq1ptbW5sBS3TFcnLFBJlbm9bq1ptbW5vW6tab/G8DVnLF6MVyAAACAHUAAwPfBQ8AGgA1AAABHgYVFA4DBy4DNTQ+BQMOAhceBBcWNj8BNiYnLgInJjc2IyYCKhVJT1dOPiUzVnB9P1SbfEokP0xXUEm8FykoAwEbITEcExUWAgYCCQkFEikMGiACCAgFD0iPdXdzdYdFR4BeRiYEBTpjl1lFh3ZzeHaQ/f4hS4I6JUEnIw4IBwwQIgoYBwQQQSlZtgsBAAAAAwAAAAAEywRsAAwAKgAvAAABNz4CHgEXHgEPAiUhMhcHISIGFREUFjMhMjY9ATcRFAYjISImNRE0NgkBBzcBA+hsAgYUFR0OFgoFBmz9BQGQMje7/pApOzspAfQpO8i7o/5wpbm5Azj+lqE3AWMD9XMBAgIEDw4WKgsKc8gNuzsp/gwpOzsptsj+tKW5uaUBkKW5/tf+ljKqAWMAAgAAAAAEkwRMABsANgAAASEGByMiBhURFBYzITI2NTcVFAYjISImNRE0NgUBFhQHAQYmJzUmDgMHPgY3NT4BAV4BaaQ0wyk7OykB9Ck7yLml/nClubkCfwFTCAj+rAcLARo5ZFRYGgouOUlARioTAQsETJI2Oyn+DCk7OymZZ6W5uaUBkKW5G/7TBxUH/s4GBAnLAQINFjAhO2JBNB0UBwHSCgUAAAAAAgAAAAAEnQRMAB0ANQAAASEyFwchIgYVERQWMyEyNj0BNxUUBiMhIiY1ETQ2CQE2Mh8BFhQHAQYiLwEmND8BNjIfARYyAV4BXjxDsv6jKTs7KQH0KTvIuaX+cKW5uQHKAYsHFQdlBwf97QcVB/gHB2UHFQdvCBQETBexOyn+DCk7OylFyNulubmlAZCluf4zAYsHB2UHFQf97AcH+AcVB2UHB28HAAAAAQAKAAoEpgSmADsAAAkBNjIXARYGKwEVMzU0NhcBFhQHAQYmPQEjFTMyFgcBBiInASY2OwE1IxUUBicBJjQ3ATYWHQEzNSMiJgE+AQgIFAgBBAcFCqrICggBCAgI/vgICsiqCgUH/vwIFAj++AgFCq/ICgj++AgIAQgICsivCgUDlgEICAj++AgKyK0KBAf+/AcVB/73BwQKrcgKCP74CAgBCAgKyK0KBAcBCQcVBwEEBwQKrcgKAAEAyAAAA4QETAAZAAATMzIWFREBNhYVERQGJwERFAYrASImNRE0NvpkFR0B0A8VFQ/+MB0VZBUdHQRMHRX+SgHFDggV/BgVCA4Bxf5KFR0dFQPoFR0AAAABAAAAAASwBEwAIwAAEzMyFhURATYWFREBNhYVERQGJwERFAYnAREUBisBIiY1ETQ2MmQVHQHQDxUB0A8VFQ/+MBUP/jAdFWQVHR0ETB0V/koBxQ4IFf5KAcUOCBX8GBUIDgHF/koVCA4Bxf5KFR0dFQPoFR0AAAABAJ0AGQSwBDMAFQAAAREUBicBERQGJwEmNDcBNhYVEQE2FgSwFQ/+MBUP/hQPDwHsDxUB0A8VBBr8GBUIDgHF/koVCA4B4A4qDgHgDggV/koBxQ4IAAAAAQDIABYEMwQ2AAsAABMBFhQHAQYmNRE0NvMDLhIS/NISGRkEMv4OCx4L/g4LDhUD6BUOAAIAyABkA4QD6AAPAB8AABMzMhYVERQGKwEiJjURNDYhMzIWFREUBisBIiY1ETQ2+sgVHR0VyBUdHQGlyBUdHRXIFR0dA+gdFfzgFR0dFQMgFR0dFfzgFR0dFQMgFR0AAAEAyABkBEwD6AAPAAABERQGIyEiJjURNDYzITIWBEwdFfzgFR0dFQMgFR0DtvzgFR0dFQMgFR0dAAAAAAEAAAAZBBMEMwAVAAABETQ2FwEWFAcBBiY1EQEGJjURNDYXAfQVDwHsDw/+FA8V/jAPFRUPAmQBthUIDv4gDioO/iAOCBUBtv47DggVA+gVCA4AAAH//gACBLMETwAjAAABNzIWFRMUBiMHIiY1AwEGJjUDAQYmNQM0NhcBAzQ2FwEDNDYEGGQUHgUdFWQVHQL+MQ4VAv4yDxUFFQ8B0gIVDwHSAh0ETgEdFfwYFR0BHRUBtf46DwkVAbX+OQ4JFAPoFQkP/j4BthQJDv49AbYVHQAAAQEsAAAD6ARMABkAAAEzMhYVERQGKwEiJjURAQYmNRE0NhcBETQ2A1JkFR0dFWQVHf4wDxUVDwHQHQRMHRX8GBUdHRUBtv47DggVA+gVCA7+OwG2FR0AAAIAZADIBLAESAALABsAAAkBFgYjISImNwE2MgEhMhYdARQGIyEiJj0BNDYCrgH1DwkW++4WCQ8B9Q8q/fcD6BUdHRX8GBUdHQQ5/eQPFhYPAhwP/UgdFWQVHR0VZBUdAAEAiP/8A3UESgAFAAAJAgcJAQN1/qABYMX92AIoA4T+n/6fxgIoAiYAAAAAAQE7//wEKARKAAUAAAkBJwkBNwQo/dnGAWH+n8YCI/3ZxgFhAWHGAAIAFwAXBJkEmQAPADMAAAAyHgIUDgIiLgI0PgEFIyIGHQEjIgYdARQWOwEVFBY7ATI2PQEzMjY9ATQmKwE1NCYB4+rWm1tbm9bq1ptbW5sBfWQVHZYVHR0Vlh0VZBUdlhUdHRWWHQSZW5vW6tabW1ub1urWm7odFZYdFWQVHZYVHR0Vlh0VZBUdlhUdAAAAAAIAFwAXBJkEmQAPAB8AAAAyHgIUDgIiLgI0PgEBISIGHQEUFjMhMjY9ATQmAePq1ptbW5vW6tabW1ubAkX+DBUdHRUB9BUdHQSZW5vW6tabW1ub1urWm/5+HRVkFR0dFWQVHQACABcAFwSZBJkADwAzAAAAMh4CFA4CIi4CND4BBCIPAScmIg8BBhQfAQcGFB8BFjI/ARcWMj8BNjQvATc2NC8BAePq1ptbW5vW6tabW1ubAeUZCXh4CRkJjQkJeHgJCY0JGQl4eAkZCY0JCXh4CQmNBJlbm9bq1ptbW5vW6tabrQl4eAkJjQkZCXh4CRkJjQkJeHgJCY0JGQl4eAkZCY0AAgAXABcEmQSZAA8AJAAAADIeAhQOAiIuAjQ+AQEnJiIPAQYUHwEWMjcBNjQvASYiBwHj6tabW1ub1urWm1tbmwEVVAcVCIsHB/IHFQcBdwcHiwcVBwSZW5vW6tabW1ub1urWm/4xVQcHiwgUCPEICAF3BxUIiwcHAAAAAAMAFwAXBJkEmQAPADsASwAAADIeAhQOAiIuAjQ+AQUiDgMVFDsBFjc+ATMyFhUUBgciDgUHBhY7ATI+AzU0LgMTIyIGHQEUFjsBMjY9ATQmAePq1ptbW5vW6tabW1ubAT8dPEIyIRSDHgUGHR8UFw4TARkOGhITDAIBDQ6tBx4oIxgiM0Q8OpYKDw8KlgoPDwSZW5vW6tabW1ub1urWm5ELHi9PMhkFEBQQFRIXFgcIBw4UHCoZCBEQKDhcNi9IKhsJ/eMPCpYKDw8KlgoPAAADABcAFwSZBJkADwAfAD4AAAAyHgIUDgIiLgI0PgEFIyIGHQEUFjsBMjY9ATQmAyMiBh0BFBY7ARUjIgYdARQWMyEyNj0BNCYrARE0JgHj6tabW1ub1urWm1tbmwGWlgoPDwqWCg8PCvoKDw8KS0sKDw8KAV4KDw8KSw8EmVub1urWm1tbm9bq1ptWDwqWCg8PCpYKD/7UDwoyCg/IDwoyCg8PCjIKDwETCg8AAgAAAAAEsASwAC8AXwAAATMyFh0BHgEXMzIWHQEUBisBDgEHFRQGKwEiJj0BLgEnIyImPQE0NjsBPgE3NTQ2ExUUBisBIiY9AQ4BBzMyFh0BFAYrAR4BFzU0NjsBMhYdAT4BNyMiJj0BNDY7AS4BAg2WCg9nlxvCCg8PCsIbl2cPCpYKD2eXG8IKDw8KwhuXZw+5DwqWCg9EZheoCg8PCqgXZkQPCpYKD0RmF6gKDw8KqBdmBLAPCsIbl2cPCpYKD2eXG8IKDw8KwhuXZw8KlgoPZ5cbwgoP/s2oCg8PCqgXZkQPCpYKD0RmF6gKDw8KqBdmRA8KlgoPRGYAAwAXABcEmQSZAA8AGwA/AAAAMh4CFA4CIi4CND4BBCIOARQeATI+ATQmBxcWFA8BFxYUDwEGIi8BBwYiLwEmND8BJyY0PwE2Mh8BNzYyAePq1ptbW5vW6tabW1ubAb/oxXJyxejFcnKaQAcHfHwHB0AHFQd8fAcVB0AHB3x8BwdABxUHfHwHFQSZW5vW6tabW1ub1urWmztyxejFcnLF6MVaQAcVB3x8BxUHQAcHfHwHB0AHFQd8fAcVB0AHB3x8BwAAAAMAFwAXBJkEmQAPABsAMAAAADIeAhQOAiIuAjQ+AQQiDgEUHgEyPgE0JgcXFhQHAQYiLwEmND8BNjIfATc2MgHj6tabW1ub1urWm1tbmwG/6MVycsXoxXJyg2oHB/7ACBQIyggIagcVB0/FBxUEmVub1urWm1tbm9bq1ps7csXoxXJyxejFfWoHFQf+vwcHywcVB2oICE/FBwAAAAMAFwAXBJkEmQAPABgAIQAAADIeAhQOAiIuAjQ+AQUiDgEVFBcBJhcBFjMyPgE1NAHj6tabW1ub1urWm1tbmwFLdMVyQQJLafX9uGhzdMVyBJlbm9bq1ptbW5vW6tabO3LFdHhpAktB0P24PnLFdHMAAAAAAQAXAFMEsAP5ABUAABMBNhYVESEyFh0BFAYjIREUBicBJjQnAgoQFwImFR0dFf3aFxD99hACRgGrDQoV/t0dFcgVHf7dFQoNAasNJgAAAAABAAAAUwSZA/kAFQAACQEWFAcBBiY1ESEiJj0BNDYzIRE0NgJ/AgoQEP32EBf92hUdHRUCJhcD8f5VDSYN/lUNChUBIx0VyBUdASMVCgAAAAEAtwAABF0EmQAVAAAJARYGIyERFAYrASImNREhIiY3ATYyAqoBqw0KFf7dHRXIFR3+3RUKDQGrDSYEif32EBf92hUdHRUCJhcQAgoQAAAAAQC3ABcEXQSwABUAAAEzMhYVESEyFgcBBiInASY2MyERNDYCJsgVHQEjFQoN/lUNJg3+VQ0KFQEjHQSwHRX92hcQ/fYQEAIKEBcCJhUdAAABAAAAtwSZBF0AFwAACQEWFAcBBiY1EQ4DBz4ENxE0NgJ/AgoQEP32EBdesKWBJAUsW4fHfhcEVf5VDSYN/lUNChUBIwIkRHVNabGdcUYHAQYVCgACAAAAAASwBLAAFQArAAABITIWFREUBi8BBwYiLwEmND8BJyY2ASEiJjURNDYfATc2Mh8BFhQPARcWBgNSASwVHRUOXvkIFAhqBwf5Xg4I/iH+1BUdFQ5e+QgUCGoHB/leDggEsB0V/tQVCA5e+QcHaggUCPleDhX7UB0VASwVCA5e+QcHaggUCPleDhUAAAACAEkASQRnBGcAFQArAAABFxYUDwEXFgYjISImNRE0Nh8BNzYyASEyFhURFAYvAQcGIi8BJjQ/AScmNgP2agcH+V4OCBX+1BUdFQ5e+QgU/QwBLBUdFQ5e+QgUCGoHB/leDggEYGoIFAj5Xg4VHRUBLBUIDl75B/3xHRX+1BUIDl75BwdqCBQI+V4OFQAAAAADABcAFwSZBJkADwAfAC8AAAAyHgIUDgIiLgI0PgEFIyIGFxMeATsBMjY3EzYmAyMiBh0BFBY7ATI2PQE0JgHj6tabW1ub1urWm1tbmwGz0BQYBDoEIxQ2FCMEOgQYMZYKDw8KlgoPDwSZW5vW6tabW1ub1urWm7odFP7SFB0dFAEuFB3+DA8KlgoPDwqWCg8AAAAABQAAAAAEsASwAEkAVQBhAGgAbwAAATIWHwEWHwEWFxY3Nj8BNjc2MzIWHwEWHwIeATsBMhYdARQGKwEiBh0BIREjESE1NCYrASImPQE0NjsBMjY1ND8BNjc+BAUHBhY7ATI2LwEuAQUnJgYPAQYWOwEyNhMhIiY1ESkBERQGIyERAQQJFAUFFhbEFQ8dCAsmxBYXERUXMA0NDgQZCAEPCj0KDw8KMgoP/nDI/nAPCjIKDw8KPQsOCRkFDgIGFRYfAp2mBwQK2woKAzMDEP41sQgQAzMDCgrnCwMe/okKDwGQAlgPCv6JBLAEAgIKDXYNCxUJDRZ2DQoHIREQFRh7LAkLDwoyCg8PCq8BLP7UrwoPDwoyCg8GBQQwgBkUAwgWEQ55ogcKDgqVCgSqnQcECo8KDgr8cg8KAXf+iQoPAZAAAAAAAgAAAAwErwSmACsASQAAATYWFQYCDgQuAScmByYOAQ8BBiY1NDc+ATc+AScuAT4BNz4GFyYGBw4BDwEOBAcOARY2Nz4CNz4DNz4BBI0IGgItQmxhi2KORDg9EQQRMxuZGhYqCFUYEyADCQIQOjEnUmFch3vAJQgdHyaiPT44XHRZUhcYDhItIRmKcVtGYWtbKRYEBKYDEwiy/t3IlVgxEQgLCwwBAQIbG5kYEyJAJghKFRE8Hzdff4U/M0o1JSMbL0QJGCYvcSEhHjZST2c1ODwEJygeW0AxJUBff1UyFAABAF0AHgRyBM8ATwAAAQ4BHgQXLgc+ATceAwYHDgQHBicmNzY3PgQuAScWDgMmJy4BJyY+BDcGHgM3PgEuAicmPgMCjScfCic4R0IgBBsKGAoQAwEJEg5gikggBhANPkpTPhZINx8SBgsNJysiCRZOQQoVNU1bYC9QZwICBAUWITsoCAYdJzIYHw8YIiYHDyJJYlkEz0OAZVxEOSQMBzgXOB42IzElKRIqg5Gnl0o3Z0c6IAYWCwYNAwQFIDhHXGF1OWiqb0sdBxUknF0XNTQ8PEUiNWNROBYJDS5AQVUhVZloUSkAAAAAA//cAGoE1ARGABsAPwBRAAAAMh4FFA4FIi4FND4EBSYGFxYVFAYiJjU0NzYmBwYHDgEXHgQyPgM3NiYnJgUHDgEXFhcWNj8BNiYnJicuAQIGpJ17bk85HBw6T257naKde25POhwcOU9uewIPDwYIGbD4sBcIBw5GWg0ECxYyWl+DiINfWjIWCwQMWv3/Iw8JCSU4EC0OIw4DDywtCyIERi1JXGJcSSpJXGJcSS0tSVxiXEkqSVxiXEncDwYTOT58sLB8OzcTBg9FcxAxEiRGXkQxMEVeRSQSMRF1HiQPLxJEMA0EDyIPJQ8sSRIEAAAABP/cAAAE1ASwABQAJwA7AEwAACEjNy4ENTQ+BTMyFzczEzceARUUDgMHNz4BNzYmJyYlBgcOARceBBc3LgE1NDc2JhcHDgEXFhcWNj8CJyYnLgECUJQfW6l2WSwcOU9ue51SPUEglCYvbIknUGqYUi5NdiYLBAw2/VFGWg0ECxIqSExoNSlrjxcIB3wjDwkJJTgQLQ4MFgMsLQsieBRhdHpiGxVJXGJcSS0Pef5StVXWNBpacm5jGq0xiD8SMRFGckVzEDESHjxRQTkNmhKnbjs3EwZwJA8vEkQwDQQPC1YELEkSBAAAAAP/ngAABRIEqwALABgAKAAAJwE2FhcBFgYjISImJSE1NDY7ATIWHQEhAQczMhYPAQ4BKwEiJi8BJjZaAoIUOBQCghUbJfryJRsBCgFZDwqWCg8BWf5DaNAUGAQ6BCMUNhQjBDoEGGQEKh8FIfvgIEdEhEsKDw8KSwLT3x0U/BQdHRT8FB0AAAABAGQAFQSwBLAAKAAAADIWFREBHgEdARQGJyURFh0BFAYvAQcGJj0BNDcRBQYmPQE0NjcBETQCTHxYAWsPFhgR/plkGhPNzRMaZP6ZERgWDwFrBLBYPv6t/rsOMRQpFA0M+f75XRRAFRAJgIAJEBVAFF0BB/kMDRQpFDEOAUUBUz4AAAARAAAAAARMBLAAHQAnACsALwAzADcAOwA/AEMARwBLAE8AUwBXAFsAXwBjAAABMzIWHQEzMhYdASE1NDY7ATU0NjsBMhYdASE1NDYBERQGIyEiJjURFxUzNTMVMzUzFTM1MxUzNTMVMzUFFTM1MxUzNTMVMzUzFTM1MxUzNQUVMzUzFTM1MxUzNTMVMzUzFTM1A1JkFR0yFR37tB0VMh0VZBUdAfQdAQ8dFfwYFR1kZGRkZGRkZGRk/HxkZGRkZGRkZGT8fGRkZGRkZGRkZASwHRUyHRWWlhUdMhUdHRUyMhUd/nD9EhUdHRUC7shkZGRkZGRkZGRkyGRkZGRkZGRkZGTIZGRkZGRkZGRkZAAAAAMAAAAZBXcElwAZACUANwAAARcWFA8BBiY9ASMBISImPQE0NjsBATM1NDYBBycjIiY9ATQ2MyEBFxYUDwEGJj0BIyc3FzM1NDYEb/kPD/kOFZ/9qP7dFR0dFdECWPEV/amNetEVHR0VASMDGvkPD/kOFfG1jXqfFQSN5g4qDuYOCBWW/agdFWQVHQJYlhUI/piNeh0VZBUd/k3mDioO5g4IFZa1jXqWFQgAAAABAAAAAASwBEwAEgAAEyEyFhURFAYjIQERIyImNRE0NmQD6Ck7Oyn9rP7QZCk7OwRMOyn9qCk7/tQBLDspAlgpOwAAAAMAZAAABEwEsAAJABMAPwAAEzMyFh0BITU0NiEzMhYdASE1NDYBERQOBSIuBTURIRUUFRwBHgYyPgYmNTQ9AZbIFR3+1B0C0cgVHf7UHQEPBhgoTGacwJxmTCgYBgEsAwcNFB8nNkI2Jx8TDwUFAQSwHRX6+hUdHRX6+hUd/nD+1ClJalZcPigoPlxWakkpASz6CRIVKyclIRsWEAgJEBccISUnKhURCPoAAAAB//8A1ARMA8IABQAAAQcJAScBBEzG/p/+n8UCJwGbxwFh/p/HAicAAQAAAO4ETQPcAAUAAAkCNwkBBE392v3ZxgFhAWEDFf3ZAifH/p8BYQAAAAAC/1EAZAVfA+gAFAApAAABITIWFREzMhYPAQYiLwEmNjsBESElFxYGKwERIRchIiY1ESMiJj8BNjIBlALqFR2WFQgO5g4qDuYOCBWW/oP+HOYOCBWWAYHX/RIVHZYVCA7mDioD6B0V/dkVDvkPD/kOFQGRuPkOFf5wyB0VAiYVDvkPAAABAAYAAASeBLAAMAAAEzMyFh8BITIWBwMOASMhFyEyFhQGKwEVFAYiJj0BIRUUBiImPQEjIiYvAQMjIiY0NjheERwEJgOAGB4FZAUsIf2HMAIXFR0dFTIdKh3+1B0qHR8SHQYFyTYUHh4EsBYQoiUY/iUVK8gdKh0yFR0dFTIyFR0dFTIUCQoDwR0qHQAAAAACAAAAAASwBEwACwAPAAABFSE1MzQ2MyEyFhUFIREhBLD7UMg7KQEsKTv9RASw+1AD6GRkKTs7Kcj84AACAAAAAAXcBEwADAAQAAATAxEzNDYzITIWFSEVBQEhAcjIyDspASwqOgH0ASz+1PtQASwDIP5wAlgpOzspyGT9RAK8AAEBRQAAA2sErwAbAAABFxYGKwERMzIWDwEGIi8BJjY7AREjIiY/ATYyAnvmDggVlpYVCA7mDioO5g4IFZaWFQgO5g4qBKD5DhX9pxUO+Q8P+Q4VAlkVDvkPAAAAAQABAUQErwNrABsAAAEXFhQPAQYmPQEhFRQGLwEmND8BNhYdASE1NDYDqPkODvkPFf2oFQ/5Dg75DxUCWBUDYOUPKQ/lDwkUl5cUCQ/lDykP5Q8JFZWVFQkAAAAEAAAAAASwBLAACQAZAB0AIQAAAQMuASMhIgYHAwUhIgYdARQWMyEyNj0BNCYFNTMVMzUzFQSRrAUkFP1gFCQFrAQt/BgpOzspA+gpOzv+q2RkZAGQAtwXLSgV/R1kOylkKTs7KWQpO8hkZGRkAAAAA/+cAGQEsARMAAsAIwAxAAAAMhYVERQGIiY1ETQDJSMTFgYjIisBIiYnAj0BNDU0PgE7ASUBFSIuAz0BND4CNwRpKh0dKh1k/V0mLwMRFQUCVBQdBDcCCwzIAqP8GAQOIhoWFR0dCwRMHRX8rhUdHRUDUhX8mcj+7BAIHBUBUQ76AgQQDw36/tT6AQsTKRwyGigUDAEAAAACAEoAAARmBLAALAA1AAABMzIWDwEeARcTFzMyFhQGBw4EIyIuBC8BLgE0NjsBNxM+ATcnJjYDFjMyNw4BIiYCKV4UEgYSU3oPP3YRExwaEggeZGqfTzl0XFU+LwwLEhocExF2Pw96UxIGEyQyNDUxDDdGOASwFRMlE39N/rmtHSkoBwQLHBYSCg4REg4FBAgoKR2tAUdNfhQgExr7vgYGMT09AAEAFAAUBJwEnAAXAAABNwcXBxcHFycHJwcnBzcnNyc3Jxc3FzcDIOBO6rS06k7gLZubLeBO6rS06k7gLZubA7JO4C2bmy3gTuq0tOpO4C2bmy3gTuq0tAADAAAAZASwBLAAIQAtAD0AAAEzMhYdAQchMhYdARQHAw4BKwEiJi8BIyImNRE0PwI+ARcPAREzFzMTNSE3NQEzMhYVERQGKwEiJjURNDYCijIoPBwBSCg8He4QLBf6B0YfHz0tNxSRYA0xG2SWZIjW+v4+Mv12ZBUdHRVkFR0dBLBRLJZ9USxkLR3+qBghMhkZJCcBkCQbxMYcKGTU1f6JZAF3feGv/tQdFf4MFR0dFQH0FR0AAAAAAwAAAAAEsARMACAAMAA8AAABMzIWFxMWHQEUBiMhFh0BFAYrASImLwImNRE0NjsBNgUzMhYVERQGKwEiJjURNDYhByMRHwEzNSchNQMCWPoXLBDuHTwo/rgcPCgyGzENYJEUNy09fP3pZBUdHRVkFR0dAl+IZJZkMjIBwvoETCEY/qgdLWQsUXYHlixRKBzGxBskAZAnJGRkHRX+DBUdHRUB9BUdZP6J1dSv4X0BdwADAAAAZAUOBE8AGwA3AEcAAAElNh8BHgEPASEyFhQGKwEDDgEjISImNRE0NjcXERchEz4BOwEyNiYjISoDLgQnJj8BJwUzMhYVERQGKwEiJjURNDYBZAFrHxZuDQEMVAEuVGxuVGqDBhsP/qoHphwOOmQBJYMGGw/LFRMSFv44AgoCCQMHAwUDAQwRklb9T2QVHR0VZBUdHQNp5hAWcA0mD3lMkE7+rRUoog0CDRElCkj+CVkBUxUoMjIBAgIDBQIZFrdT5B0V/gwVHR0VAfQVHQAAAAP/nABkBLAETwAdADYARgAAAQUeBBURFAYjISImJwMjIiY0NjMhJyY2PwE2BxcWBw4FKgIjIRUzMhYXEyE3ESUFMzIWFREUBisBIiY1ETQ2AdsBbgIIFBANrAf+qg8bBoNqVW1sVAEuVQsBDW4WSpIRDAIDBQMHAwkDCgH+Jd0PHAaCASZq/qoCUGQVHR0VZBUdHQRP5gEFEBEXC/3zDaIoFQFTTpBMeQ8mDXAWrrcWGQIFAwICAWQoFf6tWQH37OQdFf4MFR0dFQH0FR0AAAADAGEAAARMBQ4AGwA3AEcAAAAyFh0BBR4BFREUBiMhIiYvAQMmPwE+AR8BETQXNTQmBhURHAMOBAcGLwEHEyE3ESUuAQMhMhYdARQGIyEiJj0BNDYB3pBOAVMVKKIN/fMRJQoJ5hAWcA0mD3nGMjIBAgIDBQIZFrdT7AH3Wf6tFSiWAfQVHR0V/gwVHR0FDm5UaoMGGw/+qgemHA4OAWsfFm4NAQxUAS5U1ssVExIW/jgCCgIJAwcDBQMBDBGSVv6tZAElgwYb/QsdFWQVHR0VZBUdAAP//QAGA+gFFAAPAC0ASQAAASEyNj0BNCYjISIGHQEUFgEVFAYiJjURBwYmLwEmNxM+BDMhMhYVERQGBwEDFzc2Fx4FHAIVERQWNj0BNDY3JREnAV4B9BUdHRX+DBUdHQEPTpBMeQ8mDXAWEOYBBRARFwsCDQ2iKBX9iexTtxYZAgUDAgIBMjIoFQFTWQRMHRVkFR0dFWQVHfzmalRubFQBLlQMAQ1uFh8BawIIEw8Mpgf+qg8bBgHP/q1WkhEMAQMFAwcDCQIKAv44FhITFcsPGwaDASVkAAIAFgAWBJoEmgAPACUAAAAyHgIUDgIiLgI0PgEBJSYGHQEhIgYdARQWMyEVFBY3JTY0AeLs1ptbW5vW7NabW1ubAob+7RAX/u0KDw8KARMXEAETEASaW5vW7NabW1ub1uzWm/453w0KFYkPCpYKD4kVCg3fDSYAAAIAFgAWBJoEmgAPACUAAAAyHgIUDgIiLgI0PgENAQYUFwUWNj0BITI2PQE0JiMhNTQmAeLs1ptbW5vW7NabW1ubASX+7RAQARMQFwETCg8PCv7tFwSaW5vW7NabW1ub1uzWm+jfDSYN3w0KFYkPCpYKD4kVCgAAAAIAFgAWBJoEmgAPACUAAAAyHgIUDgIiLgI0PgEBAyYiBwMGFjsBERQWOwEyNjURMzI2AeLs1ptbW5vW7NabW1ubAkvfDSYN3w0KFYkPCpYKD4kVCgSaW5vW7NabW1ub1uzWm/5AARMQEP7tEBf+7QoPDwoBExcAAAIAFgAWBJoEmgAPACUAAAAyHgIUDgIiLgI0PgEFIyIGFREjIgYXExYyNxM2JisBETQmAeLs1ptbW5vW7NabW1ubAZeWCg+JFQoN3w0mDd8NChWJDwSaW5vW7NabW1ub1uzWm7sPCv7tFxD+7RAQARMQFwETCg8AAAMAGAAYBJgEmAAPAJYApgAAADIeAhQOAiIuAjQ+ASUOAwcGJgcOAQcGFgcOAQcGFgcUFgcyHgEXHgIXHgI3Fg4BFx4CFxQGFBcWNz4CNy4BJy4BJyIOAgcGJyY2NS4BJzYuAQYHBicmNzY3HgIXHgMfAT4CJyY+ATc+AzcmNzIWMjY3LgMnND4CJiceAT8BNi4CJwYHFB4BFS4CJz4BNxYyPgEB5OjVm1xcm9Xo1ZtcXJsBZA8rHDoKDz0PFD8DAxMBAzEFCRwGIgEMFhkHECIvCxU/OR0HFBkDDRQjEwcFaHUeISQDDTAMD0UREi4oLBAzDwQBBikEAQMLGhIXExMLBhAGKBsGBxYVEwYFAgsFAwMNFwQGCQcYFgYQCCARFwkKKiFBCwQCAQMDHzcLDAUdLDgNEiEQEgg/KhADGgMKEgoRBJhcm9Xo1ZtcXJvV6NWbEQwRBwkCAwYFBycPCxcHInIWInYcCUcYChQECA4QBAkuHgQPJioRFRscBAcSCgwCch0kPiAIAQcHEAsBAgsLIxcBMQENCQIPHxkCFBkdHB4QBgEBBwoMGBENBAMMJSAQEhYXDQ4qFBkKEhIDCQsXJxQiBgEOCQwHAQ0DBAUcJAwSCwRnETIoAwEJCwsLJQcKDBEAAAAAAQAAAAIErwSFABYAAAE2FwUXNxYGBw4BJwEGIi8BJjQ3ASY2AvSkjv79kfsGUE08hjv9rA8rD28PDwJYIk8EhVxliuh+WYcrIgsW/awQEG4PKxACV2XJAAYAAABgBLAErAAPABMAIwAnADcAOwAAEyEyFh0BFAYjISImPQE0NgUjFTMFITIWHQEUBiMhIiY9ATQ2BSEVIQUhMhYdARQGIyEiJj0BNDYFIRUhZAPoKTs7KfwYKTs7BBHIyPwYA+gpOzsp/BgpOzsEEf4MAfT8GAPoKTs7KfwYKTs7BBH+1AEsBKw7KWQpOzspZCk7ZGTIOylkKTs7KWQpO2RkyDspZCk7OylkKTtkZAAAAAIAZAAABEwEsAALABEAABMhMhYUBiMhIiY0NgERBxEBIZYDhBUdHRX8fBUdHQI7yP6iA4QEsB0qHR0qHf1E/tTIAfQB9AAAAAMAAABkBLAEsAAXABsAJQAAATMyFh0BITIWFREhNSMVIRE0NjMhNTQ2FxUzNQEVFAYjISImPQEB9MgpOwEsKTv+DMj+DDspASw7KcgB9Dsp/BgpOwSwOylkOyn+cGRkAZApO2QpO2RkZP1EyCk7OynIAAAABAAAAAAEsASwABUAKwBBAFcAABMhMhYPARcWFA8BBiIvAQcGJjURNDYpATIWFREUBi8BBwYiLwEmND8BJyY2ARcWFA8BFxYGIyEiJjURNDYfATc2MgU3NhYVERQGIyEiJj8BJyY0PwE2MhcyASwVCA5exwcHaggUCMdeDhUdAzUBLBUdFQ5exwgUCGoHB8deDgj+L2oHB8deDggV/tQVHRUOXscIFALLXg4VHRX+1BUIDl7HBwdqCBQIBLAVDl7HCBQIagcHx14OCBUBLBUdHRX+1BUIDl7HBwdqCBQIx14OFf0maggUCMdeDhUdFQEsFQgOXscHzl4OCBX+1BUdFQ5exwgUCGoHBwAAAAYAAAAABKgEqAAPABsAIwA7AEMASwAAADIeAhQOAiIuAjQ+AQQiDgEUHgEyPgE0JiQyFhQGIiY0JDIWFAYjIicHFhUUBiImNTQ2PwImNTQEMhYUBiImNCQyFhQGIiY0Advy3Z9fX5/d8t2gXl6gAcbgv29vv+C/b2/+LS0gIC0gAUwtICAWDg83ETNIMykfegEJ/octICAtIAIdLSAgLSAEqF+f3fLdoF5eoN3y3Z9Xb7/gv29vv+C/BiAtISEtICAtIQqRFxwkMzMkIDEFfgEODhekIC0gIC0gIC0gIC0AAf/YAFoEuQS8AFsAACUBNjc2JicmIyIOAwcABw4EFx4BMzI3ATYnLgEjIgcGBwEOASY0NwA3PgEzMhceARcWBgcOBgcGIyImJyY2NwE2NzYzMhceARcWBgcBDgEnLgECIgHVWwgHdl8WGSJBMD8hIP6IDx4eLRMNBQlZN0ozAiQkEAcdEhoYDRr+qw8pHA4BRyIjQS4ODyw9DQ4YIwwod26La1YOOEBGdiIwGkQB/0coW2tQSE5nDxE4Qv4eDyoQEAOtAdZbZWKbEQQUGjIhH/6JDxsdNSg3HT5CMwIkJCcQFBcMGv6uDwEcKQ4BTSIjIQEINykvYyMLKnhuiWZMBxtAOU6+RAH/SBg3ISSGV121Qv4kDwIPDyYAAAACAGQAWASvBEQAGQBEAAABPgIeAhUUDgMHLgQ1ND4CHgEFIg4DIi4DIyIGFRQeAhcWFx4EMj4DNzY3PgQ1NCYCiTB7eHVYNkN5hKg+PqeFeEM4WnZ4eQEjIT8yLSohJyktPyJDbxtBMjMPBw86KzEhDSIzKUAMBAgrKT8dF2oDtURIBS1TdkA5eYB/slVVsn+AeTlAdlMtBUgtJjY1JiY1NiZvTRc4SjQxDwcOPCouGBgwKEALBAkpKkQqMhNPbQACADn/8gR3BL4AFwAuAAAAMh8BFhUUBg8BJi8BNycBFwcvASY0NwEDNxYfARYUBwEGIi8BJjQ/ARYfAQcXAQKru0KNQjgiHR8uEl/3/nvUaRONQkIBGxJpCgmNQkL+5UK6Qo1CQjcdLhJf9wGFBL5CjUJeKmsiHTUuEl/4/nvUahKNQrpCARv+RmkICY1CukL+5UJCjUK7Qjc3LxFf+AGFAAAAAAMAyAAAA+gEsAARABUAHQAAADIeAhURFAYjISImNRE0PgEHESERACIGFBYyNjQCBqqaZDo7Kf2oKTs8Zj4CWP7/Vj09Vj0EsB4uMhX8Ryk7OykDuRUzLar9RAK8/RY9Vj09VgABAAAAAASwBLAAFgAACQEWFAYiLwEBEScBBRMBJyEBJyY0NjIDhgEbDx0qDiT+6dT+zP7oywEz0gEsAQsjDx0qBKH+5g8qHQ8j/vX+1NL+zcsBGAE01AEXJA4qHQAAAAADAScAEQQJBOAAMgBAAEsAAAEVHgQXIy4DJxEXHgQVFAYHFSM1JicuASczHgEXEScuBDU0PgI3NRkBDgMVFB4DFxYXET4ENC4CArwmRVI8LAKfBA0dMydAIjxQNyiym2SWVygZA4sFV0obLkJOMCAyVWg6HSoqFQ4TJhkZCWgWKTEiGBkzNwTgTgUTLD9pQiQuLBsH/s0NBxMtPGQ+i6oMTU8QVyhrVk1iEAFPCA4ZLzlYNkZwSCoGTf4SARIEDh02Jh0rGRQIBgPQ/soCCRYgNEM0JRkAAAABAGQAZgOUBK0ASgAAATIeARUjNC4CIyIGBwYVFB4BFxYXMxUjFgYHBgc+ATM2FjMyNxcOAyMiLgEHDgEPASc+BTc+AScjNTMmJy4CPgE3NgIxVJlemSc8OxolVBQpGxoYBgPxxQgVFS02ImIWIIwiUzUyHzY4HCAXanQmJ1YYFzcEGAcTDBEJMAwk3aYXFQcKAg4tJGEErVCLTig/IhIdFSw5GkowKgkFZDKCHj4yCg8BIh6TExcIASIfBAMaDAuRAxAFDQsRCjePR2QvORQrREFMIVgAAAACABn//wSXBLAADwAfAAABMzIWDwEGIi8BJjY7AREzBRcWBisBESMRIyImPwE2MgGQlhUIDuYOKg7mDggVlsgCF+YOCBWWyJYVCA7mDioBLBYO+g8P+g4WA4QQ+Q4V/HwDhBUO+Q8AAAQAGf//A+gEsAAHABcAGwAlAAABIzUjFSMRIQEzMhYPAQYiLwEmNjsBETMFFTM1EwczFSE1NyM1IQPoZGRkASz9qJYVCA7mDioO5g4IFZbIAZFkY8jI/tTIyAEsArxkZAH0/HwWDvoPD/oOFgOEZMjI/RL6ZJb6ZAAAAAAEABn//wPoBLAADwAZACEAJQAAATMyFg8BBiIvASY2OwERMwUHMxUhNTcjNSERIzUjFSMRIQcVMzUBkJYVCA7mDioO5g4IFZbIAljIyP7UyMgBLGRkZAEsx2QBLBYO+g8P+g4WA4SW+mSW+mT7UGRkAfRkyMgAAAAEABn//wRMBLAADwAVABsAHwAAATMyFg8BBiIvASY2OwERMwEjESM1MxMjNSMRIQcVMzUBkJYVCA7mDioO5g4IFZbIAlhkZMhkZMgBLMdkASwWDvoPD/oOFgOE/gwBkGT7UGQBkGTIyAAAAAAEABn//wRMBLAADwAVABkAHwAAATMyFg8BBiIvASY2OwERMwEjNSMRIQcVMzUDIxEjNTMBkJYVCA7mDioO5g4IFZbIArxkyAEsx2QBZGTIASwWDvoPD/oOFgOE/gxkAZBkyMj7tAGQZAAAAAAFABn//wSwBLAADwATABcAGwAfAAABMzIWDwEGIi8BJjY7AREzBSM1MxMhNSETITUhEyE1IQGQlhUIDuYOKg7mDggVlsgB9MjIZP7UASxk/nABkGT+DAH0ASwWDvoPD/oOFgOEyMj+DMj+DMj+DMgABQAZ//8EsASwAA8AEwAXABsAHwAAATMyFg8BBiIvASY2OwERMwUhNSEDITUhAyE1IQMjNTMBkJYVCA7mDioO5g4IFZbIAyD+DAH0ZP5wAZBk/tQBLGTIyAEsFg76Dw/6DhYDhMjI/gzI/gzI/gzIAAIAAAAABEwETAAPAB8AAAEhMhYVERQGIyEiJjURNDYFISIGFREUFjMhMjY1ETQmAV4BkKK8u6P+cKW5uQJn/gwpOzspAfQpOzsETLuj/nClubmlAZClucg7Kf4MKTs7KQH0KTsAAAAAAwAAAAAETARMAA8AHwArAAABITIWFREUBiMhIiY1ETQ2BSEiBhURFBYzITI2NRE0JgUXFhQPAQYmNRE0NgFeAZClubml/nCju7wCZP4MKTs7KQH0KTs7/m/9ERH9EBgYBEy5pf5wpbm5pQGQo7vIOyn+DCk7OykB9Ck7gr4MJAy+DAsVAZAVCwAAAAADAAAAAARMBEwADwAfACsAAAEhMhYVERQGIyEiJjURNDYFISIGFREUFjMhMjY1ETQmBSEyFg8BBiIvASY2AV4BkKO7uaX+cKW5uQJn/gwpOzspAfQpOzv+FQGQFQsMvgwkDL4MCwRMvKL+cKW5uaUBkKO7yDsp/gwpOzspAfQpO8gYEP0REf0QGAAAAAMAAAAABEwETAAPAB8AKwAAASEyFhURFAYjISImNRE0NgUhIgYVERQWMyEyNjURNCYFFxYGIyEiJj8BNjIBXgGQpbm5pf5wo7u5Amf+DCk7OykB9Ck7O/77vgwLFf5wFQsMvgwkBEy5pf5wo7u8ogGQpbnIOyn+DCk7OykB9Ck7z/0QGBgQ/REAAAAAAgAAAAAFFARMAB8ANQAAASEyFhURFAYjISImPQE0NjMhMjY1ETQmIyEiJj0BNDYHARYUBwEGJj0BIyImPQE0NjsBNTQ2AiYBkKW5uaX+cBUdHRUBwik7Oyn+PhUdHb8BRBAQ/rwQFvoVHR0V+hYETLml/nCluR0VZBUdOykB9Ck7HRVkFR3p/uQOJg7+5A4KFZYdFcgVHZYVCgAAAQDZAAID1wSeACMAAAEXFgcGAgclMhYHIggBBwYrAScmNz4BPwEhIicmNzYANjc2MwMZCQgDA5gCASwYEQ4B/vf+8wQMDgkJCQUCUCcn/tIXCAoQSwENuwUJEASeCQoRC/5TBwEjEv7K/sUFDwgLFQnlbm4TFRRWAS/TBhAAAAACAAAAAAT+BEwAHwA1AAABITIWHQEUBiMhIgYVERQWMyEyFh0BFAYjISImNRE0NgUBFhQHAQYmPQEjIiY9ATQ2OwE1NDYBXgGQFR0dFf4+KTs7KQHCFR0dFf5wpbm5AvEBRBAQ/rwQFvoVHR0V+hYETB0VZBUdOyn+DCk7HRVkFR25pQGQpbnp/uQOJg7+5A4KFZYdFcgVHZYVCgACAAAAAASwBLAAFQAxAAABITIWFREUBi8BAQYiLwEmNDcBJyY2ASMiBhURFBYzITI2PQE3ERQGIyEiJjURNDYzIQLuAZAVHRUObf7IDykPjQ8PAThtDgj+75wpOzspAfQpO8i7o/5wpbm5pQEsBLAdFf5wFQgObf7IDw+NDykPAThtDhX+1Dsp/gwpOzsplMj+1qW5uaUBkKW5AAADAA4ADgSiBKIADwAbACMAAAAyHgIUDgIiLgI0PgEEIg4BFB4BMj4BNCYEMhYUBiImNAHh7tmdXV2d2e7ZnV1dnQHD5sJxccLmwnFx/nugcnKgcgSiXZ3Z7tmdXV2d2e7ZnUdxwubCcXHC5sJzcqBycqAAAAMAAAAABEwEsAAVAB8AIwAAATMyFhURMzIWBwEGIicBJjY7ARE0NgEhMhYdASE1NDYFFTM1AcLIFR31FAoO/oEOJw3+hQ0JFfod/oUD6BUd+7QdA2dkBLAdFf6iFg/+Vg8PAaoPFgFeFR38fB0V+voVHWQyMgAAAAMAAAAABEwErAAVAB8AIwAACQEWBisBFRQGKwEiJj0BIyImNwE+AQEhMhYdASE1NDYFFTM1AkcBeg4KFfQiFsgUGPoUCw4Bfw4n/fkD6BUd+7QdA2dkBJ7+TQ8g+hQeHRX6IQ8BrxAC/H8dFfr6FR1kMjIAAwAAAAAETARLABQAHgAiAAAJATYyHwEWFAcBBiInASY0PwE2MhcDITIWHQEhNTQ2BRUzNQGMAXEHFQeLBwf98wcVB/7cBweLCBUH1APoFR37tB0DZ2QC0wFxBweLCBUH/fMICAEjCBQIiwcH/dIdFfr6FR1kMjIABAAAAAAETASbAAkAGQAjACcAABM3NjIfAQcnJjQFNzYWFQMOASMFIiY/ASc3ASEyFh0BITU0NgUVMzWHjg4qDk3UTQ4CFtIOFQIBHRX9qxUIDtCa1P49A+gVHfu0HQNnZAP/jg4OTdRMDyqa0g4IFf2pFB4BFQ7Qm9T9Oh0V+voVHWQyMgAAAAQAAAAABEwEsAAPABkAIwAnAAABBR4BFRMUBi8BByc3JyY2EwcGIi8BJjQ/AQEhMhYdASE1NDYFFTM1AV4CVxQeARUO0JvUm9IOCMNMDyoOjg4OTf76A+gVHfu0HQNnZASwAgEdFf2rFQgO0JrUmtIOFf1QTQ4Ojg4qDk3+WB0V+voVHWQyMgACAAT/7ASwBK8ABQAIAAAlCQERIQkBFQEEsP4d/sb+cQSs/TMCq2cBFP5xAacDHPz55gO5AAAAAAIAAABkBEwEsAAVABkAAAERFAYrAREhESMiJjURNDY7AREhETMHIzUzBEwdFZb9RJYVHR0V+gH0ZMhkZAPo/K4VHQGQ/nAdFQPoFB7+1AEsyMgAAAMAAABFBN0EsAAWABoALwAAAQcBJyYiDwEhESMiJjURNDY7AREhETMHIzUzARcWFAcBBiIvASY0PwE2Mh8BATYyBEwC/tVfCRkJlf7IlhUdHRX6AfRkyGRkAbBqBwf+XAgUCMoICGoHFQdPASkHFQPolf7VXwkJk/5wHRUD6BQe/tQBLMjI/c5qBxUH/lsHB8sHFQdqCAhPASkHAAMAAAANBQcEsAAWABoAPgAAAREHJy4BBwEhESMiJjURNDY7AREhETMHIzUzARcWFA8BFxYUDwEGIi8BBwYiLwEmND8BJyY0PwE2Mh8BNzYyBExnhg8lEP72/reWFR0dFfoB9GTIZGQB9kYPD4ODDw9GDykPg4MPKQ9GDw+Dgw8PRg8pD4ODDykD6P7zZ4YPAw7+9v5wHRUD6BQe/tQBLMjI/YxGDykPg4MPKQ9GDw+Dgw8PRg8pD4ODDykPRg8Pg4MPAAADAAAAFQSXBLAAFQAZAC8AAAERISIGHQEhESMiJjURNDY7AREhETMHIzUzEzMyFh0BMzIWDwEGIi8BJjY7ATU0NgRM/qIVHf4MlhUdHRX6AfRkyGRklmQVHZYVCA7mDioO5g4IFZYdA+j+1B0Vlv5wHRUD6BQe/tQBLMjI/agdFfoVDuYODuYOFfoVHQAAAAADAAAAAASXBLAAFQAZAC8AAAERJyYiBwEhESMiJjURNDY7AREhETMHIzUzExcWBisBFRQGKwEiJj0BIyImPwE2MgRMpQ4qDv75/m6WFR0dFfoB9GTIZGTr5g4IFZYdFWQVHZYVCA7mDioD6P5wpQ8P/vf+cB0VA+gUHv7UASzIyP2F5Q8V+hQeHhT6FQ/lDwADAAAAyASwBEwACQATABcAABMhMhYdASE1NDYBERQGIyEiJjURExUhNTIETBUd+1AdBJMdFfu0FR1kAZAETB0VlpYVHf7U/doVHR0VAib+1MjIAAAGAAMAfQStBJcADwAZAB0ALQAxADsAAAEXFhQPAQYmPQEhNSE1NDYBIyImPQE0NjsBFyM1MwE3NhYdASEVIRUUBi8BJjQFIzU7AjIWHQEUBisBA6f4Dg74DhX+cAGQFf0vMhUdHRUyyGRk/oL3DhUBkP5wFQ73DwOBZGRkMxQdHRQzBI3mDioO5g4IFZbIlhUI/oUdFWQVHcjI/cvmDggVlsiWFQgO5g4qecgdFWQVHQAAAAACAGQAAASwBLAAFgBRAAABJTYWFREUBisBIiY1ES4ENRE0NiUyFh8BERQOAg8BERQGKwEiJjURLgQ1ETQ+AzMyFh8BETMRPAE+AjMyFh8BETMRND4DA14BFBklHRXIFR0EDiIaFiX+4RYZAgEVHR0LCh0VyBUdBA4iGhYBBwoTDRQZAgNkBQkVDxcZAQFkAQUJFQQxdBIUH/uuFR0dFQGNAQgbHzUeAWcfRJEZDA3+Phw/MSkLC/5BFR0dFQG/BA8uLkAcAcICBxENCxkMDf6iAV4CBxENCxkMDf6iAV4CBxENCwABAGQAAASwBEwAMwAAARUiDgMVERQWHwEVITUyNjURIREUFjMVITUyPgM1ETQmLwE1IRUiBhURIRE0JiM1BLAEDiIaFjIZGf5wSxn+DBlL/nAEDiIaFjIZGQGQSxkB9BlLBEw4AQUKFA78iBYZAQI4OA0lAYr+diUNODgBBQoUDgN4FhkBAjg4DSX+dgGKJQ04AAAABgAAAAAETARMAAwAHAAgACQAKAA0AAABITIWHQEjBTUnITchBSEyFhURFAYjISImNRE0NhcVITUBBTUlBRUhNQUVFAYjIQchJyE3MwKjAXcVHWn+2cj+cGQBd/4lASwpOzsp/tQpOzspASwCvP5wAZD8GAEsArwdFf6JZP6JZAGQyGkD6B0VlmJiyGTIOyn+DCk7OykB9Ck7ZMjI/veFo4XGyMhm+BUdZGTIAAEAEAAQBJ8EnwAmAAATNzYWHwEWBg8BHgEXNz4BHwEeAQ8BBiIuBicuBTcRohEuDosOBhF3ZvyNdxEzE8ATBxGjAw0uMUxPZWZ4O0p3RjITCwED76IRBhPCFDERdo78ZXYRBA6IDi8RogEECBUgNUNjO0qZfHNVQBAAAAACAAAAAASwBEwAIwBBAAAAMh4EHwEVFAYvAS4BPQEmIAcVFAYPAQYmPQE+BRIyHgIfARUBHgEdARQGIyEiJj0BNDY3ATU0PgIB/LimdWQ/LAkJHRTKFB2N/sKNHRTKFB0DDTE7ZnTKcFImFgEBAW0OFR0V+7QVHRUOAW0CFiYETBUhKCgiCgrIFRgDIgMiFZIYGJIVIgMiAxgVyAQNJyQrIP7kExwcCgoy/tEPMhTUFR0dFdQUMg8BLzIEDSEZAAADAAAAAASwBLAADQAdACcAAAEHIScRMxUzNTMVMzUzASEyFhQGKwEXITcjIiY0NgMhMhYdASE1NDYETMj9qMjIyMjIyPyuArwVHR0VDIn8SokMFR0dswRMFR37UB0CvMjIAfTIyMjI/OAdKh1kZB0qHf7UHRUyMhUdAAAAAwBkAAAEsARMAAkAEwAdAAABIyIGFREhETQmASMiBhURIRE0JgEhETQ2OwEyFhUCvGQpOwEsOwFnZCk7ASw7/Rv+1DspZCk7BEw7KfwYA+gpO/7UOyn9RAK8KTv84AGQKTs7KQAAAAAF/5wAAASwBEwADwATAB8AJQApAAATITIWFREUBiMhIiY1ETQ2FxEhEQUjFTMRITUzNSMRIQURByMRMwcRMxHIArx8sLB8/UR8sLAYA4T+DMjI/tTIyAEsAZBkyMhkZARMsHz+DHywsHwB9HywyP1EArzIZP7UZGQBLGT+1GQB9GT+1AEsAAAABf+cAAAEsARMAA8AEwAfACUAKQAAEyEyFhURFAYjISImNRE0NhcRIREBIzUjFSMRMxUzNTMFEQcjETMHETMRyAK8fLCwfP1EfLCwGAOE/gxkZGRkZGQBkGTIyGRkBEywfP4MfLCwfAH0fLDI/UQCvP2oyMgB9MjIZP7UZAH0ZP7UASwABP+cAAAEsARMAA8AEwAbACMAABMhMhYVERQGIyEiJjURNDYXESERBSMRMxUhESEFIxEzFSERIcgCvHywsHz9RHywsBgDhP4MyMj+1AEsAZDIyP7UASwETLB8/gx8sLB8AfR8sMj9RAK8yP7UZAH0ZP7UZAH0AAAABP+cAAAEsARMAA8AEwAWABkAABMhMhYVERQGIyEiJjURNDYXESERAS0BDQERyAK8fLCwfP1EfLCwGAOE/gz+1AEsAZD+1ARMsHz+DHywsHwB9HywyP1EArz+DJaWlpYBLAAAAAX/nAAABLAETAAPABMAFwAgACkAABMhMhYVERQGIyEiJjURNDYXESERAyERIQcjIgYVFBY7AQERMzI2NTQmI8gCvHywsHz9RHywsBgDhGT9RAK8ZIImOTYpgv4Mgik2OSYETLB8/gx8sLB8AfR8sMj9RAK8/agB9GRWQUFUASz+1FRBQVYAAAAF/5wAAASwBEwADwATAB8AJQApAAATITIWFREUBiMhIiY1ETQ2FxEhEQUjFTMRITUzNSMRIQEjESM1MwMjNTPIArx8sLB8/UR8sLAYA4T+DMjI/tTIyAEsAZBkZMjIZGQETLB8/gx8sLB8AfR8sMj9RAK8yGT+1GRkASz+DAGQZP4MZAAG/5wAAASwBEwADwATABkAHwAjACcAABMhMhYVERQGIyEiJjURNDYXESERBTMRIREzASMRIzUzBRUzNQEjNTPIArx8sLB8/UR8sLAYA4T9RMj+1GQCWGRkyP2oZAEsZGQETLB8/gx8sLB8AfR8sMj9RAK8yP5wAfT+DAGQZMjIyP7UZAAF/5wAAASwBEwADwATABwAIgAmAAATITIWFREUBiMhIiY1ETQ2FxEhEQEHIzU3NSM1IQEjESM1MwMjNTPIArx8sLB8/UR8sLAYA4T+DMdkx8gBLAGQZGTIx2RkBEywfP4MfLCwfAH0fLDI/UQCvP5wyDLIlmT+DAGQZP4MZAAAAAMACQAJBKcEpwAPABsAJQAAADIeAhQOAiIuAjQ+AQQiDgEUHgEyPgE0JgchFSEVISc1NyEB4PDbnl5entvw255eXp4BxeTCcXHC5MJxcWz+1AEs/tRkZAEsBKdentvw255eXp7b8NueTHHC5MJxccLkwtDIZGTIZAAAAAAEAAkACQSnBKcADwAbACcAKwAAADIeAhQOAiIuAjQ+AQQiDgEUHgEyPgE0JgcVBxcVIycjFSMRIQcVMzUB4PDbnl5entvw255eXp4BxeTCcXHC5MJxcWwyZGRklmQBLMjIBKdentvw255eXp7b8NueTHHC5MJxccLkwtBkMmQyZGQBkGRkZAAAAv/y/50EwgRBACAANgAAATIWFzYzMhYUBisBNTQmIyEiBh0BIyImNTQ2NyY1ND4BEzMyFhURMzIWDwEGIi8BJjY7ARE0NgH3brUsLC54qqp4gB0V/tQVHd5QcFZBAmKqepYKD4kVCg3fDSYN3w0KFYkPBEF3YQ6t8a36FR0dFfpzT0VrDhMSZKpi/bMPCv7tFxD0EBD0EBcBEwoPAAAAAAL/8v+cBMMEQQAcADMAAAEyFhc2MzIWFxQGBwEmIgcBIyImNTQ2NyY1ND4BExcWBisBERQGKwEiJjURIyImNzY3NjIB9m62LCsueaoBeFr+hg0lDf6DCU9xVkECYqnm3w0KFYkPCpYKD4kVCg3HGBMZBEF3YQ+teGOkHAFoEBD+k3NPRWsOExNkqWP9kuQQF/7tCg8PCgETFxDMGBMAAAABAGQAAARMBG0AGAAAJTUhATMBMwkBMwEzASEVIyIGHQEhNTQmIwK8AZD+8qr+8qr+1P7Uqv7yqv7yAZAyFR0BkB0VZGQBLAEsAU3+s/7U/tRkHRUyMhUdAAAAAAEAeQAABDcEmwAvAAABMhYXHgEVFAYHFhUUBiMiJxUyFh0BITU0NjM1BiMiJjU0Ny4BNTQ2MzIXNCY1NDYCWF6TGll7OzIJaUo3LRUd/tQdFS03SmkELzlpSgUSAqMEm3FZBoNaPWcfHRpKaR77HRUyMhUd+x5pShIUFVg1SmkCAhAFdKMAAAAGACcAFASJBJwAEQAqAEIASgBiAHsAAAEWEgIHDgEiJicmAhI3PgEyFgUiBw4BBwYWHwEWMzI3Njc2Nz4BLwEmJyYXIgcOAQcGFh8BFjMyNz4BNz4BLwEmJyYWJiIGFBYyNjciBw4BBw4BHwEWFxYzMjc+ATc2Ji8BJhciBwYHBgcOAR8BFhcWMzI3PgE3NiYvASYD8m9PT29T2dzZU29PT29T2dzZ/j0EBHmxIgQNDCQDBBcGG0dGYAsNAwkDCwccBAVQdRgEDA0iBAQWBhJROQwMAwkDCwf5Y4xjY4xjVhYGElE6CwwDCQMLBwgEBVB1GAQNDCIEjRcGG0dGYAsNAwkDCwcIBAR5sSIEDQwkAwPyb/7V/tVvU1dXU28BKwErb1NXVxwBIrF5DBYDCQEWYEZHGwMVDCMNBgSRAhh1UA0WAwkBFTpREgMVCyMMBwT6Y2OMY2MVFTpREQQVCyMMBwQCGHVQDRYDCQEkFmBGRxsDFQwjDQYEASKxeQwWAwkBAAAABQBkAAAD6ASwAAwADwAWABwAIgAAASERIzUhFSERNDYzIQEjNQMzByczNTMDISImNREFFRQGKwECvAEstP6s/oQPCgI/ASzIZKLU1KJktP51Cg8DhA8KwwMg/oTIyALzCg/+1Mj84NTUyP4MDwoBi8jDCg8AAAAABQBkAAAD6ASwAAkADAATABoAIQAAASERCQERNDYzIQEjNRMjFSM1IzcDISImPQEpARUUBisBNQK8ASz+ov3aDwoCPwEsyD6iZKLUqv6dCg8BfAIIDwqbAyD9+AFe/doERwoP/tTI/HzIyNT+ZA8KNzcKD1AAAAAAAwAAAAAEsAP0AAgAGQAfAAABIxUzFyERIzcFMzIeAhUhFSEDETM0PgIBMwMhASEEiqJkZP7UotT9EsgbGiEOASz9qMhkDiEaAnPw8PzgASwB9AMgyGQBLNTUBBErJGT+ogHCJCsRBP5w/nAB9AAAAAMAAAAABEwETAAZADIAOQAAATMyFh0BMzIWHQEUBiMhIiY9ATQ2OwE1NDYFNTIWFREUBiMhIic3ARE0NjMVFBYzITI2AQc1IzUzNQKKZBUdMhUdHRX+1BUdHRUyHQFzKTs7Kf2oARP2/ro7KVg+ASw+WP201MjIBEwdFTIdFWQVHR0VZBUdMhUd+pY7KfzgKTsE9gFGAUQpO5Y+WFj95tSiZKIAAwBkAAAEvARMABkANgA9AAABMzIWHQEzMhYdARQGIyEiJj0BNDY7ATU0NgU1MhYVESMRMxQOAiMhIiY1ETQ2MxUUFjMhMjYBBzUjNTM1AcJkFR0yFR0dFf7UFR0dFTIdAXMpO8jIDiEaG/2oKTs7KVg+ASw+WAGc1MjIBEwdFTIdFWQVHR0VZBUdMhUd+pY7Kf4M/tQkKxEEOykDICk7lj5YWP3m1KJkogAAAAP/ogAABRYE1AALABsAHwAACQEWBiMhIiY3ATYyEyMiBhcTHgE7ATI2NxM2JgMVMzUCkgJ9FyAs+wQsIBcCfRZARNAUGAQ6BCMUNhQjBDoEGODIBK37sCY3NyYEUCf+TB0U/tIUHR0UAS4UHf4MZGQAAAAACQAAAAAETARMAA8AHwAvAD8ATwBfAG8AfwCPAAABMzIWHQEUBisBIiY9ATQ2EzMyFh0BFAYrASImPQE0NiEzMhYdARQGKwEiJj0BNDYBMzIWHQEUBisBIiY9ATQ2ITMyFh0BFAYrASImPQE0NiEzMhYdARQGKwEiJj0BNDYBMzIWHQEUBisBIiY9ATQ2ITMyFh0BFAYrASImPQE0NiEzMhYdARQGKwEiJj0BNDYBqfoKDw8K+goPDwr6Cg8PCvoKDw8BmvoKDw8K+goPD/zq+goPDwr6Cg8PAZr6Cg8PCvoKDw8BmvoKDw8K+goPD/zq+goPDwr6Cg8PAZr6Cg8PCvoKDw8BmvoKDw8K+goPDwRMDwqWCg8PCpYKD/7UDwqWCg8PCpYKDw8KlgoPDwqWCg/+1A8KlgoPDwqWCg8PCpYKDw8KlgoPDwqWCg8PCpYKD/7UDwqWCg8PCpYKDw8KlgoPDwqWCg8PCpYKDw8KlgoPAAAAAwAAAAAEsAUUABkAKQAzAAABMxUjFSEyFg8BBgchJi8BJjYzITUjNTM1MwEhMhYUBisBFyE3IyImNDYDITIWHQEhNTQ2ArxkZAFePjEcQiko/PwoKUIcMT4BXmRkyP4+ArwVHR0VDIn8SooNFR0dswRMFR37UB0EsMhkTzeEUzMzU4Q3T2TIZPx8HSodZGQdKh3+1B0VMjIVHQAABAAAAAAEsAUUAAUAGQArADUAAAAyFhUjNAchFhUUByEyFg8BIScmNjMhJjU0AyEyFhQGKwEVBSElNSMiJjQ2AyEyFh0BITU0NgIwUDnCPAE6EgMBSCkHIq/9WrIiCikBSAOvArwVHR0VlgET/EoBE5YVHR2zBEwVHftQHQUUOykpjSUmCBEhFpGRFiERCCb+lR0qHcjIyMgdKh39qB0VMjIVHQAEAAAAAASwBJ0ABwAUACQALgAAADIWFAYiJjQTMzIWFRQXITY1NDYzASEyFhQGKwEXITcjIiY0NgMhMhYdASE1NDYCDZZqapZqty4iKyf+vCcrI/7NArwVHR0VDYr8SokMFR0dswRMFR37UB0EnWqWamqW/us5Okxra0w6Of5yHSodZGQdKh3+1B0VMjIVHQAEAAAAAASwBRQADwAcACwANgAAATIeARUUBiImNTQ3FzcnNhMzMhYVFBchNjU0NjMBITIWFAYrARchNyMiJjQ2AyEyFh0BITU0NgJYL1szb5xvIpBvoyIfLiIrJ/68Jysj/s0CvBUdHRUNivxKiQwVHR2zBEwVHftQHQUUa4s2Tm9vTj5Rj2+jGv4KOTpMa2tMOjn+ch0qHWRkHSod/tQdFTIyFR0AAAADAAAAAASwBRIAEgAiACwAAAEFFSEUHgMXIS4BNTQ+AjcBITIWFAYrARchNyMiJjQ2AyEyFh0BITU0NgJYASz+1CU/P00T/e48PUJtj0r+ogK8FR0dFQ2K/EqJDBUdHbMETBUd+1AdBLChizlmUT9IGVO9VFShdksE/H4dKh1kZB0qHf7UHRUyMhUdAAIAyAAAA+gFFAAPACkAAAAyFh0BHgEdASE1NDY3NTQDITIWFyMVMxUjFTMVIxUzFAYjISImNRE0NgIvUjsuNv5wNi5kAZA2XBqsyMjIyMh1U/5wU3V1BRQ7KU4aXDYyMjZcGk4p/kc2LmRkZGRkU3V1UwGQU3UAAAMAZP//BEwETAAPAC8AMwAAEyEyFhURFAYjISImNRE0NgMhMhYdARQGIyEXFhQGIi8BIQcGIiY0PwEhIiY9ATQ2BQchJ5YDhBUdHRX8fBUdHQQDtgoPDwr+5eANGiUNWP30Vw0mGg3g/t8KDw8BqmQBRGQETB0V/gwVHR0VAfQVHf1EDwoyCg/gDSUbDVhYDRslDeAPCjIKD2RkZAAAAAAEAAAAAASwBEwAGQAjAC0ANwAAEyEyFh0BIzQmKwEiBhUjNCYrASIGFSM1NDYDITIWFREhETQ2ExUUBisBIiY9ASEVFAYrASImPQHIAyBTdWQ7KfopO2Q7KfopO2R1EQPoKTv7UDvxHRVkFR0D6B0VZBUdBEx1U8gpOzspKTs7KchTdf4MOyn+1AEsKTv+DDIVHR0VMjIVHR0VMgADAAEAAASpBKwADQARABsAAAkBFhQPASEBJjQ3ATYyCQMDITIWHQEhNTQ2AeACqh8fg/4f/fsgIAEnH1n+rAFWAS/+q6IDIBUd/HwdBI39VR9ZH4MCBh9ZHwEoH/5u/qoBMAFV/BsdFTIyFR0AAAAAAgCPAAAEIQSwABcALwAAAQMuASMhIgYHAwYWMyEVFBYyNj0BMzI2AyE1NDY7ATU0NjsBETMRMzIWHQEzMhYVBCG9CCcV/nAVJwi9CBMVAnEdKh19FROo/a0dFTIdFTDILxUdMhUdAocB+hMcHBP+BhMclhUdHRWWHP2MMhUdMhUdASz+1B0VMh0VAAAEAAAAAASwBLAADQAQAB8AIgAAASERFAYjIREBNTQ2MyEBIzUBIREUBiMhIiY1ETQ2MyEBIzUDhAEsDwr+if7UDwoBdwEsyP2oASwPCv12Cg8PCgF3ASzIAyD9wQoPAk8BLFQKD/7UyP4M/cEKDw8KA7YKD/7UyAAC/5wAZAUUBEcARgBWAAABMzIeAhcWFxY2NzYnJjc+ARYXFgcOASsBDgEPAQ4BKwEiJj8BBisBIicHDgErASImPwEmLwEuAT0BNDY7ATY3JyY2OwE2BSMiBh0BFBY7ATI2PQE0JgHkw0uOakkMEhEfQwoKGRMKBQ8XDCkCA1Y9Pgc4HCcDIhVkFRgDDDEqwxgpCwMiFWQVGAMaVCyfExwdFXwLLW8QBxXLdAFF+goPDwr6Cg8PBEdBa4pJDgYKISAiJRsQCAYIDCw9P1c3fCbqFB0dFEYOCEAUHR0UnUplNQcmFTIVHVdPXw4TZV8PCjIKDw8KMgoPAAb/nP/mBRQEfgAJACQANAA8AFIAYgAAASU2Fh8BFgYPASUzMhYfASEyFh0BFAYHBQYmJyYjISImPQE0NhcjIgYdARQ7ATI2NTQmJyYEIgYUFjI2NAE3PgEeARceAT8BFxYGDwEGJi8BJjYlBwYfAR4BPwE2Jy4BJy4BAoEBpxMuDiAOAxCL/CtqQ0geZgM3FR0cE/0fFyIJKjr+1D5YWLlQExIqhhALIAsSAYBALS1ALf4PmBIgHhMQHC0aPzANITNQL3wpgigJASlmHyElDR0RPRMFAhQHCxADhPcICxAmDyoNeMgiNtQdFTIVJgeEBBQPQ1g+yD5YrBwVODMQEAtEERzJLUAtLUD+24ITChESEyMgAwWzPUkrRSgJL5cvfRxYGyYrDwkLNRAhFEgJDAQAAAAAAwBkAAAEOQSwAFEAYABvAAABMzIWHQEeARcWDgIPATIeBRUUDgUjFRQGKwEiJj0BIxUUBisBIiY9ASMiJj0BNDY7AREjIiY9ATQ2OwE1NDY7ATIWHQEzNTQ2AxUhMj4CNTc0LgMjARUhMj4CNTc0LgMjAnGWCg9PaAEBIC4uEBEGEjQwOiodFyI2LUAjGg8KlgoPZA8KlgoPrwoPDwpLSwoPDwqvDwqWCg9kD9cBBxwpEwsBAQsTKRz++QFrHCkTCwEBCxMpHASwDwptIW1KLk0tHwYGAw8UKDJOLTtdPCoVCwJLCg8PCktLCg8PCksPCpYKDwJYDwqWCg9LCg8PCktLCg/+1MgVHR0LCgQOIhoW/nDIFR0dCwoEDiIaFgAAAwAEAAIEsASuABcAKQAsAAATITIWFREUBg8BDgEjISImJy4CNRE0NgQiDgQPARchNy4FAyMT1AMMVnokEhIdgVL9xFKCHAgYKHoCIIx9VkcrHQYGnAIwnAIIIClJVSGdwwSuelb+YDO3QkJXd3ZYHFrFMwGgVnqZFyYtLSUMDPPzBQ8sKDEj/sIBBQACAMgAAAOEBRQADwAZAAABMzIWFREUBiMhIiY1ETQ2ARUUBisBIiY9AQHblmesVCn+PilUrAFINhWWFTYFFKxn/gwpVFQpAfRnrPwY4RU2NhXhAAACAMgAAAOEBRQADwAZAAABMxQWMxEUBiMhIiY1ETQ2ARUUBisBIiY9AQHbYLOWVCn+PilUrAFINhWWFTYFFJaz/kIpVFQpAfRnrPwY4RU2NhXhAAACAAAAFAUOBBoAFAAaAAAJASUHFRcVJwc1NzU0Jj4CPwEnCQEFJTUFJQUO/YL+hk5klpZkAQEBBQQvkwKCAVz+ov6iAV4BXgL//uWqPOCWx5SVyJb6BA0GCgYDKEEBG/1ipqaTpaUAAAMAZAH0BLADIAAHAA8AFwAAEjIWFAYiJjQkMhYUBiImNCQyFhQGIiY0vHxYWHxYAeh8WFh8WAHofFhYfFgDIFh8WFh8WFh8WFh8WFh8WFh8AAAAAAMBkAAAArwETAAHAA8AFwAAADIWFAYiJjQSMhYUBiImNBIyFhQGIiY0Aeh8WFh8WFh8WFh8WFh8WFh8WARMWHxYWHz+yFh8WFh8/shYfFhYfAAAAAMAZABkBEwETAAPAB8ALwAAEyEyFh0BFAYjISImPQE0NhMhMhYdARQGIyEiJj0BNDYTITIWHQEUBiMhIiY9ATQ2fQO2Cg8PCvxKCg8PCgO2Cg8PCvxKCg8PCgO2Cg8PCvxKCg8PBEwPCpYKDw8KlgoP/nAPCpYKDw8KlgoP/nAPCpYKDw8KlgoPAAAABAAAAAAEsASwAA8AHwAvADMAAAEhMhYVERQGIyEiJjURNDYFISIGFREUFjMhMjY1ETQmBSEyFhURFAYjISImNRE0NhcVITUBXgH0ory7o/4Mpbm5Asv9qCk7OykCWCk7O/2xAfQVHR0V/gwVHR1HAZAEsLuj/gylubmlAfSlucg7Kf2oKTs7KQJYKTtkHRX+1BUdHRUBLBUdZMjIAAAAAAEAZABkBLAETAA7AAATITIWFAYrARUzMhYUBisBFTMyFhQGKwEVMzIWFAYjISImNDY7ATUjIiY0NjsBNSMiJjQ2OwE1IyImNDaWA+gVHR0VMjIVHR0VMjIVHR0VMjIVHR0V/BgVHR0VMjIVHR0VMjIVHR0VMjIVHR0ETB0qHcgdKh3IHSodyB0qHR0qHcgdKh3IHSodyB0qHQAAAAYBLAAFA+gEowAHAA0AEwAZAB8AKgAAAR4BBgcuATYBMhYVIiYlFAYjNDYBMhYVIiYlFAYjNDYDFRQGIiY9ARYzMgKKVz8/V1c/P/75fLB8sAK8sHyw/cB8sHywArywfLCwHSodKAMRBKNDsrJCQrKy/sCwfLB8fLB8sP7UsHywfHywfLD+05AVHR0VjgQAAAH/tQDIBJQDgQBCAAABNzYXAR4BBw4BKwEyFRQOBCsBIhE0NyYiBxYVECsBIi4DNTQzIyImJyY2NwE2HwEeAQ4BLwEHIScHBi4BNgLpRRkUASoLCAYFGg8IAQQNGyc/KZK4ChRUFQu4jjBJJxkHAgcPGQYGCAsBKhQaTBQVCiMUM7YDe7YsFCMKFgNuEwYS/tkLHw8OEw0dNkY4MhwBIBgXBAQYF/7gKjxTQyMNEw4PHwoBKBIHEwUjKBYGDMHBDAUWKCMAAAAAAgAAAAAEsASwACUAQwAAASM0LgUrAREUFh8BFSE1Mj4DNREjIg4FFSMRIQEjNC4DKwERFBYXMxUjNTI1ESMiDgMVIzUhBLAyCAsZEyYYGcgyGRn+cAQOIhoWyBkYJhMZCwgyA+j9RBkIChgQEWQZDQzIMmQREBgKCBkB9AOEFSAVDggDAfyuFhkBAmRkAQUJFQ4DUgEDCA4VIBUBLP0SDxMKBQH+VwsNATIyGQGpAQUKEw+WAAAAAAMAAAAABEwErgAdACAAMAAAATUiJy4BLwEBIwEGBw4BDwEVITUiJj8BIRcWBiMVARsBARUUBiMhIiY9ATQ2MyEyFgPoGR4OFgUE/t9F/tQSFQkfCwsBETE7EkUBJT0NISf+7IZ5AbEdFfwYFR0dFQPoFR0BLDIgDiIKCwLr/Q4jFQkTBQUyMisusKYiQTIBhwFW/qr942QVHR0VZBUdHQADAAAAAASwBLAADwBHAEoAABMhMhYVERQGIyEiJjURNDYFIyIHAQYHBgcGHQEUFjMhMjY9ATQmIyInJj8BIRcWBwYjIgYdARQWMyEyNj0BNCYnIicmJyMBJhMjEzIETBUdHRX7tBUdHQJGRg0F/tUREhImDAsJAREIDAwINxAKCj8BCjkLEQwYCAwMCAE5CAwLCBEZGQ8B/uAFDsVnBLAdFfu0FR0dFQRMFR1SDP0PIBMSEAUNMggMDAgyCAwXDhmjmR8YEQwIMggMDAgyBwwBGRskAuwM/gUBCAAABAAAAAAEsASwAAMAEwAjACcAAAEhNSEFITIWFREUBiMhIiY1ETQ2KQEyFhURFAYjISImNRE0NhcRIREEsPtQBLD7ggGQFR0dFf5wFR0dAm0BkBUdHRX+cBUdHUcBLARMZMgdFfx8FR0dFQOEFR0dFf5wFR0dFQGQFR1k/tQBLAAEAAAAAASwBLAADwAfACMAJwAAEyEyFhURFAYjISImNRE0NgEhMhYVERQGIyEiJjURNDYXESEREyE1ITIBkBUdHRX+cBUdHQJtAZAVHR0V/nAVHR1HASzI+1AEsASwHRX8fBUdHRUDhBUd/gwdFf5wFR0dFQGQFR1k/tQBLP2oZAAAAAACAAAAZASwA+gAJwArAAATITIWFREzNTQ2MyEyFh0BMxUjFRQGIyEiJj0BIxEUBiMhIiY1ETQ2AREhETIBkBUdZB0VAZAVHWRkHRX+cBUdZB0V/nAVHR0CnwEsA+gdFf6ilhUdHRWWZJYVHR0Vlv6iFR0dFQMgFR3+1P7UASwAAAQAAAAABLAEsAADABMAFwAnAAAzIxEzFyEyFhURFAYjISImNRE0NhcRIREBITIWFREUBiMhIiY1ETQ2ZGRklgGQFR0dFf5wFR0dRwEs/qIDhBUdHRX8fBUdHQSwZB0V/nAVHR0VAZAVHWT+1AEs/gwdFf5wFR0dFQGQFR0AAAAAAgBkAAAETASwACcAKwAAATMyFhURFAYrARUhMhYVERQGIyEiJjURNDYzITUjIiY1ETQ2OwE1MwcRIRECWJYVHR0VlgHCFR0dFfx8FR0dFQFelhUdHRWWZMgBLARMHRX+cBUdZB0V/nAVHR0VAZAVHWQdFQGQFR1kyP7UASwAAAAEAAAAAASwBLAAAwATABcAJwAAISMRMwUhMhYVERQGIyEiJjURNDYXESERASEyFhURFAYjISImNRE0NgSwZGT9dgGQFR0dFf5wFR0dRwEs/K4DhBUdHRX8fBUdHQSwZB0V/nAVHR0VAZAVHWT+1AEs/gwdFf5wFR0dFQGQFR0AAAEBLAAwA28EgAAPAAAJAQYjIiY1ETQ2MzIXARYUA2H+EhcSDhAQDhIXAe4OAjX+EhcbGQPoGRsX/hIOKgAAAAABAUEAMgOEBH4ACwAACQE2FhURFAYnASY0AU8B7h0qKh3+Eg4CewHuHREp/BgpER0B7g4qAAAAAAEAMgFBBH4DhAALAAATITIWBwEGIicBJjZkA+gpER3+Eg4qDv4SHREDhCod/hIODgHuHSoAAAAAAQAyASwEfgNvAAsAAAkBFgYjISImNwE2MgJ7Ae4dESn8GCkRHQHuDioDYf4SHSoqHQHuDgAAAAACAAgAAASwBCgABgAKAAABFQE1LQE1ASE1IQK8/UwBnf5jBKj84AMgAuW2/r3dwcHd+9jIAAAAAAIAAABkBLAEsAALADEAAAEjFTMVIREzNSM1IQEzND4FOwERFAYPARUhNSIuAzURMzIeBRUzESEEsMjI/tTIyAEs+1AyCAsZEyYYGWQyGRkBkAQOIhoWZBkYJhMZCwgy/OADhGRkASxkZP4MFSAVDggDAf3aFhkBAmRkAQUJFQ4CJgEDCA4VIBUBLAAAAgAAAAAETAPoACUAMQAAASM0LgUrAREUFh8BFSE1Mj4DNREjIg4FFSMRIQEjFTMVIREzNSM1IQMgMggLGRMmGBlkMhkZ/nAEDiIaFmQZGCYTGQsIMgMgASzIyP7UyMgBLAK8FSAVDggDAf3aFhkCAWRkAQUJFQ4CJgEDCA4VIBUBLPzgZGQBLGRkAAABAMgAZgNyBEoAEgAAATMyFgcJARYGKwEiJwEmNDcBNgK9oBAKDP4wAdAMChCgDQr+KQcHAdcKBEoWDP4w/jAMFgkB1wgUCAHXCQAAAQE+AGYD6ARKABIAAAEzMhcBFhQHAQYrASImNwkBJjYBU6ANCgHXBwf+KQoNoBAKDAHQ/jAMCgRKCf4pCBQI/ikJFgwB0AHQDBYAAAEAZgDIBEoDcgASAAAAFh0BFAcBBiInASY9ATQ2FwkBBDQWCf4pCBQI/ikJFgwB0AHQA3cKEKANCv4pBwcB1woNoBAKDP4wAdAAAAABAGYBPgRKA+gAEgAACQEWHQEUBicJAQYmPQE0NwE2MgJqAdcJFgz+MP4wDBYJAdcIFAPh/ikKDaAQCgwB0P4wDAoQoA0KAdcHAAAAAgDZ//kEPQSwAAUAOgAAARQGIzQ2BTMyFh8BNjc+Ah4EBgcOBgcGIiYjIgYiJy4DLwEuAT4EHgEXJyY2A+iwfLD+VmQVJgdPBQsiKFAzRyorDwURAQQSFyozTSwNOkkLDkc3EDlfNyYHBw8GDyUqPjdGMR+TDA0EsHywfLDIHBPCAQIGBwcFDx81S21DBxlLR1xKQhEFBQcHGWt0bCQjP2hJNyATBwMGBcASGAAAAAACAMgAFQOEBLAAFgAaAAATITIWFREUBisBEQcGJjURIyImNRE0NhcVITX6AlgVHR0Vlv8TGpYVHR2rASwEsB0V/nAVHf4MsgkQFQKKHRUBkBUdZGRkAAAAAgDIABkETASwAA4AEgAAEyEyFhURBRElIREjETQ2ARU3NfoC7ic9/UQCWP1EZB8BDWQEsFEs/Ft1A7Z9/BgEARc0/V1kFGQAAQAAAAECTW/DBF9fDzz1AB8EsAAAAADQdnOXAAAAANB2c5f/Uf+cBdwFFAAAAAgAAgAAAAAAAAABAAAFFP+FAAAFFP9R/tQF3AABAAAAAAAAAAAAAAAAAAAAowG4ACgAAAAAAZAAAASwAAAEsABkBLAAAASwAAAEsABwAooAAAUUAAACigAABRQAAAGxAAABRQAAANgAAADYAAAAogAAAQQAAABIAAABBAAAAUUAAASwAGQEsAB7BLAAyASwAMgB9AAABLD/8gSwAAAEsAAABLD/8ASwAAAEsAAOBLAACQSwAGQEsP/TBLD/0wSwAAAEsAAABLAAAASwAAAEsAAABLAAJgSwAG4EsAAXBLAAFwSwABcEsABkBLAAGgSwAGQEsAAMBLAAZASwABcEsP+cBLAAZASwABcEsAAXBLAAAASwABcEsAAXBLAAFwSwAGQEsAAABLAAZASwAAAEsAAABLAAAASwAAAEsAAABLAAAASwAAAEsAAABLAAZASwAMgEsAAABLAAAASwADUEsABkBLAAyASw/7UEsAAhBLAAAASwAAAEsAAABLAAAASwAAAEsP+cBLAAAASwAAAEsAAABLAA2wSwABcEsAB1BLAAAASwAAAEsAAABLAACgSwAMgEsAAABLAAnQSwAMgEsADIBLAAyASwAAAEsP/+BLABLASwAGQEsACIBLABOwSwABcEsAAXBLAAFwSwABcEsAAXBLAAFwSwAAAEsAAXBLAAFwSwABcEsAAXBLAAAASwALcEsAC3BLAAAASwAAAEsABJBLAAFwSwAAAEsAAABLAAXQSw/9wEsP/cBLD/nwSwAGQEsAAABLAAAASwAAAEsABkBLD//wSwAAAEsP9RBLAABgSwAAAEsAAABLABRQSwAAEEsAAABLD/nASwAEoEsAAUBLAAAASwAAAEsAAABLD/nASwAGEEsP/9BLAAFgSwABYEsAAWBLAAFgSwABgEsAAABMQAAASwAGQAAAAAAAD/2ABkADkAyAAAAScAZAAZABkAGQAZABkAGQAZAAAAAAAAAAAAAADZAAAAAAAOAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAMAZABkAAAAEAAAAAAAZP+c/5z/nP+c/5z/nP+c/5wACQAJ//L/8gBkAHkAJwBkAGQAAAAAAGT/ogAAAAAAAAAAAAAAAADIAGQAAAABAI8AAP+c/5wAZAAEAMgAyAAAAGQBkABkAAAAZAEs/7UAAAAAAAAAAAAAAAAAAABkAAABLAFBADIAMgAIAAAAAADIAT4AZgBmANkAyADIAAAAKgAqACoAKgCyAOgA6AFOAU4BTgFOAU4BTgFOAU4BTgFOAU4BTgFOAU4BpAIGAiICfgKGAqwC5ANGA24DjAPEBAgEMgRiBKIE3AVcBboGcgb0ByAHYgfKCB4IYgi+CTYJhAm2Cd4KKApMCpQK4gswC4oLygwIDFgNKg1eDbAODg5oDrQPKA+mD+YQEhBUEJAQqhEqEXYRthIKEjgSfBLAExoTdBPQFCoU1BU8FagVzBYEFjYWYBawFv4XUhemGAIYLhhqGJYYsBjgGP4ZKBloGZQZxBnaGe4aNhpoGrga9hteG7QcMhyUHOIdHB1EHWwdlB28HeYeLh52HsAfYh/SIEYgviEyIXYhuCJAIpYiuCMOIyIjOCN6I8Ij4CQCJDAkXiSWJOIlNCVgJbwmFCZ+JuYnUCe8J/goNChwKKwpoCnMKiYqSiqEKworeiwILGgsuizsLRwtiC30LiguZi6iLtgvDi9GL34vsi/4MD4whDDSMRIxYDGuMegyJDJeMpoy3jMiMz4zaDO2NBg0YDSoNNI1LDWeNeg2PjZ8Ntw3GjdON5I31DgQOEI4hjjIOQo5SjmIOcw6HDpsOpo63jugO9w8GDxQPKI8+D0yPew+Oj6MPtQ/KD9uP6o/+kBIQIBAxkECQX5CGEKoQu5DGENCQ3ZDoEPKRBBEYESuRPZFWkW2RgZGdEa0RvZHNkd2R7ZH9kgWSDJITkhqSIZIzEkSSThJXkmESapKAkouSlIAAQAAARcApwARAAAAAAACAAAAAQABAAAAQAAuAAAAAAAAABAAxgABAAAAAAATABIAAAADAAEECQAAAGoAEgADAAEECQABACgAfAADAAEECQACAA4ApAADAAEECQADAEwAsgADAAEECQAEADgA/gADAAEECQAFAHgBNgADAAEECQAGADYBrgADAAEECQAIABYB5AADAAEECQAJABYB+gADAAEECQALACQCEAADAAEECQAMACQCNAADAAEECQATACQCWAADAAEECQDIABYCfAADAAEECQDJADACkgADAAEECdkDABoCwnd3dy5nbHlwaGljb25zLmNvbQBDAG8AcAB5AHIAaQBnAGgAdAAgAKkAIAAyADAAMQA0ACAAYgB5ACAASgBhAG4AIABLAG8AdgBhAHIAaQBrAC4AIABBAGwAbAAgAHIAaQBnAGgAdABzACAAcgBlAHMAZQByAHYAZQBkAC4ARwBMAFkAUABIAEkAQwBPAE4AUwAgAEgAYQBsAGYAbABpAG4AZwBzAFIAZQBnAHUAbABhAHIAMQAuADAAMAA5ADsAVQBLAFcATgA7AEcATABZAFAASABJAEMATwBOAFMASABhAGwAZgBsAGkAbgBnAHMALQBSAGUAZwB1AGwAYQByAEcATABZAFAASABJAEMATwBOAFMAIABIAGEAbABmAGwAaQBuAGcAcwAgAFIAZQBnAHUAbABhAHIAVgBlAHIAcwBpAG8AbgAgADEALgAwADAAOQA7AFAAUwAgADAAMAAxAC4AMAAwADkAOwBoAG8AdABjAG8AbgB2ACAAMQAuADAALgA3ADAAOwBtAGEAawBlAG8AdABmAC4AbABpAGIAMgAuADUALgA1ADgAMwAyADkARwBMAFkAUABIAEkAQwBPAE4AUwBIAGEAbABmAGwAaQBuAGcAcwAtAFIAZQBnAHUAbABhAHIASgBhAG4AIABLAG8AdgBhAHIAaQBrAEoAYQBuACAASwBvAHYAYQByAGkAawB3AHcAdwAuAGcAbAB5AHAAaABpAGMAbwBuAHMALgBjAG8AbQB3AHcAdwAuAGcAbAB5AHAAaABpAGMAbwBuAHMALgBjAG8AbQB3AHcAdwAuAGcAbAB5AHAAaABpAGMAbwBuAHMALgBjAG8AbQBXAGUAYgBmAG8AbgB0ACAAMQAuADAAVwBlAGQAIABPAGMAdAAgADIAOQAgADAANgA6ADMANgA6ADAANwAgADIAMAAxADQARgBvAG4AdAAgAFMAcQB1AGkAcgByAGUAbAAAAAIAAAAAAAD/tQAyAAAAAAAAAAAAAAAAAAAAAAAAAAABFwAAAQIBAwADAA0ADgEEAJYBBQEGAQcBCAEJAQoBCwEMAQ0BDgEPARABEQESARMA7wEUARUBFgEXARgBGQEaARsBHAEdAR4BHwEgASEBIgEjASQBJQEmAScBKAEpASoBKwEsAS0BLgEvATABMQEyATMBNAE1ATYBNwE4ATkBOgE7ATwBPQE+AT8BQAFBAUIBQwFEAUUBRgFHAUgBSQFKAUsBTAFNAU4BTwFQAVEBUgFTAVQBVQFWAVcBWAFZAVoBWwFcAV0BXgFfAWABYQFiAWMBZAFlAWYBZwFoAWkBagFrAWwBbQFuAW8BcAFxAXIBcwF0AXUBdgF3AXgBeQF6AXsBfAF9AX4BfwGAAYEBggGDAYQBhQGGAYcBiAGJAYoBiwGMAY0BjgGPAZABkQGSAZMBlAGVAZYBlwGYAZkBmgGbAZwBnQGeAZ8BoAGhAaIBowGkAaUBpgGnAagBqQGqAasBrAGtAa4BrwGwAbEBsgGzAbQBtQG2AbcBuAG5AboBuwG8Ab0BvgG/AcABwQHCAcMBxAHFAcYBxwHIAckBygHLAcwBzQHOAc8B0AHRAdIB0wHUAdUB1gHXAdgB2QHaAdsB3AHdAd4B3wHgAeEB4gHjAeQB5QHmAecB6AHpAeoB6wHsAe0B7gHvAfAB8QHyAfMB9AH1AfYB9wH4AfkB+gH7AfwB/QH+Af8CAAIBAgICAwIEAgUCBgIHAggCCQIKAgsCDAINAg4CDwIQAhECEgZnbHlwaDEGZ2x5cGgyB3VuaTAwQTAHdW5pMjAwMAd1bmkyMDAxB3VuaTIwMDIHdW5pMjAwMwd1bmkyMDA0B3VuaTIwMDUHdW5pMjAwNgd1bmkyMDA3B3VuaTIwMDgHdW5pMjAwOQd1bmkyMDBBB3VuaTIwMkYHdW5pMjA1RgRFdXJvB3VuaTIwQkQHdW5pMjMxQgd1bmkyNUZDB3VuaTI2MDEHdW5pMjZGQQd1bmkyNzA5B3VuaTI3MEYHdW5pRTAwMQd1bmlFMDAyB3VuaUUwMDMHdW5pRTAwNQd1bmlFMDA2B3VuaUUwMDcHdW5pRTAwOAd1bmlFMDA5B3VuaUUwMTAHdW5pRTAxMQd1bmlFMDEyB3VuaUUwMTMHdW5pRTAxNAd1bmlFMDE1B3VuaUUwMTYHdW5pRTAxNwd1bmlFMDE4B3VuaUUwMTkHdW5pRTAyMAd1bmlFMDIxB3VuaUUwMjIHdW5pRTAyMwd1bmlFMDI0B3VuaUUwMjUHdW5pRTAyNgd1bmlFMDI3B3VuaUUwMjgHdW5pRTAyOQd1bmlFMDMwB3VuaUUwMzEHdW5pRTAzMgd1bmlFMDMzB3VuaUUwMzQHdW5pRTAzNQd1bmlFMDM2B3VuaUUwMzcHdW5pRTAzOAd1bmlFMDM5B3VuaUUwNDAHdW5pRTA0MQd1bmlFMDQyB3VuaUUwNDMHdW5pRTA0NAd1bmlFMDQ1B3VuaUUwNDYHdW5pRTA0Nwd1bmlFMDQ4B3VuaUUwNDkHdW5pRTA1MAd1bmlFMDUxB3VuaUUwNTIHdW5pRTA1Mwd1bmlFMDU0B3VuaUUwNTUHdW5pRTA1Ngd1bmlFMDU3B3VuaUUwNTgHdW5pRTA1OQd1bmlFMDYwB3VuaUUwNjIHdW5pRTA2Mwd1bmlFMDY0B3VuaUUwNjUHdW5pRTA2Ngd1bmlFMDY3B3VuaUUwNjgHdW5pRTA2OQd1bmlFMDcwB3VuaUUwNzEHdW5pRTA3Mgd1bmlFMDczB3VuaUUwNzQHdW5pRTA3NQd1bmlFMDc2B3VuaUUwNzcHdW5pRTA3OAd1bmlFMDc5B3VuaUUwODAHdW5pRTA4MQd1bmlFMDgyB3VuaUUwODMHdW5pRTA4NAd1bmlFMDg1B3VuaUUwODYHdW5pRTA4Nwd1bmlFMDg4B3VuaUUwODkHdW5pRTA5MAd1bmlFMDkxB3VuaUUwOTIHdW5pRTA5Mwd1bmlFMDk0B3VuaUUwOTUHdW5pRTA5Ngd1bmlFMDk3B3VuaUUxMDEHdW5pRTEwMgd1bmlFMTAzB3VuaUUxMDQHdW5pRTEwNQd1bmlFMTA2B3VuaUUxMDcHdW5pRTEwOAd1bmlFMTA5B3VuaUUxMTAHdW5pRTExMQd1bmlFMTEyB3VuaUUxMTMHdW5pRTExNAd1bmlFMTE1B3VuaUUxMTYHdW5pRTExNwd1bmlFMTE4B3VuaUUxMTkHdW5pRTEyMAd1bmlFMTIxB3VuaUUxMjIHdW5pRTEyMwd1bmlFMTI0B3VuaUUxMjUHdW5pRTEyNgd1bmlFMTI3B3VuaUUxMjgHdW5pRTEyOQd1bmlFMTMwB3VuaUUxMzEHdW5pRTEzMgd1bmlFMTMzB3VuaUUxMzQHdW5pRTEzNQd1bmlFMTM2B3VuaUUxMzcHdW5pRTEzOAd1bmlFMTM5B3VuaUUxNDAHdW5pRTE0MQd1bmlFMTQyB3VuaUUxNDMHdW5pRTE0NAd1bmlFMTQ1B3VuaUUxNDYHdW5pRTE0OAd1bmlFMTQ5B3VuaUUxNTAHdW5pRTE1MQd1bmlFMTUyB3VuaUUxNTMHdW5pRTE1NAd1bmlFMTU1B3VuaUUxNTYHdW5pRTE1Nwd1bmlFMTU4B3VuaUUxNTkHdW5pRTE2MAd1bmlFMTYxB3VuaUUxNjIHdW5pRTE2Mwd1bmlFMTY0B3VuaUUxNjUHdW5pRTE2Ngd1bmlFMTY3B3VuaUUxNjgHdW5pRTE2OQd1bmlFMTcwB3VuaUUxNzEHdW5pRTE3Mgd1bmlFMTczB3VuaUUxNzQHdW5pRTE3NQd1bmlFMTc2B3VuaUUxNzcHdW5pRTE3OAd1bmlFMTc5B3VuaUUxODAHdW5pRTE4MQd1bmlFMTgyB3VuaUUxODMHdW5pRTE4NAd1bmlFMTg1B3VuaUUxODYHdW5pRTE4Nwd1bmlFMTg4B3VuaUUxODkHdW5pRTE5MAd1bmlFMTkxB3VuaUUxOTIHdW5pRTE5Mwd1bmlFMTk0B3VuaUUxOTUHdW5pRTE5Nwd1bmlFMTk4B3VuaUUxOTkHdW5pRTIwMAd1bmlFMjAxB3VuaUUyMDIHdW5pRTIwMwd1bmlFMjA0B3VuaUUyMDUHdW5pRTIwNgd1bmlFMjA5B3VuaUUyMTAHdW5pRTIxMQd1bmlFMjEyB3VuaUUyMTMHdW5pRTIxNAd1bmlFMjE1B3VuaUUyMTYHdW5pRTIxOAd1bmlFMjE5B3VuaUUyMjEHdW5pRTIyMwd1bmlFMjI0B3VuaUUyMjUHdW5pRTIyNgd1bmlFMjI3B3VuaUUyMzAHdW5pRTIzMQd1bmlFMjMyB3VuaUUyMzMHdW5pRTIzNAd1bmlFMjM1B3VuaUUyMzYHdW5pRTIzNwd1bmlFMjM4B3VuaUUyMzkHdW5pRTI0MAd1bmlFMjQxB3VuaUUyNDIHdW5pRTI0Mwd1bmlFMjQ0B3VuaUUyNDUHdW5pRTI0Ngd1bmlFMjQ3B3VuaUUyNDgHdW5pRTI0OQd1bmlFMjUwB3VuaUUyNTEHdW5pRTI1Mgd1bmlFMjUzB3VuaUUyNTQHdW5pRTI1NQd1bmlFMjU2B3VuaUUyNTcHdW5pRTI1OAd1bmlFMjU5B3VuaUUyNjAHdW5pRjhGRgZ1MUY1MTEGdTFGNkFBAAAAAAFUUMMXAAA=) format('truetype'),url() format('svg')}.glyphicon{position:relative;top:1px;display:inline-block;font-family:'Glyphicons Halflings';font-style:normal;font-weight:400;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.glyphicon-asterisk:before{content:"\2a"}.glyphicon-plus:before{content:"\2b"}.glyphicon-eur:before,.glyphicon-euro:before{content:"\20ac"}.glyphicon-minus:before{content:"\2212"}.glyphicon-cloud:before{content:"\2601"}.glyphicon-envelope:before{content:"\2709"}.glyphicon-pencil:before{content:"\270f"}.glyphicon-glass:before{content:"\e001"}.glyphicon-music:before{content:"\e002"}.glyphicon-search:before{content:"\e003"}.glyphicon-heart:before{content:"\e005"}.glyphicon-star:before{content:"\e006"}.glyphicon-star-empty:before{content:"\e007"}.glyphicon-user:before{content:"\e008"}.glyphicon-film:before{content:"\e009"}.glyphicon-th-large:before{content:"\e010"}.glyphicon-th:before{content:"\e011"}.glyphicon-th-list:before{content:"\e012"}.glyphicon-ok:before{content:"\e013"}.glyphicon-remove:before{content:"\e014"}.glyphicon-zoom-in:before{content:"\e015"}.glyphicon-zoom-out:before{content:"\e016"}.glyphicon-off:before{content:"\e017"}.glyphicon-signal:before{content:"\e018"}.glyphicon-cog:before{content:"\e019"}.glyphicon-trash:before{content:"\e020"}.glyphicon-home:before{content:"\e021"}.glyphicon-file:before{content:"\e022"}.glyphicon-time:before{content:"\e023"}.glyphicon-road:before{content:"\e024"}.glyphicon-download-alt:before{content:"\e025"}.glyphicon-download:before{content:"\e026"}.glyphicon-upload:before{content:"\e027"}.glyphicon-inbox:before{content:"\e028"}.glyphicon-play-circle:before{content:"\e029"}.glyphicon-repeat:before{content:"\e030"}.glyphicon-refresh:before{content:"\e031"}.glyphicon-list-alt:before{content:"\e032"}.glyphicon-lock:before{content:"\e033"}.glyphicon-flag:before{content:"\e034"}.glyphicon-headphones:before{content:"\e035"}.glyphicon-volume-off:before{content:"\e036"}.glyphicon-volume-down:before{content:"\e037"}.glyphicon-volume-up:before{content:"\e038"}.glyphicon-qrcode:before{content:"\e039"}.glyphicon-barcode:before{content:"\e040"}.glyphicon-tag:before{content:"\e041"}.glyphicon-tags:before{content:"\e042"}.glyphicon-book:before{content:"\e043"}.glyphicon-bookmark:before{content:"\e044"}.glyphicon-print:before{content:"\e045"}.glyphicon-camera:before{content:"\e046"}.glyphicon-font:before{content:"\e047"}.glyphicon-bold:before{content:"\e048"}.glyphicon-italic:before{content:"\e049"}.glyphicon-text-height:before{content:"\e050"}.glyphicon-text-width:before{content:"\e051"}.glyphicon-align-left:before{content:"\e052"}.glyphicon-align-center:before{content:"\e053"}.glyphicon-align-right:before{content:"\e054"}.glyphicon-align-justify:before{content:"\e055"}.glyphicon-list:before{content:"\e056"}.glyphicon-indent-left:before{content:"\e057"}.glyphicon-indent-right:before{content:"\e058"}.glyphicon-facetime-video:before{content:"\e059"}.glyphicon-picture:before{content:"\e060"}.glyphicon-map-marker:before{content:"\e062"}.glyphicon-adjust:before{content:"\e063"}.glyphicon-tint:before{content:"\e064"}.glyphicon-edit:before{content:"\e065"}.glyphicon-share:before{content:"\e066"}.glyphicon-check:before{content:"\e067"}.glyphicon-move:before{content:"\e068"}.glyphicon-step-backward:before{content:"\e069"}.glyphicon-fast-backward:before{content:"\e070"}.glyphicon-backward:before{content:"\e071"}.glyphicon-play:before{content:"\e072"}.glyphicon-pause:before{content:"\e073"}.glyphicon-stop:before{content:"\e074"}.glyphicon-forward:before{content:"\e075"}.glyphicon-fast-forward:before{content:"\e076"}.glyphicon-step-forward:before{content:"\e077"}.glyphicon-eject:before{content:"\e078"}.glyphicon-chevron-left:before{content:"\e079"}.glyphicon-chevron-right:before{content:"\e080"}.glyphicon-plus-sign:before{content:"\e081"}.glyphicon-minus-sign:before{content:"\e082"}.glyphicon-remove-sign:before{content:"\e083"}.glyphicon-ok-sign:before{content:"\e084"}.glyphicon-question-sign:before{content:"\e085"}.glyphicon-info-sign:before{content:"\e086"}.glyphicon-screenshot:before{content:"\e087"}.glyphicon-remove-circle:before{content:"\e088"}.glyphicon-ok-circle:before{content:"\e089"}.glyphicon-ban-circle:before{content:"\e090"}.glyphicon-arrow-left:before{content:"\e091"}.glyphicon-arrow-right:before{content:"\e092"}.glyphicon-arrow-up:before{content:"\e093"}.glyphicon-arrow-down:before{content:"\e094"}.glyphicon-share-alt:before{content:"\e095"}.glyphicon-resize-full:before{content:"\e096"}.glyphicon-resize-small:before{content:"\e097"}.glyphicon-exclamation-sign:before{content:"\e101"}.glyphicon-gift:before{content:"\e102"}.glyphicon-leaf:before{content:"\e103"}.glyphicon-fire:before{content:"\e104"}.glyphicon-eye-open:before{content:"\e105"}.glyphicon-eye-close:before{content:"\e106"}.glyphicon-warning-sign:before{content:"\e107"}.glyphicon-plane:before{content:"\e108"}.glyphicon-calendar:before{content:"\e109"}.glyphicon-random:before{content:"\e110"}.glyphicon-comment:before{content:"\e111"}.glyphicon-magnet:before{content:"\e112"}.glyphicon-chevron-up:before{content:"\e113"}.glyphicon-chevron-down:before{content:"\e114"}.glyphicon-retweet:before{content:"\e115"}.glyphicon-shopping-cart:before{content:"\e116"}.glyphicon-folder-close:before{content:"\e117"}.glyphicon-folder-open:before{content:"\e118"}.glyphicon-resize-vertical:before{content:"\e119"}.glyphicon-resize-horizontal:before{content:"\e120"}.glyphicon-hdd:before{content:"\e121"}.glyphicon-bullhorn:before{content:"\e122"}.glyphicon-bell:before{content:"\e123"}.glyphicon-certificate:before{content:"\e124"}.glyphicon-thumbs-up:before{content:"\e125"}.glyphicon-thumbs-down:before{content:"\e126"}.glyphicon-hand-right:before{content:"\e127"}.glyphicon-hand-left:before{content:"\e128"}.glyphicon-hand-up:before{content:"\e129"}.glyphicon-hand-down:before{content:"\e130"}.glyphicon-circle-arrow-right:before{content:"\e131"}.glyphicon-circle-arrow-left:before{content:"\e132"}.glyphicon-circle-arrow-up:before{content:"\e133"}.glyphicon-circle-arrow-down:before{content:"\e134"}.glyphicon-globe:before{content:"\e135"}.glyphicon-wrench:before{content:"\e136"}.glyphicon-tasks:before{content:"\e137"}.glyphicon-filter:before{content:"\e138"}.glyphicon-briefcase:before{content:"\e139"}.glyphicon-fullscreen:before{content:"\e140"}.glyphicon-dashboard:before{content:"\e141"}.glyphicon-paperclip:before{content:"\e142"}.glyphicon-heart-empty:before{content:"\e143"}.glyphicon-link:before{content:"\e144"}.glyphicon-phone:before{content:"\e145"}.glyphicon-pushpin:before{content:"\e146"}.glyphicon-usd:before{content:"\e148"}.glyphicon-gbp:before{content:"\e149"}.glyphicon-sort:before{content:"\e150"}.glyphicon-sort-by-alphabet:before{content:"\e151"}.glyphicon-sort-by-alphabet-alt:before{content:"\e152"}.glyphicon-sort-by-order:before{content:"\e153"}.glyphicon-sort-by-order-alt:before{content:"\e154"}.glyphicon-sort-by-attributes:before{content:"\e155"}.glyphicon-sort-by-attributes-alt:before{content:"\e156"}.glyphicon-unchecked:before{content:"\e157"}.glyphicon-expand:before{content:"\e158"}.glyphicon-collapse-down:before{content:"\e159"}.glyphicon-collapse-up:before{content:"\e160"}.glyphicon-log-in:before{content:"\e161"}.glyphicon-flash:before{content:"\e162"}.glyphicon-log-out:before{content:"\e163"}.glyphicon-new-window:before{content:"\e164"}.glyphicon-record:before{content:"\e165"}.glyphicon-save:before{content:"\e166"}.glyphicon-open:before{content:"\e167"}.glyphicon-saved:before{content:"\e168"}.glyphicon-import:before{content:"\e169"}.glyphicon-export:before{content:"\e170"}.glyphicon-send:before{content:"\e171"}.glyphicon-floppy-disk:before{content:"\e172"}.glyphicon-floppy-saved:before{content:"\e173"}.glyphicon-floppy-remove:before{content:"\e174"}.glyphicon-floppy-save:before{content:"\e175"}.glyphicon-floppy-open:before{content:"\e176"}.glyphicon-credit-card:before{content:"\e177"}.glyphicon-transfer:before{content:"\e178"}.glyphicon-cutlery:before{content:"\e179"}.glyphicon-header:before{content:"\e180"}.glyphicon-compressed:before{content:"\e181"}.glyphicon-earphone:before{content:"\e182"}.glyphicon-phone-alt:before{content:"\e183"}.glyphicon-tower:before{content:"\e184"}.glyphicon-stats:before{content:"\e185"}.glyphicon-sd-video:before{content:"\e186"}.glyphicon-hd-video:before{content:"\e187"}.glyphicon-subtitles:before{content:"\e188"}.glyphicon-sound-stereo:before{content:"\e189"}.glyphicon-sound-dolby:before{content:"\e190"}.glyphicon-sound-5-1:before{content:"\e191"}.glyphicon-sound-6-1:before{content:"\e192"}.glyphicon-sound-7-1:before{content:"\e193"}.glyphicon-copyright-mark:before{content:"\e194"}.glyphicon-registration-mark:before{content:"\e195"}.glyphicon-cloud-download:before{content:"\e197"}.glyphicon-cloud-upload:before{content:"\e198"}.glyphicon-tree-conifer:before{content:"\e199"}.glyphicon-tree-deciduous:before{content:"\e200"}.glyphicon-cd:before{content:"\e201"}.glyphicon-save-file:before{content:"\e202"}.glyphicon-open-file:before{content:"\e203"}.glyphicon-level-up:before{content:"\e204"}.glyphicon-copy:before{content:"\e205"}.glyphicon-paste:before{content:"\e206"}.glyphicon-alert:before{content:"\e209"}.glyphicon-equalizer:before{content:"\e210"}.glyphicon-king:before{content:"\e211"}.glyphicon-queen:before{content:"\e212"}.glyphicon-pawn:before{content:"\e213"}.glyphicon-bishop:before{content:"\e214"}.glyphicon-knight:before{content:"\e215"}.glyphicon-baby-formula:before{content:"\e216"}.glyphicon-tent:before{content:"\26fa"}.glyphicon-blackboard:before{content:"\e218"}.glyphicon-bed:before{content:"\e219"}.glyphicon-apple:before{content:"\f8ff"}.glyphicon-erase:before{content:"\e221"}.glyphicon-hourglass:before{content:"\231b"}.glyphicon-lamp:before{content:"\e223"}.glyphicon-duplicate:before{content:"\e224"}.glyphicon-piggy-bank:before{content:"\e225"}.glyphicon-scissors:before{content:"\e226"}.glyphicon-bitcoin:before{content:"\e227"}.glyphicon-btc:before{content:"\e227"}.glyphicon-xbt:before{content:"\e227"}.glyphicon-yen:before{content:"\00a5"}.glyphicon-jpy:before{content:"\00a5"}.glyphicon-ruble:before{content:"\20bd"}.glyphicon-rub:before{content:"\20bd"}.glyphicon-scale:before{content:"\e230"}.glyphicon-ice-lolly:before{content:"\e231"}.glyphicon-ice-lolly-tasted:before{content:"\e232"}.glyphicon-education:before{content:"\e233"}.glyphicon-option-horizontal:before{content:"\e234"}.glyphicon-option-vertical:before{content:"\e235"}.glyphicon-menu-hamburger:before{content:"\e236"}.glyphicon-modal-window:before{content:"\e237"}.glyphicon-oil:before{content:"\e238"}.glyphicon-grain:before{content:"\e239"}.glyphicon-sunglasses:before{content:"\e240"}.glyphicon-text-size:before{content:"\e241"}.glyphicon-text-color:before{content:"\e242"}.glyphicon-text-background:before{content:"\e243"}.glyphicon-object-align-top:before{content:"\e244"}.glyphicon-object-align-bottom:before{content:"\e245"}.glyphicon-object-align-horizontal:before{content:"\e246"}.glyphicon-object-align-left:before{content:"\e247"}.glyphicon-object-align-vertical:before{content:"\e248"}.glyphicon-object-align-right:before{content:"\e249"}.glyphicon-triangle-right:before{content:"\e250"}.glyphicon-triangle-left:before{content:"\e251"}.glyphicon-triangle-bottom:before{content:"\e252"}.glyphicon-triangle-top:before{content:"\e253"}.glyphicon-console:before{content:"\e254"}.glyphicon-superscript:before{content:"\e255"}.glyphicon-subscript:before{content:"\e256"}.glyphicon-menu-left:before{content:"\e257"}.glyphicon-menu-right:before{content:"\e258"}.glyphicon-menu-down:before{content:"\e259"}.glyphicon-menu-up:before{content:"\e260"}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}:after,:before{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:10px;-webkit-tap-highlight-color:rgba(0,0,0,0)}body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;line-height:1.42857143;color:#333;background-color:#fff}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}a{color:#337ab7;text-decoration:none}a:focus,a:hover{color:#23527c;text-decoration:underline}a:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}figure{margin:0}img{vertical-align:middle}.carousel-inner>.item>a>img,.carousel-inner>.item>img,.img-responsive,.thumbnail a>img,.thumbnail>img{display:block;max-width:100%;height:auto}.img-rounded{border-radius:6px}.img-thumbnail{display:inline-block;max-width:100%;height:auto;padding:4px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:all .2s ease-in-out;-o-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.img-circle{border-radius:50%}hr{margin-top:20px;margin-bottom:20px;border:0;border-top:1px solid #eee}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}[role=button]{cursor:pointer}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:inherit;font-weight:500;line-height:1.1;color:inherit}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-weight:400;line-height:1;color:#777}.h1,.h2,.h3,h1,h2,h3{margin-top:20px;margin-bottom:10px}.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small{font-size:65%}.h4,.h5,.h6,h4,h5,h6{margin-top:10px;margin-bottom:10px}.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small{font-size:75%}.h1,h1{font-size:36px}.h2,h2{font-size:30px}.h3,h3{font-size:24px}.h4,h4{font-size:18px}.h5,h5{font-size:14px}.h6,h6{font-size:12px}p{margin:0 0 10px}.lead{margin-bottom:20px;font-size:16px;font-weight:300;line-height:1.4}@media (min-width:768px){.lead{font-size:21px}}.small,small{font-size:85%}.mark,mark{padding:.2em;background-color:#fcf8e3}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}.text-nowrap{white-space:nowrap}.text-lowercase{text-transform:lowercase}.text-uppercase{text-transform:uppercase}.text-capitalize{text-transform:capitalize}.text-muted{color:#777}.text-primary{color:#337ab7}a.text-primary:focus,a.text-primary:hover{color:#286090}.text-success{color:#3c763d}a.text-success:focus,a.text-success:hover{color:#2b542c}.text-info{color:#31708f}a.text-info:focus,a.text-info:hover{color:#245269}.text-warning{color:#8a6d3b}a.text-warning:focus,a.text-warning:hover{color:#66512c}.text-danger{color:#a94442}a.text-danger:focus,a.text-danger:hover{color:#843534}.bg-primary{color:#fff;background-color:#337ab7}a.bg-primary:focus,a.bg-primary:hover{background-color:#286090}.bg-success{background-color:#dff0d8}a.bg-success:focus,a.bg-success:hover{background-color:#c1e2b3}.bg-info{background-color:#d9edf7}a.bg-info:focus,a.bg-info:hover{background-color:#afd9ee}.bg-warning{background-color:#fcf8e3}a.bg-warning:focus,a.bg-warning:hover{background-color:#f7ecb5}.bg-danger{background-color:#f2dede}a.bg-danger:focus,a.bg-danger:hover{background-color:#e4b9b9}.page-header{padding-bottom:9px;margin:40px 0 20px;border-bottom:1px solid #eee}ol,ul{margin-top:0;margin-bottom:10px}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;margin-left:-5px;list-style:none}.list-inline>li{display:inline-block;padding-right:5px;padding-left:5px}dl{margin-top:0;margin-bottom:20px}dd,dt{line-height:1.42857143}dt{font-weight:700}dd{margin-left:0}@media (min-width:768px){.dl-horizontal dt{float:left;width:160px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:180px}}abbr[data-original-title],abbr[title]{cursor:help;border-bottom:1px dotted #777}.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:10px 20px;margin:0 0 20px;font-size:17.5px;border-left:5px solid #eee}blockquote ol:last-child,blockquote p:last-child,blockquote ul:last-child{margin-bottom:0}blockquote .small,blockquote footer,blockquote small{display:block;font-size:80%;line-height:1.42857143;color:#777}blockquote .small:before,blockquote footer:before,blockquote small:before{content:'\2014 \00A0'}.blockquote-reverse,blockquote.pull-right{padding-right:15px;padding-left:0;text-align:right;border-right:5px solid #eee;border-left:0}.blockquote-reverse .small:before,.blockquote-reverse footer:before,.blockquote-reverse small:before,blockquote.pull-right .small:before,blockquote.pull-right footer:before,blockquote.pull-right small:before{content:''}.blockquote-reverse .small:after,.blockquote-reverse footer:after,.blockquote-reverse small:after,blockquote.pull-right .small:after,blockquote.pull-right footer:after,blockquote.pull-right small:after{content:'\00A0 \2014'}address{margin-bottom:20px;font-style:normal;line-height:1.42857143}code,kbd,pre,samp{font-family:monospace}code{padding:2px 4px;font-size:90%;color:#c7254e;background-color:#f9f2f4;border-radius:4px}kbd{padding:2px 4px;font-size:90%;color:#fff;background-color:#333;border-radius:3px;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.25);box-shadow:inset 0 -1px 0 rgba(0,0,0,.25)}kbd kbd{padding:0;font-size:100%;font-weight:700;-webkit-box-shadow:none;box-shadow:none}pre{display:block;padding:9.5px;margin:0 0 10px;font-size:13px;line-height:1.42857143;color:#333;word-break:break-all;word-wrap:break-word;background-color:#f5f5f5;border:1px solid #ccc;border-radius:4px}pre code{padding:0;font-size:inherit;color:inherit;white-space:pre-wrap;background-color:transparent;border-radius:0}.pre-scrollable{max-height:340px;overflow-y:scroll}.container{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}@media (min-width:768px){.container{width:750px}}@media (min-width:992px){.container{width:970px}}@media (min-width:1200px){.container{width:1170px}}.container-fluid{padding-right:15px;padding-left:15px;margin-right:auto;margin-left:auto}.row{margin-right:-15px;margin-left:-15px}.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9,.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9,.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9,.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{position:relative;min-height:1px;padding-right:15px;padding-left:15px}.col-xs-1,.col-xs-10,.col-xs-11,.col-xs-12,.col-xs-2,.col-xs-3,.col-xs-4,.col-xs-5,.col-xs-6,.col-xs-7,.col-xs-8,.col-xs-9{float:left}.col-xs-12{width:100%}.col-xs-11{width:91.66666667%}.col-xs-10{width:83.33333333%}.col-xs-9{width:75%}.col-xs-8{width:66.66666667%}.col-xs-7{width:58.33333333%}.col-xs-6{width:50%}.col-xs-5{width:41.66666667%}.col-xs-4{width:33.33333333%}.col-xs-3{width:25%}.col-xs-2{width:16.66666667%}.col-xs-1{width:8.33333333%}.col-xs-pull-12{right:100%}.col-xs-pull-11{right:91.66666667%}.col-xs-pull-10{right:83.33333333%}.col-xs-pull-9{right:75%}.col-xs-pull-8{right:66.66666667%}.col-xs-pull-7{right:58.33333333%}.col-xs-pull-6{right:50%}.col-xs-pull-5{right:41.66666667%}.col-xs-pull-4{right:33.33333333%}.col-xs-pull-3{right:25%}.col-xs-pull-2{right:16.66666667%}.col-xs-pull-1{right:8.33333333%}.col-xs-pull-0{right:auto}.col-xs-push-12{left:100%}.col-xs-push-11{left:91.66666667%}.col-xs-push-10{left:83.33333333%}.col-xs-push-9{left:75%}.col-xs-push-8{left:66.66666667%}.col-xs-push-7{left:58.33333333%}.col-xs-push-6{left:50%}.col-xs-push-5{left:41.66666667%}.col-xs-push-4{left:33.33333333%}.col-xs-push-3{left:25%}.col-xs-push-2{left:16.66666667%}.col-xs-push-1{left:8.33333333%}.col-xs-push-0{left:auto}.col-xs-offset-12{margin-left:100%}.col-xs-offset-11{margin-left:91.66666667%}.col-xs-offset-10{margin-left:83.33333333%}.col-xs-offset-9{margin-left:75%}.col-xs-offset-8{margin-left:66.66666667%}.col-xs-offset-7{margin-left:58.33333333%}.col-xs-offset-6{margin-left:50%}.col-xs-offset-5{margin-left:41.66666667%}.col-xs-offset-4{margin-left:33.33333333%}.col-xs-offset-3{margin-left:25%}.col-xs-offset-2{margin-left:16.66666667%}.col-xs-offset-1{margin-left:8.33333333%}.col-xs-offset-0{margin-left:0}@media (min-width:768px){.col-sm-1,.col-sm-10,.col-sm-11,.col-sm-12,.col-sm-2,.col-sm-3,.col-sm-4,.col-sm-5,.col-sm-6,.col-sm-7,.col-sm-8,.col-sm-9{float:left}.col-sm-12{width:100%}.col-sm-11{width:91.66666667%}.col-sm-10{width:83.33333333%}.col-sm-9{width:75%}.col-sm-8{width:66.66666667%}.col-sm-7{width:58.33333333%}.col-sm-6{width:50%}.col-sm-5{width:41.66666667%}.col-sm-4{width:33.33333333%}.col-sm-3{width:25%}.col-sm-2{width:16.66666667%}.col-sm-1{width:8.33333333%}.col-sm-pull-12{right:100%}.col-sm-pull-11{right:91.66666667%}.col-sm-pull-10{right:83.33333333%}.col-sm-pull-9{right:75%}.col-sm-pull-8{right:66.66666667%}.col-sm-pull-7{right:58.33333333%}.col-sm-pull-6{right:50%}.col-sm-pull-5{right:41.66666667%}.col-sm-pull-4{right:33.33333333%}.col-sm-pull-3{right:25%}.col-sm-pull-2{right:16.66666667%}.col-sm-pull-1{right:8.33333333%}.col-sm-pull-0{right:auto}.col-sm-push-12{left:100%}.col-sm-push-11{left:91.66666667%}.col-sm-push-10{left:83.33333333%}.col-sm-push-9{left:75%}.col-sm-push-8{left:66.66666667%}.col-sm-push-7{left:58.33333333%}.col-sm-push-6{left:50%}.col-sm-push-5{left:41.66666667%}.col-sm-push-4{left:33.33333333%}.col-sm-push-3{left:25%}.col-sm-push-2{left:16.66666667%}.col-sm-push-1{left:8.33333333%}.col-sm-push-0{left:auto}.col-sm-offset-12{margin-left:100%}.col-sm-offset-11{margin-left:91.66666667%}.col-sm-offset-10{margin-left:83.33333333%}.col-sm-offset-9{margin-left:75%}.col-sm-offset-8{margin-left:66.66666667%}.col-sm-offset-7{margin-left:58.33333333%}.col-sm-offset-6{margin-left:50%}.col-sm-offset-5{margin-left:41.66666667%}.col-sm-offset-4{margin-left:33.33333333%}.col-sm-offset-3{margin-left:25%}.col-sm-offset-2{margin-left:16.66666667%}.col-sm-offset-1{margin-left:8.33333333%}.col-sm-offset-0{margin-left:0}}@media (min-width:992px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:left}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}.col-md-pull-12{right:100%}.col-md-pull-11{right:91.66666667%}.col-md-pull-10{right:83.33333333%}.col-md-pull-9{right:75%}.col-md-pull-8{right:66.66666667%}.col-md-pull-7{right:58.33333333%}.col-md-pull-6{right:50%}.col-md-pull-5{right:41.66666667%}.col-md-pull-4{right:33.33333333%}.col-md-pull-3{right:25%}.col-md-pull-2{right:16.66666667%}.col-md-pull-1{right:8.33333333%}.col-md-pull-0{right:auto}.col-md-push-12{left:100%}.col-md-push-11{left:91.66666667%}.col-md-push-10{left:83.33333333%}.col-md-push-9{left:75%}.col-md-push-8{left:66.66666667%}.col-md-push-7{left:58.33333333%}.col-md-push-6{left:50%}.col-md-push-5{left:41.66666667%}.col-md-push-4{left:33.33333333%}.col-md-push-3{left:25%}.col-md-push-2{left:16.66666667%}.col-md-push-1{left:8.33333333%}.col-md-push-0{left:auto}.col-md-offset-12{margin-left:100%}.col-md-offset-11{margin-left:91.66666667%}.col-md-offset-10{margin-left:83.33333333%}.col-md-offset-9{margin-left:75%}.col-md-offset-8{margin-left:66.66666667%}.col-md-offset-7{margin-left:58.33333333%}.col-md-offset-6{margin-left:50%}.col-md-offset-5{margin-left:41.66666667%}.col-md-offset-4{margin-left:33.33333333%}.col-md-offset-3{margin-left:25%}.col-md-offset-2{margin-left:16.66666667%}.col-md-offset-1{margin-left:8.33333333%}.col-md-offset-0{margin-left:0}}@media (min-width:1200px){.col-lg-1,.col-lg-10,.col-lg-11,.col-lg-12,.col-lg-2,.col-lg-3,.col-lg-4,.col-lg-5,.col-lg-6,.col-lg-7,.col-lg-8,.col-lg-9{float:left}.col-lg-12{width:100%}.col-lg-11{width:91.66666667%}.col-lg-10{width:83.33333333%}.col-lg-9{width:75%}.col-lg-8{width:66.66666667%}.col-lg-7{width:58.33333333%}.col-lg-6{width:50%}.col-lg-5{width:41.66666667%}.col-lg-4{width:33.33333333%}.col-lg-3{width:25%}.col-lg-2{width:16.66666667%}.col-lg-1{width:8.33333333%}.col-lg-pull-12{right:100%}.col-lg-pull-11{right:91.66666667%}.col-lg-pull-10{right:83.33333333%}.col-lg-pull-9{right:75%}.col-lg-pull-8{right:66.66666667%}.col-lg-pull-7{right:58.33333333%}.col-lg-pull-6{right:50%}.col-lg-pull-5{right:41.66666667%}.col-lg-pull-4{right:33.33333333%}.col-lg-pull-3{right:25%}.col-lg-pull-2{right:16.66666667%}.col-lg-pull-1{right:8.33333333%}.col-lg-pull-0{right:auto}.col-lg-push-12{left:100%}.col-lg-push-11{left:91.66666667%}.col-lg-push-10{left:83.33333333%}.col-lg-push-9{left:75%}.col-lg-push-8{left:66.66666667%}.col-lg-push-7{left:58.33333333%}.col-lg-push-6{left:50%}.col-lg-push-5{left:41.66666667%}.col-lg-push-4{left:33.33333333%}.col-lg-push-3{left:25%}.col-lg-push-2{left:16.66666667%}.col-lg-push-1{left:8.33333333%}.col-lg-push-0{left:auto}.col-lg-offset-12{margin-left:100%}.col-lg-offset-11{margin-left:91.66666667%}.col-lg-offset-10{margin-left:83.33333333%}.col-lg-offset-9{margin-left:75%}.col-lg-offset-8{margin-left:66.66666667%}.col-lg-offset-7{margin-left:58.33333333%}.col-lg-offset-6{margin-left:50%}.col-lg-offset-5{margin-left:41.66666667%}.col-lg-offset-4{margin-left:33.33333333%}.col-lg-offset-3{margin-left:25%}.col-lg-offset-2{margin-left:16.66666667%}.col-lg-offset-1{margin-left:8.33333333%}.col-lg-offset-0{margin-left:0}}table{background-color:transparent}caption{padding-top:8px;padding-bottom:8px;color:#777;text-align:left}th{}.table{width:100%;max-width:100%;margin-bottom:20px}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}.table>thead>tr>th{vertical-align:bottom;border-bottom:2px solid #ddd}.table>caption+thead>tr:first-child>td,.table>caption+thead>tr:first-child>th,.table>colgroup+thead>tr:first-child>td,.table>colgroup+thead>tr:first-child>th,.table>thead:first-child>tr:first-child>td,.table>thead:first-child>tr:first-child>th{border-top:0}.table>tbody+tbody{border-top:2px solid #ddd}.table .table{background-color:#fff}.table-condensed>tbody>tr>td,.table-condensed>tbody>tr>th,.table-condensed>tfoot>tr>td,.table-condensed>tfoot>tr>th,.table-condensed>thead>tr>td,.table-condensed>thead>tr>th{padding:5px}.table-bordered{border:1px solid #ddd}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border-bottom-width:2px}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}.table-hover>tbody>tr:hover{background-color:#f5f5f5}table col[class*=col-]{position:static;display:table-column;float:none}table td[class*=col-],table th[class*=col-]{position:static;display:table-cell;float:none}.table>tbody>tr.active>td,.table>tbody>tr.active>th,.table>tbody>tr>td.active,.table>tbody>tr>th.active,.table>tfoot>tr.active>td,.table>tfoot>tr.active>th,.table>tfoot>tr>td.active,.table>tfoot>tr>th.active,.table>thead>tr.active>td,.table>thead>tr.active>th,.table>thead>tr>td.active,.table>thead>tr>th.active{background-color:#f5f5f5}.table-hover>tbody>tr.active:hover>td,.table-hover>tbody>tr.active:hover>th,.table-hover>tbody>tr:hover>.active,.table-hover>tbody>tr>td.active:hover,.table-hover>tbody>tr>th.active:hover{background-color:#e8e8e8}.table>tbody>tr.success>td,.table>tbody>tr.success>th,.table>tbody>tr>td.success,.table>tbody>tr>th.success,.table>tfoot>tr.success>td,.table>tfoot>tr.success>th,.table>tfoot>tr>td.success,.table>tfoot>tr>th.success,.table>thead>tr.success>td,.table>thead>tr.success>th,.table>thead>tr>td.success,.table>thead>tr>th.success{background-color:#dff0d8}.table-hover>tbody>tr.success:hover>td,.table-hover>tbody>tr.success:hover>th,.table-hover>tbody>tr:hover>.success,.table-hover>tbody>tr>td.success:hover,.table-hover>tbody>tr>th.success:hover{background-color:#d0e9c6}.table>tbody>tr.info>td,.table>tbody>tr.info>th,.table>tbody>tr>td.info,.table>tbody>tr>th.info,.table>tfoot>tr.info>td,.table>tfoot>tr.info>th,.table>tfoot>tr>td.info,.table>tfoot>tr>th.info,.table>thead>tr.info>td,.table>thead>tr.info>th,.table>thead>tr>td.info,.table>thead>tr>th.info{background-color:#d9edf7}.table-hover>tbody>tr.info:hover>td,.table-hover>tbody>tr.info:hover>th,.table-hover>tbody>tr:hover>.info,.table-hover>tbody>tr>td.info:hover,.table-hover>tbody>tr>th.info:hover{background-color:#c4e3f3}.table>tbody>tr.warning>td,.table>tbody>tr.warning>th,.table>tbody>tr>td.warning,.table>tbody>tr>th.warning,.table>tfoot>tr.warning>td,.table>tfoot>tr.warning>th,.table>tfoot>tr>td.warning,.table>tfoot>tr>th.warning,.table>thead>tr.warning>td,.table>thead>tr.warning>th,.table>thead>tr>td.warning,.table>thead>tr>th.warning{background-color:#fcf8e3}.table-hover>tbody>tr.warning:hover>td,.table-hover>tbody>tr.warning:hover>th,.table-hover>tbody>tr:hover>.warning,.table-hover>tbody>tr>td.warning:hover,.table-hover>tbody>tr>th.warning:hover{background-color:#faf2cc}.table>tbody>tr.danger>td,.table>tbody>tr.danger>th,.table>tbody>tr>td.danger,.table>tbody>tr>th.danger,.table>tfoot>tr.danger>td,.table>tfoot>tr.danger>th,.table>tfoot>tr>td.danger,.table>tfoot>tr>th.danger,.table>thead>tr.danger>td,.table>thead>tr.danger>th,.table>thead>tr>td.danger,.table>thead>tr>th.danger{background-color:#f2dede}.table-hover>tbody>tr.danger:hover>td,.table-hover>tbody>tr.danger:hover>th,.table-hover>tbody>tr:hover>.danger,.table-hover>tbody>tr>td.danger:hover,.table-hover>tbody>tr>th.danger:hover{background-color:#ebcccc}.table-responsive{min-height:.01%;overflow-x:auto}@media screen and (max-width:767px){.table-responsive{width:100%;margin-bottom:15px;overflow-y:hidden;-ms-overflow-style:-ms-autohiding-scrollbar;border:1px solid #ddd}.table-responsive>.table{margin-bottom:0}.table-responsive>.table>tbody>tr>td,.table-responsive>.table>tbody>tr>th,.table-responsive>.table>tfoot>tr>td,.table-responsive>.table>tfoot>tr>th,.table-responsive>.table>thead>tr>td,.table-responsive>.table>thead>tr>th{white-space:nowrap}.table-responsive>.table-bordered{border:0}.table-responsive>.table-bordered>tbody>tr>td:first-child,.table-responsive>.table-bordered>tbody>tr>th:first-child,.table-responsive>.table-bordered>tfoot>tr>td:first-child,.table-responsive>.table-bordered>tfoot>tr>th:first-child,.table-responsive>.table-bordered>thead>tr>td:first-child,.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.table-responsive>.table-bordered>tbody>tr>td:last-child,.table-responsive>.table-bordered>tbody>tr>th:last-child,.table-responsive>.table-bordered>tfoot>tr>td:last-child,.table-responsive>.table-bordered>tfoot>tr>th:last-child,.table-responsive>.table-bordered>thead>tr>td:last-child,.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.table-responsive>.table-bordered>tbody>tr:last-child>td,.table-responsive>.table-bordered>tbody>tr:last-child>th,.table-responsive>.table-bordered>tfoot>tr:last-child>td,.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}}fieldset{min-width:0;padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:20px;font-size:21px;line-height:inherit;color:#333;border:0;border-bottom:1px solid #e5e5e5}label{display:inline-block;max-width:100%;margin-bottom:5px;font-weight:700}input[type=search]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}input[type=checkbox],input[type=radio]{margin:4px 0 0;margin-top:1px\9;line-height:normal}input[type=file]{display:block}input[type=range]{display:block;width:100%}select[multiple],select[size]{height:auto}input[type=file]:focus,input[type=checkbox]:focus,input[type=radio]:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}output{display:block;padding-top:7px;font-size:14px;line-height:1.42857143;color:#555}.form-control{display:block;width:100%;height:34px;padding:6px 12px;font-size:14px;line-height:1.42857143;color:#555;background-color:#fff;background-image:none;border:1px solid #ccc;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075);-webkit-transition:border-color ease-in-out .15s,-webkit-box-shadow ease-in-out .15s;-o-transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s;transition:border-color ease-in-out .15s,box-shadow ease-in-out .15s}.form-control:focus{border-color:#66afe9;outline:0;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6);box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 8px rgba(102,175,233,.6)}.form-control::-moz-placeholder{color:#999;opacity:1}.form-control:-ms-input-placeholder{color:#999}.form-control::-webkit-input-placeholder{color:#999}.form-control[disabled],.form-control[readonly],fieldset[disabled] .form-control{background-color:#eee;opacity:1}.form-control[disabled],fieldset[disabled] .form-control{cursor:not-allowed}textarea.form-control{height:auto}input[type=search]{-webkit-appearance:none}@media screen and (-webkit-min-device-pixel-ratio:0){input[type=date].form-control,input[type=time].form-control,input[type=datetime-local].form-control,input[type=month].form-control{line-height:34px}.input-group-sm input[type=date],.input-group-sm input[type=time],.input-group-sm input[type=datetime-local],.input-group-sm input[type=month],input[type=date].input-sm,input[type=time].input-sm,input[type=datetime-local].input-sm,input[type=month].input-sm{line-height:30px}.input-group-lg input[type=date],.input-group-lg input[type=time],.input-group-lg input[type=datetime-local],.input-group-lg input[type=month],input[type=date].input-lg,input[type=time].input-lg,input[type=datetime-local].input-lg,input[type=month].input-lg{line-height:46px}}.form-group{margin-bottom:15px}.checkbox,.radio{position:relative;display:block;margin-top:10px;margin-bottom:10px}.checkbox label,.radio label{min-height:20px;padding-left:20px;margin-bottom:0;font-weight:400;cursor:pointer}.checkbox input[type=checkbox],.checkbox-inline input[type=checkbox],.radio input[type=radio],.radio-inline input[type=radio]{position:absolute;margin-top:4px\9;margin-left:-20px}.checkbox+.checkbox,.radio+.radio{margin-top:-5px}.checkbox-inline,.radio-inline{position:relative;display:inline-block;padding-left:20px;margin-bottom:0;font-weight:400;vertical-align:middle;cursor:pointer}.checkbox-inline+.checkbox-inline,.radio-inline+.radio-inline{margin-top:0;margin-left:10px}fieldset[disabled] input[type=checkbox],fieldset[disabled] input[type=radio],input[type=checkbox].disabled,input[type=checkbox][disabled],input[type=radio].disabled,input[type=radio][disabled]{cursor:not-allowed}.checkbox-inline.disabled,.radio-inline.disabled,fieldset[disabled] .checkbox-inline,fieldset[disabled] .radio-inline{cursor:not-allowed}.checkbox.disabled label,.radio.disabled label,fieldset[disabled] .checkbox label,fieldset[disabled] .radio label{cursor:not-allowed}.form-control-static{min-height:34px;padding-top:7px;padding-bottom:7px;margin-bottom:0}.form-control-static.input-lg,.form-control-static.input-sm{padding-right:0;padding-left:0}.input-sm{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-sm{height:30px;line-height:30px}select[multiple].input-sm,textarea.input-sm{height:auto}.form-group-sm .form-control{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.form-group-sm select.form-control{height:30px;line-height:30px}.form-group-sm select[multiple].form-control,.form-group-sm textarea.form-control{height:auto}.form-group-sm .form-control-static{height:30px;min-height:32px;padding:6px 10px;font-size:12px;line-height:1.5}.input-lg{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-lg{height:46px;line-height:46px}select[multiple].input-lg,textarea.input-lg{height:auto}.form-group-lg .form-control{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.form-group-lg select.form-control{height:46px;line-height:46px}.form-group-lg select[multiple].form-control,.form-group-lg textarea.form-control{height:auto}.form-group-lg .form-control-static{height:46px;min-height:38px;padding:11px 16px;font-size:18px;line-height:1.3333333}.has-feedback{position:relative}.has-feedback .form-control{padding-right:42.5px}.form-control-feedback{position:absolute;top:0;right:0;z-index:2;display:block;width:34px;height:34px;line-height:34px;text-align:center;pointer-events:none}.form-group-lg .form-control+.form-control-feedback,.input-group-lg+.form-control-feedback,.input-lg+.form-control-feedback{width:46px;height:46px;line-height:46px}.form-group-sm .form-control+.form-control-feedback,.input-group-sm+.form-control-feedback,.input-sm+.form-control-feedback{width:30px;height:30px;line-height:30px}.has-success .checkbox,.has-success .checkbox-inline,.has-success .control-label,.has-success .help-block,.has-success .radio,.has-success .radio-inline,.has-success.checkbox label,.has-success.checkbox-inline label,.has-success.radio label,.has-success.radio-inline label{color:#3c763d}.has-success .form-control{border-color:#3c763d;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-success .form-control:focus{border-color:#2b542c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #67b168}.has-success .input-group-addon{color:#3c763d;background-color:#dff0d8;border-color:#3c763d}.has-success .form-control-feedback{color:#3c763d}.has-warning .checkbox,.has-warning .checkbox-inline,.has-warning .control-label,.has-warning .help-block,.has-warning .radio,.has-warning .radio-inline,.has-warning.checkbox label,.has-warning.checkbox-inline label,.has-warning.radio label,.has-warning.radio-inline label{color:#8a6d3b}.has-warning .form-control{border-color:#8a6d3b;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-warning .form-control:focus{border-color:#66512c;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #c0a16b}.has-warning .input-group-addon{color:#8a6d3b;background-color:#fcf8e3;border-color:#8a6d3b}.has-warning .form-control-feedback{color:#8a6d3b}.has-error .checkbox,.has-error .checkbox-inline,.has-error .control-label,.has-error .help-block,.has-error .radio,.has-error .radio-inline,.has-error.checkbox label,.has-error.checkbox-inline label,.has-error.radio label,.has-error.radio-inline label{color:#a94442}.has-error .form-control{border-color:#a94442;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075);box-shadow:inset 0 1px 1px rgba(0,0,0,.075)}.has-error .form-control:focus{border-color:#843534;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483;box-shadow:inset 0 1px 1px rgba(0,0,0,.075),0 0 6px #ce8483}.has-error .input-group-addon{color:#a94442;background-color:#f2dede;border-color:#a94442}.has-error .form-control-feedback{color:#a94442}.has-feedback label~.form-control-feedback{top:25px}.has-feedback label.sr-only~.form-control-feedback{top:0}.help-block{display:block;margin-top:5px;margin-bottom:10px;color:#737373}@media (min-width:768px){.form-inline .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.form-inline .form-control{display:inline-block;width:auto;vertical-align:middle}.form-inline .form-control-static{display:inline-block}.form-inline .input-group{display:inline-table;vertical-align:middle}.form-inline .input-group .form-control,.form-inline .input-group .input-group-addon,.form-inline .input-group .input-group-btn{width:auto}.form-inline .input-group>.form-control{width:100%}.form-inline .control-label{margin-bottom:0;vertical-align:middle}.form-inline .checkbox,.form-inline .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.form-inline .checkbox label,.form-inline .radio label{padding-left:0}.form-inline .checkbox input[type=checkbox],.form-inline .radio input[type=radio]{position:relative;margin-left:0}.form-inline .has-feedback .form-control-feedback{top:0}}.form-horizontal .checkbox,.form-horizontal .checkbox-inline,.form-horizontal .radio,.form-horizontal .radio-inline{padding-top:7px;margin-top:0;margin-bottom:0}.form-horizontal .checkbox,.form-horizontal .radio{min-height:27px}.form-horizontal .form-group{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.form-horizontal .control-label{padding-top:7px;margin-bottom:0;text-align:right}}.form-horizontal .has-feedback .form-control-feedback{right:15px}@media (min-width:768px){.form-horizontal .form-group-lg .control-label{padding-top:14.33px;font-size:18px}}@media (min-width:768px){.form-horizontal .form-group-sm .control-label{padding-top:6px;font-size:12px}}.btn{display:inline-block;padding:6px 12px;margin-bottom:0;font-size:14px;font-weight:400;line-height:1.42857143;text-align:center;white-space:nowrap;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-image:none;border:1px solid transparent;border-radius:4px}.btn.active.focus,.btn.active:focus,.btn.focus,.btn:active.focus,.btn:active:focus,.btn:focus{outline:thin dotted;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn.focus,.btn:focus,.btn:hover{color:#333;text-decoration:none}.btn.active,.btn:active{background-image:none;outline:0;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn.disabled,.btn[disabled],fieldset[disabled] .btn{cursor:not-allowed;filter:alpha(opacity=65);-webkit-box-shadow:none;box-shadow:none;opacity:.65}a.btn.disabled,fieldset[disabled] a.btn{pointer-events:none}.btn-default{color:#333;background-color:#fff;border-color:#ccc}.btn-default.focus,.btn-default:focus{color:#333;background-color:#e6e6e6;border-color:#8c8c8c}.btn-default:hover{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active,.btn-default:active,.open>.dropdown-toggle.btn-default{color:#333;background-color:#e6e6e6;border-color:#adadad}.btn-default.active.focus,.btn-default.active:focus,.btn-default.active:hover,.btn-default:active.focus,.btn-default:active:focus,.btn-default:active:hover,.open>.dropdown-toggle.btn-default.focus,.open>.dropdown-toggle.btn-default:focus,.open>.dropdown-toggle.btn-default:hover{color:#333;background-color:#d4d4d4;border-color:#8c8c8c}.btn-default.active,.btn-default:active,.open>.dropdown-toggle.btn-default{background-image:none}.btn-default.disabled,.btn-default.disabled.active,.btn-default.disabled.focus,.btn-default.disabled:active,.btn-default.disabled:focus,.btn-default.disabled:hover,.btn-default[disabled],.btn-default[disabled].active,.btn-default[disabled].focus,.btn-default[disabled]:active,.btn-default[disabled]:focus,.btn-default[disabled]:hover,fieldset[disabled] .btn-default,fieldset[disabled] .btn-default.active,fieldset[disabled] .btn-default.focus,fieldset[disabled] .btn-default:active,fieldset[disabled] .btn-default:focus,fieldset[disabled] .btn-default:hover{background-color:#fff;border-color:#ccc}.btn-default .badge{color:#fff;background-color:#333}.btn-primary{color:#fff;background-color:#337ab7;border-color:#2e6da4}.btn-primary.focus,.btn-primary:focus{color:#fff;background-color:#286090;border-color:#122b40}.btn-primary:hover{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active,.btn-primary:active,.open>.dropdown-toggle.btn-primary{color:#fff;background-color:#286090;border-color:#204d74}.btn-primary.active.focus,.btn-primary.active:focus,.btn-primary.active:hover,.btn-primary:active.focus,.btn-primary:active:focus,.btn-primary:active:hover,.open>.dropdown-toggle.btn-primary.focus,.open>.dropdown-toggle.btn-primary:focus,.open>.dropdown-toggle.btn-primary:hover{color:#fff;background-color:#204d74;border-color:#122b40}.btn-primary.active,.btn-primary:active,.open>.dropdown-toggle.btn-primary{background-image:none}.btn-primary.disabled,.btn-primary.disabled.active,.btn-primary.disabled.focus,.btn-primary.disabled:active,.btn-primary.disabled:focus,.btn-primary.disabled:hover,.btn-primary[disabled],.btn-primary[disabled].active,.btn-primary[disabled].focus,.btn-primary[disabled]:active,.btn-primary[disabled]:focus,.btn-primary[disabled]:hover,fieldset[disabled] .btn-primary,fieldset[disabled] .btn-primary.active,fieldset[disabled] .btn-primary.focus,fieldset[disabled] .btn-primary:active,fieldset[disabled] .btn-primary:focus,fieldset[disabled] .btn-primary:hover{background-color:#337ab7;border-color:#2e6da4}.btn-primary .badge{color:#337ab7;background-color:#fff}.btn-success{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.btn-success.focus,.btn-success:focus{color:#fff;background-color:#449d44;border-color:#255625}.btn-success:hover{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{color:#fff;background-color:#449d44;border-color:#398439}.btn-success.active.focus,.btn-success.active:focus,.btn-success.active:hover,.btn-success:active.focus,.btn-success:active:focus,.btn-success:active:hover,.open>.dropdown-toggle.btn-success.focus,.open>.dropdown-toggle.btn-success:focus,.open>.dropdown-toggle.btn-success:hover{color:#fff;background-color:#398439;border-color:#255625}.btn-success.active,.btn-success:active,.open>.dropdown-toggle.btn-success{background-image:none}.btn-success.disabled,.btn-success.disabled.active,.btn-success.disabled.focus,.btn-success.disabled:active,.btn-success.disabled:focus,.btn-success.disabled:hover,.btn-success[disabled],.btn-success[disabled].active,.btn-success[disabled].focus,.btn-success[disabled]:active,.btn-success[disabled]:focus,.btn-success[disabled]:hover,fieldset[disabled] .btn-success,fieldset[disabled] .btn-success.active,fieldset[disabled] .btn-success.focus,fieldset[disabled] .btn-success:active,fieldset[disabled] .btn-success:focus,fieldset[disabled] .btn-success:hover{background-color:#5cb85c;border-color:#4cae4c}.btn-success .badge{color:#5cb85c;background-color:#fff}.btn-info{color:#fff;background-color:#5bc0de;border-color:#46b8da}.btn-info.focus,.btn-info:focus{color:#fff;background-color:#31b0d5;border-color:#1b6d85}.btn-info:hover{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active,.btn-info:active,.open>.dropdown-toggle.btn-info{color:#fff;background-color:#31b0d5;border-color:#269abc}.btn-info.active.focus,.btn-info.active:focus,.btn-info.active:hover,.btn-info:active.focus,.btn-info:active:focus,.btn-info:active:hover,.open>.dropdown-toggle.btn-info.focus,.open>.dropdown-toggle.btn-info:focus,.open>.dropdown-toggle.btn-info:hover{color:#fff;background-color:#269abc;border-color:#1b6d85}.btn-info.active,.btn-info:active,.open>.dropdown-toggle.btn-info{background-image:none}.btn-info.disabled,.btn-info.disabled.active,.btn-info.disabled.focus,.btn-info.disabled:active,.btn-info.disabled:focus,.btn-info.disabled:hover,.btn-info[disabled],.btn-info[disabled].active,.btn-info[disabled].focus,.btn-info[disabled]:active,.btn-info[disabled]:focus,.btn-info[disabled]:hover,fieldset[disabled] .btn-info,fieldset[disabled] .btn-info.active,fieldset[disabled] .btn-info.focus,fieldset[disabled] .btn-info:active,fieldset[disabled] .btn-info:focus,fieldset[disabled] .btn-info:hover{background-color:#5bc0de;border-color:#46b8da}.btn-info .badge{color:#5bc0de;background-color:#fff}.btn-warning{color:#fff;background-color:#f0ad4e;border-color:#eea236}.btn-warning.focus,.btn-warning:focus{color:#fff;background-color:#ec971f;border-color:#985f0d}.btn-warning:hover{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active,.btn-warning:active,.open>.dropdown-toggle.btn-warning{color:#fff;background-color:#ec971f;border-color:#d58512}.btn-warning.active.focus,.btn-warning.active:focus,.btn-warning.active:hover,.btn-warning:active.focus,.btn-warning:active:focus,.btn-warning:active:hover,.open>.dropdown-toggle.btn-warning.focus,.open>.dropdown-toggle.btn-warning:focus,.open>.dropdown-toggle.btn-warning:hover{color:#fff;background-color:#d58512;border-color:#985f0d}.btn-warning.active,.btn-warning:active,.open>.dropdown-toggle.btn-warning{background-image:none}.btn-warning.disabled,.btn-warning.disabled.active,.btn-warning.disabled.focus,.btn-warning.disabled:active,.btn-warning.disabled:focus,.btn-warning.disabled:hover,.btn-warning[disabled],.btn-warning[disabled].active,.btn-warning[disabled].focus,.btn-warning[disabled]:active,.btn-warning[disabled]:focus,.btn-warning[disabled]:hover,fieldset[disabled] .btn-warning,fieldset[disabled] .btn-warning.active,fieldset[disabled] .btn-warning.focus,fieldset[disabled] .btn-warning:active,fieldset[disabled] .btn-warning:focus,fieldset[disabled] .btn-warning:hover{background-color:#f0ad4e;border-color:#eea236}.btn-warning .badge{color:#f0ad4e;background-color:#fff}.btn-danger{color:#fff;background-color:#d9534f;border-color:#d43f3a}.btn-danger.focus,.btn-danger:focus{color:#fff;background-color:#c9302c;border-color:#761c19}.btn-danger:hover{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active,.btn-danger:active,.open>.dropdown-toggle.btn-danger{color:#fff;background-color:#c9302c;border-color:#ac2925}.btn-danger.active.focus,.btn-danger.active:focus,.btn-danger.active:hover,.btn-danger:active.focus,.btn-danger:active:focus,.btn-danger:active:hover,.open>.dropdown-toggle.btn-danger.focus,.open>.dropdown-toggle.btn-danger:focus,.open>.dropdown-toggle.btn-danger:hover{color:#fff;background-color:#ac2925;border-color:#761c19}.btn-danger.active,.btn-danger:active,.open>.dropdown-toggle.btn-danger{background-image:none}.btn-danger.disabled,.btn-danger.disabled.active,.btn-danger.disabled.focus,.btn-danger.disabled:active,.btn-danger.disabled:focus,.btn-danger.disabled:hover,.btn-danger[disabled],.btn-danger[disabled].active,.btn-danger[disabled].focus,.btn-danger[disabled]:active,.btn-danger[disabled]:focus,.btn-danger[disabled]:hover,fieldset[disabled] .btn-danger,fieldset[disabled] .btn-danger.active,fieldset[disabled] .btn-danger.focus,fieldset[disabled] .btn-danger:active,fieldset[disabled] .btn-danger:focus,fieldset[disabled] .btn-danger:hover{background-color:#d9534f;border-color:#d43f3a}.btn-danger .badge{color:#d9534f;background-color:#fff}.btn-link{font-weight:400;color:#337ab7;border-radius:0}.btn-link,.btn-link.active,.btn-link:active,.btn-link[disabled],fieldset[disabled] .btn-link{background-color:transparent;-webkit-box-shadow:none;box-shadow:none}.btn-link,.btn-link:active,.btn-link:focus,.btn-link:hover{border-color:transparent}.btn-link:focus,.btn-link:hover{color:#23527c;text-decoration:underline;background-color:transparent}.btn-link[disabled]:focus,.btn-link[disabled]:hover,fieldset[disabled] .btn-link:focus,fieldset[disabled] .btn-link:hover{color:#777;text-decoration:none}.btn-group-lg>.btn,.btn-lg{padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}.btn-group-sm>.btn,.btn-sm{padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}.btn-group-xs>.btn,.btn-xs{padding:1px 5px;font-size:12px;line-height:1.5;border-radius:3px}.btn-block{display:block;width:100%}.btn-block+.btn-block{margin-top:5px}input[type=button].btn-block,input[type=reset].btn-block,input[type=submit].btn-block{width:100%}.fade{opacity:0;-webkit-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1}.collapse{display:none}.collapse.in{display:block}tr.collapse.in{display:table-row}tbody.collapse.in{display:table-row-group}.collapsing{position:relative;height:0;overflow:hidden;-webkit-transition-timing-function:ease;-o-transition-timing-function:ease;transition-timing-function:ease;-webkit-transition-duration:.35s;-o-transition-duration:.35s;transition-duration:.35s;-webkit-transition-property:height,visibility;-o-transition-property:height,visibility;transition-property:height,visibility}.caret{display:inline-block;width:0;height:0;margin-left:2px;vertical-align:middle;border-top:4px dashed;border-top:4px solid\9;border-right:4px solid transparent;border-left:4px solid transparent}.dropdown,.dropup{position:relative}.dropdown-toggle:focus{outline:0}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:5px 0;margin:2px 0 0;font-size:14px;text-align:left;list-style:none;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.15);border-radius:4px;-webkit-box-shadow:0 6px 12px rgba(0,0,0,.175);box-shadow:0 6px 12px rgba(0,0,0,.175)}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.dropdown-menu>li>a{display:block;padding:3px 20px;clear:both;font-weight:400;line-height:1.42857143;color:#333;white-space:nowrap}.dropdown-menu>li>a:focus,.dropdown-menu>li>a:hover{color:#262626;text-decoration:none;background-color:#f5f5f5}.dropdown-menu>.active>a,.dropdown-menu>.active>a:focus,.dropdown-menu>.active>a:hover{color:#fff;text-decoration:none;background-color:#337ab7;outline:0}.dropdown-menu>.disabled>a,.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{color:#777}.dropdown-menu>.disabled>a:focus,.dropdown-menu>.disabled>a:hover{text-decoration:none;cursor:not-allowed;background-color:transparent;background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled=false)}.open>.dropdown-menu{display:block}.open>a{outline:0}.dropdown-menu-right{right:0;left:auto}.dropdown-menu-left{right:auto;left:0}.dropdown-header{display:block;padding:3px 20px;font-size:12px;line-height:1.42857143;color:#777;white-space:nowrap}.dropdown-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:990}.pull-right>.dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{content:"";border-top:0;border-bottom:4px dashed;border-bottom:4px solid\9}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:2px}@media (min-width:768px){.navbar-right .dropdown-menu{right:0;left:auto}.navbar-right .dropdown-menu-left{right:auto;left:0}}.btn-group,.btn-group-vertical{position:relative;display:inline-block;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;float:left}.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:2}.btn-group .btn+.btn,.btn-group .btn+.btn-group,.btn-group .btn-group+.btn,.btn-group .btn-group+.btn-group{margin-left:-1px}.btn-toolbar{margin-left:-5px}.btn-toolbar .btn,.btn-toolbar .btn-group,.btn-toolbar .input-group{float:left}.btn-toolbar>.btn,.btn-toolbar>.btn-group,.btn-toolbar>.input-group{margin-left:5px}.btn-group>.btn:not(:first-child):not(:last-child):not(.dropdown-toggle){border-radius:0}.btn-group>.btn:first-child{margin-left:0}.btn-group>.btn:first-child:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn:last-child:not(:first-child),.btn-group>.dropdown-toggle:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.btn-group>.btn-group{float:left}.btn-group>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-bottom-left-radius:0}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.btn+.dropdown-toggle{padding-right:8px;padding-left:8px}.btn-group>.btn-lg+.dropdown-toggle{padding-right:12px;padding-left:12px}.btn-group.open .dropdown-toggle{-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.btn-group.open .dropdown-toggle.btn-link{-webkit-box-shadow:none;box-shadow:none}.btn .caret{margin-left:0}.btn-lg .caret{border-width:5px 5px 0;border-bottom-width:0}.dropup .btn-lg .caret{border-width:0 5px 5px}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group,.btn-group-vertical>.btn-group>.btn{display:block;float:none;width:100%;max-width:100%}.btn-group-vertical>.btn-group>.btn{float:none}.btn-group-vertical>.btn+.btn,.btn-group-vertical>.btn+.btn-group,.btn-group-vertical>.btn-group+.btn,.btn-group-vertical>.btn-group+.btn-group{margin-top:-1px;margin-left:0}.btn-group-vertical>.btn:not(:first-child):not(:last-child){border-radius:0}.btn-group-vertical>.btn:first-child:not(:last-child){border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn:last-child:not(:first-child){border-top-left-radius:0;border-top-right-radius:0;border-bottom-left-radius:4px}.btn-group-vertical>.btn-group:not(:first-child):not(:last-child)>.btn{border-radius:0}.btn-group-vertical>.btn-group:first-child:not(:last-child)>.btn:last-child,.btn-group-vertical>.btn-group:first-child:not(:last-child)>.dropdown-toggle{border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:last-child:not(:first-child)>.btn:first-child{border-top-left-radius:0;border-top-right-radius:0}.btn-group-justified{display:table;width:100%;table-layout:fixed;border-collapse:separate}.btn-group-justified>.btn,.btn-group-justified>.btn-group{display:table-cell;float:none;width:1%}.btn-group-justified>.btn-group .btn{width:100%}.btn-group-justified>.btn-group .dropdown-menu{left:auto}[data-toggle=buttons]>.btn input[type=checkbox],[data-toggle=buttons]>.btn input[type=radio],[data-toggle=buttons]>.btn-group>.btn input[type=checkbox],[data-toggle=buttons]>.btn-group>.btn input[type=radio]{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.input-group{position:relative;display:table;border-collapse:separate}.input-group[class*=col-]{float:none;padding-right:0;padding-left:0}.input-group .form-control{position:relative;z-index:2;float:left;width:100%;margin-bottom:0}.input-group-lg>.form-control,.input-group-lg>.input-group-addon,.input-group-lg>.input-group-btn>.btn{height:46px;padding:10px 16px;font-size:18px;line-height:1.3333333;border-radius:6px}select.input-group-lg>.form-control,select.input-group-lg>.input-group-addon,select.input-group-lg>.input-group-btn>.btn{height:46px;line-height:46px}select[multiple].input-group-lg>.form-control,select[multiple].input-group-lg>.input-group-addon,select[multiple].input-group-lg>.input-group-btn>.btn,textarea.input-group-lg>.form-control,textarea.input-group-lg>.input-group-addon,textarea.input-group-lg>.input-group-btn>.btn{height:auto}.input-group-sm>.form-control,.input-group-sm>.input-group-addon,.input-group-sm>.input-group-btn>.btn{height:30px;padding:5px 10px;font-size:12px;line-height:1.5;border-radius:3px}select.input-group-sm>.form-control,select.input-group-sm>.input-group-addon,select.input-group-sm>.input-group-btn>.btn{height:30px;line-height:30px}select[multiple].input-group-sm>.form-control,select[multiple].input-group-sm>.input-group-addon,select[multiple].input-group-sm>.input-group-btn>.btn,textarea.input-group-sm>.form-control,textarea.input-group-sm>.input-group-addon,textarea.input-group-sm>.input-group-btn>.btn{height:auto}.input-group .form-control,.input-group-addon,.input-group-btn{display:table-cell}.input-group .form-control:not(:first-child):not(:last-child),.input-group-addon:not(:first-child):not(:last-child),.input-group-btn:not(:first-child):not(:last-child){border-radius:0}.input-group-addon,.input-group-btn{width:1%;white-space:nowrap;vertical-align:middle}.input-group-addon{padding:6px 12px;font-size:14px;font-weight:400;line-height:1;color:#555;text-align:center;background-color:#eee;border:1px solid #ccc;border-radius:4px}.input-group-addon.input-sm{padding:5px 10px;font-size:12px;border-radius:3px}.input-group-addon.input-lg{padding:10px 16px;font-size:18px;border-radius:6px}.input-group-addon input[type=checkbox],.input-group-addon input[type=radio]{margin-top:0}.input-group .form-control:first-child,.input-group-addon:first-child,.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group>.btn,.input-group-btn:first-child>.dropdown-toggle,.input-group-btn:last-child>.btn-group:not(:last-child)>.btn,.input-group-btn:last-child>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.input-group-addon:first-child{border-right:0}.input-group .form-control:last-child,.input-group-addon:last-child,.input-group-btn:first-child>.btn-group:not(:first-child)>.btn,.input-group-btn:first-child>.btn:not(:first-child),.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group>.btn,.input-group-btn:last-child>.dropdown-toggle{border-top-left-radius:0;border-bottom-left-radius:0}.input-group-addon:last-child{border-left:0}.input-group-btn{position:relative;font-size:0;white-space:nowrap}.input-group-btn>.btn{position:relative}.input-group-btn>.btn+.btn{margin-left:-1px}.input-group-btn>.btn:active,.input-group-btn>.btn:focus,.input-group-btn>.btn:hover{z-index:2}.input-group-btn:first-child>.btn,.input-group-btn:first-child>.btn-group{margin-right:-1px}.input-group-btn:last-child>.btn,.input-group-btn:last-child>.btn-group{z-index:2;margin-left:-1px}.nav{padding-left:0;margin-bottom:0;list-style:none}.nav>li{position:relative;display:block}.nav>li>a{position:relative;display:block;padding:10px 15px}.nav>li>a:focus,.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>li.disabled>a{color:#777}.nav>li.disabled>a:focus,.nav>li.disabled>a:hover{color:#777;text-decoration:none;cursor:not-allowed;background-color:transparent}.nav .open>a,.nav .open>a:focus,.nav .open>a:hover{background-color:#eee;border-color:#337ab7}.nav .nav-divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.nav>li>a>img{max-width:none}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{float:left;margin-bottom:-1px}.nav-tabs>li>a{margin-right:2px;line-height:1.42857143;border:1px solid transparent;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>li.active>a,.nav-tabs>li.active>a:focus,.nav-tabs>li.active>a:hover{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-tabs.nav-justified{width:100%;border-bottom:0}.nav-tabs.nav-justified>li{float:none}.nav-tabs.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-tabs.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-tabs.nav-justified>li{display:table-cell;width:1%}.nav-tabs.nav-justified>li>a{margin-bottom:0}}.nav-tabs.nav-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs.nav-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs.nav-justified>.active>a,.nav-tabs.nav-justified>.active>a:focus,.nav-tabs.nav-justified>.active>a:hover{border-bottom-color:#fff}}.nav-pills>li{float:left}.nav-pills>li>a{border-radius:4px}.nav-pills>li+li{margin-left:2px}.nav-pills>li.active>a,.nav-pills>li.active>a:focus,.nav-pills>li.active>a:hover{color:#fff;background-color:#337ab7}.nav-stacked>li{float:none}.nav-stacked>li+li{margin-top:2px;margin-left:0}.nav-justified{width:100%}.nav-justified>li{float:none}.nav-justified>li>a{margin-bottom:5px;text-align:center}.nav-justified>.dropdown .dropdown-menu{top:auto;left:auto}@media (min-width:768px){.nav-justified>li{display:table-cell;width:1%}.nav-justified>li>a{margin-bottom:0}}.nav-tabs-justified{border-bottom:0}.nav-tabs-justified>li>a{margin-right:0;border-radius:4px}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border:1px solid #ddd}@media (min-width:768px){.nav-tabs-justified>li>a{border-bottom:1px solid #ddd;border-radius:4px 4px 0 0}.nav-tabs-justified>.active>a,.nav-tabs-justified>.active>a:focus,.nav-tabs-justified>.active>a:hover{border-bottom-color:#fff}}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.nav-tabs .dropdown-menu{margin-top:-1px;border-top-left-radius:0;border-top-right-radius:0}.navbar{position:relative;min-height:50px;margin-bottom:20px;border:1px solid transparent}@media (min-width:768px){.navbar{border-radius:4px}}@media (min-width:768px){.navbar-header{float:left}}.navbar-collapse{padding-right:15px;padding-left:15px;overflow-x:visible;-webkit-overflow-scrolling:touch;border-top:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}.navbar-collapse.in{overflow-y:auto}@media (min-width:768px){.navbar-collapse{width:auto;border-top:0;-webkit-box-shadow:none;box-shadow:none}.navbar-collapse.collapse{display:block!important;height:auto!important;padding-bottom:0;overflow:visible!important}.navbar-collapse.in{overflow-y:visible}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse,.navbar-static-top .navbar-collapse{padding-right:0;padding-left:0}}.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:340px}@media (max-device-width:480px) and (orientation:landscape){.navbar-fixed-bottom .navbar-collapse,.navbar-fixed-top .navbar-collapse{max-height:200px}}.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:-15px;margin-left:-15px}@media (min-width:768px){.container-fluid>.navbar-collapse,.container-fluid>.navbar-header,.container>.navbar-collapse,.container>.navbar-header{margin-right:0;margin-left:0}}.navbar-static-top{z-index:1000;border-width:0 0 1px}@media (min-width:768px){.navbar-static-top{border-radius:0}}.navbar-fixed-bottom,.navbar-fixed-top{position:fixed;right:0;left:0;z-index:1030}@media (min-width:768px){.navbar-fixed-bottom,.navbar-fixed-top{border-radius:0}}.navbar-fixed-top{top:0;border-width:0 0 1px}.navbar-fixed-bottom{bottom:0;margin-bottom:0;border-width:1px 0 0}.navbar-brand{float:left;height:50px;padding:15px 15px;font-size:18px;line-height:20px}.navbar-brand:focus,.navbar-brand:hover{text-decoration:none}.navbar-brand>img{display:block}@media (min-width:768px){.navbar>.container .navbar-brand,.navbar>.container-fluid .navbar-brand{margin-left:-15px}}.navbar-toggle{position:relative;float:right;padding:9px 10px;margin-top:8px;margin-right:15px;margin-bottom:8px;background-color:transparent;background-image:none;border:1px solid transparent;border-radius:4px}.navbar-toggle:focus{outline:0}.navbar-toggle .icon-bar{display:block;width:22px;height:2px;border-radius:1px}.navbar-toggle .icon-bar+.icon-bar{margin-top:4px}@media (min-width:768px){.navbar-toggle{display:none}}.navbar-nav{margin:7.5px -15px}.navbar-nav>li>a{padding-top:10px;padding-bottom:10px;line-height:20px}@media (max-width:767px){.navbar-nav .open .dropdown-menu{position:static;float:none;width:auto;margin-top:0;background-color:transparent;border:0;-webkit-box-shadow:none;box-shadow:none}.navbar-nav .open .dropdown-menu .dropdown-header,.navbar-nav .open .dropdown-menu>li>a{padding:5px 15px 5px 25px}.navbar-nav .open .dropdown-menu>li>a{line-height:20px}.navbar-nav .open .dropdown-menu>li>a:focus,.navbar-nav .open .dropdown-menu>li>a:hover{background-image:none}}@media (min-width:768px){.navbar-nav{float:left;margin:0}.navbar-nav>li{float:left}.navbar-nav>li>a{padding-top:15px;padding-bottom:15px}}.navbar-form{padding:10px 15px;margin-top:8px;margin-right:-15px;margin-bottom:8px;margin-left:-15px;border-top:1px solid transparent;border-bottom:1px solid transparent;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1);box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 1px 0 rgba(255,255,255,.1)}@media (min-width:768px){.navbar-form .form-group{display:inline-block;margin-bottom:0;vertical-align:middle}.navbar-form .form-control{display:inline-block;width:auto;vertical-align:middle}.navbar-form .form-control-static{display:inline-block}.navbar-form .input-group{display:inline-table;vertical-align:middle}.navbar-form .input-group .form-control,.navbar-form .input-group .input-group-addon,.navbar-form .input-group .input-group-btn{width:auto}.navbar-form .input-group>.form-control{width:100%}.navbar-form .control-label{margin-bottom:0;vertical-align:middle}.navbar-form .checkbox,.navbar-form .radio{display:inline-block;margin-top:0;margin-bottom:0;vertical-align:middle}.navbar-form .checkbox label,.navbar-form .radio label{padding-left:0}.navbar-form .checkbox input[type=checkbox],.navbar-form .radio input[type=radio]{position:relative;margin-left:0}.navbar-form .has-feedback .form-control-feedback{top:0}}@media (max-width:767px){.navbar-form .form-group{margin-bottom:5px}.navbar-form .form-group:last-child{margin-bottom:0}}@media (min-width:768px){.navbar-form{width:auto;padding-top:0;padding-bottom:0;margin-right:0;margin-left:0;border:0;-webkit-box-shadow:none;box-shadow:none}}.navbar-nav>li>.dropdown-menu{margin-top:0;border-top-left-radius:0;border-top-right-radius:0}.navbar-fixed-bottom .navbar-nav>li>.dropdown-menu{margin-bottom:0;border-top-left-radius:4px;border-top-right-radius:4px;border-bottom-right-radius:0;border-bottom-left-radius:0}.navbar-btn{margin-top:8px;margin-bottom:8px}.navbar-btn.btn-sm{margin-top:10px;margin-bottom:10px}.navbar-btn.btn-xs{margin-top:14px;margin-bottom:14px}.navbar-text{margin-top:15px;margin-bottom:15px}@media (min-width:768px){.navbar-text{float:left;margin-right:15px;margin-left:15px}}@media (min-width:768px){.navbar-left{float:left!important}.navbar-right{float:right!important;margin-right:-15px}.navbar-right~.navbar-right{margin-right:0}}.navbar-default{background-color:#f8f8f8;border-color:#e7e7e7}.navbar-default .navbar-brand{color:#777}.navbar-default .navbar-brand:focus,.navbar-default .navbar-brand:hover{color:#5e5e5e;background-color:transparent}.navbar-default .navbar-text{color:#777}.navbar-default .navbar-nav>li>a{color:#777}.navbar-default .navbar-nav>li>a:focus,.navbar-default .navbar-nav>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav>.active>a,.navbar-default .navbar-nav>.active>a:focus,.navbar-default .navbar-nav>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav>.disabled>a,.navbar-default .navbar-nav>.disabled>a:focus,.navbar-default .navbar-nav>.disabled>a:hover{color:#ccc;background-color:transparent}.navbar-default .navbar-toggle{border-color:#ddd}.navbar-default .navbar-toggle:focus,.navbar-default .navbar-toggle:hover{background-color:#ddd}.navbar-default .navbar-toggle .icon-bar{background-color:#888}.navbar-default .navbar-collapse,.navbar-default .navbar-form{border-color:#e7e7e7}.navbar-default .navbar-nav>.open>a,.navbar-default .navbar-nav>.open>a:focus,.navbar-default .navbar-nav>.open>a:hover{color:#555;background-color:#e7e7e7}@media (max-width:767px){.navbar-default .navbar-nav .open .dropdown-menu>li>a{color:#777}.navbar-default .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>li>a:hover{color:#333;background-color:transparent}.navbar-default .navbar-nav .open .dropdown-menu>.active>a,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.active>a:hover{color:#555;background-color:#e7e7e7}.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-default .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#ccc;background-color:transparent}}.navbar-default .navbar-link{color:#777}.navbar-default .navbar-link:hover{color:#333}.navbar-default .btn-link{color:#777}.navbar-default .btn-link:focus,.navbar-default .btn-link:hover{color:#333}.navbar-default .btn-link[disabled]:focus,.navbar-default .btn-link[disabled]:hover,fieldset[disabled] .navbar-default .btn-link:focus,fieldset[disabled] .navbar-default .btn-link:hover{color:#ccc}.navbar-inverse{background-color:#222;border-color:#080808}.navbar-inverse .navbar-brand{color:#9d9d9d}.navbar-inverse .navbar-brand:focus,.navbar-inverse .navbar-brand:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-text{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav>li>a:focus,.navbar-inverse .navbar-nav>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav>.active>a,.navbar-inverse .navbar-nav>.active>a:focus,.navbar-inverse .navbar-nav>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav>.disabled>a,.navbar-inverse .navbar-nav>.disabled>a:focus,.navbar-inverse .navbar-nav>.disabled>a:hover{color:#444;background-color:transparent}.navbar-inverse .navbar-toggle{border-color:#333}.navbar-inverse .navbar-toggle:focus,.navbar-inverse .navbar-toggle:hover{background-color:#333}.navbar-inverse .navbar-toggle .icon-bar{background-color:#fff}.navbar-inverse .navbar-collapse,.navbar-inverse .navbar-form{border-color:#101010}.navbar-inverse .navbar-nav>.open>a,.navbar-inverse .navbar-nav>.open>a:focus,.navbar-inverse .navbar-nav>.open>a:hover{color:#fff;background-color:#080808}@media (max-width:767px){.navbar-inverse .navbar-nav .open .dropdown-menu>.dropdown-header{border-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu .divider{background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a{color:#9d9d9d}.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>li>a:hover{color:#fff;background-color:transparent}.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.active>a:hover{color:#fff;background-color:#080808}.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:focus,.navbar-inverse .navbar-nav .open .dropdown-menu>.disabled>a:hover{color:#444;background-color:transparent}}.navbar-inverse .navbar-link{color:#9d9d9d}.navbar-inverse .navbar-link:hover{color:#fff}.navbar-inverse .btn-link{color:#9d9d9d}.navbar-inverse .btn-link:focus,.navbar-inverse .btn-link:hover{color:#fff}.navbar-inverse .btn-link[disabled]:focus,.navbar-inverse .btn-link[disabled]:hover,fieldset[disabled] .navbar-inverse .btn-link:focus,fieldset[disabled] .navbar-inverse .btn-link:hover{color:#444}.breadcrumb{padding:8px 15px;margin-bottom:20px;list-style:none;background-color:#f5f5f5;border-radius:4px}.breadcrumb>li{display:inline-block}.breadcrumb>li+li:before{padding:0 5px;color:#ccc;content:"/\00a0"}.breadcrumb>.active{color:#777}.pagination{display:inline-block;padding-left:0;margin:20px 0;border-radius:4px}.pagination>li{display:inline}.pagination>li>a,.pagination>li>span{position:relative;float:left;padding:6px 12px;margin-left:-1px;line-height:1.42857143;color:#337ab7;text-decoration:none;background-color:#fff;border:1px solid #ddd}.pagination>li:first-child>a,.pagination>li:first-child>span{margin-left:0;border-top-left-radius:4px;border-bottom-left-radius:4px}.pagination>li:last-child>a,.pagination>li:last-child>span{border-top-right-radius:4px;border-bottom-right-radius:4px}.pagination>li>a:focus,.pagination>li>a:hover,.pagination>li>span:focus,.pagination>li>span:hover{z-index:3;color:#23527c;background-color:#eee;border-color:#ddd}.pagination>.active>a,.pagination>.active>a:focus,.pagination>.active>a:hover,.pagination>.active>span,.pagination>.active>span:focus,.pagination>.active>span:hover{z-index:2;color:#fff;cursor:default;background-color:#337ab7;border-color:#337ab7}.pagination>.disabled>a,.pagination>.disabled>a:focus,.pagination>.disabled>a:hover,.pagination>.disabled>span,.pagination>.disabled>span:focus,.pagination>.disabled>span:hover{color:#777;cursor:not-allowed;background-color:#fff;border-color:#ddd}.pagination-lg>li>a,.pagination-lg>li>span{padding:10px 16px;font-size:18px;line-height:1.3333333}.pagination-lg>li:first-child>a,.pagination-lg>li:first-child>span{border-top-left-radius:6px;border-bottom-left-radius:6px}.pagination-lg>li:last-child>a,.pagination-lg>li:last-child>span{border-top-right-radius:6px;border-bottom-right-radius:6px}.pagination-sm>li>a,.pagination-sm>li>span{padding:5px 10px;font-size:12px;line-height:1.5}.pagination-sm>li:first-child>a,.pagination-sm>li:first-child>span{border-top-left-radius:3px;border-bottom-left-radius:3px}.pagination-sm>li:last-child>a,.pagination-sm>li:last-child>span{border-top-right-radius:3px;border-bottom-right-radius:3px}.pager{padding-left:0;margin:20px 0;text-align:center;list-style:none}.pager li{display:inline}.pager li>a,.pager li>span{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;border-radius:15px}.pager li>a:focus,.pager li>a:hover{text-decoration:none;background-color:#eee}.pager .next>a,.pager .next>span{float:right}.pager .previous>a,.pager .previous>span{float:left}.pager .disabled>a,.pager .disabled>a:focus,.pager .disabled>a:hover,.pager .disabled>span{color:#777;cursor:not-allowed;background-color:#fff}.label{display:inline;padding:.2em .6em .3em;font-size:75%;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25em}a.label:focus,a.label:hover{color:#fff;text-decoration:none;cursor:pointer}.label:empty{display:none}.btn .label{position:relative;top:-1px}.label-default{background-color:#777}.label-default[href]:focus,.label-default[href]:hover{background-color:#5e5e5e}.label-primary{background-color:#337ab7}.label-primary[href]:focus,.label-primary[href]:hover{background-color:#286090}.label-success{background-color:#5cb85c}.label-success[href]:focus,.label-success[href]:hover{background-color:#449d44}.label-info{background-color:#5bc0de}.label-info[href]:focus,.label-info[href]:hover{background-color:#31b0d5}.label-warning{background-color:#f0ad4e}.label-warning[href]:focus,.label-warning[href]:hover{background-color:#ec971f}.label-danger{background-color:#d9534f}.label-danger[href]:focus,.label-danger[href]:hover{background-color:#c9302c}.badge{display:inline-block;min-width:10px;padding:3px 7px;font-size:12px;font-weight:700;line-height:1;color:#fff;text-align:center;white-space:nowrap;vertical-align:middle;background-color:#777;border-radius:10px}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.btn-group-xs>.btn .badge,.btn-xs .badge{top:0;padding:1px 5px}a.badge:focus,a.badge:hover{color:#fff;text-decoration:none;cursor:pointer}.list-group-item.active>.badge,.nav-pills>.active>a>.badge{color:#337ab7;background-color:#fff}.list-group-item>.badge{float:right}.list-group-item>.badge+.badge{margin-right:5px}.nav-pills>li>a>.badge{margin-left:3px}.jumbotron{padding-top:30px;padding-bottom:30px;margin-bottom:30px;color:inherit;background-color:#eee}.jumbotron .h1,.jumbotron h1{color:inherit}.jumbotron p{margin-bottom:15px;font-size:21px;font-weight:200}.jumbotron>hr{border-top-color:#d5d5d5}.container .jumbotron,.container-fluid .jumbotron{border-radius:6px}.jumbotron .container{max-width:100%}@media screen and (min-width:768px){.jumbotron{padding-top:48px;padding-bottom:48px}.container .jumbotron,.container-fluid .jumbotron{padding-right:60px;padding-left:60px}.jumbotron .h1,.jumbotron h1{font-size:63px}}.thumbnail{display:block;padding:4px;margin-bottom:20px;line-height:1.42857143;background-color:#fff;border:1px solid #ddd;border-radius:4px;-webkit-transition:border .2s ease-in-out;-o-transition:border .2s ease-in-out;transition:border .2s ease-in-out}.thumbnail a>img,.thumbnail>img{margin-right:auto;margin-left:auto}a.thumbnail.active,a.thumbnail:focus,a.thumbnail:hover{border-color:#337ab7}.thumbnail .caption{padding:9px;color:#333}.alert{padding:15px;margin-bottom:20px;border:1px solid transparent;border-radius:4px}.alert h4{margin-top:0;color:inherit}.alert .alert-link{font-weight:700}.alert>p,.alert>ul{margin-bottom:0}.alert>p+p{margin-top:5px}.alert-dismissable,.alert-dismissible{padding-right:35px}.alert-dismissable .close,.alert-dismissible .close{position:relative;top:-2px;right:-21px;color:inherit}.alert-success{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.alert-success hr{border-top-color:#c9e2b3}.alert-success .alert-link{color:#2b542c}.alert-info{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.alert-info hr{border-top-color:#a6e1ec}.alert-info .alert-link{color:#245269}.alert-warning{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.alert-warning hr{border-top-color:#f7e1b5}.alert-warning .alert-link{color:#66512c}.alert-danger{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.alert-danger hr{border-top-color:#e4b9c0}.alert-danger .alert-link{color:#843534}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:20px;margin-bottom:20px;overflow:hidden;background-color:#f5f5f5;border-radius:4px;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,.1);box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.progress-bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;background-color:#337ab7;-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);-webkit-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.progress-bar-striped,.progress-striped .progress-bar{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);-webkit-background-size:40px 40px;background-size:40px 40px}.progress-bar.active,.progress.active .progress-bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-bar-success{background-color:#5cb85c}.progress-striped .progress-bar-success{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-info{background-color:#5bc0de}.progress-striped .progress-bar-info{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-warning{background-color:#f0ad4e}.progress-striped .progress-bar-warning{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.progress-bar-danger{background-color:#d9534f}.progress-striped .progress-bar-danger{background-image:-webkit-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent)}.media{margin-top:15px}.media:first-child{margin-top:0}.media,.media-body{overflow:hidden;zoom:1}.media-body{width:10000px}.media-object{display:block}.media-object.img-thumbnail{max-width:none}.media-right,.media>.pull-right{padding-left:10px}.media-left,.media>.pull-left{padding-right:10px}.media-body,.media-left,.media-right{display:table-cell;vertical-align:top}.media-middle{vertical-align:middle}.media-bottom{vertical-align:bottom}.media-heading{margin-top:0;margin-bottom:5px}.media-list{padding-left:0;list-style:none}.list-group{padding-left:0;margin-bottom:20px}.list-group-item{position:relative;display:block;padding:10px 15px;margin-bottom:-1px;background-color:#fff;border:1px solid #ddd}.list-group-item:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.list-group-item:last-child{margin-bottom:0;border-bottom-right-radius:4px;border-bottom-left-radius:4px}a.list-group-item,button.list-group-item{color:#555}a.list-group-item .list-group-item-heading,button.list-group-item .list-group-item-heading{color:#333}a.list-group-item:focus,a.list-group-item:hover,button.list-group-item:focus,button.list-group-item:hover{color:#555;text-decoration:none;background-color:#f5f5f5}button.list-group-item{width:100%;text-align:left}.list-group-item.disabled,.list-group-item.disabled:focus,.list-group-item.disabled:hover{color:#777;cursor:not-allowed;background-color:#eee}.list-group-item.disabled .list-group-item-heading,.list-group-item.disabled:focus .list-group-item-heading,.list-group-item.disabled:hover .list-group-item-heading{color:inherit}.list-group-item.disabled .list-group-item-text,.list-group-item.disabled:focus .list-group-item-text,.list-group-item.disabled:hover .list-group-item-text{color:#777}.list-group-item.active,.list-group-item.active:focus,.list-group-item.active:hover{z-index:2;color:#fff;background-color:#337ab7;border-color:#337ab7}.list-group-item.active .list-group-item-heading,.list-group-item.active .list-group-item-heading>.small,.list-group-item.active .list-group-item-heading>small,.list-group-item.active:focus .list-group-item-heading,.list-group-item.active:focus .list-group-item-heading>.small,.list-group-item.active:focus .list-group-item-heading>small,.list-group-item.active:hover .list-group-item-heading,.list-group-item.active:hover .list-group-item-heading>.small,.list-group-item.active:hover .list-group-item-heading>small{color:inherit}.list-group-item.active .list-group-item-text,.list-group-item.active:focus .list-group-item-text,.list-group-item.active:hover .list-group-item-text{color:#c7ddef}.list-group-item-success{color:#3c763d;background-color:#dff0d8}a.list-group-item-success,button.list-group-item-success{color:#3c763d}a.list-group-item-success .list-group-item-heading,button.list-group-item-success .list-group-item-heading{color:inherit}a.list-group-item-success:focus,a.list-group-item-success:hover,button.list-group-item-success:focus,button.list-group-item-success:hover{color:#3c763d;background-color:#d0e9c6}a.list-group-item-success.active,a.list-group-item-success.active:focus,a.list-group-item-success.active:hover,button.list-group-item-success.active,button.list-group-item-success.active:focus,button.list-group-item-success.active:hover{color:#fff;background-color:#3c763d;border-color:#3c763d}.list-group-item-info{color:#31708f;background-color:#d9edf7}a.list-group-item-info,button.list-group-item-info{color:#31708f}a.list-group-item-info .list-group-item-heading,button.list-group-item-info .list-group-item-heading{color:inherit}a.list-group-item-info:focus,a.list-group-item-info:hover,button.list-group-item-info:focus,button.list-group-item-info:hover{color:#31708f;background-color:#c4e3f3}a.list-group-item-info.active,a.list-group-item-info.active:focus,a.list-group-item-info.active:hover,button.list-group-item-info.active,button.list-group-item-info.active:focus,button.list-group-item-info.active:hover{color:#fff;background-color:#31708f;border-color:#31708f}.list-group-item-warning{color:#8a6d3b;background-color:#fcf8e3}a.list-group-item-warning,button.list-group-item-warning{color:#8a6d3b}a.list-group-item-warning .list-group-item-heading,button.list-group-item-warning .list-group-item-heading{color:inherit}a.list-group-item-warning:focus,a.list-group-item-warning:hover,button.list-group-item-warning:focus,button.list-group-item-warning:hover{color:#8a6d3b;background-color:#faf2cc}a.list-group-item-warning.active,a.list-group-item-warning.active:focus,a.list-group-item-warning.active:hover,button.list-group-item-warning.active,button.list-group-item-warning.active:focus,button.list-group-item-warning.active:hover{color:#fff;background-color:#8a6d3b;border-color:#8a6d3b}.list-group-item-danger{color:#a94442;background-color:#f2dede}a.list-group-item-danger,button.list-group-item-danger{color:#a94442}a.list-group-item-danger .list-group-item-heading,button.list-group-item-danger .list-group-item-heading{color:inherit}a.list-group-item-danger:focus,a.list-group-item-danger:hover,button.list-group-item-danger:focus,button.list-group-item-danger:hover{color:#a94442;background-color:#ebcccc}a.list-group-item-danger.active,a.list-group-item-danger.active:focus,a.list-group-item-danger.active:hover,button.list-group-item-danger.active,button.list-group-item-danger.active:focus,button.list-group-item-danger.active:hover{color:#fff;background-color:#a94442;border-color:#a94442}.list-group-item-heading{margin-top:0;margin-bottom:5px}.list-group-item-text{margin-bottom:0;line-height:1.3}.panel{margin-bottom:20px;background-color:#fff;border:1px solid transparent;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,.05);box-shadow:0 1px 1px rgba(0,0,0,.05)}.panel-body{padding:15px}.panel-heading{padding:10px 15px;border-bottom:1px solid transparent;border-top-left-radius:3px;border-top-right-radius:3px}.panel-heading>.dropdown .dropdown-toggle{color:inherit}.panel-title{margin-top:0;margin-bottom:0;font-size:16px;color:inherit}.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit}.panel-footer{padding:10px 15px;background-color:#f5f5f5;border-top:1px solid #ddd;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.list-group,.panel>.panel-collapse>.list-group{margin-bottom:0}.panel>.list-group .list-group-item,.panel>.panel-collapse>.list-group .list-group-item{border-width:1px 0;border-radius:0}.panel>.list-group:first-child .list-group-item:first-child,.panel>.panel-collapse>.list-group:first-child .list-group-item:first-child{border-top:0;border-top-left-radius:3px;border-top-right-radius:3px}.panel>.list-group:last-child .list-group-item:last-child,.panel>.panel-collapse>.list-group:last-child .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.panel-heading+.panel-collapse>.list-group .list-group-item:first-child{border-top-left-radius:0;border-top-right-radius:0}.panel-heading+.list-group .list-group-item:first-child{border-top-width:0}.list-group+.panel-footer{border-top-width:0}.panel>.panel-collapse>.table,.panel>.table,.panel>.table-responsive>.table{margin-bottom:0}.panel>.panel-collapse>.table caption,.panel>.table caption,.panel>.table-responsive>.table caption{padding-right:15px;padding-left:15px}.panel>.table-responsive:first-child>.table:first-child,.panel>.table:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child,.panel>.table:first-child>thead:first-child>tr:first-child{border-top-left-radius:3px;border-top-right-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:first-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:first-child,.panel>.table:first-child>thead:first-child>tr:first-child td:first-child,.panel>.table:first-child>thead:first-child>tr:first-child th:first-child{border-top-left-radius:3px}.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table-responsive:first-child>.table:first-child>thead:first-child>tr:first-child th:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child td:last-child,.panel>.table:first-child>tbody:first-child>tr:first-child th:last-child,.panel>.table:first-child>thead:first-child>tr:first-child td:last-child,.panel>.table:first-child>thead:first-child>tr:first-child th:last-child{border-top-right-radius:3px}.panel>.table-responsive:last-child>.table:last-child,.panel>.table:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child{border-bottom-right-radius:3px;border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:first-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:first-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:first-child{border-bottom-left-radius:3px}.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table-responsive:last-child>.table:last-child>tfoot:last-child>tr:last-child th:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child td:last-child,.panel>.table:last-child>tbody:last-child>tr:last-child th:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child td:last-child,.panel>.table:last-child>tfoot:last-child>tr:last-child th:last-child{border-bottom-right-radius:3px}.panel>.panel-body+.table,.panel>.panel-body+.table-responsive,.panel>.table+.panel-body,.panel>.table-responsive+.panel-body{border-top:1px solid #ddd}.panel>.table>tbody:first-child>tr:first-child td,.panel>.table>tbody:first-child>tr:first-child th{border-top:0}.panel>.table-bordered,.panel>.table-responsive>.table-bordered{border:0}.panel>.table-bordered>tbody>tr>td:first-child,.panel>.table-bordered>tbody>tr>th:first-child,.panel>.table-bordered>tfoot>tr>td:first-child,.panel>.table-bordered>tfoot>tr>th:first-child,.panel>.table-bordered>thead>tr>td:first-child,.panel>.table-bordered>thead>tr>th:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:first-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:first-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:first-child,.panel>.table-responsive>.table-bordered>thead>tr>td:first-child,.panel>.table-responsive>.table-bordered>thead>tr>th:first-child{border-left:0}.panel>.table-bordered>tbody>tr>td:last-child,.panel>.table-bordered>tbody>tr>th:last-child,.panel>.table-bordered>tfoot>tr>td:last-child,.panel>.table-bordered>tfoot>tr>th:last-child,.panel>.table-bordered>thead>tr>td:last-child,.panel>.table-bordered>thead>tr>th:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>td:last-child,.panel>.table-responsive>.table-bordered>tbody>tr>th:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>td:last-child,.panel>.table-responsive>.table-bordered>tfoot>tr>th:last-child,.panel>.table-responsive>.table-bordered>thead>tr>td:last-child,.panel>.table-responsive>.table-bordered>thead>tr>th:last-child{border-right:0}.panel>.table-bordered>tbody>tr:first-child>td,.panel>.table-bordered>tbody>tr:first-child>th,.panel>.table-bordered>thead>tr:first-child>td,.panel>.table-bordered>thead>tr:first-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:first-child>th,.panel>.table-responsive>.table-bordered>thead>tr:first-child>td,.panel>.table-responsive>.table-bordered>thead>tr:first-child>th{border-bottom:0}.panel>.table-bordered>tbody>tr:last-child>td,.panel>.table-bordered>tbody>tr:last-child>th,.panel>.table-bordered>tfoot>tr:last-child>td,.panel>.table-bordered>tfoot>tr:last-child>th,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>td,.panel>.table-responsive>.table-bordered>tbody>tr:last-child>th,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>td,.panel>.table-responsive>.table-bordered>tfoot>tr:last-child>th{border-bottom:0}.panel>.table-responsive{margin-bottom:0;border:0}.panel-group{margin-bottom:20px}.panel-group .panel{margin-bottom:0;border-radius:4px}.panel-group .panel+.panel{margin-top:5px}.panel-group .panel-heading{border-bottom:0}.panel-group .panel-heading+.panel-collapse>.list-group,.panel-group .panel-heading+.panel-collapse>.panel-body{border-top:1px solid #ddd}.panel-group .panel-footer{border-top:0}.panel-group .panel-footer+.panel-collapse .panel-body{border-bottom:1px solid #ddd}.panel-default{border-color:#ddd}.panel-default>.panel-heading{color:#333;background-color:#f5f5f5;border-color:#ddd}.panel-default>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ddd}.panel-default>.panel-heading .badge{color:#f5f5f5;background-color:#333}.panel-default>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ddd}.panel-primary{border-color:#337ab7}.panel-primary>.panel-heading{color:#fff;background-color:#337ab7;border-color:#337ab7}.panel-primary>.panel-heading+.panel-collapse>.panel-body{border-top-color:#337ab7}.panel-primary>.panel-heading .badge{color:#337ab7;background-color:#fff}.panel-primary>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#337ab7}.panel-success{border-color:#d6e9c6}.panel-success>.panel-heading{color:#3c763d;background-color:#dff0d8;border-color:#d6e9c6}.panel-success>.panel-heading+.panel-collapse>.panel-body{border-top-color:#d6e9c6}.panel-success>.panel-heading .badge{color:#dff0d8;background-color:#3c763d}.panel-success>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#d6e9c6}.panel-info{border-color:#bce8f1}.panel-info>.panel-heading{color:#31708f;background-color:#d9edf7;border-color:#bce8f1}.panel-info>.panel-heading+.panel-collapse>.panel-body{border-top-color:#bce8f1}.panel-info>.panel-heading .badge{color:#d9edf7;background-color:#31708f}.panel-info>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#bce8f1}.panel-warning{border-color:#faebcc}.panel-warning>.panel-heading{color:#8a6d3b;background-color:#fcf8e3;border-color:#faebcc}.panel-warning>.panel-heading+.panel-collapse>.panel-body{border-top-color:#faebcc}.panel-warning>.panel-heading .badge{color:#fcf8e3;background-color:#8a6d3b}.panel-warning>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#faebcc}.panel-danger{border-color:#ebccd1}.panel-danger>.panel-heading{color:#a94442;background-color:#f2dede;border-color:#ebccd1}.panel-danger>.panel-heading+.panel-collapse>.panel-body{border-top-color:#ebccd1}.panel-danger>.panel-heading .badge{color:#f2dede;background-color:#a94442}.panel-danger>.panel-footer+.panel-collapse>.panel-body{border-bottom-color:#ebccd1}.embed-responsive{position:relative;display:block;height:0;padding:0;overflow:hidden}.embed-responsive .embed-responsive-item,.embed-responsive embed,.embed-responsive iframe,.embed-responsive object,.embed-responsive video{position:absolute;top:0;bottom:0;left:0;width:100%;height:100%;border:0}.embed-responsive-16by9{padding-bottom:56.25%}.embed-responsive-4by3{padding-bottom:75%}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #e3e3e3;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,.05);box-shadow:inset 0 1px 1px rgba(0,0,0,.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,.15)}.well-lg{padding:24px;border-radius:6px}.well-sm{padding:9px;border-radius:3px}.close{float:right;font-size:21px;font-weight:700;line-height:1;color:#000;text-shadow:0 1px 0 #fff;filter:alpha(opacity=20);opacity:.2}.close:focus,.close:hover{color:#000;text-decoration:none;cursor:pointer;filter:alpha(opacity=50);opacity:.5}button.close{-webkit-appearance:none;padding:0;cursor:pointer;background:0 0;border:0}.modal-open{overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1050;display:none;overflow:hidden;-webkit-overflow-scrolling:touch;outline:0}.modal.fade .modal-dialog{-webkit-transition:-webkit-transform .3s ease-out;-o-transition:-o-transform .3s ease-out;transition:transform .3s ease-out;-webkit-transform:translate(0,-25%);-ms-transform:translate(0,-25%);-o-transform:translate(0,-25%);transform:translate(0,-25%)}.modal.in .modal-dialog{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);-o-transform:translate(0,0);transform:translate(0,0)}.modal-open .modal{overflow-x:hidden;overflow-y:auto}.modal-dialog{position:relative;width:auto;margin:10px}.modal-content{position:relative;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #999;border:1px solid rgba(0,0,0,.2);border-radius:6px;outline:0;-webkit-box-shadow:0 3px 9px rgba(0,0,0,.5);box-shadow:0 3px 9px rgba(0,0,0,.5)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{filter:alpha(opacity=0);opacity:0}.modal-backdrop.in{filter:alpha(opacity=50);opacity:.5}.modal-header{min-height:16.43px;padding:15px;border-bottom:1px solid #e5e5e5}.modal-header .close{margin-top:-2px}.modal-title{margin:0;line-height:1.42857143}.modal-body{position:relative;padding:15px}.modal-footer{padding:15px;text-align:right;border-top:1px solid #e5e5e5}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.modal-footer .btn-block+.btn-block{margin-left:0}.modal-scrollbar-measure{position:absolute;top:-9999px;width:50px;height:50px;overflow:scroll}@media (min-width:768px){.modal-dialog{width:600px;margin:30px auto}.modal-content{-webkit-box-shadow:0 5px 15px rgba(0,0,0,.5);box-shadow:0 5px 15px rgba(0,0,0,.5)}.modal-sm{width:300px}}@media (min-width:992px){.modal-lg{width:900px}}.tooltip{position:absolute;z-index:1070;display:block;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:12px;font-style:normal;font-weight:400;line-height:1.42857143;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;word-wrap:normal;white-space:normal;filter:alpha(opacity=0);opacity:0;line-break:auto}.tooltip.in{filter:alpha(opacity=90);opacity:.9}.tooltip.top{padding:5px 0;margin-top:-3px}.tooltip.right{padding:0 5px;margin-left:3px}.tooltip.bottom{padding:5px 0;margin-top:3px}.tooltip.left{padding:0 5px;margin-left:-3px}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;background-color:#000;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0;border-color:transparent;border-style:solid}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-left .tooltip-arrow{right:5px;bottom:0;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.top-right .tooltip-arrow{bottom:0;left:5px;margin-bottom:-5px;border-width:5px 5px 0;border-top-color:#000}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-width:5px 5px 5px 0;border-right-color:#000}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-width:5px 0 5px 5px;border-left-color:#000}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-left .tooltip-arrow{top:0;right:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.tooltip.bottom-right .tooltip-arrow{top:0;left:5px;margin-top:-5px;border-width:0 5px 5px;border-bottom-color:#000}.popover{position:absolute;top:0;left:0;z-index:1060;display:none;max-width:276px;padding:1px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;font-style:normal;font-weight:400;line-height:1.42857143;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;word-wrap:normal;white-space:normal;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,.2);box-shadow:0 5px 10px rgba(0,0,0,.2);line-break:auto}.popover.top{margin-top:-10px}.popover.right{margin-left:10px}.popover.bottom{margin-top:10px}.popover.left{margin-left:-10px}.popover-title{padding:8px 14px;margin:0;font-size:14px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0}.popover-content{padding:9px 14px}.popover>.arrow,.popover>.arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid}.popover>.arrow{border-width:11px}.popover>.arrow:after{content:"";border-width:10px}.popover.top>.arrow{bottom:-11px;left:50%;margin-left:-11px;border-top-color:#999;border-top-color:rgba(0,0,0,.25);border-bottom-width:0}.popover.top>.arrow:after{bottom:1px;margin-left:-10px;content:" ";border-top-color:#fff;border-bottom-width:0}.popover.right>.arrow{top:50%;left:-11px;margin-top:-11px;border-right-color:#999;border-right-color:rgba(0,0,0,.25);border-left-width:0}.popover.right>.arrow:after{bottom:-10px;left:1px;content:" ";border-right-color:#fff;border-left-width:0}.popover.bottom>.arrow{top:-11px;left:50%;margin-left:-11px;border-top-width:0;border-bottom-color:#999;border-bottom-color:rgba(0,0,0,.25)}.popover.bottom>.arrow:after{top:1px;margin-left:-10px;content:" ";border-top-width:0;border-bottom-color:#fff}.popover.left>.arrow{top:50%;right:-11px;margin-top:-11px;border-right-width:0;border-left-color:#999;border-left-color:rgba(0,0,0,.25)}.popover.left>.arrow:after{right:1px;bottom:-10px;content:" ";border-right-width:0;border-left-color:#fff}.carousel{position:relative}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner>.item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;-o-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel-inner>.item>a>img,.carousel-inner>.item>img{line-height:1}@media all and (transform-3d),(-webkit-transform-3d){.carousel-inner>.item{-webkit-transition:-webkit-transform .6s ease-in-out;-o-transition:-o-transform .6s ease-in-out;transition:transform .6s ease-in-out;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-perspective:1000px;perspective:1000px}.carousel-inner>.item.active.right,.carousel-inner>.item.next{left:0;-webkit-transform:translate3d(100%,0,0);transform:translate3d(100%,0,0)}.carousel-inner>.item.active.left,.carousel-inner>.item.prev{left:0;-webkit-transform:translate3d(-100%,0,0);transform:translate3d(-100%,0,0)}.carousel-inner>.item.active,.carousel-inner>.item.next.left,.carousel-inner>.item.prev.right{left:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}.carousel-inner>.active,.carousel-inner>.next,.carousel-inner>.prev{display:block}.carousel-inner>.active{left:0}.carousel-inner>.next,.carousel-inner>.prev{position:absolute;top:0;width:100%}.carousel-inner>.next{left:100%}.carousel-inner>.prev{left:-100%}.carousel-inner>.next.left,.carousel-inner>.prev.right{left:0}.carousel-inner>.active.left{left:-100%}.carousel-inner>.active.right{left:100%}.carousel-control{position:absolute;top:0;bottom:0;left:0;width:15%;font-size:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6);filter:alpha(opacity=50);opacity:.5}.carousel-control.left{background-image:-webkit-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,.0001)));background-image:linear-gradient(to right,rgba(0,0,0,.5) 0,rgba(0,0,0,.0001) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#80000000', endColorstr='#00000000', GradientType=1);background-repeat:repeat-x}.carousel-control.right{right:0;left:auto;background-image:-webkit-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-o-linear-gradient(left,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);background-image:-webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.0001)),to(rgba(0,0,0,.5)));background-image:linear-gradient(to right,rgba(0,0,0,.0001) 0,rgba(0,0,0,.5) 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#80000000', GradientType=1);background-repeat:repeat-x}.carousel-control:focus,.carousel-control:hover{color:#fff;text-decoration:none;filter:alpha(opacity=90);outline:0;opacity:.9}.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{position:absolute;top:50%;z-index:5;display:inline-block;margin-top:-10px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{left:50%;margin-left:-10px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{right:50%;margin-right:-10px}.carousel-control .icon-next,.carousel-control .icon-prev{width:20px;height:20px;font-family:serif;line-height:1}.carousel-control .icon-prev:before{content:'\2039'}.carousel-control .icon-next:before{content:'\203a'}.carousel-indicators{position:absolute;bottom:10px;left:50%;z-index:15;width:60%;padding-left:0;margin-left:-30%;text-align:center;list-style:none}.carousel-indicators li{display:inline-block;width:10px;height:10px;margin:1px;text-indent:-999px;cursor:pointer;background-color:#000\9;background-color:rgba(0,0,0,0);border:1px solid #fff;border-radius:10px}.carousel-indicators .active{width:12px;height:12px;margin:0;background-color:#fff}.carousel-caption{position:absolute;right:15%;bottom:20px;left:15%;z-index:10;padding-top:20px;padding-bottom:20px;color:#fff;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6)}.carousel-caption .btn{text-shadow:none}@media screen and (min-width:768px){.carousel-control .glyphicon-chevron-left,.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next,.carousel-control .icon-prev{width:30px;height:30px;margin-top:-15px;font-size:30px}.carousel-control .glyphicon-chevron-left,.carousel-control .icon-prev{margin-left:-15px}.carousel-control .glyphicon-chevron-right,.carousel-control .icon-next{margin-right:-15px}.carousel-caption{right:20%;left:20%;padding-bottom:30px}.carousel-indicators{bottom:20px}}.btn-group-vertical>.btn-group:after,.btn-group-vertical>.btn-group:before,.btn-toolbar:after,.btn-toolbar:before,.clearfix:after,.clearfix:before,.container-fluid:after,.container-fluid:before,.container:after,.container:before,.dl-horizontal dd:after,.dl-horizontal dd:before,.form-horizontal .form-group:after,.form-horizontal .form-group:before,.modal-footer:after,.modal-footer:before,.nav:after,.nav:before,.navbar-collapse:after,.navbar-collapse:before,.navbar-header:after,.navbar-header:before,.navbar:after,.navbar:before,.pager:after,.pager:before,.panel-body:after,.panel-body:before,.row:after,.row:before{display:table;content:" "}.btn-group-vertical>.btn-group:after,.btn-toolbar:after,.clearfix:after,.container-fluid:after,.container:after,.dl-horizontal dd:after,.form-horizontal .form-group:after,.modal-footer:after,.nav:after,.navbar-collapse:after,.navbar-header:after,.navbar:after,.pager:after,.panel-body:after,.row:after{clear:both}.center-block{display:block;margin-right:auto;margin-left:auto}.pull-right{float:right!important}.pull-left{float:left!important}.hide{display:none!important}.show{display:block!important}.invisible{visibility:hidden}.text-hide{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.hidden{display:none!important}.affix{position:fixed}@-ms-viewport{width:device-width}.visible-lg,.visible-md,.visible-sm,.visible-xs{display:none!important}.visible-lg-block,.visible-lg-inline,.visible-lg-inline-block,.visible-md-block,.visible-md-inline,.visible-md-inline-block,.visible-sm-block,.visible-sm-inline,.visible-sm-inline-block,.visible-xs-block,.visible-xs-inline,.visible-xs-inline-block{display:none!important}@media (max-width:767px){.visible-xs{display:block!important}table.visible-xs{display:table!important}tr.visible-xs{display:table-row!important}td.visible-xs,th.visible-xs{display:table-cell!important}}@media (max-width:767px){.visible-xs-block{display:block!important}}@media (max-width:767px){.visible-xs-inline{display:inline!important}}@media (max-width:767px){.visible-xs-inline-block{display:inline-block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm{display:block!important}table.visible-sm{display:table!important}tr.visible-sm{display:table-row!important}td.visible-sm,th.visible-sm{display:table-cell!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-block{display:block!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-inline{display:inline!important}}@media (min-width:768px) and (max-width:991px){.visible-sm-inline-block{display:inline-block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md{display:block!important}table.visible-md{display:table!important}tr.visible-md{display:table-row!important}td.visible-md,th.visible-md{display:table-cell!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-block{display:block!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-inline{display:inline!important}}@media (min-width:992px) and (max-width:1199px){.visible-md-inline-block{display:inline-block!important}}@media (min-width:1200px){.visible-lg{display:block!important}table.visible-lg{display:table!important}tr.visible-lg{display:table-row!important}td.visible-lg,th.visible-lg{display:table-cell!important}}@media (min-width:1200px){.visible-lg-block{display:block!important}}@media (min-width:1200px){.visible-lg-inline{display:inline!important}}@media (min-width:1200px){.visible-lg-inline-block{display:inline-block!important}}@media (max-width:767px){.hidden-xs{display:none!important}}@media (min-width:768px) and (max-width:991px){.hidden-sm{display:none!important}}@media (min-width:992px) and (max-width:1199px){.hidden-md{display:none!important}}@media (min-width:1200px){.hidden-lg{display:none!important}}.visible-print{display:none!important}@media print{.visible-print{display:block!important}table.visible-print{display:table!important}tr.visible-print{display:table-row!important}td.visible-print,th.visible-print{display:table-cell!important}}.visible-print-block{display:none!important}@media print{.visible-print-block{display:block!important}}.visible-print-inline{display:none!important}@media print{.visible-print-inline{display:inline!important}}.visible-print-inline-block{display:none!important}@media print{.visible-print-inline-block{display:inline-block!important}}@media print{.hidden-print{display:none!important}} +</style> +<script>/*! + * Bootstrap v3.3.5 (http://getbootstrap.com) + * Copyright 2011-2015 Twitter, Inc. + * Licensed under the MIT license + */ +if("undefined"==typeof jQuery)throw new Error("Bootstrap's JavaScript requires jQuery");+function(a){"use strict";var b=a.fn.jquery.split(" ")[0].split(".");if(b[0]<2&&b[1]<9||1==b[0]&&9==b[1]&&b[2]<1)throw new Error("Bootstrap's JavaScript requires jQuery version 1.9.1 or higher")}(jQuery),+function(a){"use strict";function b(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"};for(var c in b)if(void 0!==a.style[c])return{end:b[c]};return!1}a.fn.emulateTransitionEnd=function(b){var c=!1,d=this;a(this).one("bsTransitionEnd",function(){c=!0});var e=function(){c||a(d).trigger(a.support.transition.end)};return setTimeout(e,b),this},a(function(){a.support.transition=b(),a.support.transition&&(a.event.special.bsTransitionEnd={bindType:a.support.transition.end,delegateType:a.support.transition.end,handle:function(b){return a(b.target).is(this)?b.handleObj.handler.apply(this,arguments):void 0}})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var c=a(this),e=c.data("bs.alert");e||c.data("bs.alert",e=new d(this)),"string"==typeof b&&e[b].call(c)})}var c='[data-dismiss="alert"]',d=function(b){a(b).on("click",c,this.close)};d.VERSION="3.3.5",d.TRANSITION_DURATION=150,d.prototype.close=function(b){function c(){g.detach().trigger("closed.bs.alert").remove()}var e=a(this),f=e.attr("data-target");f||(f=e.attr("href"),f=f&&f.replace(/.*(?=#[^\s]*$)/,""));var g=a(f);b&&b.preventDefault(),g.length||(g=e.closest(".alert")),g.trigger(b=a.Event("close.bs.alert")),b.isDefaultPrevented()||(g.removeClass("in"),a.support.transition&&g.hasClass("fade")?g.one("bsTransitionEnd",c).emulateTransitionEnd(d.TRANSITION_DURATION):c())};var e=a.fn.alert;a.fn.alert=b,a.fn.alert.Constructor=d,a.fn.alert.noConflict=function(){return a.fn.alert=e,this},a(document).on("click.bs.alert.data-api",c,d.prototype.close)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.button"),f="object"==typeof b&&b;e||d.data("bs.button",e=new c(this,f)),"toggle"==b?e.toggle():b&&e.setState(b)})}var c=function(b,d){this.$element=a(b),this.options=a.extend({},c.DEFAULTS,d),this.isLoading=!1};c.VERSION="3.3.5",c.DEFAULTS={loadingText:"loading..."},c.prototype.setState=function(b){var c="disabled",d=this.$element,e=d.is("input")?"val":"html",f=d.data();b+="Text",null==f.resetText&&d.data("resetText",d[e]()),setTimeout(a.proxy(function(){d[e](null==f[b]?this.options[b]:f[b]),"loadingText"==b?(this.isLoading=!0,d.addClass(c).attr(c,c)):this.isLoading&&(this.isLoading=!1,d.removeClass(c).removeAttr(c))},this),0)},c.prototype.toggle=function(){var a=!0,b=this.$element.closest('[data-toggle="buttons"]');if(b.length){var c=this.$element.find("input");"radio"==c.prop("type")?(c.prop("checked")&&(a=!1),b.find(".active").removeClass("active"),this.$element.addClass("active")):"checkbox"==c.prop("type")&&(c.prop("checked")!==this.$element.hasClass("active")&&(a=!1),this.$element.toggleClass("active")),c.prop("checked",this.$element.hasClass("active")),a&&c.trigger("change")}else this.$element.attr("aria-pressed",!this.$element.hasClass("active")),this.$element.toggleClass("active")};var d=a.fn.button;a.fn.button=b,a.fn.button.Constructor=c,a.fn.button.noConflict=function(){return a.fn.button=d,this},a(document).on("click.bs.button.data-api",'[data-toggle^="button"]',function(c){var d=a(c.target);d.hasClass("btn")||(d=d.closest(".btn")),b.call(d,"toggle"),a(c.target).is('input[type="radio"]')||a(c.target).is('input[type="checkbox"]')||c.preventDefault()}).on("focus.bs.button.data-api blur.bs.button.data-api",'[data-toggle^="button"]',function(b){a(b.target).closest(".btn").toggleClass("focus",/^focus(in)?$/.test(b.type))})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.carousel"),f=a.extend({},c.DEFAULTS,d.data(),"object"==typeof b&&b),g="string"==typeof b?b:f.slide;e||d.data("bs.carousel",e=new c(this,f)),"number"==typeof b?e.to(b):g?e[g]():f.interval&&e.pause().cycle()})}var c=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.paused=null,this.sliding=null,this.interval=null,this.$active=null,this.$items=null,this.options.keyboard&&this.$element.on("keydown.bs.carousel",a.proxy(this.keydown,this)),"hover"==this.options.pause&&!("ontouchstart"in document.documentElement)&&this.$element.on("mouseenter.bs.carousel",a.proxy(this.pause,this)).on("mouseleave.bs.carousel",a.proxy(this.cycle,this))};c.VERSION="3.3.5",c.TRANSITION_DURATION=600,c.DEFAULTS={interval:5e3,pause:"hover",wrap:!0,keyboard:!0},c.prototype.keydown=function(a){if(!/input|textarea/i.test(a.target.tagName)){switch(a.which){case 37:this.prev();break;case 39:this.next();break;default:return}a.preventDefault()}},c.prototype.cycle=function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},c.prototype.getItemIndex=function(a){return this.$items=a.parent().children(".item"),this.$items.index(a||this.$active)},c.prototype.getItemForDirection=function(a,b){var c=this.getItemIndex(b),d="prev"==a&&0===c||"next"==a&&c==this.$items.length-1;if(d&&!this.options.wrap)return b;var e="prev"==a?-1:1,f=(c+e)%this.$items.length;return this.$items.eq(f)},c.prototype.to=function(a){var b=this,c=this.getItemIndex(this.$active=this.$element.find(".item.active"));return a>this.$items.length-1||0>a?void 0:this.sliding?this.$element.one("slid.bs.carousel",function(){b.to(a)}):c==a?this.pause().cycle():this.slide(a>c?"next":"prev",this.$items.eq(a))},c.prototype.pause=function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),this.interval=clearInterval(this.interval),this},c.prototype.next=function(){return this.sliding?void 0:this.slide("next")},c.prototype.prev=function(){return this.sliding?void 0:this.slide("prev")},c.prototype.slide=function(b,d){var e=this.$element.find(".item.active"),f=d||this.getItemForDirection(b,e),g=this.interval,h="next"==b?"left":"right",i=this;if(f.hasClass("active"))return this.sliding=!1;var j=f[0],k=a.Event("slide.bs.carousel",{relatedTarget:j,direction:h});if(this.$element.trigger(k),!k.isDefaultPrevented()){if(this.sliding=!0,g&&this.pause(),this.$indicators.length){this.$indicators.find(".active").removeClass("active");var l=a(this.$indicators.children()[this.getItemIndex(f)]);l&&l.addClass("active")}var m=a.Event("slid.bs.carousel",{relatedTarget:j,direction:h});return a.support.transition&&this.$element.hasClass("slide")?(f.addClass(b),f[0].offsetWidth,e.addClass(h),f.addClass(h),e.one("bsTransitionEnd",function(){f.removeClass([b,h].join(" ")).addClass("active"),e.removeClass(["active",h].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger(m)},0)}).emulateTransitionEnd(c.TRANSITION_DURATION)):(e.removeClass("active"),f.addClass("active"),this.sliding=!1,this.$element.trigger(m)),g&&this.cycle(),this}};var d=a.fn.carousel;a.fn.carousel=b,a.fn.carousel.Constructor=c,a.fn.carousel.noConflict=function(){return a.fn.carousel=d,this};var e=function(c){var d,e=a(this),f=a(e.attr("data-target")||(d=e.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""));if(f.hasClass("carousel")){var g=a.extend({},f.data(),e.data()),h=e.attr("data-slide-to");h&&(g.interval=!1),b.call(f,g),h&&f.data("bs.carousel").to(h),c.preventDefault()}};a(document).on("click.bs.carousel.data-api","[data-slide]",e).on("click.bs.carousel.data-api","[data-slide-to]",e),a(window).on("load",function(){a('[data-ride="carousel"]').each(function(){var c=a(this);b.call(c,c.data())})})}(jQuery),+function(a){"use strict";function b(b){var c,d=b.attr("data-target")||(c=b.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,"");return a(d)}function c(b){return this.each(function(){var c=a(this),e=c.data("bs.collapse"),f=a.extend({},d.DEFAULTS,c.data(),"object"==typeof b&&b);!e&&f.toggle&&/show|hide/.test(b)&&(f.toggle=!1),e||c.data("bs.collapse",e=new d(this,f)),"string"==typeof b&&e[b]()})}var d=function(b,c){this.$element=a(b),this.options=a.extend({},d.DEFAULTS,c),this.$trigger=a('[data-toggle="collapse"][href="#'+b.id+'"],[data-toggle="collapse"][data-target="#'+b.id+'"]'),this.transitioning=null,this.options.parent?this.$parent=this.getParent():this.addAriaAndCollapsedClass(this.$element,this.$trigger),this.options.toggle&&this.toggle()};d.VERSION="3.3.5",d.TRANSITION_DURATION=350,d.DEFAULTS={toggle:!0},d.prototype.dimension=function(){var a=this.$element.hasClass("width");return a?"width":"height"},d.prototype.show=function(){if(!this.transitioning&&!this.$element.hasClass("in")){var b,e=this.$parent&&this.$parent.children(".panel").children(".in, .collapsing");if(!(e&&e.length&&(b=e.data("bs.collapse"),b&&b.transitioning))){var f=a.Event("show.bs.collapse");if(this.$element.trigger(f),!f.isDefaultPrevented()){e&&e.length&&(c.call(e,"hide"),b||e.data("bs.collapse",null));var g=this.dimension();this.$element.removeClass("collapse").addClass("collapsing")[g](0).attr("aria-expanded",!0),this.$trigger.removeClass("collapsed").attr("aria-expanded",!0),this.transitioning=1;var h=function(){this.$element.removeClass("collapsing").addClass("collapse in")[g](""),this.transitioning=0,this.$element.trigger("shown.bs.collapse")};if(!a.support.transition)return h.call(this);var i=a.camelCase(["scroll",g].join("-"));this.$element.one("bsTransitionEnd",a.proxy(h,this)).emulateTransitionEnd(d.TRANSITION_DURATION)[g](this.$element[0][i])}}}},d.prototype.hide=function(){if(!this.transitioning&&this.$element.hasClass("in")){var b=a.Event("hide.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.dimension();this.$element[c](this.$element[c]())[0].offsetHeight,this.$element.addClass("collapsing").removeClass("collapse in").attr("aria-expanded",!1),this.$trigger.addClass("collapsed").attr("aria-expanded",!1),this.transitioning=1;var e=function(){this.transitioning=0,this.$element.removeClass("collapsing").addClass("collapse").trigger("hidden.bs.collapse")};return a.support.transition?void this.$element[c](0).one("bsTransitionEnd",a.proxy(e,this)).emulateTransitionEnd(d.TRANSITION_DURATION):e.call(this)}}},d.prototype.toggle=function(){this[this.$element.hasClass("in")?"hide":"show"]()},d.prototype.getParent=function(){return a(this.options.parent).find('[data-toggle="collapse"][data-parent="'+this.options.parent+'"]').each(a.proxy(function(c,d){var e=a(d);this.addAriaAndCollapsedClass(b(e),e)},this)).end()},d.prototype.addAriaAndCollapsedClass=function(a,b){var c=a.hasClass("in");a.attr("aria-expanded",c),b.toggleClass("collapsed",!c).attr("aria-expanded",c)};var e=a.fn.collapse;a.fn.collapse=c,a.fn.collapse.Constructor=d,a.fn.collapse.noConflict=function(){return a.fn.collapse=e,this},a(document).on("click.bs.collapse.data-api",'[data-toggle="collapse"]',function(d){var e=a(this);e.attr("data-target")||d.preventDefault();var f=b(e),g=f.data("bs.collapse"),h=g?"toggle":e.data();c.call(f,h)})}(jQuery),+function(a){"use strict";function b(b){var c=b.attr("data-target");c||(c=b.attr("href"),c=c&&/#[A-Za-z]/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,""));var d=c&&a(c);return d&&d.length?d:b.parent()}function c(c){c&&3===c.which||(a(e).remove(),a(f).each(function(){var d=a(this),e=b(d),f={relatedTarget:this};e.hasClass("open")&&(c&&"click"==c.type&&/input|textarea/i.test(c.target.tagName)&&a.contains(e[0],c.target)||(e.trigger(c=a.Event("hide.bs.dropdown",f)),c.isDefaultPrevented()||(d.attr("aria-expanded","false"),e.removeClass("open").trigger("hidden.bs.dropdown",f))))}))}function d(b){return this.each(function(){var c=a(this),d=c.data("bs.dropdown");d||c.data("bs.dropdown",d=new g(this)),"string"==typeof b&&d[b].call(c)})}var e=".dropdown-backdrop",f='[data-toggle="dropdown"]',g=function(b){a(b).on("click.bs.dropdown",this.toggle)};g.VERSION="3.3.5",g.prototype.toggle=function(d){var e=a(this);if(!e.is(".disabled, :disabled")){var f=b(e),g=f.hasClass("open");if(c(),!g){"ontouchstart"in document.documentElement&&!f.closest(".navbar-nav").length&&a(document.createElement("div")).addClass("dropdown-backdrop").insertAfter(a(this)).on("click",c);var h={relatedTarget:this};if(f.trigger(d=a.Event("show.bs.dropdown",h)),d.isDefaultPrevented())return;e.trigger("focus").attr("aria-expanded","true"),f.toggleClass("open").trigger("shown.bs.dropdown",h)}return!1}},g.prototype.keydown=function(c){if(/(38|40|27|32)/.test(c.which)&&!/input|textarea/i.test(c.target.tagName)){var d=a(this);if(c.preventDefault(),c.stopPropagation(),!d.is(".disabled, :disabled")){var e=b(d),g=e.hasClass("open");if(!g&&27!=c.which||g&&27==c.which)return 27==c.which&&e.find(f).trigger("focus"),d.trigger("click");var h=" li:not(.disabled):visible a",i=e.find(".dropdown-menu"+h);if(i.length){var j=i.index(c.target);38==c.which&&j>0&&j--,40==c.which&&j<i.length-1&&j++,~j||(j=0),i.eq(j).trigger("focus")}}}};var h=a.fn.dropdown;a.fn.dropdown=d,a.fn.dropdown.Constructor=g,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=h,this},a(document).on("click.bs.dropdown.data-api",c).on("click.bs.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.bs.dropdown.data-api",f,g.prototype.toggle).on("keydown.bs.dropdown.data-api",f,g.prototype.keydown).on("keydown.bs.dropdown.data-api",".dropdown-menu",g.prototype.keydown)}(jQuery),+function(a){"use strict";function b(b,d){return this.each(function(){var e=a(this),f=e.data("bs.modal"),g=a.extend({},c.DEFAULTS,e.data(),"object"==typeof b&&b);f||e.data("bs.modal",f=new c(this,g)),"string"==typeof b?f[b](d):g.show&&f.show(d)})}var c=function(b,c){this.options=c,this.$body=a(document.body),this.$element=a(b),this.$dialog=this.$element.find(".modal-dialog"),this.$backdrop=null,this.isShown=null,this.originalBodyPad=null,this.scrollbarWidth=0,this.ignoreBackdropClick=!1,this.options.remote&&this.$element.find(".modal-content").load(this.options.remote,a.proxy(function(){this.$element.trigger("loaded.bs.modal")},this))};c.VERSION="3.3.5",c.TRANSITION_DURATION=300,c.BACKDROP_TRANSITION_DURATION=150,c.DEFAULTS={backdrop:!0,keyboard:!0,show:!0},c.prototype.toggle=function(a){return this.isShown?this.hide():this.show(a)},c.prototype.show=function(b){var d=this,e=a.Event("show.bs.modal",{relatedTarget:b});this.$element.trigger(e),this.isShown||e.isDefaultPrevented()||(this.isShown=!0,this.checkScrollbar(),this.setScrollbar(),this.$body.addClass("modal-open"),this.escape(),this.resize(),this.$element.on("click.dismiss.bs.modal",'[data-dismiss="modal"]',a.proxy(this.hide,this)),this.$dialog.on("mousedown.dismiss.bs.modal",function(){d.$element.one("mouseup.dismiss.bs.modal",function(b){a(b.target).is(d.$element)&&(d.ignoreBackdropClick=!0)})}),this.backdrop(function(){var e=a.support.transition&&d.$element.hasClass("fade");d.$element.parent().length||d.$element.appendTo(d.$body),d.$element.show().scrollTop(0),d.adjustDialog(),e&&d.$element[0].offsetWidth,d.$element.addClass("in"),d.enforceFocus();var f=a.Event("shown.bs.modal",{relatedTarget:b});e?d.$dialog.one("bsTransitionEnd",function(){d.$element.trigger("focus").trigger(f)}).emulateTransitionEnd(c.TRANSITION_DURATION):d.$element.trigger("focus").trigger(f)}))},c.prototype.hide=function(b){b&&b.preventDefault(),b=a.Event("hide.bs.modal"),this.$element.trigger(b),this.isShown&&!b.isDefaultPrevented()&&(this.isShown=!1,this.escape(),this.resize(),a(document).off("focusin.bs.modal"),this.$element.removeClass("in").off("click.dismiss.bs.modal").off("mouseup.dismiss.bs.modal"),this.$dialog.off("mousedown.dismiss.bs.modal"),a.support.transition&&this.$element.hasClass("fade")?this.$element.one("bsTransitionEnd",a.proxy(this.hideModal,this)).emulateTransitionEnd(c.TRANSITION_DURATION):this.hideModal())},c.prototype.enforceFocus=function(){a(document).off("focusin.bs.modal").on("focusin.bs.modal",a.proxy(function(a){this.$element[0]===a.target||this.$element.has(a.target).length||this.$element.trigger("focus")},this))},c.prototype.escape=function(){this.isShown&&this.options.keyboard?this.$element.on("keydown.dismiss.bs.modal",a.proxy(function(a){27==a.which&&this.hide()},this)):this.isShown||this.$element.off("keydown.dismiss.bs.modal")},c.prototype.resize=function(){this.isShown?a(window).on("resize.bs.modal",a.proxy(this.handleUpdate,this)):a(window).off("resize.bs.modal")},c.prototype.hideModal=function(){var a=this;this.$element.hide(),this.backdrop(function(){a.$body.removeClass("modal-open"),a.resetAdjustments(),a.resetScrollbar(),a.$element.trigger("hidden.bs.modal")})},c.prototype.removeBackdrop=function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},c.prototype.backdrop=function(b){var d=this,e=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var f=a.support.transition&&e;if(this.$backdrop=a(document.createElement("div")).addClass("modal-backdrop "+e).appendTo(this.$body),this.$element.on("click.dismiss.bs.modal",a.proxy(function(a){return this.ignoreBackdropClick?void(this.ignoreBackdropClick=!1):void(a.target===a.currentTarget&&("static"==this.options.backdrop?this.$element[0].focus():this.hide()))},this)),f&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in"),!b)return;f?this.$backdrop.one("bsTransitionEnd",b).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):b()}else if(!this.isShown&&this.$backdrop){this.$backdrop.removeClass("in");var g=function(){d.removeBackdrop(),b&&b()};a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one("bsTransitionEnd",g).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):g()}else b&&b()},c.prototype.handleUpdate=function(){this.adjustDialog()},c.prototype.adjustDialog=function(){var a=this.$element[0].scrollHeight>document.documentElement.clientHeight;this.$element.css({paddingLeft:!this.bodyIsOverflowing&&a?this.scrollbarWidth:"",paddingRight:this.bodyIsOverflowing&&!a?this.scrollbarWidth:""})},c.prototype.resetAdjustments=function(){this.$element.css({paddingLeft:"",paddingRight:""})},c.prototype.checkScrollbar=function(){var a=window.innerWidth;if(!a){var b=document.documentElement.getBoundingClientRect();a=b.right-Math.abs(b.left)}this.bodyIsOverflowing=document.body.clientWidth<a,this.scrollbarWidth=this.measureScrollbar()},c.prototype.setScrollbar=function(){var a=parseInt(this.$body.css("padding-right")||0,10);this.originalBodyPad=document.body.style.paddingRight||"",this.bodyIsOverflowing&&this.$body.css("padding-right",a+this.scrollbarWidth)},c.prototype.resetScrollbar=function(){this.$body.css("padding-right",this.originalBodyPad)},c.prototype.measureScrollbar=function(){var a=document.createElement("div");a.className="modal-scrollbar-measure",this.$body.append(a);var b=a.offsetWidth-a.clientWidth;return this.$body[0].removeChild(a),b};var d=a.fn.modal;a.fn.modal=b,a.fn.modal.Constructor=c,a.fn.modal.noConflict=function(){return a.fn.modal=d,this},a(document).on("click.bs.modal.data-api",'[data-toggle="modal"]',function(c){var d=a(this),e=d.attr("href"),f=a(d.attr("data-target")||e&&e.replace(/.*(?=#[^\s]+$)/,"")),g=f.data("bs.modal")?"toggle":a.extend({remote:!/#/.test(e)&&e},f.data(),d.data());d.is("a")&&c.preventDefault(),f.one("show.bs.modal",function(a){a.isDefaultPrevented()||f.one("hidden.bs.modal",function(){d.is(":visible")&&d.trigger("focus")})}),b.call(f,g,this)})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tooltip"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.tooltip",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.type=null,this.options=null,this.enabled=null,this.timeout=null,this.hoverState=null,this.$element=null,this.inState=null,this.init("tooltip",a,b)};c.VERSION="3.3.5",c.TRANSITION_DURATION=150,c.DEFAULTS={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1,viewport:{selector:"body",padding:0}},c.prototype.init=function(b,c,d){if(this.enabled=!0,this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.$viewport=this.options.viewport&&a(a.isFunction(this.options.viewport)?this.options.viewport.call(this,this.$element):this.options.viewport.selector||this.options.viewport),this.inState={click:!1,hover:!1,focus:!1},this.$element[0]instanceof document.constructor&&!this.options.selector)throw new Error("`selector` option must be specified when initializing "+this.type+" on the window.document object!");for(var e=this.options.trigger.split(" "),f=e.length;f--;){var g=e[f];if("click"==g)this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this));else if("manual"!=g){var h="hover"==g?"mouseenter":"focusin",i="hover"==g?"mouseleave":"focusout";this.$element.on(h+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(i+"."+this.type,this.options.selector,a.proxy(this.leave,this))}}this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.getOptions=function(b){return b=a.extend({},this.getDefaults(),this.$element.data(),b),b.delay&&"number"==typeof b.delay&&(b.delay={show:b.delay,hide:b.delay}),b},c.prototype.getDelegateOptions=function(){var b={},c=this.getDefaults();return this._options&&a.each(this._options,function(a,d){c[a]!=d&&(b[a]=d)}),b},c.prototype.enter=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),b instanceof a.Event&&(c.inState["focusin"==b.type?"focus":"hover"]=!0),c.tip().hasClass("in")||"in"==c.hoverState?void(c.hoverState="in"):(clearTimeout(c.timeout),c.hoverState="in",c.options.delay&&c.options.delay.show?void(c.timeout=setTimeout(function(){"in"==c.hoverState&&c.show()},c.options.delay.show)):c.show())},c.prototype.isInStateTrue=function(){for(var a in this.inState)if(this.inState[a])return!0;return!1},c.prototype.leave=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),b instanceof a.Event&&(c.inState["focusout"==b.type?"focus":"hover"]=!1),c.isInStateTrue()?void 0:(clearTimeout(c.timeout),c.hoverState="out",c.options.delay&&c.options.delay.hide?void(c.timeout=setTimeout(function(){"out"==c.hoverState&&c.hide()},c.options.delay.hide)):c.hide())},c.prototype.show=function(){var b=a.Event("show.bs."+this.type);if(this.hasContent()&&this.enabled){this.$element.trigger(b);var d=a.contains(this.$element[0].ownerDocument.documentElement,this.$element[0]);if(b.isDefaultPrevented()||!d)return;var e=this,f=this.tip(),g=this.getUID(this.type);this.setContent(),f.attr("id",g),this.$element.attr("aria-describedby",g),this.options.animation&&f.addClass("fade");var h="function"==typeof this.options.placement?this.options.placement.call(this,f[0],this.$element[0]):this.options.placement,i=/\s?auto?\s?/i,j=i.test(h);j&&(h=h.replace(i,"")||"top"),f.detach().css({top:0,left:0,display:"block"}).addClass(h).data("bs."+this.type,this),this.options.container?f.appendTo(this.options.container):f.insertAfter(this.$element),this.$element.trigger("inserted.bs."+this.type);var k=this.getPosition(),l=f[0].offsetWidth,m=f[0].offsetHeight;if(j){var n=h,o=this.getPosition(this.$viewport);h="bottom"==h&&k.bottom+m>o.bottom?"top":"top"==h&&k.top-m<o.top?"bottom":"right"==h&&k.right+l>o.width?"left":"left"==h&&k.left-l<o.left?"right":h,f.removeClass(n).addClass(h)}var p=this.getCalculatedOffset(h,k,l,m);this.applyPlacement(p,h);var q=function(){var a=e.hoverState;e.$element.trigger("shown.bs."+e.type),e.hoverState=null,"out"==a&&e.leave(e)};a.support.transition&&this.$tip.hasClass("fade")?f.one("bsTransitionEnd",q).emulateTransitionEnd(c.TRANSITION_DURATION):q()}},c.prototype.applyPlacement=function(b,c){var d=this.tip(),e=d[0].offsetWidth,f=d[0].offsetHeight,g=parseInt(d.css("margin-top"),10),h=parseInt(d.css("margin-left"),10);isNaN(g)&&(g=0),isNaN(h)&&(h=0),b.top+=g,b.left+=h,a.offset.setOffset(d[0],a.extend({using:function(a){d.css({top:Math.round(a.top),left:Math.round(a.left)})}},b),0),d.addClass("in");var i=d[0].offsetWidth,j=d[0].offsetHeight;"top"==c&&j!=f&&(b.top=b.top+f-j);var k=this.getViewportAdjustedDelta(c,b,i,j);k.left?b.left+=k.left:b.top+=k.top;var l=/top|bottom/.test(c),m=l?2*k.left-e+i:2*k.top-f+j,n=l?"offsetWidth":"offsetHeight";d.offset(b),this.replaceArrow(m,d[0][n],l)},c.prototype.replaceArrow=function(a,b,c){this.arrow().css(c?"left":"top",50*(1-a/b)+"%").css(c?"top":"left","")},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},c.prototype.hide=function(b){function d(){"in"!=e.hoverState&&f.detach(),e.$element.removeAttr("aria-describedby").trigger("hidden.bs."+e.type),b&&b()}var e=this,f=a(this.$tip),g=a.Event("hide.bs."+this.type);return this.$element.trigger(g),g.isDefaultPrevented()?void 0:(f.removeClass("in"),a.support.transition&&f.hasClass("fade")?f.one("bsTransitionEnd",d).emulateTransitionEnd(c.TRANSITION_DURATION):d(),this.hoverState=null,this)},c.prototype.fixTitle=function(){var a=this.$element;(a.attr("title")||"string"!=typeof a.attr("data-original-title"))&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},c.prototype.hasContent=function(){return this.getTitle()},c.prototype.getPosition=function(b){b=b||this.$element;var c=b[0],d="BODY"==c.tagName,e=c.getBoundingClientRect();null==e.width&&(e=a.extend({},e,{width:e.right-e.left,height:e.bottom-e.top}));var f=d?{top:0,left:0}:b.offset(),g={scroll:d?document.documentElement.scrollTop||document.body.scrollTop:b.scrollTop()},h=d?{width:a(window).width(),height:a(window).height()}:null;return a.extend({},e,g,h,f)},c.prototype.getCalculatedOffset=function(a,b,c,d){return"bottom"==a?{top:b.top+b.height,left:b.left+b.width/2-c/2}:"top"==a?{top:b.top-d,left:b.left+b.width/2-c/2}:"left"==a?{top:b.top+b.height/2-d/2,left:b.left-c}:{top:b.top+b.height/2-d/2,left:b.left+b.width}},c.prototype.getViewportAdjustedDelta=function(a,b,c,d){var e={top:0,left:0};if(!this.$viewport)return e;var f=this.options.viewport&&this.options.viewport.padding||0,g=this.getPosition(this.$viewport);if(/right|left/.test(a)){var h=b.top-f-g.scroll,i=b.top+f-g.scroll+d;h<g.top?e.top=g.top-h:i>g.top+g.height&&(e.top=g.top+g.height-i)}else{var j=b.left-f,k=b.left+f+c;j<g.left?e.left=g.left-j:k>g.right&&(e.left=g.left+g.width-k)}return e},c.prototype.getTitle=function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||("function"==typeof c.title?c.title.call(b[0]):c.title)},c.prototype.getUID=function(a){do a+=~~(1e6*Math.random());while(document.getElementById(a));return a},c.prototype.tip=function(){if(!this.$tip&&(this.$tip=a(this.options.template),1!=this.$tip.length))throw new Error(this.type+" `template` option must consist of exactly 1 top-level element!");return this.$tip},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},c.prototype.enable=function(){this.enabled=!0},c.prototype.disable=function(){this.enabled=!1},c.prototype.toggleEnabled=function(){this.enabled=!this.enabled},c.prototype.toggle=function(b){var c=this;b&&(c=a(b.currentTarget).data("bs."+this.type),c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c))),b?(c.inState.click=!c.inState.click,c.isInStateTrue()?c.enter(c):c.leave(c)):c.tip().hasClass("in")?c.leave(c):c.enter(c)},c.prototype.destroy=function(){var a=this;clearTimeout(this.timeout),this.hide(function(){a.$element.off("."+a.type).removeData("bs."+a.type),a.$tip&&a.$tip.detach(),a.$tip=null,a.$arrow=null,a.$viewport=null})};var d=a.fn.tooltip;a.fn.tooltip=b,a.fn.tooltip.Constructor=c,a.fn.tooltip.noConflict=function(){return a.fn.tooltip=d,this}}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.popover"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.popover",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.init("popover",a,b)};if(!a.fn.tooltip)throw new Error("Popover requires tooltip.js");c.VERSION="3.3.5",c.DEFAULTS=a.extend({},a.fn.tooltip.Constructor.DEFAULTS,{placement:"right",trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),c.prototype=a.extend({},a.fn.tooltip.Constructor.prototype),c.prototype.constructor=c,c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content").children().detach().end()[this.options.html?"string"==typeof c?"html":"append":"text"](c),a.removeClass("fade top bottom left right in"),a.find(".popover-title").html()||a.find(".popover-title").hide()},c.prototype.hasContent=function(){return this.getTitle()||this.getContent()},c.prototype.getContent=function(){var a=this.$element,b=this.options;return a.attr("data-content")||("function"==typeof b.content?b.content.call(a[0]):b.content)},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".arrow")};var d=a.fn.popover;a.fn.popover=b,a.fn.popover.Constructor=c,a.fn.popover.noConflict=function(){return a.fn.popover=d,this}}(jQuery),+function(a){"use strict";function b(c,d){this.$body=a(document.body),this.$scrollElement=a(a(c).is(document.body)?window:c),this.options=a.extend({},b.DEFAULTS,d),this.selector=(this.options.target||"")+" .nav li > a",this.offsets=[],this.targets=[],this.activeTarget=null,this.scrollHeight=0,this.$scrollElement.on("scroll.bs.scrollspy",a.proxy(this.process,this)),this.refresh(),this.process()}function c(c){return this.each(function(){var d=a(this),e=d.data("bs.scrollspy"),f="object"==typeof c&&c;e||d.data("bs.scrollspy",e=new b(this,f)),"string"==typeof c&&e[c]()})}b.VERSION="3.3.5",b.DEFAULTS={offset:10},b.prototype.getScrollHeight=function(){return this.$scrollElement[0].scrollHeight||Math.max(this.$body[0].scrollHeight,document.documentElement.scrollHeight)},b.prototype.refresh=function(){var b=this,c="offset",d=0;this.offsets=[],this.targets=[],this.scrollHeight=this.getScrollHeight(),a.isWindow(this.$scrollElement[0])||(c="position",d=this.$scrollElement.scrollTop()),this.$body.find(this.selector).map(function(){var b=a(this),e=b.data("target")||b.attr("href"),f=/^#./.test(e)&&a(e);return f&&f.length&&f.is(":visible")&&[[f[c]().top+d,e]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},b.prototype.process=function(){var a,b=this.$scrollElement.scrollTop()+this.options.offset,c=this.getScrollHeight(),d=this.options.offset+c-this.$scrollElement.height(),e=this.offsets,f=this.targets,g=this.activeTarget;if(this.scrollHeight!=c&&this.refresh(),b>=d)return g!=(a=f[f.length-1])&&this.activate(a);if(g&&b<e[0])return this.activeTarget=null,this.clear();for(a=e.length;a--;)g!=f[a]&&b>=e[a]&&(void 0===e[a+1]||b<e[a+1])&&this.activate(f[a])},b.prototype.activate=function(b){this.activeTarget=b,this.clear();var c=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',d=a(c).parents("li").addClass("active");d.parent(".dropdown-menu").length&&(d=d.closest("li.dropdown").addClass("active")), +d.trigger("activate.bs.scrollspy")},b.prototype.clear=function(){a(this.selector).parentsUntil(this.options.target,".active").removeClass("active")};var d=a.fn.scrollspy;a.fn.scrollspy=c,a.fn.scrollspy.Constructor=b,a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=d,this},a(window).on("load.bs.scrollspy.data-api",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);c.call(b,b.data())})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tab");e||d.data("bs.tab",e=new c(this)),"string"==typeof b&&e[b]()})}var c=function(b){this.element=a(b)};c.VERSION="3.3.5",c.TRANSITION_DURATION=150,c.prototype.show=function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.data("target");if(d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),!b.parent("li").hasClass("active")){var e=c.find(".active:last a"),f=a.Event("hide.bs.tab",{relatedTarget:b[0]}),g=a.Event("show.bs.tab",{relatedTarget:e[0]});if(e.trigger(f),b.trigger(g),!g.isDefaultPrevented()&&!f.isDefaultPrevented()){var h=a(d);this.activate(b.closest("li"),c),this.activate(h,h.parent(),function(){e.trigger({type:"hidden.bs.tab",relatedTarget:b[0]}),b.trigger({type:"shown.bs.tab",relatedTarget:e[0]})})}}},c.prototype.activate=function(b,d,e){function f(){g.removeClass("active").find("> .dropdown-menu > .active").removeClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!1),b.addClass("active").find('[data-toggle="tab"]').attr("aria-expanded",!0),h?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu").length&&b.closest("li.dropdown").addClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!0),e&&e()}var g=d.find("> .active"),h=e&&a.support.transition&&(g.length&&g.hasClass("fade")||!!d.find("> .fade").length);g.length&&h?g.one("bsTransitionEnd",f).emulateTransitionEnd(c.TRANSITION_DURATION):f(),g.removeClass("in")};var d=a.fn.tab;a.fn.tab=b,a.fn.tab.Constructor=c,a.fn.tab.noConflict=function(){return a.fn.tab=d,this};var e=function(c){c.preventDefault(),b.call(a(this),"show")};a(document).on("click.bs.tab.data-api",'[data-toggle="tab"]',e).on("click.bs.tab.data-api",'[data-toggle="pill"]',e)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.affix"),f="object"==typeof b&&b;e||d.data("bs.affix",e=new c(this,f)),"string"==typeof b&&e[b]()})}var c=function(b,d){this.options=a.extend({},c.DEFAULTS,d),this.$target=a(this.options.target).on("scroll.bs.affix.data-api",a.proxy(this.checkPosition,this)).on("click.bs.affix.data-api",a.proxy(this.checkPositionWithEventLoop,this)),this.$element=a(b),this.affixed=null,this.unpin=null,this.pinnedOffset=null,this.checkPosition()};c.VERSION="3.3.5",c.RESET="affix affix-top affix-bottom",c.DEFAULTS={offset:0,target:window},c.prototype.getState=function(a,b,c,d){var e=this.$target.scrollTop(),f=this.$element.offset(),g=this.$target.height();if(null!=c&&"top"==this.affixed)return c>e?"top":!1;if("bottom"==this.affixed)return null!=c?e+this.unpin<=f.top?!1:"bottom":a-d>=e+g?!1:"bottom";var h=null==this.affixed,i=h?e:f.top,j=h?g:b;return null!=c&&c>=e?"top":null!=d&&i+j>=a-d?"bottom":!1},c.prototype.getPinnedOffset=function(){if(this.pinnedOffset)return this.pinnedOffset;this.$element.removeClass(c.RESET).addClass("affix");var a=this.$target.scrollTop(),b=this.$element.offset();return this.pinnedOffset=b.top-a},c.prototype.checkPositionWithEventLoop=function(){setTimeout(a.proxy(this.checkPosition,this),1)},c.prototype.checkPosition=function(){if(this.$element.is(":visible")){var b=this.$element.height(),d=this.options.offset,e=d.top,f=d.bottom,g=Math.max(a(document).height(),a(document.body).height());"object"!=typeof d&&(f=e=d),"function"==typeof e&&(e=d.top(this.$element)),"function"==typeof f&&(f=d.bottom(this.$element));var h=this.getState(g,b,e,f);if(this.affixed!=h){null!=this.unpin&&this.$element.css("top","");var i="affix"+(h?"-"+h:""),j=a.Event(i+".bs.affix");if(this.$element.trigger(j),j.isDefaultPrevented())return;this.affixed=h,this.unpin="bottom"==h?this.getPinnedOffset():null,this.$element.removeClass(c.RESET).addClass(i).trigger(i.replace("affix","affixed")+".bs.affix")}"bottom"==h&&this.$element.offset({top:g-b-f})}};var d=a.fn.affix;a.fn.affix=b,a.fn.affix.Constructor=c,a.fn.affix.noConflict=function(){return a.fn.affix=d,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var c=a(this),d=c.data();d.offset=d.offset||{},null!=d.offsetBottom&&(d.offset.bottom=d.offsetBottom),null!=d.offsetTop&&(d.offset.top=d.offsetTop),b.call(c,d)})})}(jQuery);</script> +<script>/** +* @preserve HTML5 Shiv 3.7.2 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed +*/ +// Only run this code in IE 8 +if (!!window.navigator.userAgent.match("MSIE 8")) { +!function(a,b){function c(a,b){var c=a.createElement("p"),d=a.getElementsByTagName("head")[0]||a.documentElement;return c.innerHTML="x<style>"+b+"</style>",d.insertBefore(c.lastChild,d.firstChild)}function d(){var a=t.elements;return"string"==typeof a?a.split(" "):a}function e(a,b){var c=t.elements;"string"!=typeof c&&(c=c.join(" ")),"string"!=typeof a&&(a=a.join(" ")),t.elements=c+" "+a,j(b)}function f(a){var b=s[a[q]];return b||(b={},r++,a[q]=r,s[r]=b),b}function g(a,c,d){if(c||(c=b),l)return c.createElement(a);d||(d=f(c));var e;return e=d.cache[a]?d.cache[a].cloneNode():p.test(a)?(d.cache[a]=d.createElem(a)).cloneNode():d.createElem(a),!e.canHaveChildren||o.test(a)||e.tagUrn?e:d.frag.appendChild(e)}function h(a,c){if(a||(a=b),l)return a.createDocumentFragment();c=c||f(a);for(var e=c.frag.cloneNode(),g=0,h=d(),i=h.length;i>g;g++)e.createElement(h[g]);return e}function i(a,b){b.cache||(b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag()),a.createElement=function(c){return t.shivMethods?g(c,a,b):b.createElem(c)},a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+d().join().replace(/[\w\-:]+/g,function(a){return b.createElem(a),b.frag.createElement(a),'c("'+a+'")'})+");return n}")(t,b.frag)}function j(a){a||(a=b);var d=f(a);return!t.shivCSS||k||d.hasCSS||(d.hasCSS=!!c(a,"article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}")),l||i(a,d),a}var k,l,m="3.7.2",n=a.html5||{},o=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,p=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,q="_html5shiv",r=0,s={};!function(){try{var a=b.createElement("a");a.innerHTML="<xyz></xyz>",k="hidden"in a,l=1==a.childNodes.length||function(){b.createElement("a");var a=b.createDocumentFragment();return"undefined"==typeof a.cloneNode||"undefined"==typeof a.createDocumentFragment||"undefined"==typeof a.createElement}()}catch(c){k=!0,l=!0}}();var t={elements:n.elements||"abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output picture progress section summary template time video",version:m,shivCSS:n.shivCSS!==!1,supportsUnknownElements:l,shivMethods:n.shivMethods!==!1,type:"default",shivDocument:j,createElement:g,createDocumentFragment:h,addElements:e};a.html5=t,j(b)}(this,document); +}; +</script> +<script>/*! Respond.js v1.4.2: min/max-width media query polyfill * Copyright 2013 Scott Jehl + * Licensed under https://github.com/scottjehl/Respond/blob/master/LICENSE-MIT + * */ + +// Only run this code in IE 8 +if (!!window.navigator.userAgent.match("MSIE 8")) { +!function(a){"use strict";a.matchMedia=a.matchMedia||function(a){var b,c=a.documentElement,d=c.firstElementChild||c.firstChild,e=a.createElement("body"),f=a.createElement("div");return f.id="mq-test-1",f.style.cssText="position:absolute;top:-100em",e.style.background="none",e.appendChild(f),function(a){return f.innerHTML='­<style media="'+a+'"> #mq-test-1 { width: 42px; }</style>',c.insertBefore(e,d),b=42===f.offsetWidth,c.removeChild(e),{matches:b,media:a}}}(a.document)}(this),function(a){"use strict";function b(){u(!0)}var c={};a.respond=c,c.update=function(){};var d=[],e=function(){var b=!1;try{b=new a.XMLHttpRequest}catch(c){b=new a.ActiveXObject("Microsoft.XMLHTTP")}return function(){return b}}(),f=function(a,b){var c=e();c&&(c.open("GET",a,!0),c.onreadystatechange=function(){4!==c.readyState||200!==c.status&&304!==c.status||b(c.responseText)},4!==c.readyState&&c.send(null))};if(c.ajax=f,c.queue=d,c.regex={media:/@media[^\{]+\{([^\{\}]*\{[^\}\{]*\})+/gi,keyframes:/@(?:\-(?:o|moz|webkit)\-)?keyframes[^\{]+\{(?:[^\{\}]*\{[^\}\{]*\})+[^\}]*\}/gi,urls:/(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g,findStyles:/@media *([^\{]+)\{([\S\s]+?)$/,only:/(only\s+)?([a-zA-Z]+)\s?/,minw:/\([\s]*min\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/,maxw:/\([\s]*max\-width\s*:[\s]*([\s]*[0-9\.]+)(px|em)[\s]*\)/},c.mediaQueriesSupported=a.matchMedia&&null!==a.matchMedia("only all")&&a.matchMedia("only all").matches,!c.mediaQueriesSupported){var g,h,i,j=a.document,k=j.documentElement,l=[],m=[],n=[],o={},p=30,q=j.getElementsByTagName("head")[0]||k,r=j.getElementsByTagName("base")[0],s=q.getElementsByTagName("link"),t=function(){var a,b=j.createElement("div"),c=j.body,d=k.style.fontSize,e=c&&c.style.fontSize,f=!1;return b.style.cssText="position:absolute;font-size:1em;width:1em",c||(c=f=j.createElement("body"),c.style.background="none"),k.style.fontSize="100%",c.style.fontSize="100%",c.appendChild(b),f&&k.insertBefore(c,k.firstChild),a=b.offsetWidth,f?k.removeChild(c):c.removeChild(b),k.style.fontSize=d,e&&(c.style.fontSize=e),a=i=parseFloat(a)},u=function(b){var c="clientWidth",d=k[c],e="CSS1Compat"===j.compatMode&&d||j.body[c]||d,f={},o=s[s.length-1],r=(new Date).getTime();if(b&&g&&p>r-g)return a.clearTimeout(h),h=a.setTimeout(u,p),void 0;g=r;for(var v in l)if(l.hasOwnProperty(v)){var w=l[v],x=w.minw,y=w.maxw,z=null===x,A=null===y,B="em";x&&(x=parseFloat(x)*(x.indexOf(B)>-1?i||t():1)),y&&(y=parseFloat(y)*(y.indexOf(B)>-1?i||t():1)),w.hasquery&&(z&&A||!(z||e>=x)||!(A||y>=e))||(f[w.media]||(f[w.media]=[]),f[w.media].push(m[w.rules]))}for(var C in n)n.hasOwnProperty(C)&&n[C]&&n[C].parentNode===q&&q.removeChild(n[C]);n.length=0;for(var D in f)if(f.hasOwnProperty(D)){var E=j.createElement("style"),F=f[D].join("\n");E.type="text/css",E.media=D,q.insertBefore(E,o.nextSibling),E.styleSheet?E.styleSheet.cssText=F:E.appendChild(j.createTextNode(F)),n.push(E)}},v=function(a,b,d){var e=a.replace(c.regex.keyframes,"").match(c.regex.media),f=e&&e.length||0;b=b.substring(0,b.lastIndexOf("/"));var g=function(a){return a.replace(c.regex.urls,"$1"+b+"$2$3")},h=!f&&d;b.length&&(b+="/"),h&&(f=1);for(var i=0;f>i;i++){var j,k,n,o;h?(j=d,m.push(g(a))):(j=e[i].match(c.regex.findStyles)&&RegExp.$1,m.push(RegExp.$2&&g(RegExp.$2))),n=j.split(","),o=n.length;for(var p=0;o>p;p++)k=n[p],l.push({media:k.split("(")[0].match(c.regex.only)&&RegExp.$2||"all",rules:m.length-1,hasquery:k.indexOf("(")>-1,minw:k.match(c.regex.minw)&&parseFloat(RegExp.$1)+(RegExp.$2||""),maxw:k.match(c.regex.maxw)&&parseFloat(RegExp.$1)+(RegExp.$2||"")})}u()},w=function(){if(d.length){var b=d.shift();f(b.href,function(c){v(c,b.href,b.media),o[b.href]=!0,a.setTimeout(function(){w()},0)})}},x=function(){for(var b=0;b<s.length;b++){var c=s[b],e=c.href,f=c.media,g=c.rel&&"stylesheet"===c.rel.toLowerCase();e&&g&&!o[e]&&(c.styleSheet&&c.styleSheet.rawCssText?(v(c.styleSheet.rawCssText,e,f),o[e]=!0):(!/^([a-zA-Z:]*\/\/)/.test(e)&&!r||e.replace(RegExp.$1,"").split("/")[0]===a.location.host)&&("//"===e.substring(0,2)&&(e=a.location.protocol+e),d.push({href:e,media:f})))}w()};x(),c.update=x,c.getEmValue=t,a.addEventListener?a.addEventListener("resize",b,!1):a.attachEvent&&a.attachEvent("onresize",b)}}(this); +}; +</script> +<script> + +/** + * jQuery Plugin: Sticky Tabs + * + * @author Aidan Lister <aidan@php.net> + * adapted by Ruben Arslan to activate parent tabs too + * http://www.aidanlister.com/2014/03/persisting-the-tab-state-in-bootstrap/ + */ +(function($) { + "use strict"; + $.fn.rmarkdownStickyTabs = function() { + var context = this; + // Show the tab corresponding with the hash in the URL, or the first tab + var showStuffFromHash = function() { + var hash = window.location.hash; + var selector = hash ? 'a[href="' + hash + '"]' : 'li.active > a'; + var $selector = $(selector, context); + if($selector.data('toggle') === "tab") { + $selector.tab('show'); + // walk up the ancestors of this element, show any hidden tabs + $selector.parents('.section.tabset').each(function(i, elm) { + var link = $('a[href="#' + $(elm).attr('id') + '"]'); + if(link.data('toggle') === "tab") { + link.tab("show"); + } + }); + } + }; + + + // Set the correct tab when the page loads + showStuffFromHash(context); + + // Set the correct tab when a user uses their back/forward button + $(window).on('hashchange', function() { + showStuffFromHash(context); + }); + + // Change the URL when tabs are clicked + $('a', context).on('click', function(e) { + history.pushState(null, null, this.href); + showStuffFromHash(context); + }); + + return this; + }; +}(jQuery)); + +window.buildTabsets = function(tocID) { + + // build a tabset from a section div with the .tabset class + function buildTabset(tabset) { + + // check for fade and pills options + var fade = tabset.hasClass("tabset-fade"); + var pills = tabset.hasClass("tabset-pills"); + var navClass = pills ? "nav-pills" : "nav-tabs"; + + // determine the heading level of the tabset and tabs + var match = tabset.attr('class').match(/level(\d) /); + if (match === null) + return; + var tabsetLevel = Number(match[1]); + var tabLevel = tabsetLevel + 1; + + // find all subheadings immediately below + var tabs = tabset.find("div.section.level" + tabLevel); + if (!tabs.length) + return; + + // create tablist and tab-content elements + var tabList = $('<ul class="nav ' + navClass + '" role="tablist"></ul>'); + $(tabs[0]).before(tabList); + var tabContent = $('<div class="tab-content"></div>'); + $(tabs[0]).before(tabContent); + + // build the tabset + var activeTab = 0; + tabs.each(function(i) { + + // get the tab div + var tab = $(tabs[i]); + + // get the id then sanitize it for use with bootstrap tabs + var id = tab.attr('id'); + + // see if this is marked as the active tab + if (tab.hasClass('active')) + activeTab = i; + + // remove any table of contents entries associated with + // this ID (since we'll be removing the heading element) + $("div#" + tocID + " li a[href='#" + id + "']").parent().remove(); + + // sanitize the id for use with bootstrap tabs + id = id.replace(/[.\/?&!#<>]/g, '').replace(/\s/g, '_'); + tab.attr('id', id); + + // get the heading element within it, grab it's text, then remove it + var heading = tab.find('h' + tabLevel + ':first'); + var headingText = heading.html(); + heading.remove(); + + // build and append the tab list item + var a = $('<a role="tab" data-toggle="tab">' + headingText + '</a>'); + a.attr('href', '#' + id); + a.attr('aria-controls', id); + var li = $('<li role="presentation"></li>'); + li.append(a); + tabList.append(li); + + // set it's attributes + tab.attr('role', 'tabpanel'); + tab.addClass('tab-pane'); + tab.addClass('tabbed-pane'); + if (fade) + tab.addClass('fade'); + + // move it into the tab content div + tab.detach().appendTo(tabContent); + }); + + // set active tab + $(tabList.children('li')[activeTab]).addClass('active'); + var active = $(tabContent.children('div.section')[activeTab]); + active.addClass('active'); + if (fade) + active.addClass('in'); + + if (tabset.hasClass("tabset-sticky")) + tabset.rmarkdownStickyTabs(); + } + + // convert section divs with the .tabset class to tabsets + var tabsets = $("div.section.tabset"); + tabsets.each(function(i) { + buildTabset($(tabsets[i])); + }); +}; + +</script> +<style type="text/css">.hljs-literal { +color: #990073; +} +.hljs-number { +color: #099; +} +.hljs-comment { +color: #998; +font-style: italic; +} +.hljs-keyword { +color: #900; +font-weight: bold; +} +.hljs-string { +color: #d14; +} +</style> +<script src="data:application/javascript;base64,LyohIGhpZ2hsaWdodC5qcyB2OS4xMi4wIHwgQlNEMyBMaWNlbnNlIHwgZ2l0LmlvL2hsanNsaWNlbnNlICovCiFmdW5jdGlvbihlKXt2YXIgbj0ib2JqZWN0Ij09dHlwZW9mIHdpbmRvdyYmd2luZG93fHwib2JqZWN0Ij09dHlwZW9mIHNlbGYmJnNlbGY7InVuZGVmaW5lZCIhPXR5cGVvZiBleHBvcnRzP2UoZXhwb3J0cyk6biYmKG4uaGxqcz1lKHt9KSwiZnVuY3Rpb24iPT10eXBlb2YgZGVmaW5lJiZkZWZpbmUuYW1kJiZkZWZpbmUoW10sZnVuY3Rpb24oKXtyZXR1cm4gbi5obGpzfSkpfShmdW5jdGlvbihlKXtmdW5jdGlvbiBuKGUpe3JldHVybiBlLnJlcGxhY2UoLyYvZywiJmFtcDsiKS5yZXBsYWNlKC88L2csIiZsdDsiKS5yZXBsYWNlKC8+L2csIiZndDsiKX1mdW5jdGlvbiB0KGUpe3JldHVybiBlLm5vZGVOYW1lLnRvTG93ZXJDYXNlKCl9ZnVuY3Rpb24gcihlLG4pe3ZhciB0PWUmJmUuZXhlYyhuKTtyZXR1cm4gdCYmMD09PXQuaW5kZXh9ZnVuY3Rpb24gYShlKXtyZXR1cm4gay50ZXN0KGUpfWZ1bmN0aW9uIGkoZSl7dmFyIG4sdCxyLGksbz1lLmNsYXNzTmFtZSsiICI7aWYobys9ZS5wYXJlbnROb2RlP2UucGFyZW50Tm9kZS5jbGFzc05hbWU6IiIsdD1CLmV4ZWMobykpcmV0dXJuIHcodFsxXSk/dFsxXToibm8taGlnaGxpZ2h0Ijtmb3Iobz1vLnNwbGl0KC9ccysvKSxuPTAscj1vLmxlbmd0aDtyPm47bisrKWlmKGk9b1tuXSxhKGkpfHx3KGkpKXJldHVybiBpfWZ1bmN0aW9uIG8oZSl7dmFyIG4sdD17fSxyPUFycmF5LnByb3RvdHlwZS5zbGljZS5jYWxsKGFyZ3VtZW50cywxKTtmb3IobiBpbiBlKXRbbl09ZVtuXTtyZXR1cm4gci5mb3JFYWNoKGZ1bmN0aW9uKGUpe2ZvcihuIGluIGUpdFtuXT1lW25dfSksdH1mdW5jdGlvbiB1KGUpe3ZhciBuPVtdO3JldHVybiBmdW5jdGlvbiByKGUsYSl7Zm9yKHZhciBpPWUuZmlyc3RDaGlsZDtpO2k9aS5uZXh0U2libGluZykzPT09aS5ub2RlVHlwZT9hKz1pLm5vZGVWYWx1ZS5sZW5ndGg6MT09PWkubm9kZVR5cGUmJihuLnB1c2goe2V2ZW50OiJzdGFydCIsb2Zmc2V0OmEsbm9kZTppfSksYT1yKGksYSksdChpKS5tYXRjaCgvYnJ8aHJ8aW1nfGlucHV0Lyl8fG4ucHVzaCh7ZXZlbnQ6InN0b3AiLG9mZnNldDphLG5vZGU6aX0pKTtyZXR1cm4gYX0oZSwwKSxufWZ1bmN0aW9uIGMoZSxyLGEpe2Z1bmN0aW9uIGkoKXtyZXR1cm4gZS5sZW5ndGgmJnIubGVuZ3RoP2VbMF0ub2Zmc2V0IT09clswXS5vZmZzZXQ/ZVswXS5vZmZzZXQ8clswXS5vZmZzZXQ/ZTpyOiJzdGFydCI9PT1yWzBdLmV2ZW50P2U6cjplLmxlbmd0aD9lOnJ9ZnVuY3Rpb24gbyhlKXtmdW5jdGlvbiByKGUpe3JldHVybiIgIitlLm5vZGVOYW1lKyc9IicrbihlLnZhbHVlKS5yZXBsYWNlKCciJywiJnF1b3Q7IikrJyInfXMrPSI8Iit0KGUpK0UubWFwLmNhbGwoZS5hdHRyaWJ1dGVzLHIpLmpvaW4oIiIpKyI+In1mdW5jdGlvbiB1KGUpe3MrPSI8LyIrdChlKSsiPiJ9ZnVuY3Rpb24gYyhlKXsoInN0YXJ0Ij09PWUuZXZlbnQ/bzp1KShlLm5vZGUpfWZvcih2YXIgbD0wLHM9IiIsZj1bXTtlLmxlbmd0aHx8ci5sZW5ndGg7KXt2YXIgZz1pKCk7aWYocys9bihhLnN1YnN0cmluZyhsLGdbMF0ub2Zmc2V0KSksbD1nWzBdLm9mZnNldCxnPT09ZSl7Zi5yZXZlcnNlKCkuZm9yRWFjaCh1KTtkbyBjKGcuc3BsaWNlKDAsMSlbMF0pLGc9aSgpO3doaWxlKGc9PT1lJiZnLmxlbmd0aCYmZ1swXS5vZmZzZXQ9PT1sKTtmLnJldmVyc2UoKS5mb3JFYWNoKG8pfWVsc2Uic3RhcnQiPT09Z1swXS5ldmVudD9mLnB1c2goZ1swXS5ub2RlKTpmLnBvcCgpLGMoZy5zcGxpY2UoMCwxKVswXSl9cmV0dXJuIHMrbihhLnN1YnN0cihsKSl9ZnVuY3Rpb24gbChlKXtyZXR1cm4gZS52JiYhZS5jYWNoZWRfdmFyaWFudHMmJihlLmNhY2hlZF92YXJpYW50cz1lLnYubWFwKGZ1bmN0aW9uKG4pe3JldHVybiBvKGUse3Y6bnVsbH0sbil9KSksZS5jYWNoZWRfdmFyaWFudHN8fGUuZVcmJltvKGUpXXx8W2VdfWZ1bmN0aW9uIHMoZSl7ZnVuY3Rpb24gbihlKXtyZXR1cm4gZSYmZS5zb3VyY2V8fGV9ZnVuY3Rpb24gdCh0LHIpe3JldHVybiBuZXcgUmVnRXhwKG4odCksIm0iKyhlLmNJPyJpIjoiIikrKHI/ImciOiIiKSl9ZnVuY3Rpb24gcihhLGkpe2lmKCFhLmNvbXBpbGVkKXtpZihhLmNvbXBpbGVkPSEwLGEuaz1hLmt8fGEuYkssYS5rKXt2YXIgbz17fSx1PWZ1bmN0aW9uKG4sdCl7ZS5jSSYmKHQ9dC50b0xvd2VyQ2FzZSgpKSx0LnNwbGl0KCIgIikuZm9yRWFjaChmdW5jdGlvbihlKXt2YXIgdD1lLnNwbGl0KCJ8Iik7b1t0WzBdXT1bbix0WzFdP051bWJlcih0WzFdKToxXX0pfTsic3RyaW5nIj09dHlwZW9mIGEuaz91KCJrZXl3b3JkIixhLmspOngoYS5rKS5mb3JFYWNoKGZ1bmN0aW9uKGUpe3UoZSxhLmtbZV0pfSksYS5rPW99YS5sUj10KGEubHx8L1x3Ky8sITApLGkmJihhLmJLJiYoYS5iPSJcXGIoIithLmJLLnNwbGl0KCIgIikuam9pbigifCIpKyIpXFxiIiksYS5ifHwoYS5iPS9cQnxcYi8pLGEuYlI9dChhLmIpLGEuZXx8YS5lV3x8KGEuZT0vXEJ8XGIvKSxhLmUmJihhLmVSPXQoYS5lKSksYS50RT1uKGEuZSl8fCIiLGEuZVcmJmkudEUmJihhLnRFKz0oYS5lPyJ8IjoiIikraS50RSkpLGEuaSYmKGEuaVI9dChhLmkpKSxudWxsPT1hLnImJihhLnI9MSksYS5jfHwoYS5jPVtdKSxhLmM9QXJyYXkucHJvdG90eXBlLmNvbmNhdC5hcHBseShbXSxhLmMubWFwKGZ1bmN0aW9uKGUpe3JldHVybiBsKCJzZWxmIj09PWU/YTplKX0pKSxhLmMuZm9yRWFjaChmdW5jdGlvbihlKXtyKGUsYSl9KSxhLnN0YXJ0cyYmcihhLnN0YXJ0cyxpKTt2YXIgYz1hLmMubWFwKGZ1bmN0aW9uKGUpe3JldHVybiBlLmJLPyJcXC4/KCIrZS5iKyIpXFwuPyI6ZS5ifSkuY29uY2F0KFthLnRFLGEuaV0pLm1hcChuKS5maWx0ZXIoQm9vbGVhbik7YS50PWMubGVuZ3RoP3QoYy5qb2luKCJ8IiksITApOntleGVjOmZ1bmN0aW9uKCl7cmV0dXJuIG51bGx9fX19cihlKX1mdW5jdGlvbiBmKGUsdCxhLGkpe2Z1bmN0aW9uIG8oZSxuKXt2YXIgdCxhO2Zvcih0PTAsYT1uLmMubGVuZ3RoO2E+dDt0KyspaWYocihuLmNbdF0uYlIsZSkpcmV0dXJuIG4uY1t0XX1mdW5jdGlvbiB1KGUsbil7aWYocihlLmVSLG4pKXtmb3IoO2UuZW5kc1BhcmVudCYmZS5wYXJlbnQ7KWU9ZS5wYXJlbnQ7cmV0dXJuIGV9cmV0dXJuIGUuZVc/dShlLnBhcmVudCxuKTp2b2lkIDB9ZnVuY3Rpb24gYyhlLG4pe3JldHVybiFhJiZyKG4uaVIsZSl9ZnVuY3Rpb24gbChlLG4pe3ZhciB0PU4uY0k/blswXS50b0xvd2VyQ2FzZSgpOm5bMF07cmV0dXJuIGUuay5oYXNPd25Qcm9wZXJ0eSh0KSYmZS5rW3RdfWZ1bmN0aW9uIHAoZSxuLHQscil7dmFyIGE9cj8iIjpJLmNsYXNzUHJlZml4LGk9JzxzcGFuIGNsYXNzPSInK2Esbz10PyIiOkM7cmV0dXJuIGkrPWUrJyI+JyxpK24rb31mdW5jdGlvbiBoKCl7dmFyIGUsdCxyLGE7aWYoIUUuaylyZXR1cm4gbihrKTtmb3IoYT0iIix0PTAsRS5sUi5sYXN0SW5kZXg9MCxyPUUubFIuZXhlYyhrKTtyOylhKz1uKGsuc3Vic3RyaW5nKHQsci5pbmRleCkpLGU9bChFLHIpLGU/KEIrPWVbMV0sYSs9cChlWzBdLG4oclswXSkpKTphKz1uKHJbMF0pLHQ9RS5sUi5sYXN0SW5kZXgscj1FLmxSLmV4ZWMoayk7cmV0dXJuIGErbihrLnN1YnN0cih0KSl9ZnVuY3Rpb24gZCgpe3ZhciBlPSJzdHJpbmciPT10eXBlb2YgRS5zTDtpZihlJiYheVtFLnNMXSlyZXR1cm4gbihrKTt2YXIgdD1lP2YoRS5zTCxrLCEwLHhbRS5zTF0pOmcoayxFLnNMLmxlbmd0aD9FLnNMOnZvaWQgMCk7cmV0dXJuIEUucj4wJiYoQis9dC5yKSxlJiYoeFtFLnNMXT10LnRvcCkscCh0Lmxhbmd1YWdlLHQudmFsdWUsITEsITApfWZ1bmN0aW9uIGIoKXtMKz1udWxsIT1FLnNMP2QoKTpoKCksaz0iIn1mdW5jdGlvbiB2KGUpe0wrPWUuY04/cChlLmNOLCIiLCEwKToiIixFPU9iamVjdC5jcmVhdGUoZSx7cGFyZW50Ont2YWx1ZTpFfX0pfWZ1bmN0aW9uIG0oZSxuKXtpZihrKz1lLG51bGw9PW4pcmV0dXJuIGIoKSwwO3ZhciB0PW8obixFKTtpZih0KXJldHVybiB0LnNraXA/ays9bjoodC5lQiYmKGsrPW4pLGIoKSx0LnJCfHx0LmVCfHwoaz1uKSksdih0LG4pLHQuckI/MDpuLmxlbmd0aDt2YXIgcj11KEUsbik7aWYocil7dmFyIGE9RTthLnNraXA/ays9bjooYS5yRXx8YS5lRXx8KGsrPW4pLGIoKSxhLmVFJiYoaz1uKSk7ZG8gRS5jTiYmKEwrPUMpLEUuc2tpcHx8KEIrPUUuciksRT1FLnBhcmVudDt3aGlsZShFIT09ci5wYXJlbnQpO3JldHVybiByLnN0YXJ0cyYmdihyLnN0YXJ0cywiIiksYS5yRT8wOm4ubGVuZ3RofWlmKGMobixFKSl0aHJvdyBuZXcgRXJyb3IoJ0lsbGVnYWwgbGV4ZW1lICInK24rJyIgZm9yIG1vZGUgIicrKEUuY058fCI8dW5uYW1lZD4iKSsnIicpO3JldHVybiBrKz1uLG4ubGVuZ3RofHwxfXZhciBOPXcoZSk7aWYoIU4pdGhyb3cgbmV3IEVycm9yKCdVbmtub3duIGxhbmd1YWdlOiAiJytlKyciJyk7cyhOKTt2YXIgUixFPWl8fE4seD17fSxMPSIiO2ZvcihSPUU7UiE9PU47Uj1SLnBhcmVudClSLmNOJiYoTD1wKFIuY04sIiIsITApK0wpO3ZhciBrPSIiLEI9MDt0cnl7Zm9yKHZhciBNLGosTz0wOzspe2lmKEUudC5sYXN0SW5kZXg9TyxNPUUudC5leGVjKHQpLCFNKWJyZWFrO2o9bSh0LnN1YnN0cmluZyhPLE0uaW5kZXgpLE1bMF0pLE89TS5pbmRleCtqfWZvcihtKHQuc3Vic3RyKE8pKSxSPUU7Ui5wYXJlbnQ7Uj1SLnBhcmVudClSLmNOJiYoTCs9Qyk7cmV0dXJue3I6Qix2YWx1ZTpMLGxhbmd1YWdlOmUsdG9wOkV9fWNhdGNoKFQpe2lmKFQubWVzc2FnZSYmLTEhPT1ULm1lc3NhZ2UuaW5kZXhPZigiSWxsZWdhbCIpKXJldHVybntyOjAsdmFsdWU6bih0KX07dGhyb3cgVH19ZnVuY3Rpb24gZyhlLHQpe3Q9dHx8SS5sYW5ndWFnZXN8fHgoeSk7dmFyIHI9e3I6MCx2YWx1ZTpuKGUpfSxhPXI7cmV0dXJuIHQuZmlsdGVyKHcpLmZvckVhY2goZnVuY3Rpb24obil7dmFyIHQ9ZihuLGUsITEpO3QubGFuZ3VhZ2U9bix0LnI+YS5yJiYoYT10KSx0LnI+ci5yJiYoYT1yLHI9dCl9KSxhLmxhbmd1YWdlJiYoci5zZWNvbmRfYmVzdD1hKSxyfWZ1bmN0aW9uIHAoZSl7cmV0dXJuIEkudGFiUmVwbGFjZXx8SS51c2VCUj9lLnJlcGxhY2UoTSxmdW5jdGlvbihlLG4pe3JldHVybiBJLnVzZUJSJiYiXG4iPT09ZT8iPGJyPiI6SS50YWJSZXBsYWNlP24ucmVwbGFjZSgvXHQvZyxJLnRhYlJlcGxhY2UpOiIifSk6ZX1mdW5jdGlvbiBoKGUsbix0KXt2YXIgcj1uP0xbbl06dCxhPVtlLnRyaW0oKV07cmV0dXJuIGUubWF0Y2goL1xiaGxqc1xiLyl8fGEucHVzaCgiaGxqcyIpLC0xPT09ZS5pbmRleE9mKHIpJiZhLnB1c2gociksYS5qb2luKCIgIikudHJpbSgpfWZ1bmN0aW9uIGQoZSl7dmFyIG4sdCxyLG8sbCxzPWkoZSk7YShzKXx8KEkudXNlQlI/KG49ZG9jdW1lbnQuY3JlYXRlRWxlbWVudE5TKCJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hodG1sIiwiZGl2Iiksbi5pbm5lckhUTUw9ZS5pbm5lckhUTUwucmVwbGFjZSgvXG4vZywiIikucmVwbGFjZSgvPGJyWyBcL10qPi9nLCJcbiIpKTpuPWUsbD1uLnRleHRDb250ZW50LHI9cz9mKHMsbCwhMCk6ZyhsKSx0PXUobiksdC5sZW5ndGgmJihvPWRvY3VtZW50LmNyZWF0ZUVsZW1lbnROUygiaHR0cDovL3d3dy53My5vcmcvMTk5OS94aHRtbCIsImRpdiIpLG8uaW5uZXJIVE1MPXIudmFsdWUsci52YWx1ZT1jKHQsdShvKSxsKSksci52YWx1ZT1wKHIudmFsdWUpLGUuaW5uZXJIVE1MPXIudmFsdWUsZS5jbGFzc05hbWU9aChlLmNsYXNzTmFtZSxzLHIubGFuZ3VhZ2UpLGUucmVzdWx0PXtsYW5ndWFnZTpyLmxhbmd1YWdlLHJlOnIucn0sci5zZWNvbmRfYmVzdCYmKGUuc2Vjb25kX2Jlc3Q9e2xhbmd1YWdlOnIuc2Vjb25kX2Jlc3QubGFuZ3VhZ2UscmU6ci5zZWNvbmRfYmVzdC5yfSkpfWZ1bmN0aW9uIGIoZSl7ST1vKEksZSl9ZnVuY3Rpb24gdigpe2lmKCF2LmNhbGxlZCl7di5jYWxsZWQ9ITA7dmFyIGU9ZG9jdW1lbnQucXVlcnlTZWxlY3RvckFsbCgicHJlIGNvZGUiKTtFLmZvckVhY2guY2FsbChlLGQpfX1mdW5jdGlvbiBtKCl7YWRkRXZlbnRMaXN0ZW5lcigiRE9NQ29udGVudExvYWRlZCIsdiwhMSksYWRkRXZlbnRMaXN0ZW5lcigibG9hZCIsdiwhMSl9ZnVuY3Rpb24gTihuLHQpe3ZhciByPXlbbl09dChlKTtyLmFsaWFzZXMmJnIuYWxpYXNlcy5mb3JFYWNoKGZ1bmN0aW9uKGUpe0xbZV09bn0pfWZ1bmN0aW9uIFIoKXtyZXR1cm4geCh5KX1mdW5jdGlvbiB3KGUpe3JldHVybiBlPShlfHwiIikudG9Mb3dlckNhc2UoKSx5W2VdfHx5W0xbZV1dfXZhciBFPVtdLHg9T2JqZWN0LmtleXMseT17fSxMPXt9LGs9L14obm8tP2hpZ2hsaWdodHxwbGFpbnx0ZXh0KSQvaSxCPS9cYmxhbmcoPzp1YWdlKT8tKFtcdy1dKylcYi9pLE09LygoXig8W14+XSs+fFx0fCkrfCg/OlxuKSkpL2dtLEM9Ijwvc3Bhbj4iLEk9e2NsYXNzUHJlZml4OiJobGpzLSIsdGFiUmVwbGFjZTpudWxsLHVzZUJSOiExLGxhbmd1YWdlczp2b2lkIDB9O3JldHVybiBlLmhpZ2hsaWdodD1mLGUuaGlnaGxpZ2h0QXV0bz1nLGUuZml4TWFya3VwPXAsZS5oaWdobGlnaHRCbG9jaz1kLGUuY29uZmlndXJlPWIsZS5pbml0SGlnaGxpZ2h0aW5nPXYsZS5pbml0SGlnaGxpZ2h0aW5nT25Mb2FkPW0sZS5yZWdpc3Rlckxhbmd1YWdlPU4sZS5saXN0TGFuZ3VhZ2VzPVIsZS5nZXRMYW5ndWFnZT13LGUuaW5oZXJpdD1vLGUuSVI9IlthLXpBLVpdXFx3KiIsZS5VSVI9IlthLXpBLVpfXVxcdyoiLGUuTlI9IlxcYlxcZCsoXFwuXFxkKyk/IixlLkNOUj0iKC0/KShcXGIwW3hYXVthLWZBLUYwLTldK3woXFxiXFxkKyhcXC5cXGQqKT98XFwuXFxkKykoW2VFXVstK10/XFxkKyk/KSIsZS5CTlI9IlxcYigwYlswMV0rKSIsZS5SU1I9IiF8IT18IT09fCV8JT18JnwmJnwmPXxcXCp8XFwqPXxcXCt8XFwrPXwsfC18LT18Lz18L3w6fDt8PDx8PDw9fDw9fDx8PT09fD09fD18Pj4+PXw+Pj18Pj18Pj4+fD4+fD58XFw/fFxcW3xcXHt8XFwofFxcXnxcXF49fFxcfHxcXHw9fFxcfFxcfHx+IixlLkJFPXtiOiJcXFxcW1xcc1xcU10iLHI6MH0sZS5BU009e2NOOiJzdHJpbmciLGI6IiciLGU6IiciLGk6IlxcbiIsYzpbZS5CRV19LGUuUVNNPXtjTjoic3RyaW5nIixiOiciJyxlOiciJyxpOiJcXG4iLGM6W2UuQkVdfSxlLlBXTT17YjovXGIoYXxhbnx0aGV8YXJlfEknbXxpc24ndHxkb24ndHxkb2Vzbid0fHdvbid0fGJ1dHxqdXN0fHNob3VsZHxwcmV0dHl8c2ltcGx5fGVub3VnaHxnb25uYXxnb2luZ3x3dGZ8c298c3VjaHx3aWxsfHlvdXx5b3VyfHRoZXl8bGlrZXxtb3JlKVxiL30sZS5DPWZ1bmN0aW9uKG4sdCxyKXt2YXIgYT1lLmluaGVyaXQoe2NOOiJjb21tZW50IixiOm4sZTp0LGM6W119LHJ8fHt9KTtyZXR1cm4gYS5jLnB1c2goZS5QV00pLGEuYy5wdXNoKHtjTjoiZG9jdGFnIixiOiIoPzpUT0RPfEZJWE1FfE5PVEV8QlVHfFhYWCk6IixyOjB9KSxhfSxlLkNMQ009ZS5DKCIvLyIsIiQiKSxlLkNCQ009ZS5DKCIvXFwqIiwiXFwqLyIpLGUuSENNPWUuQygiIyIsIiQiKSxlLk5NPXtjTjoibnVtYmVyIixiOmUuTlIscjowfSxlLkNOTT17Y046Im51bWJlciIsYjplLkNOUixyOjB9LGUuQk5NPXtjTjoibnVtYmVyIixiOmUuQk5SLHI6MH0sZS5DU1NOTT17Y046Im51bWJlciIsYjplLk5SKyIoJXxlbXxleHxjaHxyZW18dnd8dmh8dm1pbnx2bWF4fGNtfG1tfGlufHB0fHBjfHB4fGRlZ3xncmFkfHJhZHx0dXJufHN8bXN8SHp8a0h6fGRwaXxkcGNtfGRwcHgpPyIscjowfSxlLlJNPXtjTjoicmVnZXhwIixiOi9cLy8sZTovXC9bZ2ltdXldKi8saTovXG4vLGM6W2UuQkUse2I6L1xbLyxlOi9cXS8scjowLGM6W2UuQkVdfV19LGUuVE09e2NOOiJ0aXRsZSIsYjplLklSLHI6MH0sZS5VVE09e2NOOiJ0aXRsZSIsYjplLlVJUixyOjB9LGUuTUVUSE9EX0dVQVJEPXtiOiJcXC5cXHMqIitlLlVJUixyOjB9LGV9KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInNxbCIsZnVuY3Rpb24oZSl7dmFyIHQ9ZS5DKCItLSIsIiQiKTtyZXR1cm57Y0k6ITAsaTovWzw+e30qI10vLGM6W3tiSzoiYmVnaW4gZW5kIHN0YXJ0IGNvbW1pdCByb2xsYmFjayBzYXZlcG9pbnQgbG9jayBhbHRlciBjcmVhdGUgZHJvcCByZW5hbWUgY2FsbCBkZWxldGUgZG8gaGFuZGxlciBpbnNlcnQgbG9hZCByZXBsYWNlIHNlbGVjdCB0cnVuY2F0ZSB1cGRhdGUgc2V0IHNob3cgcHJhZ21hIGdyYW50IG1lcmdlIGRlc2NyaWJlIHVzZSBleHBsYWluIGhlbHAgZGVjbGFyZSBwcmVwYXJlIGV4ZWN1dGUgZGVhbGxvY2F0ZSByZWxlYXNlIHVubG9jayBwdXJnZSByZXNldCBjaGFuZ2Ugc3RvcCBhbmFseXplIGNhY2hlIGZsdXNoIG9wdGltaXplIHJlcGFpciBraWxsIGluc3RhbGwgdW5pbnN0YWxsIGNoZWNrc3VtIHJlc3RvcmUgY2hlY2sgYmFja3VwIHJldm9rZSBjb21tZW50IixlOi87LyxlVzohMCxsOi9bXHdcLl0rLyxrOntrZXl3b3JkOiJhYm9ydCBhYnMgYWJzb2x1dGUgYWNjIGFjY2UgYWNjZXAgYWNjZXB0IGFjY2VzcyBhY2Nlc3NlZCBhY2Nlc3NpYmxlIGFjY291bnQgYWNvcyBhY3Rpb24gYWN0aXZhdGUgYWRkIGFkZHRpbWUgYWRtaW4gYWRtaW5pc3RlciBhZHZhbmNlZCBhZHZpc2UgYWVzX2RlY3J5cHQgYWVzX2VuY3J5cHQgYWZ0ZXIgYWdlbnQgYWdncmVnYXRlIGFsaSBhbGlhIGFsaWFzIGFsbG9jYXRlIGFsbG93IGFsdGVyIGFsd2F5cyBhbmFseXplIGFuY2lsbGFyeSBhbmQgYW55IGFueWRhdGEgYW55ZGF0YXNldCBhbnlzY2hlbWEgYW55dHlwZSBhcHBseSBhcmNoaXZlIGFyY2hpdmVkIGFyY2hpdmVsb2cgYXJlIGFzIGFzYyBhc2NpaSBhc2luIGFzc2VtYmx5IGFzc2VydGlvbiBhc3NvY2lhdGUgYXN5bmNocm9ub3VzIGF0IGF0YW4gYXRuMiBhdHRyIGF0dHJpIGF0dHJpYiBhdHRyaWJ1IGF0dHJpYnV0IGF0dHJpYnV0ZSBhdHRyaWJ1dGVzIGF1ZGl0IGF1dGhlbnRpY2F0ZWQgYXV0aGVudGljYXRpb24gYXV0aGlkIGF1dGhvcnMgYXV0byBhdXRvYWxsb2NhdGUgYXV0b2RibGluayBhdXRvZXh0ZW5kIGF1dG9tYXRpYyBhdmFpbGFiaWxpdHkgYXZnIGJhY2t1cCBiYWRmaWxlIGJhc2ljZmlsZSBiZWZvcmUgYmVnaW4gYmVnaW5uaW5nIGJlbmNobWFyayBiZXR3ZWVuIGJmaWxlIGJmaWxlX2Jhc2UgYmlnIGJpZ2ZpbGUgYmluIGJpbmFyeV9kb3VibGUgYmluYXJ5X2Zsb2F0IGJpbmxvZyBiaXRfYW5kIGJpdF9jb3VudCBiaXRfbGVuZ3RoIGJpdF9vciBiaXRfeG9yIGJpdG1hcCBibG9iX2Jhc2UgYmxvY2sgYmxvY2tzaXplIGJvZHkgYm90aCBib3VuZCBidWZmZXJfY2FjaGUgYnVmZmVyX3Bvb2wgYnVpbGQgYnVsayBieSBieXRlIGJ5dGVvcmRlcm1hcmsgYnl0ZXMgY2FjaGUgY2FjaGluZyBjYWxsIGNhbGxpbmcgY2FuY2VsIGNhcGFjaXR5IGNhc2NhZGUgY2FzY2FkZWQgY2FzZSBjYXN0IGNhdGFsb2cgY2F0ZWdvcnkgY2VpbCBjZWlsaW5nIGNoYWluIGNoYW5nZSBjaGFuZ2VkIGNoYXJfYmFzZSBjaGFyX2xlbmd0aCBjaGFyYWN0ZXJfbGVuZ3RoIGNoYXJhY3RlcnMgY2hhcmFjdGVyc2V0IGNoYXJpbmRleCBjaGFyc2V0IGNoYXJzZXRmb3JtIGNoYXJzZXRpZCBjaGVjayBjaGVja3N1bSBjaGVja3N1bV9hZ2cgY2hpbGQgY2hvb3NlIGNociBjaHVuayBjbGFzcyBjbGVhbnVwIGNsZWFyIGNsaWVudCBjbG9iIGNsb2JfYmFzZSBjbG9uZSBjbG9zZSBjbHVzdGVyX2lkIGNsdXN0ZXJfcHJvYmFiaWxpdHkgY2x1c3Rlcl9zZXQgY2x1c3RlcmluZyBjb2FsZXNjZSBjb2VyY2liaWxpdHkgY29sIGNvbGxhdGUgY29sbGF0aW9uIGNvbGxlY3QgY29sdSBjb2x1bSBjb2x1bW4gY29sdW1uX3ZhbHVlIGNvbHVtbnMgY29sdW1uc191cGRhdGVkIGNvbW1lbnQgY29tbWl0IGNvbXBhY3QgY29tcGF0aWJpbGl0eSBjb21waWxlZCBjb21wbGV0ZSBjb21wb3NpdGVfbGltaXQgY29tcG91bmQgY29tcHJlc3MgY29tcHV0ZSBjb25jYXQgY29uY2F0X3dzIGNvbmN1cnJlbnQgY29uZmlybSBjb25uIGNvbm5lYyBjb25uZWN0IGNvbm5lY3RfYnlfaXNjeWNsZSBjb25uZWN0X2J5X2lzbGVhZiBjb25uZWN0X2J5X3Jvb3QgY29ubmVjdF90aW1lIGNvbm5lY3Rpb24gY29uc2lkZXIgY29uc2lzdGVudCBjb25zdGFudCBjb25zdHJhaW50IGNvbnN0cmFpbnRzIGNvbnN0cnVjdG9yIGNvbnRhaW5lciBjb250ZW50IGNvbnRlbnRzIGNvbnRleHQgY29udHJpYnV0b3JzIGNvbnRyb2xmaWxlIGNvbnYgY29udmVydCBjb252ZXJ0X3R6IGNvcnIgY29ycl9rIGNvcnJfcyBjb3JyZXNwb25kaW5nIGNvcnJ1cHRpb24gY29zIGNvc3QgY291bnQgY291bnRfYmlnIGNvdW50ZWQgY292YXJfcG9wIGNvdmFyX3NhbXAgY3B1X3Blcl9jYWxsIGNwdV9wZXJfc2Vzc2lvbiBjcmMzMiBjcmVhdGUgY3JlYXRpb24gY3JpdGljYWwgY3Jvc3MgY3ViZSBjdW1lX2Rpc3QgY3VyZGF0ZSBjdXJyZW50IGN1cnJlbnRfZGF0ZSBjdXJyZW50X3RpbWUgY3VycmVudF90aW1lc3RhbXAgY3VycmVudF91c2VyIGN1cnNvciBjdXJ0aW1lIGN1c3RvbWRhdHVtIGN5Y2xlIGRhdGEgZGF0YWJhc2UgZGF0YWJhc2VzIGRhdGFmaWxlIGRhdGFmaWxlcyBkYXRhbGVuZ3RoIGRhdGVfYWRkIGRhdGVfY2FjaGUgZGF0ZV9mb3JtYXQgZGF0ZV9zdWIgZGF0ZWFkZCBkYXRlZGlmZiBkYXRlZnJvbXBhcnRzIGRhdGVuYW1lIGRhdGVwYXJ0IGRhdGV0aW1lMmZyb21wYXJ0cyBkYXkgZGF5X3RvX3NlY29uZCBkYXluYW1lIGRheW9mbW9udGggZGF5b2Z3ZWVrIGRheW9meWVhciBkYXlzIGRiX3JvbGVfY2hhbmdlIGRidGltZXpvbmUgZGRsIGRlYWxsb2NhdGUgZGVjbGFyZSBkZWNvZGUgZGVjb21wb3NlIGRlY3JlbWVudCBkZWNyeXB0IGRlZHVwbGljYXRlIGRlZiBkZWZhIGRlZmF1IGRlZmF1bCBkZWZhdWx0IGRlZmF1bHRzIGRlZmVycmVkIGRlZmkgZGVmaW4gZGVmaW5lIGRlZ3JlZXMgZGVsYXllZCBkZWxlZ2F0ZSBkZWxldGUgZGVsZXRlX2FsbCBkZWxpbWl0ZWQgZGVtYW5kIGRlbnNlX3JhbmsgZGVwdGggZGVxdWV1ZSBkZXNfZGVjcnlwdCBkZXNfZW5jcnlwdCBkZXNfa2V5X2ZpbGUgZGVzYyBkZXNjciBkZXNjcmkgZGVzY3JpYiBkZXNjcmliZSBkZXNjcmlwdG9yIGRldGVybWluaXN0aWMgZGlhZ25vc3RpY3MgZGlmZmVyZW5jZSBkaW1lbnNpb24gZGlyZWN0X2xvYWQgZGlyZWN0b3J5IGRpc2FibGUgZGlzYWJsZV9hbGwgZGlzYWxsb3cgZGlzYXNzb2NpYXRlIGRpc2NhcmRmaWxlIGRpc2Nvbm5lY3QgZGlza2dyb3VwIGRpc3RpbmN0IGRpc3RpbmN0cm93IGRpc3RyaWJ1dGUgZGlzdHJpYnV0ZWQgZGl2IGRvIGRvY3VtZW50IGRvbWFpbiBkb3RuZXQgZG91YmxlIGRvd25ncmFkZSBkcm9wIGR1bXBmaWxlIGR1cGxpY2F0ZSBkdXJhdGlvbiBlYWNoIGVkaXRpb24gZWRpdGlvbmFibGUgZWRpdGlvbnMgZWxlbWVudCBlbGxpcHNpcyBlbHNlIGVsc2lmIGVsdCBlbXB0eSBlbmFibGUgZW5hYmxlX2FsbCBlbmNsb3NlZCBlbmNvZGUgZW5jb2RpbmcgZW5jcnlwdCBlbmQgZW5kLWV4ZWMgZW5kaWFuIGVuZm9yY2VkIGVuZ2luZSBlbmdpbmVzIGVucXVldWUgZW50ZXJwcmlzZSBlbnRpdHllc2NhcGluZyBlb21vbnRoIGVycm9yIGVycm9ycyBlc2NhcGVkIGV2YWxuYW1lIGV2YWx1YXRlIGV2ZW50IGV2ZW50ZGF0YSBldmVudHMgZXhjZXB0IGV4Y2VwdGlvbiBleGNlcHRpb25zIGV4Y2hhbmdlIGV4Y2x1ZGUgZXhjbHVkaW5nIGV4ZWN1IGV4ZWN1dCBleGVjdXRlIGV4ZW1wdCBleGlzdHMgZXhpdCBleHAgZXhwaXJlIGV4cGxhaW4gZXhwb3J0IGV4cG9ydF9zZXQgZXh0ZW5kZWQgZXh0ZW50IGV4dGVybmFsIGV4dGVybmFsXzEgZXh0ZXJuYWxfMiBleHRlcm5hbGx5IGV4dHJhY3QgZmFpbGVkIGZhaWxlZF9sb2dpbl9hdHRlbXB0cyBmYWlsb3ZlciBmYWlsdXJlIGZhciBmYXN0IGZlYXR1cmVfc2V0IGZlYXR1cmVfdmFsdWUgZmV0Y2ggZmllbGQgZmllbGRzIGZpbGUgZmlsZV9uYW1lX2NvbnZlcnQgZmlsZXN5c3RlbV9saWtlX2xvZ2dpbmcgZmluYWwgZmluaXNoIGZpcnN0IGZpcnN0X3ZhbHVlIGZpeGVkIGZsYXNoX2NhY2hlIGZsYXNoYmFjayBmbG9vciBmbHVzaCBmb2xsb3dpbmcgZm9sbG93cyBmb3IgZm9yYWxsIGZvcmNlIGZvcm0gZm9ybWEgZm9ybWF0IGZvdW5kIGZvdW5kX3Jvd3MgZnJlZWxpc3QgZnJlZWxpc3RzIGZyZWVwb29scyBmcmVzaCBmcm9tIGZyb21fYmFzZTY0IGZyb21fZGF5cyBmdHAgZnVsbCBmdW5jdGlvbiBnZW5lcmFsIGdlbmVyYXRlZCBnZXQgZ2V0X2Zvcm1hdCBnZXRfbG9jayBnZXRkYXRlIGdldHV0Y2RhdGUgZ2xvYmFsIGdsb2JhbF9uYW1lIGdsb2JhbGx5IGdvIGdvdG8gZ3JhbnQgZ3JhbnRzIGdyZWF0ZXN0IGdyb3VwIGdyb3VwX2NvbmNhdCBncm91cF9pZCBncm91cGluZyBncm91cGluZ19pZCBncm91cHMgZ3RpZF9zdWJ0cmFjdCBndWFyYW50ZWUgZ3VhcmQgaGFuZGxlciBoYXNoIGhhc2hrZXlzIGhhdmluZyBoZWEgaGVhZCBoZWFkaSBoZWFkaW4gaGVhZGluZyBoZWFwIGhlbHAgaGV4IGhpZXJhcmNoeSBoaWdoIGhpZ2hfcHJpb3JpdHkgaG9zdHMgaG91ciBodHRwIGlkIGlkZW50X2N1cnJlbnQgaWRlbnRfaW5jciBpZGVudF9zZWVkIGlkZW50aWZpZWQgaWRlbnRpdHkgaWRsZV90aW1lIGlmIGlmbnVsbCBpZ25vcmUgaWlmIGlsaWtlIGlsbSBpbW1lZGlhdGUgaW1wb3J0IGluIGluY2x1ZGUgaW5jbHVkaW5nIGluY3JlbWVudCBpbmRleCBpbmRleGVzIGluZGV4aW5nIGluZGV4dHlwZSBpbmRpY2F0b3IgaW5kaWNlcyBpbmV0Nl9hdG9uIGluZXQ2X250b2EgaW5ldF9hdG9uIGluZXRfbnRvYSBpbmZpbGUgaW5pdGlhbCBpbml0aWFsaXplZCBpbml0aWFsbHkgaW5pdHJhbnMgaW5tZW1vcnkgaW5uZXIgaW5ub2RiIGlucHV0IGluc2VydCBpbnN0YWxsIGluc3RhbmNlIGluc3RhbnRpYWJsZSBpbnN0ciBpbnRlcmZhY2UgaW50ZXJsZWF2ZWQgaW50ZXJzZWN0IGludG8gaW52YWxpZGF0ZSBpbnZpc2libGUgaXMgaXNfZnJlZV9sb2NrIGlzX2lwdjQgaXNfaXB2NF9jb21wYXQgaXNfbm90IGlzX25vdF9udWxsIGlzX3VzZWRfbG9jayBpc2RhdGUgaXNudWxsIGlzb2xhdGlvbiBpdGVyYXRlIGphdmEgam9pbiBqc29uIGpzb25fZXhpc3RzIGtlZXAga2VlcF9kdXBsaWNhdGVzIGtleSBrZXlzIGtpbGwgbGFuZ3VhZ2UgbGFyZ2UgbGFzdCBsYXN0X2RheSBsYXN0X2luc2VydF9pZCBsYXN0X3ZhbHVlIGxheCBsY2FzZSBsZWFkIGxlYWRpbmcgbGVhc3QgbGVhdmVzIGxlZnQgbGVuIGxlbmdodCBsZW5ndGggbGVzcyBsZXZlbCBsZXZlbHMgbGlicmFyeSBsaWtlIGxpa2UyIGxpa2U0IGxpa2VjIGxpbWl0IGxpbmVzIGxpbmsgbGlzdCBsaXN0YWdnIGxpdHRsZSBsbiBsb2FkIGxvYWRfZmlsZSBsb2IgbG9icyBsb2NhbCBsb2NhbHRpbWUgbG9jYWx0aW1lc3RhbXAgbG9jYXRlIGxvY2F0b3IgbG9jayBsb2NrZWQgbG9nIGxvZzEwIGxvZzIgbG9nZmlsZSBsb2dmaWxlcyBsb2dnaW5nIGxvZ2ljYWwgbG9naWNhbF9yZWFkc19wZXJfY2FsbCBsb2dvZmYgbG9nb24gbG9ncyBsb25nIGxvb3AgbG93IGxvd19wcmlvcml0eSBsb3dlciBscGFkIGxydHJpbSBsdHJpbSBtYWluIG1ha2Vfc2V0IG1ha2VkYXRlIG1ha2V0aW1lIG1hbmFnZWQgbWFuYWdlbWVudCBtYW51YWwgbWFwIG1hcHBpbmcgbWFzayBtYXN0ZXIgbWFzdGVyX3Bvc193YWl0IG1hdGNoIG1hdGNoZWQgbWF0ZXJpYWxpemVkIG1heCBtYXhleHRlbnRzIG1heGltaXplIG1heGluc3RhbmNlcyBtYXhsZW4gbWF4bG9nZmlsZXMgbWF4bG9naGlzdG9yeSBtYXhsb2dtZW1iZXJzIG1heHNpemUgbWF4dHJhbnMgbWQ1IG1lYXN1cmVzIG1lZGlhbiBtZWRpdW0gbWVtYmVyIG1lbWNvbXByZXNzIG1lbW9yeSBtZXJnZSBtaWNyb3NlY29uZCBtaWQgbWlncmF0aW9uIG1pbiBtaW5leHRlbnRzIG1pbmltdW0gbWluaW5nIG1pbnVzIG1pbnV0ZSBtaW52YWx1ZSBtaXNzaW5nIG1vZCBtb2RlIG1vZGVsIG1vZGlmaWNhdGlvbiBtb2RpZnkgbW9kdWxlIG1vbml0b3JpbmcgbW9udGggbW9udGhzIG1vdW50IG1vdmUgbW92ZW1lbnQgbXVsdGlzZXQgbXV0ZXggbmFtZSBuYW1lX2NvbnN0IG5hbWVzIG5hbiBuYXRpb25hbCBuYXRpdmUgbmF0dXJhbCBuYXYgbmNoYXIgbmNsb2IgbmVzdGVkIG5ldmVyIG5ldyBuZXdsaW5lIG5leHQgbmV4dHZhbCBubyBub193cml0ZV90b19iaW5sb2cgbm9hcmNoaXZlbG9nIG5vYXVkaXQgbm9iYWRmaWxlIG5vY2hlY2sgbm9jb21wcmVzcyBub2NvcHkgbm9jeWNsZSBub2RlbGF5IG5vZGlzY2FyZGZpbGUgbm9lbnRpdHllc2NhcGluZyBub2d1YXJhbnRlZSBub2tlZXAgbm9sb2dmaWxlIG5vbWFwcGluZyBub21heHZhbHVlIG5vbWluaW1pemUgbm9taW52YWx1ZSBub21vbml0b3Jpbmcgbm9uZSBub25lZGl0aW9uYWJsZSBub25zY2hlbWEgbm9vcmRlciBub3ByIG5vcHJvIG5vcHJvbSBub3Byb21wIG5vcHJvbXB0IG5vcmVseSBub3Jlc2V0bG9ncyBub3JldmVyc2Ugbm9ybWFsIG5vcm93ZGVwZW5kZW5jaWVzIG5vc2NoZW1hY2hlY2sgbm9zd2l0Y2ggbm90IG5vdGhpbmcgbm90aWNlIG5vdHJpbSBub3ZhbGlkYXRlIG5vdyBub3dhaXQgbnRoX3ZhbHVlIG51bGxpZiBudWxscyBudW0gbnVtYiBudW1iZSBudmFyY2hhciBudmFyY2hhcjIgb2JqZWN0IG9jaWNvbGwgb2NpZGF0ZSBvY2lkYXRldGltZSBvY2lkdXJhdGlvbiBvY2lpbnRlcnZhbCBvY2lsb2Jsb2NhdG9yIG9jaW51bWJlciBvY2lyZWYgb2NpcmVmY3Vyc29yIG9jaXJvd2lkIG9jaXN0cmluZyBvY2l0eXBlIG9jdCBvY3RldF9sZW5ndGggb2Ygb2ZmIG9mZmxpbmUgb2Zmc2V0IG9pZCBvaWRpbmRleCBvbGQgb24gb25saW5lIG9ubHkgb3BhcXVlIG9wZW4gb3BlcmF0aW9ucyBvcGVyYXRvciBvcHRpbWFsIG9wdGltaXplIG9wdGlvbiBvcHRpb25hbGx5IG9yIG9yYWNsZSBvcmFjbGVfZGF0ZSBvcmFkYXRhIG9yZCBvcmRhdWRpbyBvcmRkaWNvbSBvcmRkb2Mgb3JkZXIgb3JkaW1hZ2Ugb3JkaW5hbGl0eSBvcmR2aWRlbyBvcmdhbml6YXRpb24gb3JsYW55IG9ybHZhcnkgb3V0IG91dGVyIG91dGZpbGUgb3V0bGluZSBvdXRwdXQgb3ZlciBvdmVyZmxvdyBvdmVycmlkaW5nIHBhY2thZ2UgcGFkIHBhcmFsbGVsIHBhcmFsbGVsX2VuYWJsZSBwYXJhbWV0ZXJzIHBhcmVudCBwYXJzZSBwYXJ0aWFsIHBhcnRpdGlvbiBwYXJ0aXRpb25zIHBhc2NhbCBwYXNzaW5nIHBhc3N3b3JkIHBhc3N3b3JkX2dyYWNlX3RpbWUgcGFzc3dvcmRfbG9ja190aW1lIHBhc3N3b3JkX3JldXNlX21heCBwYXNzd29yZF9yZXVzZV90aW1lIHBhc3N3b3JkX3ZlcmlmeV9mdW5jdGlvbiBwYXRjaCBwYXRoIHBhdGluZGV4IHBjdGluY3JlYXNlIHBjdHRocmVzaG9sZCBwY3R1c2VkIHBjdHZlcnNpb24gcGVyY2VudCBwZXJjZW50X3JhbmsgcGVyY2VudGlsZV9jb250IHBlcmNlbnRpbGVfZGlzYyBwZXJmb3JtYW5jZSBwZXJpb2QgcGVyaW9kX2FkZCBwZXJpb2RfZGlmZiBwZXJtYW5lbnQgcGh5c2ljYWwgcGkgcGlwZSBwaXBlbGluZWQgcGl2b3QgcGx1Z2dhYmxlIHBsdWdpbiBwb2xpY3kgcG9zaXRpb24gcG9zdF90cmFuc2FjdGlvbiBwb3cgcG93ZXIgcHJhZ21hIHByZWJ1aWx0IHByZWNlZGVzIHByZWNlZGluZyBwcmVjaXNpb24gcHJlZGljdGlvbiBwcmVkaWN0aW9uX2Nvc3QgcHJlZGljdGlvbl9kZXRhaWxzIHByZWRpY3Rpb25fcHJvYmFiaWxpdHkgcHJlZGljdGlvbl9zZXQgcHJlcGFyZSBwcmVzZW50IHByZXNlcnZlIHByaW9yIHByaW9yaXR5IHByaXZhdGUgcHJpdmF0ZV9zZ2EgcHJpdmlsZWdlcyBwcm9jZWR1cmFsIHByb2NlZHVyZSBwcm9jZWR1cmVfYW5hbHl6ZSBwcm9jZXNzbGlzdCBwcm9maWxlcyBwcm9qZWN0IHByb21wdCBwcm90ZWN0aW9uIHB1YmxpYyBwdWJsaXNoaW5nc2VydmVybmFtZSBwdXJnZSBxdWFydGVyIHF1ZXJ5IHF1aWNrIHF1aWVzY2UgcXVvdGEgcXVvdGVuYW1lIHJhZGlhbnMgcmFpc2UgcmFuZCByYW5nZSByYW5rIHJhdyByZWFkIHJlYWRzIHJlYWRzaXplIHJlYnVpbGQgcmVjb3JkIHJlY29yZHMgcmVjb3ZlciByZWNvdmVyeSByZWN1cnNpdmUgcmVjeWNsZSByZWRvIHJlZHVjZWQgcmVmIHJlZmVyZW5jZSByZWZlcmVuY2VkIHJlZmVyZW5jZXMgcmVmZXJlbmNpbmcgcmVmcmVzaCByZWdleHBfbGlrZSByZWdpc3RlciByZWdyX2F2Z3ggcmVncl9hdmd5IHJlZ3JfY291bnQgcmVncl9pbnRlcmNlcHQgcmVncl9yMiByZWdyX3Nsb3BlIHJlZ3Jfc3h4IHJlZ3Jfc3h5IHJlamVjdCByZWtleSByZWxhdGlvbmFsIHJlbGF0aXZlIHJlbGF5bG9nIHJlbGVhc2UgcmVsZWFzZV9sb2NrIHJlbGllc19vbiByZWxvY2F0ZSByZWx5IHJlbSByZW1haW5kZXIgcmVuYW1lIHJlcGFpciByZXBlYXQgcmVwbGFjZSByZXBsaWNhdGUgcmVwbGljYXRpb24gcmVxdWlyZWQgcmVzZXQgcmVzZXRsb2dzIHJlc2l6ZSByZXNvdXJjZSByZXNwZWN0IHJlc3RvcmUgcmVzdHJpY3RlZCByZXN1bHQgcmVzdWx0X2NhY2hlIHJlc3VtYWJsZSByZXN1bWUgcmV0ZW50aW9uIHJldHVybiByZXR1cm5pbmcgcmV0dXJucyByZXVzZSByZXZlcnNlIHJldm9rZSByaWdodCBybGlrZSByb2xlIHJvbGVzIHJvbGxiYWNrIHJvbGxpbmcgcm9sbHVwIHJvdW5kIHJvdyByb3dfY291bnQgcm93ZGVwZW5kZW5jaWVzIHJvd2lkIHJvd251bSByb3dzIHJ0cmltIHJ1bGVzIHNhZmUgc2FsdCBzYW1wbGUgc2F2ZSBzYXZlcG9pbnQgc2IxIHNiMiBzYjQgc2NhbiBzY2hlbWEgc2NoZW1hY2hlY2sgc2NuIHNjb3BlIHNjcm9sbCBzZG9fZ2VvcmFzdGVyIHNkb190b3BvX2dlb21ldHJ5IHNlYXJjaCBzZWNfdG9fdGltZSBzZWNvbmQgc2VjdGlvbiBzZWN1cmVmaWxlIHNlY3VyaXR5IHNlZWQgc2VnbWVudCBzZWxlY3Qgc2VsZiBzZXF1ZW5jZSBzZXF1ZW50aWFsIHNlcmlhbGl6YWJsZSBzZXJ2ZXIgc2VydmVyZXJyb3Igc2Vzc2lvbiBzZXNzaW9uX3VzZXIgc2Vzc2lvbnNfcGVyX3VzZXIgc2V0IHNldHMgc2V0dGluZ3Mgc2hhIHNoYTEgc2hhMiBzaGFyZSBzaGFyZWQgc2hhcmVkX3Bvb2wgc2hvcnQgc2hvdyBzaHJpbmsgc2h1dGRvd24gc2lfYXZlcmFnZWNvbG9yIHNpX2NvbG9yaGlzdG9ncmFtIHNpX2ZlYXR1cmVsaXN0IHNpX3Bvc2l0aW9uYWxjb2xvciBzaV9zdGlsbGltYWdlIHNpX3RleHR1cmUgc2libGluZ3Mgc2lkIHNpZ24gc2luIHNpemUgc2l6ZV90IHNpemVzIHNraXAgc2xhdmUgc2xlZXAgc21hbGxkYXRldGltZWZyb21wYXJ0cyBzbWFsbGZpbGUgc25hcHNob3Qgc29tZSBzb25hbWUgc29ydCBzb3VuZGV4IHNvdXJjZSBzcGFjZSBzcGFyc2Ugc3BmaWxlIHNwbGl0IHNxbCBzcWxfYmlnX3Jlc3VsdCBzcWxfYnVmZmVyX3Jlc3VsdCBzcWxfY2FjaGUgc3FsX2NhbGNfZm91bmRfcm93cyBzcWxfc21hbGxfcmVzdWx0IHNxbF92YXJpYW50X3Byb3BlcnR5IHNxbGNvZGUgc3FsZGF0YSBzcWxlcnJvciBzcWxuYW1lIHNxbHN0YXRlIHNxcnQgc3F1YXJlIHN0YW5kYWxvbmUgc3RhbmRieSBzdGFydCBzdGFydGluZyBzdGFydHVwIHN0YXRlbWVudCBzdGF0aWMgc3RhdGlzdGljcyBzdGF0c19iaW5vbWlhbF90ZXN0IHN0YXRzX2Nyb3NzdGFiIHN0YXRzX2tzX3Rlc3Qgc3RhdHNfbW9kZSBzdGF0c19td190ZXN0IHN0YXRzX29uZV93YXlfYW5vdmEgc3RhdHNfdF90ZXN0XyBzdGF0c190X3Rlc3RfaW5kZXAgc3RhdHNfdF90ZXN0X29uZSBzdGF0c190X3Rlc3RfcGFpcmVkIHN0YXRzX3dzcl90ZXN0IHN0YXR1cyBzdGQgc3RkZGV2IHN0ZGRldl9wb3Agc3RkZGV2X3NhbXAgc3RkZXYgc3RvcCBzdG9yYWdlIHN0b3JlIHN0b3JlZCBzdHIgc3RyX3RvX2RhdGUgc3RyYWlnaHRfam9pbiBzdHJjbXAgc3RyaWN0IHN0cmluZyBzdHJ1Y3Qgc3R1ZmYgc3R5bGUgc3ViZGF0ZSBzdWJwYXJ0aXRpb24gc3VicGFydGl0aW9ucyBzdWJzdGl0dXRhYmxlIHN1YnN0ciBzdWJzdHJpbmcgc3VidGltZSBzdWJ0cmluZ19pbmRleCBzdWJ0eXBlIHN1Y2Nlc3Mgc3VtIHN1c3BlbmQgc3dpdGNoIHN3aXRjaG9mZnNldCBzd2l0Y2hvdmVyIHN5bmMgc3luY2hyb25vdXMgc3lub255bSBzeXMgc3lzX3htbGFnZyBzeXNhc20gc3lzYXV4IHN5c2RhdGUgc3lzZGF0ZXRpbWVvZmZzZXQgc3lzZGJhIHN5c29wZXIgc3lzdGVtIHN5c3RlbV91c2VyIHN5c3V0Y2RhdGV0aW1lIHRhYmxlIHRhYmxlcyB0YWJsZXNwYWNlIHRhbiB0ZG8gdGVtcGxhdGUgdGVtcG9yYXJ5IHRlcm1pbmF0ZWQgdGVydGlhcnlfd2VpZ2h0cyB0ZXN0IHRoYW4gdGhlbiB0aHJlYWQgdGhyb3VnaCB0aWVyIHRpZXMgdGltZSB0aW1lX2Zvcm1hdCB0aW1lX3pvbmUgdGltZWRpZmYgdGltZWZyb21wYXJ0cyB0aW1lb3V0IHRpbWVzdGFtcCB0aW1lc3RhbXBhZGQgdGltZXN0YW1wZGlmZiB0aW1lem9uZV9hYmJyIHRpbWV6b25lX21pbnV0ZSB0aW1lem9uZV9yZWdpb24gdG8gdG9fYmFzZTY0IHRvX2RhdGUgdG9fZGF5cyB0b19zZWNvbmRzIHRvZGF0ZXRpbWVvZmZzZXQgdHJhY2UgdHJhY2tpbmcgdHJhbnNhY3Rpb24gdHJhbnNhY3Rpb25hbCB0cmFuc2xhdGUgdHJhbnNsYXRpb24gdHJlYXQgdHJpZ2dlciB0cmlnZ2VyX25lc3RsZXZlbCB0cmlnZ2VycyB0cmltIHRydW5jYXRlIHRyeV9jYXN0IHRyeV9jb252ZXJ0IHRyeV9wYXJzZSB0eXBlIHViMSB1YjIgdWI0IHVjYXNlIHVuYXJjaGl2ZWQgdW5ib3VuZGVkIHVuY29tcHJlc3MgdW5kZXIgdW5kbyB1bmhleCB1bmljb2RlIHVuaWZvcm0gdW5pbnN0YWxsIHVuaW9uIHVuaXF1ZSB1bml4X3RpbWVzdGFtcCB1bmtub3duIHVubGltaXRlZCB1bmxvY2sgdW5waXZvdCB1bnJlY292ZXJhYmxlIHVuc2FmZSB1bnNpZ25lZCB1bnRpbCB1bnRydXN0ZWQgdW51c2FibGUgdW51c2VkIHVwZGF0ZSB1cGRhdGVkIHVwZ3JhZGUgdXBwZWQgdXBwZXIgdXBzZXJ0IHVybCB1cm93aWQgdXNhYmxlIHVzYWdlIHVzZSB1c2Vfc3RvcmVkX291dGxpbmVzIHVzZXIgdXNlcl9kYXRhIHVzZXJfcmVzb3VyY2VzIHVzZXJzIHVzaW5nIHV0Y19kYXRlIHV0Y190aW1lc3RhbXAgdXVpZCB1dWlkX3Nob3J0IHZhbGlkYXRlIHZhbGlkYXRlX3Bhc3N3b3JkX3N0cmVuZ3RoIHZhbGlkYXRpb24gdmFsaXN0IHZhbHVlIHZhbHVlcyB2YXIgdmFyX3NhbXAgdmFyY2hhcmMgdmFyaSB2YXJpYSB2YXJpYWIgdmFyaWFibCB2YXJpYWJsZSB2YXJpYWJsZXMgdmFyaWFuY2UgdmFycCB2YXJyYXcgdmFycmF3YyB2YXJyYXkgdmVyaWZ5IHZlcnNpb24gdmVyc2lvbnMgdmlldyB2aXJ0dWFsIHZpc2libGUgdm9pZCB3YWl0IHdhbGxldCB3YXJuaW5nIHdhcm5pbmdzIHdlZWsgd2Vla2RheSB3ZWVrb2Z5ZWFyIHdlbGxmb3JtZWQgd2hlbiB3aGVuZSB3aGVuZXYgd2hlbmV2ZSB3aGVuZXZlciB3aGVyZSB3aGlsZSB3aGl0ZXNwYWNlIHdpdGggd2l0aGluIHdpdGhvdXQgd29yayB3cmFwcGVkIHhkYiB4bWwgeG1sYWdnIHhtbGF0dHJpYnV0ZXMgeG1sY2FzdCB4bWxjb2xhdHR2YWwgeG1sZWxlbWVudCB4bWxleGlzdHMgeG1sZm9yZXN0IHhtbGluZGV4IHhtbG5hbWVzcGFjZXMgeG1scGkgeG1scXVlcnkgeG1scm9vdCB4bWxzY2hlbWEgeG1sc2VyaWFsaXplIHhtbHRhYmxlIHhtbHR5cGUgeG9yIHllYXIgeWVhcl90b19tb250aCB5ZWFycyB5ZWFyd2VlayIsbGl0ZXJhbDoidHJ1ZSBmYWxzZSBudWxsIixidWlsdF9pbjoiYXJyYXkgYmlnaW50IGJpbmFyeSBiaXQgYmxvYiBib29sZWFuIGNoYXIgY2hhcmFjdGVyIGRhdGUgZGVjIGRlY2ltYWwgZmxvYXQgaW50IGludDggaW50ZWdlciBpbnRlcnZhbCBudW1iZXIgbnVtZXJpYyByZWFsIHJlY29yZCBzZXJpYWwgc2VyaWFsOCBzbWFsbGludCB0ZXh0IHZhcmNoYXIgdmFyeWluZyB2b2lkIn0sYzpbe2NOOiJzdHJpbmciLGI6IiciLGU6IiciLGM6W2UuQkUse2I6IicnIn1dfSx7Y046InN0cmluZyIsYjonIicsZTonIicsYzpbZS5CRSx7YjonIiInfV19LHtjTjoic3RyaW5nIixiOiJgIixlOiJgIixjOltlLkJFXX0sZS5DTk0sZS5DQkNNLHRdfSxlLkNCQ00sdF19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJyIixmdW5jdGlvbihlKXt2YXIgcj0iKFthLXpBLVpdfFxcLlthLXpBLVouXSlbYS16QS1aMC05Ll9dKiI7cmV0dXJue2M6W2UuSENNLHtiOnIsbDpyLGs6e2tleXdvcmQ6ImZ1bmN0aW9uIGlmIGluIGJyZWFrIG5leHQgcmVwZWF0IGVsc2UgZm9yIHJldHVybiBzd2l0Y2ggd2hpbGUgdHJ5IHRyeUNhdGNoIHN0b3Agd2FybmluZyByZXF1aXJlIGxpYnJhcnkgYXR0YWNoIGRldGFjaCBzb3VyY2Ugc2V0TWV0aG9kIHNldEdlbmVyaWMgc2V0R3JvdXBHZW5lcmljIHNldENsYXNzIC4uLiIsbGl0ZXJhbDoiTlVMTCBOQSBUUlVFIEZBTFNFIFQgRiBJbmYgTmFOIE5BX2ludGVnZXJffDEwIE5BX3JlYWxffDEwIE5BX2NoYXJhY3Rlcl98MTAgTkFfY29tcGxleF98MTAifSxyOjB9LHtjTjoibnVtYmVyIixiOiIwW3hYXVswLTlhLWZBLUZdK1tMaV0/XFxiIixyOjB9LHtjTjoibnVtYmVyIixiOiJcXGQrKD86W2VFXVsrXFwtXT9cXGQqKT9MXFxiIixyOjB9LHtjTjoibnVtYmVyIixiOiJcXGQrXFwuKD8hXFxkKSg/OmlcXGIpPyIscjowfSx7Y046Im51bWJlciIsYjoiXFxkKyg/OlxcLlxcZCopPyg/OltlRV1bK1xcLV0/XFxkKik/aT9cXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IlxcLlxcZCsoPzpbZUVdWytcXC1dP1xcZCopP2k/XFxiIixyOjB9LHtiOiJgIixlOiJgIixyOjB9LHtjTjoic3RyaW5nIixjOltlLkJFXSx2Olt7YjonIicsZTonIid9LHtiOiInIixlOiInIn1dfV19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJwZXJsIixmdW5jdGlvbihlKXt2YXIgdD0iZ2V0cHdlbnQgZ2V0c2VydmVudCBxdW90ZW1ldGEgbXNncmN2IHNjYWxhciBraWxsIGRibWNsb3NlIHVuZGVmIGxjIG1hIHN5c3dyaXRlIHRyIHNlbmQgdW1hc2sgc3lzb3BlbiBzaG13cml0ZSB2ZWMgcXggdXRpbWUgbG9jYWwgb2N0IHNlbWN0bCBsb2NhbHRpbWUgcmVhZHBpcGUgZG8gcmV0dXJuIGZvcm1hdCByZWFkIHNwcmludGYgZGJtb3BlbiBwb3AgZ2V0cGdycCBub3QgZ2V0cHduYW0gcmV3aW5kZGlyIHFxZmlsZW5vIHF3IGVuZHByb3RvZW50IHdhaXQgc2V0aG9zdGVudCBibGVzcyBzfDAgb3BlbmRpciBjb250aW51ZSBlYWNoIHNsZWVwIGVuZGdyZW50IHNodXRkb3duIGR1bXAgY2hvbXAgY29ubmVjdCBnZXRzb2NrbmFtZSBkaWUgc29ja2V0cGFpciBjbG9zZSBmbG9jayBleGlzdHMgaW5kZXggc2htZ2V0c3ViIGZvciBlbmRwd2VudCByZWRvIGxzdGF0IG1zZ2N0bCBzZXRwZ3JwIGFicyBleGl0IHNlbGVjdCBwcmludCByZWYgZ2V0aG9zdGJ5YWRkciB1bnNoaWZ0IGZjbnRsIHN5c2NhbGwgZ290byBnZXRuZXRieWFkZHIgam9pbiBnbXRpbWUgc3ltbGluayBzZW1nZXQgc3BsaWNlIHh8MCBnZXRwZWVybmFtZSByZWN2IGxvZyBzZXRzb2Nrb3B0IGNvcyBsYXN0IHJldmVyc2UgZ2V0aG9zdGJ5bmFtZSBnZXRncm5hbSBzdHVkeSBmb3JtbGluZSBlbmRob3N0ZW50IHRpbWVzIGNob3AgbGVuZ3RoIGdldGhvc3RlbnQgZ2V0bmV0ZW50IHBhY2sgZ2V0cHJvdG9lbnQgZ2V0c2VydmJ5bmFtZSByYW5kIG1rZGlyIHBvcyBjaG1vZCB5fDAgc3Vic3RyIGVuZG5ldGVudCBwcmludGYgbmV4dCBvcGVuIG1zZ3NuZCByZWFkZGlyIHVzZSB1bmxpbmsgZ2V0c29ja29wdCBnZXRwcmlvcml0eSByaW5kZXggd2FudGFycmF5IGhleCBzeXN0ZW0gZ2V0c2VydmJ5cG9ydCBlbmRzZXJ2ZW50IGludCBjaHIgdW50aWUgcm1kaXIgcHJvdG90eXBlIHRlbGwgbGlzdGVuIGZvcmsgc2htcmVhZCB1Y2ZpcnN0IHNldHByb3RvZW50IGVsc2Ugc3lzc2VlayBsaW5rIGdldGdyZ2lkIHNobWN0bCB3YWl0cGlkIHVucGFjayBnZXRuZXRieW5hbWUgcmVzZXQgY2hkaXIgZ3JlcCBzcGxpdCByZXF1aXJlIGNhbGxlciBsY2ZpcnN0IHVudGlsIHdhcm4gd2hpbGUgdmFsdWVzIHNoaWZ0IHRlbGxkaXIgZ2V0cHd1aWQgbXkgZ2V0cHJvdG9ieW51bWJlciBkZWxldGUgYW5kIHNvcnQgdWMgZGVmaW5lZCBzcmFuZCBhY2NlcHQgcGFja2FnZSBzZWVrZGlyIGdldHByb3RvYnluYW1lIHNlbW9wIG91ciByZW5hbWUgc2VlayBpZiBxfDAgY2hyb290IHN5c3JlYWQgc2V0cHdlbnQgbm8gY3J5cHQgZ2V0YyBjaG93biBzcXJ0IHdyaXRlIHNldG5ldGVudCBzZXRwcmlvcml0eSBmb3JlYWNoIHRpZSBzaW4gbXNnZ2V0IG1hcCBzdGF0IGdldGxvZ2luIHVubGVzcyBlbHNpZiB0cnVuY2F0ZSBleGVjIGtleXMgZ2xvYiB0aWVkIGNsb3NlZGlyaW9jdGwgc29ja2V0IHJlYWRsaW5rIGV2YWwgeG9yIHJlYWRsaW5lIGJpbm1vZGUgc2V0c2VydmVudCBlb2Ygb3JkIGJpbmQgYWxhcm0gcGlwZSBhdGFuMiBnZXRncmVudCBleHAgdGltZSBwdXNoIHNldGdyZW50IGd0IGx0IG9yIG5lIG18MCBicmVhayBnaXZlbiBzYXkgc3RhdGUgd2hlbiIscj17Y046InN1YnN0IixiOiJbJEBdXFx7IixlOiJcXH0iLGs6dH0scz17YjoiLT57IixlOiJ9In0sbj17djpbe2I6L1wkXGQvfSx7YjovW1wkJUBdKFxeXHdcYnwjXHcrKDo6XHcrKSp8e1x3K318XHcrKDo6XHcqKSopL30se2I6L1tcJCVAXVteXHNcd3tdLyxyOjB9XX0saT1bZS5CRSxyLG5dLG89W24sZS5IQ00sZS5DKCJeXFw9XFx3IiwiXFw9Y3V0Iix7ZVc6ITB9KSxzLHtjTjoic3RyaW5nIixjOmksdjpbe2I6InFbcXd4cl0/XFxzKlxcKCIsZToiXFwpIixyOjV9LHtiOiJxW3F3eHJdP1xccypcXFsiLGU6IlxcXSIscjo1fSx7YjoicVtxd3hyXT9cXHMqXFx7IixlOiJcXH0iLHI6NX0se2I6InFbcXd4cl0/XFxzKlxcfCIsZToiXFx8IixyOjV9LHtiOiJxW3F3eHJdP1xccypcXDwiLGU6IlxcPiIscjo1fSx7YjoicXdcXHMrcSIsZToicSIscjo1fSx7YjoiJyIsZToiJyIsYzpbZS5CRV19LHtiOiciJyxlOiciJ30se2I6ImAiLGU6ImAiLGM6W2UuQkVdfSx7Yjoie1xcdyt9IixjOltdLHI6MH0se2I6Ii0/XFx3K1xccypcXD1cXD4iLGM6W10scjowfV19LHtjTjoibnVtYmVyIixiOiIoXFxiMFswLTdfXSspfChcXGIweFswLTlhLWZBLUZfXSspfChcXGJbMS05XVswLTlfXSooXFwuWzAtOV9dKyk/KXxbMF9dXFxiIixyOjB9LHtiOiIoXFwvXFwvfCIrZS5SU1IrInxcXGIoc3BsaXR8cmV0dXJufHByaW50fHJldmVyc2V8Z3JlcClcXGIpXFxzKiIsazoic3BsaXQgcmV0dXJuIHByaW50IHJldmVyc2UgZ3JlcCIscjowLGM6W2UuSENNLHtjTjoicmVnZXhwIixiOiIoc3x0cnx5KS8oXFxcXC58W14vXSkqLyhcXFxcLnxbXi9dKSovW2Etel0qIixyOjEwfSx7Y046InJlZ2V4cCIsYjoiKG18cXIpPy8iLGU6Ii9bYS16XSoiLGM6W2UuQkVdLHI6MH1dfSx7Y046ImZ1bmN0aW9uIixiSzoic3ViIixlOiIoXFxzKlxcKC4qP1xcKSk/Wzt7XSIsZUU6ITAscjo1LGM6W2UuVE1dfSx7YjoiLVxcd1xcYiIscjowfSx7YjoiXl9fREFUQV9fJCIsZToiXl9fRU5EX18kIixzTDoibW9qb2xpY2lvdXMiLGM6W3tiOiJeQEAuKiIsZToiJCIsY046ImNvbW1lbnQifV19XTtyZXR1cm4gci5jPW8scy5jPW8se2FsaWFzZXM6WyJwbCIsInBtIl0sbDovW1x3XC5dKy8sazp0LGM6b319KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoImluaSIsZnVuY3Rpb24oZSl7dmFyIGI9e2NOOiJzdHJpbmciLGM6W2UuQkVdLHY6W3tiOiInJyciLGU6IicnJyIscjoxMH0se2I6JyIiIicsZTonIiIiJyxyOjEwfSx7YjonIicsZTonIid9LHtiOiInIixlOiInIn1dfTtyZXR1cm57YWxpYXNlczpbInRvbWwiXSxjSTohMCxpOi9cUy8sYzpbZS5DKCI7IiwiJCIpLGUuSENNLHtjTjoic2VjdGlvbiIsYjovXlxzKlxbKy8sZTovXF0rL30se2I6L15bYS16MC05XFtcXV8tXStccyo9XHMqLyxlOiIkIixyQjohMCxjOlt7Y046ImF0dHIiLGI6L1thLXowLTlcW1xdXy1dKy99LHtiOi89LyxlVzohMCxyOjAsYzpbe2NOOiJsaXRlcmFsIixiOi9cYm9ufG9mZnx0cnVlfGZhbHNlfHllc3xub1xiL30se2NOOiJ2YXJpYWJsZSIsdjpbe2I6L1wkW1x3XGQiXVtcd1xkX10qL30se2I6L1wkXHsoLio/KX0vfV19LGIse2NOOiJudW1iZXIiLGI6LyhbXCtcLV0rKT9bXGRdK19bXGRfXSsvfSxlLk5NXX1dfV19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJkaWZmIixmdW5jdGlvbihlKXtyZXR1cm57YWxpYXNlczpbInBhdGNoIl0sYzpbe2NOOiJtZXRhIixyOjEwLHY6W3tiOi9eQEAgK1wtXGQrLFxkKyArXCtcZCssXGQrICtAQCQvfSx7YjovXlwqXCpcKiArXGQrLFxkKyArXCpcKlwqXCokL30se2I6L15cLVwtXC0gK1xkKyxcZCsgK1wtXC1cLVwtJC99XX0se2NOOiJjb21tZW50Iix2Olt7YjovSW5kZXg6IC8sZTovJC99LHtiOi89ezMsfS8sZTovJC99LHtiOi9eXC17M30vLGU6LyQvfSx7YjovXlwqezN9IC8sZTovJC99LHtiOi9eXCt7M30vLGU6LyQvfSx7YjovXCp7NX0vLGU6L1wqezV9JC99XX0se2NOOiJhZGRpdGlvbiIsYjoiXlxcKyIsZToiJCJ9LHtjTjoiZGVsZXRpb24iLGI6Il5cXC0iLGU6IiQifSx7Y046ImFkZGl0aW9uIixiOiJeXFwhIixlOiIkIn1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiZ28iLGZ1bmN0aW9uKGUpe3ZhciB0PXtrZXl3b3JkOiJicmVhayBkZWZhdWx0IGZ1bmMgaW50ZXJmYWNlIHNlbGVjdCBjYXNlIG1hcCBzdHJ1Y3QgY2hhbiBlbHNlIGdvdG8gcGFja2FnZSBzd2l0Y2ggY29uc3QgZmFsbHRocm91Z2ggaWYgcmFuZ2UgdHlwZSBjb250aW51ZSBmb3IgaW1wb3J0IHJldHVybiB2YXIgZ28gZGVmZXIgYm9vbCBieXRlIGNvbXBsZXg2NCBjb21wbGV4MTI4IGZsb2F0MzIgZmxvYXQ2NCBpbnQ4IGludDE2IGludDMyIGludDY0IHN0cmluZyB1aW50OCB1aW50MTYgdWludDMyIHVpbnQ2NCBpbnQgdWludCB1aW50cHRyIHJ1bmUiLGxpdGVyYWw6InRydWUgZmFsc2UgaW90YSBuaWwiLGJ1aWx0X2luOiJhcHBlbmQgY2FwIGNsb3NlIGNvbXBsZXggY29weSBpbWFnIGxlbiBtYWtlIG5ldyBwYW5pYyBwcmludCBwcmludGxuIHJlYWwgcmVjb3ZlciBkZWxldGUifTtyZXR1cm57YWxpYXNlczpbImdvbGFuZyJdLGs6dCxpOiI8LyIsYzpbZS5DTENNLGUuQ0JDTSx7Y046InN0cmluZyIsdjpbZS5RU00se2I6IiciLGU6IlteXFxcXF0nIn0se2I6ImAiLGU6ImAifV19LHtjTjoibnVtYmVyIix2Olt7YjplLkNOUisiW2RmbHNpXSIscjoxfSxlLkNOTV19LHtiOi86PS99LHtjTjoiZnVuY3Rpb24iLGJLOiJmdW5jIixlOi9ccypcey8sZUU6ITAsYzpbZS5UTSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxrOnQsaTovWyInXS99XX1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiYmFzaCIsZnVuY3Rpb24oZSl7dmFyIHQ9e2NOOiJ2YXJpYWJsZSIsdjpbe2I6L1wkW1x3XGQjQF1bXHdcZF9dKi99LHtiOi9cJFx7KC4qPyl9L31dfSxzPXtjTjoic3RyaW5nIixiOi8iLyxlOi8iLyxjOltlLkJFLHQse2NOOiJ2YXJpYWJsZSIsYjovXCRcKC8sZTovXCkvLGM6W2UuQkVdfV19LGE9e2NOOiJzdHJpbmciLGI6LycvLGU6LycvfTtyZXR1cm57YWxpYXNlczpbInNoIiwienNoIl0sbDovXGItP1thLXpcLl9dK1xiLyxrOntrZXl3b3JkOiJpZiB0aGVuIGVsc2UgZWxpZiBmaSBmb3Igd2hpbGUgaW4gZG8gZG9uZSBjYXNlIGVzYWMgZnVuY3Rpb24iLGxpdGVyYWw6InRydWUgZmFsc2UiLGJ1aWx0X2luOiJicmVhayBjZCBjb250aW51ZSBldmFsIGV4ZWMgZXhpdCBleHBvcnQgZ2V0b3B0cyBoYXNoIHB3ZCByZWFkb25seSByZXR1cm4gc2hpZnQgdGVzdCB0aW1lcyB0cmFwIHVtYXNrIHVuc2V0IGFsaWFzIGJpbmQgYnVpbHRpbiBjYWxsZXIgY29tbWFuZCBkZWNsYXJlIGVjaG8gZW5hYmxlIGhlbHAgbGV0IGxvY2FsIGxvZ291dCBtYXBmaWxlIHByaW50ZiByZWFkIHJlYWRhcnJheSBzb3VyY2UgdHlwZSB0eXBlc2V0IHVsaW1pdCB1bmFsaWFzIHNldCBzaG9wdCBhdXRvbG9hZCBiZyBiaW5ka2V5IGJ5ZSBjYXAgY2hkaXIgY2xvbmUgY29tcGFyZ3VtZW50cyBjb21wY2FsbCBjb21wY3RsIGNvbXBkZXNjcmliZSBjb21wZmlsZXMgY29tcGdyb3VwcyBjb21wcXVvdGUgY29tcHRhZ3MgY29tcHRyeSBjb21wdmFsdWVzIGRpcnMgZGlzYWJsZSBkaXNvd24gZWNob3RjIGVjaG90aSBlbXVsYXRlIGZjIGZnIGZsb2F0IGZ1bmN0aW9ucyBnZXRjYXAgZ2V0bG4gaGlzdG9yeSBpbnRlZ2VyIGpvYnMga2lsbCBsaW1pdCBsb2cgbm9nbG9iIHBvcGQgcHJpbnQgcHVzaGQgcHVzaGxuIHJlaGFzaCBzY2hlZCBzZXRjYXAgc2V0b3B0IHN0YXQgc3VzcGVuZCB0dHljdGwgdW5mdW5jdGlvbiB1bmhhc2ggdW5saW1pdCB1bnNldG9wdCB2YXJlZCB3YWl0IHdoZW5jZSB3aGVyZSB3aGljaCB6Y29tcGlsZSB6Zm9ybWF0IHpmdHAgemxlIHptb2Rsb2FkIHpwYXJzZW9wdHMgenByb2YgenB0eSB6cmVnZXhwYXJzZSB6c29ja2V0IHpzdHlsZSB6dGNwIixfOiItbmUgLWVxIC1sdCAtZ3QgLWYgLWQgLWUgLXMgLWwgLWEifSxjOlt7Y046Im1ldGEiLGI6L14jIVteXG5dK3NoXHMqJC8scjoxMH0se2NOOiJmdW5jdGlvbiIsYjovXHdbXHdcZF9dKlxzKlwoXHMqXClccypcey8sckI6ITAsYzpbZS5pbmhlcml0KGUuVE0se2I6L1x3W1x3XGRfXSovfSldLHI6MH0sZS5IQ00scyxhLHRdfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgicHl0aG9uIixmdW5jdGlvbihlKXt2YXIgcj17a2V5d29yZDoiYW5kIGVsaWYgaXMgZ2xvYmFsIGFzIGluIGlmIGZyb20gcmFpc2UgZm9yIGV4Y2VwdCBmaW5hbGx5IHByaW50IGltcG9ydCBwYXNzIHJldHVybiBleGVjIGVsc2UgYnJlYWsgbm90IHdpdGggY2xhc3MgYXNzZXJ0IHlpZWxkIHRyeSB3aGlsZSBjb250aW51ZSBkZWwgb3IgZGVmIGxhbWJkYSBhc3luYyBhd2FpdCBub25sb2NhbHwxMCBOb25lIFRydWUgRmFsc2UiLGJ1aWx0X2luOiJFbGxpcHNpcyBOb3RJbXBsZW1lbnRlZCJ9LGI9e2NOOiJtZXRhIixiOi9eKD4+PnxcLlwuXC4pIC99LGM9e2NOOiJzdWJzdCIsYjovXHsvLGU6L1x9LyxrOnIsaTovIy99LGE9e2NOOiJzdHJpbmciLGM6W2UuQkVdLHY6W3tiOi8odXxiKT9yPycnJy8sZTovJycnLyxjOltiXSxyOjEwfSx7YjovKHV8Yik/cj8iIiIvLGU6LyIiIi8sYzpbYl0scjoxMH0se2I6LyhmcnxyZnxmKScnJy8sZTovJycnLyxjOltiLGNdfSx7YjovKGZyfHJmfGYpIiIiLyxlOi8iIiIvLGM6W2IsY119LHtiOi8odXxyfHVyKScvLGU6LycvLHI6MTB9LHtiOi8odXxyfHVyKSIvLGU6LyIvLHI6MTB9LHtiOi8oYnxiciknLyxlOi8nL30se2I6LyhifGJyKSIvLGU6LyIvfSx7YjovKGZyfHJmfGYpJy8sZTovJy8sYzpbY119LHtiOi8oZnJ8cmZ8ZikiLyxlOi8iLyxjOltjXX0sZS5BU00sZS5RU01dfSxzPXtjTjoibnVtYmVyIixyOjAsdjpbe2I6ZS5CTlIrIltsTGpKXT8ifSx7YjoiXFxiKDBvWzAtN10rKVtsTGpKXT8ifSx7YjplLkNOUisiW2xMakpdPyJ9XX0saT17Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxjOlsic2VsZiIsYixzLGFdfTtyZXR1cm4gYy5jPVthLHMsYl0se2FsaWFzZXM6WyJweSIsImd5cCJdLGs6cixpOi8oPFwvfC0+fFw/KXw9Pi8sYzpbYixzLGEsZS5IQ00se3Y6W3tjTjoiZnVuY3Rpb24iLGJLOiJkZWYifSx7Y046ImNsYXNzIixiSzoiY2xhc3MifV0sZTovOi8saTovWyR7PTtcbixdLyxjOltlLlVUTSxpLHtiOi8tPi8sZVc6ITAsazoiTm9uZSJ9XX0se2NOOiJtZXRhIixiOi9eW1x0IF0qQC8sZTovJC99LHtiOi9cYihwcmludHxleGVjKVwoL31dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgianVsaWEiLGZ1bmN0aW9uKGUpe3ZhciByPXtrZXl3b3JkOiJpbiBpc2Egd2hlcmUgYmFyZW1vZHVsZSBiZWdpbiBicmVhayBjYXRjaCBjY2FsbCBjb25zdCBjb250aW51ZSBkbyBlbHNlIGVsc2VpZiBlbmQgZXhwb3J0IGZhbHNlIGZpbmFsbHkgZm9yIGZ1bmN0aW9uIGdsb2JhbCBpZiBpbXBvcnQgaW1wb3J0YWxsIGxldCBsb2NhbCBtYWNybyBtb2R1bGUgcXVvdGUgcmV0dXJuIHRydWUgdHJ5IHVzaW5nIHdoaWxlIHR5cGUgaW1tdXRhYmxlIGFic3RyYWN0IGJpdHN0eXBlIHR5cGVhbGlhcyAiLGxpdGVyYWw6InRydWUgZmFsc2UgQVJHUyBDX05VTEwgRGV2TnVsbCBFTkRJQU5fQk9NIEVOViBJIEluZiBJbmYxNiBJbmYzMiBJbmY2NCBJbnNlcnRpb25Tb3J0IEpVTElBX0hPTUUgTE9BRF9QQVRIIE1lcmdlU29ydCBOYU4gTmFOMTYgTmFOMzIgTmFONjQgUFJPR1JBTV9GSUxFIFF1aWNrU29ydCBSb3VuZERvd24gUm91bmRGcm9tWmVybyBSb3VuZE5lYXJlc3QgUm91bmROZWFyZXN0VGllc0F3YXkgUm91bmROZWFyZXN0VGllc1VwIFJvdW5kVG9aZXJvIFJvdW5kVXAgU1RERVJSIFNURElOIFNURE9VVCBWRVJTSU9OIGNhdGFsYW4gZXwwIGV1fDAgZXVsZXJnYW1tYSBnb2xkZW4gaW0gbm90aGluZyBwaSDOsyDPgCDPhiAiLGJ1aWx0X2luOiJBTlkgQWJzdHJhY3RBcnJheSBBYnN0cmFjdENoYW5uZWwgQWJzdHJhY3RGbG9hdCBBYnN0cmFjdE1hdHJpeCBBYnN0cmFjdFJORyBBYnN0cmFjdFNlcmlhbGl6ZXIgQWJzdHJhY3RTZXQgQWJzdHJhY3RTcGFyc2VBcnJheSBBYnN0cmFjdFNwYXJzZU1hdHJpeCBBYnN0cmFjdFNwYXJzZVZlY3RvciBBYnN0cmFjdFN0cmluZyBBYnN0cmFjdFVuaXRSYW5nZSBBYnN0cmFjdFZlY09yTWF0IEFic3RyYWN0VmVjdG9yIEFueSBBcmd1bWVudEVycm9yIEFycmF5IEFzc2VydGlvbkVycm9yIEFzc29jaWF0aXZlIEJhc2U2NERlY29kZVBpcGUgQmFzZTY0RW5jb2RlUGlwZSBCaWRpYWdvbmFsIEJpZ0Zsb2F0IEJpZ0ludCBCaXRBcnJheSBCaXRNYXRyaXggQml0VmVjdG9yIEJvb2wgQm91bmRzRXJyb3IgQnVmZmVyU3RyZWFtIENhY2hpbmdQb29sIENhcHR1cmVkRXhjZXB0aW9uIENhcnRlc2lhbkluZGV4IENhcnRlc2lhblJhbmdlIENjaGFyIENkb3VibGUgQ2Zsb2F0IENoYW5uZWwgQ2hhciBDaW50IENpbnRtYXhfdCBDbG9uZyBDbG9uZ2xvbmcgQ2x1c3Rlck1hbmFnZXIgQ21kIENvZGVJbmZvIENvbG9uIENvbXBsZXggQ29tcGxleDEyOCBDb21wbGV4MzIgQ29tcGxleDY0IENvbXBvc2l0ZUV4Y2VwdGlvbiBDb25kaXRpb24gQ29uakFycmF5IENvbmpNYXRyaXggQ29ualZlY3RvciBDcHRyZGlmZl90IENzaG9ydCBDc2l6ZV90IENzc2l6ZV90IENzdHJpbmcgQ3VjaGFyIEN1aW50IEN1aW50bWF4X3QgQ3Vsb25nIEN1bG9uZ2xvbmcgQ3VzaG9ydCBDd2NoYXJfdCBDd3N0cmluZyBEYXRhVHlwZSBEYXRlIERhdGVGb3JtYXQgRGF0ZVRpbWUgRGVuc2VBcnJheSBEZW5zZU1hdHJpeCBEZW5zZVZlY09yTWF0IERlbnNlVmVjdG9yIERpYWdvbmFsIERpY3QgRGltZW5zaW9uTWlzbWF0Y2ggRGltcyBEaXJlY3RJbmRleFN0cmluZyBEaXNwbGF5IERpdmlkZUVycm9yIERvbWFpbkVycm9yIEVPRkVycm9yIEVhY2hMaW5lIEVudW0gRW51bWVyYXRlIEVycm9yRXhjZXB0aW9uIEV4Y2VwdGlvbiBFeHBvbmVudGlhbEJhY2tPZmYgRXhwciBGYWN0b3JpemF0aW9uIEZpbGVNb25pdG9yIEZsb2F0MTYgRmxvYXQzMiBGbG9hdDY0IEZ1bmN0aW9uIEZ1dHVyZSBHbG9iYWxSZWYgR290b05vZGUgSFRNTCBIZXJtaXRpYW4gSU8gSU9CdWZmZXIgSU9Db250ZXh0IElPU3RyZWFtIElQQWRkciBJUHY0IElQdjYgSW5kZXhDYXJ0ZXNpYW4gSW5kZXhMaW5lYXIgSW5kZXhTdHlsZSBJbmV4YWN0RXJyb3IgSW5pdEVycm9yIEludCBJbnQxMjggSW50MTYgSW50MzIgSW50NjQgSW50OCBJbnRTZXQgSW50ZWdlciBJbnRlcnJ1cHRFeGNlcHRpb24gSW52YWxpZFN0YXRlRXhjZXB0aW9uIElycmF0aW9uYWwgS2V5RXJyb3IgTGFiZWxOb2RlIExpblNwYWNlIExpbmVOdW1iZXJOb2RlIExvYWRFcnJvciBMb3dlclRyaWFuZ3VsYXIgTUlNRSBNYXRyaXggTWVyc2VubmVUd2lzdGVyIE1ldGhvZCBNZXRob2RFcnJvciBNZXRob2RUYWJsZSBNb2R1bGUgTlR1cGxlIE5ld3Zhck5vZGUgTnVsbEV4Y2VwdGlvbiBOdWxsYWJsZSBOdW1iZXIgT2JqZWN0SWREaWN0IE9yZGluYWxSYW5nZSBPdXRPZk1lbW9yeUVycm9yIE92ZXJmbG93RXJyb3IgUGFpciBQYXJzZUVycm9yIFBhcnRpYWxRdWlja1NvcnQgUGVybXV0ZWREaW1zQXJyYXkgUGlwZSBQb2xsaW5nRmlsZVdhdGNoZXIgUHJvY2Vzc0V4aXRlZEV4Y2VwdGlvbiBQdHIgUXVvdGVOb2RlIFJhbmRvbURldmljZSBSYW5nZSBSYW5nZUluZGV4IFJhdGlvbmFsIFJhd0ZEIFJlYWRPbmx5TWVtb3J5RXJyb3IgUmVhbCBSZWVudHJhbnRMb2NrIFJlZiBSZWdleCBSZWdleE1hdGNoIFJlbW90ZUNoYW5uZWwgUmVtb3RlRXhjZXB0aW9uIFJldlN0cmluZyBSb3VuZGluZ01vZGUgUm93VmVjdG9yIFNTQVZhbHVlIFNlZ21lbnRhdGlvbkZhdWx0IFNlcmlhbGl6YXRpb25TdGF0ZSBTZXQgU2hhcmVkQXJyYXkgU2hhcmVkTWF0cml4IFNoYXJlZFZlY3RvciBTaWduZWQgU2ltcGxlVmVjdG9yIFNsb3QgU2xvdE51bWJlciBTcGFyc2VNYXRyaXhDU0MgU3BhcnNlVmVjdG9yIFN0YWNrRnJhbWUgU3RhY2tPdmVyZmxvd0Vycm9yIFN0YWNrVHJhY2UgU3RlcFJhbmdlIFN0ZXBSYW5nZUxlbiBTdHJpZGVkQXJyYXkgU3RyaWRlZE1hdHJpeCBTdHJpZGVkVmVjT3JNYXQgU3RyaWRlZFZlY3RvciBTdHJpbmcgU3ViQXJyYXkgU3ViU3RyaW5nIFN5bVRyaWRpYWdvbmFsIFN5bWJvbCBTeW1tZXRyaWMgU3lzdGVtRXJyb3IgVENQU29ja2V0IFRhc2sgVGV4dCBUZXh0RGlzcGxheSBUaW1lciBUcmlkaWFnb25hbCBUdXBsZSBUeXBlIFR5cGVFcnJvciBUeXBlTWFwRW50cnkgVHlwZU1hcExldmVsIFR5cGVOYW1lIFR5cGVWYXIgVHlwZWRTbG90IFVEUFNvY2tldCBVSW50IFVJbnQxMjggVUludDE2IFVJbnQzMiBVSW50NjQgVUludDggVW5kZWZSZWZFcnJvciBVbmRlZlZhckVycm9yIFVuaWNvZGVFcnJvciBVbmlmb3JtU2NhbGluZyBVbmlvbiBVbmlvbkFsbCBVbml0UmFuZ2UgVW5zaWduZWQgVXBwZXJUcmlhbmd1bGFyIFZhbCBWYXJhcmcgVmVjRWxlbWVudCBWZWNPck1hdCBWZWN0b3IgVmVyc2lvbk51bWJlciBWb2lkIFdlYWtLZXlEaWN0IFdlYWtSZWYgV29ya2VyQ29uZmlnIFdvcmtlclBvb2wgIn0sdD0iW0EtWmEtel9cXHUwMEExLVxcdUZGRkZdW0EtWmEtel8wLTlcXHUwMEExLVxcdUZGRkZdKiIsYT17bDp0LGs6cixpOi88XC8vfSxuPXtjTjoibnVtYmVyIixiOi8oXGIweFtcZF9dKihcLltcZF9dKik/fDB4XC5cZFtcZF9dKilwWy0rXT9cZCt8XGIwW2JveF1bYS1mQS1GMC05XVthLWZBLUYwLTlfXSp8KFxiXGRbXGRfXSooXC5bXGRfXSopP3xcLlxkW1xkX10qKShbZUVmRl1bLStdP1xkKyk/LyxyOjB9LG89e2NOOiJzdHJpbmciLGI6LycoLnxcXFt4WHVVXVthLXpBLVowLTldKyknL30saT17Y046InN1YnN0IixiOi9cJFwoLyxlOi9cKS8sazpyfSxsPXtjTjoidmFyaWFibGUiLGI6IlxcJCIrdH0sYz17Y046InN0cmluZyIsYzpbZS5CRSxpLGxdLHY6W3tiOi9cdyoiIiIvLGU6LyIiIlx3Ki8scjoxMH0se2I6L1x3KiIvLGU6LyJcdyovfV19LHM9e2NOOiJzdHJpbmciLGM6W2UuQkUsaSxsXSxiOiJgIixlOiJgIn0sZD17Y046Im1ldGEiLGI6IkAiK3R9LHU9e2NOOiJjb21tZW50Iix2Olt7YjoiIz0iLGU6Ij0jIixyOjEwfSx7YjoiIyIsZToiJCJ9XX07cmV0dXJuIGEuYz1bbixvLGMscyxkLHUsZS5IQ00se2NOOiJrZXl3b3JkIixiOiJcXGIoKChhYnN0cmFjdHxwcmltaXRpdmUpXFxzKyl0eXBlfChtdXRhYmxlXFxzKyk/c3RydWN0KVxcYiJ9LHtiOi88Oi99XSxpLmM9YS5jLGF9KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoImNvZmZlZXNjcmlwdCIsZnVuY3Rpb24oZSl7dmFyIGM9e2tleXdvcmQ6ImluIGlmIGZvciB3aGlsZSBmaW5hbGx5IG5ldyBkbyByZXR1cm4gZWxzZSBicmVhayBjYXRjaCBpbnN0YW5jZW9mIHRocm93IHRyeSB0aGlzIHN3aXRjaCBjb250aW51ZSB0eXBlb2YgZGVsZXRlIGRlYnVnZ2VyIHN1cGVyIHlpZWxkIGltcG9ydCBleHBvcnQgZnJvbSBhcyBkZWZhdWx0IGF3YWl0IHRoZW4gdW5sZXNzIHVudGlsIGxvb3Agb2YgYnkgd2hlbiBhbmQgb3IgaXMgaXNudCBub3QiLGxpdGVyYWw6InRydWUgZmFsc2UgbnVsbCB1bmRlZmluZWQgeWVzIG5vIG9uIG9mZiIsYnVpbHRfaW46Im5wbSByZXF1aXJlIGNvbnNvbGUgcHJpbnQgbW9kdWxlIGdsb2JhbCB3aW5kb3cgZG9jdW1lbnQifSxuPSJbQS1aYS16JF9dWzAtOUEtWmEteiRfXSoiLHI9e2NOOiJzdWJzdCIsYjovI1x7LyxlOi99LyxrOmN9LGk9W2UuQk5NLGUuaW5oZXJpdChlLkNOTSx7c3RhcnRzOntlOiIoXFxzKi8pPyIscjowfX0pLHtjTjoic3RyaW5nIix2Olt7YjovJycnLyxlOi8nJycvLGM6W2UuQkVdfSx7YjovJy8sZTovJy8sYzpbZS5CRV19LHtiOi8iIiIvLGU6LyIiIi8sYzpbZS5CRSxyXX0se2I6LyIvLGU6LyIvLGM6W2UuQkUscl19XX0se2NOOiJyZWdleHAiLHY6W3tiOiIvLy8iLGU6Ii8vLyIsYzpbcixlLkhDTV19LHtiOiIvL1tnaW1dKiIscjowfSx7YjovXC8oPyFbICpdKShcXFwvfC4pKj9cL1tnaW1dKig/PVxXfCQpL31dfSx7YjoiQCIrbn0se3NMOiJqYXZhc2NyaXB0IixlQjohMCxlRTohMCx2Olt7YjoiYGBgIixlOiJgYGAifSx7YjoiYCIsZToiYCJ9XX1dO3IuYz1pO3ZhciBzPWUuaW5oZXJpdChlLlRNLHtiOm59KSx0PSIoXFwoLipcXCkpP1xccypcXEJbLT1dPiIsbz17Y046InBhcmFtcyIsYjoiXFwoW15cXChdIixyQjohMCxjOlt7YjovXCgvLGU6L1wpLyxrOmMsYzpbInNlbGYiXS5jb25jYXQoaSl9XX07cmV0dXJue2FsaWFzZXM6WyJjb2ZmZWUiLCJjc29uIiwiaWNlZCJdLGs6YyxpOi9cL1wqLyxjOmkuY29uY2F0KFtlLkMoIiMjIyIsIiMjIyIpLGUuSENNLHtjTjoiZnVuY3Rpb24iLGI6Il5cXHMqIituKyJcXHMqPVxccyoiK3QsZToiWy09XT4iLHJCOiEwLGM6W3Msb119LHtiOi9bOlwoLD1dXHMqLyxyOjAsYzpbe2NOOiJmdW5jdGlvbiIsYjp0LGU6IlstPV0+IixyQjohMCxjOltvXX1dfSx7Y046ImNsYXNzIixiSzoiY2xhc3MiLGU6IiQiLGk6L1s6PSJcW1xdXS8sYzpbe2JLOiJleHRlbmRzIixlVzohMCxpOi9bOj0iXFtcXV0vLGM6W3NdfSxzXX0se2I6bisiOiIsZToiOiIsckI6ITAsckU6ITAscjowfV0pfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiY3BwIixmdW5jdGlvbih0KXt2YXIgZT17Y046ImtleXdvcmQiLGI6IlxcYlthLXpcXGRfXSpfdFxcYiJ9LHI9e2NOOiJzdHJpbmciLHY6W3tiOicodTg/fFUpP0w/IicsZTonIicsaToiXFxuIixjOlt0LkJFXX0se2I6Jyh1OD98VSk/UiInLGU6JyInLGM6W3QuQkVdfSx7YjoiJ1xcXFw/LiIsZToiJyIsaToiLiJ9XX0scz17Y046Im51bWJlciIsdjpbe2I6IlxcYigwYlswMSddKykifSx7YjoiKC0/KVxcYihbXFxkJ10rKFxcLltcXGQnXSopP3xcXC5bXFxkJ10rKSh1fFV8bHxMfHVsfFVMfGZ8RnxifEIpIn0se2I6IigtPykoXFxiMFt4WF1bYS1mQS1GMC05J10rfChcXGJbXFxkJ10rKFxcLltcXGQnXSopP3xcXC5bXFxkJ10rKShbZUVdWy0rXT9bXFxkJ10rKT8pIn1dLHI6MH0saT17Y046Im1ldGEiLGI6LyNccypbYS16XStcYi8sZTovJC8sazp7Im1ldGEta2V5d29yZCI6ImlmIGVsc2UgZWxpZiBlbmRpZiBkZWZpbmUgdW5kZWYgd2FybmluZyBlcnJvciBsaW5lIHByYWdtYSBpZmRlZiBpZm5kZWYgaW5jbHVkZSJ9LGM6W3tiOi9cXFxuLyxyOjB9LHQuaW5oZXJpdChyLHtjTjoibWV0YS1zdHJpbmcifSkse2NOOiJtZXRhLXN0cmluZyIsYjovPFteXG4+XSo+LyxlOi8kLyxpOiJcXG4ifSx0LkNMQ00sdC5DQkNNXX0sYT10LklSKyJcXHMqXFwoIixjPXtrZXl3b3JkOiJpbnQgZmxvYXQgd2hpbGUgcHJpdmF0ZSBjaGFyIGNhdGNoIGltcG9ydCBtb2R1bGUgZXhwb3J0IHZpcnR1YWwgb3BlcmF0b3Igc2l6ZW9mIGR5bmFtaWNfY2FzdHwxMCB0eXBlZGVmIGNvbnN0X2Nhc3R8MTAgY29uc3QgZm9yIHN0YXRpY19jYXN0fDEwIHVuaW9uIG5hbWVzcGFjZSB1bnNpZ25lZCBsb25nIHZvbGF0aWxlIHN0YXRpYyBwcm90ZWN0ZWQgYm9vbCB0ZW1wbGF0ZSBtdXRhYmxlIGlmIHB1YmxpYyBmcmllbmQgZG8gZ290byBhdXRvIHZvaWQgZW51bSBlbHNlIGJyZWFrIGV4dGVybiB1c2luZyBhc20gY2FzZSB0eXBlaWQgc2hvcnQgcmVpbnRlcnByZXRfY2FzdHwxMCBkZWZhdWx0IGRvdWJsZSByZWdpc3RlciBleHBsaWNpdCBzaWduZWQgdHlwZW5hbWUgdHJ5IHRoaXMgc3dpdGNoIGNvbnRpbnVlIGlubGluZSBkZWxldGUgYWxpZ25vZiBjb25zdGV4cHIgZGVjbHR5cGUgbm9leGNlcHQgc3RhdGljX2Fzc2VydCB0aHJlYWRfbG9jYWwgcmVzdHJpY3QgX0Jvb2wgY29tcGxleCBfQ29tcGxleCBfSW1hZ2luYXJ5IGF0b21pY19ib29sIGF0b21pY19jaGFyIGF0b21pY19zY2hhciBhdG9taWNfdWNoYXIgYXRvbWljX3Nob3J0IGF0b21pY191c2hvcnQgYXRvbWljX2ludCBhdG9taWNfdWludCBhdG9taWNfbG9uZyBhdG9taWNfdWxvbmcgYXRvbWljX2xsb25nIGF0b21pY191bGxvbmcgbmV3IHRocm93IHJldHVybiBhbmQgb3Igbm90IixidWlsdF9pbjoic3RkIHN0cmluZyBjaW4gY291dCBjZXJyIGNsb2cgc3RkaW4gc3Rkb3V0IHN0ZGVyciBzdHJpbmdzdHJlYW0gaXN0cmluZ3N0cmVhbSBvc3RyaW5nc3RyZWFtIGF1dG9fcHRyIGRlcXVlIGxpc3QgcXVldWUgc3RhY2sgdmVjdG9yIG1hcCBzZXQgYml0c2V0IG11bHRpc2V0IG11bHRpbWFwIHVub3JkZXJlZF9zZXQgdW5vcmRlcmVkX21hcCB1bm9yZGVyZWRfbXVsdGlzZXQgdW5vcmRlcmVkX211bHRpbWFwIGFycmF5IHNoYXJlZF9wdHIgYWJvcnQgYWJzIGFjb3MgYXNpbiBhdGFuMiBhdGFuIGNhbGxvYyBjZWlsIGNvc2ggY29zIGV4aXQgZXhwIGZhYnMgZmxvb3IgZm1vZCBmcHJpbnRmIGZwdXRzIGZyZWUgZnJleHAgZnNjYW5mIGlzYWxudW0gaXNhbHBoYSBpc2NudHJsIGlzZGlnaXQgaXNncmFwaCBpc2xvd2VyIGlzcHJpbnQgaXNwdW5jdCBpc3NwYWNlIGlzdXBwZXIgaXN4ZGlnaXQgdG9sb3dlciB0b3VwcGVyIGxhYnMgbGRleHAgbG9nMTAgbG9nIG1hbGxvYyByZWFsbG9jIG1lbWNociBtZW1jbXAgbWVtY3B5IG1lbXNldCBtb2RmIHBvdyBwcmludGYgcHV0Y2hhciBwdXRzIHNjYW5mIHNpbmggc2luIHNucHJpbnRmIHNwcmludGYgc3FydCBzc2NhbmYgc3RyY2F0IHN0cmNociBzdHJjbXAgc3RyY3B5IHN0cmNzcG4gc3RybGVuIHN0cm5jYXQgc3RybmNtcCBzdHJuY3B5IHN0cnBicmsgc3RycmNociBzdHJzcG4gc3Ryc3RyIHRhbmggdGFuIHZmcHJpbnRmIHZwcmludGYgdnNwcmludGYgZW5kbCBpbml0aWFsaXplcl9saXN0IHVuaXF1ZV9wdHIiLGxpdGVyYWw6InRydWUgZmFsc2UgbnVsbHB0ciBOVUxMIn0sbj1bZSx0LkNMQ00sdC5DQkNNLHMscl07cmV0dXJue2FsaWFzZXM6WyJjIiwiY2MiLCJoIiwiYysrIiwiaCsrIiwiaHBwIl0sazpjLGk6IjwvIixjOm4uY29uY2F0KFtpLHtiOiJcXGIoZGVxdWV8bGlzdHxxdWV1ZXxzdGFja3x2ZWN0b3J8bWFwfHNldHxiaXRzZXR8bXVsdGlzZXR8bXVsdGltYXB8dW5vcmRlcmVkX21hcHx1bm9yZGVyZWRfc2V0fHVub3JkZXJlZF9tdWx0aXNldHx1bm9yZGVyZWRfbXVsdGltYXB8YXJyYXkpXFxzKjwiLGU6Ij4iLGs6YyxjOlsic2VsZiIsZV19LHtiOnQuSVIrIjo6IixrOmN9LHt2Olt7YjovPS8sZTovOy99LHtiOi9cKC8sZTovXCkvfSx7Yks6Im5ldyB0aHJvdyByZXR1cm4gZWxzZSIsZTovOy99XSxrOmMsYzpuLmNvbmNhdChbe2I6L1woLyxlOi9cKS8sazpjLGM6bi5jb25jYXQoWyJzZWxmIl0pLHI6MH1dKSxyOjB9LHtjTjoiZnVuY3Rpb24iLGI6IigiK3QuSVIrIltcXComXFxzXSspKyIrYSxyQjohMCxlOi9bezs9XS8sZUU6ITAsazpjLGk6L1teXHdcc1wqJl0vLGM6W3tiOmEsckI6ITAsYzpbdC5UTV0scjowfSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxrOmMscjowLGM6W3QuQ0xDTSx0LkNCQ00scixzLGVdfSx0LkNMQ00sdC5DQkNNLGldfSx7Y046ImNsYXNzIixiSzoiY2xhc3Mgc3RydWN0IixlOi9bezs6XS8sYzpbe2I6LzwvLGU6Lz4vLGM6WyJzZWxmIl19LHQuVE1dfV0pLGV4cG9ydHM6e3ByZXByb2Nlc3NvcjppLHN0cmluZ3M6cixrOmN9fX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgicnVieSIsZnVuY3Rpb24oZSl7dmFyIGI9IlthLXpBLVpfXVxcdypbIT89XT98Wy0rfl1cXEB8PDx8Pj58PX58PT09P3w8PT58Wzw+XT0/fFxcKlxcKnxbLS8rJV4mKn5gfF18XFxbXFxdPT8iLHI9e2tleXdvcmQ6ImFuZCB0aGVuIGRlZmluZWQgbW9kdWxlIGluIHJldHVybiByZWRvIGlmIEJFR0lOIHJldHJ5IGVuZCBmb3Igc2VsZiB3aGVuIG5leHQgdW50aWwgZG8gYmVnaW4gdW5sZXNzIEVORCByZXNjdWUgZWxzZSBicmVhayB1bmRlZiBub3Qgc3VwZXIgY2xhc3MgY2FzZSByZXF1aXJlIHlpZWxkIGFsaWFzIHdoaWxlIGVuc3VyZSBlbHNpZiBvciBpbmNsdWRlIGF0dHJfcmVhZGVyIGF0dHJfd3JpdGVyIGF0dHJfYWNjZXNzb3IiLGxpdGVyYWw6InRydWUgZmFsc2UgbmlsIn0sYz17Y046ImRvY3RhZyIsYjoiQFtBLVphLXpdKyJ9LGE9e2I6IiM8IixlOiI+In0scz1bZS5DKCIjIiwiJCIse2M6W2NdfSksZS5DKCJeXFw9YmVnaW4iLCJeXFw9ZW5kIix7YzpbY10scjoxMH0pLGUuQygiXl9fRU5EX18iLCJcXG4kIildLG49e2NOOiJzdWJzdCIsYjoiI1xceyIsZToifSIsazpyfSx0PXtjTjoic3RyaW5nIixjOltlLkJFLG5dLHY6W3tiOi8nLyxlOi8nL30se2I6LyIvLGU6LyIvfSx7YjovYC8sZTovYC99LHtiOiIlW3FRd1d4XT9cXCgiLGU6IlxcKSJ9LHtiOiIlW3FRd1d4XT9cXFsiLGU6IlxcXSJ9LHtiOiIlW3FRd1d4XT97IixlOiJ9In0se2I6IiVbcVF3V3hdPzwiLGU6Ij4ifSx7YjoiJVtxUXdXeF0/LyIsZToiLyJ9LHtiOiIlW3FRd1d4XT8lIixlOiIlIn0se2I6IiVbcVF3V3hdPy0iLGU6Ii0ifSx7YjoiJVtxUXdXeF0/XFx8IixlOiJcXHwifSx7YjovXEJcPyhcXFxkezEsM318XFx4W0EtRmEtZjAtOV17MSwyfXxcXHVbQS1GYS1mMC05XXs0fXxcXD9cUylcYi99LHtiOi88PCgtPylcdyskLyxlOi9eXHMqXHcrJC99XX0saT17Y046InBhcmFtcyIsYjoiXFwoIixlOiJcXCkiLGVuZHNQYXJlbnQ6ITAsazpyfSxkPVt0LGEse2NOOiJjbGFzcyIsYks6ImNsYXNzIG1vZHVsZSIsZToiJHw7IixpOi89LyxjOltlLmluaGVyaXQoZS5UTSx7YjoiW0EtWmEtel9dXFx3Kig6OlxcdyspKihcXD98XFwhKT8ifSkse2I6IjxcXHMqIixjOlt7YjoiKCIrZS5JUisiOjopPyIrZS5JUn1dfV0uY29uY2F0KHMpfSx7Y046ImZ1bmN0aW9uIixiSzoiZGVmIixlOiIkfDsiLGM6W2UuaW5oZXJpdChlLlRNLHtiOmJ9KSxpXS5jb25jYXQocyl9LHtiOmUuSVIrIjo6In0se2NOOiJzeW1ib2wiLGI6ZS5VSVIrIihcXCF8XFw/KT86IixyOjB9LHtjTjoic3ltYm9sIixiOiI6KD8hXFxzKSIsYzpbdCx7YjpifV0scjowfSx7Y046Im51bWJlciIsYjoiKFxcYjBbMC03X10rKXwoXFxiMHhbMC05YS1mQS1GX10rKXwoXFxiWzEtOV1bMC05X10qKFxcLlswLTlfXSspPyl8WzBfXVxcYiIscjowfSx7YjoiKFxcJFxcVyl8KChcXCR8XFxAXFxAPykoXFx3KykpIn0se2NOOiJwYXJhbXMiLGI6L1x8LyxlOi9cfC8sazpyfSx7YjoiKCIrZS5SU1IrInx1bmxlc3MpXFxzKiIsazoidW5sZXNzIixjOlthLHtjTjoicmVnZXhwIixjOltlLkJFLG5dLGk6L1xuLyx2Olt7YjoiLyIsZToiL1thLXpdKiJ9LHtiOiIlcnsiLGU6In1bYS16XSoifSx7YjoiJXJcXCgiLGU6IlxcKVthLXpdKiJ9LHtiOiIlciEiLGU6IiFbYS16XSoifSx7YjoiJXJcXFsiLGU6IlxcXVthLXpdKiJ9XX1dLmNvbmNhdChzKSxyOjB9XS5jb25jYXQocyk7bi5jPWQsaS5jPWQ7dmFyIGw9Ils+P10+IixvPSJbXFx3I10rXFwoXFx3K1xcKTpcXGQrOlxcZCs+Iix1PSIoXFx3Ky0pP1xcZCtcXC5cXGQrXFwuXFxkKHBcXGQrKT9bXj5dKz4iLHc9W3tiOi9eXHMqPT4vLHN0YXJ0czp7ZToiJCIsYzpkfX0se2NOOiJtZXRhIixiOiJeKCIrbCsifCIrbysifCIrdSsiKSIsc3RhcnRzOntlOiIkIixjOmR9fV07cmV0dXJue2FsaWFzZXM6WyJyYiIsImdlbXNwZWMiLCJwb2RzcGVjIiwidGhvciIsImlyYiJdLGs6cixpOi9cL1wqLyxjOnMuY29uY2F0KHcpLmNvbmNhdChkKX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInlhbWwiLGZ1bmN0aW9uKGUpe3ZhciBiPSJ0cnVlIGZhbHNlIHllcyBubyBudWxsIixhPSJeWyBcXC1dKiIscj0iW2EtekEtWl9dW1xcd1xcLV0qIix0PXtjTjoiYXR0ciIsdjpbe2I6YStyKyI6In0se2I6YSsnIicrcisnIjonfSx7YjphKyInIityKyInOiJ9XX0sYz17Y046InRlbXBsYXRlLXZhcmlhYmxlIix2Olt7Yjoie3siLGU6In19In0se2I6IiV7IixlOiJ9In1dfSxsPXtjTjoic3RyaW5nIixyOjAsdjpbe2I6LycvLGU6LycvfSx7YjovIi8sZTovIi99LHtiOi9cUysvfV0sYzpbZS5CRSxjXX07cmV0dXJue2NJOiEwLGFsaWFzZXM6WyJ5bWwiLCJZQU1MIiwieWFtbCJdLGM6W3Qse2NOOiJtZXRhIixiOiJeLS0tcyokIixyOjEwfSx7Y046InN0cmluZyIsYjoiW1xcfD5dICokIixyRTohMCxjOmwuYyxlOnQudlswXS5ifSx7YjoiPCVbJT0tXT8iLGU6IlslLV0/JT4iLHNMOiJydWJ5IixlQjohMCxlRTohMCxyOjB9LHtjTjoidHlwZSIsYjoiISEiK2UuVUlSfSx7Y046Im1ldGEiLGI6IiYiK2UuVUlSKyIkIn0se2NOOiJtZXRhIixiOiJcXCoiK2UuVUlSKyIkIn0se2NOOiJidWxsZXQiLGI6Il4gKi0iLHI6MH0sZS5IQ00se2JLOmIsazp7bGl0ZXJhbDpifX0sZS5DTk0sbF19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJjc3MiLGZ1bmN0aW9uKGUpe3ZhciBjPSJbYS16QS1aLV1bYS16QS1aMC05Xy1dKiIsdD17YjovW0EtWlxfXC5cLV0rXHMqOi8sckI6ITAsZToiOyIsZVc6ITAsYzpbe2NOOiJhdHRyaWJ1dGUiLGI6L1xTLyxlOiI6IixlRTohMCxzdGFydHM6e2VXOiEwLGVFOiEwLGM6W3tiOi9bXHctXStcKC8sckI6ITAsYzpbe2NOOiJidWlsdF9pbiIsYjovW1x3LV0rL30se2I6L1woLyxlOi9cKS8sYzpbZS5BU00sZS5RU01dfV19LGUuQ1NTTk0sZS5RU00sZS5BU00sZS5DQkNNLHtjTjoibnVtYmVyIixiOiIjWzAtOUEtRmEtZl0rIn0se2NOOiJtZXRhIixiOiIhaW1wb3J0YW50In1dfX1dfTtyZXR1cm57Y0k6ITAsaTovWz1cL3wnXCRdLyxjOltlLkNCQ00se2NOOiJzZWxlY3Rvci1pZCIsYjovI1tBLVphLXowLTlfLV0rL30se2NOOiJzZWxlY3Rvci1jbGFzcyIsYjovXC5bQS1aYS16MC05Xy1dKy99LHtjTjoic2VsZWN0b3ItYXR0ciIsYjovXFsvLGU6L1xdLyxpOiIkIn0se2NOOiJzZWxlY3Rvci1wc2V1ZG8iLGI6LzooOik/W2EtekEtWjAtOVxfXC1cK1woXCkiJy5dKy99LHtiOiJAKGZvbnQtZmFjZXxwYWdlKSIsbDoiW2Etei1dKyIsazoiZm9udC1mYWNlIHBhZ2UifSx7YjoiQCIsZToiW3s7XSIsaTovOi8sYzpbe2NOOiJrZXl3b3JkIixiOi9cdysvfSx7YjovXHMvLGVXOiEwLGVFOiEwLHI6MCxjOltlLkFTTSxlLlFTTSxlLkNTU05NXX1dfSx7Y046InNlbGVjdG9yLXRhZyIsYjpjLHI6MH0se2I6InsiLGU6In0iLGk6L1xTLyxjOltlLkNCQ00sdF19XX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoImZvcnRyYW4iLGZ1bmN0aW9uKGUpe3ZhciB0PXtjTjoicGFyYW1zIixiOiJcXCgiLGU6IlxcKSJ9LG49e2xpdGVyYWw6Ii5GYWxzZS4gLlRydWUuIixrZXl3b3JkOiJraW5kIGRvIHdoaWxlIHByaXZhdGUgY2FsbCBpbnRyaW5zaWMgd2hlcmUgZWxzZXdoZXJlIHR5cGUgZW5kdHlwZSBlbmRtb2R1bGUgZW5kc2VsZWN0IGVuZGludGVyZmFjZSBlbmQgZW5kZG8gZW5kaWYgaWYgZm9yYWxsIGVuZGZvcmFsbCBvbmx5IGNvbnRhaW5zIGRlZmF1bHQgcmV0dXJuIHN0b3AgdGhlbiBwdWJsaWMgc3Vicm91dGluZXwxMCBmdW5jdGlvbiBwcm9ncmFtIC5hbmQuIC5vci4gLm5vdC4gLmxlLiAuZXEuIC5nZS4gLmd0LiAubHQuIGdvdG8gc2F2ZSBlbHNlIHVzZSBtb2R1bGUgc2VsZWN0IGNhc2UgYWNjZXNzIGJsYW5rIGRpcmVjdCBleGlzdCBmaWxlIGZtdCBmb3JtIGZvcm1hdHRlZCBpb3N0YXQgbmFtZSBuYW1lZCBuZXh0cmVjIG51bWJlciBvcGVuZWQgcmVjIHJlY2wgc2VxdWVudGlhbCBzdGF0dXMgdW5mb3JtYXR0ZWQgdW5pdCBjb250aW51ZSBmb3JtYXQgcGF1c2UgY3ljbGUgZXhpdCBjX251bGxfY2hhciBjX2FsZXJ0IGNfYmFja3NwYWNlIGNfZm9ybV9mZWVkIGZsdXNoIHdhaXQgZGVjaW1hbCByb3VuZCBpb21zZyBzeW5jaHJvbm91cyBub3Bhc3Mgbm9uX292ZXJyaWRhYmxlIHBhc3MgcHJvdGVjdGVkIHZvbGF0aWxlIGFic3RyYWN0IGV4dGVuZHMgaW1wb3J0IG5vbl9pbnRyaW5zaWMgdmFsdWUgZGVmZXJyZWQgZ2VuZXJpYyBmaW5hbCBlbnVtZXJhdG9yIGNsYXNzIGFzc29jaWF0ZSBiaW5kIGVudW0gY19pbnQgY19zaG9ydCBjX2xvbmcgY19sb25nX2xvbmcgY19zaWduZWRfY2hhciBjX3NpemVfdCBjX2ludDhfdCBjX2ludDE2X3QgY19pbnQzMl90IGNfaW50NjRfdCBjX2ludF9sZWFzdDhfdCBjX2ludF9sZWFzdDE2X3QgY19pbnRfbGVhc3QzMl90IGNfaW50X2xlYXN0NjRfdCBjX2ludF9mYXN0OF90IGNfaW50X2Zhc3QxNl90IGNfaW50X2Zhc3QzMl90IGNfaW50X2Zhc3Q2NF90IGNfaW50bWF4X3QgQ19pbnRwdHJfdCBjX2Zsb2F0IGNfZG91YmxlIGNfbG9uZ19kb3VibGUgY19mbG9hdF9jb21wbGV4IGNfZG91YmxlX2NvbXBsZXggY19sb25nX2RvdWJsZV9jb21wbGV4IGNfYm9vbCBjX2NoYXIgY19udWxsX3B0ciBjX251bGxfZnVucHRyIGNfbmV3X2xpbmUgY19jYXJyaWFnZV9yZXR1cm4gY19ob3Jpem9udGFsX3RhYiBjX3ZlcnRpY2FsX3RhYiBpc29fY19iaW5kaW5nIGNfbG9jIGNfZnVubG9jIGNfYXNzb2NpYXRlZCAgY19mX3BvaW50ZXIgY19wdHIgY19mdW5wdHIgaXNvX2ZvcnRyYW5fZW52IGNoYXJhY3Rlcl9zdG9yYWdlX3NpemUgZXJyb3JfdW5pdCBmaWxlX3N0b3JhZ2Vfc2l6ZSBpbnB1dF91bml0IGlvc3RhdF9lbmQgaW9zdGF0X2VvciBudW1lcmljX3N0b3JhZ2Vfc2l6ZSBvdXRwdXRfdW5pdCBjX2ZfcHJvY3BvaW50ZXIgaWVlZV9hcml0aG1ldGljIGllZWVfc3VwcG9ydF91bmRlcmZsb3dfY29udHJvbCBpZWVlX2dldF91bmRlcmZsb3dfbW9kZSBpZWVlX3NldF91bmRlcmZsb3dfbW9kZSBuZXd1bml0IGNvbnRpZ3VvdXMgcmVjdXJzaXZlIHBhZCBwb3NpdGlvbiBhY3Rpb24gZGVsaW0gcmVhZHdyaXRlIGVvciBhZHZhbmNlIG5tbCBpbnRlcmZhY2UgcHJvY2VkdXJlIG5hbWVsaXN0IGluY2x1ZGUgc2VxdWVuY2UgZWxlbWVudGFsIHB1cmUgaW50ZWdlciByZWFsIGNoYXJhY3RlciBjb21wbGV4IGxvZ2ljYWwgZGltZW5zaW9uIGFsbG9jYXRhYmxlfDEwIHBhcmFtZXRlciBleHRlcm5hbCBpbXBsaWNpdHwxMCBub25lIGRvdWJsZSBwcmVjaXNpb24gYXNzaWduIGludGVudCBvcHRpb25hbCBwb2ludGVyIHRhcmdldCBpbiBvdXQgY29tbW9uIGVxdWl2YWxlbmNlIGRhdGEiLGJ1aWx0X2luOiJhbG9nIGFsb2cxMCBhbWF4MCBhbWF4MSBhbWluMCBhbWluMSBhbW9kIGNhYnMgY2NvcyBjZXhwIGNsb2cgY3NpbiBjc3FydCBkYWJzIGRhY29zIGRhc2luIGRhdGFuIGRhdGFuMiBkY29zIGRjb3NoIGRkaW0gZGV4cCBkaW50IGRsb2cgZGxvZzEwIGRtYXgxIGRtaW4xIGRtb2QgZG5pbnQgZHNpZ24gZHNpbiBkc2luaCBkc3FydCBkdGFuIGR0YW5oIGZsb2F0IGlhYnMgaWRpbSBpZGludCBpZG5pbnQgaWZpeCBpc2lnbiBtYXgwIG1heDEgbWluMCBtaW4xIHNuZ2wgYWxnYW1hIGNkYWJzIGNkY29zIGNkZXhwIGNkbG9nIGNkc2luIGNkc3FydCBjcWFicyBjcWNvcyBjcWV4cCBjcWxvZyBjcXNpbiBjcXNxcnQgZGNtcGx4IGRjb25qZyBkZXJmIGRlcmZjIGRmbG9hdCBkZ2FtbWEgZGltYWcgZGxnYW1hIGlxaW50IHFhYnMgcWFjb3MgcWFzaW4gcWF0YW4gcWF0YW4yIHFjbXBseCBxY29uamcgcWNvcyBxY29zaCBxZGltIHFlcmYgcWVyZmMgcWV4cCBxZ2FtbWEgcWltYWcgcWxnYW1hIHFsb2cgcWxvZzEwIHFtYXgxIHFtaW4xIHFtb2QgcW5pbnQgcXNpZ24gcXNpbiBxc2luaCBxc3FydCBxdGFuIHF0YW5oIGFicyBhY29zIGFpbWFnIGFpbnQgYW5pbnQgYXNpbiBhdGFuIGF0YW4yIGNoYXIgY21wbHggY29uamcgY29zIGNvc2ggZXhwIGljaGFyIGluZGV4IGludCBsb2cgbG9nMTAgbWF4IG1pbiBuaW50IHNpZ24gc2luIHNpbmggc3FydCB0YW4gdGFuaCBwcmludCB3cml0ZSBkaW0gbGdlIGxndCBsbGUgbGx0IG1vZCBudWxsaWZ5IGFsbG9jYXRlIGRlYWxsb2NhdGUgYWRqdXN0bCBhZGp1c3RyIGFsbCBhbGxvY2F0ZWQgYW55IGFzc29jaWF0ZWQgYml0X3NpemUgYnRlc3QgY2VpbGluZyBjb3VudCBjc2hpZnQgZGF0ZV9hbmRfdGltZSBkaWdpdHMgZG90X3Byb2R1Y3QgZW9zaGlmdCBlcHNpbG9uIGV4cG9uZW50IGZsb29yIGZyYWN0aW9uIGh1Z2UgaWFuZCBpYmNsciBpYml0cyBpYnNldCBpZW9yIGlvciBpc2hmdCBpc2hmdGMgbGJvdW5kIGxlbl90cmltIG1hdG11bCBtYXhleHBvbmVudCBtYXhsb2MgbWF4dmFsIG1lcmdlIG1pbmV4cG9uZW50IG1pbmxvYyBtaW52YWwgbW9kdWxvIG12Yml0cyBuZWFyZXN0IHBhY2sgcHJlc2VudCBwcm9kdWN0IHJhZGl4IHJhbmRvbV9udW1iZXIgcmFuZG9tX3NlZWQgcmFuZ2UgcmVwZWF0IHJlc2hhcGUgcnJzcGFjaW5nIHNjYWxlIHNjYW4gc2VsZWN0ZWRfaW50X2tpbmQgc2VsZWN0ZWRfcmVhbF9raW5kIHNldF9leHBvbmVudCBzaGFwZSBzaXplIHNwYWNpbmcgc3ByZWFkIHN1bSBzeXN0ZW1fY2xvY2sgdGlueSB0cmFuc3Bvc2UgdHJpbSB1Ym91bmQgdW5wYWNrIHZlcmlmeSBhY2hhciBpYWNoYXIgdHJhbnNmZXIgZGJsZSBlbnRyeSBkcHJvZCBjcHVfdGltZSBjb21tYW5kX2FyZ3VtZW50X2NvdW50IGdldF9jb21tYW5kIGdldF9jb21tYW5kX2FyZ3VtZW50IGdldF9lbnZpcm9ubWVudF92YXJpYWJsZSBpc19pb3N0YXRfZW5kIGllZWVfYXJpdGhtZXRpYyBpZWVlX3N1cHBvcnRfdW5kZXJmbG93X2NvbnRyb2wgaWVlZV9nZXRfdW5kZXJmbG93X21vZGUgaWVlZV9zZXRfdW5kZXJmbG93X21vZGUgaXNfaW9zdGF0X2VvciBtb3ZlX2FsbG9jIG5ld19saW5lIHNlbGVjdGVkX2NoYXJfa2luZCBzYW1lX3R5cGVfYXMgZXh0ZW5kc190eXBlX29mYWNvc2ggYXNpbmggYXRhbmggYmVzc2VsX2owIGJlc3NlbF9qMSBiZXNzZWxfam4gYmVzc2VsX3kwIGJlc3NlbF95MSBiZXNzZWxfeW4gZXJmIGVyZmMgZXJmY19zY2FsZWQgZ2FtbWEgbG9nX2dhbW1hIGh5cG90IG5vcm0yIGF0b21pY19kZWZpbmUgYXRvbWljX3JlZiBleGVjdXRlX2NvbW1hbmRfbGluZSBsZWFkeiB0cmFpbHogc3RvcmFnZV9zaXplIG1lcmdlX2JpdHMgYmdlIGJndCBibGUgYmx0IGRzaGlmdGwgZHNoaWZ0ciBmaW5kbG9jIGlhbGwgaWFueSBpcGFyaXR5IGltYWdlX2luZGV4IGxjb2JvdW5kIHVjb2JvdW5kIG1hc2tsIG1hc2tyIG51bV9pbWFnZXMgcGFyaXR5IHBvcGNudCBwb3BwYXIgc2hpZnRhIHNoaWZ0bCBzaGlmdHIgdGhpc19pbWFnZSJ9O3JldHVybntjSTohMCxhbGlhc2VzOlsiZjkwIiwiZjk1Il0sazpuLGk6L1wvXCovLGM6W2UuaW5oZXJpdChlLkFTTSx7Y046InN0cmluZyIscjowfSksZS5pbmhlcml0KGUuUVNNLHtjTjoic3RyaW5nIixyOjB9KSx7Y046ImZ1bmN0aW9uIixiSzoic3Vicm91dGluZSBmdW5jdGlvbiBwcm9ncmFtIixpOiJbJHs9XFxuXSIsYzpbZS5VVE0sdF19LGUuQygiISIsIiQiLHtyOjB9KSx7Y046Im51bWJlciIsYjoiKD89XFxifFxcK3xcXC18XFwuKSg/PVxcLlxcZHxcXGQpKD86XFxkKyk/KD86XFwuP1xcZCopKD86W2RlXVsrLV0/XFxkKyk/XFxiXFwuPyIscjowfV19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJhd2siLGZ1bmN0aW9uKGUpe3ZhciByPXtjTjoidmFyaWFibGUiLHY6W3tiOi9cJFtcd1xkI0BdW1x3XGRfXSovfSx7YjovXCRceyguKj8pfS99XX0sYj0iQkVHSU4gRU5EIGlmIGVsc2Ugd2hpbGUgZG8gZm9yIGluIGJyZWFrIGNvbnRpbnVlIGRlbGV0ZSBuZXh0IG5leHRmaWxlIGZ1bmN0aW9uIGZ1bmMgZXhpdHwxMCIsbj17Y046InN0cmluZyIsYzpbZS5CRV0sdjpbe2I6Lyh1fGIpP3I/JycnLyxlOi8nJycvLHI6MTB9LHtiOi8odXxiKT9yPyIiIi8sZTovIiIiLyxyOjEwfSx7YjovKHV8cnx1ciknLyxlOi8nLyxyOjEwfSx7YjovKHV8cnx1cikiLyxlOi8iLyxyOjEwfSx7YjovKGJ8YnIpJy8sZTovJy99LHtiOi8oYnxicikiLyxlOi8iL30sZS5BU00sZS5RU01dfTtyZXR1cm57azp7a2V5d29yZDpifSxjOltyLG4sZS5STSxlLkhDTSxlLk5NXX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoIm1ha2VmaWxlIixmdW5jdGlvbihlKXt2YXIgaT17Y046InZhcmlhYmxlIix2Olt7YjoiXFwkXFwoIitlLlVJUisiXFwpIixjOltlLkJFXX0se2I6L1wkW0AlPD9cXlwrXCpdL31dfSxyPXtjTjoic3RyaW5nIixiOi8iLyxlOi8iLyxjOltlLkJFLGldfSxhPXtjTjoidmFyaWFibGUiLGI6L1wkXChbXHctXStccy8sZTovXCkvLGs6e2J1aWx0X2luOiJzdWJzdCBwYXRzdWJzdCBzdHJpcCBmaW5kc3RyaW5nIGZpbHRlciBmaWx0ZXItb3V0IHNvcnQgd29yZCB3b3JkbGlzdCBmaXJzdHdvcmQgbGFzdHdvcmQgZGlyIG5vdGRpciBzdWZmaXggYmFzZW5hbWUgYWRkc3VmZml4IGFkZHByZWZpeCBqb2luIHdpbGRjYXJkIHJlYWxwYXRoIGFic3BhdGggZXJyb3Igd2FybmluZyBzaGVsbCBvcmlnaW4gZmxhdm9yIGZvcmVhY2ggaWYgb3IgYW5kIGNhbGwgZXZhbCBmaWxlIHZhbHVlIn0sYzpbaV19LG49e2I6Il4iK2UuVUlSKyJcXHMqWzorP10/PSIsaToiXFxuIixyQjohMCxjOlt7YjoiXiIrZS5VSVIsZToiWzorP10/PSIsZUU6ITB9XX0sdD17Y046Im1ldGEiLGI6L15cLlBIT05ZOi8sZTovJC8sazp7Im1ldGEta2V5d29yZCI6Ii5QSE9OWSJ9LGw6L1tcLlx3XSsvfSxsPXtjTjoic2VjdGlvbiIsYjovXlteXHNdKzovLGU6LyQvLGM6W2ldfTtyZXR1cm57YWxpYXNlczpbIm1rIiwibWFrIl0sazoiZGVmaW5lIGVuZGVmIHVuZGVmaW5lIGlmZGVmIGlmbmRlZiBpZmVxIGlmbmVxIGVsc2UgZW5kaWYgaW5jbHVkZSAtaW5jbHVkZSBzaW5jbHVkZSBvdmVycmlkZSBleHBvcnQgdW5leHBvcnQgcHJpdmF0ZSB2cGF0aCIsbDovW1x3LV0rLyxjOltlLkhDTSxpLHIsYSxuLHQsbF19fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJqYXZhIixmdW5jdGlvbihlKXt2YXIgYT0iW8OALcq4YS16QS1aXyRdW8OALcq4YS16QS1aXyQwLTldKiIsdD1hKyIoPCIrYSsiKFxccyosXFxzKiIrYSsiKSo+KT8iLHI9ImZhbHNlIHN5bmNocm9uaXplZCBpbnQgYWJzdHJhY3QgZmxvYXQgcHJpdmF0ZSBjaGFyIGJvb2xlYW4gc3RhdGljIG51bGwgaWYgY29uc3QgZm9yIHRydWUgd2hpbGUgbG9uZyBzdHJpY3RmcCBmaW5hbGx5IHByb3RlY3RlZCBpbXBvcnQgbmF0aXZlIGZpbmFsIHZvaWQgZW51bSBlbHNlIGJyZWFrIHRyYW5zaWVudCBjYXRjaCBpbnN0YW5jZW9mIGJ5dGUgc3VwZXIgdm9sYXRpbGUgY2FzZSBhc3NlcnQgc2hvcnQgcGFja2FnZSBkZWZhdWx0IGRvdWJsZSBwdWJsaWMgdHJ5IHRoaXMgc3dpdGNoIGNvbnRpbnVlIHRocm93cyBwcm90ZWN0ZWQgcHVibGljIHByaXZhdGUgbW9kdWxlIHJlcXVpcmVzIGV4cG9ydHMgZG8iLHM9IlxcYigwW2JCXShbMDFdK1swMV9dK1swMV0rfFswMV0rKXwwW3hYXShbYS1mQS1GMC05XStbYS1mQS1GMC05X10rW2EtZkEtRjAtOV0rfFthLWZBLUYwLTldKyl8KChbXFxkXStbXFxkX10rW1xcZF0rfFtcXGRdKykoXFwuKFtcXGRdK1tcXGRfXStbXFxkXSt8W1xcZF0rKSk/fFxcLihbXFxkXStbXFxkX10rW1xcZF0rfFtcXGRdKykpKFtlRV1bLStdP1xcZCspPylbbExmRl0/IixjPXtjTjoibnVtYmVyIixiOnMscjowfTtyZXR1cm57YWxpYXNlczpbImpzcCJdLGs6cixpOi88XC98Iy8sYzpbZS5DKCIvXFwqXFwqIiwiXFwqLyIse3I6MCxjOlt7YjovXHcrQC8scjowfSx7Y046ImRvY3RhZyIsYjoiQFtBLVphLXpdKyJ9XX0pLGUuQ0xDTSxlLkNCQ00sZS5BU00sZS5RU00se2NOOiJjbGFzcyIsYks6ImNsYXNzIGludGVyZmFjZSIsZTovW3s7PV0vLGVFOiEwLGs6ImNsYXNzIGludGVyZmFjZSIsaTovWzoiXFtcXV0vLGM6W3tiSzoiZXh0ZW5kcyBpbXBsZW1lbnRzIn0sZS5VVE1dfSx7Yks6Im5ldyB0aHJvdyByZXR1cm4gZWxzZSIscjowfSx7Y046ImZ1bmN0aW9uIixiOiIoIit0KyJcXHMrKSsiK2UuVUlSKyJcXHMqXFwoIixyQjohMCxlOi9bezs9XS8sZUU6ITAsazpyLGM6W3tiOmUuVUlSKyJcXHMqXFwoIixyQjohMCxyOjAsYzpbZS5VVE1dfSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxrOnIscjowLGM6W2UuQVNNLGUuUVNNLGUuQ05NLGUuQ0JDTV19LGUuQ0xDTSxlLkNCQ01dfSxjLHtjTjoibWV0YSIsYjoiQFtBLVphLXpdKyJ9XX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInN0YW4iLGZ1bmN0aW9uKGUpe3JldHVybntjOltlLkhDTSxlLkNMQ00sZS5DQkNNLHtiOmUuVUlSLGw6ZS5VSVIsazp7bmFtZToiZm9yIGluIHdoaWxlIHJlcGVhdCB1bnRpbCBpZiB0aGVuIGVsc2UiLHN5bWJvbDoiYmVybm91bGxpIGJlcm5vdWxsaV9sb2dpdCBiaW5vbWlhbCBiaW5vbWlhbF9sb2dpdCBiZXRhX2Jpbm9taWFsIGh5cGVyZ2VvbWV0cmljIGNhdGVnb3JpY2FsIGNhdGVnb3JpY2FsX2xvZ2l0IG9yZGVyZWRfbG9naXN0aWMgbmVnX2Jpbm9taWFsIG5lZ19iaW5vbWlhbF8yIG5lZ19iaW5vbWlhbF8yX2xvZyBwb2lzc29uIHBvaXNzb25fbG9nIG11bHRpbm9taWFsIG5vcm1hbCBleHBfbW9kX25vcm1hbCBza2V3X25vcm1hbCBzdHVkZW50X3QgY2F1Y2h5IGRvdWJsZV9leHBvbmVudGlhbCBsb2dpc3RpYyBndW1iZWwgbG9nbm9ybWFsIGNoaV9zcXVhcmUgaW52X2NoaV9zcXVhcmUgc2NhbGVkX2ludl9jaGlfc3F1YXJlIGV4cG9uZW50aWFsIGludl9nYW1tYSB3ZWlidWxsIGZyZWNoZXQgcmF5bGVpZ2ggd2llbmVyIHBhcmV0byBwYXJldG9fdHlwZV8yIHZvbl9taXNlcyB1bmlmb3JtIG11bHRpX25vcm1hbCBtdWx0aV9ub3JtYWxfcHJlYyBtdWx0aV9ub3JtYWxfY2hvbGVza3kgbXVsdGlfZ3AgbXVsdGlfZ3BfY2hvbGVza3kgbXVsdGlfc3R1ZGVudF90IGdhdXNzaWFuX2RsbV9vYnMgZGlyaWNobGV0IGxral9jb3JyIGxral9jb3JyX2Nob2xlc2t5IHdpc2hhcnQgaW52X3dpc2hhcnQiLCJzZWxlY3Rvci10YWciOiJpbnQgcmVhbCB2ZWN0b3Igc2ltcGxleCB1bml0X3ZlY3RvciBvcmRlcmVkIHBvc2l0aXZlX29yZGVyZWQgcm93X3ZlY3RvciBtYXRyaXggY2hvbGVza3lfZmFjdG9yX2NvcnIgY2hvbGVza3lfZmFjdG9yX2NvdiBjb3JyX21hdHJpeCBjb3ZfbWF0cml4Iix0aXRsZToiZnVuY3Rpb25zIG1vZGVsIGRhdGEgcGFyYW1ldGVycyBxdWFudGl0aWVzIHRyYW5zZm9ybWVkIGdlbmVyYXRlZCIsbGl0ZXJhbDoidHJ1ZSBmYWxzZSJ9LHI6MH0se2NOOiJudW1iZXIiLGI6IjBbeFhdWzAtOWEtZkEtRl0rW0xpXT9cXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IjBbeFhdWzAtOWEtZkEtRl0rW0xpXT9cXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IlxcZCsoPzpbZUVdWytcXC1dP1xcZCopP0xcXGIiLHI6MH0se2NOOiJudW1iZXIiLGI6IlxcZCtcXC4oPyFcXGQpKD86aVxcYik/IixyOjB9LHtjTjoibnVtYmVyIixiOiJcXGQrKD86XFwuXFxkKik/KD86W2VFXVsrXFwtXT9cXGQqKT9pP1xcYiIscjowfSx7Y046Im51bWJlciIsYjoiXFwuXFxkKyg/OltlRV1bK1xcLV0/XFxkKik/aT9cXGIiLHI6MH1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgiamF2YXNjcmlwdCIsZnVuY3Rpb24oZSl7dmFyIHI9IltBLVphLXokX11bMC05QS1aYS16JF9dKiIsdD17a2V5d29yZDoiaW4gb2YgaWYgZm9yIHdoaWxlIGZpbmFsbHkgdmFyIG5ldyBmdW5jdGlvbiBkbyByZXR1cm4gdm9pZCBlbHNlIGJyZWFrIGNhdGNoIGluc3RhbmNlb2Ygd2l0aCB0aHJvdyBjYXNlIGRlZmF1bHQgdHJ5IHRoaXMgc3dpdGNoIGNvbnRpbnVlIHR5cGVvZiBkZWxldGUgbGV0IHlpZWxkIGNvbnN0IGV4cG9ydCBzdXBlciBkZWJ1Z2dlciBhcyBhc3luYyBhd2FpdCBzdGF0aWMgaW1wb3J0IGZyb20gYXMiLGxpdGVyYWw6InRydWUgZmFsc2UgbnVsbCB1bmRlZmluZWQgTmFOIEluZmluaXR5IixidWlsdF9pbjoiZXZhbCBpc0Zpbml0ZSBpc05hTiBwYXJzZUZsb2F0IHBhcnNlSW50IGRlY29kZVVSSSBkZWNvZGVVUklDb21wb25lbnQgZW5jb2RlVVJJIGVuY29kZVVSSUNvbXBvbmVudCBlc2NhcGUgdW5lc2NhcGUgT2JqZWN0IEZ1bmN0aW9uIEJvb2xlYW4gRXJyb3IgRXZhbEVycm9yIEludGVybmFsRXJyb3IgUmFuZ2VFcnJvciBSZWZlcmVuY2VFcnJvciBTdG9wSXRlcmF0aW9uIFN5bnRheEVycm9yIFR5cGVFcnJvciBVUklFcnJvciBOdW1iZXIgTWF0aCBEYXRlIFN0cmluZyBSZWdFeHAgQXJyYXkgRmxvYXQzMkFycmF5IEZsb2F0NjRBcnJheSBJbnQxNkFycmF5IEludDMyQXJyYXkgSW50OEFycmF5IFVpbnQxNkFycmF5IFVpbnQzMkFycmF5IFVpbnQ4QXJyYXkgVWludDhDbGFtcGVkQXJyYXkgQXJyYXlCdWZmZXIgRGF0YVZpZXcgSlNPTiBJbnRsIGFyZ3VtZW50cyByZXF1aXJlIG1vZHVsZSBjb25zb2xlIHdpbmRvdyBkb2N1bWVudCBTeW1ib2wgU2V0IE1hcCBXZWFrU2V0IFdlYWtNYXAgUHJveHkgUmVmbGVjdCBQcm9taXNlIn0sYT17Y046Im51bWJlciIsdjpbe2I6IlxcYigwW2JCXVswMV0rKSJ9LHtiOiJcXGIoMFtvT11bMC03XSspIn0se2I6ZS5DTlJ9XSxyOjB9LG49e2NOOiJzdWJzdCIsYjoiXFwkXFx7IixlOiJcXH0iLGs6dCxjOltdfSxjPXtjTjoic3RyaW5nIixiOiJgIixlOiJgIixjOltlLkJFLG5dfTtuLmM9W2UuQVNNLGUuUVNNLGMsYSxlLlJNXTt2YXIgcz1uLmMuY29uY2F0KFtlLkNCQ00sZS5DTENNXSk7cmV0dXJue2FsaWFzZXM6WyJqcyIsImpzeCJdLGs6dCxjOlt7Y046Im1ldGEiLHI6MTAsYjovXlxzKlsnIl11c2UgKHN0cmljdHxhc20pWyciXS99LHtjTjoibWV0YSIsYjovXiMhLyxlOi8kL30sZS5BU00sZS5RU00sYyxlLkNMQ00sZS5DQkNNLGEse2I6L1t7LF1ccyovLHI6MCxjOlt7YjpyKyJcXHMqOiIsckI6ITAscjowLGM6W3tjTjoiYXR0ciIsYjpyLHI6MH1dfV19LHtiOiIoIitlLlJTUisifFxcYihjYXNlfHJldHVybnx0aHJvdylcXGIpXFxzKiIsazoicmV0dXJuIHRocm93IGNhc2UiLGM6W2UuQ0xDTSxlLkNCQ00sZS5STSx7Y046ImZ1bmN0aW9uIixiOiIoXFwoLio/XFwpfCIrcisiKVxccyo9PiIsckI6ITAsZToiXFxzKj0+IixjOlt7Y046InBhcmFtcyIsdjpbe2I6cn0se2I6L1woXHMqXCkvfSx7YjovXCgvLGU6L1wpLyxlQjohMCxlRTohMCxrOnQsYzpzfV19XX0se2I6LzwvLGU6LyhcL1x3K3xcdytcLyk+LyxzTDoieG1sIixjOlt7YjovPFx3K1xzKlwvPi8sc2tpcDohMH0se2I6LzxcdysvLGU6LyhcL1x3K3xcdytcLyk+Lyxza2lwOiEwLGM6W3tiOi88XHcrXHMqXC8+Lyxza2lwOiEwfSwic2VsZiJdfV19XSxyOjB9LHtjTjoiZnVuY3Rpb24iLGJLOiJmdW5jdGlvbiIsZTovXHsvLGVFOiEwLGM6W2UuaW5oZXJpdChlLlRNLHtiOnJ9KSx7Y046InBhcmFtcyIsYjovXCgvLGU6L1wpLyxlQjohMCxlRTohMCxjOnN9XSxpOi9cW3wlL30se2I6L1wkWyguXS99LGUuTUVUSE9EX0dVQVJELHtjTjoiY2xhc3MiLGJLOiJjbGFzcyIsZTovW3s7PV0vLGVFOiEwLGk6L1s6IlxbXF1dLyxjOlt7Yks6ImV4dGVuZHMifSxlLlVUTV19LHtiSzoiY29uc3RydWN0b3IiLGU6L1x7LyxlRTohMH1dLGk6LyMoPyEhKS99fSk7aGxqcy5yZWdpc3Rlckxhbmd1YWdlKCJ0ZXgiLGZ1bmN0aW9uKGMpe3ZhciBlPXtjTjoidGFnIixiOi9cXC8scjowLGM6W3tjTjoibmFtZSIsdjpbe2I6L1thLXpBLVrQsC3Rj9CQLdGPXStbKl0/L30se2I6L1teYS16QS1a0LAt0Y/QkC3RjzAtOV0vfV0sc3RhcnRzOntlVzohMCxyOjAsYzpbe2NOOiJzdHJpbmciLHY6W3tiOi9cWy8sZTovXF0vfSx7YjovXHsvLGU6L1x9L31dfSx7YjovXHMqPVxzKi8sZVc6ITAscjowLGM6W3tjTjoibnVtYmVyIixiOi8tP1xkKlwuP1xkKyhwdHxwY3xtbXxjbXxpbnxkZHxjY3xleHxlbSk/L31dfV19fV19O3JldHVybntjOltlLHtjTjoiZm9ybXVsYSIsYzpbZV0scjowLHY6W3tiOi9cJFwkLyxlOi9cJFwkL30se2I6L1wkLyxlOi9cJC99XX0sYy5DKCIlIiwiJCIse3I6MH0pXX19KTtobGpzLnJlZ2lzdGVyTGFuZ3VhZ2UoInhtbCIsZnVuY3Rpb24ocyl7dmFyIGU9IltBLVphLXowLTlcXC5fOi1dKyIsdD17ZVc6ITAsaTovPC8scjowLGM6W3tjTjoiYXR0ciIsYjplLHI6MH0se2I6Lz1ccyovLHI6MCxjOlt7Y046InN0cmluZyIsZW5kc1BhcmVudDohMCx2Olt7YjovIi8sZTovIi99LHtiOi8nLyxlOi8nL30se2I6L1teXHMiJz08PmBdKy99XX1dfV19O3JldHVybnthbGlhc2VzOlsiaHRtbCIsInhodG1sIiwicnNzIiwiYXRvbSIsInhqYiIsInhzZCIsInhzbCIsInBsaXN0Il0sY0k6ITAsYzpbe2NOOiJtZXRhIixiOiI8IURPQ1RZUEUiLGU6Ij4iLHI6MTAsYzpbe2I6IlxcWyIsZToiXFxdIn1dfSxzLkMoIjwhLS0iLCItLT4iLHtyOjEwfSkse2I6IjxcXCFcXFtDREFUQVxcWyIsZToiXFxdXFxdPiIscjoxMH0se2I6LzxcPyhwaHApPy8sZTovXD8+LyxzTDoicGhwIixjOlt7YjoiL1xcKiIsZToiXFwqLyIsc2tpcDohMH1dfSx7Y046InRhZyIsYjoiPHN0eWxlKD89XFxzfD58JCkiLGU6Ij4iLGs6e25hbWU6InN0eWxlIn0sYzpbdF0sc3RhcnRzOntlOiI8L3N0eWxlPiIsckU6ITAsc0w6WyJjc3MiLCJ4bWwiXX19LHtjTjoidGFnIixiOiI8c2NyaXB0KD89XFxzfD58JCkiLGU6Ij4iLGs6e25hbWU6InNjcmlwdCJ9LGM6W3RdLHN0YXJ0czp7ZToiPC9zY3JpcHQ+IixyRTohMCxzTDpbImFjdGlvbnNjcmlwdCIsImphdmFzY3JpcHQiLCJoYW5kbGViYXJzIiwieG1sIl19fSx7Y046Im1ldGEiLHY6W3tiOi88XD94bWwvLGU6L1w/Pi8scjoxMH0se2I6LzxcP1x3Ky8sZTovXD8+L31dfSx7Y046InRhZyIsYjoiPC8/IixlOiIvPz4iLGM6W3tjTjoibmFtZSIsYjovW15cLz48XHNdKy8scjowfSx0XX1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgibWFya2Rvd24iLGZ1bmN0aW9uKGUpe3JldHVybnthbGlhc2VzOlsibWQiLCJta2Rvd24iLCJta2QiXSxjOlt7Y046InNlY3Rpb24iLHY6W3tiOiJeI3sxLDZ9IixlOiIkIn0se2I6Il4uKz9cXG5bPS1dezIsfSQifV19LHtiOiI8IixlOiI+IixzTDoieG1sIixyOjB9LHtjTjoiYnVsbGV0IixiOiJeKFsqKy1dfChcXGQrXFwuKSlcXHMrIn0se2NOOiJzdHJvbmciLGI6IlsqX117Mn0uKz9bKl9dezJ9In0se2NOOiJlbXBoYXNpcyIsdjpbe2I6IlxcKi4rP1xcKiJ9LHtiOiJfLis/XyIscjowfV19LHtjTjoicXVvdGUiLGI6Il4+XFxzKyIsZToiJCJ9LHtjTjoiY29kZSIsdjpbe2I6Il5gYGB3KnMqJCIsZToiXmBgYHMqJCJ9LHtiOiJgLis/YCJ9LHtiOiJeKCB7NH18CSkiLGU6IiQiLHI6MH1dfSx7YjoiXlstXFwqXXszLH0iLGU6IiQifSx7YjoiXFxbLis/XFxdW1xcKFxcW10uKj9bXFwpXFxdXSIsckI6ITAsYzpbe2NOOiJzdHJpbmciLGI6IlxcWyIsZToiXFxdIixlQjohMCxyRTohMCxyOjB9LHtjTjoibGluayIsYjoiXFxdXFwoIixlOiJcXCkiLGVCOiEwLGVFOiEwfSx7Y046InN5bWJvbCIsYjoiXFxdXFxbIixlOiJcXF0iLGVCOiEwLGVFOiEwfV0scjoxMH0se2I6L15cW1teXG5dK1xdOi8sckI6ITAsYzpbe2NOOiJzeW1ib2wiLGI6L1xbLyxlOi9cXS8sZUI6ITAsZUU6ITB9LHtjTjoibGluayIsYjovOlxzKi8sZTovJC8sZUI6ITB9XX1dfX0pO2hsanMucmVnaXN0ZXJMYW5ndWFnZSgianNvbiIsZnVuY3Rpb24oZSl7dmFyIGk9e2xpdGVyYWw6InRydWUgZmFsc2UgbnVsbCJ9LG49W2UuUVNNLGUuQ05NXSxyPXtlOiIsIixlVzohMCxlRTohMCxjOm4sazppfSx0PXtiOiJ7IixlOiJ9IixjOlt7Y046ImF0dHIiLGI6LyIvLGU6LyIvLGM6W2UuQkVdLGk6IlxcbiJ9LGUuaW5oZXJpdChyLHtiOi86L30pXSxpOiJcXFMifSxjPXtiOiJcXFsiLGU6IlxcXSIsYzpbZS5pbmhlcml0KHIpXSxpOiJcXFMifTtyZXR1cm4gbi5zcGxpY2Uobi5sZW5ndGgsMCx0LGMpLHtjOm4sazppLGk6IlxcUyJ9fSk7"></script> + +<style type="text/css">code{white-space: pre;}</style> +<style type="text/css"> + +</style> +<script type="text/javascript"> +if (window.hljs) { + hljs.configure({languages: []}); + hljs.initHighlightingOnLoad(); + if (document.readyState && document.readyState === "complete") { + window.setTimeout(function() { hljs.initHighlighting(); }, 0); + } +} +</script> + + + +<style type="text/css"> +h1 { + font-size: 34px; +} +h1.title { + font-size: 38px; +} +h2 { + font-size: 30px; +} +h3 { + font-size: 24px; +} +h4 { + font-size: 18px; +} +h5 { + font-size: 16px; +} +h6 { + font-size: 12px; +} +.table th:not([align]) { + text-align: left; +} +</style> + +<style type="text/css">body { +margin: 0px auto; +max-width: 1134px; +font-family: sans-serif; +font-size: 10pt; +} + +div#TOC ul { +padding: 0px 0px 0px 45px; +list-style: none; +background-image: none; +background-repeat: none; +background-position: 0; +font-size: 10pt; +font-family: Helvetica, Arial, sans-serif; +} +div#TOC > ul { +padding: 0px 150px 0px 65px; +font-size: 12pt; +} +div#TOC > ul > li { +padding: 5px 0px 0px 0px; +} +div#TOC ul ul { +font-size: 11pt; +} +div#TOC.tocify ul { +padding: 0px; +font-size: inherit; +font-family: inherit; +} +div#TOC.tocify li { +padding: 5px; +font-size: inherit; +font-family: inherit; +} +p, dl { +padding: 0px 150px 0px 65px; +text-align: justify; +} + +p, img, table { +margin-top: 10px; +margin-bottom: 10px; +} + +ol, ul { +padding: 0px 150px 0px 100px; +list-style: square; +} +li ol, li ul { +padding: 0px 0px 0px 35px; +} +li p { +padding: 0; +} +pre { +margin: 0em 150px 0.5em 0em; +padding: 0px 0px 0px 65px; +border: 0px none; +background-color: #f0f0f0; +white-space: pre; +overflow-x: auto; +font-size: 90%; +} +li pre { +margin: 0em 0px 0.5em -65px; +padding: 0px 0px 0px 65px; +} +pre code { +background-color: inherit; +display: block; +padding: 10px 10px 10px 0px; +overflow-x: inherit; +font-size: 100%; +} + +pre code[class] { +background-color: inherit; +} + +pre[class] code { +background-color: inherit; +} +tt, code, pre { +font-family: 'DejaVu Sans Mono', 'Droid Sans Mono', 'Lucida Console', Consolas, Monaco, monospace; +} +h1, h2, h3, h4, h5, h6 { +font-family: Helvetica, Arial, sans-serif; +margin: 1.2em 150px 0.6em 0em; + +padding-left: 65px; +text-indent: -65px; +} +h1.title { +color: #87b13f; +line-height: 1.1em; +margin-top: 25px; +border-bottom: 0px; +} +h1 { +line-height: 1.4em; +border-bottom: 1px #1a81c2 solid; +} +h1, h2, h3 { +color: #1a81c2; +} +h1 { +font-size: 18.0pt; +} +h2 { +font-size: 14.5pt; +} +h3, h4 { +font-size: 12pt; +} +span.header-section-number { +float: left; +width: 65px; +} + +p.author-name { +font-size: 14.5pt; +font-weight: bold; +font-style: italic; +text-align: left; +} +.date { +text-indent: 0px; +font-weight: bold; +} +.abstract, .package { +font-weight: bold; +} + +code { +background-color: #f0f0f0; +color: #404040; +font-size: 90%; +} + +.figure { +margin: 0em 0px 0.5em; +} +img { +max-width: 100%; +display: block; +padding: 0px 150px 0px 130px; +} +p > img { +padding-left: 65px; +padding-right: 0px; +} +td > img { +padding: 0px; +max-width: 100%; +display: inline; +} +img.smallfigure { +padding-left: 195px; +padding-right: 280px; +} +p > img.smallfigure { +padding-left: 130px; +padding-right: 130px; +} +img.widefigure { +padding-left: 65px; +padding-right: 85px; +margin-right: -65px; +} +p > img.widefigure { +padding-left: 0px; +padding-right: 0px; +margin-right: -65px; +} +p.caption, caption { +color: inherit; +font-size: 8pt; +} +p.caption { +padding-left: 130px; +padding-right: 85px; +margin-bottom: 20px; +} +caption { +padding: 0px; +margin-bottom: 10px; +min-width: 583; +} +span.caption-title { +color: #1a81c2; +font-weight: bold; +} +span.caption-label { +font-weight: bold; +} + +table { +margin-left: 130px; +margin-right: 85px; +} +.table { +max-width: 518px; +} + +dd { +margin-left: 65px; +margin-bottom: 10px; +} + +.code-folding-btn { +position: relative; +margin-top: -26px; +top: 26px; +} +.col-md-12 { +min-height: 0px; +} + +.sidenote { +float: right; +clear: right; +margin-right: -150px; +width: 130px; +margin-top: 0; +margin-bottom: 1rem; +font-size: 8pt; +line-height: 1.3; +vertical-align: baseline; +position: relative; +text-align: left; +} +.sidenote-number, .affil-mark { +position: relative; +vertical-align: super; +font-size: 7.5pt; +font-weight: normal; +font-style: normal; +line-height: normal; +} +input.margin-toggle { display: none; } +label.sidenote-number { display: inline; } +label.margin-toggle:not(.sidenote-number) { display: none; } + +code > span.kw { color: #E07020; } +code > span.dt { color: #404040; } +code > span.dv { color: #D02070; } +code > span.bn { color: #d14; } +code > span.fl { color: #D02070; } +code > span.ch { color: #40A040; } +code > span.st { color: #40A040; } +code > span.co { color: #808080; font-style: italic; } +code > span.ot { color: #2020F0; } +code > span.al { color: #ff0000; font-weight: bold; } +code > span.fu { color: #E07020; } +code > span.er { color: #FF0000; } +code > span.identifier { color: #404040; } +code > span.number { color: #D02070; } +code > span.string { color: #40A040; } +code > span.comment { color: #808080; font-style: italic; } +code > span.keyword { color: #2020F0; } +code > span.literal { color: #2020F0; } +code > span.operator { color: #000000;} +code > span.paren { color: #000000;} + +.js-plotly-plot .plotly { +padding-left: 65px; +} +</style> + + + +<style type="text/css"> +.main-container { + max-width: 828px; + margin-left: auto; + margin-right: auto; +} + +img { + max-width:100%; +} +.tabbed-pane { + padding-top: 12px; +} +.html-widget { + margin-bottom: 20px; +} +button.code-folding-btn:focus { + outline: none; +} +summary { + display: list-item; +} +</style> + + + +<!-- tabsets --> + +<style type="text/css"> +.tabset-dropdown > .nav-tabs { + display: inline-table; + max-height: 500px; + min-height: 44px; + overflow-y: auto; + background: white; + border: 1px solid #ddd; + border-radius: 4px; +} + +.tabset-dropdown > .nav-tabs > li.active:before { + content: ""; + font-family: 'Glyphicons Halflings'; + display: inline-block; + padding: 10px; + border-right: 1px solid #ddd; +} + +.tabset-dropdown > .nav-tabs.nav-tabs-open > li.active:before { + content: ""; + border: none; +} + +.tabset-dropdown > .nav-tabs.nav-tabs-open:before { + content: ""; + font-family: 'Glyphicons Halflings'; + display: inline-block; + padding: 10px; + border-right: 1px solid #ddd; +} + +.tabset-dropdown > .nav-tabs > li.active { + display: block; +} + +.tabset-dropdown > .nav-tabs > li > a, +.tabset-dropdown > .nav-tabs > li > a:focus, +.tabset-dropdown > .nav-tabs > li > a:hover { + border: none; + display: inline-block; + border-radius: 4px; + background-color: transparent; +} + +.tabset-dropdown > .nav-tabs.nav-tabs-open > li { + display: block; + float: none; +} + +.tabset-dropdown > .nav-tabs > li { + display: none; +} +</style> + +<!-- code folding --> + + + + +</head> + +<body> + + +<div class="container-fluid main-container"> + + + + +<div class="fluid-row" id="header"> + + + +<h1 class="title toc-ignore">Using multicrispr for gRNA design</h1> +<p class="author-name">Aditya M Bhagwat</p> +<h4 class="date">2020-04-23</h4> + +</div> + +<h1>Contents</h1> +<div id="TOC"> +<ul> +<li><a href="#background"><span class="toc-section-number">1</span> Background</a><ul> +<li><a href="#crisprcas9-and-prime-editing"><span class="toc-section-number">1.1</span> Crispr/Cas9 and Prime Editing</a></li> +<li><a href="#guide-rna-design"><span class="toc-section-number">1.2</span> Guide RNA design</a></li> +</ul></li> +<li><a href="#multicrispr"><span class="toc-section-number">2</span> Multicrispr</a><ul> +<li><a href="#install"><span class="toc-section-number">2.1</span> Install</a></li> +<li><a href="#define-targets"><span class="toc-section-number">2.2</span> Define targets</a></li> +<li><a href="#transform-targets"><span class="toc-section-number">2.3</span> Transform targets</a></li> +<li><a href="#find-spacers"><span class="toc-section-number">2.4</span> Find spacers</a></li> +<li><a href="#add-offtargets"><span class="toc-section-number">2.5</span> Add offtargets</a></li> +<li><a href="#add-efficiency"><span class="toc-section-number">2.6</span> Add efficiency</a></li> +<li><a href="#return-spacer-granges"><span class="toc-section-number">2.7</span> Return spacer GRanges</a></li> +</ul></li> +<li><a href="#references">References</a></li> +</ul> +</div> + +<!--  --> +<div id="background" class="section level1"> +<h1><span class="header-section-number">1</span> Background</h1> +<div id="crisprcas9-and-prime-editing" class="section level2"> +<h2><span class="header-section-number">1.1</span> Crispr/Cas9 and Prime Editing</h2> +<p><strong>Crispr/Cas9</strong> is a prokaryotic immune system turned into a genome engineering tool, with a Cas9/gRNA complex at the heart of its functioning. The <strong>gRNA</strong> (guide RNA) contains a 20 nucleotide (proto)<strong>spacer</strong> which guides the complex to a genomic locus with identical sequence, but only when followed by an <em>NGG</em> <strong>PAM</strong> (protospacer adjacent motif (see Figure 1A). The <strong>Cas9</strong> enzyme performs some effector action at that locus: <em>wildtype Cas9</em> cuts both strands after spacer nucleotide 17, <em>Cas9Nickase</em> cuts only a single strand (two variants exist, cutting respectively each of the strands), while catalytically dead <em>dCas9</em>, fused to some effector domain (KRAB, VPR, APEX) performs some alternative action (e.g. KRAB represses, VPR activates, APEX biotinylates).</p> +<p><strong>Prime Editing</strong> extends this further, by coupling Cas9 to a Reverse Transcriptase (RT). As shown in Figure 1, the guide RNA is extended with a 3’ extension that contains primer binding site (binding a complementary DNA region that acts as a primer for reverse transcription) and reverse transcription template (the template used for reverse transcription). The spacer still acts as targeting agent, guiding the Cas9/RT complex to targeted genomic locus.</p> +<div class="figure"><span id="fig:unnamed-chunk-2"></span> +<img src="" alt="gRNAs for Crispr/Cas9 (A) and Prime Editing" width="100%" class="smallfigure" /> +<p class="caption"> +Figure 1: <span class="caption-title">gRNAs for Crispr/Cas9 (A) and Prime Editing</span><br> +</p> +</div> +</div> +<div id="guide-rna-design" class="section level2"> +<h2><span class="header-section-number">1.2</span> Guide RNA design</h2> +<p><strong>Guide RNA design</strong> involves finding good guide RNAs to hit the targets of interest. Plasmids with guide RNA scaffolds, ready for cloning desired spacers into, can be readily ordered from AddGene. The actual task, therefore, boils down to finding good spacers for the targets of interest. For prime editing, it additionally involves finding appropriate primer binding site and reverse transcription template to edit the target site of interest.</p> +<p>A <strong>good spacer</strong> needs to fulfill two requirements.</p> +<ol style="list-style-type: decimal"> +<li><p><strong>Minimal off-target</strong> (mis)matches, so that only intended targets are hit.</p> +<ul> +<li>Crispr gRNAs can hit exact (with identical and alternate NGG pam), as well as (up-to 2) mismatch offtargets.</li> +<li>Prime Editing is much more specific, hitting only exact offtargets.</li> +</ul></li> +<li><p><strong>Maximal on-target</strong> efficiency. Over the years, several sequence-to-efficiency prediction models have been developed, of which the Doench 2016 score has currently become the community standard. The score is not perfect, and examples can be found where the prediction and the actual outcome differ. Yet, to-date it is the best heuristic to predict on-target efficiency, worth making use of.</p></li> +</ol> +</div> +</div> +<div id="multicrispr" class="section level1"> +<h1><span class="header-section-number">2</span> Multicrispr</h1> +<p>Multicrispr was developed to make guide RNA design easier. As shown below, it contains functions to <strong>define</strong> and <strong>transform</strong> targets, <strong>find spacers</strong>, compute/add <strong>offtarget counts</strong> and <strong>efficiency scores</strong> (Doench 2016), and finally return all of this as a <strong>GRanges</strong> object.</p> +<p><img src="" width="80%" class="widefigure" /></p> +<div id="install" class="section level2"> +<h2><span class="header-section-number">2.1</span> Install</h2> +<p>Installing <strong>multicrispr</strong> is simple:</p> +<pre class="r"><code>url <- 'https://gitlab.gwdg.de/loosolab/software/multicrispr.git' +remotes::install_git(url, repos = BiocManager::repositories())</code></pre> +<p>Doench et al. (2016) ’s python package <strong>azimuth</strong> for on-target efficiency prediction using their method can be easily installed and activated using reticulate:</p> +<pre class="r"><code># Install - run R(Studio) with admin privileges for this to work! + reticulate::conda_create('azienv', 'python=2.7') + reticulate::conda_install('azienv', 'azimuth', pip = TRUE) + reticulate::conda_install('azienv', 'scikit-learn==0.17.1', pip = TRUE)</code></pre> +<pre class="r"><code># Activate + reticulate::use_condaenv('azienv')</code></pre> +<p>Bowtie-indexed genomes for quick offtarget analysis can be installed using <code>index_genome</code>. For the two genomes used in the examples, mm10 and hg38, the functions downloads pre-build indexes from our data server, allowing a quick exploration (set <code>download=FALSE</code> to build index anew):</p> +<pre class="r"><code>index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) +index_genome(BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 )</code></pre> +<!-- 1. Install conda for python 2.7 --> +<!-- 2. Create a new conda environment: `conda create --name azimuthenv python=2.7` --> +<!-- 3. Activate conda environment: `conda activate azimuthenv` --> +<!-- 4. Install module azimuth: `pip install azimuth` --> +<!-- 5. Install scikit-learn: `pip install scikit-learn==0.17.1` --> +</div> +<div id="define-targets" class="section level2"> +<h2><span class="header-section-number">2.2</span> Define targets</h2> +<p><img src="" width="70%" class="smallfigure" /></p> +<p><code>bed_to_granges</code> converts a (0-based) BED coordinate file into a (1-based) GRanges.<br /> +An example is loading the 1974 binding sites of the transcription factor SRF:</p> +<pre class="r"><code>require(magrittr) +require(multicrispr) +bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +tfbs0 <- bed_to_granges(bedfile, genome = 'mm10') +## Read SRF.bed into GRanges +## 1974 ranges on 21 chromosomes</code></pre> +<p><img src="" width="100%" /></p> +<p><code>genes_to_granges</code> and <code>genefile_to_granges</code> convert entrez/ensembl gene identifiers into GRanges using <code>txdb</code> gene models. +An example that loads of a small subset of the 1974 SRF binding sites:</p> +<pre class="r"><code>require(multicrispr) +entrezfile <- system.file('extdata/SRF.entrez', package = 'multicrispr') +txdb <- TxDb.Mmusculus.UCSC.mm10.knownGene::TxDb.Mmusculus.UCSC.mm10.knownGene +sometfbs0 <- genefile_to_granges(entrezfile, txdb, complement = TRUE) +## Convert 10 genes to 10 GRanges +## 20 ranges after adding inverse strands</code></pre> +<p><img src="" width="100%" /></p> +<p><code>char_to_granges</code> uses a 1-based coordinate vector to specify the GRanges.<br /> +It can be used to define four prime editing sites mentioned by Anzalone et al. (2019):</p> +<pre class="r"><code># char_to_granges: Anzalone et al. (2019) prime editing targets +bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +pe0 <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) +plot_intervals(pe0)</code></pre> +<p><img src="" width="336" /></p> +</div> +<div id="transform-targets" class="section level2"> +<h2><span class="header-section-number">2.3</span> Transform targets</h2> +<p><img src="" width="70%" class="smallfigure" /></p> +<p>As a second step, the original targets may require transformation. The functions <code>extend</code>, <code>up_flank</code> (upstream flanks), <code>down_flank</code> (downstream flanks), and <code>double_flank</code> (double flanks) can be used to update the target ranges as required.</p> +<pre class="r"><code># Extend +targets <- pe0 +invisible(extend(targets, -22, 22, plot = TRUE))</code></pre> +<p><img src="" width="65%" /></p> +<pre class="r"><code># Up flank +invisible(up_flank( targets, -200, -1, plot = TRUE))</code></pre> +<p><img src="" width="65%" /></p> +<pre class="r"><code># Down flank +invisible(down_flank( targets, 1, 200, plot = TRUE))</code></pre> +<p><img src="" width="65%" /></p> +<pre class="r"><code># Double flank +invisible(double_flank(targets, -200, -1, +1, +200, plot = TRUE)) +## 2 flank ranges: 1 up + 1 down</code></pre> +<p><img src="" width="65%" /></p> +</div> +<div id="find-spacers" class="section level2"> +<h2><span class="header-section-number">2.4</span> Find spacers</h2> +<p><img src="" width="70%" class="smallfigure" /></p> +<p>The next step is to find N20 spacers followed by NGG pam sites. +This can be done with <code>find_spacers</code>, after extending target range(s) to prime editing neighbourhood(s):</p> +<pre class="r"><code>bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +neighbourhood <- extend_for_pe(targets, bsgenome) +spacers <- find_spacers(neighbourhood, bsgenome, complement = FALSE)</code></pre> +<p><img src="" width="288" /></p> +<p>For prime editing, however, it is better to use <code>find_pe_spacers</code>, which performs target to neighbourhood extension implicitly, and also adds 3’ extension (Fig 1) to returned spacer GRanges.</p> +<pre class="r"><code>spacers <- find_pe_spacers(targets, bsgenome=bsgenome) </code></pre> +<p><img src="" width="316.8" /></p> +<p>This finds prime editing sites that follow Anzalone et al. (2019)’s recommended default settings: a 13-nucleotide primer and a 16-nucleotide reverse transcription template. These settings can be easily altered (e.g. Anzalone et al. report success with reverse transcription templates of up to 48 nucleotides) by:</p> +<pre class="r"><code>spacers <- find_pe_spacers(targets, bsgenome=bsgenome, nrt = 48) </code></pre> +<p><img src="" width="345.6" /></p> +</div> +<div id="add-offtargets" class="section level2"> +<h2><span class="header-section-number">2.5</span> Add offtargets</h2> +<p><img src="" width="70%" class="smallfigure" /></p> +<pre class="r"><code>if (has_been_indexed(bsgenome)){ + spacers %<>% add_offtargets(bsgenome, mismatch = 0, plot = TRUE) +} +## Add genome counts +## Expand iupac ambiguities in pam +## Write reads to ~/multicrisprout/spacers.fa +## Map reads: ~/multicrisprout/spacers/spacers_to_BSgenome.Hsapiens.UCSC.hg38.txt +## Load results +## Count matches +## Calculate offtargets for 6 spacers</code></pre> +<p><img src="" width="345.6" /></p> +</div> +<div id="add-efficiency" class="section level2"> +<h2><span class="header-section-number">2.6</span> Add efficiency</h2> +<p><img src="" width="70%" class="smallfigure" /></p> +<p>Not all N<sub>20</sub>NGG gRNA sequences target equally well (even when matching sequence perfectly). For each position in the 23-bp gRNA sequence, the nucleotide present in current, previous and next position has an effect on targeting efficiency. The current community standard for on-target efficiency prediction is that of Doench et al. (2016), which can be computed and added with <code>add_efficiency</code>:</p> +<pre class="r"><code>if (reticulate::py_module_available('azimuth')){ + spacers %<>% add_efficiency(bsgenome, 'Doench2016') +} +## Score crispr spacers +## Add (4-23-3) contextseqs +## Score contextseqs with Doench2016 (azimuth) +## Run Doench2016 1 times on 10000-seq chunks to preserve memory +## No model file specified, using V3_model_nopos +## Completed in 1.2 secs</code></pre> +<p><img src="" width="345.6" /></p> +</div> +<div id="return-spacer-granges" class="section level2"> +<h2><span class="header-section-number">2.7</span> Return spacer GRanges</h2> +<pre class="r"><code> spacers +## GRanges object with 6 ranges and 14 metadata columns: +## seqnames ranges strand | crisprcontext +## <Rle> <IRanges> <Rle> | <character> +## HBB_1 chr11 5226958-5226977 + | TCATCCACGTTCACCTTGCCCCACAGGGCA +## HBB_2 chr11 5226959-5226978 + | CATCCACGTTCACCTTGCCCCACAGGGCAG +## HBB_3 chr11 5226968-5226987 + | TCACCTTGCCCCACAGGGCAGTAACGGCAG +## HBB_4 chr11 5227003-5227022 - | ACACCATGGTGCATCTGACTCCTGAGGAGA +## HBB_5 chr11 5226984-5227003 + | GGCAGTAACGGCAGACTTCTCCTCAGGAGT +## HBB_6 chr11 5227021-5227040 - | ACTAGCAACCTCAAACAGACACCATGGTGC +## targetname targetstart targetend crisprname crisprspacer +## <character> <integer> <integer> <character> <character> +## HBB_1 HBB 5227002 5227002 HBB_1 CCACGTTCACCTTGCCCCAC +## HBB_2 HBB 5227002 5227002 HBB_2 CACGTTCACCTTGCCCCACA +## HBB_3 HBB 5227002 5227002 HBB_3 CTTGCCCCACAGGGCAGTAA +## HBB_4 HBB 5227002 5227002 HBB_4 CATGGTGCATCTGACTCCTG +## HBB_5 HBB 5227002 5227002 HBB_5 GTAACGGCAGACTTCTCCTC +## HBB_6 HBB 5227002 5227002 HBB_6 GCAACCTCAAACAGACACCA +## crisprpam primer +## <character> <character> +## HBB_1 AGG GTTCACCTTGCCC +## HBB_2 GGG TTCACCTTGCCCC +## HBB_3 CGG CCCCACAGGGCAG +## HBB_4 AGG GTGCATCTGACTC +## HBB_5 AGG CGGCAGACTTCTC +## HBB_6 TGG CCTCAAACAGACA +## revtranscript +## <character> +## HBB_1 CACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATG +## HBB_2 ACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATGG +## HBB_3 TAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATGGTGTCTGTTT +## HBB_4 CTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGGCAAGGTGAACGTGG +## HBB_5 CTCAGGAGTCAGATGCACCATGGTGTCTGTTTGAGGTTGCTAGTGAAC +## HBB_6 CCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGT +## extension G0 +## <character> <integer> +## HBB_1 CATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGGCAAGGTGAAC 1 +## HBB_2 CCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGGCAAGGTGAA 1 +## HBB_3 AAACAGACACCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCGTTACTGCCCTGTGGGG 1 +## HBB_4 CCACGTTCACCTTGCCCCACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCAC 2 +## HBB_5 GTTCACTAGCAACCTCAAACAGACACCATGGTGCATCTGACTCCTGAGGAGAAGTCTGCCG 1 +## HBB_6 ACAGGGCAGTAACGGCAGACTTCTCCTCAGGAGTCAGATGCACCATGGTGTCTGTTTGAGG 2 +## off off0 Doench2016 +## <numeric> <numeric> <numeric> +## HBB_1 0 0 0.462600534483403 +## HBB_2 0 0 0.611140169152868 +## HBB_3 0 0 0.485226524206282 +## HBB_4 1 1 0.666241339730174 +## HBB_5 0 0 0.517610901468318 +## HBB_6 1 1 0.68921726226521 +## ------- +## seqinfo: 455 sequences (1 circular) from hg38 genome</code></pre> +</div> +</div> +<div id="references" class="section level1 unnumbered"> +<h1>References</h1> +<p>Anzalone, A.V., Randolph, P.B., Davis, J.R. et al. Search-and-replace genome editing without double-strand breaks or donor DNA. Nature 576, 149–157 (2019). <a href="https://doi.org/10.1038/s41586-019-1711-4" class="uri">https://doi.org/10.1038/s41586-019-1711-4</a></p> +<p>Doench et al. (2016). Optimized sgRNA design to maximize activity and minimize off-target effects of CRISPR-Cas9. Nature Biotechnology, 34(7), <a href="doi:10.1038/nbt.3437" class="uri">doi:10.1038/nbt.3437</a></p> +</div> + + + + +</div> + +<script> + +// add bootstrap table styles to pandoc tables +function bootstrapStylePandocTables() { + $('tr.header').parent('thead').parent('table').addClass('table table-condensed'); +} +$(document).ready(function () { + bootstrapStylePandocTables(); +}); + + +</script> + +<!-- tabsets --> + +<script> +$(document).ready(function () { + window.buildTabsets("TOC"); +}); + +$(document).ready(function () { + $('.tabset-dropdown > .nav-tabs > li').click(function () { + $(this).parent().toggleClass('nav-tabs-open') + }); +}); +</script> + +<!-- code folding --> + + +<script type="text/x-mathjax-config"> + MathJax.Hub.Config({ + "HTML-CSS": { + styles: { + ".MathJax_Display": { + "text-align": "center", + padding: "0px 150px 0px 65px", + margin: "0px 0px 0.5em" + }, + } + } + }); +</script> +<!-- dynamically load mathjax for compatibility with self-contained --> +<script> + (function () { + var script = document.createElement("script"); + script.type = "text/javascript"; + script.src = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML"; + document.getElementsByTagName("head")[0].appendChild(script); + })(); +</script> + +</body> +</html> diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-10-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-10-1.png index ed429de9e83776691cb8fbfab84ac5b3b4c1be22..82a5112650f24bc5e8b21578e5c10d27480e1878 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-10-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-10-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-11-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-11-1.png index 2266ec280fe82757c30e5db092390ba3dd9fbe7c..75faf2c27c49351f5cf1c7af2fa0a949095b27c0 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-11-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-11-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-12-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-12-1.png index 4558e4ae38c368898376816fd69bf134a660b407..3e4498be6b66b681ceed4864c913573254b6fc7d 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-12-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-12-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-1.png index 8cd7ab5ee66ba40abcdc5ea8934b0cc4d555f477..8bb93e21848adf18ba163c3a479996c582b2c857 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-2.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-2.png index 67297c9795b716464805d50179ab93b966377a9b..fcdafd3a8e0191d62ac051002f351d8b4967b219 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-2.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-2.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-3.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-3.png index 07ea59409fe894341ec130709a4faae54dcdad4e..0a74471a710bc98b14af7ed50422bdbe2642ff48 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-3.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-3.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-4.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-4.png index 9b48a739b20af2861710f107fc13a24de1e14c02..42d899f63c528f9d8321be869ec8f65248b38de2 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-4.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-13-4.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-15-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-15-1.png index 4b8a2b03713fa453dc8377873beaad13c0279d4e..2d9374c61343c09777c3d13b381eb48527b7f70d 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-15-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-15-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-16-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-16-1.png index 212a2722854da8ed75c8e243e90cd97c79b93a35..c39769fd347f1ffa8905fabae829c3dfca625573 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-16-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-16-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-17-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-17-1.png index f61a5ae350b11ded660563f36d297e14a289dfa2..8678eb0e43539d19f2bdb77e98634db8d6411e1f 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-17-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-17-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-19-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-19-1.png index 5d89a5b05d2473f1e295705b6959e02fa3d5e3d3..1e800ca4da786bdc9a07c51c25a9c2ac11c8cbae 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-19-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-19-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-21-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-21-1.png index 73a9e53b4788f5554295e7d0a1e946bb3efabff2..aecfa24983df697863a60dd77f1ebadfacb66688 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-21-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-21-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-6-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-6-1.png index c3820baf6dba6b9dc2faed753d81a91eeb50c501..657860428f5e146078c627f84f042cfc7013af5c 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-6-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-6-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-7-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-7-1.png index 25f9288c91d94999a0239567f5d2e46b8532ddfb..9d4a111aba52abaac62a05d6fd8ca45c210616b4 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-7-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-7-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-8-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-8-1.png index 16c6a8c9f64eabcae223ef9eb4d1656cd3e62e49..0879f481a3ef9f6d2eb921b6545db79ca15434c5 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-8-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-8-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-1.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-1.png index ab87411df8a8b1fa3081cb1c993637c7feec2e0a..6560f7059deb6358ea9533b2868136496366dcc3 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-1.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-1.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-2.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-2.png index f6f3b82a440a99e6220afa147a37c9beb5b41a1f..1b5ada938144d6f9eb21f5dc2dfb61373558d6e3 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-2.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-2.png differ diff --git a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-3.png b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-3.png index b176ae69e807f63f1951ff0b66bdbc489417274b..ac1e4dedbd4d5deb35101d123ec227a89162af26 100644 Binary files a/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-3.png and b/public/articles/designing_grna_libraries_files/figure-html/unnamed-chunk-9-3.png differ diff --git a/public/articles/index.html b/public/articles/index.html index cc38d29e2266cb70566ad5a0a4b997ea4fa80800..c21ba053ad6c23f33069c585b95402ad285f1a40 100644 --- a/public/articles/index.html +++ b/public/articles/index.html @@ -1,146 +1,146 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Articles • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Articles" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-article-index"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Articles</h1> - </div> - - <div class="section "> - <h3>All vignettes</h3> - <p class="section-desc"></p> - - <ul> - <li><a href="designing_grna_libraries.html">Using multicrispr for gRNA design</a></li> - </ul> - </div> - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Articles • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Articles" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-article-index"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Articles</h1> + </div> + + <div class="section "> + <h3>All vignettes</h3> + <p class="section-desc"></p> + + <ul> + <li><a href="designing_grna_libraries.html">Using multicrispr for gRNA design</a></li> + </ul> + </div> + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/authors.html b/public/authors.html index 04794c9990e4fab46f1a89b12fb012097864827d..8516951200035ee82068a42ea342b8a0707a0957 100644 --- a/public/authors.html +++ b/public/authors.html @@ -1,171 +1,171 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Authors • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="pkgdown.css" rel="stylesheet"> -<script src="pkgdown.js"></script> - - - - -<meta property="og:title" content="Authors" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-authors"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="contents col-md-9"> - <div class="page-header"> - <h1>Authors</h1> - </div> - - <ul class="list-unstyled"> - <li> - <p><strong>Aditya Bhagwat</strong>. Author, maintainer. - </p> - </li> - <li> - <p><strong>Johannes Graumann</strong>. Scientific advisor. - </p> - </li> - <li> - <p><strong>Mette Bentsen</strong>. Contributor. - </p> - </li> - <li> - <p><strong>Jens Preussner</strong>. Contributor. - </p> - </li> - <li> - <p><strong>Michael Lawrence</strong>. Contributor. - </p> - </li> - <li> - <p><strong>Herve Pages</strong>. Contributor. - </p> - </li> - <li> - <p><strong>Mario Looso</strong>. Scientific advisor, research team head. - </p> - </li> - </ul> - - </div> - -</div> - - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Authors • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="pkgdown.css" rel="stylesheet"> +<script src="pkgdown.js"></script> + + + + +<meta property="og:title" content="Authors" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-authors"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="contents col-md-9"> + <div class="page-header"> + <h1>Authors</h1> + </div> + + <ul class="list-unstyled"> + <li> + <p><strong>Aditya Bhagwat</strong>. Author, maintainer. + </p> + </li> + <li> + <p><strong>Johannes Graumann</strong>. Scientific advisor. + </p> + </li> + <li> + <p><strong>Mette Bentsen</strong>. Contributor. + </p> + </li> + <li> + <p><strong>Jens Preussner</strong>. Contributor. + </p> + </li> + <li> + <p><strong>Michael Lawrence</strong>. Contributor. + </p> + </li> + <li> + <p><strong>Herve Pages</strong>. Contributor. + </p> + </li> + <li> + <p><strong>Mario Looso</strong>. Scientific advisor, research team head. + </p> + </li> + </ul> + + </div> + +</div> + + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/index.html b/public/index.html index ba91c842f919893944ac586eba0c5bf523b24770..b0a4f3c6d50ea9915c692b5e9f776e8ea96b941c 100644 --- a/public/index.html +++ b/public/index.html @@ -13,119 +13,119 @@ <script src="pkgdown.js"></script><meta property="og:title" content="Multi-locus multi-purpose Crispr/Cas design"> <meta property="og:description" content="Contains functions to facilitate the design of a multi-locus Crispr/Cas library."> <meta name="twitter:card" content="summary"> -<!-- mathjax --><script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script><!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<!-- mathjax --><script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script><!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> <![endif]--> </head> -<body> - <div class="container template-home"> - <header><div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> +<body> + <div class="container template-home"> + <header><div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> <ul class="nav navbar-nav"> -<li> - <a href="index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> +<li> + <a href="index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> <ul class="dropdown-menu" role="menu"> -<li> - <a href="articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> +<li> + <a href="articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> </ul> -</li> +</li> </ul> <ul class="nav navbar-nav navbar-right"></ul> </div> -<!--/.nav-collapse --> +<!--/.nav-collapse --> </div> -<!--/.container --> +<!--/.container --> </div> -<!--/.navbar --> - - - - </header><div class="row"> - <div class="contents col-md-9"> - -<center> <div class="page-header"><h1> multicrispr </h1></div> </center> -<p><img src="inst/extdata/readme_portrait.png"></p> -<div id="installation" class="section level3"> -<h3 class="hasAnchor"> -<a href="#installation" class="anchor"></a>Installation</h3> -<div class="sourceCode" id="cb1"><pre class="sourceCode R"><code class="sourceCode r"><a class="sourceLine" id="cb1-1" title="1"><span class="co"># Install multicrispr</span></a> -<a class="sourceLine" id="cb1-2" title="2"> remotes<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/remotes/man/install_git.html">install_git</a></span>(<span class="st">'https://gitlab.gwdg.de/loosolab/software/multicrispr.git'</span>, </a> -<a class="sourceLine" id="cb1-3" title="3"> <span class="dt">repos =</span> BiocManager<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/BiocManager/man/repositories.html">repositories</a></span>())</a> -<a class="sourceLine" id="cb1-4" title="4"><span class="co"># Install azimuth</span></a> -<a class="sourceLine" id="cb1-5" title="5"> <span class="kw"><a href="https://rdrr.io/r/utils/install.packages.html">install.packages</a></span>(<span class="st">'reticulate'</span>)</a> -<a class="sourceLine" id="cb1-6" title="6"> reticulate<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/reticulate/man/conda-tools.html">conda_create</a></span>(<span class="st">'azienv'</span>, <span class="kw"><a href="https://rdrr.io/r/base/c.html">c</a></span>(<span class="st">'python=2.7'</span>))</a> -<a class="sourceLine" id="cb1-7" title="7"> reticulate<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/reticulate/man/use_python.html">use_condaenv</a></span>(<span class="st">'azienv'</span>)</a> -<a class="sourceLine" id="cb1-8" title="8"> reticulate<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/reticulate/man/py_install.html">py_install</a></span>(<span class="kw"><a href="https://rdrr.io/r/base/c.html">c</a></span>(<span class="st">'azimuth'</span>, <span class="st">'scikit-learn==0.17.1'</span>), <span class="st">'azienv'</span>, <span class="dt">pip =</span> <span class="ot">TRUE</span>)</a> -<a class="sourceLine" id="cb1-9" title="9"><span class="co"># Index mm10 and hg38</span></a> -<a class="sourceLine" id="cb1-10" title="10"> BiocManager<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/BiocManager/man/install.html">install</a></span>(<span class="st">'BSgenome.Mmusculus.UCSC.mm10'</span>)</a> -<a class="sourceLine" id="cb1-11" title="11"> BiocManager<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/BiocManager/man/install.html">install</a></span>(<span class="st">'BSgenome.Hsapiens.UCSC.hg38'</span>)</a> -<a class="sourceLine" id="cb1-12" title="12"> <span class="kw"><a href="reference/index_genome.html">index_genome</a></span>(BSgenome.Mmusculus.UCSC.mm10<span class="op">::</span>BSgenome.Mmusculus.UCSC.mm10)</a> -<a class="sourceLine" id="cb1-13" title="13"> <span class="kw"><a href="reference/index_genome.html">index_genome</a></span>(BSgenome.Hsapiens.UCSC.hg38<span class="op">::</span>BSgenome.Hsapiens.UCSC.hg38)</a></code></pre></div> -</div> - - </div> - - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <div class="license"> -<h2>License</h2> +<!--/.navbar --> + + + + </header><div class="row"> + <div class="contents col-md-9"> + +<center> <div class="page-header"><h1> multicrispr </h1></div> </center> +<p><img src="inst/extdata/readme_portrait.png"></p> +<div id="installation" class="section level3"> +<h3 class="hasAnchor"> +<a href="#installation" class="anchor"></a>Installation</h3> +<div class="sourceCode" id="cb1"><pre class="sourceCode R"><code class="sourceCode r"><a class="sourceLine" id="cb1-1" title="1"><span class="co"># Install multicrispr</span></a> +<a class="sourceLine" id="cb1-2" title="2"> remotes<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/remotes/man/install_git.html">install_git</a></span>(<span class="st">'https://gitlab.gwdg.de/loosolab/software/multicrispr.git'</span>, </a> +<a class="sourceLine" id="cb1-3" title="3"> <span class="dt">repos =</span> BiocManager<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/BiocManager/man/repositories.html">repositories</a></span>())</a> +<a class="sourceLine" id="cb1-4" title="4"><span class="co"># Install azimuth</span></a> +<a class="sourceLine" id="cb1-5" title="5"> <span class="kw"><a href="https://rdrr.io/r/utils/install.packages.html">install.packages</a></span>(<span class="st">'reticulate'</span>)</a> +<a class="sourceLine" id="cb1-6" title="6"> reticulate<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/reticulate/man/conda-tools.html">conda_create</a></span>(<span class="st">'azienv'</span>, <span class="kw"><a href="https://rdrr.io/r/base/c.html">c</a></span>(<span class="st">'python=2.7'</span>))</a> +<a class="sourceLine" id="cb1-7" title="7"> reticulate<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/reticulate/man/use_python.html">use_condaenv</a></span>(<span class="st">'azienv'</span>)</a> +<a class="sourceLine" id="cb1-8" title="8"> reticulate<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/reticulate/man/py_install.html">py_install</a></span>(<span class="kw"><a href="https://rdrr.io/r/base/c.html">c</a></span>(<span class="st">'azimuth'</span>, <span class="st">'scikit-learn==0.17.1'</span>), <span class="st">'azienv'</span>, <span class="dt">pip =</span> <span class="ot">TRUE</span>)</a> +<a class="sourceLine" id="cb1-9" title="9"><span class="co"># Index mm10 and hg38</span></a> +<a class="sourceLine" id="cb1-10" title="10"> BiocManager<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/BiocManager/man/install.html">install</a></span>(<span class="st">'BSgenome.Mmusculus.UCSC.mm10'</span>)</a> +<a class="sourceLine" id="cb1-11" title="11"> BiocManager<span class="op">::</span><span class="kw"><a href="https://rdrr.io/pkg/BiocManager/man/install.html">install</a></span>(<span class="st">'BSgenome.Hsapiens.UCSC.hg38'</span>)</a> +<a class="sourceLine" id="cb1-12" title="12"> <span class="kw"><a href="reference/index_genome.html">index_genome</a></span>(BSgenome.Mmusculus.UCSC.mm10<span class="op">::</span>BSgenome.Mmusculus.UCSC.mm10)</a> +<a class="sourceLine" id="cb1-13" title="13"> <span class="kw"><a href="reference/index_genome.html">index_genome</a></span>(BSgenome.Hsapiens.UCSC.hg38<span class="op">::</span>BSgenome.Hsapiens.UCSC.hg38)</a></code></pre></div> +</div> + + </div> + + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <div class="license"> +<h2>License</h2> <ul class="list-unstyled"> -<li>GPL</li> +<li>GPL</li> </ul> -</div> -<div class="developers"> -<h2>Developers</h2> +</div> +<div class="developers"> +<h2>Developers</h2> <ul class="list-unstyled"> -<li>Aditya Bhagwat <br><small class="roles"> Author, maintainer </small> </li> -<li><a href="authors.html">All authors...</a></li> +<li>Aditya Bhagwat <br><small class="roles"> Author, maintainer </small> </li> +<li><a href="authors.html">All authors...</a></li> </ul> -</div> - - </div> -</div> - - - <footer><div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - +</div> + + </div> +</div> + + + <footer><div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + </footer> -</div> - - - - +</div> + + + + </body> </html> diff --git a/public/inst/extdata/01_define_targets.png b/public/inst/extdata/01_define_targets.png index 062db963d5453ee3e985082a798d7c22b532de4b..41b1209e34340effb1040841fa717ce1fd8b0263 100644 Binary files a/public/inst/extdata/01_define_targets.png and b/public/inst/extdata/01_define_targets.png differ diff --git a/public/inst/extdata/02_transform.png b/public/inst/extdata/02_transform.png index 5db5e3e8b70b6dcd24d5f3067af7e5a57886b899..627a91b0553f3d497033412131e69487677c1ed5 100644 Binary files a/public/inst/extdata/02_transform.png and b/public/inst/extdata/02_transform.png differ diff --git a/public/inst/extdata/03_find.png b/public/inst/extdata/03_find.png index bfc9e0af82590bb2f3bc5ae56aab7648be91634d..e71a4b9244b8561bfc8b46e07988848a34ace12f 100644 Binary files a/public/inst/extdata/03_find.png and b/public/inst/extdata/03_find.png differ diff --git a/public/inst/extdata/04_offtargets.png b/public/inst/extdata/04_offtargets.png index 63fdd2f707d370b5b890a602da3c5787ffb4aee8..c89eeff2f3fcc03040c6033ce7c1c65b94182ed4 100644 Binary files a/public/inst/extdata/04_offtargets.png and b/public/inst/extdata/04_offtargets.png differ diff --git a/public/inst/extdata/05_efficiency.png b/public/inst/extdata/05_efficiency.png index c0002c07c42a6c321d8c2487db28074bd9598cf7..1c4d327c67d31490e8f0055cd9eb5f11a3b2756f 100644 Binary files a/public/inst/extdata/05_efficiency.png and b/public/inst/extdata/05_efficiency.png differ diff --git a/public/inst/extdata/pe.png b/public/inst/extdata/pe.png index 4bc9bb3da80fd432d498ef3d738842f0aa8f0880..3d413015a9933f683bb0d0df5f770057c7bd5b0a 100644 Binary files a/public/inst/extdata/pe.png and b/public/inst/extdata/pe.png differ diff --git a/public/inst/extdata/readme_portrait.png b/public/inst/extdata/readme_portrait.png index 34a09e1c65feb87d50cd41ed745b67ac07dbaff7..96c4cd26606f3d0afed6487dbbddbdb9189a6021 100644 Binary files a/public/inst/extdata/readme_portrait.png and b/public/inst/extdata/readme_portrait.png differ diff --git a/public/pkgdown.yml b/public/pkgdown.yml index ac692088d2839aff312fca63e8f2679449e23f54..5b25a3211cbe2f648cb78aaa24c613ff8d49a248 100644 --- a/public/pkgdown.yml +++ b/public/pkgdown.yml @@ -1,6 +1,6 @@ -pandoc: 2.7.2 -pkgdown: 1.4.1 -pkgdown_sha: ~ -articles: - designing_grna_libraries: designing_grna_libraries.html - +pandoc: 2.7.2 +pkgdown: 1.4.1 +pkgdown_sha: ~ +articles: + designing_grna_libraries: designing_grna_libraries.html + diff --git a/public/reference/EnsDb.Hsapiens.v99.html b/public/reference/EnsDb.Hsapiens.v99.html index a07c3b51a6577bcbe7cb2f699a337d3c15b585e8..38497b92701e0476720bd6f9973f81a5cd47528b 100644 --- a/public/reference/EnsDb.Hsapiens.v99.html +++ b/public/reference/EnsDb.Hsapiens.v99.html @@ -1,179 +1,179 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Get EnsDb.Hsapiens.v98 from AnnotationHub — EnsDb.Hsapiens.v99 • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Get EnsDb.Hsapiens.v98 from AnnotationHub — EnsDb.Hsapiens.v99" /> -<meta property="og:description" content="Get EnsDb.Hsapiens.v98 from AnnotationHub" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Get EnsDb.Hsapiens.v98 from AnnotationHub</h1> - - <div class="hidden name"><code>EnsDb.Hsapiens.v99.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Get EnsDb.Hsapiens.v98 from AnnotationHub</p> - </div> - - <pre class="usage"><span class='fu'>EnsDb.Hsapiens.v99</span>()</pre> - - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/ensembldb/man/EnsDb-class.html'>EnsDb-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'>EnsDb.Hsapiens.v99</span>()</div><div class='output co'>#> <span class='message'>snapshotDate(): 2019-10-29</span></div><div class='output co'>#> <span class='message'>loading from cache</span></div><div class='output co'>#> <span class='message'>require("ensembldb")</span></div><div class='output co'>#> EnsDb for Ensembl: -#> |Backend: SQLite -#> |Db type: EnsDb -#> |Type of Gene ID: Ensembl Gene ID -#> |Supporting package: ensembldb -#> |Db created by: ensembldb package from Bioconductor -#> |script_version: 0.3.5 -#> |Creation time: Mon Feb 3 13:20:00 2020 -#> |ensembl_version: 99 -#> |ensembl_host: localhost -#> |Organism: Homo sapiens -#> |taxonomy_id: 9606 -#> |genome_build: GRCh38 -#> |DBSCHEMAVERSION: 2.1 -#> | No. of genes: 67998. -#> | No. of transcripts: 250641. -#> |Protein data available.</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Get EnsDb.Hsapiens.v98 from AnnotationHub — EnsDb.Hsapiens.v99 • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Get EnsDb.Hsapiens.v98 from AnnotationHub — EnsDb.Hsapiens.v99" /> +<meta property="og:description" content="Get EnsDb.Hsapiens.v98 from AnnotationHub" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Get EnsDb.Hsapiens.v98 from AnnotationHub</h1> + + <div class="hidden name"><code>EnsDb.Hsapiens.v99.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Get EnsDb.Hsapiens.v98 from AnnotationHub</p> + </div> + + <pre class="usage"><span class='fu'>EnsDb.Hsapiens.v99</span>()</pre> + + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/ensembldb/man/EnsDb-class.html'>EnsDb-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'>EnsDb.Hsapiens.v99</span>()</div><div class='output co'>#> <span class='message'>snapshotDate(): 2019-10-29</span></div><div class='output co'>#> <span class='message'>loading from cache</span></div><div class='output co'>#> <span class='message'>require("ensembldb")</span></div><div class='output co'>#> EnsDb for Ensembl: +#> |Backend: SQLite +#> |Db type: EnsDb +#> |Type of Gene ID: Ensembl Gene ID +#> |Supporting package: ensembldb +#> |Db created by: ensembldb package from Bioconductor +#> |script_version: 0.3.5 +#> |Creation time: Mon Feb 3 13:20:00 2020 +#> |ensembl_version: 99 +#> |ensembl_host: localhost +#> |Organism: Homo sapiens +#> |taxonomy_id: 9606 +#> |genome_build: GRCh38 +#> |DBSCHEMAVERSION: 2.1 +#> | No. of genes: 67998. +#> | No. of transcripts: 250641. +#> |Protein data available.</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/EnsDb.Mmusculus.v98.html b/public/reference/EnsDb.Mmusculus.v98.html index c6d4cb0b25653dc155193ec82da7dc3bfd5d99d4..65d60e74afb3bce853c2ffa0e8dc2ef09adbb45e 100644 --- a/public/reference/EnsDb.Mmusculus.v98.html +++ b/public/reference/EnsDb.Mmusculus.v98.html @@ -1,179 +1,179 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Get EnsDb.Mmusculus.v98 from AnnotationHub — EnsDb.Mmusculus.v98 • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Get EnsDb.Mmusculus.v98 from AnnotationHub — EnsDb.Mmusculus.v98" /> -<meta property="og:description" content="Get EnsDb.Mmusculus.v98 from AnnotationHub" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Get EnsDb.Mmusculus.v98 from AnnotationHub</h1> - - <div class="hidden name"><code>EnsDb.Mmusculus.v98.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Get EnsDb.Mmusculus.v98 from AnnotationHub</p> - </div> - - <pre class="usage"><span class='fu'>EnsDb.Mmusculus.v98</span>()</pre> - - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/ensembldb/man/EnsDb-class.html'>EnsDb-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'>EnsDb.Mmusculus.v98</span>()</div><div class='output co'>#> <span class='message'>snapshotDate(): 2019-10-29</span></div><div class='output co'>#> <span class='message'>loading from cache</span></div><div class='output co'>#> EnsDb for Ensembl: -#> |Backend: SQLite -#> |Db type: EnsDb -#> |Type of Gene ID: Ensembl Gene ID -#> |Supporting package: ensembldb -#> |Db created by: ensembldb package from Bioconductor -#> |script_version: 0.3.5 -#> |Creation time: Wed Nov 20 02:13:02 2019 -#> |ensembl_version: 98 -#> |ensembl_host: localhost -#> |Organism: Mus musculus -#> |taxonomy_id: 10090 -#> |genome_build: GRCm38 -#> |DBSCHEMAVERSION: 2.1 -#> | No. of genes: 56239. -#> | No. of transcripts: 144524. -#> |Protein data available.</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Get EnsDb.Mmusculus.v98 from AnnotationHub — EnsDb.Mmusculus.v98 • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Get EnsDb.Mmusculus.v98 from AnnotationHub — EnsDb.Mmusculus.v98" /> +<meta property="og:description" content="Get EnsDb.Mmusculus.v98 from AnnotationHub" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Get EnsDb.Mmusculus.v98 from AnnotationHub</h1> + + <div class="hidden name"><code>EnsDb.Mmusculus.v98.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Get EnsDb.Mmusculus.v98 from AnnotationHub</p> + </div> + + <pre class="usage"><span class='fu'>EnsDb.Mmusculus.v98</span>()</pre> + + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/ensembldb/man/EnsDb-class.html'>EnsDb-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'>EnsDb.Mmusculus.v98</span>()</div><div class='output co'>#> <span class='message'>snapshotDate(): 2019-10-29</span></div><div class='output co'>#> <span class='message'>loading from cache</span></div><div class='output co'>#> EnsDb for Ensembl: +#> |Backend: SQLite +#> |Db type: EnsDb +#> |Type of Gene ID: Ensembl Gene ID +#> |Supporting package: ensembldb +#> |Db created by: ensembldb package from Bioconductor +#> |script_version: 0.3.5 +#> |Creation time: Wed Nov 20 02:13:02 2019 +#> |ensembl_version: 98 +#> |ensembl_host: localhost +#> |Organism: Mus musculus +#> |taxonomy_id: 10090 +#> |genome_build: GRCm38 +#> |DBSCHEMAVERSION: 2.1 +#> | No. of genes: 56239. +#> | No. of transcripts: 144524. +#> |Protein data available.</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/add_context-1.png b/public/reference/add_context-1.png index 81a9f5c744b832c768da6574277f3b600d569f4c..3ad37c1bb7faa30d9dd2254ffe54ca918721a6b0 100644 Binary files a/public/reference/add_context-1.png and b/public/reference/add_context-1.png differ diff --git a/public/reference/add_context-2.png b/public/reference/add_context-2.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/add_context-2.png and b/public/reference/add_context-2.png differ diff --git a/public/reference/add_context-3.png b/public/reference/add_context-3.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/add_context-3.png and b/public/reference/add_context-3.png differ diff --git a/public/reference/add_context-4.png b/public/reference/add_context-4.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/add_context-4.png and b/public/reference/add_context-4.png differ diff --git a/public/reference/add_context.html b/public/reference/add_context.html index 049a552edc70ab6ba6fa438fd0a12a14074eb93e..21bfc185dbb41e4dacc71e5d0ca877fd24b604d2 100644 --- a/public/reference/add_context.html +++ b/public/reference/add_context.html @@ -1,295 +1,295 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Add [-4, +3] context — add_context • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Add [-4, +3] context — add_context" /> -<meta property="og:description" content="Add context for Doench2016 scoring" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Add [-4, +3] context</h1> - - <div class="hidden name"><code>add_context.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Add context for Doench2016 scoring</p> - </div> - - <pre class="usage"><span class='fu'>add_context</span>(<span class='no'>spacers</span>, <span class='no'>bsgenome</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>spacers</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code>: spacer ranges</p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>character vector</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>)</div><div class='output co'>#> <span class='message'>Lade nötiges Paket: magrittr</span></div><div class='input'> <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>), <span class='no'>bsgenome</span>, <span class='kw'>complement</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='img'><img src='add_context-1.png' alt='' width='700' height='433' /></div><div class='input'> (<span class='fu'>add_context</span>(<span class='no'>spacers</span>, <span class='no'>bsgenome</span>))</div><div class='output co'>#> <span class='message'> Add (4-23-3) contextseqs</span></div><div class='output co'>#> GRanges object with 10 ranges and 7 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 -#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 -#> HBB_f chr11 5226984-5227003 + | HBB 5227002 -#> HBB_r chr11 5227003-5227022 - | HBB 5227002 -#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 -#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 -#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 -#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 -#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 -#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 -#> targetend crisprname crisprspacer crisprpam -#> <integer> <character> <character> <character> -#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG -#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG -#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG -#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG -#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG -#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG -#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG -#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG -#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG -#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG -#> crisprcontext -#> <character> -#> CFTR_f CACCATTAAAGAAAATATCATCTTTGGTGT -#> CFTR_r CGCTTCTGTATCTATATTCATCATAGGAAA -#> HBB_f GGCAGTAACGGCAGACTTCTCCTCAGGAGT -#> HBB_r ACACCATGGTGCATCTGACTCCTGAGGAGA -#> HEXA_f_1 ACTATGTAGAAATCCTTCCAGTCAGGGCCA -#> HEXA_f_2 AGAAATCCTTCCAGTCAGGGCCATAGGATA -#> PRNP_f_1 CTGCAGCAGCTGGGGCAGTGGTGGGGGGCC -#> PRNP_f_2 TGCAGCAGCTGGGGCAGTGGTGGGGGGCCT -#> PRNP_f_3 AGCTGGGGCAGTGGTGGGGGGCCTTGGCGG -#> PRNP_f_4 TGGGGCAGTGGTGGGGGGCCTTGGCGGCTA -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'></span> -#> <span class='message'>Attache Paket: 'BiocGenerics'</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:parallel':</span> -#> <span class='message'></span> -#> <span class='message'> clusterApply, clusterApplyLB, clusterCall, clusterEvalQ,</span> -#> <span class='message'> clusterExport, clusterMap, parApply, parCapply, parLapply,</span> -#> <span class='message'> parLapplyLB, parRapply, parSapply, parSapplyLB</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:stats':</span> -#> <span class='message'></span> -#> <span class='message'> IQR, mad, sd, var, xtabs</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:base':</span> -#> <span class='message'></span> -#> <span class='message'> anyDuplicated, append, as.data.frame, basename, cbind, colnames,</span> -#> <span class='message'> dirname, do.call, duplicated, eval, evalq, Filter, Find, get, grep,</span> -#> <span class='message'> grepl, intersect, is.unsorted, lapply, Map, mapply, match, mget,</span> -#> <span class='message'> order, paste, pmax, pmax.int, pmin, pmin.int, Position, rank,</span> -#> <span class='message'> rbind, Reduce, rownames, sapply, setdiff, sort, table, tapply,</span> -#> <span class='message'> union, unique, unsplit, which, which.max, which.min</span></div><div class='output co'>#> <span class='message'></span> -#> <span class='message'>Attache Paket: 'S4Vectors'</span></div><div class='output co'>#> <span class='message'>The following object is masked from 'package:base':</span> -#> <span class='message'></span> -#> <span class='message'> expand.grid</span></div><div class='output co'>#> <span class='message'></span> -#> <span class='message'>Attache Paket: 'IRanges'</span></div><div class='output co'>#> <span class='message'>The following object is masked from 'package:grDevices':</span> -#> <span class='message'></span> -#> <span class='message'> windows</span></div><div class='output co'>#> <span class='message'></span> -#> <span class='message'>Attache Paket: 'Biostrings'</span></div><div class='output co'>#> <span class='message'>The following object is masked from 'package:base':</span> -#> <span class='message'></span> -#> <span class='message'> strsplit</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_context-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_context-3.png' alt='' width='700' height='433' /></div><div class='input'> (<span class='no'>spacers</span> <span class='kw'>%<>%</span> <span class='fu'>add_context</span>(<span class='no'>bsgenome</span>))</div><div class='output co'>#> <span class='message'> Add (4-23-3) contextseqs</span></div><div class='output co'>#> GRanges object with 10159 ranges and 9 metadata columns: -#> seqnames ranges strand | name score -#> <Rle> <IRanges> <Rle> | <character> <numeric> -#> T0001_r_5 chr1 4712619-4712638 - | SRF_MA0083.3 10.49542 -#> T0001_r_4 chr1 4712620-4712639 - | SRF_MA0083.3 10.49542 -#> T0001_r_3 chr1 4712627-4712646 - | SRF_MA0083.3 10.49542 -#> T0001_r_2 chr1 4712633-4712652 - | SRF_MA0083.3 10.49542 -#> T0001_r_1 chr1 4712634-4712653 - | SRF_MA0083.3 10.49542 -#> ... ... ... ... . ... ... -#> T1974_r_3 chrY 89126492-89126511 - | SRF_MA0083.3 4.54393 -#> T1974_f_3 chrY 89126496-89126515 + | SRF_MA0083.3 4.54393 -#> T1974_r_2 chrY 89126499-89126518 - | SRF_MA0083.3 4.54393 -#> T1974_r_1 chrY 89126500-89126519 - | SRF_MA0083.3 4.54393 -#> T1974_f_4 chrY 89126501-89126520 + | SRF_MA0083.3 4.54393 -#> targetname targetstart targetend crisprname crisprspacer -#> <character> <integer> <integer> <character> <character> -#> T0001_r_5 T0001 4712628 4712643 T0001_r_5 ATATAAGGGCATTGGAAGAA -#> T0001_r_4 T0001 4712628 4712643 T0001_r_4 AATATAAGGGCATTGGAAGA -#> T0001_r_3 T0001 4712628 4712643 T0001_r_3 TGGAGACAATATAAGGGCAT -#> T0001_r_2 T0001 4712628 4712643 T0001_r_2 TTCTGCTGGAGACAATATAA -#> T0001_r_1 T0001 4712628 4712643 T0001_r_1 CTTCTGCTGGAGACAATATA -#> ... ... ... ... ... ... -#> T1974_r_3 T1974 89126494 89126509 T1974_r_3 TTTGCCCATACTAGGGAGAG -#> T1974_f_3 T1974 89126494 89126509 T1974_f_3 CCCTAGTATGGGCAAATATA -#> T1974_r_2 T1974 89126494 89126509 T1974_r_2 CCATATATTTGCCCATACTA -#> T1974_r_1 T1974 89126494 89126509 T1974_r_1 TCCATATATTTGCCCATACT -#> T1974_f_4 T1974 89126494 89126509 T1974_f_4 GTATGGGCAAATATATGGAA -#> crisprpam crisprcontext -#> <character> <character> -#> T0001_r_5 GGG GACAATATAAGGGCATTGGAAGAAGGGAGT -#> T0001_r_4 AGG AGACAATATAAGGGCATTGGAAGAAGGGAG -#> T0001_r_3 TGG CTGCTGGAGACAATATAAGGGCATTGGAAG -#> T0001_r_2 GGG CACCTTCTGCTGGAGACAATATAAGGGCAT -#> T0001_r_1 AGG ACACCTTCTGCTGGAGACAATATAAGGGCA -#> ... ... ... -#> T1974_r_3 CGG TATATTTGCCCATACTAGGGAGAGCGGCTT -#> T1974_f_3 TGG CTCTCCCTAGTATGGGCAAATATATGGAAT -#> T1974_r_2 GGG CATTCCATATATTTGCCCATACTAGGGAGA -#> T1974_r_1 AGG CCATTCCATATATTTGCCCATACTAGGGAG -#> T1974_f_4 TGG CCTAGTATGGGCAAATATATGGAATGGAAA -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Add [-4, +3] context — add_context • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Add [-4, +3] context — add_context" /> +<meta property="og:description" content="Add context for Doench2016 scoring" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Add [-4, +3] context</h1> + + <div class="hidden name"><code>add_context.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Add context for Doench2016 scoring</p> + </div> + + <pre class="usage"><span class='fu'>add_context</span>(<span class='no'>spacers</span>, <span class='no'>bsgenome</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>spacers</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code>: spacer ranges</p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>character vector</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>)</div><div class='output co'>#> <span class='message'>Lade nötiges Paket: magrittr</span></div><div class='input'> <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>), <span class='no'>bsgenome</span>, <span class='kw'>complement</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='img'><img src='add_context-1.png' alt='' width='700' height='433' /></div><div class='input'> (<span class='fu'>add_context</span>(<span class='no'>spacers</span>, <span class='no'>bsgenome</span>))</div><div class='output co'>#> <span class='message'> Add (4-23-3) contextseqs</span></div><div class='output co'>#> GRanges object with 10 ranges and 7 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 +#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 +#> HBB_f chr11 5226984-5227003 + | HBB 5227002 +#> HBB_r chr11 5227003-5227022 - | HBB 5227002 +#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 +#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 +#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 +#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 +#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 +#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 +#> targetend crisprname crisprspacer crisprpam +#> <integer> <character> <character> <character> +#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG +#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG +#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG +#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG +#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG +#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG +#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG +#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG +#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG +#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG +#> crisprcontext +#> <character> +#> CFTR_f CACCATTAAAGAAAATATCATCTTTGGTGT +#> CFTR_r CGCTTCTGTATCTATATTCATCATAGGAAA +#> HBB_f GGCAGTAACGGCAGACTTCTCCTCAGGAGT +#> HBB_r ACACCATGGTGCATCTGACTCCTGAGGAGA +#> HEXA_f_1 ACTATGTAGAAATCCTTCCAGTCAGGGCCA +#> HEXA_f_2 AGAAATCCTTCCAGTCAGGGCCATAGGATA +#> PRNP_f_1 CTGCAGCAGCTGGGGCAGTGGTGGGGGGCC +#> PRNP_f_2 TGCAGCAGCTGGGGCAGTGGTGGGGGGCCT +#> PRNP_f_3 AGCTGGGGCAGTGGTGGGGGGCCTTGGCGG +#> PRNP_f_4 TGGGGCAGTGGTGGGGGGCCTTGGCGGCTA +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'></span> +#> <span class='message'>Attache Paket: 'BiocGenerics'</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:parallel':</span> +#> <span class='message'></span> +#> <span class='message'> clusterApply, clusterApplyLB, clusterCall, clusterEvalQ,</span> +#> <span class='message'> clusterExport, clusterMap, parApply, parCapply, parLapply,</span> +#> <span class='message'> parLapplyLB, parRapply, parSapply, parSapplyLB</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:stats':</span> +#> <span class='message'></span> +#> <span class='message'> IQR, mad, sd, var, xtabs</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:base':</span> +#> <span class='message'></span> +#> <span class='message'> anyDuplicated, append, as.data.frame, basename, cbind, colnames,</span> +#> <span class='message'> dirname, do.call, duplicated, eval, evalq, Filter, Find, get, grep,</span> +#> <span class='message'> grepl, intersect, is.unsorted, lapply, Map, mapply, match, mget,</span> +#> <span class='message'> order, paste, pmax, pmax.int, pmin, pmin.int, Position, rank,</span> +#> <span class='message'> rbind, Reduce, rownames, sapply, setdiff, sort, table, tapply,</span> +#> <span class='message'> union, unique, unsplit, which, which.max, which.min</span></div><div class='output co'>#> <span class='message'></span> +#> <span class='message'>Attache Paket: 'S4Vectors'</span></div><div class='output co'>#> <span class='message'>The following object is masked from 'package:base':</span> +#> <span class='message'></span> +#> <span class='message'> expand.grid</span></div><div class='output co'>#> <span class='message'></span> +#> <span class='message'>Attache Paket: 'IRanges'</span></div><div class='output co'>#> <span class='message'>The following object is masked from 'package:grDevices':</span> +#> <span class='message'></span> +#> <span class='message'> windows</span></div><div class='output co'>#> <span class='message'></span> +#> <span class='message'>Attache Paket: 'Biostrings'</span></div><div class='output co'>#> <span class='message'>The following object is masked from 'package:base':</span> +#> <span class='message'></span> +#> <span class='message'> strsplit</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_context-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_context-3.png' alt='' width='700' height='433' /></div><div class='input'> (<span class='no'>spacers</span> <span class='kw'>%<>%</span> <span class='fu'>add_context</span>(<span class='no'>bsgenome</span>))</div><div class='output co'>#> <span class='message'> Add (4-23-3) contextseqs</span></div><div class='output co'>#> GRanges object with 10159 ranges and 9 metadata columns: +#> seqnames ranges strand | name score +#> <Rle> <IRanges> <Rle> | <character> <numeric> +#> T0001_r_5 chr1 4712619-4712638 - | SRF_MA0083.3 10.49542 +#> T0001_r_4 chr1 4712620-4712639 - | SRF_MA0083.3 10.49542 +#> T0001_r_3 chr1 4712627-4712646 - | SRF_MA0083.3 10.49542 +#> T0001_r_2 chr1 4712633-4712652 - | SRF_MA0083.3 10.49542 +#> T0001_r_1 chr1 4712634-4712653 - | SRF_MA0083.3 10.49542 +#> ... ... ... ... . ... ... +#> T1974_r_3 chrY 89126492-89126511 - | SRF_MA0083.3 4.54393 +#> T1974_f_3 chrY 89126496-89126515 + | SRF_MA0083.3 4.54393 +#> T1974_r_2 chrY 89126499-89126518 - | SRF_MA0083.3 4.54393 +#> T1974_r_1 chrY 89126500-89126519 - | SRF_MA0083.3 4.54393 +#> T1974_f_4 chrY 89126501-89126520 + | SRF_MA0083.3 4.54393 +#> targetname targetstart targetend crisprname crisprspacer +#> <character> <integer> <integer> <character> <character> +#> T0001_r_5 T0001 4712628 4712643 T0001_r_5 ATATAAGGGCATTGGAAGAA +#> T0001_r_4 T0001 4712628 4712643 T0001_r_4 AATATAAGGGCATTGGAAGA +#> T0001_r_3 T0001 4712628 4712643 T0001_r_3 TGGAGACAATATAAGGGCAT +#> T0001_r_2 T0001 4712628 4712643 T0001_r_2 TTCTGCTGGAGACAATATAA +#> T0001_r_1 T0001 4712628 4712643 T0001_r_1 CTTCTGCTGGAGACAATATA +#> ... ... ... ... ... ... +#> T1974_r_3 T1974 89126494 89126509 T1974_r_3 TTTGCCCATACTAGGGAGAG +#> T1974_f_3 T1974 89126494 89126509 T1974_f_3 CCCTAGTATGGGCAAATATA +#> T1974_r_2 T1974 89126494 89126509 T1974_r_2 CCATATATTTGCCCATACTA +#> T1974_r_1 T1974 89126494 89126509 T1974_r_1 TCCATATATTTGCCCATACT +#> T1974_f_4 T1974 89126494 89126509 T1974_f_4 GTATGGGCAAATATATGGAA +#> crisprpam crisprcontext +#> <character> <character> +#> T0001_r_5 GGG GACAATATAAGGGCATTGGAAGAAGGGAGT +#> T0001_r_4 AGG AGACAATATAAGGGCATTGGAAGAAGGGAG +#> T0001_r_3 TGG CTGCTGGAGACAATATAAGGGCATTGGAAG +#> T0001_r_2 GGG CACCTTCTGCTGGAGACAATATAAGGGCAT +#> T0001_r_1 AGG ACACCTTCTGCTGGAGACAATATAAGGGCA +#> ... ... ... +#> T1974_r_3 CGG TATATTTGCCCATACTAGGGAGAGCGGCTT +#> T1974_f_3 TGG CTCTCCCTAGTATGGGCAAATATATGGAAT +#> T1974_r_2 GGG CATTCCATATATTTGCCCATACTAGGGAGA +#> T1974_r_1 AGG CCATTCCATATATTTGCCCATACTAGGGAG +#> T1974_f_4 TGG CCTAGTATGGGCAAATATATGGAATGGAAA +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/add_efficiency-1.png b/public/reference/add_efficiency-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/add_efficiency-1.png and b/public/reference/add_efficiency-1.png differ diff --git a/public/reference/add_efficiency-2.png b/public/reference/add_efficiency-2.png index 7eca7e4b5f21985997e54da4c0a1908251862caf..121ab030b00920a908703cc82650d229154305a6 100644 Binary files a/public/reference/add_efficiency-2.png and b/public/reference/add_efficiency-2.png differ diff --git a/public/reference/add_efficiency-3.png b/public/reference/add_efficiency-3.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/add_efficiency-3.png and b/public/reference/add_efficiency-3.png differ diff --git a/public/reference/add_efficiency-4.png b/public/reference/add_efficiency-4.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/add_efficiency-4.png and b/public/reference/add_efficiency-4.png differ diff --git a/public/reference/add_efficiency.html b/public/reference/add_efficiency.html index bf602f987c709c850e461e6eaf73317b6e6c371b..7b397f0c4a2edcf2a03117e9b891f64b08ca04c2 100644 --- a/public/reference/add_efficiency.html +++ b/public/reference/add_efficiency.html @@ -1,328 +1,328 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Add efficiency scores and filter — add_efficiency • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Add efficiency scores and filter — add_efficiency" /> -<meta property="og:description" content="Add Doench2014 or Doench2016 efficiency scores and filter on them" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Add efficiency scores and filter</h1> - - <div class="hidden name"><code>add_efficiency.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Add Doench2014 or Doench2016 efficiency scores and filter on them</p> - </div> - - <pre class="usage"><span class='fu'>add_efficiency</span>( - <span class='no'>spacers</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>method</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>"Doench2014"</span>, <span class='st'>"Doench2016"</span>)[<span class='fl'>1</span>], - <span class='kw'>chunksize</span> <span class='kw'>=</span> <span class='fl'>10000</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='fu'>default_alpha_var</span>(<span class='no'>spacers</span>), - <span class='kw'>size_var</span> <span class='kw'>=</span> <span class='no'>method</span> -) - -<span class='fu'>filter_efficient</span>( - <span class='no'>spacers</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>method</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>"Doench2014"</span>, <span class='st'>"Doench2016"</span>)[<span class='fl'>1</span>], - <span class='no'>cutoff</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='fu'>default_alpha_var</span>(<span class='no'>spacers</span>) -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>spacers</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code>: spacers</p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>method</th> - <td><p>'Doench2014' (default) or 'Doench2016' -(requires non-NULL argument python, virtualenv, or condaenv)</p></td> - </tr> - <tr> - <th>chunksize</th> - <td><p>Doench2016 is executed in chunks of chunksize</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>alpha_var</th> - <td><p>NULL or string: var mapped to alpha in plot</p></td> - </tr> - <tr> - <th>size_var</th> - <td><p>NULL or string: var mapped to size in plot</p></td> - </tr> - <tr> - <th>cutoff</th> - <td><p>value to filter on</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>numeric vector</p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p><code>add_efficiency</code> adds efficiency scores -<code>filter_efficiency</code> adds efficiency scores and filters on them</p> - <h2 class="hasAnchor" id="references"><a class="anchor" href="#references"></a>References</h2> - - <p>Doench 2014, Rational design of highly active sgRNAs for -CRISPR-Cas9-mediated gene inactivation. Nature Biotechnology, -doi: 10.1038/nbt.3026</p> -<p>Doench 2016, Optimized sgRNA design to maximize activity and minimize -off-target effects of CRISPR-Cas9. Nature Biotechnology, -doi: 10.1038/nbt.3437</p> -<p>Python module azimuth: github/MicrosoftResearch/azimuth</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'> -<span class='co'># Install azimuth </span> -<span class='co'>#----------------</span> - <span class='co'>## With reticulate</span> - <span class='co'># require(reticulate)</span> - <span class='co'># conda_create('azienv', c('python=2.7'))</span> - <span class='co'># use_condaenv('azienv')</span> - <span class='co'># py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE)</span> - - <span class='co'>## Directly</span> - <span class='co'># conda create --name azienv python=2.7</span> - <span class='co'># conda activate azienv</span> - <span class='co'># pip install azimuth</span> - <span class='co'># pip install scikit-learn==0.17.1</span> - -<span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='add_efficiency-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'>#spacers <- find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE)</span> - (<span class='no'>spacers</span> <span class='kw'>%<>%</span> <span class='fu'>add_efficiency</span>(<span class='no'>bsgenome</span>, <span class='st'>'Doench2014'</span>))</div><div class='output co'>#> <span class='message'> Score crispr spacers</span></div><div class='output co'>#> <span class='message'> Add (4-23-3) contextseqs</span></div><div class='output co'>#> <span class='message'> Score contextseqs with Doench2014</span></div><div class='img'><img src='add_efficiency-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 11 metadata columns: -#> seqnames ranges strand | crisprcontext -#> <Rle> <IRanges> <Rle> | <character> -#> CFTR_1 chr7 117559575-117559594 + | CACCATTAAAGAAAATATCATCTTTGGTGT -#> CFTR_2 chr7 117559606-117559625 - | CGCTTCTGTATCTATATTCATCATAGGAAA -#> HBB_1 chr11 5227003-5227022 - | ACACCATGGTGCATCTGACTCCTGAGGAGA -#> HBB_2 chr11 5226984-5227003 + | GGCAGTAACGGCAGACTTCTCCTCAGGAGT -#> HEXA_1 chr15 72346551-72346570 + | ACTATGTAGAAATCCTTCCAGTCAGGGCCA -#> HEXA_2 chr15 72346558-72346577 + | AGAAATCCTTCCAGTCAGGGCCATAGGATA -#> PRNP_1 chr20 4699568-4699587 + | CTGCAGCAGCTGGGGCAGTGGTGGGGGGCC -#> PRNP_2 chr20 4699569-4699588 + | TGCAGCAGCTGGGGCAGTGGTGGGGGGCCT -#> PRNP_3 chr20 4699575-4699594 + | AGCTGGGGCAGTGGTGGGGGGCCTTGGCGG -#> PRNP_4 chr20 4699578-4699597 + | TGGGGCAGTGGTGGGGGGCCTTGGCGGCTA -#> targetname targetstart targetend crisprname crisprspacer -#> <character> <integer> <integer> <character> <character> -#> CFTR_1 CFTR 117559593 117559595 CFTR_1 ATTAAAGAAAATATCATCTT -#> CFTR_2 CFTR 117559593 117559595 CFTR_2 TCTGTATCTATATTCATCAT -#> HBB_1 HBB 5227002 5227002 HBB_1 CATGGTGCATCTGACTCCTG -#> HBB_2 HBB 5227002 5227002 HBB_2 GTAACGGCAGACTTCTCCTC -#> HEXA_1 HEXA 72346580 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA -#> HEXA_2 HEXA 72346580 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT -#> PRNP_1 PRNP 4699600 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG -#> PRNP_2 PRNP 4699600 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG -#> PRNP_3 PRNP 4699600 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT -#> PRNP_4 PRNP 4699600 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG -#> crisprpam primer revtranscript -#> <character> <character> <character> -#> CFTR_1 TGG AAGAAAATATCAT CTTTGGTGTTTCCTAT -#> CFTR_2 AGG TATCTATATTCAT CATAGGAAACACCAAA -#> HBB_1 AGG GTGCATCTGACTC CTGAGGAGAAGTCTGC -#> HBB_2 AGG CGGCAGACTTCTC CTCAGGAGTCAGATGC -#> HEXA_1 GGG GAAATCCTTCCAG TCAGGGCCATAGGATA -#> HEXA_2 AGG TTCCAGTCAGGGC CATAGGATATACGGTT -#> PRNP_1 GGG GCTGGGGCAGTGG TGGGGGGCCTTGGCGG -#> PRNP_2 GGG CTGGGGCAGTGGT GGGGGGCCTTGGCGGC -#> PRNP_3 TGG CAGTGGTGGGGGG CCTTGGCGGCTACATG -#> PRNP_4 CGG TGGTGGGGGGCCT TGGCGGCTACATGCTG -#> extension Doench2014 -#> <character> <numeric> -#> CFTR_1 ATAGGAAACACCAAAGATGATATTTTCTT 0.0339998970537971 -#> CFTR_2 TTTGGTGTTTCCTATGATGAATATAGATA 0.223370560176775 -#> HBB_1 GCAGACTTCTCCTCAGGAGTCAGATGCAC 0.13111422370078 -#> HBB_2 GCATCTGACTCCTGAGGAGAAGTCTGCCG 0.413980645125447 -#> HEXA_1 TATCCTATGGCCCTGACTGGAAGGATTTC 0.107283614825074 -#> HEXA_2 AACCGTATATCCTATGGCCCTGACTGGAA 0.0394252780338432 -#> PRNP_1 CCGCCAAGGCCCCCCACCACTGCCCCAGC 0.00994899162104746 -#> PRNP_2 GCCGCCAAGGCCCCCCACCACTGCCCCAG 0.0449662673405108 -#> PRNP_3 CATGTAGCCGCCAAGGCCCCCCACCACTG 0.00996253852673941 -#> PRNP_4 CAGCATGTAGCCGCCAAGGCCCCCCACCA 0.20935862741641 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='co'># reticulate::use_condaenv('azienv')</span> - <span class='co'># reticulate::import('azimuth')</span> - <span class='co'># spacers %<>% add_efficiency(bsgenome, 'Doench2016')</span> - <span class='co'># filter_efficient(spacers, bsgenome, 'Doench2016', 0.4)</span> - -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_efficiency-3.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_efficiency-4.png' alt='' width='700' height='433' /></div><div class='input'> # reticulate::use_condaenv('azienv') - # reticulate::import('azienv') - # (spacers %<>% add_offtargets(bsgenome, targets)) - # (spacers %>% add_efficiency(bsgenome, 'Doench2014')) - # (spacers %>% add_efficiency(bsgenome, 'Doench2016')) -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#references">References</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Add efficiency scores and filter — add_efficiency • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Add efficiency scores and filter — add_efficiency" /> +<meta property="og:description" content="Add Doench2014 or Doench2016 efficiency scores and filter on them" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Add efficiency scores and filter</h1> + + <div class="hidden name"><code>add_efficiency.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Add Doench2014 or Doench2016 efficiency scores and filter on them</p> + </div> + + <pre class="usage"><span class='fu'>add_efficiency</span>( + <span class='no'>spacers</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>method</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>"Doench2014"</span>, <span class='st'>"Doench2016"</span>)[<span class='fl'>1</span>], + <span class='kw'>chunksize</span> <span class='kw'>=</span> <span class='fl'>10000</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='fu'>default_alpha_var</span>(<span class='no'>spacers</span>), + <span class='kw'>size_var</span> <span class='kw'>=</span> <span class='no'>method</span> +) + +<span class='fu'>filter_efficient</span>( + <span class='no'>spacers</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>method</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>"Doench2014"</span>, <span class='st'>"Doench2016"</span>)[<span class='fl'>1</span>], + <span class='no'>cutoff</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='fu'>default_alpha_var</span>(<span class='no'>spacers</span>) +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>spacers</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code>: spacers</p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>method</th> + <td><p>'Doench2014' (default) or 'Doench2016' +(requires non-NULL argument python, virtualenv, or condaenv)</p></td> + </tr> + <tr> + <th>chunksize</th> + <td><p>Doench2016 is executed in chunks of chunksize</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>alpha_var</th> + <td><p>NULL or string: var mapped to alpha in plot</p></td> + </tr> + <tr> + <th>size_var</th> + <td><p>NULL or string: var mapped to size in plot</p></td> + </tr> + <tr> + <th>cutoff</th> + <td><p>value to filter on</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>numeric vector</p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p><code>add_efficiency</code> adds efficiency scores +<code>filter_efficiency</code> adds efficiency scores and filters on them</p> + <h2 class="hasAnchor" id="references"><a class="anchor" href="#references"></a>References</h2> + + <p>Doench 2014, Rational design of highly active sgRNAs for +CRISPR-Cas9-mediated gene inactivation. Nature Biotechnology, +doi: 10.1038/nbt.3026</p> +<p>Doench 2016, Optimized sgRNA design to maximize activity and minimize +off-target effects of CRISPR-Cas9. Nature Biotechnology, +doi: 10.1038/nbt.3437</p> +<p>Python module azimuth: github/MicrosoftResearch/azimuth</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'> +<span class='co'># Install azimuth </span> +<span class='co'>#----------------</span> + <span class='co'>## With reticulate</span> + <span class='co'># require(reticulate)</span> + <span class='co'># conda_create('azienv', c('python=2.7'))</span> + <span class='co'># use_condaenv('azienv')</span> + <span class='co'># py_install(c('azimuth', 'scikit-learn==0.17.1'), 'azienv', pip = TRUE)</span> + + <span class='co'>## Directly</span> + <span class='co'># conda create --name azienv python=2.7</span> + <span class='co'># conda activate azienv</span> + <span class='co'># pip install azimuth</span> + <span class='co'># pip install scikit-learn==0.17.1</span> + +<span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='add_efficiency-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'>#spacers <- find_spacers(extend_for_pe(gr), bsgenome, complement = FALSE)</span> + (<span class='no'>spacers</span> <span class='kw'>%<>%</span> <span class='fu'>add_efficiency</span>(<span class='no'>bsgenome</span>, <span class='st'>'Doench2014'</span>))</div><div class='output co'>#> <span class='message'> Score crispr spacers</span></div><div class='output co'>#> <span class='message'> Add (4-23-3) contextseqs</span></div><div class='output co'>#> <span class='message'> Score contextseqs with Doench2014</span></div><div class='img'><img src='add_efficiency-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 11 metadata columns: +#> seqnames ranges strand | crisprcontext +#> <Rle> <IRanges> <Rle> | <character> +#> CFTR_1 chr7 117559575-117559594 + | CACCATTAAAGAAAATATCATCTTTGGTGT +#> CFTR_2 chr7 117559606-117559625 - | CGCTTCTGTATCTATATTCATCATAGGAAA +#> HBB_1 chr11 5227003-5227022 - | ACACCATGGTGCATCTGACTCCTGAGGAGA +#> HBB_2 chr11 5226984-5227003 + | GGCAGTAACGGCAGACTTCTCCTCAGGAGT +#> HEXA_1 chr15 72346551-72346570 + | ACTATGTAGAAATCCTTCCAGTCAGGGCCA +#> HEXA_2 chr15 72346558-72346577 + | AGAAATCCTTCCAGTCAGGGCCATAGGATA +#> PRNP_1 chr20 4699568-4699587 + | CTGCAGCAGCTGGGGCAGTGGTGGGGGGCC +#> PRNP_2 chr20 4699569-4699588 + | TGCAGCAGCTGGGGCAGTGGTGGGGGGCCT +#> PRNP_3 chr20 4699575-4699594 + | AGCTGGGGCAGTGGTGGGGGGCCTTGGCGG +#> PRNP_4 chr20 4699578-4699597 + | TGGGGCAGTGGTGGGGGGCCTTGGCGGCTA +#> targetname targetstart targetend crisprname crisprspacer +#> <character> <integer> <integer> <character> <character> +#> CFTR_1 CFTR 117559593 117559595 CFTR_1 ATTAAAGAAAATATCATCTT +#> CFTR_2 CFTR 117559593 117559595 CFTR_2 TCTGTATCTATATTCATCAT +#> HBB_1 HBB 5227002 5227002 HBB_1 CATGGTGCATCTGACTCCTG +#> HBB_2 HBB 5227002 5227002 HBB_2 GTAACGGCAGACTTCTCCTC +#> HEXA_1 HEXA 72346580 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA +#> HEXA_2 HEXA 72346580 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT +#> PRNP_1 PRNP 4699600 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG +#> PRNP_2 PRNP 4699600 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG +#> PRNP_3 PRNP 4699600 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT +#> PRNP_4 PRNP 4699600 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG +#> crisprpam primer revtranscript +#> <character> <character> <character> +#> CFTR_1 TGG AAGAAAATATCAT CTTTGGTGTTTCCTAT +#> CFTR_2 AGG TATCTATATTCAT CATAGGAAACACCAAA +#> HBB_1 AGG GTGCATCTGACTC CTGAGGAGAAGTCTGC +#> HBB_2 AGG CGGCAGACTTCTC CTCAGGAGTCAGATGC +#> HEXA_1 GGG GAAATCCTTCCAG TCAGGGCCATAGGATA +#> HEXA_2 AGG TTCCAGTCAGGGC CATAGGATATACGGTT +#> PRNP_1 GGG GCTGGGGCAGTGG TGGGGGGCCTTGGCGG +#> PRNP_2 GGG CTGGGGCAGTGGT GGGGGGCCTTGGCGGC +#> PRNP_3 TGG CAGTGGTGGGGGG CCTTGGCGGCTACATG +#> PRNP_4 CGG TGGTGGGGGGCCT TGGCGGCTACATGCTG +#> extension Doench2014 +#> <character> <numeric> +#> CFTR_1 ATAGGAAACACCAAAGATGATATTTTCTT 0.0339998970537971 +#> CFTR_2 TTTGGTGTTTCCTATGATGAATATAGATA 0.223370560176775 +#> HBB_1 GCAGACTTCTCCTCAGGAGTCAGATGCAC 0.13111422370078 +#> HBB_2 GCATCTGACTCCTGAGGAGAAGTCTGCCG 0.413980645125447 +#> HEXA_1 TATCCTATGGCCCTGACTGGAAGGATTTC 0.107283614825074 +#> HEXA_2 AACCGTATATCCTATGGCCCTGACTGGAA 0.0394252780338432 +#> PRNP_1 CCGCCAAGGCCCCCCACCACTGCCCCAGC 0.00994899162104746 +#> PRNP_2 GCCGCCAAGGCCCCCCACCACTGCCCCAG 0.0449662673405108 +#> PRNP_3 CATGTAGCCGCCAAGGCCCCCCACCACTG 0.00996253852673941 +#> PRNP_4 CAGCATGTAGCCGCCAAGGCCCCCCACCA 0.20935862741641 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='co'># reticulate::use_condaenv('azienv')</span> + <span class='co'># reticulate::import('azimuth')</span> + <span class='co'># spacers %<>% add_efficiency(bsgenome, 'Doench2016')</span> + <span class='co'># filter_efficient(spacers, bsgenome, 'Doench2016', 0.4)</span> + +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_efficiency-3.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_efficiency-4.png' alt='' width='700' height='433' /></div><div class='input'> # reticulate::use_condaenv('azienv') + # reticulate::import('azienv') + # (spacers %<>% add_offtargets(bsgenome, targets)) + # (spacers %>% add_efficiency(bsgenome, 'Doench2014')) + # (spacers %>% add_efficiency(bsgenome, 'Doench2016')) +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#references">References</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/add_genome_counts-1.png b/public/reference/add_genome_counts-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/add_genome_counts-1.png and b/public/reference/add_genome_counts-1.png differ diff --git a/public/reference/add_genome_counts-2.png b/public/reference/add_genome_counts-2.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/add_genome_counts-2.png and b/public/reference/add_genome_counts-2.png differ diff --git a/public/reference/add_genome_counts-3.png b/public/reference/add_genome_counts-3.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/add_genome_counts-3.png and b/public/reference/add_genome_counts-3.png differ diff --git a/public/reference/add_genome_counts.html b/public/reference/add_genome_counts.html index 6ab15ae24fc23e261329927732c6d7a7a624fd47..d9618b3bbbb6da24dbce748e8e4d83eb934a3b3e 100644 --- a/public/reference/add_genome_counts.html +++ b/public/reference/add_genome_counts.html @@ -1,238 +1,238 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Add genome counts — add_genome_counts • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Add genome counts — add_genome_counts" /> -<meta property="og:description" content="Count spacer matches to genome and add to GRanges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Add genome counts</h1> - - <div class="hidden name"><code>add_genome_counts.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Count spacer matches to genome and add to GRanges</p> - </div> - - <pre class="usage"><span class='fu'>add_genome_counts</span>( - <span class='no'>spacers</span>, - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>spacers</span>)[<span class='fl'>1</span>]), - <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>spacers</th> - <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>mismatches</th> - <td><p>number (default 2): max number of mismatches to consider</p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string (default 'NGG') pam pattern to expand</p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>dir where output is written to</p></td> - </tr> - <tr> - <th>indexedgenomesdir</th> - <td><p>string: dir with indexed genomes</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>FALSE (default) or TRUE</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>spacer GRanges with additional mcols</p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>Expands iupac amgiguities in the pam sequence. -Matches all resulting sequences against (indexes) target and genome. -Adds match counts to GRanges object, and then returns it.</p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='add_genome_counts-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># index_genome(bsgenome)</span> - <span class='co'># add_genome_counts(spacers, bsgenome, mismatches=0, plot = TRUE)</span> - -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_genome_counts-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_genome_counts-3.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) - # add_genome_counts(spacers, bsgenome) - # add_genome_counts(spacers, bsgenome, mismatches=3) -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Add genome counts — add_genome_counts • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Add genome counts — add_genome_counts" /> +<meta property="og:description" content="Count spacer matches to genome and add to GRanges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Add genome counts</h1> + + <div class="hidden name"><code>add_genome_counts.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Count spacer matches to genome and add to GRanges</p> + </div> + + <pre class="usage"><span class='fu'>add_genome_counts</span>( + <span class='no'>spacers</span>, + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>spacers</span>)[<span class='fl'>1</span>]), + <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>spacers</th> + <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>mismatches</th> + <td><p>number (default 2): max number of mismatches to consider</p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string (default 'NGG') pam pattern to expand</p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>dir where output is written to</p></td> + </tr> + <tr> + <th>indexedgenomesdir</th> + <td><p>string: dir with indexed genomes</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>FALSE (default) or TRUE</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>spacer GRanges with additional mcols</p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>Expands iupac amgiguities in the pam sequence. +Matches all resulting sequences against (indexes) target and genome. +Adds match counts to GRanges object, and then returns it.</p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='add_genome_counts-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># index_genome(bsgenome)</span> + <span class='co'># add_genome_counts(spacers, bsgenome, mismatches=0, plot = TRUE)</span> + +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_genome_counts-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_genome_counts-3.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) + # add_genome_counts(spacers, bsgenome) + # add_genome_counts(spacers, bsgenome, mismatches=3) +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/add_inverse_strand-1.png b/public/reference/add_inverse_strand-1.png index 91dfba09cdb49e8c6a43ef4c10e205b2accddbdb..6568a75515801b16b4ec5dedb9cf85bc9f0c810b 100644 Binary files a/public/reference/add_inverse_strand-1.png and b/public/reference/add_inverse_strand-1.png differ diff --git a/public/reference/add_inverse_strand-2.png b/public/reference/add_inverse_strand-2.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/add_inverse_strand-2.png and b/public/reference/add_inverse_strand-2.png differ diff --git a/public/reference/add_inverse_strand.html b/public/reference/add_inverse_strand.html index aed2dffff65eafd8f4e088fa6cae52b25bb51dbd..ef34c4171dee1d96d8405ac004e44d38f7379072 100644 --- a/public/reference/add_inverse_strand.html +++ b/public/reference/add_inverse_strand.html @@ -1,246 +1,246 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Add inverse strand — add_inverse_strand • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Add inverse strand — add_inverse_strand" /> -<meta property="og:description" content="Add inverse strand" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Add inverse strand</h1> - - <div class="hidden name"><code>add_inverse_strand.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Add inverse strand</p> - </div> - - <pre class="usage"><span class='fu'>add_inverse_strand</span>(<span class='no'>gr</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, <span class='no'>...</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - <tr> - <th>...</th> - <td><p><code><a href='plot_intervals.html'>plot_intervals</a></code> arguments</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='fu'>add_inverse_strand</span>(<span class='no'>gr</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='add_inverse_strand-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_f chr7 117559593-117559595 + | CFTR 117559593 -#> CFTR_r chr7 117559593-117559595 - | CFTR 117559593 -#> HBB_r chr11 5227002 - | HBB 5227002 -#> HBB_f chr11 5227002 + | HBB 5227002 -#> HEXA_r chr15 72346580-72346583 - | HEXA 72346580 -#> HEXA_f chr15 72346580-72346583 + | HEXA 72346580 -#> PRNP_f chr20 4699600 + | PRNP 4699600 -#> PRNP_r chr20 4699600 - | PRNP 4699600 -#> targetend -#> <integer> -#> CFTR_f 117559595 -#> CFTR_r 117559595 -#> HBB_r 5227002 -#> HBB_f 5227002 -#> HEXA_r 72346583 -#> HEXA_f 72346583 -#> PRNP_f 4699600 -#> PRNP_r 4699600 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_inverse_strand-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>add_inverse_strand</span>(<span class='no'>gr</span>)</div><div class='output co'>#> GRanges object with 3948 ranges and 5 metadata columns: -#> seqnames ranges strand | name score -#> <Rle> <IRanges> <Rle> | <character> <numeric> -#> T0001_r chr1 4712628-4712643 - | SRF_MA0083.3 10.49542 -#> T0001_f chr1 4712628-4712643 + | SRF_MA0083.3 10.49542 -#> T0002_r chr1 5250212-5250227 - | SRF_MA0083.3 9.7378 -#> T0002_f chr1 5250212-5250227 + | SRF_MA0083.3 9.7378 -#> T0003_r chr1 5250452-5250467 - | SRF_MA0083.3 5.92033 -#> ... ... ... ... . ... ... -#> T1972_f chrY 42512400-42512415 + | SRF_MA0083.3 6.59053 -#> T1973_r chrY 79048176-79048191 - | SRF_MA0083.3 9.7378 -#> T1973_f chrY 79048176-79048191 + | SRF_MA0083.3 9.7378 -#> T1974_r chrY 89126494-89126509 - | SRF_MA0083.3 4.54393 -#> T1974_f chrY 89126494-89126509 + | SRF_MA0083.3 4.54393 -#> targetname targetstart targetend -#> <character> <integer> <integer> -#> T0001_r T0001 4712628 4712643 -#> T0001_f T0001 4712628 4712643 -#> T0002_r T0002 5250212 5250227 -#> T0002_f T0002 5250212 5250227 -#> T0003_r T0003 5250452 5250467 -#> ... ... ... ... -#> T1972_f T1972 42512400 42512415 -#> T1973_r T1973 79048176 79048191 -#> T1973_f T1973 79048176 79048191 -#> T1974_r T1974 89126494 89126509 -#> T1974_f T1974 89126494 89126509 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Add inverse strand — add_inverse_strand • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Add inverse strand — add_inverse_strand" /> +<meta property="og:description" content="Add inverse strand" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Add inverse strand</h1> + + <div class="hidden name"><code>add_inverse_strand.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Add inverse strand</p> + </div> + + <pre class="usage"><span class='fu'>add_inverse_strand</span>(<span class='no'>gr</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, <span class='no'>...</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + <tr> + <th>...</th> + <td><p><code><a href='plot_intervals.html'>plot_intervals</a></code> arguments</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='fu'>add_inverse_strand</span>(<span class='no'>gr</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='add_inverse_strand-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_f chr7 117559593-117559595 + | CFTR 117559593 +#> CFTR_r chr7 117559593-117559595 - | CFTR 117559593 +#> HBB_r chr11 5227002 - | HBB 5227002 +#> HBB_f chr11 5227002 + | HBB 5227002 +#> HEXA_r chr15 72346580-72346583 - | HEXA 72346580 +#> HEXA_f chr15 72346580-72346583 + | HEXA 72346580 +#> PRNP_f chr20 4699600 + | PRNP 4699600 +#> PRNP_r chr20 4699600 - | PRNP 4699600 +#> targetend +#> <integer> +#> CFTR_f 117559595 +#> CFTR_r 117559595 +#> HBB_r 5227002 +#> HBB_f 5227002 +#> HEXA_r 72346583 +#> HEXA_f 72346583 +#> PRNP_f 4699600 +#> PRNP_r 4699600 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_inverse_strand-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>add_inverse_strand</span>(<span class='no'>gr</span>)</div><div class='output co'>#> GRanges object with 3948 ranges and 5 metadata columns: +#> seqnames ranges strand | name score +#> <Rle> <IRanges> <Rle> | <character> <numeric> +#> T0001_r chr1 4712628-4712643 - | SRF_MA0083.3 10.49542 +#> T0001_f chr1 4712628-4712643 + | SRF_MA0083.3 10.49542 +#> T0002_r chr1 5250212-5250227 - | SRF_MA0083.3 9.7378 +#> T0002_f chr1 5250212-5250227 + | SRF_MA0083.3 9.7378 +#> T0003_r chr1 5250452-5250467 - | SRF_MA0083.3 5.92033 +#> ... ... ... ... . ... ... +#> T1972_f chrY 42512400-42512415 + | SRF_MA0083.3 6.59053 +#> T1973_r chrY 79048176-79048191 - | SRF_MA0083.3 9.7378 +#> T1973_f chrY 79048176-79048191 + | SRF_MA0083.3 9.7378 +#> T1974_r chrY 89126494-89126509 - | SRF_MA0083.3 4.54393 +#> T1974_f chrY 89126494-89126509 + | SRF_MA0083.3 4.54393 +#> targetname targetstart targetend +#> <character> <integer> <integer> +#> T0001_r T0001 4712628 4712643 +#> T0001_f T0001 4712628 4712643 +#> T0002_r T0002 5250212 5250227 +#> T0002_f T0002 5250212 5250227 +#> T0003_r T0003 5250452 5250467 +#> ... ... ... ... +#> T1972_f T1972 42512400 42512415 +#> T1973_r T1973 79048176 79048191 +#> T1973_f T1973 79048176 79048191 +#> T1974_r T1974 89126494 89126509 +#> T1974_f T1974 89126494 89126509 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/add_offtargets-1.png b/public/reference/add_offtargets-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/add_offtargets-1.png and b/public/reference/add_offtargets-1.png differ diff --git a/public/reference/add_offtargets-2.png b/public/reference/add_offtargets-2.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/add_offtargets-2.png and b/public/reference/add_offtargets-2.png differ diff --git a/public/reference/add_offtargets-3.png b/public/reference/add_offtargets-3.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/add_offtargets-3.png and b/public/reference/add_offtargets-3.png differ diff --git a/public/reference/add_offtargets.html b/public/reference/add_offtargets.html index c9a57d46c79aee7b1c04326f9181144d695d3ab1..2f34306b87423e29e95443c245a1cdcab5647ab3 100644 --- a/public/reference/add_offtargets.html +++ b/public/reference/add_offtargets.html @@ -1,255 +1,255 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Add offtarget counts — add_specificity • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Add offtarget counts — add_specificity" /> -<meta property="og:description" content="Add mcols 'off' (offtargets), 'off0' (0-mismatch offtargets), etc." /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Add offtarget counts</h1> - - <div class="hidden name"><code>add_offtargets.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Add mcols 'off' (offtargets), 'off0' (0-mismatch offtargets), etc.</p> - </div> - - <pre class="usage"><span class='fu'>add_specificity</span>(<span class='no'>...</span>) - -<span class='fu'>add_offtargets</span>( - <span class='no'>spacers</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>targets</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, - <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>size_var</span> <span class='kw'>=</span> <span class='fu'>default_size_var</span>(<span class='no'>spacers</span>), - <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='st'>"off"</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>...</th> - <td><p>to channel deprecated add_specificity to add_offtargets</p></td> - </tr> - <tr> - <th>spacers</th> - <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>targets</th> - <td><p>NULL (default) or target -<code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>mismatches</th> - <td><p>number (default 2): max number of mismatches to consider</p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string (default 'NGG'): pam sequence</p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>directory where output is written to</p></td> - </tr> - <tr> - <th>indexedgenomesdir</th> - <td><p>string: dir with indexed genomes</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>size_var</th> - <td><p>string: mapped to size in plot</p></td> - </tr> - <tr> - <th>alpha_var</th> - <td><p>string: mapped to alpha in plot</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>filtered spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>For NULL targets: offtarget counts = (G0- 1) + G1 + ... -Non-NULL targets: offtarget counts = (G0-T0) + (G1-T1) + ...</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='add_offtargets-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># index_genome(bsgenome)</span> - <span class='co'># add_offtargets(spacers, bsgenome, mismatches=0)</span> - <span class='co'># add_offtargets(spacers, bsgenome, mismatches=2)</span> -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_offtargets-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_offtargets-3.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) - # spacers %>% add_offtargets(bsgenome) # off = G - 1 - # spacers %>% add_offtargets(bsgenome, targets) # off = G - T -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Add offtarget counts — add_specificity • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Add offtarget counts — add_specificity" /> +<meta property="og:description" content="Add mcols 'off' (offtargets), 'off0' (0-mismatch offtargets), etc." /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Add offtarget counts</h1> + + <div class="hidden name"><code>add_offtargets.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Add mcols 'off' (offtargets), 'off0' (0-mismatch offtargets), etc.</p> + </div> + + <pre class="usage"><span class='fu'>add_specificity</span>(<span class='no'>...</span>) + +<span class='fu'>add_offtargets</span>( + <span class='no'>spacers</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>targets</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, + <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>size_var</span> <span class='kw'>=</span> <span class='fu'>default_size_var</span>(<span class='no'>spacers</span>), + <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='st'>"off"</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>...</th> + <td><p>to channel deprecated add_specificity to add_offtargets</p></td> + </tr> + <tr> + <th>spacers</th> + <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>targets</th> + <td><p>NULL (default) or target +<code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>mismatches</th> + <td><p>number (default 2): max number of mismatches to consider</p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string (default 'NGG'): pam sequence</p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>directory where output is written to</p></td> + </tr> + <tr> + <th>indexedgenomesdir</th> + <td><p>string: dir with indexed genomes</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>size_var</th> + <td><p>string: mapped to size in plot</p></td> + </tr> + <tr> + <th>alpha_var</th> + <td><p>string: mapped to alpha in plot</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>filtered spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>For NULL targets: offtarget counts = (G0- 1) + G1 + ... +Non-NULL targets: offtarget counts = (G0-T0) + (G1-T1) + ...</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='add_offtargets-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># index_genome(bsgenome)</span> + <span class='co'># add_offtargets(spacers, bsgenome, mismatches=0)</span> + <span class='co'># add_offtargets(spacers, bsgenome, mismatches=2)</span> +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_offtargets-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_offtargets-3.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) + # spacers %>% add_offtargets(bsgenome) # off = G - 1 + # spacers %>% add_offtargets(bsgenome, targets) # off = G - T +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/add_seq-1.png b/public/reference/add_seq-1.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/add_seq-1.png and b/public/reference/add_seq-1.png differ diff --git a/public/reference/add_seq.html b/public/reference/add_seq.html index d53e3ee217c85df6d18daec1bf798d30c167efb8..e2cb211aa354885c6b451826e1498f90e1bf80f7 100644 --- a/public/reference/add_seq.html +++ b/public/reference/add_seq.html @@ -1,240 +1,240 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Add sequence to GRanges — add_seq • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Add sequence to GRanges — add_seq" /> -<meta property="og:description" content="Add sequence to GRanges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Add sequence to GRanges</h1> - - <div class="hidden name"><code>add_seq.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Add sequence to GRanges</p> - </div> - - <pre class="usage"><span class='fu'>add_seq</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, <span class='kw'>as.character</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - <tr> - <th>as.character</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - (<span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'>add_seq</span>(<span class='no'>bsgenome</span>))</div><div class='output co'>#> GRanges object with 4 ranges and 4 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699600 + | PRNP 4699600 4699600 -#> HBB chr11 5227002 - | HBB 5227002 5227002 -#> HEXA chr15 72346580-72346583 - | HEXA 72346580 72346583 -#> CFTR chr7 117559593-117559595 + | CFTR 117559593 117559595 -#> seq -#> <character> -#> PRNP G -#> HBB A -#> HEXA TATC -#> CFTR TTT -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_seq-1.png' alt='' width='700' height='433' /></div><div class='input'> (<span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'>add_seq</span>(<span class='no'>bsgenome</span>))</div><div class='output co'>#> GRanges object with 1974 ranges and 6 metadata columns: -#> seqnames ranges strand | name score targetname -#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> -#> T0001 chr1 4712628-4712643 - | SRF_MA0083.3 10.49542 T0001 -#> T0002 chr1 5250212-5250227 - | SRF_MA0083.3 9.7378 T0002 -#> T0003 chr1 5250452-5250467 - | SRF_MA0083.3 5.92033 T0003 -#> T0004 chr1 5256193-5256208 - | SRF_MA0083.3 9.7378 T0004 -#> T0005 chr1 5985728-5985743 - | SRF_MA0083.3 9.44821 T0005 -#> ... ... ... ... . ... ... ... -#> T1970 chrY 6770312-6770327 + | SRF_MA0083.3 9.7378 T1970 -#> T1971 chrY 23130568-23130583 + | SRF_MA0083.3 9.7378 T1971 -#> T1972 chrY 42512400-42512415 - | SRF_MA0083.3 6.59053 T1972 -#> T1973 chrY 79048176-79048191 - | SRF_MA0083.3 9.7378 T1973 -#> T1974 chrY 89126494-89126509 - | SRF_MA0083.3 4.54393 T1974 -#> targetstart targetend seq -#> <integer> <integer> <character> -#> T0001 4712628 4712643 AGACAATATAAGGGCA -#> T0002 5250212 5250227 AGACAATATAAGGACA -#> T0003 5250452 5250467 TGACAATATTTGGAAT -#> T0004 5256193 5256208 AGACAATATAAGGACA -#> T0005 5985728 5985743 CCACCAAATATGGGCT -#> ... ... ... ... -#> T1970 6770312 6770327 AGACAATATAAGGACA -#> T1971 23130568 23130583 AGACAATATAAGGACA -#> T1972 42512400 42512415 TGGCCAAATATGTGGA -#> T1973 79048176 79048191 AGACAATATAAGGACA -#> T1974 89126494 89126509 TGCCCATACTAGGGAG -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Add sequence to GRanges — add_seq • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Add sequence to GRanges — add_seq" /> +<meta property="og:description" content="Add sequence to GRanges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Add sequence to GRanges</h1> + + <div class="hidden name"><code>add_seq.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Add sequence to GRanges</p> + </div> + + <pre class="usage"><span class='fu'>add_seq</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, <span class='kw'>as.character</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + <tr> + <th>as.character</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + (<span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'>add_seq</span>(<span class='no'>bsgenome</span>))</div><div class='output co'>#> GRanges object with 4 ranges and 4 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699600 + | PRNP 4699600 4699600 +#> HBB chr11 5227002 - | HBB 5227002 5227002 +#> HEXA chr15 72346580-72346583 - | HEXA 72346580 72346583 +#> CFTR chr7 117559593-117559595 + | CFTR 117559593 117559595 +#> seq +#> <character> +#> PRNP G +#> HBB A +#> HEXA TATC +#> CFTR TTT +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_seq-1.png' alt='' width='700' height='433' /></div><div class='input'> (<span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'>add_seq</span>(<span class='no'>bsgenome</span>))</div><div class='output co'>#> GRanges object with 1974 ranges and 6 metadata columns: +#> seqnames ranges strand | name score targetname +#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> +#> T0001 chr1 4712628-4712643 - | SRF_MA0083.3 10.49542 T0001 +#> T0002 chr1 5250212-5250227 - | SRF_MA0083.3 9.7378 T0002 +#> T0003 chr1 5250452-5250467 - | SRF_MA0083.3 5.92033 T0003 +#> T0004 chr1 5256193-5256208 - | SRF_MA0083.3 9.7378 T0004 +#> T0005 chr1 5985728-5985743 - | SRF_MA0083.3 9.44821 T0005 +#> ... ... ... ... . ... ... ... +#> T1970 chrY 6770312-6770327 + | SRF_MA0083.3 9.7378 T1970 +#> T1971 chrY 23130568-23130583 + | SRF_MA0083.3 9.7378 T1971 +#> T1972 chrY 42512400-42512415 - | SRF_MA0083.3 6.59053 T1972 +#> T1973 chrY 79048176-79048191 - | SRF_MA0083.3 9.7378 T1973 +#> T1974 chrY 89126494-89126509 - | SRF_MA0083.3 4.54393 T1974 +#> targetstart targetend seq +#> <integer> <integer> <character> +#> T0001 4712628 4712643 AGACAATATAAGGGCA +#> T0002 5250212 5250227 AGACAATATAAGGACA +#> T0003 5250452 5250467 TGACAATATTTGGAAT +#> T0004 5256193 5256208 AGACAATATAAGGACA +#> T0005 5985728 5985743 CCACCAAATATGGGCT +#> ... ... ... ... +#> T1970 6770312 6770327 AGACAATATAAGGACA +#> T1971 23130568 23130583 AGACAATATAAGGACA +#> T1972 42512400 42512415 TGGCCAAATATGTGGA +#> T1973 79048176 79048191 AGACAATATAAGGACA +#> T1974 89126494 89126509 TGCCCATACTAGGGAG +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/add_target_counts-1.png b/public/reference/add_target_counts-1.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/add_target_counts-1.png and b/public/reference/add_target_counts-1.png differ diff --git a/public/reference/add_target_counts-2.png b/public/reference/add_target_counts-2.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/add_target_counts-2.png and b/public/reference/add_target_counts-2.png differ diff --git a/public/reference/add_target_counts.html b/public/reference/add_target_counts.html index b74ee154b8a10c16cd7dc6e972e183b122a5af30..d418e142a16db8d8fd2edc58a83f0b02b5ef123b 100644 --- a/public/reference/add_target_counts.html +++ b/public/reference/add_target_counts.html @@ -1,259 +1,259 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Add target counts — add_target_counts • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Add target counts — add_target_counts" /> -<meta property="og:description" content="Count spacer matches among targets" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Add target counts</h1> - - <div class="hidden name"><code>add_target_counts.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Count spacer matches among targets</p> - </div> - - <pre class="usage"><span class='fu'>add_target_counts</span>( - <span class='no'>spacers</span>, - <span class='no'>targets</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>spacers</th> - <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>targets</th> - <td><p>target <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>mismatches</th> - <td><p>number (default 2): max number of mismatches to consider</p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string (default 'NGG') pam pattern to expand</p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>dir where output is written to</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>updated spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>Expands iupac amgiguities in the pam sequence. -Matches all resulting sequences against (indexes) target and genome. -Adds match counts to GRanges object, and then returns it.</p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_target_counts-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_target_counts-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>add_target_counts</span>(<span class='no'>spacers</span>, <span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets/targets</span></div><div class='output co'>#> <span class='message'> Add target counts</span></div><div class='output co'>#> <span class='message'> Expand iupac ambiguities in pam</span></div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> GRanges object with 10159 ranges and 11 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> T0001_r_5 chr1 4712619-4712638 - | T0001 4712628 -#> T0001_r_4 chr1 4712620-4712639 - | T0001 4712628 -#> T0001_r_3 chr1 4712627-4712646 - | T0001 4712628 -#> T0001_r_2 chr1 4712633-4712652 - | T0001 4712628 -#> T0001_r_1 chr1 4712634-4712653 - | T0001 4712628 -#> ... ... ... ... . ... ... -#> T1974_r_3 chrY 89126492-89126511 - | T1974 89126494 -#> T1974_f_3 chrY 89126496-89126515 + | T1974 89126494 -#> T1974_r_2 chrY 89126499-89126518 - | T1974 89126494 -#> T1974_r_1 chrY 89126500-89126519 - | T1974 89126494 -#> T1974_f_4 chrY 89126501-89126520 + | T1974 89126494 -#> targetend crisprname crisprspacer crisprpam name -#> <integer> <character> <character> <character> <character> -#> T0001_r_5 4712643 T0001_r_5 ATATAAGGGCATTGGAAGAA GGG SRF_MA0083.3 -#> T0001_r_4 4712643 T0001_r_4 AATATAAGGGCATTGGAAGA AGG SRF_MA0083.3 -#> T0001_r_3 4712643 T0001_r_3 TGGAGACAATATAAGGGCAT TGG SRF_MA0083.3 -#> T0001_r_2 4712643 T0001_r_2 TTCTGCTGGAGACAATATAA GGG SRF_MA0083.3 -#> T0001_r_1 4712643 T0001_r_1 CTTCTGCTGGAGACAATATA AGG SRF_MA0083.3 -#> ... ... ... ... ... ... -#> T1974_r_3 89126509 T1974_r_3 TTTGCCCATACTAGGGAGAG CGG SRF_MA0083.3 -#> T1974_f_3 89126509 T1974_f_3 CCCTAGTATGGGCAAATATA TGG SRF_MA0083.3 -#> T1974_r_2 89126509 T1974_r_2 CCATATATTTGCCCATACTA GGG SRF_MA0083.3 -#> T1974_r_1 89126509 T1974_r_1 TCCATATATTTGCCCATACT AGG SRF_MA0083.3 -#> T1974_f_4 89126509 T1974_f_4 GTATGGGCAAATATATGGAA TGG SRF_MA0083.3 -#> score T0 T1 T2 -#> <numeric> <integer> <integer> <integer> -#> T0001_r_5 10.49542 1 973 97 -#> T0001_r_4 10.49542 1 960 105 -#> T0001_r_3 10.49542 1 975 95 -#> T0001_r_2 10.49542 2 827 237 -#> T0001_r_1 10.49542 825 242 19 -#> ... ... ... ... ... -#> T1974_r_3 4.54393 5 3 7 -#> T1974_f_3 4.54393 5 1 9 -#> T1974_r_2 4.54393 5 1 9 -#> T1974_r_1 4.54393 6 0 9 -#> T1974_f_4 4.54393 6 0 9 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Add target counts — add_target_counts • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Add target counts — add_target_counts" /> +<meta property="og:description" content="Count spacer matches among targets" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Add target counts</h1> + + <div class="hidden name"><code>add_target_counts.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Count spacer matches among targets</p> + </div> + + <pre class="usage"><span class='fu'>add_target_counts</span>( + <span class='no'>spacers</span>, + <span class='no'>targets</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>spacers</th> + <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>targets</th> + <td><p>target <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>mismatches</th> + <td><p>number (default 2): max number of mismatches to consider</p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string (default 'NGG') pam pattern to expand</p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>dir where output is written to</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>updated spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>Expands iupac amgiguities in the pam sequence. +Matches all resulting sequences against (indexes) target and genome. +Adds match counts to GRanges object, and then returns it.</p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='add_target_counts-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='add_target_counts-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>add_target_counts</span>(<span class='no'>spacers</span>, <span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets/targets</span></div><div class='output co'>#> <span class='message'> Add target counts</span></div><div class='output co'>#> <span class='message'> Expand iupac ambiguities in pam</span></div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> GRanges object with 10159 ranges and 11 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> T0001_r_5 chr1 4712619-4712638 - | T0001 4712628 +#> T0001_r_4 chr1 4712620-4712639 - | T0001 4712628 +#> T0001_r_3 chr1 4712627-4712646 - | T0001 4712628 +#> T0001_r_2 chr1 4712633-4712652 - | T0001 4712628 +#> T0001_r_1 chr1 4712634-4712653 - | T0001 4712628 +#> ... ... ... ... . ... ... +#> T1974_r_3 chrY 89126492-89126511 - | T1974 89126494 +#> T1974_f_3 chrY 89126496-89126515 + | T1974 89126494 +#> T1974_r_2 chrY 89126499-89126518 - | T1974 89126494 +#> T1974_r_1 chrY 89126500-89126519 - | T1974 89126494 +#> T1974_f_4 chrY 89126501-89126520 + | T1974 89126494 +#> targetend crisprname crisprspacer crisprpam name +#> <integer> <character> <character> <character> <character> +#> T0001_r_5 4712643 T0001_r_5 ATATAAGGGCATTGGAAGAA GGG SRF_MA0083.3 +#> T0001_r_4 4712643 T0001_r_4 AATATAAGGGCATTGGAAGA AGG SRF_MA0083.3 +#> T0001_r_3 4712643 T0001_r_3 TGGAGACAATATAAGGGCAT TGG SRF_MA0083.3 +#> T0001_r_2 4712643 T0001_r_2 TTCTGCTGGAGACAATATAA GGG SRF_MA0083.3 +#> T0001_r_1 4712643 T0001_r_1 CTTCTGCTGGAGACAATATA AGG SRF_MA0083.3 +#> ... ... ... ... ... ... +#> T1974_r_3 89126509 T1974_r_3 TTTGCCCATACTAGGGAGAG CGG SRF_MA0083.3 +#> T1974_f_3 89126509 T1974_f_3 CCCTAGTATGGGCAAATATA TGG SRF_MA0083.3 +#> T1974_r_2 89126509 T1974_r_2 CCATATATTTGCCCATACTA GGG SRF_MA0083.3 +#> T1974_r_1 89126509 T1974_r_1 TCCATATATTTGCCCATACT AGG SRF_MA0083.3 +#> T1974_f_4 89126509 T1974_f_4 GTATGGGCAAATATATGGAA TGG SRF_MA0083.3 +#> score T0 T1 T2 +#> <numeric> <integer> <integer> <integer> +#> T0001_r_5 10.49542 1 973 97 +#> T0001_r_4 10.49542 1 960 105 +#> T0001_r_3 10.49542 1 975 95 +#> T0001_r_2 10.49542 2 827 237 +#> T0001_r_1 10.49542 825 242 19 +#> ... ... ... ... ... +#> T1974_r_3 4.54393 5 3 7 +#> T1974_f_3 4.54393 5 1 9 +#> T1974_r_2 4.54393 5 1 9 +#> T1974_r_1 4.54393 6 0 9 +#> T1974_f_4 4.54393 6 0 9 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/as.granges.html b/public/reference/as.granges.html index 71365796f54bf12fc781b9ede5f40fd68b250ba2..da26c5e5046947c51673f4aefd4e9a78b047f96b 100644 --- a/public/reference/as.granges.html +++ b/public/reference/as.granges.html @@ -1,201 +1,201 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Convert data.table into GenomicRanges::GRanges — as.granges • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Convert data.table into GenomicRanges::GRanges — as.granges" /> - -<meta property="og:description" content="Convert data.table into GenomicRanges::GRanges" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Convert data.table into GenomicRanges::GRanges</h1> - - <div class="hidden name"><code>as.granges.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Convert data.table into GenomicRanges::GRanges</p> - - </div> - - <pre class="usage"><span class='fu'>as.granges</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>x</th> - <td><p>data.table</p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p>BSgenome, e.g. BSgenome.Mmusculus.UCSC.mm10::Mmusculus</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>)</div><div class='output co'>#> <span class='message'>Lade nötiges Paket: magrittr</span></div><div class='output co'>#> <span class='message'></span> -#> <span class='message'>Attache Paket: 'magrittr'</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:testthat':</span> -#> <span class='message'></span> -#> <span class='message'> equals, is_less_than, not</span></div><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span>$<span class='no'>seqs</span> <span class='kw'><-</span> <span class='fu'><a href='seqs.html'>seqs</a></span>(<span class='no'>granges</span>) -<span class='no'>x</span> <span class='kw'><-</span> <span class='no'>granges</span> <span class='kw'>%>%</span> <span class='kw pkg'>data.table</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/data.table/man/as.data.table.html'>as.data.table</a></span>() -<span class='no'>x</span> <span class='kw'>%>%</span> <span class='fu'>as.granges</span>(<span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='no'>bsgenome</span>)</div><div class='output co'>#> GRanges object with 1974 ranges and 1 metadata column: -#> seqnames ranges strand | seqs -#> <Rle> <IRanges> <Rle> | <character> -#> [1] chr1 4712627-4712643 - | AGACAATATAAGGGCAT -#> [2] chr1 5250211-5250227 - | AGACAATATAAGGACAT -#> [3] chr1 5250451-5250467 - | TGACAATATTTGGAATG -#> [4] chr1 5256192-5256208 - | AGACAATATAAGGACAT -#> [5] chr1 5985727-5985743 - | CCACCAAATATGGGCTT -#> ... ... ... ... . ... -#> [1970] chrY 6770311-6770327 + | GAGACAATATAAGGACA -#> [1971] chrY 23130567-23130583 + | GAGACAATATAAGGACA -#> [1972] chrY 42512399-42512415 - | TGGCCAAATATGTGGAA -#> [1973] chrY 79048175-79048191 - | AGACAATATAAGGACAT -#> [1974] chrY 89126493-89126509 - | TGCCCATACTAGGGAGA -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Convert data.table into GenomicRanges::GRanges — as.granges • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Convert data.table into GenomicRanges::GRanges — as.granges" /> + +<meta property="og:description" content="Convert data.table into GenomicRanges::GRanges" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Convert data.table into GenomicRanges::GRanges</h1> + + <div class="hidden name"><code>as.granges.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Convert data.table into GenomicRanges::GRanges</p> + + </div> + + <pre class="usage"><span class='fu'>as.granges</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>x</th> + <td><p>data.table</p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p>BSgenome, e.g. BSgenome.Mmusculus.UCSC.mm10::Mmusculus</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>)</div><div class='output co'>#> <span class='message'>Lade nötiges Paket: magrittr</span></div><div class='output co'>#> <span class='message'></span> +#> <span class='message'>Attache Paket: 'magrittr'</span></div><div class='output co'>#> <span class='message'>The following objects are masked from 'package:testthat':</span> +#> <span class='message'></span> +#> <span class='message'> equals, is_less_than, not</span></div><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span>$<span class='no'>seqs</span> <span class='kw'><-</span> <span class='fu'><a href='seqs.html'>seqs</a></span>(<span class='no'>granges</span>) +<span class='no'>x</span> <span class='kw'><-</span> <span class='no'>granges</span> <span class='kw'>%>%</span> <span class='kw pkg'>data.table</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/data.table/man/as.data.table.html'>as.data.table</a></span>() +<span class='no'>x</span> <span class='kw'>%>%</span> <span class='fu'>as.granges</span>(<span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='no'>bsgenome</span>)</div><div class='output co'>#> GRanges object with 1974 ranges and 1 metadata column: +#> seqnames ranges strand | seqs +#> <Rle> <IRanges> <Rle> | <character> +#> [1] chr1 4712627-4712643 - | AGACAATATAAGGGCAT +#> [2] chr1 5250211-5250227 - | AGACAATATAAGGACAT +#> [3] chr1 5250451-5250467 - | TGACAATATTTGGAATG +#> [4] chr1 5256192-5256208 - | AGACAATATAAGGACAT +#> [5] chr1 5985727-5985743 - | CCACCAAATATGGGCTT +#> ... ... ... ... . ... +#> [1970] chrY 6770311-6770327 + | GAGACAATATAAGGACA +#> [1971] chrY 23130567-23130583 + | GAGACAATATAAGGACA +#> [1972] chrY 42512399-42512415 - | TGGCCAAATATGTGGAA +#> [1973] chrY 79048175-79048191 - | AGACAATATAAGGACAT +#> [1974] chrY 89126493-89126509 - | TGCCCATACTAGGGAGA +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/assert_is_granges_datatable.html b/public/reference/assert_is_granges_datatable.html index 8d21cc01b6de0700f8ce599cb9c1c66a2aa4876b..aacee76d7d8e06109cd62a62f7a046ccd9748cb7 100644 --- a/public/reference/assert_is_granges_datatable.html +++ b/public/reference/assert_is_granges_datatable.html @@ -1,182 +1,182 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Assert that object is a genomic ranges datatable — assert_is_granges_datatable • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Assert that object is a genomic ranges datatable — assert_is_granges_datatable" /> - -<meta property="og:description" content="Assert that object is a genomic ranges datatable" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Assert that object is a genomic ranges datatable</h1> - - <div class="hidden name"><code>assert_is_granges_datatable.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Assert that object is a genomic ranges datatable</p> - - </div> - - <pre class="usage"><span class='fu'>assert_is_granges_datatable</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>x</th> - <td><p>data.table</p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p>BSgenome, e.g. BSgenome.Mmusculus.UCSC.mm10::Mmusculus</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>invisible(x)</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>x</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> <span class='kw pkg'>data.table</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/data.table/man/as.data.table.html'>as.data.table</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='fu'>assert_is_granges_datatable</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Assert that object is a genomic ranges datatable — assert_is_granges_datatable • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Assert that object is a genomic ranges datatable — assert_is_granges_datatable" /> + +<meta property="og:description" content="Assert that object is a genomic ranges datatable" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Assert that object is a genomic ranges datatable</h1> + + <div class="hidden name"><code>assert_is_granges_datatable.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Assert that object is a genomic ranges datatable</p> + + </div> + + <pre class="usage"><span class='fu'>assert_is_granges_datatable</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>x</th> + <td><p>data.table</p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p>BSgenome, e.g. BSgenome.Mmusculus.UCSC.mm10::Mmusculus</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>invisible(x)</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>x</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> <span class='kw pkg'>data.table</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/data.table/man/as.data.table.html'>as.data.table</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='fu'>assert_is_granges_datatable</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/bed_to_granges-1.png b/public/reference/bed_to_granges-1.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/bed_to_granges-1.png and b/public/reference/bed_to_granges-1.png differ diff --git a/public/reference/bed_to_granges.html b/public/reference/bed_to_granges.html index 8d70f63b8c4424fb89a3f0dfe22ef914ea1fe106..1d5bf8acffc65b227142e39c2051ef9d82a6d49e 100644 --- a/public/reference/bed_to_granges.html +++ b/public/reference/bed_to_granges.html @@ -1,234 +1,234 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Read bedfile into GRanges — bed_to_granges • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Read bedfile into GRanges — bed_to_granges" /> -<meta property="og:description" content="Read bedfile into GRanges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Read bedfile into GRanges</h1> - - <div class="hidden name"><code>bed_to_granges.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Read bedfile into GRanges</p> - </div> - - <pre class="usage"><span class='fu'>bed_to_granges</span>( - <span class='no'>bedfile</span>, - <span class='no'>genome</span>, - <span class='kw'>txdb</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, - <span class='kw'>do_order</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>bedfile</th> - <td><p>file path</p></td> - </tr> - <tr> - <th>genome</th> - <td><p>string: UCSC genome name (e.g. 'mm10')</p></td> - </tr> - <tr> - <th>txdb</th> - <td><p>NULL (default) or <code><a href='https://rdrr.io/pkg/GenomicFeatures/man/TxDb-class.html'>TxDb-class</a></code> -(used for gene annotation)</p></td> - </tr> - <tr> - <th>do_order</th> - <td><p>TRUE (default) or FALSE: order on seqnames and star?</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE: plot karyogram?</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='char_to_granges.html'>char_to_granges</a></code>, <code><a href='genes_to_granges.html'>genes_to_granges</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> -(<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>bed_to_granges</span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span><span class='kw'>=</span><span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='bed_to_granges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: -#> seqnames ranges strand | name score targetname -#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> -#> T0001 chr1 4712628-4712643 - | SRF_MA0083.3 10.49542 T0001 -#> T0002 chr1 5250212-5250227 - | SRF_MA0083.3 9.7378 T0002 -#> T0003 chr1 5250452-5250467 - | SRF_MA0083.3 5.92033 T0003 -#> T0004 chr1 5256193-5256208 - | SRF_MA0083.3 9.7378 T0004 -#> T0005 chr1 5985728-5985743 - | SRF_MA0083.3 9.44821 T0005 -#> ... ... ... ... . ... ... ... -#> T1970 chrY 6770312-6770327 + | SRF_MA0083.3 9.7378 T1970 -#> T1971 chrY 23130568-23130583 + | SRF_MA0083.3 9.7378 T1971 -#> T1972 chrY 42512400-42512415 - | SRF_MA0083.3 6.59053 T1972 -#> T1973 chrY 79048176-79048191 - | SRF_MA0083.3 9.7378 T1973 -#> T1974 chrY 89126494-89126509 - | SRF_MA0083.3 4.54393 T1974 -#> targetstart targetend -#> <integer> <integer> -#> T0001 4712628 4712643 -#> T0002 5250212 5250227 -#> T0003 5250452 5250467 -#> T0004 5256193 5256208 -#> T0005 5985728 5985743 -#> ... ... ... -#> T1970 6770312 6770327 -#> T1971 23130568 23130583 -#> T1972 42512400 42512415 -#> T1973 79048176 79048191 -#> T1974 89126494 89126509 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Read bedfile into GRanges — bed_to_granges • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Read bedfile into GRanges — bed_to_granges" /> +<meta property="og:description" content="Read bedfile into GRanges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Read bedfile into GRanges</h1> + + <div class="hidden name"><code>bed_to_granges.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Read bedfile into GRanges</p> + </div> + + <pre class="usage"><span class='fu'>bed_to_granges</span>( + <span class='no'>bedfile</span>, + <span class='no'>genome</span>, + <span class='kw'>txdb</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, + <span class='kw'>do_order</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>bedfile</th> + <td><p>file path</p></td> + </tr> + <tr> + <th>genome</th> + <td><p>string: UCSC genome name (e.g. 'mm10')</p></td> + </tr> + <tr> + <th>txdb</th> + <td><p>NULL (default) or <code><a href='https://rdrr.io/pkg/GenomicFeatures/man/TxDb-class.html'>TxDb-class</a></code> +(used for gene annotation)</p></td> + </tr> + <tr> + <th>do_order</th> + <td><p>TRUE (default) or FALSE: order on seqnames and star?</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE: plot karyogram?</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='char_to_granges.html'>char_to_granges</a></code>, <code><a href='genes_to_granges.html'>genes_to_granges</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> +(<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>bed_to_granges</span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span><span class='kw'>=</span><span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='bed_to_granges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: +#> seqnames ranges strand | name score targetname +#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> +#> T0001 chr1 4712628-4712643 - | SRF_MA0083.3 10.49542 T0001 +#> T0002 chr1 5250212-5250227 - | SRF_MA0083.3 9.7378 T0002 +#> T0003 chr1 5250452-5250467 - | SRF_MA0083.3 5.92033 T0003 +#> T0004 chr1 5256193-5256208 - | SRF_MA0083.3 9.7378 T0004 +#> T0005 chr1 5985728-5985743 - | SRF_MA0083.3 9.44821 T0005 +#> ... ... ... ... . ... ... ... +#> T1970 chrY 6770312-6770327 + | SRF_MA0083.3 9.7378 T1970 +#> T1971 chrY 23130568-23130583 + | SRF_MA0083.3 9.7378 T1971 +#> T1972 chrY 42512400-42512415 - | SRF_MA0083.3 6.59053 T1972 +#> T1973 chrY 79048176-79048191 - | SRF_MA0083.3 9.7378 T1973 +#> T1974 chrY 89126494-89126509 - | SRF_MA0083.3 4.54393 T1974 +#> targetstart targetend +#> <integer> <integer> +#> T0001 4712628 4712643 +#> T0002 5250212 5250227 +#> T0003 5250452 5250467 +#> T0004 5256193 5256208 +#> T0005 5985728 5985743 +#> ... ... ... +#> T1970 6770312 6770327 +#> T1971 23130568 23130583 +#> T1972 42512400 42512415 +#> T1973 79048176 79048191 +#> T1974 89126494 89126509 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/char_to_granges-1.png b/public/reference/char_to_granges-1.png index f0fa34196c666b3704b159254a7888d4b813190c..54d41d9dd4bf2b124e614623b2583164b4abc29d 100644 Binary files a/public/reference/char_to_granges-1.png and b/public/reference/char_to_granges-1.png differ diff --git a/public/reference/char_to_granges.html b/public/reference/char_to_granges.html index 8ec18a8ba2c694ed0466263bcbb8c7a9d6e55184..2374a2395f61ab3d44c76087659884323d6bf766 100644 --- a/public/reference/char_to_granges.html +++ b/public/reference/char_to_granges.html @@ -1,187 +1,187 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Convert character vector into GRanges — char_to_granges • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Convert character vector into GRanges — char_to_granges" /> -<meta property="og:description" content="Convert character vector into GRanges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Convert character vector into GRanges</h1> - - <div class="hidden name"><code>char_to_granges.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Convert character vector into GRanges</p> - </div> - - <pre class="usage"><span class='fu'>char_to_granges</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>x</th> - <td><p>character vector</p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='bed_to_granges.html'>bed_to_granges</a></code>, <code><a href='genes_to_granges.html'>genes_to_granges</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> -<span class='no'>x</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>) <span class='co'># ins</span> -<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>char_to_granges</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>) -<span class='fu'><a href='plot_intervals.html'>plot_intervals</a></span>(<span class='no'>gr</span>, <span class='kw'>facet_var</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>'targetname'</span>, <span class='st'>'seqnames'</span>))</div><div class='img'><img src='char_to_granges-1.png' alt='' width='700' height='433' /></div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Convert character vector into GRanges — char_to_granges • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Convert character vector into GRanges — char_to_granges" /> +<meta property="og:description" content="Convert character vector into GRanges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Convert character vector into GRanges</h1> + + <div class="hidden name"><code>char_to_granges.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Convert character vector into GRanges</p> + </div> + + <pre class="usage"><span class='fu'>char_to_granges</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>x</th> + <td><p>character vector</p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='bed_to_granges.html'>bed_to_granges</a></code>, <code><a href='genes_to_granges.html'>genes_to_granges</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> +<span class='no'>x</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>) <span class='co'># ins</span> +<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>char_to_granges</span>(<span class='no'>x</span>, <span class='no'>bsgenome</span>) +<span class='fu'><a href='plot_intervals.html'>plot_intervals</a></span>(<span class='no'>gr</span>, <span class='kw'>facet_var</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>'targetname'</span>, <span class='st'>'seqnames'</span>))</div><div class='img'><img src='char_to_granges-1.png' alt='' width='700' height='433' /></div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/cmessage.html b/public/reference/cmessage.html index 1dd60db6fbc5d633910e9989a35844ad1f99c9ab..6303bdfc067f6a3bbb09564e4b69389a08804a0c 100644 --- a/public/reference/cmessage.html +++ b/public/reference/cmessage.html @@ -1,165 +1,165 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Message with sprintf syntax — cmessage • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Message with sprintf syntax — cmessage" /> - -<meta property="og:description" content="Message with sprintf syntax" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Message with sprintf syntax</h1> - - <div class="hidden name"><code>cmessage.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Message with sprintf syntax</p> - - </div> - - <pre class="usage"><span class='fu'>cmessage</span>(<span class='no'>...</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>...</th> - <td><p>passed to message(sprintf(...))</p></td> - </tr> - </table> - - - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Message with sprintf syntax — cmessage • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Message with sprintf syntax — cmessage" /> + +<meta property="og:description" content="Message with sprintf syntax" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Message with sprintf syntax</h1> + + <div class="hidden name"><code>cmessage.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Message with sprintf syntax</p> + + </div> + + <pre class="usage"><span class='fu'>cmessage</span>(<span class='no'>...</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>...</th> + <td><p>passed to message(sprintf(...))</p></td> + </tr> + </table> + + + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/complement.html b/public/reference/complement.html index 9c65be5c9bef19737eb2c392e3beeaa9443f56ed..a49deb4a7d30826e28c4d8dd3e5616b15208512e 100644 --- a/public/reference/complement.html +++ b/public/reference/complement.html @@ -1,211 +1,211 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Complement granges — complement • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Complement granges — complement" /> - -<meta property="og:description" content="Complement granges" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Complement granges</h1> - - <div class="hidden name"><code>complement.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Complement granges</p> - - </div> - - <pre class="usage"><span class='fu'>complement</span>(<span class='no'>granges</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 - -#> [2] chr1 5250211-5250227 - -#> [3] chr1 5250451-5250467 - -#> [4] chr1 5256192-5256208 - -#> [5] chr1 5985727-5985743 - -#> ... ... ... ... -#> [1970] chrY 6770311-6770327 + -#> [1971] chrY 23130567-23130583 + -#> [1972] chrY 42512399-42512415 - -#> [1973] chrY 79048175-79048191 - -#> [1974] chrY 89126493-89126509 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='fu'>complement</span>(<span class='no'>granges</span>)</div><div class='output co'>#> <span class='message'> 1974 strand-complementary granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 + -#> [2] chr1 5250211-5250227 + -#> [3] chr1 5250451-5250467 + -#> [4] chr1 5256192-5256208 + -#> [5] chr1 5985727-5985743 + -#> ... ... ... ... -#> [1970] chrY 6770311-6770327 - -#> [1971] chrY 23130567-23130583 - -#> [1972] chrY 42512399-42512415 + -#> [1973] chrY 79048175-79048191 + -#> [1974] chrY 89126493-89126509 + -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Complement granges — complement • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Complement granges — complement" /> + +<meta property="og:description" content="Complement granges" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Complement granges</h1> + + <div class="hidden name"><code>complement.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Complement granges</p> + + </div> + + <pre class="usage"><span class='fu'>complement</span>(<span class='no'>granges</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 - +#> [2] chr1 5250211-5250227 - +#> [3] chr1 5250451-5250467 - +#> [4] chr1 5256192-5256208 - +#> [5] chr1 5985727-5985743 - +#> ... ... ... ... +#> [1970] chrY 6770311-6770327 + +#> [1971] chrY 23130567-23130583 + +#> [1972] chrY 42512399-42512415 - +#> [1973] chrY 79048175-79048191 - +#> [1974] chrY 89126493-89126509 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='fu'>complement</span>(<span class='no'>granges</span>)</div><div class='output co'>#> <span class='message'> 1974 strand-complementary granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 + +#> [2] chr1 5250211-5250227 + +#> [3] chr1 5250451-5250467 + +#> [4] chr1 5256192-5256208 + +#> [5] chr1 5985727-5985743 + +#> ... ... ... ... +#> [1970] chrY 6770311-6770327 - +#> [1971] chrY 23130567-23130583 - +#> [1972] chrY 42512399-42512415 + +#> [1973] chrY 79048175-79048191 + +#> [1974] chrY 89126493-89126509 + +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/contextseqs.html b/public/reference/contextseqs.html index 8c2e33b13330bfabe5137669d2364937d1ea0e85..f82655f4c9aa0f63cd3dca9602d815b228f8ef5c 100644 --- a/public/reference/contextseqs.html +++ b/public/reference/contextseqs.html @@ -1,176 +1,176 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Get contextseqs — contextseqs • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Get contextseqs — contextseqs" /> - -<meta property="og:description" content="Get [-3, +3] contextseqs for given cas9ranges" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Get contextseqs</h1> - - <div class="hidden name"><code>contextseqs.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Get [-3, +3] contextseqs for given cas9ranges</p> - - </div> - - <pre class="usage"><span class='fu'>contextseqs</span>(<span class='no'>cas9ranges</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>cas9ranges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - </table> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>cas9ranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> - <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>() <span class='kw'>%>%</span> - <span class='fu'><a href='find_cas9ranges.html'>find_cas9ranges</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='output co'>#> <span class='message'> Find N{20}NGG cas9seqs</span></div><div class='output co'>#> <span class='message'> Rm 10 targetranges with no cas9sites</span></div><div class='output co'>#> <span class='message'> 9922 cas9 seqs across 33518 targetranges</span></div><div class='input'><span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'><a href='seqs.html'>seqs</a></span>()</div><div class='output co'>#> [1] "CTCTAGAGTCACAGAACTTATGG" "AATTTATTATGACTTACAGTCGG" -#> [3] "TTCAGTTGCAGCTGTGAAAATGG"</div><div class='input'><span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'>contextseqs</span>()</div><div class='output co'>#> [1] "GGTTCTCTAGAGTCACAGAACTTATGGACA" "AAGGAATTTATTATGACTTACAGTCGGCAG" -#> [3] "ATTGTTCAGTTGCAGCTGTGAAAATGGAAG"</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Get contextseqs — contextseqs • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Get contextseqs — contextseqs" /> + +<meta property="og:description" content="Get [-3, +3] contextseqs for given cas9ranges" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Get contextseqs</h1> + + <div class="hidden name"><code>contextseqs.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Get [-3, +3] contextseqs for given cas9ranges</p> + + </div> + + <pre class="usage"><span class='fu'>contextseqs</span>(<span class='no'>cas9ranges</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>cas9ranges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + </table> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>cas9ranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> + <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>() <span class='kw'>%>%</span> + <span class='fu'><a href='find_cas9ranges.html'>find_cas9ranges</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='output co'>#> <span class='message'> Find N{20}NGG cas9seqs</span></div><div class='output co'>#> <span class='message'> Rm 10 targetranges with no cas9sites</span></div><div class='output co'>#> <span class='message'> 9922 cas9 seqs across 33518 targetranges</span></div><div class='input'><span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'><a href='seqs.html'>seqs</a></span>()</div><div class='output co'>#> [1] "CTCTAGAGTCACAGAACTTATGG" "AATTTATTATGACTTACAGTCGG" +#> [3] "TTCAGTTGCAGCTGTGAAAATGG"</div><div class='input'><span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'>contextseqs</span>()</div><div class='output co'>#> [1] "GGTTCTCTAGAGTCACAGAACTTATGGACA" "AAGGAATTTATTATGACTTACAGTCGGCAG" +#> [3] "ATTGTTCAGTTGCAGCTGTGAAAATGGAAG"</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/double_flank-1.png b/public/reference/double_flank-1.png index f5ef104f139d5e37eefb3415403344d4bf9e2825..6218fd2c6fd2bc4ebdeffa626835d9c62f5e45de 100644 Binary files a/public/reference/double_flank-1.png and b/public/reference/double_flank-1.png differ diff --git a/public/reference/double_flank-2.png b/public/reference/double_flank-2.png index 9a6f097ceea1b912be23b7ca4481745215ffe540..ca4cd182ce22984b1d19d4a9d9079e8d13133ea1 100644 Binary files a/public/reference/double_flank-2.png and b/public/reference/double_flank-2.png differ diff --git a/public/reference/double_flank.html b/public/reference/double_flank.html index ef237ee750fec7cc511414b0755d6c54203aaa80..0497267624ea4b296b207e4101f146a980548fa4 100644 --- a/public/reference/double_flank.html +++ b/public/reference/double_flank.html @@ -1,277 +1,277 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Double flank — double_flank • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Double flank — double_flank" /> -<meta property="og:description" content="Double flank" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Double flank</h1> - - <div class="hidden name"><code>double_flank.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Double flank</p> - </div> - - <pre class="usage"><span class='fu'>double_flank</span>( - <span class='no'>gr</span>, - <span class='kw'>upstart</span> <span class='kw'>=</span> -<span class='fl'>200</span>, - <span class='kw'>upend</span> <span class='kw'>=</span> -<span class='fl'>1</span>, - <span class='kw'>downstart</span> <span class='kw'>=</span> <span class='fl'>1</span>, - <span class='kw'>downend</span> <span class='kw'>=</span> <span class='fl'>200</span>, - <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, - <span class='no'>...</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>upstart</th> - <td><p>upstream flank start in relation to start(gr)</p></td> - </tr> - <tr> - <th>upend</th> - <td><p>upstream flank end in relation to start(gr)</p></td> - </tr> - <tr> - <th>downstart</th> - <td><p>downstream flank start in relation to end(gr)</p></td> - </tr> - <tr> - <th>downend</th> - <td><p>downstream flank end in relation to end(gr)</p></td> - </tr> - <tr> - <th>strandaware</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - <tr> - <th>linetype_var</th> - <td><p>gr var mapped to linetype</p></td> - </tr> - <tr> - <th>...</th> - <td><p>passed to plot_intervals</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># Prime Editing example</span> -<span class='co'>#----------------------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='fu'>double_flank</span>(<span class='no'>gr</span>, -<span class='fl'>10</span>, -<span class='fl'>1</span>, +<span class='fl'>1</span>, +<span class='fl'>20</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='message'> 8 flank ranges: 4 up + 4 down</span></div><div class='img'><img src='double_flank-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> PRNP_u chr20 4699590-4699599 + | PRNP 4699600 -#> HBB_u chr11 5227003-5227012 - | HBB 5227002 -#> HEXA_u chr15 72346584-72346593 - | HEXA 72346580 -#> CFTR_u chr7 117559583-117559592 + | CFTR 117559593 -#> PRNP_d chr20 4699601-4699620 + | PRNP 4699600 -#> HBB_d chr11 5226982-5227001 - | HBB 5227002 -#> HEXA_d chr15 72346560-72346579 - | HEXA 72346580 -#> CFTR_d chr7 117559596-117559615 + | CFTR 117559593 -#> targetend -#> <integer> -#> PRNP_u 4699600 -#> HBB_u 5227002 -#> HEXA_u 72346583 -#> CFTR_u 117559595 -#> PRNP_d 4699600 -#> HBB_d 5227002 -#> HEXA_d 72346583 -#> CFTR_d 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='input'> <span class='fu'>double_flank</span>(<span class='no'>gr</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='message'> 3948 flank ranges: 1974 up + 1974 down</span></div><div class='img'><img src='double_flank-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 3948 ranges and 5 metadata columns: -#> seqnames ranges strand | name score -#> <Rle> <IRanges> <Rle> | <character> <numeric> -#> T0001_u chr1 4712644-4712843 - | SRF_MA0083.3 10.49542 -#> T0002_u chr1 5250228-5250427 - | SRF_MA0083.3 9.7378 -#> T0003_u chr1 5250468-5250667 - | SRF_MA0083.3 5.92033 -#> T0004_u chr1 5256209-5256408 - | SRF_MA0083.3 9.7378 -#> T0005_u chr1 5985744-5985943 - | SRF_MA0083.3 9.44821 -#> ... ... ... ... . ... ... -#> T1970_d chrY 6770328-6770527 + | SRF_MA0083.3 9.7378 -#> T1971_d chrY 23130584-23130783 + | SRF_MA0083.3 9.7378 -#> T1972_d chrY 42512200-42512399 - | SRF_MA0083.3 6.59053 -#> T1973_d chrY 79047976-79048175 - | SRF_MA0083.3 9.7378 -#> T1974_d chrY 89126294-89126493 - | SRF_MA0083.3 4.54393 -#> targetname targetstart targetend -#> <character> <integer> <integer> -#> T0001_u T0001 4712628 4712643 -#> T0002_u T0002 5250212 5250227 -#> T0003_u T0003 5250452 5250467 -#> T0004_u T0004 5256193 5256208 -#> T0005_u T0005 5985728 5985743 -#> ... ... ... ... -#> T1970_d T1970 6770312 6770327 -#> T1971_d T1971 23130568 23130583 -#> T1972_d T1972 42512400 42512415 -#> T1973_d T1973 79048176 79048191 -#> T1974_d T1974 89126494 89126509 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Double flank — double_flank • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Double flank — double_flank" /> +<meta property="og:description" content="Double flank" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Double flank</h1> + + <div class="hidden name"><code>double_flank.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Double flank</p> + </div> + + <pre class="usage"><span class='fu'>double_flank</span>( + <span class='no'>gr</span>, + <span class='kw'>upstart</span> <span class='kw'>=</span> -<span class='fl'>200</span>, + <span class='kw'>upend</span> <span class='kw'>=</span> -<span class='fl'>1</span>, + <span class='kw'>downstart</span> <span class='kw'>=</span> <span class='fl'>1</span>, + <span class='kw'>downend</span> <span class='kw'>=</span> <span class='fl'>200</span>, + <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, + <span class='no'>...</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>upstart</th> + <td><p>upstream flank start in relation to start(gr)</p></td> + </tr> + <tr> + <th>upend</th> + <td><p>upstream flank end in relation to start(gr)</p></td> + </tr> + <tr> + <th>downstart</th> + <td><p>downstream flank start in relation to end(gr)</p></td> + </tr> + <tr> + <th>downend</th> + <td><p>downstream flank end in relation to end(gr)</p></td> + </tr> + <tr> + <th>strandaware</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + <tr> + <th>linetype_var</th> + <td><p>gr var mapped to linetype</p></td> + </tr> + <tr> + <th>...</th> + <td><p>passed to plot_intervals</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># Prime Editing example</span> +<span class='co'>#----------------------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='fu'>double_flank</span>(<span class='no'>gr</span>, -<span class='fl'>10</span>, -<span class='fl'>1</span>, +<span class='fl'>1</span>, +<span class='fl'>20</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='message'> 8 flank ranges: 4 up + 4 down</span></div><div class='img'><img src='double_flank-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> PRNP_u chr20 4699590-4699599 + | PRNP 4699600 +#> HBB_u chr11 5227003-5227012 - | HBB 5227002 +#> HEXA_u chr15 72346584-72346593 - | HEXA 72346580 +#> CFTR_u chr7 117559583-117559592 + | CFTR 117559593 +#> PRNP_d chr20 4699601-4699620 + | PRNP 4699600 +#> HBB_d chr11 5226982-5227001 - | HBB 5227002 +#> HEXA_d chr15 72346560-72346579 - | HEXA 72346580 +#> CFTR_d chr7 117559596-117559615 + | CFTR 117559593 +#> targetend +#> <integer> +#> PRNP_u 4699600 +#> HBB_u 5227002 +#> HEXA_u 72346583 +#> CFTR_u 117559595 +#> PRNP_d 4699600 +#> HBB_d 5227002 +#> HEXA_d 72346583 +#> CFTR_d 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='input'> <span class='fu'>double_flank</span>(<span class='no'>gr</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='message'> 3948 flank ranges: 1974 up + 1974 down</span></div><div class='img'><img src='double_flank-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 3948 ranges and 5 metadata columns: +#> seqnames ranges strand | name score +#> <Rle> <IRanges> <Rle> | <character> <numeric> +#> T0001_u chr1 4712644-4712843 - | SRF_MA0083.3 10.49542 +#> T0002_u chr1 5250228-5250427 - | SRF_MA0083.3 9.7378 +#> T0003_u chr1 5250468-5250667 - | SRF_MA0083.3 5.92033 +#> T0004_u chr1 5256209-5256408 - | SRF_MA0083.3 9.7378 +#> T0005_u chr1 5985744-5985943 - | SRF_MA0083.3 9.44821 +#> ... ... ... ... . ... ... +#> T1970_d chrY 6770328-6770527 + | SRF_MA0083.3 9.7378 +#> T1971_d chrY 23130584-23130783 + | SRF_MA0083.3 9.7378 +#> T1972_d chrY 42512200-42512399 - | SRF_MA0083.3 6.59053 +#> T1973_d chrY 79047976-79048175 - | SRF_MA0083.3 9.7378 +#> T1974_d chrY 89126294-89126493 - | SRF_MA0083.3 4.54393 +#> targetname targetstart targetend +#> <character> <integer> <integer> +#> T0001_u T0001 4712628 4712643 +#> T0002_u T0002 5250212 5250227 +#> T0003_u T0003 5250452 5250467 +#> T0004_u T0004 5256193 5256208 +#> T0005_u T0005 5985728 5985743 +#> ... ... ... ... +#> T1970_d T1970 6770312 6770327 +#> T1971_d T1971 23130568 23130583 +#> T1972_d T1972 42512400 42512415 +#> T1973_d T1973 79048176 79048191 +#> T1974_d T1974 89126494 89126509 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/extend_for_pe-1.png b/public/reference/extend_for_pe-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/extend_for_pe-1.png and b/public/reference/extend_for_pe-1.png differ diff --git a/public/reference/extend_for_pe-2.png b/public/reference/extend_for_pe-2.png index 81a9f5c744b832c768da6574277f3b600d569f4c..3ad37c1bb7faa30d9dd2254ffe54ca918721a6b0 100644 Binary files a/public/reference/extend_for_pe-2.png and b/public/reference/extend_for_pe-2.png differ diff --git a/public/reference/extend_for_pe-3.png b/public/reference/extend_for_pe-3.png index 81a9f5c744b832c768da6574277f3b600d569f4c..3ad37c1bb7faa30d9dd2254ffe54ca918721a6b0 100644 Binary files a/public/reference/extend_for_pe-3.png and b/public/reference/extend_for_pe-3.png differ diff --git a/public/reference/extend_for_pe.html b/public/reference/extend_for_pe.html index 5b42934af591cf6bbaa4eb9ace064c79ef481c8f..6878785691cdd8651690cf53cec27e163a435bbb 100644 --- a/public/reference/extend_for_pe.html +++ b/public/reference/extend_for_pe.html @@ -1,296 +1,296 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Extend ranges for prime editing — extend_for_pe • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Extend ranges for prime editing — extend_for_pe" /> -<meta property="og:description" content="Extend target ranges to span in which to look for spacer-pam seqs" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Extend ranges for prime editing</h1> - - <div class="hidden name"><code>extend_for_pe.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Extend target ranges to span in which to look for spacer-pam seqs</p> - </div> - - <pre class="usage"><span class='fu'>extend_for_pe</span>( - <span class='no'>gr</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>nrt</span> <span class='kw'>=</span> <span class='fl'>16</span>, - <span class='kw'>spacer</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>"N"</span>, <span class='fl'>20</span>), - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>nrt</th> - <td><p>number: reverse transcription length</p></td> - </tr> - <tr> - <th>spacer</th> - <td><p>string: spacer pattern in extended IUPAC alphabet</p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string: pam pattern in extended IUPAC alphabet</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>Extend target ranges to find nearby spacers for prime editing</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> -<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>( <span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='no'>bsgenome</span>) -<span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='extend_for_pe-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 9 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_1 chr7 117559575-117559594 + | CFTR 117559593 -#> CFTR_2 chr7 117559606-117559625 - | CFTR 117559593 -#> HBB_1 chr11 5227003-5227022 - | HBB 5227002 -#> HBB_2 chr11 5226984-5227003 + | HBB 5227002 -#> HEXA_1 chr15 72346551-72346570 + | HEXA 72346580 -#> HEXA_2 chr15 72346558-72346577 + | HEXA 72346580 -#> PRNP_1 chr20 4699568-4699587 + | PRNP 4699600 -#> PRNP_2 chr20 4699569-4699588 + | PRNP 4699600 -#> PRNP_3 chr20 4699575-4699594 + | PRNP 4699600 -#> PRNP_4 chr20 4699578-4699597 + | PRNP 4699600 -#> targetend crisprname crisprspacer crisprpam primer -#> <integer> <character> <character> <character> <character> -#> CFTR_1 117559595 CFTR_1 ATTAAAGAAAATATCATCTT TGG AAGAAAATATCAT -#> CFTR_2 117559595 CFTR_2 TCTGTATCTATATTCATCAT AGG TATCTATATTCAT -#> HBB_1 5227002 HBB_1 CATGGTGCATCTGACTCCTG AGG GTGCATCTGACTC -#> HBB_2 5227002 HBB_2 GTAACGGCAGACTTCTCCTC AGG CGGCAGACTTCTC -#> HEXA_1 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA GGG GAAATCCTTCCAG -#> HEXA_2 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT AGG TTCCAGTCAGGGC -#> PRNP_1 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG GGG GCTGGGGCAGTGG -#> PRNP_2 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG GGG CTGGGGCAGTGGT -#> PRNP_3 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT TGG CAGTGGTGGGGGG -#> PRNP_4 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG CGG TGGTGGGGGGCCT -#> revtranscript extension -#> <character> <character> -#> CFTR_1 CTTTGGTGTTTCCTAT ATAGGAAACACCAAAGATGATATTTTCTT -#> CFTR_2 CATAGGAAACACCAAA TTTGGTGTTTCCTATGATGAATATAGATA -#> HBB_1 CTGAGGAGAAGTCTGC GCAGACTTCTCCTCAGGAGTCAGATGCAC -#> HBB_2 CTCAGGAGTCAGATGC GCATCTGACTCCTGAGGAGAAGTCTGCCG -#> HEXA_1 TCAGGGCCATAGGATA TATCCTATGGCCCTGACTGGAAGGATTTC -#> HEXA_2 CATAGGATATACGGTT AACCGTATATCCTATGGCCCTGACTGGAA -#> PRNP_1 TGGGGGGCCTTGGCGG CCGCCAAGGCCCCCCACCACTGCCCCAGC -#> PRNP_2 GGGGGGCCTTGGCGGC GCCGCCAAGGCCCCCCACCACTGCCCCAG -#> PRNP_3 CCTTGGCGGCTACATG CATGTAGCCGCCAAGGCCCCCCACCACTG -#> PRNP_4 TGGCGGCTACATGCTG CAGCATGTAGCCGCCAAGGCCCCCCACCA -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'>(<span class='no'>grext</span> <span class='kw'><-</span> <span class='fu'>extend_for_pe</span>(<span class='no'>gr</span>))</div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> PRNP_f chr20 4699568-4699605 + | PRNP 4699600 -#> HBB_f chr11 5226970-5227007 + | HBB 5227002 -#> HEXA_f chr15 72346551-72346585 + | HEXA 72346580 -#> CFTR_f chr7 117559563-117559598 + | CFTR 117559593 -#> PRNP_r chr20 4699595-4699632 - | PRNP 4699600 -#> HBB_r chr11 5226997-5227034 - | HBB 5227002 -#> HEXA_r chr15 72346578-72346612 - | HEXA 72346580 -#> CFTR_r chr7 117559590-117559625 - | CFTR 117559593 -#> targetend -#> <integer> -#> PRNP_f 4699600 -#> HBB_f 5227002 -#> HEXA_f 72346583 -#> CFTR_f 117559595 -#> PRNP_r 4699600 -#> HBB_r 5227002 -#> HEXA_r 72346583 -#> CFTR_r 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>grext</span>, <span class='no'>bsgenome</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='img'><img src='extend_for_pe-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 6 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 -#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 -#> HBB_f chr11 5226984-5227003 + | HBB 5227002 -#> HBB_r chr11 5227003-5227022 - | HBB 5227002 -#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 -#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 -#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 -#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 -#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 -#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 -#> targetend crisprname crisprspacer crisprpam -#> <integer> <character> <character> <character> -#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG -#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG -#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG -#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG -#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG -#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG -#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG -#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG -#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG -#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Extend ranges for prime editing — extend_for_pe • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Extend ranges for prime editing — extend_for_pe" /> +<meta property="og:description" content="Extend target ranges to span in which to look for spacer-pam seqs" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Extend ranges for prime editing</h1> + + <div class="hidden name"><code>extend_for_pe.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Extend target ranges to span in which to look for spacer-pam seqs</p> + </div> + + <pre class="usage"><span class='fu'>extend_for_pe</span>( + <span class='no'>gr</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>nrt</span> <span class='kw'>=</span> <span class='fl'>16</span>, + <span class='kw'>spacer</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>"N"</span>, <span class='fl'>20</span>), + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>nrt</th> + <td><p>number: reverse transcription length</p></td> + </tr> + <tr> + <th>spacer</th> + <td><p>string: spacer pattern in extended IUPAC alphabet</p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string: pam pattern in extended IUPAC alphabet</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>Extend target ranges to find nearby spacers for prime editing</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> +<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>( <span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='no'>bsgenome</span>) +<span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='extend_for_pe-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 9 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_1 chr7 117559575-117559594 + | CFTR 117559593 +#> CFTR_2 chr7 117559606-117559625 - | CFTR 117559593 +#> HBB_1 chr11 5227003-5227022 - | HBB 5227002 +#> HBB_2 chr11 5226984-5227003 + | HBB 5227002 +#> HEXA_1 chr15 72346551-72346570 + | HEXA 72346580 +#> HEXA_2 chr15 72346558-72346577 + | HEXA 72346580 +#> PRNP_1 chr20 4699568-4699587 + | PRNP 4699600 +#> PRNP_2 chr20 4699569-4699588 + | PRNP 4699600 +#> PRNP_3 chr20 4699575-4699594 + | PRNP 4699600 +#> PRNP_4 chr20 4699578-4699597 + | PRNP 4699600 +#> targetend crisprname crisprspacer crisprpam primer +#> <integer> <character> <character> <character> <character> +#> CFTR_1 117559595 CFTR_1 ATTAAAGAAAATATCATCTT TGG AAGAAAATATCAT +#> CFTR_2 117559595 CFTR_2 TCTGTATCTATATTCATCAT AGG TATCTATATTCAT +#> HBB_1 5227002 HBB_1 CATGGTGCATCTGACTCCTG AGG GTGCATCTGACTC +#> HBB_2 5227002 HBB_2 GTAACGGCAGACTTCTCCTC AGG CGGCAGACTTCTC +#> HEXA_1 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA GGG GAAATCCTTCCAG +#> HEXA_2 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT AGG TTCCAGTCAGGGC +#> PRNP_1 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG GGG GCTGGGGCAGTGG +#> PRNP_2 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG GGG CTGGGGCAGTGGT +#> PRNP_3 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT TGG CAGTGGTGGGGGG +#> PRNP_4 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG CGG TGGTGGGGGGCCT +#> revtranscript extension +#> <character> <character> +#> CFTR_1 CTTTGGTGTTTCCTAT ATAGGAAACACCAAAGATGATATTTTCTT +#> CFTR_2 CATAGGAAACACCAAA TTTGGTGTTTCCTATGATGAATATAGATA +#> HBB_1 CTGAGGAGAAGTCTGC GCAGACTTCTCCTCAGGAGTCAGATGCAC +#> HBB_2 CTCAGGAGTCAGATGC GCATCTGACTCCTGAGGAGAAGTCTGCCG +#> HEXA_1 TCAGGGCCATAGGATA TATCCTATGGCCCTGACTGGAAGGATTTC +#> HEXA_2 CATAGGATATACGGTT AACCGTATATCCTATGGCCCTGACTGGAA +#> PRNP_1 TGGGGGGCCTTGGCGG CCGCCAAGGCCCCCCACCACTGCCCCAGC +#> PRNP_2 GGGGGGCCTTGGCGGC GCCGCCAAGGCCCCCCACCACTGCCCCAG +#> PRNP_3 CCTTGGCGGCTACATG CATGTAGCCGCCAAGGCCCCCCACCACTG +#> PRNP_4 TGGCGGCTACATGCTG CAGCATGTAGCCGCCAAGGCCCCCCACCA +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'>(<span class='no'>grext</span> <span class='kw'><-</span> <span class='fu'>extend_for_pe</span>(<span class='no'>gr</span>))</div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> PRNP_f chr20 4699568-4699605 + | PRNP 4699600 +#> HBB_f chr11 5226970-5227007 + | HBB 5227002 +#> HEXA_f chr15 72346551-72346585 + | HEXA 72346580 +#> CFTR_f chr7 117559563-117559598 + | CFTR 117559593 +#> PRNP_r chr20 4699595-4699632 - | PRNP 4699600 +#> HBB_r chr11 5226997-5227034 - | HBB 5227002 +#> HEXA_r chr15 72346578-72346612 - | HEXA 72346580 +#> CFTR_r chr7 117559590-117559625 - | CFTR 117559593 +#> targetend +#> <integer> +#> PRNP_f 4699600 +#> HBB_f 5227002 +#> HEXA_f 72346583 +#> CFTR_f 117559595 +#> PRNP_r 4699600 +#> HBB_r 5227002 +#> HEXA_r 72346583 +#> CFTR_r 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>grext</span>, <span class='no'>bsgenome</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='img'><img src='extend_for_pe-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 6 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 +#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 +#> HBB_f chr11 5226984-5227003 + | HBB 5227002 +#> HBB_r chr11 5227003-5227022 - | HBB 5227002 +#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 +#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 +#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 +#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 +#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 +#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 +#> targetend crisprname crisprspacer crisprpam +#> <integer> <character> <character> <character> +#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG +#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG +#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG +#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG +#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG +#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG +#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG +#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG +#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG +#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/extend_pe_to_gg.html b/public/reference/extend_pe_to_gg.html index 2e91bfe762e33a4bfb00278fa981b19ae16184ad..fff4359a72a6e644fa2dae864ce5103511c29b78 100644 --- a/public/reference/extend_pe_to_gg.html +++ b/public/reference/extend_pe_to_gg.html @@ -1,213 +1,213 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Extend prime editing target to find GG sites — extend_pe_to_gg • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Extend prime editing target to find GG sites — extend_pe_to_gg" /> -<meta property="og:description" content="Extend prime editing target to find GG sites in accessible neighbourhood" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Extend prime editing target to find GG sites</h1> - - <div class="hidden name"><code>extend_pe_to_gg.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Extend prime editing target to find GG sites in accessible neighbourhood</p> - </div> - - <pre class="usage"><span class='fu'>extend_pe_to_gg</span>(<span class='no'>gr</span>, <span class='kw'>nrt</span> <span class='kw'>=</span> <span class='fl'>16</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p>target <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>nrt</th> - <td><p>n RT nucleotides (default 16, recommended 10-16)</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>Extends each target range to the area in which to search for a prime editing -GG duplet, as shown in the sketch below.</p> -<p>===============> - ----GG---------> - ----GG---------> - ** - <---------GG--- - <---------GG---- - <===============</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='fu'>extend_pe_to_gg</span>(<span class='no'>gr</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> CFTR chr7 117559584-117559598 + | CFTR 117559593 117559595 -#> CFTR chr7 117559590-117559604 - | CFTR 117559593 117559595 -#> HBB chr11 5226991-5227007 + | HBB 5227002 5227002 -#> HBB chr11 5226997-5227013 - | HBB 5227002 5227002 -#> HEXA chr15 72346572-72346585 + | HEXA 72346580 72346583 -#> HEXA chr15 72346578-72346591 - | HEXA 72346580 72346583 -#> PRNP chr20 4699589-4699605 + | PRNP 4699600 4699600 -#> PRNP chr20 4699595-4699611 - | PRNP 4699600 4699600 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Extend prime editing target to find GG sites — extend_pe_to_gg • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Extend prime editing target to find GG sites — extend_pe_to_gg" /> +<meta property="og:description" content="Extend prime editing target to find GG sites in accessible neighbourhood" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Extend prime editing target to find GG sites</h1> + + <div class="hidden name"><code>extend_pe_to_gg.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Extend prime editing target to find GG sites in accessible neighbourhood</p> + </div> + + <pre class="usage"><span class='fu'>extend_pe_to_gg</span>(<span class='no'>gr</span>, <span class='kw'>nrt</span> <span class='kw'>=</span> <span class='fl'>16</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p>target <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>nrt</th> + <td><p>n RT nucleotides (default 16, recommended 10-16)</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>Extends each target range to the area in which to search for a prime editing +GG duplet, as shown in the sketch below.</p> +<p>===============> + ----GG---------> + ----GG---------> + ** + <---------GG--- + <---------GG---- + <===============</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='fu'>extend_pe_to_gg</span>(<span class='no'>gr</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> GRanges object with 8 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> CFTR chr7 117559584-117559598 + | CFTR 117559593 117559595 +#> CFTR chr7 117559590-117559604 - | CFTR 117559593 117559595 +#> HBB chr11 5226991-5227007 + | HBB 5227002 5227002 +#> HBB chr11 5226997-5227013 - | HBB 5227002 5227002 +#> HEXA chr15 72346572-72346585 + | HEXA 72346580 72346583 +#> HEXA chr15 72346578-72346591 - | HEXA 72346580 72346583 +#> PRNP chr20 4699589-4699605 + | PRNP 4699600 4699600 +#> PRNP chr20 4699595-4699611 - | PRNP 4699600 4699600 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/extract_matchranges-1.png b/public/reference/extract_matchranges-1.png index 5e003d8a12d797dbedc23943340fa1238c0f8ef6..91881418cd3f1d2343a798f587f2d2b69ce13c64 100644 Binary files a/public/reference/extract_matchranges-1.png and b/public/reference/extract_matchranges-1.png differ diff --git a/public/reference/extract_matchranges-2.png b/public/reference/extract_matchranges-2.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/extract_matchranges-2.png and b/public/reference/extract_matchranges-2.png differ diff --git a/public/reference/extract_matchranges-3.png b/public/reference/extract_matchranges-3.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/extract_matchranges-3.png and b/public/reference/extract_matchranges-3.png differ diff --git a/public/reference/extract_matchranges.html b/public/reference/extract_matchranges.html index 7c29f404130aa447f5b6b9d8b08cb105a0dd1622..ebeb00361bf2ed74b1fc960fa696d4808f3dff21 100644 --- a/public/reference/extract_matchranges.html +++ b/public/reference/extract_matchranges.html @@ -1,254 +1,254 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Extract matching subranges — extract_matchranges • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Extract matching subranges — extract_matchranges" /> -<meta property="og:description" content="Extract subranges that match pattern" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Extract matching subranges</h1> - - <div class="hidden name"><code>extract_matchranges.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Extract subranges that match pattern</p> - </div> - - <pre class="usage"><span class='fu'>extract_matchranges</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='no'>pattern</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code>BSgenome{BSgenome-class}</code></p></td> - </tr> - <tr> - <th>pattern</th> - <td><p>string: search pattern in extended IUPAC alphabet</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#------------</span> -<span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> -<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) -<span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>() -<span class='no'>pattern</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>'N'</span>,<span class='fl'>20</span>) <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/base/paste.html'>paste0</a></span>(<span class='st'>'NGG'</span>) -<span class='fu'>extract_matchranges</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='no'>pattern</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='img'><img src='extract_matchranges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_f chr7 117559575-117559597 + | CFTR 117559593 -#> CFTR_r chr7 117559603-117559625 - | CFTR 117559593 -#> HBB_f chr11 5226984-5227006 + | HBB 5227002 -#> HBB_r chr11 5227000-5227022 - | HBB 5227002 -#> HEXA_f_1 chr15 72346551-72346573 + | HEXA 72346580 -#> HEXA_f_2 chr15 72346558-72346580 + | HEXA 72346580 -#> PRNP_f_1 chr20 4699568-4699590 + | PRNP 4699600 -#> PRNP_f_2 chr20 4699569-4699591 + | PRNP 4699600 -#> PRNP_f_3 chr20 4699575-4699597 + | PRNP 4699600 -#> PRNP_f_4 chr20 4699578-4699600 + | PRNP 4699600 -#> targetend -#> <integer> -#> CFTR_f 117559595 -#> CFTR_r 117559595 -#> HBB_f 5227002 -#> HBB_r 5227002 -#> HEXA_f_1 72346583 -#> HEXA_f_2 72346583 -#> PRNP_f_1 4699600 -#> PRNP_f_2 4699600 -#> PRNP_f_3 4699600 -#> PRNP_f_4 4699600 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> -<span class='co'># TFBS examples</span> -<span class='co'>#--------------</span> -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) -<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>) <span class='kw'>%>%</span> <span class='fu'><a href='up_flank.html'>extend</a></span>()</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='extract_matchranges-2.png' alt='' width='700' height='433' /></div><div class='input'><span class='fu'>extract_matchranges</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='kw'>pattern</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>'N'</span>,<span class='fl'>20</span>) <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/base/paste.html'>paste0</a></span>(<span class='st'>'NGG'</span>))</div><div class='output co'>#> GRanges object with 6616 ranges and 5 metadata columns: -#> seqnames ranges strand | name score -#> <Rle> <IRanges> <Rle> | <character> <numeric> -#> T0001_5 chr1 4712616-4712638 - | SRF_MA0083.3 10.49542 -#> T0001_4 chr1 4712617-4712639 - | SRF_MA0083.3 10.49542 -#> T0001_3 chr1 4712624-4712646 - | SRF_MA0083.3 10.49542 -#> T0001_2 chr1 4712630-4712652 - | SRF_MA0083.3 10.49542 -#> T0001_1 chr1 4712631-4712653 - | SRF_MA0083.3 10.49542 -#> ... ... ... ... . ... ... -#> T1973_2 chrY 79048172-79048194 - | SRF_MA0083.3 9.7378 -#> T1973_1 chrY 79048179-79048201 - | SRF_MA0083.3 9.7378 -#> T1974_3 chrY 89126489-89126511 - | SRF_MA0083.3 4.54393 -#> T1974_2 chrY 89126496-89126518 - | SRF_MA0083.3 4.54393 -#> T1974_1 chrY 89126497-89126519 - | SRF_MA0083.3 4.54393 -#> targetname targetstart targetend -#> <character> <integer> <integer> -#> T0001_5 T0001 4712628 4712643 -#> T0001_4 T0001 4712628 4712643 -#> T0001_3 T0001 4712628 4712643 -#> T0001_2 T0001 4712628 4712643 -#> T0001_1 T0001 4712628 4712643 -#> ... ... ... ... -#> T1973_2 T1973 79048176 79048191 -#> T1973_1 T1973 79048176 79048191 -#> T1974_3 T1974 89126494 89126509 -#> T1974_2 T1974 89126494 89126509 -#> T1974_1 T1974 89126494 89126509 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Extract matching subranges — extract_matchranges • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Extract matching subranges — extract_matchranges" /> +<meta property="og:description" content="Extract subranges that match pattern" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Extract matching subranges</h1> + + <div class="hidden name"><code>extract_matchranges.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Extract subranges that match pattern</p> + </div> + + <pre class="usage"><span class='fu'>extract_matchranges</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='no'>pattern</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code>BSgenome{BSgenome-class}</code></p></td> + </tr> + <tr> + <th>pattern</th> + <td><p>string: search pattern in extended IUPAC alphabet</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#------------</span> +<span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> +<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) +<span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>() +<span class='no'>pattern</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>'N'</span>,<span class='fl'>20</span>) <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/base/paste.html'>paste0</a></span>(<span class='st'>'NGG'</span>) +<span class='fu'>extract_matchranges</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='no'>pattern</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='img'><img src='extract_matchranges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_f chr7 117559575-117559597 + | CFTR 117559593 +#> CFTR_r chr7 117559603-117559625 - | CFTR 117559593 +#> HBB_f chr11 5226984-5227006 + | HBB 5227002 +#> HBB_r chr11 5227000-5227022 - | HBB 5227002 +#> HEXA_f_1 chr15 72346551-72346573 + | HEXA 72346580 +#> HEXA_f_2 chr15 72346558-72346580 + | HEXA 72346580 +#> PRNP_f_1 chr20 4699568-4699590 + | PRNP 4699600 +#> PRNP_f_2 chr20 4699569-4699591 + | PRNP 4699600 +#> PRNP_f_3 chr20 4699575-4699597 + | PRNP 4699600 +#> PRNP_f_4 chr20 4699578-4699600 + | PRNP 4699600 +#> targetend +#> <integer> +#> CFTR_f 117559595 +#> CFTR_r 117559595 +#> HBB_f 5227002 +#> HBB_r 5227002 +#> HEXA_f_1 72346583 +#> HEXA_f_2 72346583 +#> PRNP_f_1 4699600 +#> PRNP_f_2 4699600 +#> PRNP_f_3 4699600 +#> PRNP_f_4 4699600 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> +<span class='co'># TFBS examples</span> +<span class='co'>#--------------</span> +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) +<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>) <span class='kw'>%>%</span> <span class='fu'><a href='up_flank.html'>extend</a></span>()</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='extract_matchranges-2.png' alt='' width='700' height='433' /></div><div class='input'><span class='fu'>extract_matchranges</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>, <span class='kw'>pattern</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>'N'</span>,<span class='fl'>20</span>) <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/base/paste.html'>paste0</a></span>(<span class='st'>'NGG'</span>))</div><div class='output co'>#> GRanges object with 6616 ranges and 5 metadata columns: +#> seqnames ranges strand | name score +#> <Rle> <IRanges> <Rle> | <character> <numeric> +#> T0001_5 chr1 4712616-4712638 - | SRF_MA0083.3 10.49542 +#> T0001_4 chr1 4712617-4712639 - | SRF_MA0083.3 10.49542 +#> T0001_3 chr1 4712624-4712646 - | SRF_MA0083.3 10.49542 +#> T0001_2 chr1 4712630-4712652 - | SRF_MA0083.3 10.49542 +#> T0001_1 chr1 4712631-4712653 - | SRF_MA0083.3 10.49542 +#> ... ... ... ... . ... ... +#> T1973_2 chrY 79048172-79048194 - | SRF_MA0083.3 9.7378 +#> T1973_1 chrY 79048179-79048201 - | SRF_MA0083.3 9.7378 +#> T1974_3 chrY 89126489-89126511 - | SRF_MA0083.3 4.54393 +#> T1974_2 chrY 89126496-89126518 - | SRF_MA0083.3 4.54393 +#> T1974_1 chrY 89126497-89126519 - | SRF_MA0083.3 4.54393 +#> targetname targetstart targetend +#> <character> <integer> <integer> +#> T0001_5 T0001 4712628 4712643 +#> T0001_4 T0001 4712628 4712643 +#> T0001_3 T0001 4712628 4712643 +#> T0001_2 T0001 4712628 4712643 +#> T0001_1 T0001 4712628 4712643 +#> ... ... ... ... +#> T1973_2 T1973 79048176 79048191 +#> T1973_1 T1973 79048176 79048191 +#> T1974_3 T1974 89126494 89126509 +#> T1974_2 T1974 89126494 89126509 +#> T1974_1 T1974 89126494 89126509 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/extract_subranges-1.png b/public/reference/extract_subranges-1.png index 9a8bf3b15e2fdf5b4349bfd572f19c9833de42fa..84f4efa7ce2e54307589f3acb16fd988a663eaeb 100644 Binary files a/public/reference/extract_subranges-1.png and b/public/reference/extract_subranges-1.png differ diff --git a/public/reference/extract_subranges.html b/public/reference/extract_subranges.html index 1fb9156112d14560dc222f0a50288660837c13a2..83b1ee35ccc9bcfe0ea12069c6b9127cee8f88e1 100644 --- a/public/reference/extract_subranges.html +++ b/public/reference/extract_subranges.html @@ -1,191 +1,191 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Extract subranges — extract_subranges • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Extract subranges — extract_subranges" /> -<meta property="og:description" content="Extract subranges from a GRanges-class object" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Extract subranges</h1> - - <div class="hidden name"><code>extract_subranges.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Extract subranges from a <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code> object</p> - </div> - - <pre class="usage"><span class='fu'>extract_subranges</span>(<span class='no'>gr</span>, <span class='no'>ir</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>ir</th> - <td><p><code><a href='https://rdrr.io/pkg/IRanges/man/IRanges-class.html'>IRanges-class</a></code>: subranges to be extracted</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code>.</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='no'>gr</span> <span class='kw'><-</span> <span class='kw pkg'>GenomicRanges</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>A</span> <span class='kw'>=</span> <span class='st'>'chr1:1-100:+'</span>, <span class='kw'>B</span> <span class='kw'>=</span> <span class='st'>'chr1:1-100:-'</span>)) -<span class='no'>gr</span>$<span class='no'>targetname</span> <span class='kw'><-</span> <span class='st'>'AB'</span> -<span class='no'>ir</span> <span class='kw'><-</span> <span class='kw pkg'>IRanges</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/IRanges/man/IRanges-constructor.html'>IRanges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>A</span> <span class='kw'>=</span> <span class='st'>'1-10'</span>, <span class='kw'>A</span> <span class='kw'>=</span> <span class='st'>'11-20'</span>, <span class='kw'>B</span> <span class='kw'>=</span> <span class='st'>'1-10'</span>, <span class='kw'>B</span> <span class='kw'>=</span> <span class='st'>'11-20'</span>)) -<span class='fu'>extract_subranges</span>(<span class='no'>gr</span>, <span class='no'>ir</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='img'><img src='extract_subranges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 1 metadata column: -#> seqnames ranges strand | targetname -#> <Rle> <IRanges> <Rle> | <character> -#> A_1 chr1 1-10 + | AB -#> A_2 chr1 11-20 + | AB -#> B_1 chr1 91-100 - | AB -#> B_2 chr1 81-90 - | AB -#> ------- -#> seqinfo: 1 sequence from an unspecified genome; no seqlengths</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Extract subranges — extract_subranges • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Extract subranges — extract_subranges" /> +<meta property="og:description" content="Extract subranges from a GRanges-class object" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Extract subranges</h1> + + <div class="hidden name"><code>extract_subranges.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Extract subranges from a <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code> object</p> + </div> + + <pre class="usage"><span class='fu'>extract_subranges</span>(<span class='no'>gr</span>, <span class='no'>ir</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>ir</th> + <td><p><code><a href='https://rdrr.io/pkg/IRanges/man/IRanges-class.html'>IRanges-class</a></code>: subranges to be extracted</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code>.</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='no'>gr</span> <span class='kw'><-</span> <span class='kw pkg'>GenomicRanges</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>A</span> <span class='kw'>=</span> <span class='st'>'chr1:1-100:+'</span>, <span class='kw'>B</span> <span class='kw'>=</span> <span class='st'>'chr1:1-100:-'</span>)) +<span class='no'>gr</span>$<span class='no'>targetname</span> <span class='kw'><-</span> <span class='st'>'AB'</span> +<span class='no'>ir</span> <span class='kw'><-</span> <span class='kw pkg'>IRanges</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/IRanges/man/IRanges-constructor.html'>IRanges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>A</span> <span class='kw'>=</span> <span class='st'>'1-10'</span>, <span class='kw'>A</span> <span class='kw'>=</span> <span class='st'>'11-20'</span>, <span class='kw'>B</span> <span class='kw'>=</span> <span class='st'>'1-10'</span>, <span class='kw'>B</span> <span class='kw'>=</span> <span class='st'>'11-20'</span>)) +<span class='fu'>extract_subranges</span>(<span class='no'>gr</span>, <span class='no'>ir</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='img'><img src='extract_subranges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 1 metadata column: +#> seqnames ranges strand | targetname +#> <Rle> <IRanges> <Rle> | <character> +#> A_1 chr1 1-10 + | AB +#> A_2 chr1 11-20 + | AB +#> B_1 chr1 91-100 - | AB +#> B_2 chr1 81-90 - | AB +#> ------- +#> seqinfo: 1 sequence from an unspecified genome; no seqlengths</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/filter_prime_specific-1.png b/public/reference/filter_prime_specific-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/filter_prime_specific-1.png and b/public/reference/filter_prime_specific-1.png differ diff --git a/public/reference/filter_prime_specific.html b/public/reference/filter_prime_specific.html index 1d4fbf2b6dbed364c893b3be01ec60264e3169dd..46bf3f7df128d3daccb1af261d29859bc9816c5d 100644 --- a/public/reference/filter_prime_specific.html +++ b/public/reference/filter_prime_specific.html @@ -1,210 +1,210 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Filter for specific prime editing spacers — filter_prime_specific • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Filter for specific prime editing spacers — filter_prime_specific" /> -<meta property="og:description" content="Filters spacers which are specific for prime editing site" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">multicrispr: gRNA design for Crispr/Cas9 and Prime Editing</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Filter for specific prime editing spacers</h1> - - <div class="hidden name"><code>filter_prime_specific.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Filters spacers which are specific for prime editing site</p> - </div> - - <pre class="usage"><span class='fu'>filter_prime_specific</span>( - <span class='no'>spacers</span>, - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>spacers</span>)[<span class='fl'>1</span>]), - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>spacers</th> - <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string (default 'NGG'): pam sequence</p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>string: dir to which output is written</p></td> - </tr> - <tr> - <th>indexedgenomesdir</th> - <td><p>dir with bowtie-indexed genomes</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>filtered spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='filter_prime_specific-1.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) # one time effort - takes few h - # filter_prime_specific(spacers, bsgenome) -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Filter for specific prime editing spacers — filter_prime_specific • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Filter for specific prime editing spacers — filter_prime_specific" /> +<meta property="og:description" content="Filters spacers which are specific for prime editing site" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">multicrispr: gRNA design for Crispr/Cas9 and Prime Editing</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Filter for specific prime editing spacers</h1> + + <div class="hidden name"><code>filter_prime_specific.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Filters spacers which are specific for prime editing site</p> + </div> + + <pre class="usage"><span class='fu'>filter_prime_specific</span>( + <span class='no'>spacers</span>, + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>spacers</span>)[<span class='fl'>1</span>]), + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>spacers</th> + <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string (default 'NGG'): pam sequence</p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>string: dir to which output is written</p></td> + </tr> + <tr> + <th>indexedgenomesdir</th> + <td><p>dir with bowtie-indexed genomes</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>filtered spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='filter_prime_specific-1.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) # one time effort - takes few h + # filter_prime_specific(spacers, bsgenome) +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/filter_target_specific-1.png b/public/reference/filter_target_specific-1.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/filter_target_specific-1.png and b/public/reference/filter_target_specific-1.png differ diff --git a/public/reference/filter_target_specific-2.png b/public/reference/filter_target_specific-2.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/filter_target_specific-2.png and b/public/reference/filter_target_specific-2.png differ diff --git a/public/reference/filter_target_specific.html b/public/reference/filter_target_specific.html index aa84189efe486b840c5a6975989c383ed00e4646..ec56d1586d373728d7856976bbfd8d50e81b8fbe 100644 --- a/public/reference/filter_target_specific.html +++ b/public/reference/filter_target_specific.html @@ -1,234 +1,234 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Filter for target-specific spacers — add_specificity • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Filter for target-specific spacers — add_specificity" /> -<meta property="og:description" content="Filter for target-specific spacers" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">multicrispr: gRNA design for Crispr/Cas9 and Prime Editing</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Filter for target-specific spacers</h1> - - <div class="hidden name"><code>filter_target_specific.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Filter for target-specific spacers</p> - </div> - - <pre class="usage"><span class='fu'>add_specificity</span>( - <span class='no'>spacers</span>, - <span class='no'>targets</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -) - -<span class='fu'>filter_target_specific</span>( - <span class='no'>spacers</span>, - <span class='no'>targets</span>, - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>spacers</span>)[<span class='fl'>1</span>]), - <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>spacers</th> - <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>targets</th> - <td><p>target <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>mismatches</th> - <td><p>number (default 2): max number of mismatches to consider</p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string (default 'NGG'): pam sequence</p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>directory where output is written to</p></td> - </tr> - <tr> - <th>indexedgenomesdir</th> - <td><p>string: dir with indexed genomes</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>filtered spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='filter_target_specific-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='filter_target_specific-2.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) - # spacers %<>% add_specificity(targets, bsgenome) - # spacers %>% filter_target_specific(targets, bsgenome) -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Filter for target-specific spacers — add_specificity • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Filter for target-specific spacers — add_specificity" /> +<meta property="og:description" content="Filter for target-specific spacers" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">multicrispr: gRNA design for Crispr/Cas9 and Prime Editing</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Filter for target-specific spacers</h1> + + <div class="hidden name"><code>filter_target_specific.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Filter for target-specific spacers</p> + </div> + + <pre class="usage"><span class='fu'>add_specificity</span>( + <span class='no'>spacers</span>, + <span class='no'>targets</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +) + +<span class='fu'>filter_target_specific</span>( + <span class='no'>spacers</span>, + <span class='no'>targets</span>, + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>spacers</span>)[<span class='fl'>1</span>]), + <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>spacers</th> + <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>targets</th> + <td><p>target <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>mismatches</th> + <td><p>number (default 2): max number of mismatches to consider</p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string (default 'NGG'): pam sequence</p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>directory where output is written to</p></td> + </tr> + <tr> + <th>indexedgenomesdir</th> + <td><p>string: dir with indexed genomes</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>filtered spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='filter_target_specific-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='filter_target_specific-2.png' alt='' width='700' height='433' /></div><div class='input'> # index_genome(bsgenome) + # spacers %<>% add_specificity(targets, bsgenome) + # spacers %>% filter_target_specific(targets, bsgenome) +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/find_cas9ranges.html b/public/reference/find_cas9ranges.html index 4b9ff9ba6315ae40cf0ebf1cdb858c35d92982bf..5e2b1df09c36f448dffbe27296938fa328e5d5d7 100644 --- a/public/reference/find_cas9ranges.html +++ b/public/reference/find_cas9ranges.html @@ -1,197 +1,197 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Find cas9 ranges in targetranges — find_cas9ranges • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Find cas9 ranges in targetranges — find_cas9ranges" /> - -<meta property="og:description" content="Find cas9 ranges in targetranges" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Find cas9 ranges in targetranges</h1> - - <div class="hidden name"><code>find_cas9ranges.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Find cas9 ranges in targetranges</p> - - </div> - - <pre class="usage"><span class='fu'>find_cas9ranges</span>(<span class='no'>targetranges</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>targetranges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>targetranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='input'><span class='fu'>find_cas9ranges</span>(<span class='no'>targetranges</span>)</div><div class='output co'>#> <span class='message'> Find N{20}NGG cas9seqs</span></div><div class='output co'>#> <span class='message'> Rm 10 targetranges with no cas9sites</span></div><div class='output co'>#> <span class='message'> 9922 cas9 seqs across 33518 targetranges</span></div><div class='output co'>#> GRanges object with 33518 ranges and 1 metadata column: -#> seqnames ranges strand | seqs -#> <Rle> <IRanges> <Rle> | <character> -#> [1] chr1 4712436-4712458 + | CTCTAGAGTCACAGAACTTATGG -#> [2] chr1 4712480-4712502 + | AATTTATTATGACTTACAGTCGG -#> [3] chr1 4712524-4712546 + | TTCAGTTGCAGCTGTGAAAATGG -#> [4] chr1 4712566-4712588 + | TTACTCAGTCTCACGCAAGCAGG -#> [5] chr1 4712650-4712672 + | GAAGGTGTAGCCCAGATTAAAGG -#> ... ... ... ... . ... -#> [33514] chrY 89126327-89126349 - | AGCGTGGACACGCCCACCCTCGG -#> [33515] chrY 89126684-89126706 - | CTTCCAGGCCCTAATAGCCGTGG -#> [33516] chrY 89126655-89126677 - | TCTGGGCATAAGCTCCCCAATGG -#> [33517] chrY 89126584-89126606 - | AAAGTCCAATCTCTCTGCTCTGG -#> [33518] chrY 89126559-89126581 - | TCAAAGCAGCTGCATTTGCTCGG -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Find cas9 ranges in targetranges — find_cas9ranges • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Find cas9 ranges in targetranges — find_cas9ranges" /> + +<meta property="og:description" content="Find cas9 ranges in targetranges" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Find cas9 ranges in targetranges</h1> + + <div class="hidden name"><code>find_cas9ranges.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Find cas9 ranges in targetranges</p> + + </div> + + <pre class="usage"><span class='fu'>find_cas9ranges</span>(<span class='no'>targetranges</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>targetranges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>targetranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='input'><span class='fu'>find_cas9ranges</span>(<span class='no'>targetranges</span>)</div><div class='output co'>#> <span class='message'> Find N{20}NGG cas9seqs</span></div><div class='output co'>#> <span class='message'> Rm 10 targetranges with no cas9sites</span></div><div class='output co'>#> <span class='message'> 9922 cas9 seqs across 33518 targetranges</span></div><div class='output co'>#> GRanges object with 33518 ranges and 1 metadata column: +#> seqnames ranges strand | seqs +#> <Rle> <IRanges> <Rle> | <character> +#> [1] chr1 4712436-4712458 + | CTCTAGAGTCACAGAACTTATGG +#> [2] chr1 4712480-4712502 + | AATTTATTATGACTTACAGTCGG +#> [3] chr1 4712524-4712546 + | TTCAGTTGCAGCTGTGAAAATGG +#> [4] chr1 4712566-4712588 + | TTACTCAGTCTCACGCAAGCAGG +#> [5] chr1 4712650-4712672 + | GAAGGTGTAGCCCAGATTAAAGG +#> ... ... ... ... . ... +#> [33514] chrY 89126327-89126349 - | AGCGTGGACACGCCCACCCTCGG +#> [33515] chrY 89126684-89126706 - | CTTCCAGGCCCTAATAGCCGTGG +#> [33516] chrY 89126655-89126677 - | TCTGGGCATAAGCTCCCCAATGG +#> [33517] chrY 89126584-89126606 - | AAAGTCCAATCTCTCTGCTCTGG +#> [33518] chrY 89126559-89126581 - | TCAAAGCAGCTGCATTTGCTCGG +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/find_gg.html b/public/reference/find_gg.html index 5a4dc5c291435c793314f61b0d98744419b48a55..73647cf1e45e2c1dfc3c5f48fa93977444cf410e 100644 --- a/public/reference/find_gg.html +++ b/public/reference/find_gg.html @@ -1,196 +1,196 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Find GG — find_gg • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Find GG — find_gg" /> -<meta property="og:description" content="Find GG" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Find GG</h1> - - <div class="hidden name"><code>find_gg.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Find GG</p> - </div> - - <pre class="usage"><span class='fu'>find_gg</span>(<span class='no'>gr</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'><a href='extend_pe_to_gg.html'>extend_pe_to_gg</a></span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>) <span class='kw'>%>%</span> <span class='fu'><a href='add_seq.html'>add_seq</a></span>(<span class='no'>bsgenome</span>) - <span class='fu'>find_gg</span>(<span class='no'>gr</span>)</div><div class='output co'>#> GRanges object with 10 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> [1] chr7 117559596-117559597 + | CFTR 117559593 117559595 -#> [2] chr7 117559603-117559604 - | CFTR 117559593 117559595 -#> [3] chr11 5227000-5227001 - | HBB 5227002 5227002 -#> [4] chr11 5227005-5227006 + | HBB 5227002 5227002 -#> [5] chr15 72346572-72346573 + | HEXA 72346580 72346583 -#> [6] chr15 72346579-72346580 + | HEXA 72346580 72346583 -#> [7] chr20 4699589-4699590 + | PRNP 4699600 4699600 -#> [8] chr20 4699590-4699591 + | PRNP 4699600 4699600 -#> [9] chr20 4699596-4699597 + | PRNP 4699600 4699600 -#> [10] chr20 4699599-4699600 + | PRNP 4699600 4699600 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Find GG — find_gg • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Find GG — find_gg" /> +<meta property="og:description" content="Find GG" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Find GG</h1> + + <div class="hidden name"><code>find_gg.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Find GG</p> + </div> + + <pre class="usage"><span class='fu'>find_gg</span>(<span class='no'>gr</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>gr</span> <span class='kw'>%<>%</span> <span class='fu'><a href='extend_pe_to_gg.html'>extend_pe_to_gg</a></span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>) <span class='kw'>%>%</span> <span class='fu'><a href='add_seq.html'>add_seq</a></span>(<span class='no'>bsgenome</span>) + <span class='fu'>find_gg</span>(<span class='no'>gr</span>)</div><div class='output co'>#> GRanges object with 10 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> [1] chr7 117559596-117559597 + | CFTR 117559593 117559595 +#> [2] chr7 117559603-117559604 - | CFTR 117559593 117559595 +#> [3] chr11 5227000-5227001 - | HBB 5227002 5227002 +#> [4] chr11 5227005-5227006 + | HBB 5227002 5227002 +#> [5] chr15 72346572-72346573 + | HEXA 72346580 72346583 +#> [6] chr15 72346579-72346580 + | HEXA 72346580 72346583 +#> [7] chr20 4699589-4699590 + | PRNP 4699600 4699600 +#> [8] chr20 4699590-4699591 + | PRNP 4699600 4699600 +#> [9] chr20 4699596-4699597 + | PRNP 4699600 4699600 +#> [10] chr20 4699599-4699600 + | PRNP 4699600 4699600 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/find_pe_spacers-1.png b/public/reference/find_pe_spacers-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/find_pe_spacers-1.png and b/public/reference/find_pe_spacers-1.png differ diff --git a/public/reference/find_pe_spacers-2.png b/public/reference/find_pe_spacers-2.png index 81a9f5c744b832c768da6574277f3b600d569f4c..3ad37c1bb7faa30d9dd2254ffe54ca918721a6b0 100644 Binary files a/public/reference/find_pe_spacers-2.png and b/public/reference/find_pe_spacers-2.png differ diff --git a/public/reference/find_pe_spacers-3.png b/public/reference/find_pe_spacers-3.png index 81a9f5c744b832c768da6574277f3b600d569f4c..3ad37c1bb7faa30d9dd2254ffe54ca918721a6b0 100644 Binary files a/public/reference/find_pe_spacers-3.png and b/public/reference/find_pe_spacers-3.png differ diff --git a/public/reference/find_pe_spacers.html b/public/reference/find_pe_spacers.html index 8e93c7c5b9f439f8179ea51ccebdc31740af9690..3dddab20e7a85e80b5437ed0a793e5bf39a553fc 100644 --- a/public/reference/find_pe_spacers.html +++ b/public/reference/find_pe_spacers.html @@ -1,293 +1,293 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Find prime editing spacers — find_pe_spacers • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Find prime editing spacers — find_pe_spacers" /> -<meta property="og:description" content="Find prime editing spacers around target ranges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Find prime editing spacers</h1> - - <div class="hidden name"><code>find_pe_spacers.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Find prime editing spacers around target ranges</p> - </div> - - <pre class="usage"><span class='fu'>find_pe_spacers</span>( - <span class='no'>gr</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>fixes</span> <span class='kw'>=</span> <span class='fu'>get_plus_seq</span>(<span class='no'>bsgenome</span>, <span class='no'>gr</span>), - <span class='kw'>nprimer</span> <span class='kw'>=</span> <span class='fl'>13</span>, - <span class='kw'>nrt</span> <span class='kw'>=</span> <span class='fl'>16</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>fixes</th> - <td><p>character vector: '+' strand fix seqs</p></td> - </tr> - <tr> - <th>nprimer</th> - <td><p>n primer nucleotides (default 13, max 17)</p></td> - </tr> - <tr> - <th>nrt</th> - <td><p>n rev transcr nucleotides (default 16, recomm. 10-16)</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code> with PE spacer ranges -Each prime editing range is defined in terms of its N20NGG spacer. -Additionally, three sequence mcols are returned: - * spacer: N20 spacers - * pam: NGG PAMs - * 3pext: 3' extension of gRNA (RTtemplate + primerbindingsite)</p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>Below the architecture of a prime editing site. -Fixes can be performed anywhere in the revtranscript area.</p> -<p>spacer pam - --------------------=== - primer revtranscript - -------------================ - 1..............17....GG.......... - .....................CC.......... - ----------extension----------</p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='find_spacers.html'>find_spacers</a></code> to find standard crispr sites</p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='fu'>find_pe_spacers</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='find_pe_spacers-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 9 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_1 chr7 117559575-117559594 + | CFTR 117559593 -#> CFTR_2 chr7 117559606-117559625 - | CFTR 117559593 -#> HBB_1 chr11 5227003-5227022 - | HBB 5227002 -#> HBB_2 chr11 5226984-5227003 + | HBB 5227002 -#> HEXA_1 chr15 72346551-72346570 + | HEXA 72346580 -#> HEXA_2 chr15 72346558-72346577 + | HEXA 72346580 -#> PRNP_1 chr20 4699568-4699587 + | PRNP 4699600 -#> PRNP_2 chr20 4699569-4699588 + | PRNP 4699600 -#> PRNP_3 chr20 4699575-4699594 + | PRNP 4699600 -#> PRNP_4 chr20 4699578-4699597 + | PRNP 4699600 -#> targetend crisprname crisprspacer crisprpam primer -#> <integer> <character> <character> <character> <character> -#> CFTR_1 117559595 CFTR_1 ATTAAAGAAAATATCATCTT TGG AAGAAAATATCAT -#> CFTR_2 117559595 CFTR_2 TCTGTATCTATATTCATCAT AGG TATCTATATTCAT -#> HBB_1 5227002 HBB_1 CATGGTGCATCTGACTCCTG AGG GTGCATCTGACTC -#> HBB_2 5227002 HBB_2 GTAACGGCAGACTTCTCCTC AGG CGGCAGACTTCTC -#> HEXA_1 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA GGG GAAATCCTTCCAG -#> HEXA_2 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT AGG TTCCAGTCAGGGC -#> PRNP_1 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG GGG GCTGGGGCAGTGG -#> PRNP_2 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG GGG CTGGGGCAGTGGT -#> PRNP_3 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT TGG CAGTGGTGGGGGG -#> PRNP_4 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG CGG TGGTGGGGGGCCT -#> revtranscript extension -#> <character> <character> -#> CFTR_1 CTTTGGTGTTTCCTAT ATAGGAAACACCAAAGATGATATTTTCTT -#> CFTR_2 CATAGGAAACACCAAA TTTGGTGTTTCCTATGATGAATATAGATA -#> HBB_1 CTGAGGAGAAGTCTGC GCAGACTTCTCCTCAGGAGTCAGATGCAC -#> HBB_2 CTCAGGAGTCAGATGC GCATCTGACTCCTGAGGAGAAGTCTGCCG -#> HEXA_1 TCAGGGCCATAGGATA TATCCTATGGCCCTGACTGGAAGGATTTC -#> HEXA_2 CATAGGATATACGGTT AACCGTATATCCTATGGCCCTGACTGGAA -#> PRNP_1 TGGGGGGCCTTGGCGG CCGCCAAGGCCCCCCACCACTGCCCCAGC -#> PRNP_2 GGGGGGCCTTGGCGGC GCCGCCAAGGCCCCCCACCACTGCCCCAG -#> PRNP_3 CCTTGGCGGCTACATG CATGTAGCCGCCAAGGCCCCCCACCACTG -#> PRNP_4 TGGCGGCTACATGCTG CAGCATGTAGCCGCCAAGGCCCCCCACCA -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>), <span class='no'>bsgenome</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='img'><img src='find_pe_spacers-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 6 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 -#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 -#> HBB_f chr11 5226984-5227003 + | HBB 5227002 -#> HBB_r chr11 5227003-5227022 - | HBB 5227002 -#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 -#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 -#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 -#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 -#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 -#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 -#> targetend crisprname crisprspacer crisprpam -#> <integer> <character> <character> <character> -#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG -#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG -#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG -#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG -#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG -#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG -#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG -#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG -#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG -#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Find prime editing spacers — find_pe_spacers • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Find prime editing spacers — find_pe_spacers" /> +<meta property="og:description" content="Find prime editing spacers around target ranges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Find prime editing spacers</h1> + + <div class="hidden name"><code>find_pe_spacers.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Find prime editing spacers around target ranges</p> + </div> + + <pre class="usage"><span class='fu'>find_pe_spacers</span>( + <span class='no'>gr</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>fixes</span> <span class='kw'>=</span> <span class='fu'>get_plus_seq</span>(<span class='no'>bsgenome</span>, <span class='no'>gr</span>), + <span class='kw'>nprimer</span> <span class='kw'>=</span> <span class='fl'>13</span>, + <span class='kw'>nrt</span> <span class='kw'>=</span> <span class='fl'>16</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>fixes</th> + <td><p>character vector: '+' strand fix seqs</p></td> + </tr> + <tr> + <th>nprimer</th> + <td><p>n primer nucleotides (default 13, max 17)</p></td> + </tr> + <tr> + <th>nrt</th> + <td><p>n rev transcr nucleotides (default 16, recomm. 10-16)</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code> with PE spacer ranges +Each prime editing range is defined in terms of its N20NGG spacer. +Additionally, three sequence mcols are returned: + * spacer: N20 spacers + * pam: NGG PAMs + * 3pext: 3' extension of gRNA (RTtemplate + primerbindingsite)</p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>Below the architecture of a prime editing site. +Fixes can be performed anywhere in the revtranscript area.</p> +<p>spacer pam + --------------------=== + primer revtranscript + -------------================ + 1..............17....GG.......... + .....................CC.......... + ----------extension----------</p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='find_spacers.html'>find_spacers</a></code> to find standard crispr sites</p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='fu'>find_pe_spacers</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='find_pe_spacers-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 9 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_1 chr7 117559575-117559594 + | CFTR 117559593 +#> CFTR_2 chr7 117559606-117559625 - | CFTR 117559593 +#> HBB_1 chr11 5227003-5227022 - | HBB 5227002 +#> HBB_2 chr11 5226984-5227003 + | HBB 5227002 +#> HEXA_1 chr15 72346551-72346570 + | HEXA 72346580 +#> HEXA_2 chr15 72346558-72346577 + | HEXA 72346580 +#> PRNP_1 chr20 4699568-4699587 + | PRNP 4699600 +#> PRNP_2 chr20 4699569-4699588 + | PRNP 4699600 +#> PRNP_3 chr20 4699575-4699594 + | PRNP 4699600 +#> PRNP_4 chr20 4699578-4699597 + | PRNP 4699600 +#> targetend crisprname crisprspacer crisprpam primer +#> <integer> <character> <character> <character> <character> +#> CFTR_1 117559595 CFTR_1 ATTAAAGAAAATATCATCTT TGG AAGAAAATATCAT +#> CFTR_2 117559595 CFTR_2 TCTGTATCTATATTCATCAT AGG TATCTATATTCAT +#> HBB_1 5227002 HBB_1 CATGGTGCATCTGACTCCTG AGG GTGCATCTGACTC +#> HBB_2 5227002 HBB_2 GTAACGGCAGACTTCTCCTC AGG CGGCAGACTTCTC +#> HEXA_1 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA GGG GAAATCCTTCCAG +#> HEXA_2 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT AGG TTCCAGTCAGGGC +#> PRNP_1 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG GGG GCTGGGGCAGTGG +#> PRNP_2 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG GGG CTGGGGCAGTGGT +#> PRNP_3 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT TGG CAGTGGTGGGGGG +#> PRNP_4 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG CGG TGGTGGGGGGCCT +#> revtranscript extension +#> <character> <character> +#> CFTR_1 CTTTGGTGTTTCCTAT ATAGGAAACACCAAAGATGATATTTTCTT +#> CFTR_2 CATAGGAAACACCAAA TTTGGTGTTTCCTATGATGAATATAGATA +#> HBB_1 CTGAGGAGAAGTCTGC GCAGACTTCTCCTCAGGAGTCAGATGCAC +#> HBB_2 CTCAGGAGTCAGATGC GCATCTGACTCCTGAGGAGAAGTCTGCCG +#> HEXA_1 TCAGGGCCATAGGATA TATCCTATGGCCCTGACTGGAAGGATTTC +#> HEXA_2 CATAGGATATACGGTT AACCGTATATCCTATGGCCCTGACTGGAA +#> PRNP_1 TGGGGGGCCTTGGCGG CCGCCAAGGCCCCCCACCACTGCCCCAGC +#> PRNP_2 GGGGGGCCTTGGCGGC GCCGCCAAGGCCCCCCACCACTGCCCCAG +#> PRNP_3 CCTTGGCGGCTACATG CATGTAGCCGCCAAGGCCCCCCACCACTG +#> PRNP_4 TGGCGGCTACATGCTG CAGCATGTAGCCGCCAAGGCCCCCCACCA +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>), <span class='no'>bsgenome</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='img'><img src='find_pe_spacers-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 6 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 +#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 +#> HBB_f chr11 5226984-5227003 + | HBB 5227002 +#> HBB_r chr11 5227003-5227022 - | HBB 5227002 +#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 +#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 +#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 +#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 +#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 +#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 +#> targetend crisprname crisprspacer crisprpam +#> <integer> <character> <character> <character> +#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG +#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG +#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG +#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG +#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG +#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG +#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG +#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG +#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG +#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/find_spacers-1.png b/public/reference/find_spacers-1.png index 8480b1e58cf3005cb8362f3ee9fb35e1d7ee9104..13824c688c0e8701605708f86a96227f54cb8549 100644 Binary files a/public/reference/find_spacers-1.png and b/public/reference/find_spacers-1.png differ diff --git a/public/reference/find_spacers-2.png b/public/reference/find_spacers-2.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/find_spacers-2.png and b/public/reference/find_spacers-2.png differ diff --git a/public/reference/find_spacers-3.png b/public/reference/find_spacers-3.png index 81a9f5c744b832c768da6574277f3b600d569f4c..3ad37c1bb7faa30d9dd2254ffe54ca918721a6b0 100644 Binary files a/public/reference/find_spacers-3.png and b/public/reference/find_spacers-3.png differ diff --git a/public/reference/find_spacers-4.png b/public/reference/find_spacers-4.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/find_spacers-4.png and b/public/reference/find_spacers-4.png differ diff --git a/public/reference/find_spacers-5.png b/public/reference/find_spacers-5.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/find_spacers-5.png and b/public/reference/find_spacers-5.png differ diff --git a/public/reference/find_spacers-6.png b/public/reference/find_spacers-6.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/find_spacers-6.png and b/public/reference/find_spacers-6.png differ diff --git a/public/reference/find_spacers.html b/public/reference/find_spacers.html index 77988bd40022a4acf55b1c564318f521cad4b3a1..a8372231e378a8766943581c34050e77066a3409 100644 --- a/public/reference/find_spacers.html +++ b/public/reference/find_spacers.html @@ -1,330 +1,330 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Find crispr spacers in targetranges — find_spacers • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Find crispr spacers in targetranges — find_spacers" /> -<meta property="og:description" content="Find crispr spacers in targetranges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Find crispr spacers in targetranges</h1> - - <div class="hidden name"><code>find_spacers.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Find crispr spacers in targetranges</p> - </div> - - <pre class="usage"><span class='fu'>find_spacers</span>( - <span class='no'>gr</span>, - <span class='no'>bsgenome</span>, - <span class='kw'>spacer</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>"N"</span>, <span class='fl'>20</span>), - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>spacer</th> - <td><p>string: spacer pattern in extended IUPAC alphabet</p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string: pam pattern in extended IUPAC alphabet</p></td> - </tr> - <tr> - <th>complement</th> - <td><p>TRUE (default) or FALSE: also search in compl ranges?</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='find_pe_spacers.html'>find_pe_spacers</a></code> to find prime editing spacers</p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='fu'><a href='plot_intervals.html'>plot_intervals</a></span>(<span class='no'>gr</span>)</div><div class='img'><img src='find_spacers-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='find_spacers-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 9 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_1 chr7 117559575-117559594 + | CFTR 117559593 -#> CFTR_2 chr7 117559606-117559625 - | CFTR 117559593 -#> HBB_1 chr11 5227003-5227022 - | HBB 5227002 -#> HBB_2 chr11 5226984-5227003 + | HBB 5227002 -#> HEXA_1 chr15 72346551-72346570 + | HEXA 72346580 -#> HEXA_2 chr15 72346558-72346577 + | HEXA 72346580 -#> PRNP_1 chr20 4699568-4699587 + | PRNP 4699600 -#> PRNP_2 chr20 4699569-4699588 + | PRNP 4699600 -#> PRNP_3 chr20 4699575-4699594 + | PRNP 4699600 -#> PRNP_4 chr20 4699578-4699597 + | PRNP 4699600 -#> targetend crisprname crisprspacer crisprpam primer -#> <integer> <character> <character> <character> <character> -#> CFTR_1 117559595 CFTR_1 ATTAAAGAAAATATCATCTT TGG AAGAAAATATCAT -#> CFTR_2 117559595 CFTR_2 TCTGTATCTATATTCATCAT AGG TATCTATATTCAT -#> HBB_1 5227002 HBB_1 CATGGTGCATCTGACTCCTG AGG GTGCATCTGACTC -#> HBB_2 5227002 HBB_2 GTAACGGCAGACTTCTCCTC AGG CGGCAGACTTCTC -#> HEXA_1 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA GGG GAAATCCTTCCAG -#> HEXA_2 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT AGG TTCCAGTCAGGGC -#> PRNP_1 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG GGG GCTGGGGCAGTGG -#> PRNP_2 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG GGG CTGGGGCAGTGGT -#> PRNP_3 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT TGG CAGTGGTGGGGGG -#> PRNP_4 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG CGG TGGTGGGGGGCCT -#> revtranscript extension -#> <character> <character> -#> CFTR_1 CTTTGGTGTTTCCTAT ATAGGAAACACCAAAGATGATATTTTCTT -#> CFTR_2 CATAGGAAACACCAAA TTTGGTGTTTCCTATGATGAATATAGATA -#> HBB_1 CTGAGGAGAAGTCTGC GCAGACTTCTCCTCAGGAGTCAGATGCAC -#> HBB_2 CTCAGGAGTCAGATGC GCATCTGACTCCTGAGGAGAAGTCTGCCG -#> HEXA_1 TCAGGGCCATAGGATA TATCCTATGGCCCTGACTGGAAGGATTTC -#> HEXA_2 CATAGGATATACGGTT AACCGTATATCCTATGGCCCTGACTGGAA -#> PRNP_1 TGGGGGGCCTTGGCGG CCGCCAAGGCCCCCCACCACTGCCCCAGC -#> PRNP_2 GGGGGGCCTTGGCGGC GCCGCCAAGGCCCCCCACCACTGCCCCAG -#> PRNP_3 CCTTGGCGGCTACATG CATGTAGCCGCCAAGGCCCCCCACCACTG -#> PRNP_4 TGGCGGCTACATGCTG CAGCATGTAGCCGCCAAGGCCCCCCACCA -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='fu'>find_spacers</span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>), <span class='no'>bsgenome</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='img'><img src='find_spacers-3.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 6 metadata columns: -#> seqnames ranges strand | targetname targetstart -#> <Rle> <IRanges> <Rle> | <character> <integer> -#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 -#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 -#> HBB_f chr11 5226984-5227003 + | HBB 5227002 -#> HBB_r chr11 5227003-5227022 - | HBB 5227002 -#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 -#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 -#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 -#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 -#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 -#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 -#> targetend crisprname crisprspacer crisprpam -#> <integer> <character> <character> <character> -#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG -#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG -#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG -#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG -#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG -#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG -#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG -#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG -#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG -#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='co'># complement = FALSE because extend_for_pe already </span> - <span class='co'># adds reverse complements and does so in a strand-specific </span> - <span class='co'># manner</span> - -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>) <span class='kw'>%>%</span> <span class='fu'><a href='up_flank.html'>extend</a></span>()</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='find_spacers-4.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>find_spacers</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='find_spacers-5.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10159 ranges and 8 metadata columns: -#> seqnames ranges strand | name score -#> <Rle> <IRanges> <Rle> | <character> <numeric> -#> T0001_r_5 chr1 4712619-4712638 - | SRF_MA0083.3 10.49542 -#> T0001_r_4 chr1 4712620-4712639 - | SRF_MA0083.3 10.49542 -#> T0001_r_3 chr1 4712627-4712646 - | SRF_MA0083.3 10.49542 -#> T0001_r_2 chr1 4712633-4712652 - | SRF_MA0083.3 10.49542 -#> T0001_r_1 chr1 4712634-4712653 - | SRF_MA0083.3 10.49542 -#> ... ... ... ... . ... ... -#> T1974_r_3 chrY 89126492-89126511 - | SRF_MA0083.3 4.54393 -#> T1974_f_3 chrY 89126496-89126515 + | SRF_MA0083.3 4.54393 -#> T1974_r_2 chrY 89126499-89126518 - | SRF_MA0083.3 4.54393 -#> T1974_r_1 chrY 89126500-89126519 - | SRF_MA0083.3 4.54393 -#> T1974_f_4 chrY 89126501-89126520 + | SRF_MA0083.3 4.54393 -#> targetname targetstart targetend crisprname crisprspacer -#> <character> <integer> <integer> <character> <character> -#> T0001_r_5 T0001 4712628 4712643 T0001_r_5 ATATAAGGGCATTGGAAGAA -#> T0001_r_4 T0001 4712628 4712643 T0001_r_4 AATATAAGGGCATTGGAAGA -#> T0001_r_3 T0001 4712628 4712643 T0001_r_3 TGGAGACAATATAAGGGCAT -#> T0001_r_2 T0001 4712628 4712643 T0001_r_2 TTCTGCTGGAGACAATATAA -#> T0001_r_1 T0001 4712628 4712643 T0001_r_1 CTTCTGCTGGAGACAATATA -#> ... ... ... ... ... ... -#> T1974_r_3 T1974 89126494 89126509 T1974_r_3 TTTGCCCATACTAGGGAGAG -#> T1974_f_3 T1974 89126494 89126509 T1974_f_3 CCCTAGTATGGGCAAATATA -#> T1974_r_2 T1974 89126494 89126509 T1974_r_2 CCATATATTTGCCCATACTA -#> T1974_r_1 T1974 89126494 89126509 T1974_r_1 TCCATATATTTGCCCATACT -#> T1974_f_4 T1974 89126494 89126509 T1974_f_4 GTATGGGCAAATATATGGAA -#> crisprpam -#> <character> -#> T0001_r_5 GGG -#> T0001_r_4 AGG -#> T0001_r_3 TGG -#> T0001_r_2 GGG -#> T0001_r_1 AGG -#> ... ... -#> T1974_r_3 CGG -#> T1974_f_3 TGG -#> T1974_r_2 GGG -#> T1974_r_1 AGG -#> T1974_f_4 TGG -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Find crispr spacers in targetranges — find_spacers • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Find crispr spacers in targetranges — find_spacers" /> +<meta property="og:description" content="Find crispr spacers in targetranges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Find crispr spacers in targetranges</h1> + + <div class="hidden name"><code>find_spacers.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Find crispr spacers in targetranges</p> + </div> + + <pre class="usage"><span class='fu'>find_spacers</span>( + <span class='no'>gr</span>, + <span class='no'>bsgenome</span>, + <span class='kw'>spacer</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/strrep.html'>strrep</a></span>(<span class='st'>"N"</span>, <span class='fl'>20</span>), + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>spacer</th> + <td><p>string: spacer pattern in extended IUPAC alphabet</p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string: pam pattern in extended IUPAC alphabet</p></td> + </tr> + <tr> + <th>complement</th> + <td><p>TRUE (default) or FALSE: also search in compl ranges?</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='find_pe_spacers.html'>find_pe_spacers</a></code> to find prime editing spacers</p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='fu'><a href='plot_intervals.html'>plot_intervals</a></span>(<span class='no'>gr</span>)</div><div class='img'><img src='find_spacers-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='find_spacers-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 9 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_1 chr7 117559575-117559594 + | CFTR 117559593 +#> CFTR_2 chr7 117559606-117559625 - | CFTR 117559593 +#> HBB_1 chr11 5227003-5227022 - | HBB 5227002 +#> HBB_2 chr11 5226984-5227003 + | HBB 5227002 +#> HEXA_1 chr15 72346551-72346570 + | HEXA 72346580 +#> HEXA_2 chr15 72346558-72346577 + | HEXA 72346580 +#> PRNP_1 chr20 4699568-4699587 + | PRNP 4699600 +#> PRNP_2 chr20 4699569-4699588 + | PRNP 4699600 +#> PRNP_3 chr20 4699575-4699594 + | PRNP 4699600 +#> PRNP_4 chr20 4699578-4699597 + | PRNP 4699600 +#> targetend crisprname crisprspacer crisprpam primer +#> <integer> <character> <character> <character> <character> +#> CFTR_1 117559595 CFTR_1 ATTAAAGAAAATATCATCTT TGG AAGAAAATATCAT +#> CFTR_2 117559595 CFTR_2 TCTGTATCTATATTCATCAT AGG TATCTATATTCAT +#> HBB_1 5227002 HBB_1 CATGGTGCATCTGACTCCTG AGG GTGCATCTGACTC +#> HBB_2 5227002 HBB_2 GTAACGGCAGACTTCTCCTC AGG CGGCAGACTTCTC +#> HEXA_1 72346583 HEXA_1 TGTAGAAATCCTTCCAGTCA GGG GAAATCCTTCCAG +#> HEXA_2 72346583 HEXA_2 ATCCTTCCAGTCAGGGCCAT AGG TTCCAGTCAGGGC +#> PRNP_1 4699600 PRNP_1 AGCAGCTGGGGCAGTGGTGG GGG GCTGGGGCAGTGG +#> PRNP_2 4699600 PRNP_2 GCAGCTGGGGCAGTGGTGGG GGG CTGGGGCAGTGGT +#> PRNP_3 4699600 PRNP_3 GGGGCAGTGGTGGGGGGCCT TGG CAGTGGTGGGGGG +#> PRNP_4 4699600 PRNP_4 GCAGTGGTGGGGGGCCTTGG CGG TGGTGGGGGGCCT +#> revtranscript extension +#> <character> <character> +#> CFTR_1 CTTTGGTGTTTCCTAT ATAGGAAACACCAAAGATGATATTTTCTT +#> CFTR_2 CATAGGAAACACCAAA TTTGGTGTTTCCTATGATGAATATAGATA +#> HBB_1 CTGAGGAGAAGTCTGC GCAGACTTCTCCTCAGGAGTCAGATGCAC +#> HBB_2 CTCAGGAGTCAGATGC GCATCTGACTCCTGAGGAGAAGTCTGCCG +#> HEXA_1 TCAGGGCCATAGGATA TATCCTATGGCCCTGACTGGAAGGATTTC +#> HEXA_2 CATAGGATATACGGTT AACCGTATATCCTATGGCCCTGACTGGAA +#> PRNP_1 TGGGGGGCCTTGGCGG CCGCCAAGGCCCCCCACCACTGCCCCAGC +#> PRNP_2 GGGGGGCCTTGGCGGC GCCGCCAAGGCCCCCCACCACTGCCCCAG +#> PRNP_3 CCTTGGCGGCTACATG CATGTAGCCGCCAAGGCCCCCCACCACTG +#> PRNP_4 TGGCGGCTACATGCTG CAGCATGTAGCCGCCAAGGCCCCCCACCA +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='fu'>find_spacers</span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>), <span class='no'>bsgenome</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='img'><img src='find_spacers-3.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10 ranges and 6 metadata columns: +#> seqnames ranges strand | targetname targetstart +#> <Rle> <IRanges> <Rle> | <character> <integer> +#> CFTR_f chr7 117559575-117559594 + | CFTR 117559593 +#> CFTR_r chr7 117559606-117559625 - | CFTR 117559593 +#> HBB_f chr11 5226984-5227003 + | HBB 5227002 +#> HBB_r chr11 5227003-5227022 - | HBB 5227002 +#> HEXA_f_1 chr15 72346551-72346570 + | HEXA 72346580 +#> HEXA_f_2 chr15 72346558-72346577 + | HEXA 72346580 +#> PRNP_f_1 chr20 4699568-4699587 + | PRNP 4699600 +#> PRNP_f_2 chr20 4699569-4699588 + | PRNP 4699600 +#> PRNP_f_3 chr20 4699575-4699594 + | PRNP 4699600 +#> PRNP_f_4 chr20 4699578-4699597 + | PRNP 4699600 +#> targetend crisprname crisprspacer crisprpam +#> <integer> <character> <character> <character> +#> CFTR_f 117559595 CFTR_f ATTAAAGAAAATATCATCTT TGG +#> CFTR_r 117559595 CFTR_r TCTGTATCTATATTCATCAT AGG +#> HBB_f 5227002 HBB_f GTAACGGCAGACTTCTCCTC AGG +#> HBB_r 5227002 HBB_r CATGGTGCATCTGACTCCTG AGG +#> HEXA_f_1 72346583 HEXA_f_1 TGTAGAAATCCTTCCAGTCA GGG +#> HEXA_f_2 72346583 HEXA_f_2 ATCCTTCCAGTCAGGGCCAT AGG +#> PRNP_f_1 4699600 PRNP_f_1 AGCAGCTGGGGCAGTGGTGG GGG +#> PRNP_f_2 4699600 PRNP_f_2 GCAGCTGGGGCAGTGGTGGG GGG +#> PRNP_f_3 4699600 PRNP_f_3 GGGGCAGTGGTGGGGGGCCT TGG +#> PRNP_f_4 4699600 PRNP_f_4 GCAGTGGTGGGGGGCCTTGG CGG +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> <span class='co'># complement = FALSE because extend_for_pe already </span> + <span class='co'># adds reverse complements and does so in a strand-specific </span> + <span class='co'># manner</span> + +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>) <span class='kw'>%>%</span> <span class='fu'><a href='up_flank.html'>extend</a></span>()</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='find_spacers-4.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>find_spacers</span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='find_spacers-5.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 10159 ranges and 8 metadata columns: +#> seqnames ranges strand | name score +#> <Rle> <IRanges> <Rle> | <character> <numeric> +#> T0001_r_5 chr1 4712619-4712638 - | SRF_MA0083.3 10.49542 +#> T0001_r_4 chr1 4712620-4712639 - | SRF_MA0083.3 10.49542 +#> T0001_r_3 chr1 4712627-4712646 - | SRF_MA0083.3 10.49542 +#> T0001_r_2 chr1 4712633-4712652 - | SRF_MA0083.3 10.49542 +#> T0001_r_1 chr1 4712634-4712653 - | SRF_MA0083.3 10.49542 +#> ... ... ... ... . ... ... +#> T1974_r_3 chrY 89126492-89126511 - | SRF_MA0083.3 4.54393 +#> T1974_f_3 chrY 89126496-89126515 + | SRF_MA0083.3 4.54393 +#> T1974_r_2 chrY 89126499-89126518 - | SRF_MA0083.3 4.54393 +#> T1974_r_1 chrY 89126500-89126519 - | SRF_MA0083.3 4.54393 +#> T1974_f_4 chrY 89126501-89126520 + | SRF_MA0083.3 4.54393 +#> targetname targetstart targetend crisprname crisprspacer +#> <character> <integer> <integer> <character> <character> +#> T0001_r_5 T0001 4712628 4712643 T0001_r_5 ATATAAGGGCATTGGAAGAA +#> T0001_r_4 T0001 4712628 4712643 T0001_r_4 AATATAAGGGCATTGGAAGA +#> T0001_r_3 T0001 4712628 4712643 T0001_r_3 TGGAGACAATATAAGGGCAT +#> T0001_r_2 T0001 4712628 4712643 T0001_r_2 TTCTGCTGGAGACAATATAA +#> T0001_r_1 T0001 4712628 4712643 T0001_r_1 CTTCTGCTGGAGACAATATA +#> ... ... ... ... ... ... +#> T1974_r_3 T1974 89126494 89126509 T1974_r_3 TTTGCCCATACTAGGGAGAG +#> T1974_f_3 T1974 89126494 89126509 T1974_f_3 CCCTAGTATGGGCAAATATA +#> T1974_r_2 T1974 89126494 89126509 T1974_r_2 CCATATATTTGCCCATACTA +#> T1974_r_1 T1974 89126494 89126509 T1974_r_1 TCCATATATTTGCCCATACT +#> T1974_f_4 T1974 89126494 89126509 T1974_f_4 GTATGGGCAAATATATGGAA +#> crisprpam +#> <character> +#> T0001_r_5 GGG +#> T0001_r_4 AGG +#> T0001_r_3 TGG +#> T0001_r_2 GGG +#> T0001_r_1 AGG +#> ... ... +#> T1974_r_3 CGG +#> T1974_f_3 TGG +#> T1974_r_2 GGG +#> T1974_r_1 AGG +#> T1974_f_4 TGG +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/find_specific_cas9ranges.html b/public/reference/find_specific_cas9ranges.html index 67132426952a8027af5c610d2b154947f0762b63..dbdf2492ce56938f54979bb2a6a3d17490cef1bb 100644 --- a/public/reference/find_specific_cas9ranges.html +++ b/public/reference/find_specific_cas9ranges.html @@ -1,193 +1,193 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Find target cas9 ranges with no offtargets — find_specific_cas9ranges • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Find target cas9 ranges with no offtargets — find_specific_cas9ranges" /> - -<meta property="og:description" content="Find target cas9 ranges with no offtargets" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Find target cas9 ranges with no offtargets</h1> - - <div class="hidden name"><code>find_specific_cas9ranges.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Find target cas9 ranges with no offtargets</p> - - </div> - - <pre class="usage"><span class='fu'>find_specific_cas9ranges</span>(<span class='no'>targetranges</span>, <span class='kw'>mismatch</span> <span class='kw'>=</span> <span class='fl'>2</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>targetranges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - <tr> - <th>mismatch</th> - <td><p>max number of mismatches to consider</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges - mcols(GRanges) contains sequences and match counts: - matches0 = perfect match counts - matches1 = single mismatch counts - matches2 = double mismatch counts</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><span class='co'># NOT RUN {</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> - <span class='no'>targetranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)[<span class='fl'>1</span>:<span class='fl'>10</span>] <span class='kw'>%>%</span> <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>() - <span class='no'>targetranges</span> <span class='kw'>%>%</span> <span class='fu'>find_specific_cas9ranges</span>(<span class='kw'>mismatch</span><span class='kw'>=</span><span class='fl'>0</span>) -<span class='co'># }</span></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Find target cas9 ranges with no offtargets — find_specific_cas9ranges • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Find target cas9 ranges with no offtargets — find_specific_cas9ranges" /> + +<meta property="og:description" content="Find target cas9 ranges with no offtargets" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Find target cas9 ranges with no offtargets</h1> + + <div class="hidden name"><code>find_specific_cas9ranges.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Find target cas9 ranges with no offtargets</p> + + </div> + + <pre class="usage"><span class='fu'>find_specific_cas9ranges</span>(<span class='no'>targetranges</span>, <span class='kw'>mismatch</span> <span class='kw'>=</span> <span class='fl'>2</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>targetranges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + <tr> + <th>mismatch</th> + <td><p>max number of mismatches to consider</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges + mcols(GRanges) contains sequences and match counts: + matches0 = perfect match counts + matches1 = single mismatch counts + matches2 = double mismatch counts</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><span class='co'># NOT RUN {</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> + <span class='no'>targetranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)[<span class='fl'>1</span>:<span class='fl'>10</span>] <span class='kw'>%>%</span> <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>() + <span class='no'>targetranges</span> <span class='kw'>%>%</span> <span class='fu'>find_specific_cas9ranges</span>(<span class='kw'>mismatch</span><span class='kw'>=</span><span class='fl'>0</span>) +<span class='co'># }</span></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/flank_fourways.html b/public/reference/flank_fourways.html index e04adc7116c806def2a86503cb3fe61ab02a044a..552c7742ad775f763a4d4a92aae1ee6d947db121 100644 --- a/public/reference/flank_fourways.html +++ b/public/reference/flank_fourways.html @@ -1,229 +1,229 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Flank fourways — flank_fourways • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Flank fourways — flank_fourways" /> - -<meta property="og:description" content="Flank left and right, for both strands, and merge overlaps" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Flank fourways</h1> - - <div class="hidden name"><code>flank_fourways.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Flank left and right, for both strands, and merge overlaps</p> - - </div> - - <pre class="usage"><span class='fu'>flank_fourways</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>200</span>, <span class='kw'>leftend</span> <span class='kw'>=</span> -<span class='fl'>1</span>, - <span class='kw'>rightstart</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>200</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - <tr> - <th>leftstart</th> - <td><p>numeric(1): left flank start (from range start)</p></td> - </tr> - <tr> - <th>leftend</th> - <td><p>numeric(1): left flank end (from range start)</p></td> - </tr> - <tr> - <th>rightstart</th> - <td><p>numeric(1): right flank start (from range end)</p></td> - </tr> - <tr> - <th>rightend</th> - <td><p>numeric(1): right flank end (from range end)</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1): report?</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>data.table(chr, start, end, strand)</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 - -#> [2] chr1 5250211-5250227 - -#> [3] chr1 5250451-5250467 - -#> [4] chr1 5256192-5256208 - -#> [5] chr1 5985727-5985743 - -#> ... ... ... ... -#> [1970] chrY 6770311-6770327 + -#> [1971] chrY 23130567-23130583 + -#> [1972] chrY 42512399-42512415 - -#> [1973] chrY 79048175-79048191 - -#> [1974] chrY 89126493-89126509 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'>flank_fourways</span>()</div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='output co'>#> GRanges object with 7306 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712427-4712626 + -#> [2] chr1 4712644-4712843 + -#> [3] chr1 5250011-5250210 + -#> [4] chr1 5250228-5250450 + -#> [5] chr1 5250468-5250667 + -#> ... ... ... ... -#> [7302] chrY 42512416-42512615 - -#> [7303] chrY 79047975-79048174 - -#> [7304] chrY 79048192-79048391 - -#> [7305] chrY 89126293-89126492 - -#> [7306] chrY 89126510-89126709 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Flank fourways — flank_fourways • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Flank fourways — flank_fourways" /> + +<meta property="og:description" content="Flank left and right, for both strands, and merge overlaps" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Flank fourways</h1> + + <div class="hidden name"><code>flank_fourways.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Flank left and right, for both strands, and merge overlaps</p> + + </div> + + <pre class="usage"><span class='fu'>flank_fourways</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>200</span>, <span class='kw'>leftend</span> <span class='kw'>=</span> -<span class='fl'>1</span>, + <span class='kw'>rightstart</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>200</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + <tr> + <th>leftstart</th> + <td><p>numeric(1): left flank start (from range start)</p></td> + </tr> + <tr> + <th>leftend</th> + <td><p>numeric(1): left flank end (from range start)</p></td> + </tr> + <tr> + <th>rightstart</th> + <td><p>numeric(1): right flank start (from range end)</p></td> + </tr> + <tr> + <th>rightend</th> + <td><p>numeric(1): right flank end (from range end)</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1): report?</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>data.table(chr, start, end, strand)</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 - +#> [2] chr1 5250211-5250227 - +#> [3] chr1 5250451-5250467 - +#> [4] chr1 5256192-5256208 - +#> [5] chr1 5985727-5985743 - +#> ... ... ... ... +#> [1970] chrY 6770311-6770327 + +#> [1971] chrY 23130567-23130583 + +#> [1972] chrY 42512399-42512415 - +#> [1973] chrY 79048175-79048191 - +#> [1974] chrY 89126493-89126509 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'>flank_fourways</span>()</div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='output co'>#> GRanges object with 7306 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712427-4712626 + +#> [2] chr1 4712644-4712843 + +#> [3] chr1 5250011-5250210 + +#> [4] chr1 5250228-5250450 + +#> [5] chr1 5250468-5250667 + +#> ... ... ... ... +#> [7302] chrY 42512416-42512615 - +#> [7303] chrY 79047975-79048174 - +#> [7304] chrY 79048192-79048391 - +#> [7305] chrY 89126293-89126492 - +#> [7306] chrY 89126510-89126709 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/genes_to_granges-1.png b/public/reference/genes_to_granges-1.png index e20b500ff7ae491213edb956687de4da4b08a90d..47c3f11ff6423518ccb306c735f3d4b4ce0cfbe2 100644 Binary files a/public/reference/genes_to_granges-1.png and b/public/reference/genes_to_granges-1.png differ diff --git a/public/reference/genes_to_granges-2.png b/public/reference/genes_to_granges-2.png index 90e9d8a2944e1c58a44d006cebcf707740dea5e3..05dbcb78384651200b51cb01b299642c9eab3f12 100644 Binary files a/public/reference/genes_to_granges-2.png and b/public/reference/genes_to_granges-2.png differ diff --git a/public/reference/genes_to_granges.html b/public/reference/genes_to_granges.html index 43cd4d7cd476bb3fd4a6a2a756a7ff15d0a6acc5..dbf3f6f67e7700b4fca7aa064064863bd0161127 100644 --- a/public/reference/genes_to_granges.html +++ b/public/reference/genes_to_granges.html @@ -1,400 +1,400 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Convert geneids into GRanges — genes_to_granges • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Convert geneids into GRanges — genes_to_granges" /> -<meta property="og:description" content="Convert geneids into GRanges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Convert geneids into GRanges</h1> - - <div class="hidden name"><code>genes_to_granges.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Convert geneids into GRanges</p> - </div> - - <pre class="usage"><span class='fu'>genes_to_granges</span>(<span class='no'>geneids</span>, <span class='no'>txdb</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>) - -<span class='fu'>genefile_to_granges</span>(<span class='no'>file</span>, <span class='no'>txdb</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>geneids</th> - <td><p>Gene identifier vector</p></td> - </tr> - <tr> - <th>txdb</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicFeatures/man/TxDb-class.html'>TxDb-class</a></code> or -<code><a href='https://rdrr.io/pkg/ensembldb/man/EnsDb-class.html'>EnsDb-class</a></code></p></td> - </tr> - <tr> - <th>complement</th> - <td><p>TRUE (default) or FALSE: add complementary strand?</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - <tr> - <th>file</th> - <td><p>Gene identifier file (one per row)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='char_to_granges.html'>char_to_granges</a></code>, <code><a href='bed_to_granges.html'>bed_to_granges</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># Entrez</span> -<span class='co'>#-------</span> - <span class='no'>genefile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.entrez'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) - <span class='no'>geneids</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/character.html'>as.character</a></span>(<span class='fu'><a href='https://rdrr.io/r/utils/read.table.html'>read.table</a></span>(<span class='no'>genefile</span>)<span class='kw'>[[</span><span class='fl'>1</span>]]) - <span class='no'>txdb</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/utils/getFromNamespace.html'>getFromNamespace</a></span>(<span class='st'>'TxDb.Mmusculus.UCSC.mm10.knownGene'</span>, - <span class='st'>'TxDb.Mmusculus.UCSC.mm10.knownGene'</span>) - (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genes_to_granges</span>(<span class='no'>geneids</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='output co'>#> GRanges object with 20 ranges and 4 metadata columns: -#> seqnames ranges strand | gene_id targetname -#> <Rle> <IRanges> <Rle> | <character> <character> -#> 27392_r chr1 105518422-105663677 - | 27392 27392_r -#> 27392_f chr1 105518422-105663677 + | 27392 27392_f -#> 100043424_r chr2 128178319-128502765 - | 100043424 100043424_r -#> 100043424_f chr2 128178319-128502765 + | 100043424 100043424_f -#> 622434_f chr3 62338344-62462221 + | 622434 622434_f -#> ... ... ... ... . ... ... -#> 71918_f chr14 25711642-25769039 + | 71918 71918_f -#> 13653_f chr18 34859823-34864984 + | 13653 13653_f -#> 13653_r chr18 34859823-34864984 - | 13653 13653_r -#> 52662_f chr18 67933257-68268630 + | 52662 52662_f -#> 52662_r chr18 67933257-68268630 - | 52662 52662_r -#> targetstart targetend -#> <integer> <integer> -#> 27392_r 105518422 105663677 -#> 27392_f 105518422 105663677 -#> 100043424_r 128178319 128502765 -#> 100043424_f 128178319 128502765 -#> 622434_f 62338344 62462221 -#> ... ... ... -#> 71918_f 25711642 25769039 -#> 13653_f 34859823 34864984 -#> 13653_r 34859823 34864984 -#> 52662_f 67933257 68268630 -#> 52662_r 67933257 68268630 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genefile_to_granges</span>(<span class='no'>genefile</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='img'><img src='genes_to_granges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 20 ranges and 4 metadata columns: -#> seqnames ranges strand | gene_id targetname -#> <Rle> <IRanges> <Rle> | <character> <character> -#> 27392_r chr1 105518422-105663677 - | 27392 27392_r -#> 27392_f chr1 105518422-105663677 + | 27392 27392_f -#> 100043424_r chr2 128178319-128502765 - | 100043424 100043424_r -#> 100043424_f chr2 128178319-128502765 + | 100043424 100043424_f -#> 622434_f chr3 62338344-62462221 + | 622434 622434_f -#> ... ... ... ... . ... ... -#> 71918_f chr14 25711642-25769039 + | 71918 71918_f -#> 13653_f chr18 34859823-34864984 + | 13653 13653_f -#> 13653_r chr18 34859823-34864984 - | 13653 13653_r -#> 52662_f chr18 67933257-68268630 + | 52662 52662_f -#> 52662_r chr18 67933257-68268630 - | 52662 52662_r -#> targetstart targetend -#> <integer> <integer> -#> 27392_r 105518422 105663677 -#> 27392_f 105518422 105663677 -#> 100043424_r 128178319 128502765 -#> 100043424_f 128178319 128502765 -#> 622434_f 62338344 62462221 -#> ... ... ... -#> 71918_f 25711642 25769039 -#> 13653_f 34859823 34864984 -#> 13653_r 34859823 34864984 -#> 52662_f 67933257 68268630 -#> 52662_r 67933257 68268630 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> -<span class='co'># Ensembl</span> -<span class='co'>#--------</span> - <span class='no'>txdb</span> <span class='kw'><-</span> <span class='fu'><a href='EnsDb.Mmusculus.v98.html'>EnsDb.Mmusculus.v98</a></span>()</div><div class='output co'>#> <span class='message'>snapshotDate(): 2019-10-29</span></div><div class='output co'>#> <span class='message'>loading from cache</span></div><div class='input'> <span class='no'>genefile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.ensembl'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) - <span class='no'>geneids</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/character.html'>as.character</a></span>(<span class='fu'><a href='https://rdrr.io/r/utils/read.table.html'>read.table</a></span>(<span class='no'>genefile</span>)<span class='kw'>[[</span><span class='fl'>1</span>]]) - (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genes_to_granges</span>(<span class='no'>geneids</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='img'><img src='genes_to_granges-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 20 ranges and 11 metadata columns: -#> seqnames ranges strand | gene_id -#> <Rle> <IRanges> <Rle> | <character> -#> ENSMUSG00000056536_r 1 105518422-105663677 - | ENSMUSG00000056536 -#> ENSMUSG00000056536_f 1 105518422-105663677 + | ENSMUSG00000056536 -#> ENSMUSG00000074813_r 2 128178319-128502765 - | ENSMUSG00000074813 -#> ENSMUSG00000074813_f 2 128178319-128502765 + | ENSMUSG00000074813 -#> ENSMUSG00000036885_f 3 62338344-62462221 + | ENSMUSG00000036885 -#> ... ... ... ... . ... -#> ENSMUSG00000055538_f 14 25711642-25769039 + | ENSMUSG00000055538 -#> ENSMUSG00000038418_f 18 34859823-34864984 + | ENSMUSG00000038418 -#> ENSMUSG00000038418_r 18 34859823-34864984 - | ENSMUSG00000038418 -#> ENSMUSG00000024544_f 18 67933257-68268630 + | ENSMUSG00000024544 -#> ENSMUSG00000024544_r 18 67933257-68268630 - | ENSMUSG00000024544 -#> gene_name gene_biotype seq_coord_system -#> <character> <character> <character> -#> ENSMUSG00000056536_r Pign protein_coding chromosome -#> ENSMUSG00000056536_f Pign protein_coding chromosome -#> ENSMUSG00000074813_r Morrbid lncRNA chromosome -#> ENSMUSG00000074813_f Morrbid lncRNA chromosome -#> ENSMUSG00000036885_f Arhgef26 protein_coding chromosome -#> ... ... ... ... -#> ENSMUSG00000055538_f Zcchc24 protein_coding chromosome -#> ENSMUSG00000038418_f Egr1 protein_coding chromosome -#> ENSMUSG00000038418_r Egr1 protein_coding chromosome -#> ENSMUSG00000024544_f Ldlrad4 protein_coding chromosome -#> ENSMUSG00000024544_r Ldlrad4 protein_coding chromosome -#> description -#> <character> -#> ENSMUSG00000056536_r phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] -#> ENSMUSG00000056536_f phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] -#> ENSMUSG00000074813_r myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] -#> ENSMUSG00000074813_f myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] -#> ENSMUSG00000036885_f Rho guanine nucleotide exchange factor (GEF) 26 [Source:MGI Symbol;Acc:MGI:1918053] -#> ... ... -#> ENSMUSG00000055538_f zinc finger, CCHC domain containing 24 [Source:MGI Symbol;Acc:MGI:1919168] -#> ENSMUSG00000038418_f early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] -#> ENSMUSG00000038418_r early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] -#> ENSMUSG00000024544_f low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] -#> ENSMUSG00000024544_r low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] -#> gene_id_version symbol entrezid -#> <character> <character> <list> -#> ENSMUSG00000056536_r ENSMUSG00000056536.14 Pign 27392 -#> ENSMUSG00000056536_f ENSMUSG00000056536.14 Pign 27392 -#> ENSMUSG00000074813_r ENSMUSG00000074813.13 Morrbid NA -#> ENSMUSG00000074813_f ENSMUSG00000074813.13 Morrbid NA -#> ENSMUSG00000036885_f ENSMUSG00000036885.14 Arhgef26 622434 -#> ... ... ... ... -#> ENSMUSG00000055538_f ENSMUSG00000055538.7 Zcchc24 71918 -#> ENSMUSG00000038418_f ENSMUSG00000038418.7 Egr1 13653 -#> ENSMUSG00000038418_r ENSMUSG00000038418.7 Egr1 13653 -#> ENSMUSG00000024544_f ENSMUSG00000024544.9 Ldlrad4 52662 -#> ENSMUSG00000024544_r ENSMUSG00000024544.9 Ldlrad4 52662 -#> targetname targetstart targetend -#> <character> <integer> <integer> -#> ENSMUSG00000056536_r ENSMUSG00000056536_r 105518422 105663677 -#> ENSMUSG00000056536_f ENSMUSG00000056536_f 105518422 105663677 -#> ENSMUSG00000074813_r ENSMUSG00000074813_r 128178319 128502765 -#> ENSMUSG00000074813_f ENSMUSG00000074813_f 128178319 128502765 -#> ENSMUSG00000036885_f ENSMUSG00000036885_f 62338344 62462221 -#> ... ... ... ... -#> ENSMUSG00000055538_f ENSMUSG00000055538_f 25711642 25769039 -#> ENSMUSG00000038418_f ENSMUSG00000038418_f 34859823 34864984 -#> ENSMUSG00000038418_r ENSMUSG00000038418_r 34859823 34864984 -#> ENSMUSG00000024544_f ENSMUSG00000024544_f 67933257 68268630 -#> ENSMUSG00000024544_r ENSMUSG00000024544_r 67933257 68268630 -#> ------- -#> seqinfo: 118 sequences from GRCm38 genome</div><div class='input'> (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genefile_to_granges</span>(<span class='no'>genefile</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='output co'>#> GRanges object with 20 ranges and 11 metadata columns: -#> seqnames ranges strand | gene_id -#> <Rle> <IRanges> <Rle> | <character> -#> ENSMUSG00000056536_r 1 105518422-105663677 - | ENSMUSG00000056536 -#> ENSMUSG00000056536_f 1 105518422-105663677 + | ENSMUSG00000056536 -#> ENSMUSG00000074813_r 2 128178319-128502765 - | ENSMUSG00000074813 -#> ENSMUSG00000074813_f 2 128178319-128502765 + | ENSMUSG00000074813 -#> ENSMUSG00000036885_f 3 62338344-62462221 + | ENSMUSG00000036885 -#> ... ... ... ... . ... -#> ENSMUSG00000055538_f 14 25711642-25769039 + | ENSMUSG00000055538 -#> ENSMUSG00000038418_f 18 34859823-34864984 + | ENSMUSG00000038418 -#> ENSMUSG00000038418_r 18 34859823-34864984 - | ENSMUSG00000038418 -#> ENSMUSG00000024544_f 18 67933257-68268630 + | ENSMUSG00000024544 -#> ENSMUSG00000024544_r 18 67933257-68268630 - | ENSMUSG00000024544 -#> gene_name gene_biotype seq_coord_system -#> <character> <character> <character> -#> ENSMUSG00000056536_r Pign protein_coding chromosome -#> ENSMUSG00000056536_f Pign protein_coding chromosome -#> ENSMUSG00000074813_r Morrbid lncRNA chromosome -#> ENSMUSG00000074813_f Morrbid lncRNA chromosome -#> ENSMUSG00000036885_f Arhgef26 protein_coding chromosome -#> ... ... ... ... -#> ENSMUSG00000055538_f Zcchc24 protein_coding chromosome -#> ENSMUSG00000038418_f Egr1 protein_coding chromosome -#> ENSMUSG00000038418_r Egr1 protein_coding chromosome -#> ENSMUSG00000024544_f Ldlrad4 protein_coding chromosome -#> ENSMUSG00000024544_r Ldlrad4 protein_coding chromosome -#> description -#> <character> -#> ENSMUSG00000056536_r phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] -#> ENSMUSG00000056536_f phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] -#> ENSMUSG00000074813_r myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] -#> ENSMUSG00000074813_f myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] -#> ENSMUSG00000036885_f Rho guanine nucleotide exchange factor (GEF) 26 [Source:MGI Symbol;Acc:MGI:1918053] -#> ... ... -#> ENSMUSG00000055538_f zinc finger, CCHC domain containing 24 [Source:MGI Symbol;Acc:MGI:1919168] -#> ENSMUSG00000038418_f early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] -#> ENSMUSG00000038418_r early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] -#> ENSMUSG00000024544_f low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] -#> ENSMUSG00000024544_r low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] -#> gene_id_version symbol entrezid -#> <character> <character> <list> -#> ENSMUSG00000056536_r ENSMUSG00000056536.14 Pign 27392 -#> ENSMUSG00000056536_f ENSMUSG00000056536.14 Pign 27392 -#> ENSMUSG00000074813_r ENSMUSG00000074813.13 Morrbid NA -#> ENSMUSG00000074813_f ENSMUSG00000074813.13 Morrbid NA -#> ENSMUSG00000036885_f ENSMUSG00000036885.14 Arhgef26 622434 -#> ... ... ... ... -#> ENSMUSG00000055538_f ENSMUSG00000055538.7 Zcchc24 71918 -#> ENSMUSG00000038418_f ENSMUSG00000038418.7 Egr1 13653 -#> ENSMUSG00000038418_r ENSMUSG00000038418.7 Egr1 13653 -#> ENSMUSG00000024544_f ENSMUSG00000024544.9 Ldlrad4 52662 -#> ENSMUSG00000024544_r ENSMUSG00000024544.9 Ldlrad4 52662 -#> targetname targetstart targetend -#> <character> <integer> <integer> -#> ENSMUSG00000056536_r ENSMUSG00000056536_r 105518422 105663677 -#> ENSMUSG00000056536_f ENSMUSG00000056536_f 105518422 105663677 -#> ENSMUSG00000074813_r ENSMUSG00000074813_r 128178319 128502765 -#> ENSMUSG00000074813_f ENSMUSG00000074813_f 128178319 128502765 -#> ENSMUSG00000036885_f ENSMUSG00000036885_f 62338344 62462221 -#> ... ... ... ... -#> ENSMUSG00000055538_f ENSMUSG00000055538_f 25711642 25769039 -#> ENSMUSG00000038418_f ENSMUSG00000038418_f 34859823 34864984 -#> ENSMUSG00000038418_r ENSMUSG00000038418_r 34859823 34864984 -#> ENSMUSG00000024544_f ENSMUSG00000024544_f 67933257 68268630 -#> ENSMUSG00000024544_r ENSMUSG00000024544_r 67933257 68268630 -#> ------- -#> seqinfo: 118 sequences from GRCm38 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Convert geneids into GRanges — genes_to_granges • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Convert geneids into GRanges — genes_to_granges" /> +<meta property="og:description" content="Convert geneids into GRanges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Convert geneids into GRanges</h1> + + <div class="hidden name"><code>genes_to_granges.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Convert geneids into GRanges</p> + </div> + + <pre class="usage"><span class='fu'>genes_to_granges</span>(<span class='no'>geneids</span>, <span class='no'>txdb</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>) + +<span class='fu'>genefile_to_granges</span>(<span class='no'>file</span>, <span class='no'>txdb</span>, <span class='kw'>complement</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>geneids</th> + <td><p>Gene identifier vector</p></td> + </tr> + <tr> + <th>txdb</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicFeatures/man/TxDb-class.html'>TxDb-class</a></code> or +<code><a href='https://rdrr.io/pkg/ensembldb/man/EnsDb-class.html'>EnsDb-class</a></code></p></td> + </tr> + <tr> + <th>complement</th> + <td><p>TRUE (default) or FALSE: add complementary strand?</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + <tr> + <th>file</th> + <td><p>Gene identifier file (one per row)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='char_to_granges.html'>char_to_granges</a></code>, <code><a href='bed_to_granges.html'>bed_to_granges</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># Entrez</span> +<span class='co'>#-------</span> + <span class='no'>genefile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.entrez'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) + <span class='no'>geneids</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/character.html'>as.character</a></span>(<span class='fu'><a href='https://rdrr.io/r/utils/read.table.html'>read.table</a></span>(<span class='no'>genefile</span>)<span class='kw'>[[</span><span class='fl'>1</span>]]) + <span class='no'>txdb</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/utils/getFromNamespace.html'>getFromNamespace</a></span>(<span class='st'>'TxDb.Mmusculus.UCSC.mm10.knownGene'</span>, + <span class='st'>'TxDb.Mmusculus.UCSC.mm10.knownGene'</span>) + (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genes_to_granges</span>(<span class='no'>geneids</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='output co'>#> GRanges object with 20 ranges and 4 metadata columns: +#> seqnames ranges strand | gene_id targetname +#> <Rle> <IRanges> <Rle> | <character> <character> +#> 27392_r chr1 105518422-105663677 - | 27392 27392_r +#> 27392_f chr1 105518422-105663677 + | 27392 27392_f +#> 100043424_r chr2 128178319-128502765 - | 100043424 100043424_r +#> 100043424_f chr2 128178319-128502765 + | 100043424 100043424_f +#> 622434_f chr3 62338344-62462221 + | 622434 622434_f +#> ... ... ... ... . ... ... +#> 71918_f chr14 25711642-25769039 + | 71918 71918_f +#> 13653_f chr18 34859823-34864984 + | 13653 13653_f +#> 13653_r chr18 34859823-34864984 - | 13653 13653_r +#> 52662_f chr18 67933257-68268630 + | 52662 52662_f +#> 52662_r chr18 67933257-68268630 - | 52662 52662_r +#> targetstart targetend +#> <integer> <integer> +#> 27392_r 105518422 105663677 +#> 27392_f 105518422 105663677 +#> 100043424_r 128178319 128502765 +#> 100043424_f 128178319 128502765 +#> 622434_f 62338344 62462221 +#> ... ... ... +#> 71918_f 25711642 25769039 +#> 13653_f 34859823 34864984 +#> 13653_r 34859823 34864984 +#> 52662_f 67933257 68268630 +#> 52662_r 67933257 68268630 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genefile_to_granges</span>(<span class='no'>genefile</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='img'><img src='genes_to_granges-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 20 ranges and 4 metadata columns: +#> seqnames ranges strand | gene_id targetname +#> <Rle> <IRanges> <Rle> | <character> <character> +#> 27392_r chr1 105518422-105663677 - | 27392 27392_r +#> 27392_f chr1 105518422-105663677 + | 27392 27392_f +#> 100043424_r chr2 128178319-128502765 - | 100043424 100043424_r +#> 100043424_f chr2 128178319-128502765 + | 100043424 100043424_f +#> 622434_f chr3 62338344-62462221 + | 622434 622434_f +#> ... ... ... ... . ... ... +#> 71918_f chr14 25711642-25769039 + | 71918 71918_f +#> 13653_f chr18 34859823-34864984 + | 13653 13653_f +#> 13653_r chr18 34859823-34864984 - | 13653 13653_r +#> 52662_f chr18 67933257-68268630 + | 52662 52662_f +#> 52662_r chr18 67933257-68268630 - | 52662 52662_r +#> targetstart targetend +#> <integer> <integer> +#> 27392_r 105518422 105663677 +#> 27392_f 105518422 105663677 +#> 100043424_r 128178319 128502765 +#> 100043424_f 128178319 128502765 +#> 622434_f 62338344 62462221 +#> ... ... ... +#> 71918_f 25711642 25769039 +#> 13653_f 34859823 34864984 +#> 13653_r 34859823 34864984 +#> 52662_f 67933257 68268630 +#> 52662_r 67933257 68268630 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> +<span class='co'># Ensembl</span> +<span class='co'>#--------</span> + <span class='no'>txdb</span> <span class='kw'><-</span> <span class='fu'><a href='EnsDb.Mmusculus.v98.html'>EnsDb.Mmusculus.v98</a></span>()</div><div class='output co'>#> <span class='message'>snapshotDate(): 2019-10-29</span></div><div class='output co'>#> <span class='message'>loading from cache</span></div><div class='input'> <span class='no'>genefile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.ensembl'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) + <span class='no'>geneids</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/character.html'>as.character</a></span>(<span class='fu'><a href='https://rdrr.io/r/utils/read.table.html'>read.table</a></span>(<span class='no'>genefile</span>)<span class='kw'>[[</span><span class='fl'>1</span>]]) + (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genes_to_granges</span>(<span class='no'>geneids</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='img'><img src='genes_to_granges-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 20 ranges and 11 metadata columns: +#> seqnames ranges strand | gene_id +#> <Rle> <IRanges> <Rle> | <character> +#> ENSMUSG00000056536_r 1 105518422-105663677 - | ENSMUSG00000056536 +#> ENSMUSG00000056536_f 1 105518422-105663677 + | ENSMUSG00000056536 +#> ENSMUSG00000074813_r 2 128178319-128502765 - | ENSMUSG00000074813 +#> ENSMUSG00000074813_f 2 128178319-128502765 + | ENSMUSG00000074813 +#> ENSMUSG00000036885_f 3 62338344-62462221 + | ENSMUSG00000036885 +#> ... ... ... ... . ... +#> ENSMUSG00000055538_f 14 25711642-25769039 + | ENSMUSG00000055538 +#> ENSMUSG00000038418_f 18 34859823-34864984 + | ENSMUSG00000038418 +#> ENSMUSG00000038418_r 18 34859823-34864984 - | ENSMUSG00000038418 +#> ENSMUSG00000024544_f 18 67933257-68268630 + | ENSMUSG00000024544 +#> ENSMUSG00000024544_r 18 67933257-68268630 - | ENSMUSG00000024544 +#> gene_name gene_biotype seq_coord_system +#> <character> <character> <character> +#> ENSMUSG00000056536_r Pign protein_coding chromosome +#> ENSMUSG00000056536_f Pign protein_coding chromosome +#> ENSMUSG00000074813_r Morrbid lncRNA chromosome +#> ENSMUSG00000074813_f Morrbid lncRNA chromosome +#> ENSMUSG00000036885_f Arhgef26 protein_coding chromosome +#> ... ... ... ... +#> ENSMUSG00000055538_f Zcchc24 protein_coding chromosome +#> ENSMUSG00000038418_f Egr1 protein_coding chromosome +#> ENSMUSG00000038418_r Egr1 protein_coding chromosome +#> ENSMUSG00000024544_f Ldlrad4 protein_coding chromosome +#> ENSMUSG00000024544_r Ldlrad4 protein_coding chromosome +#> description +#> <character> +#> ENSMUSG00000056536_r phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] +#> ENSMUSG00000056536_f phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] +#> ENSMUSG00000074813_r myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] +#> ENSMUSG00000074813_f myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] +#> ENSMUSG00000036885_f Rho guanine nucleotide exchange factor (GEF) 26 [Source:MGI Symbol;Acc:MGI:1918053] +#> ... ... +#> ENSMUSG00000055538_f zinc finger, CCHC domain containing 24 [Source:MGI Symbol;Acc:MGI:1919168] +#> ENSMUSG00000038418_f early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] +#> ENSMUSG00000038418_r early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] +#> ENSMUSG00000024544_f low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] +#> ENSMUSG00000024544_r low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] +#> gene_id_version symbol entrezid +#> <character> <character> <list> +#> ENSMUSG00000056536_r ENSMUSG00000056536.14 Pign 27392 +#> ENSMUSG00000056536_f ENSMUSG00000056536.14 Pign 27392 +#> ENSMUSG00000074813_r ENSMUSG00000074813.13 Morrbid NA +#> ENSMUSG00000074813_f ENSMUSG00000074813.13 Morrbid NA +#> ENSMUSG00000036885_f ENSMUSG00000036885.14 Arhgef26 622434 +#> ... ... ... ... +#> ENSMUSG00000055538_f ENSMUSG00000055538.7 Zcchc24 71918 +#> ENSMUSG00000038418_f ENSMUSG00000038418.7 Egr1 13653 +#> ENSMUSG00000038418_r ENSMUSG00000038418.7 Egr1 13653 +#> ENSMUSG00000024544_f ENSMUSG00000024544.9 Ldlrad4 52662 +#> ENSMUSG00000024544_r ENSMUSG00000024544.9 Ldlrad4 52662 +#> targetname targetstart targetend +#> <character> <integer> <integer> +#> ENSMUSG00000056536_r ENSMUSG00000056536_r 105518422 105663677 +#> ENSMUSG00000056536_f ENSMUSG00000056536_f 105518422 105663677 +#> ENSMUSG00000074813_r ENSMUSG00000074813_r 128178319 128502765 +#> ENSMUSG00000074813_f ENSMUSG00000074813_f 128178319 128502765 +#> ENSMUSG00000036885_f ENSMUSG00000036885_f 62338344 62462221 +#> ... ... ... ... +#> ENSMUSG00000055538_f ENSMUSG00000055538_f 25711642 25769039 +#> ENSMUSG00000038418_f ENSMUSG00000038418_f 34859823 34864984 +#> ENSMUSG00000038418_r ENSMUSG00000038418_r 34859823 34864984 +#> ENSMUSG00000024544_f ENSMUSG00000024544_f 67933257 68268630 +#> ENSMUSG00000024544_r ENSMUSG00000024544_r 67933257 68268630 +#> ------- +#> seqinfo: 118 sequences from GRCm38 genome</div><div class='input'> (<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>genefile_to_granges</span>(<span class='no'>genefile</span>, <span class='no'>txdb</span>))</div><div class='output co'>#> <span class='message'> Convert 10 genes to 10 GRanges</span></div><div class='output co'>#> <span class='message'> 20 ranges after adding inverse strands</span></div><div class='output co'>#> GRanges object with 20 ranges and 11 metadata columns: +#> seqnames ranges strand | gene_id +#> <Rle> <IRanges> <Rle> | <character> +#> ENSMUSG00000056536_r 1 105518422-105663677 - | ENSMUSG00000056536 +#> ENSMUSG00000056536_f 1 105518422-105663677 + | ENSMUSG00000056536 +#> ENSMUSG00000074813_r 2 128178319-128502765 - | ENSMUSG00000074813 +#> ENSMUSG00000074813_f 2 128178319-128502765 + | ENSMUSG00000074813 +#> ENSMUSG00000036885_f 3 62338344-62462221 + | ENSMUSG00000036885 +#> ... ... ... ... . ... +#> ENSMUSG00000055538_f 14 25711642-25769039 + | ENSMUSG00000055538 +#> ENSMUSG00000038418_f 18 34859823-34864984 + | ENSMUSG00000038418 +#> ENSMUSG00000038418_r 18 34859823-34864984 - | ENSMUSG00000038418 +#> ENSMUSG00000024544_f 18 67933257-68268630 + | ENSMUSG00000024544 +#> ENSMUSG00000024544_r 18 67933257-68268630 - | ENSMUSG00000024544 +#> gene_name gene_biotype seq_coord_system +#> <character> <character> <character> +#> ENSMUSG00000056536_r Pign protein_coding chromosome +#> ENSMUSG00000056536_f Pign protein_coding chromosome +#> ENSMUSG00000074813_r Morrbid lncRNA chromosome +#> ENSMUSG00000074813_f Morrbid lncRNA chromosome +#> ENSMUSG00000036885_f Arhgef26 protein_coding chromosome +#> ... ... ... ... +#> ENSMUSG00000055538_f Zcchc24 protein_coding chromosome +#> ENSMUSG00000038418_f Egr1 protein_coding chromosome +#> ENSMUSG00000038418_r Egr1 protein_coding chromosome +#> ENSMUSG00000024544_f Ldlrad4 protein_coding chromosome +#> ENSMUSG00000024544_r Ldlrad4 protein_coding chromosome +#> description +#> <character> +#> ENSMUSG00000056536_r phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] +#> ENSMUSG00000056536_f phosphatidylinositol glycan anchor biosynthesis, class N [Source:MGI Symbol;Acc:MGI:1351629] +#> ENSMUSG00000074813_r myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] +#> ENSMUSG00000074813_f myeloid RNA regulator of BCL2L11 induced cell death [Source:MGI Symbol;Acc:MGI:3652191] +#> ENSMUSG00000036885_f Rho guanine nucleotide exchange factor (GEF) 26 [Source:MGI Symbol;Acc:MGI:1918053] +#> ... ... +#> ENSMUSG00000055538_f zinc finger, CCHC domain containing 24 [Source:MGI Symbol;Acc:MGI:1919168] +#> ENSMUSG00000038418_f early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] +#> ENSMUSG00000038418_r early growth response 1 [Source:MGI Symbol;Acc:MGI:95295] +#> ENSMUSG00000024544_f low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] +#> ENSMUSG00000024544_r low density lipoprotein receptor class A domain containing 4 [Source:MGI Symbol;Acc:MGI:1277150] +#> gene_id_version symbol entrezid +#> <character> <character> <list> +#> ENSMUSG00000056536_r ENSMUSG00000056536.14 Pign 27392 +#> ENSMUSG00000056536_f ENSMUSG00000056536.14 Pign 27392 +#> ENSMUSG00000074813_r ENSMUSG00000074813.13 Morrbid NA +#> ENSMUSG00000074813_f ENSMUSG00000074813.13 Morrbid NA +#> ENSMUSG00000036885_f ENSMUSG00000036885.14 Arhgef26 622434 +#> ... ... ... ... +#> ENSMUSG00000055538_f ENSMUSG00000055538.7 Zcchc24 71918 +#> ENSMUSG00000038418_f ENSMUSG00000038418.7 Egr1 13653 +#> ENSMUSG00000038418_r ENSMUSG00000038418.7 Egr1 13653 +#> ENSMUSG00000024544_f ENSMUSG00000024544.9 Ldlrad4 52662 +#> ENSMUSG00000024544_r ENSMUSG00000024544.9 Ldlrad4 52662 +#> targetname targetstart targetend +#> <character> <integer> <integer> +#> ENSMUSG00000056536_r ENSMUSG00000056536_r 105518422 105663677 +#> ENSMUSG00000056536_f ENSMUSG00000056536_f 105518422 105663677 +#> ENSMUSG00000074813_r ENSMUSG00000074813_r 128178319 128502765 +#> ENSMUSG00000074813_f ENSMUSG00000074813_f 128178319 128502765 +#> ENSMUSG00000036885_f ENSMUSG00000036885_f 62338344 62462221 +#> ... ... ... ... +#> ENSMUSG00000055538_f ENSMUSG00000055538_f 25711642 25769039 +#> ENSMUSG00000038418_f ENSMUSG00000038418_f 34859823 34864984 +#> ENSMUSG00000038418_r ENSMUSG00000038418_r 34859823 34864984 +#> ENSMUSG00000024544_f ENSMUSG00000024544_f 67933257 68268630 +#> ENSMUSG00000024544_r ENSMUSG00000024544_r 67933257 68268630 +#> ------- +#> seqinfo: 118 sequences from GRCm38 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/get_bsgenome.html b/public/reference/get_bsgenome.html index 6e5afd99c7d6dd7ffe32ee8bb933e4a6e1cac24c..f4c0da65ef3432f4ecf081475ebbf654e640523e 100644 --- a/public/reference/get_bsgenome.html +++ b/public/reference/get_bsgenome.html @@ -1,197 +1,197 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Get BSgenome — get_bsgenome • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Get BSgenome — get_bsgenome" /> - -<meta property="og:description" content="Get BSgenome" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Get BSgenome</h1> - - <div class="hidden name"><code>get_bsgenome.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Get BSgenome</p> - - </div> - - <pre class="usage"><span class='fu'>get_bsgenome</span>(<span class='no'>granges</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>BSgenome</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'>get_bsgenome</span>()</div><div class='output co'>#> Mouse genome: -#> # organism: Mus musculus (Mouse) -#> # provider: UCSC -#> # provider version: mm10 -#> # release date: Dec. 2011 -#> # release name: Genome Reference Consortium GRCm38 -#> # 66 sequences: -#> # chr1 chr2 chr3 -#> # chr4 chr5 chr6 -#> # chr7 chr8 chr9 -#> # chr10 chr11 chr12 -#> # chr13 chr14 chr15 -#> # ... ... ... -#> # chrUn_GL456372 chrUn_GL456378 chrUn_GL456379 -#> # chrUn_GL456381 chrUn_GL456382 chrUn_GL456383 -#> # chrUn_GL456385 chrUn_GL456387 chrUn_GL456389 -#> # chrUn_GL456390 chrUn_GL456392 chrUn_GL456393 -#> # chrUn_GL456394 chrUn_GL456396 chrUn_JH584304 -#> # (use 'seqnames()' to see all the sequence names, use the '$' or '[[' operator -#> # to access a given sequence)</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Get BSgenome — get_bsgenome • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Get BSgenome — get_bsgenome" /> + +<meta property="og:description" content="Get BSgenome" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Get BSgenome</h1> + + <div class="hidden name"><code>get_bsgenome.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Get BSgenome</p> + + </div> + + <pre class="usage"><span class='fu'>get_bsgenome</span>(<span class='no'>granges</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>BSgenome</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'>get_bsgenome</span>()</div><div class='output co'>#> Mouse genome: +#> # organism: Mus musculus (Mouse) +#> # provider: UCSC +#> # provider version: mm10 +#> # release date: Dec. 2011 +#> # release name: Genome Reference Consortium GRCm38 +#> # 66 sequences: +#> # chr1 chr2 chr3 +#> # chr4 chr5 chr6 +#> # chr7 chr8 chr9 +#> # chr10 chr11 chr12 +#> # chr13 chr14 chr15 +#> # ... ... ... +#> # chrUn_GL456372 chrUn_GL456378 chrUn_GL456379 +#> # chrUn_GL456381 chrUn_GL456382 chrUn_GL456383 +#> # chrUn_GL456385 chrUn_GL456387 chrUn_GL456389 +#> # chrUn_GL456390 chrUn_GL456392 chrUn_GL456393 +#> # chrUn_GL456394 chrUn_GL456396 chrUn_JH584304 +#> # (use 'seqnames()' to see all the sequence names, use the '$' or '[[' operator +#> # to access a given sequence)</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/gr2dt.html b/public/reference/gr2dt.html index 9de33a343fe465bc0ae3369d6a7dae0e9e598781..35add6e4a07929c0dfcae44972cd1082c0ff639c 100644 --- a/public/reference/gr2dt.html +++ b/public/reference/gr2dt.html @@ -1,205 +1,205 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>GRanges <-> data.table — gr2dt • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="GRanges <-> data.table — gr2dt" /> -<meta property="og:description" content="GRanges &lt;-&gt; data.table" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>GRanges <-> data.table</h1> - - <div class="hidden name"><code>gr2dt.Rd</code></div> - </div> - - <div class="ref-description"> - <p>GRanges <-> data.table</p> - </div> - - <pre class="usage"><span class='fu'>gr2dt</span>(<span class='no'>gr</span>) - -<span class='fu'>dt2gr</span>(<span class='no'>dt</span>, <span class='no'>seqinfo</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>dt</th> - <td><p>data.table</p></td> - </tr> - <tr> - <th>seqinfo</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomeInfoDb/man/Seqinfo-class.html'>Seqinfo-class</a></code></p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>data.table (gr2dt) or GRanges (dt2gr)</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> -<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) -(<span class='no'>dt</span> <span class='kw'><-</span> <span class='fu'>gr2dt</span>(<span class='no'>gr</span>))</div><div class='output co'>#> seqnames start end width strand targetname targetstart targetend -#> 1: chr20 4699600 4699600 1 + PRNP 4699600 4699600 -#> 2: chr11 5227002 5227002 1 - HBB 5227002 5227002 -#> 3: chr15 72346580 72346583 4 - HEXA 72346580 72346583 -#> 4: chr7 117559593 117559595 3 + CFTR 117559593 117559595 -#> names -#> 1: PRNP -#> 2: HBB -#> 3: HEXA -#> 4: CFTR</div><div class='input'>(<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>dt2gr</span>(<span class='no'>dt</span>, <span class='kw pkg'>BSgenome</span><span class='kw ns'>::</span><span class='fu'>seqinfo</span>(<span class='no'>bsgenome</span>)))</div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699600 + | PRNP 4699600 4699600 -#> HBB chr11 5227002 - | HBB 5227002 5227002 -#> HEXA chr15 72346580-72346583 - | HEXA 72346580 72346583 -#> CFTR chr7 117559593-117559595 + | CFTR 117559593 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>GRanges <-> data.table — gr2dt • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="GRanges <-> data.table — gr2dt" /> +<meta property="og:description" content="GRanges &lt;-&gt; data.table" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>GRanges <-> data.table</h1> + + <div class="hidden name"><code>gr2dt.Rd</code></div> + </div> + + <div class="ref-description"> + <p>GRanges <-> data.table</p> + </div> + + <pre class="usage"><span class='fu'>gr2dt</span>(<span class='no'>gr</span>) + +<span class='fu'>dt2gr</span>(<span class='no'>dt</span>, <span class='no'>seqinfo</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>dt</th> + <td><p>data.table</p></td> + </tr> + <tr> + <th>seqinfo</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomeInfoDb/man/Seqinfo-class.html'>Seqinfo-class</a></code></p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>data.table (gr2dt) or GRanges (dt2gr)</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> +<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) +(<span class='no'>dt</span> <span class='kw'><-</span> <span class='fu'>gr2dt</span>(<span class='no'>gr</span>))</div><div class='output co'>#> seqnames start end width strand targetname targetstart targetend +#> 1: chr20 4699600 4699600 1 + PRNP 4699600 4699600 +#> 2: chr11 5227002 5227002 1 - HBB 5227002 5227002 +#> 3: chr15 72346580 72346583 4 - HEXA 72346580 72346583 +#> 4: chr7 117559593 117559595 3 + CFTR 117559593 117559595 +#> names +#> 1: PRNP +#> 2: HBB +#> 3: HEXA +#> 4: CFTR</div><div class='input'>(<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'>dt2gr</span>(<span class='no'>dt</span>, <span class='kw pkg'>BSgenome</span><span class='kw ns'>::</span><span class='fu'>seqinfo</span>(<span class='no'>bsgenome</span>)))</div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699600 + | PRNP 4699600 4699600 +#> HBB chr11 5227002 - | HBB 5227002 5227002 +#> HEXA chr15 72346580-72346583 - | HEXA 72346580 72346583 +#> CFTR chr7 117559593-117559595 + | CFTR 117559593 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/has_been_indexed.html b/public/reference/has_been_indexed.html index 6c70234746f1cc7a947b1ab81ccc16e1f83d9213..11c16e0f188d1a8bd49a628fcd39647050d09cd8 100644 --- a/public/reference/has_been_indexed.html +++ b/public/reference/has_been_indexed.html @@ -1,173 +1,173 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Has been indexed? — has_been_indexed • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Has been indexed? — has_been_indexed" /> -<meta property="og:description" content="Has been indexed?" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Has been indexed?</h1> - - <div class="hidden name"><code>has_been_indexed.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Has been indexed?</p> - </div> - - <pre class="usage"><span class='fu'>has_been_indexed</span>(<span class='no'>bsgenome</span>, <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>bsgenome</th> - <td><p>BSgenome</p></td> - </tr> - <tr> - <th>indexedgenomesdir</th> - <td><p>directory with indexed genomes</p></td> - </tr> - </table> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> -<span class='fu'>has_been_indexed</span>(<span class='no'>bsgenome</span>)</div><div class='output co'>#> [1] TRUE</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Has been indexed? — has_been_indexed • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Has been indexed? — has_been_indexed" /> +<meta property="og:description" content="Has been indexed?" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Has been indexed?</h1> + + <div class="hidden name"><code>has_been_indexed.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Has been indexed?</p> + </div> + + <pre class="usage"><span class='fu'>has_been_indexed</span>(<span class='no'>bsgenome</span>, <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>bsgenome</th> + <td><p>BSgenome</p></td> + </tr> + <tr> + <th>indexedgenomesdir</th> + <td><p>directory with indexed genomes</p></td> + </tr> + </table> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> +<span class='fu'>has_been_indexed</span>(<span class='no'>bsgenome</span>)</div><div class='output co'>#> [1] TRUE</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/index.html b/public/reference/index.html index 64f63008fa2a728017283a11e04b878f35a3a70d..94ec764c22ad838c59d25b7d5d1c8a0be2ddda72 100644 --- a/public/reference/index.html +++ b/public/reference/index.html @@ -1,343 +1,343 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Function reference • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Function reference" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-index"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="contents col-md-9"> - <div class="page-header"> - <h1>Reference</h1> - </div> - - <table class="ref-index"> - - <colgroup> - - <col class="alias" /> - <col class="title" /> - </colgroup> - - <tbody> - <tr> - <th colspan="2"> - <h2 id="section-all-functions" class="hasAnchor"><a href="#section-all-functions" class="anchor"></a>All functions</h2> - <p class="section-desc"></p> - </th> - </tr> - <tr> - - <td> - <p><code><a href="add_context.html">add_context()</a></code> </p> - </td> - <td><p>Add [-4, +3] context</p></td> - </tr><tr> - - <td> - <p><code><a href="add_efficiency.html">add_efficiency()</a></code> <code><a href="add_efficiency.html">filter_efficient()</a></code> </p> - </td> - <td><p>Add efficiency scores and filter</p></td> - </tr><tr> - - <td> - <p><code><a href="add_genome_counts.html">add_genome_counts()</a></code> </p> - </td> - <td><p>Add genome counts</p></td> - </tr><tr> - - <td> - <p><code><a href="add_inverse_strand.html">add_inverse_strand()</a></code> </p> - </td> - <td><p>Add inverse strand</p></td> - </tr><tr> - - <td> - <p><code><a href="add_offtargets.html">add_specificity()</a></code> <code><a href="add_offtargets.html">add_offtargets()</a></code> </p> - </td> - <td><p>Add offtarget counts</p></td> - </tr><tr> - - <td> - <p><code><a href="add_seq.html">add_seq()</a></code> </p> - </td> - <td><p>Add sequence to GRanges</p></td> - </tr><tr> - - <td> - <p><code><a href="add_target_counts.html">add_target_counts()</a></code> </p> - </td> - <td><p>Add target counts</p></td> - </tr><tr> - - <td> - <p><code><a href="bed_to_granges.html">bed_to_granges()</a></code> </p> - </td> - <td><p>Read bedfile into GRanges</p></td> - </tr><tr> - - <td> - <p><code><a href="char_to_granges.html">char_to_granges()</a></code> </p> - </td> - <td><p>Convert character vector into GRanges</p></td> - </tr><tr> - - <td> - <p><code><a href="double_flank.html">double_flank()</a></code> </p> - </td> - <td><p>Double flank</p></td> - </tr><tr> - - <td> - <p><code><a href="EnsDb.Hsapiens.v99.html">EnsDb.Hsapiens.v99()</a></code> </p> - </td> - <td><p>Get EnsDb.Hsapiens.v98 from AnnotationHub</p></td> - </tr><tr> - - <td> - <p><code><a href="EnsDb.Mmusculus.v98.html">EnsDb.Mmusculus.v98()</a></code> </p> - </td> - <td><p>Get EnsDb.Mmusculus.v98 from AnnotationHub</p></td> - </tr><tr> - - <td> - <p><code><a href="extend_for_pe.html">extend_for_pe()</a></code> </p> - </td> - <td><p>Extend ranges for prime editing</p></td> - </tr><tr> - - <td> - <p><code><a href="extend_pe_to_gg.html">extend_pe_to_gg()</a></code> </p> - </td> - <td><p>Extend prime editing target to find GG sites</p></td> - </tr><tr> - - <td> - <p><code><a href="extract_matchranges.html">extract_matchranges()</a></code> </p> - </td> - <td><p>Extract matching subranges</p></td> - </tr><tr> - - <td> - <p><code><a href="extract_subranges.html">extract_subranges()</a></code> </p> - </td> - <td><p>Extract subranges</p></td> - </tr><tr> - - <td> - <p><code><a href="find_gg.html">find_gg()</a></code> </p> - </td> - <td><p>Find GG</p></td> - </tr><tr> - - <td> - <p><code><a href="find_pe_spacers.html">find_pe_spacers()</a></code> </p> - </td> - <td><p>Find prime editing spacers</p></td> - </tr><tr> - - <td> - <p><code><a href="find_spacers.html">find_spacers()</a></code> </p> - </td> - <td><p>Find crispr spacers in targetranges</p></td> - </tr><tr> - - <td> - <p><code><a href="genes_to_granges.html">genes_to_granges()</a></code> <code><a href="genes_to_granges.html">genefile_to_granges()</a></code> </p> - </td> - <td><p>Convert geneids into GRanges</p></td> - </tr><tr> - - <td> - <p><code><a href="gr2dt.html">gr2dt()</a></code> <code><a href="gr2dt.html">dt2gr()</a></code> </p> - </td> - <td><p>GRanges <-> data.table</p></td> - </tr><tr> - - <td> - <p><code><a href="has_been_indexed.html">has_been_indexed()</a></code> </p> - </td> - <td><p>Has been indexed?</p></td> - </tr><tr> - - <td> - <p><code><a href="index_genome.html">index_genome()</a></code> </p> - </td> - <td><p>Index genome</p></td> - </tr><tr> - - <td> - <p><code><a href="index_targets.html">index_targets()</a></code> </p> - </td> - <td><p>Index targets</p></td> - </tr><tr> - - <td> - <p><code><a href="make_unique_names.html">make_unique_names()</a></code> </p> - </td> - <td><p>Make unique names</p></td> - </tr><tr> - - <td> - <p><code><a href="match_seqs.html">match_seqs()</a></code> </p> - </td> - <td><p>Match spacer sequences</p></td> - </tr><tr> - - <td> - <p><code><a href="match_spacers.html">match_spacers()</a></code> </p> - </td> - <td><p>Match spacers</p></td> - </tr><tr> - - <td> - <p><code><a href="plot_intervals.html">plot_intervals()</a></code> </p> - </td> - <td><p>Interval plot GRanges</p></td> - </tr><tr> - - <td> - <p><code><a href="plot_karyogram.html">plot_karyogram()</a></code> </p> - </td> - <td><p>Karyo/Interval Plot GRanges(List)</p></td> - </tr><tr> - - <td> - <p><code><a href="up_flank.html">up_flank()</a></code> <code><a href="up_flank.html">down_flank()</a></code> <code><a href="up_flank.html">extend()</a></code> </p> - </td> - <td><p>Extend or Flank GRanges</p></td> - </tr> - </tbody> - </table> - </div> - - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#section-all-functions">All functions</a></li> - </ul> - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Function reference • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Function reference" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-index"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="contents col-md-9"> + <div class="page-header"> + <h1>Reference</h1> + </div> + + <table class="ref-index"> + + <colgroup> + + <col class="alias" /> + <col class="title" /> + </colgroup> + + <tbody> + <tr> + <th colspan="2"> + <h2 id="section-all-functions" class="hasAnchor"><a href="#section-all-functions" class="anchor"></a>All functions</h2> + <p class="section-desc"></p> + </th> + </tr> + <tr> + + <td> + <p><code><a href="add_context.html">add_context()</a></code> </p> + </td> + <td><p>Add [-4, +3] context</p></td> + </tr><tr> + + <td> + <p><code><a href="add_efficiency.html">add_efficiency()</a></code> <code><a href="add_efficiency.html">filter_efficient()</a></code> </p> + </td> + <td><p>Add efficiency scores and filter</p></td> + </tr><tr> + + <td> + <p><code><a href="add_genome_counts.html">add_genome_counts()</a></code> </p> + </td> + <td><p>Add genome counts</p></td> + </tr><tr> + + <td> + <p><code><a href="add_inverse_strand.html">add_inverse_strand()</a></code> </p> + </td> + <td><p>Add inverse strand</p></td> + </tr><tr> + + <td> + <p><code><a href="add_offtargets.html">add_specificity()</a></code> <code><a href="add_offtargets.html">add_offtargets()</a></code> </p> + </td> + <td><p>Add offtarget counts</p></td> + </tr><tr> + + <td> + <p><code><a href="add_seq.html">add_seq()</a></code> </p> + </td> + <td><p>Add sequence to GRanges</p></td> + </tr><tr> + + <td> + <p><code><a href="add_target_counts.html">add_target_counts()</a></code> </p> + </td> + <td><p>Add target counts</p></td> + </tr><tr> + + <td> + <p><code><a href="bed_to_granges.html">bed_to_granges()</a></code> </p> + </td> + <td><p>Read bedfile into GRanges</p></td> + </tr><tr> + + <td> + <p><code><a href="char_to_granges.html">char_to_granges()</a></code> </p> + </td> + <td><p>Convert character vector into GRanges</p></td> + </tr><tr> + + <td> + <p><code><a href="double_flank.html">double_flank()</a></code> </p> + </td> + <td><p>Double flank</p></td> + </tr><tr> + + <td> + <p><code><a href="EnsDb.Hsapiens.v99.html">EnsDb.Hsapiens.v99()</a></code> </p> + </td> + <td><p>Get EnsDb.Hsapiens.v98 from AnnotationHub</p></td> + </tr><tr> + + <td> + <p><code><a href="EnsDb.Mmusculus.v98.html">EnsDb.Mmusculus.v98()</a></code> </p> + </td> + <td><p>Get EnsDb.Mmusculus.v98 from AnnotationHub</p></td> + </tr><tr> + + <td> + <p><code><a href="extend_for_pe.html">extend_for_pe()</a></code> </p> + </td> + <td><p>Extend ranges for prime editing</p></td> + </tr><tr> + + <td> + <p><code><a href="extend_pe_to_gg.html">extend_pe_to_gg()</a></code> </p> + </td> + <td><p>Extend prime editing target to find GG sites</p></td> + </tr><tr> + + <td> + <p><code><a href="extract_matchranges.html">extract_matchranges()</a></code> </p> + </td> + <td><p>Extract matching subranges</p></td> + </tr><tr> + + <td> + <p><code><a href="extract_subranges.html">extract_subranges()</a></code> </p> + </td> + <td><p>Extract subranges</p></td> + </tr><tr> + + <td> + <p><code><a href="find_gg.html">find_gg()</a></code> </p> + </td> + <td><p>Find GG</p></td> + </tr><tr> + + <td> + <p><code><a href="find_pe_spacers.html">find_pe_spacers()</a></code> </p> + </td> + <td><p>Find prime editing spacers</p></td> + </tr><tr> + + <td> + <p><code><a href="find_spacers.html">find_spacers()</a></code> </p> + </td> + <td><p>Find crispr spacers in targetranges</p></td> + </tr><tr> + + <td> + <p><code><a href="genes_to_granges.html">genes_to_granges()</a></code> <code><a href="genes_to_granges.html">genefile_to_granges()</a></code> </p> + </td> + <td><p>Convert geneids into GRanges</p></td> + </tr><tr> + + <td> + <p><code><a href="gr2dt.html">gr2dt()</a></code> <code><a href="gr2dt.html">dt2gr()</a></code> </p> + </td> + <td><p>GRanges <-> data.table</p></td> + </tr><tr> + + <td> + <p><code><a href="has_been_indexed.html">has_been_indexed()</a></code> </p> + </td> + <td><p>Has been indexed?</p></td> + </tr><tr> + + <td> + <p><code><a href="index_genome.html">index_genome()</a></code> </p> + </td> + <td><p>Index genome</p></td> + </tr><tr> + + <td> + <p><code><a href="index_targets.html">index_targets()</a></code> </p> + </td> + <td><p>Index targets</p></td> + </tr><tr> + + <td> + <p><code><a href="make_unique_names.html">make_unique_names()</a></code> </p> + </td> + <td><p>Make unique names</p></td> + </tr><tr> + + <td> + <p><code><a href="match_seqs.html">match_seqs()</a></code> </p> + </td> + <td><p>Match spacer sequences</p></td> + </tr><tr> + + <td> + <p><code><a href="match_spacers.html">match_spacers()</a></code> </p> + </td> + <td><p>Match spacers</p></td> + </tr><tr> + + <td> + <p><code><a href="plot_intervals.html">plot_intervals()</a></code> </p> + </td> + <td><p>Interval plot GRanges</p></td> + </tr><tr> + + <td> + <p><code><a href="plot_karyogram.html">plot_karyogram()</a></code> </p> + </td> + <td><p>Karyo/Interval Plot GRanges(List)</p></td> + </tr><tr> + + <td> + <p><code><a href="up_flank.html">up_flank()</a></code> <code><a href="up_flank.html">down_flank()</a></code> <code><a href="up_flank.html">extend()</a></code> </p> + </td> + <td><p>Extend or Flank GRanges</p></td> + </tr> + </tbody> + </table> + </div> + + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#section-all-functions">All functions</a></li> + </ul> + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/index_genome.html b/public/reference/index_genome.html index 30420227988f51df879aa6de7ba366e6e2d3f6bb..f7a8a6658c0e82fe3be1c4d182367058bb072bfe 100644 --- a/public/reference/index_genome.html +++ b/public/reference/index_genome.html @@ -1,202 +1,202 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Index genome — index_genome • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Index genome — index_genome" /> -<meta property="og:description" content="Bowtie index genome" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Index genome</h1> - - <div class="hidden name"><code>index_genome.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Bowtie index genome</p> - </div> - - <pre class="usage"><span class='fu'>index_genome</span>( - <span class='no'>bsgenome</span>, - <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, - <span class='kw'>download</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>overwrite</span> <span class='kw'>=</span> <span class='fl'>FALSE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>indexedgenomesdir</th> - <td><p>string: directory with bowtie-indexed genome</p></td> - </tr> - <tr> - <th>download</th> - <td><p>TRUE (default) or FALSE: whether to download pre-indexed -version if available</p></td> - </tr> - <tr> - <th>overwrite</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>invisible(genomdir)</p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>Checks whether already available locally. If not, checks whether indexed -version can be downloaded from our s3 storage. If not, builds the -index with bowtie. This can take a few hours, but is a one-time operation.</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'>#bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -#index_genome(bsgenome) -#bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -#index_genome(bsgenome) -#bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 -#index_genome(bsgenome) -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Index genome — index_genome • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Index genome — index_genome" /> +<meta property="og:description" content="Bowtie index genome" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Index genome</h1> + + <div class="hidden name"><code>index_genome.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Bowtie index genome</p> + </div> + + <pre class="usage"><span class='fu'>index_genome</span>( + <span class='no'>bsgenome</span>, + <span class='kw'>indexedgenomesdir</span> <span class='kw'>=</span> <span class='no'>INDEXEDGENOMESDIR</span>, + <span class='kw'>download</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>overwrite</span> <span class='kw'>=</span> <span class='fl'>FALSE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>indexedgenomesdir</th> + <td><p>string: directory with bowtie-indexed genome</p></td> + </tr> + <tr> + <th>download</th> + <td><p>TRUE (default) or FALSE: whether to download pre-indexed +version if available</p></td> + </tr> + <tr> + <th>overwrite</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>invisible(genomdir)</p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>Checks whether already available locally. If not, checks whether indexed +version can be downloaded from our s3 storage. If not, builds the +index with bowtie. This can take a few hours, but is a one-time operation.</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'>#bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +#index_genome(bsgenome) +#bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +#index_genome(bsgenome) +#bsgenome <- BSgenome.Hsapiens.NCBI.GRCh38::BSgenome.Hsapiens.NCBI.GRCh38 +#index_genome(bsgenome) +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/index_targets-1.png b/public/reference/index_targets-1.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/index_targets-1.png and b/public/reference/index_targets-1.png differ diff --git a/public/reference/index_targets.html b/public/reference/index_targets.html index ac72c485662babfa75cd707d5c7de252ebfba7d4..556243809073254ce525ed7764783ce9f41519e1 100644 --- a/public/reference/index_targets.html +++ b/public/reference/index_targets.html @@ -1,192 +1,192 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Index targets — index_targets • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Index targets — index_targets" /> -<meta property="og:description" content="Bowtie index targets" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Index targets</h1> - - <div class="hidden name"><code>index_targets.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Bowtie index targets</p> - </div> - - <pre class="usage"><span class='fu'>index_targets</span>( - <span class='no'>targets</span>, - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>targets</span>)[<span class='fl'>1</span>]), - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>targets</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>string: output directory</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>invisible(targetdir)</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='index_targets-1.png' alt='' width='700' height='433' /></div><div class='input'><span class='fu'>index_targets</span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets</span></div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Index targets — index_targets • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Index targets — index_targets" /> +<meta property="og:description" content="Bowtie index targets" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Index targets</h1> + + <div class="hidden name"><code>index_targets.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Bowtie index targets</p> + </div> + + <pre class="usage"><span class='fu'>index_targets</span>( + <span class='no'>targets</span>, + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='fu'>getBSgenome</span>(<span class='fu'>genome</span>(<span class='no'>targets</span>)[<span class='fl'>1</span>]), + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>targets</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p><code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code></p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>string: output directory</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>invisible(targetdir)</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='index_targets-1.png' alt='' width='700' height='433' /></div><div class='input'><span class='fu'>index_targets</span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets</span></div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/left_flank.html b/public/reference/left_flank.html index acd16c6e19adcf62628d0297651dd6544e0821bb..b887dcee138d87d96c6c84b52baf8d15e40eb4f0 100644 --- a/public/reference/left_flank.html +++ b/public/reference/left_flank.html @@ -1,204 +1,204 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Left flank — left_flank • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Left flank — left_flank" /> - -<meta property="og:description" content="Left flank" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Left flank</h1> - - <div class="hidden name"><code>left_flank.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Left flank</p> - - </div> - - <pre class="usage"><span class='fu'>left_flank</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>200</span>, <span class='kw'>leftend</span> <span class='kw'>=</span> -<span class='fl'>1</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - <tr> - <th>leftstart</th> - <td><p>left flank start (relative to range start)</p></td> - </tr> - <tr> - <th>leftend</th> - <td><p>left flank end (relative to range start)</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>3</span>)</div><div class='output co'>#> GRanges object with 3 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 - -#> [2] chr1 5250211-5250227 - -#> [3] chr1 5250451-5250467 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>3</span>) <span class='kw'>%>%</span> <span class='fu'>left_flank</span>()</div><div class='output co'>#> <span class='message'> 3 left flanks : [start-200, start-1]</span></div><div class='output co'>#> GRanges object with 3 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712427-4712626 - -#> [2] chr1 5250011-5250210 - -#> [3] chr1 5250251-5250450 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Left flank — left_flank • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Left flank — left_flank" /> + +<meta property="og:description" content="Left flank" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Left flank</h1> + + <div class="hidden name"><code>left_flank.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Left flank</p> + + </div> + + <pre class="usage"><span class='fu'>left_flank</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>200</span>, <span class='kw'>leftend</span> <span class='kw'>=</span> -<span class='fl'>1</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + <tr> + <th>leftstart</th> + <td><p>left flank start (relative to range start)</p></td> + </tr> + <tr> + <th>leftend</th> + <td><p>left flank end (relative to range start)</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>3</span>)</div><div class='output co'>#> GRanges object with 3 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 - +#> [2] chr1 5250211-5250227 - +#> [3] chr1 5250451-5250467 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>3</span>) <span class='kw'>%>%</span> <span class='fu'>left_flank</span>()</div><div class='output co'>#> <span class='message'> 3 left flanks : [start-200, start-1]</span></div><div class='output co'>#> GRanges object with 3 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712427-4712626 - +#> [2] chr1 5250011-5250210 - +#> [3] chr1 5250251-5250450 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/make_unique_names.html b/public/reference/make_unique_names.html index 791f5425ec37985261266208b6cdc883f22430d9..082e1bbb9e4a26bb92410200d02b7b3e4b560910 100644 --- a/public/reference/make_unique_names.html +++ b/public/reference/make_unique_names.html @@ -1,173 +1,173 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Make unique names — make_unique_names • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Make unique names — make_unique_names" /> -<meta property="og:description" content="Make unique names" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Make unique names</h1> - - <div class="hidden name"><code>make_unique_names.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Make unique names</p> - </div> - - <pre class="usage"><span class='fu'>make_unique_names</span>(<span class='no'>x</span>, <span class='kw'>prefix</span> <span class='kw'>=</span> <span class='st'>"T"</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>x</th> - <td><p>vector</p></td> - </tr> - <tr> - <th>prefix</th> - <td><p>string: prefix with which to start names</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>character vector with unique names</p> - - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Make unique names — make_unique_names • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Make unique names — make_unique_names" /> +<meta property="og:description" content="Make unique names" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Make unique names</h1> + + <div class="hidden name"><code>make_unique_names.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Make unique names</p> + </div> + + <pre class="usage"><span class='fu'>make_unique_names</span>(<span class='no'>x</span>, <span class='kw'>prefix</span> <span class='kw'>=</span> <span class='st'>"T"</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>x</th> + <td><p>vector</p></td> + </tr> + <tr> + <th>prefix</th> + <td><p>string: prefix with which to start names</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>character vector with unique names</p> + + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/match_seqs-1.png b/public/reference/match_seqs-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/match_seqs-1.png and b/public/reference/match_seqs-1.png differ diff --git a/public/reference/match_seqs-2.png b/public/reference/match_seqs-2.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/match_seqs-2.png and b/public/reference/match_seqs-2.png differ diff --git a/public/reference/match_seqs-3.png b/public/reference/match_seqs-3.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/match_seqs-3.png and b/public/reference/match_seqs-3.png differ diff --git a/public/reference/match_seqs.html b/public/reference/match_seqs.html index 0abb0ec4acd809ff7ac9683f0630879da952fb1a..f215163988bd30a1c65d74f5840b4720e8f193f6 100644 --- a/public/reference/match_seqs.html +++ b/public/reference/match_seqs.html @@ -1,246 +1,246 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Match spacer sequences — match_seqs • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Match spacer sequences — match_seqs" /> -<meta property="og:description" content="Count matches to indexed target/genome" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Match spacer sequences</h1> - - <div class="hidden name"><code>match_seqs.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Count matches to indexed target/genome</p> - </div> - - <pre class="usage"><span class='fu'>match_seqs</span>( - <span class='no'>seqs</span>, - <span class='no'>indexdir</span>, - <span class='no'>norc</span>, - <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>seqs</th> - <td><p>character vector: sequences to match against indexed ref</p></td> - </tr> - <tr> - <th>indexdir</th> - <td><p>string: dir containing indexed reference. -This can be an indexed genome( <code><a href='index_genome.html'>index_genome</a></code> -It can also be indexed targets (<code><a href='index_targets.html'>index_targets</a></code>)</p></td> - </tr> - <tr> - <th>norc</th> - <td><p>TRUE or FALSE: whether to run bowtie also with revcompls -Generally TRUE for genome and FALSE for target matches, -because target ranges generally include both strands.</p></td> - </tr> - <tr> - <th>mismatches</th> - <td><p>max number of mismatches to consider</p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>string: multicrispr output directory</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>data.table</p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='match_seqs-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome)</span> - <span class='co'># match_seqs(spacers$crisprspacer, indexdir, norc=TRUE, mismatches = 1)</span> - -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='match_seqs-2.png' alt='' width='700' height='433' /></div><div class='input'><span class='no'>indexdir</span> <span class='kw'><-</span> <span class='fu'><a href='index_targets.html'>index_targets</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets</span></div><div class='input'><span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='match_seqs-3.png' alt='' width='700' height='433' /></div><div class='input'><span class='no'>seqs</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/unique.html'>unique</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/paste.html'>paste0</a></span>(<span class='no'>spacers</span>$<span class='no'>crisprspacer</span>, <span class='no'>spacers</span>$<span class='no'>crisprpam</span>)) -<span class='fu'>match_seqs</span>(<span class='no'>seqs</span>, <span class='no'>indexdir</span>, <span class='kw'>norc</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> readseq MM0 MM1 MM2 -#> 1: ATATAAGGGCATTGGAAGAAGGG 2 1910 190 -#> 2: AATATAAGGGCATTGGAAGAAGG 2 1908 210 -#> 3: TGGAGACAATATAAGGGCATTGG 2 1948 188 -#> 4: TTCTGCTGGAGACAATATAAGGG 4 1646 474 -#> 5: CTTCTGCTGGAGACAATATAAGG 1644 480 38 -#> --- -#> 3040: AGATGAGGAATATGCAAATAAGG 2 0 0 -#> 3041: TTGCATATTCCTCATCTGATTGG 2 0 0 -#> 3042: AGTGTGCTTATAAGGGGGGAAGG 2 0 0 -#> 3043: AGAGAGTGTGCTTATAAGGGGGG 2 4 6 -#> 3044: AGCACACTCTCTTAGTAAATTGG 2 6 4</div><div class='input'><span class='fu'>match_seqs</span>(<span class='no'>seqs</span>, <span class='no'>indexdir</span>, <span class='kw'>norc</span><span class='kw'>=</span><span class='fl'>FALSE</span>, <span class='kw'>mismatches</span><span class='kw'>=</span><span class='fl'>3</span>)</div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> readseq MM0 MM1 MM2 MM3 -#> 1: ATATAAGGGCATTGGAAGAAGGG 2 1910 190 18 -#> 2: AATATAAGGGCATTGGAAGAAGG 2 1908 210 22 -#> 3: TGGAGACAATATAAGGGCATTGG 2 1948 188 22 -#> 4: TTCTGCTGGAGACAATATAAGGG 4 1646 474 40 -#> 5: CTTCTGCTGGAGACAATATAAGG 1644 480 38 12 -#> --- -#> 3040: AGATGAGGAATATGCAAATAAGG 2 0 0 0 -#> 3041: TTGCATATTCCTCATCTGATTGG 2 0 0 0 -#> 3042: AGTGTGCTTATAAGGGGGGAAGG 2 0 0 0 -#> 3043: AGAGAGTGTGCTTATAAGGGGGG 2 4 6 2 -#> 3044: AGCACACTCTCTTAGTAAATTGG 2 6 4 0</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Match spacer sequences — match_seqs • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Match spacer sequences — match_seqs" /> +<meta property="og:description" content="Count matches to indexed target/genome" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Match spacer sequences</h1> + + <div class="hidden name"><code>match_seqs.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Count matches to indexed target/genome</p> + </div> + + <pre class="usage"><span class='fu'>match_seqs</span>( + <span class='no'>seqs</span>, + <span class='no'>indexdir</span>, + <span class='no'>norc</span>, + <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>seqs</th> + <td><p>character vector: sequences to match against indexed ref</p></td> + </tr> + <tr> + <th>indexdir</th> + <td><p>string: dir containing indexed reference. +This can be an indexed genome( <code><a href='index_genome.html'>index_genome</a></code> +It can also be indexed targets (<code><a href='index_targets.html'>index_targets</a></code>)</p></td> + </tr> + <tr> + <th>norc</th> + <td><p>TRUE or FALSE: whether to run bowtie also with revcompls +Generally TRUE for genome and FALSE for target matches, +because target ranges generally include both strands.</p></td> + </tr> + <tr> + <th>mismatches</th> + <td><p>max number of mismatches to consider</p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>string: multicrispr output directory</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>data.table</p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='match_seqs-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome)</span> + <span class='co'># match_seqs(spacers$crisprspacer, indexdir, norc=TRUE, mismatches = 1)</span> + +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='match_seqs-2.png' alt='' width='700' height='433' /></div><div class='input'><span class='no'>indexdir</span> <span class='kw'><-</span> <span class='fu'><a href='index_targets.html'>index_targets</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets</span></div><div class='input'><span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='match_seqs-3.png' alt='' width='700' height='433' /></div><div class='input'><span class='no'>seqs</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/unique.html'>unique</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/paste.html'>paste0</a></span>(<span class='no'>spacers</span>$<span class='no'>crisprspacer</span>, <span class='no'>spacers</span>$<span class='no'>crisprpam</span>)) +<span class='fu'>match_seqs</span>(<span class='no'>seqs</span>, <span class='no'>indexdir</span>, <span class='kw'>norc</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> readseq MM0 MM1 MM2 +#> 1: ATATAAGGGCATTGGAAGAAGGG 2 1910 190 +#> 2: AATATAAGGGCATTGGAAGAAGG 2 1908 210 +#> 3: TGGAGACAATATAAGGGCATTGG 2 1948 188 +#> 4: TTCTGCTGGAGACAATATAAGGG 4 1646 474 +#> 5: CTTCTGCTGGAGACAATATAAGG 1644 480 38 +#> --- +#> 3040: AGATGAGGAATATGCAAATAAGG 2 0 0 +#> 3041: TTGCATATTCCTCATCTGATTGG 2 0 0 +#> 3042: AGTGTGCTTATAAGGGGGGAAGG 2 0 0 +#> 3043: AGAGAGTGTGCTTATAAGGGGGG 2 4 6 +#> 3044: AGCACACTCTCTTAGTAAATTGG 2 6 4</div><div class='input'><span class='fu'>match_seqs</span>(<span class='no'>seqs</span>, <span class='no'>indexdir</span>, <span class='kw'>norc</span><span class='kw'>=</span><span class='fl'>FALSE</span>, <span class='kw'>mismatches</span><span class='kw'>=</span><span class='fl'>3</span>)</div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> readseq MM0 MM1 MM2 MM3 +#> 1: ATATAAGGGCATTGGAAGAAGGG 2 1910 190 18 +#> 2: AATATAAGGGCATTGGAAGAAGG 2 1908 210 22 +#> 3: TGGAGACAATATAAGGGCATTGG 2 1948 188 22 +#> 4: TTCTGCTGGAGACAATATAAGGG 4 1646 474 40 +#> 5: CTTCTGCTGGAGACAATATAAGG 1644 480 38 12 +#> --- +#> 3040: AGATGAGGAATATGCAAATAAGG 2 0 0 0 +#> 3041: TTGCATATTCCTCATCTGATTGG 2 0 0 0 +#> 3042: AGTGTGCTTATAAGGGGGGAAGG 2 0 0 0 +#> 3043: AGAGAGTGTGCTTATAAGGGGGG 2 4 6 2 +#> 3044: AGCACACTCTCTTAGTAAATTGG 2 6 4 0</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/match_spacers-1.png b/public/reference/match_spacers-1.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/match_spacers-1.png and b/public/reference/match_spacers-1.png differ diff --git a/public/reference/match_spacers-2.png b/public/reference/match_spacers-2.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/match_spacers-2.png and b/public/reference/match_spacers-2.png differ diff --git a/public/reference/match_spacers-3.png b/public/reference/match_spacers-3.png index d9f5e72fc41de6d79da4542471713fe9f529710a..c8ec4f45e6e192df52b236e194d0d4643c337368 100644 Binary files a/public/reference/match_spacers-3.png and b/public/reference/match_spacers-3.png differ diff --git a/public/reference/match_spacers.html b/public/reference/match_spacers.html index 479efcd1caaea7aa233f80d85452c59b584aa901..8087108473064e023a3b5a4b354e159fc2da9a3d 100644 --- a/public/reference/match_spacers.html +++ b/public/reference/match_spacers.html @@ -1,245 +1,245 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Match spacers — match_spacers • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Match spacers — match_spacers" /> -<meta property="og:description" content="Count matches to indexed target/genome and add to GRanges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Match spacers</h1> - - <div class="hidden name"><code>match_spacers.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Count matches to indexed target/genome and add to GRanges</p> - </div> - - <pre class="usage"><span class='fu'>match_spacers</span>( - <span class='no'>spacers</span>, - <span class='no'>indexdir</span>, - <span class='no'>norc</span>, - <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, - <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>spacers</th> - <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>indexdir</th> - <td><p>string: dir containing indexed reference. -This can be an indexed genome( <code><a href='index_genome.html'>index_genome</a></code> -It can also be indexed targets (<code><a href='index_targets.html'>index_targets</a></code>)</p></td> - </tr> - <tr> - <th>norc</th> - <td><p>TRUE or FALSE: whether to run bowtie also with revcompls -Generally TRUE for genome and FALSE for target matches, -because target ranges generally include both strands.</p></td> - </tr> - <tr> - <th>mismatches</th> - <td><p>number (default 2): max number of mismatches to consider</p></td> - </tr> - <tr> - <th>outdir</th> - <td><p>string: file where to output bowtie results</p></td> - </tr> - <tr> - <th>pam</th> - <td><p>string (default 'NGG') pam pattern to expand</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE (default) or FALSE</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>data.table</p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>Expands iupac amgiguities in the pam sequence. -Matches all resulting sequences against (indexes) target and genome. -Adds match counts to GRanges object, and then returns it.</p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='match_spacers-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome)</span> - <span class='co'># match_spacers(spacers, indexdir, norc=TRUE, mismatches = 1)</span> - -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='match_spacers-2.png' alt='' width='700' height='433' /></div><div class='input'><span class='no'>indexdir</span> <span class='kw'><-</span> <span class='fu'><a href='index_targets.html'>index_targets</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets</span></div><div class='input'><span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='match_spacers-3.png' alt='' width='700' height='433' /></div><div class='input'><span class='fu'>match_spacers</span>(<span class='no'>spacers</span>, <span class='no'>indexdir</span>, <span class='kw'>norc</span><span class='kw'>=</span><span class='fl'>FALSE</span>, <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>1</span>)</div><div class='output co'>#> <span class='message'> Expand iupac ambiguities in pam</span></div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> crisprspacer MM0 MM1 -#> 1: ATATAAGGGCATTGGAAGAA 2 1946 -#> 2: AATATAAGGGCATTGGAAGA 2 1920 -#> 3: TGGAGACAATATAAGGGCAT 2 1950 -#> 4: TTCTGCTGGAGACAATATAA 4 1654 -#> 5: CTTCTGCTGGAGACAATATA 1650 484 -#> --- -#> 3013: AGATGAGGAATATGCAAATA 2 0 -#> 3014: TTGCATATTCCTCATCTGAT 2 0 -#> 3015: AGTGTGCTTATAAGGGGGGA 2 0 -#> 3016: AGAGAGTGTGCTTATAAGGG 2 4 -#> 3017: AGCACACTCTCTTAGTAAAT 2 6</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Match spacers — match_spacers • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Match spacers — match_spacers" /> +<meta property="og:description" content="Count matches to indexed target/genome and add to GRanges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Match spacers</h1> + + <div class="hidden name"><code>match_spacers.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Count matches to indexed target/genome and add to GRanges</p> + </div> + + <pre class="usage"><span class='fu'>match_spacers</span>( + <span class='no'>spacers</span>, + <span class='no'>indexdir</span>, + <span class='no'>norc</span>, + <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>outdir</span> <span class='kw'>=</span> <span class='no'>OUTDIR</span>, + <span class='kw'>pam</span> <span class='kw'>=</span> <span class='st'>"NGG"</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>spacers</th> + <td><p>spacer <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>indexdir</th> + <td><p>string: dir containing indexed reference. +This can be an indexed genome( <code><a href='index_genome.html'>index_genome</a></code> +It can also be indexed targets (<code><a href='index_targets.html'>index_targets</a></code>)</p></td> + </tr> + <tr> + <th>norc</th> + <td><p>TRUE or FALSE: whether to run bowtie also with revcompls +Generally TRUE for genome and FALSE for target matches, +because target ranges generally include both strands.</p></td> + </tr> + <tr> + <th>mismatches</th> + <td><p>number (default 2): max number of mismatches to consider</p></td> + </tr> + <tr> + <th>outdir</th> + <td><p>string: file where to output bowtie results</p></td> + </tr> + <tr> + <th>pam</th> + <td><p>string (default 'NGG') pam pattern to expand</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE (default) or FALSE</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>data.table</p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>Expands iupac amgiguities in the pam sequence. +Matches all resulting sequences against (indexes) target and genome. +Adds match counts to GRanges object, and then returns it.</p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='index_genome.html'>index_genome</a></code>, <code><a href='index_targets.html'>index_targets</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), <span class='co'># ins</span> + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='match_spacers-1.png' alt='' width='700' height='433' /></div><div class='input'> <span class='co'># indexdir <- genome_dir(indexedgenomesdir = INDEXEDGENOMESDIR, bsgenome)</span> + <span class='co'># match_spacers(spacers, indexdir, norc=TRUE, mismatches = 1)</span> + +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>extend</a></span>(<span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>))</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='match_spacers-2.png' alt='' width='700' height='433' /></div><div class='input'><span class='no'>indexdir</span> <span class='kw'><-</span> <span class='fu'><a href='index_targets.html'>index_targets</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Index target sequences</span></div><div class='output co'>#> <span class='message'> 1974 target ranges</span></div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='output co'>#> <span class='message'> 3932 ranges after merging overlaps</span></div><div class='output co'>#> <span class='message'> Write seqs to ~/multicrisprout/targets.fa</span></div><div class='output co'>#> <span class='message'> Write index to ~/multicrisprout/targets</span></div><div class='input'><span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_spacers.html'>find_spacers</a></span>(<span class='no'>targets</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> 3948 ranges after adding inverse strands</span></div><div class='img'><img src='match_spacers-3.png' alt='' width='700' height='433' /></div><div class='input'><span class='fu'>match_spacers</span>(<span class='no'>spacers</span>, <span class='no'>indexdir</span>, <span class='kw'>norc</span><span class='kw'>=</span><span class='fl'>FALSE</span>, <span class='kw'>mismatches</span> <span class='kw'>=</span> <span class='fl'>1</span>)</div><div class='output co'>#> <span class='message'> Expand iupac ambiguities in pam</span></div><div class='output co'>#> <span class='message'> Write reads to ~/multicrisprout/spacers.fa</span></div><div class='output co'>#> <span class='message'> Map reads: ~/multicrisprout/spacers/spacers_to_targets.txt</span></div><div class='output co'>#> <span class='message'> Load results</span></div><div class='output co'>#> <span class='message'> Count matches</span></div><div class='output co'>#> crisprspacer MM0 MM1 +#> 1: ATATAAGGGCATTGGAAGAA 2 1946 +#> 2: AATATAAGGGCATTGGAAGA 2 1920 +#> 3: TGGAGACAATATAAGGGCAT 2 1950 +#> 4: TTCTGCTGGAGACAATATAA 4 1654 +#> 5: CTTCTGCTGGAGACAATATA 1650 484 +#> --- +#> 3013: AGATGAGGAATATGCAAATA 2 0 +#> 3014: TTGCATATTCCTCATCTGAT 2 0 +#> 3015: AGTGTGCTTATAAGGGGGGA 2 0 +#> 3016: AGAGAGTGTGCTTATAAGGG 2 4 +#> 3017: AGCACACTCTCTTAGTAAAT 2 6</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/plot_intervals-1.png b/public/reference/plot_intervals-1.png index 2e88e3053ce76fcb60794af4fd07757a42a90a89..feff32c3472dcb694cf374482d1e0a7a5502e979 100644 Binary files a/public/reference/plot_intervals-1.png and b/public/reference/plot_intervals-1.png differ diff --git a/public/reference/plot_intervals-10.png b/public/reference/plot_intervals-10.png index 18bd932df20419ba95f52ec6e9be592724b8baf6..1ed7265d61b4b40815b251c63573d84f69c9edb7 100644 Binary files a/public/reference/plot_intervals-10.png and b/public/reference/plot_intervals-10.png differ diff --git a/public/reference/plot_intervals-2.png b/public/reference/plot_intervals-2.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/plot_intervals-2.png and b/public/reference/plot_intervals-2.png differ diff --git a/public/reference/plot_intervals-3.png b/public/reference/plot_intervals-3.png index 8480b1e58cf3005cb8362f3ee9fb35e1d7ee9104..13824c688c0e8701605708f86a96227f54cb8549 100644 Binary files a/public/reference/plot_intervals-3.png and b/public/reference/plot_intervals-3.png differ diff --git a/public/reference/plot_intervals-4.png b/public/reference/plot_intervals-4.png index 33275722d27825153bed232b875cbb8e8fc50a33..0596de9c018f1f58230d2c5777b62ce83b977b2c 100644 Binary files a/public/reference/plot_intervals-4.png and b/public/reference/plot_intervals-4.png differ diff --git a/public/reference/plot_intervals-5.png b/public/reference/plot_intervals-5.png index 18bd932df20419ba95f52ec6e9be592724b8baf6..1ed7265d61b4b40815b251c63573d84f69c9edb7 100644 Binary files a/public/reference/plot_intervals-5.png and b/public/reference/plot_intervals-5.png differ diff --git a/public/reference/plot_intervals-6.png b/public/reference/plot_intervals-6.png index f9eebb3779749d8050eae637fca854c586361a30..36e76a4da140c8ca4e71414a0429a1ca1f1698c8 100644 Binary files a/public/reference/plot_intervals-6.png and b/public/reference/plot_intervals-6.png differ diff --git a/public/reference/plot_intervals-7.png b/public/reference/plot_intervals-7.png index 8480b1e58cf3005cb8362f3ee9fb35e1d7ee9104..13824c688c0e8701605708f86a96227f54cb8549 100644 Binary files a/public/reference/plot_intervals-7.png and b/public/reference/plot_intervals-7.png differ diff --git a/public/reference/plot_intervals-8.png b/public/reference/plot_intervals-8.png index efd1af1ddd2ac724aead64f1ef309fbeffe7dc34..312172597cf678c35bb4393774a70c5ed9290822 100644 Binary files a/public/reference/plot_intervals-8.png and b/public/reference/plot_intervals-8.png differ diff --git a/public/reference/plot_intervals-9.png b/public/reference/plot_intervals-9.png index 33275722d27825153bed232b875cbb8e8fc50a33..0596de9c018f1f58230d2c5777b62ce83b977b2c 100644 Binary files a/public/reference/plot_intervals-9.png and b/public/reference/plot_intervals-9.png differ diff --git a/public/reference/plot_intervals.html b/public/reference/plot_intervals.html index 3ea3c5cfd9b82d0dee2b3762fc64984879374b60..2d09346732522e27b3d9e983252ce8566eeecd80 100644 --- a/public/reference/plot_intervals.html +++ b/public/reference/plot_intervals.html @@ -1,247 +1,247 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Interval plot GRanges — plot_intervals • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Interval plot GRanges — plot_intervals" /> -<meta property="og:description" content="Interval plot GRanges" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Interval plot GRanges</h1> - - <div class="hidden name"><code>plot_intervals.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Interval plot GRanges</p> - </div> - - <pre class="usage"><span class='fu'>plot_intervals</span>( - <span class='no'>gr</span>, - <span class='kw'>xref</span> <span class='kw'>=</span> <span class='st'>"targetname"</span>, - <span class='kw'>y</span> <span class='kw'>=</span> <span class='st'>"names"</span>, - <span class='kw'>nperchrom</span> <span class='kw'>=</span> <span class='fl'>2</span>, - <span class='kw'>nchrom</span> <span class='kw'>=</span> <span class='fl'>4</span>, - <span class='kw'>color_var</span> <span class='kw'>=</span> <span class='st'>"targetname"</span>, - <span class='kw'>facet_var</span> <span class='kw'>=</span> <span class='st'>"seqnames"</span>, - <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, - <span class='kw'>size_var</span> <span class='kw'>=</span> <span class='fu'>default_size_var</span>(<span class='no'>gr</span>), - <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='fu'>default_alpha_var</span>(<span class='no'>gr</span>), - <span class='kw'>title</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, - <span class='kw'>scales</span> <span class='kw'>=</span> <span class='st'>"free"</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>xref</th> - <td><p>gr var used for scaling x axis</p></td> - </tr> - <tr> - <th>y</th> - <td><p>'names' (default) or name of gr variable</p></td> - </tr> - <tr> - <th>nperchrom</th> - <td><p>number (default 1): n head (and n tail) targets -shown per chromosome</p></td> - </tr> - <tr> - <th>nchrom</th> - <td><p>number (default 6) of chromosomes shown</p></td> - </tr> - <tr> - <th>color_var</th> - <td><p>'seqnames' (default) or other gr variable</p></td> - </tr> - <tr> - <th>facet_var</th> - <td><p>NULL(default) or gr variable mapped to facet</p></td> - </tr> - <tr> - <th>linetype_var</th> - <td><p>NULL (default) or gr variable mapped to linetype</p></td> - </tr> - <tr> - <th>size_var</th> - <td><p>NULL (default) or gr variable mapped to size</p></td> - </tr> - <tr> - <th>alpha_var</th> - <td><p>NULL or gr variable mapped to alpha</p></td> - </tr> - <tr> - <th>title</th> - <td><p>NULL or string: plot title</p></td> - </tr> - <tr> - <th>scales</th> - <td><p>'free', 'fixed', etc</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>ggplot object</p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='plot_karyogram.html'>plot_karyogram</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># SRF sites</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='no'>targets</span>)</div><div class='img'><img src='plot_intervals-1.png' alt='' width='700' height='433' /></div><div class='input'> -<span class='co'># PE targets</span> - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), - <span class='no'>bsgenome</span>) - <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='plot_intervals-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='no'>gr</span>)</div><div class='img'><img src='plot_intervals-3.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>))</div><div class='img'><img src='plot_intervals-4.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='no'>spacers</span>)</div><div class='img'><img src='plot_intervals-5.png' alt='' width='700' height='433' /></div><div class='input'> -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Interval plot GRanges — plot_intervals • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Interval plot GRanges — plot_intervals" /> +<meta property="og:description" content="Interval plot GRanges" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Interval plot GRanges</h1> + + <div class="hidden name"><code>plot_intervals.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Interval plot GRanges</p> + </div> + + <pre class="usage"><span class='fu'>plot_intervals</span>( + <span class='no'>gr</span>, + <span class='kw'>xref</span> <span class='kw'>=</span> <span class='st'>"targetname"</span>, + <span class='kw'>y</span> <span class='kw'>=</span> <span class='st'>"names"</span>, + <span class='kw'>nperchrom</span> <span class='kw'>=</span> <span class='fl'>2</span>, + <span class='kw'>nchrom</span> <span class='kw'>=</span> <span class='fl'>4</span>, + <span class='kw'>color_var</span> <span class='kw'>=</span> <span class='st'>"targetname"</span>, + <span class='kw'>facet_var</span> <span class='kw'>=</span> <span class='st'>"seqnames"</span>, + <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, + <span class='kw'>size_var</span> <span class='kw'>=</span> <span class='fu'>default_size_var</span>(<span class='no'>gr</span>), + <span class='kw'>alpha_var</span> <span class='kw'>=</span> <span class='fu'>default_alpha_var</span>(<span class='no'>gr</span>), + <span class='kw'>title</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, + <span class='kw'>scales</span> <span class='kw'>=</span> <span class='st'>"free"</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>xref</th> + <td><p>gr var used for scaling x axis</p></td> + </tr> + <tr> + <th>y</th> + <td><p>'names' (default) or name of gr variable</p></td> + </tr> + <tr> + <th>nperchrom</th> + <td><p>number (default 1): n head (and n tail) targets +shown per chromosome</p></td> + </tr> + <tr> + <th>nchrom</th> + <td><p>number (default 6) of chromosomes shown</p></td> + </tr> + <tr> + <th>color_var</th> + <td><p>'seqnames' (default) or other gr variable</p></td> + </tr> + <tr> + <th>facet_var</th> + <td><p>NULL(default) or gr variable mapped to facet</p></td> + </tr> + <tr> + <th>linetype_var</th> + <td><p>NULL (default) or gr variable mapped to linetype</p></td> + </tr> + <tr> + <th>size_var</th> + <td><p>NULL (default) or gr variable mapped to size</p></td> + </tr> + <tr> + <th>alpha_var</th> + <td><p>NULL or gr variable mapped to alpha</p></td> + </tr> + <tr> + <th>title</th> + <td><p>NULL or string: plot title</p></td> + </tr> + <tr> + <th>scales</th> + <td><p>'free', 'fixed', etc</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>ggplot object</p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='plot_karyogram.html'>plot_karyogram</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># SRF sites</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>BSgenome.Mmusculus.UCSC.mm10</a></span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>targets</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='no'>targets</span>)</div><div class='img'><img src='plot_intervals-1.png' alt='' width='700' height='433' /></div><div class='input'> +<span class='co'># PE targets</span> + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>), + <span class='no'>bsgenome</span>) + <span class='no'>spacers</span> <span class='kw'><-</span> <span class='fu'><a href='find_pe_spacers.html'>find_pe_spacers</a></span>(<span class='no'>gr</span>, <span class='no'>bsgenome</span>)</div><div class='img'><img src='plot_intervals-2.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='no'>gr</span>)</div><div class='img'><img src='plot_intervals-3.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='fu'><a href='extend_for_pe.html'>extend_for_pe</a></span>(<span class='no'>gr</span>))</div><div class='img'><img src='plot_intervals-4.png' alt='' width='700' height='433' /></div><div class='input'> <span class='fu'>plot_intervals</span>(<span class='no'>spacers</span>)</div><div class='img'><img src='plot_intervals-5.png' alt='' width='700' height='433' /></div><div class='input'> +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/plot_karyogram-1.png b/public/reference/plot_karyogram-1.png index 44d8abbe9c1a5c64233642a4bbb9565af2a70fce..8af9e3ff1d8880b3a93ca6bba9ca982ecf45abe6 100644 Binary files a/public/reference/plot_karyogram-1.png and b/public/reference/plot_karyogram-1.png differ diff --git a/public/reference/plot_karyogram.html b/public/reference/plot_karyogram.html index 65e4389855516563de7181989a36bec3138ad63e..9332b6993d15dec6683b9353c0ef9916cece5841 100644 --- a/public/reference/plot_karyogram.html +++ b/public/reference/plot_karyogram.html @@ -1,186 +1,186 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Karyo/Interval Plot GRanges(List) — plot_karyogram • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Karyo/Interval Plot GRanges(List) — plot_karyogram" /> -<meta property="og:description" content="Karyo/Interval Plot GRanges(List)" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Karyo/Interval Plot GRanges(List)</h1> - - <div class="hidden name"><code>plot_karyogram.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Karyo/Interval Plot GRanges(List)</p> - </div> - - <pre class="usage"><span class='fu'>plot_karyogram</span>(<span class='no'>grlist</span>, <span class='kw'>title</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/unique.html'>unique</a></span>(<span class='fu'>genome</span>(<span class='no'>grlist</span>)))</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>grlist</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>title</th> - <td><p>plot title</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>list</p> - <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> - - <div class='dont-index'><p><code><a href='plot_intervals.html'>plot_intervals</a></code></p></div> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># Plot GRanges</span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='input'> <span class='fu'>plot_karyogram</span>(<span class='no'>gr</span>)</div><div class='input'> -<span class='co'># Plot GRangesList</span> - <span class='no'>flanks</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>up_flank</a></span>(<span class='no'>gr</span>, <span class='kw'>stranded</span><span class='kw'>=</span><span class='fl'>FALSE</span>) - <span class='no'>grlist</span> <span class='kw'><-</span> <span class='kw pkg'>GenomicRanges</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/GenomicRanges/man/GRangesList-class.html'>GRangesList</a></span>(<span class='kw'>sites</span> <span class='kw'>=</span> <span class='no'>gr</span>, <span class='kw'>flanks</span> <span class='kw'>=</span> <span class='no'>flanks</span>) - <span class='fu'>plot_karyogram</span>(<span class='no'>grlist</span>)</div><div class='img'><img src='plot_karyogram-1.png' alt='' width='700' height='433' /></div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#see-also">See also</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Karyo/Interval Plot GRanges(List) — plot_karyogram • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Karyo/Interval Plot GRanges(List) — plot_karyogram" /> +<meta property="og:description" content="Karyo/Interval Plot GRanges(List)" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Karyo/Interval Plot GRanges(List)</h1> + + <div class="hidden name"><code>plot_karyogram.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Karyo/Interval Plot GRanges(List)</p> + </div> + + <pre class="usage"><span class='fu'>plot_karyogram</span>(<span class='no'>grlist</span>, <span class='kw'>title</span> <span class='kw'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/unique.html'>unique</a></span>(<span class='fu'>genome</span>(<span class='no'>grlist</span>)))</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>grlist</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>title</th> + <td><p>plot title</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>list</p> + <h2 class="hasAnchor" id="see-also"><a class="anchor" href="#see-also"></a>See also</h2> + + <div class='dont-index'><p><code><a href='plot_intervals.html'>plot_intervals</a></code></p></div> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># Plot GRanges</span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='st'>'mm10'</span>, <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='input'> <span class='fu'>plot_karyogram</span>(<span class='no'>gr</span>)</div><div class='input'> +<span class='co'># Plot GRangesList</span> + <span class='no'>flanks</span> <span class='kw'><-</span> <span class='fu'><a href='up_flank.html'>up_flank</a></span>(<span class='no'>gr</span>, <span class='kw'>stranded</span><span class='kw'>=</span><span class='fl'>FALSE</span>) + <span class='no'>grlist</span> <span class='kw'><-</span> <span class='kw pkg'>GenomicRanges</span><span class='kw ns'>::</span><span class='fu'><a href='https://rdrr.io/pkg/GenomicRanges/man/GRangesList-class.html'>GRangesList</a></span>(<span class='kw'>sites</span> <span class='kw'>=</span> <span class='no'>gr</span>, <span class='kw'>flanks</span> <span class='kw'>=</span> <span class='no'>flanks</span>) + <span class='fu'>plot_karyogram</span>(<span class='no'>grlist</span>)</div><div class='img'><img src='plot_karyogram-1.png' alt='' width='700' height='433' /></div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#see-also">See also</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/read_bed.html b/public/reference/read_bed.html index 47aec94372fb6e649c22783fd216cbe69ca686ce..c56eb42cfcb8d644f158ec61c3867439fa4aadb2 100644 --- a/public/reference/read_bed.html +++ b/public/reference/read_bed.html @@ -1,204 +1,204 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Read bedfile as data.table — read_bed • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Read bedfile as data.table — read_bed" /> - -<meta property="og:description" content="Read bedfile as data.table" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Read bedfile as data.table</h1> - - <div class="hidden name"><code>read_bed.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Read bedfile as data.table</p> - - </div> - - <pre class="usage"><span class='fu'>read_bed</span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>rm_duplicates</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>bedfile</th> - <td><p>file path</p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p>BSgenome, e.g. BSgenome.Mmusculus.UCSC.mm10::Mmusculus</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - <tr> - <th>rm_duplicates</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>data.table(chr, start, end, strand)</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='fu'>read_bed</span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 - -#> [2] chr1 5250211-5250227 - -#> [3] chr1 5250451-5250467 - -#> [4] chr1 5256192-5256208 - -#> [5] chr1 5985727-5985743 - -#> ... ... ... ... -#> [1970] chrY 6770311-6770327 + -#> [1971] chrY 23130567-23130583 + -#> [1972] chrY 42512399-42512415 - -#> [1973] chrY 79048175-79048191 - -#> [1974] chrY 89126493-89126509 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Read bedfile as data.table — read_bed • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Read bedfile as data.table — read_bed" /> + +<meta property="og:description" content="Read bedfile as data.table" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Read bedfile as data.table</h1> + + <div class="hidden name"><code>read_bed.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Read bedfile as data.table</p> + + </div> + + <pre class="usage"><span class='fu'>read_bed</span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, <span class='kw'>rm_duplicates</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>bedfile</th> + <td><p>file path</p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p>BSgenome, e.g. BSgenome.Mmusculus.UCSC.mm10::Mmusculus</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + <tr> + <th>rm_duplicates</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>data.table(chr, start, end, strand)</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='fu'>read_bed</span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 - +#> [2] chr1 5250211-5250227 - +#> [3] chr1 5250451-5250467 - +#> [4] chr1 5256192-5256208 - +#> [5] chr1 5985727-5985743 - +#> ... ... ... ... +#> [1970] chrY 6770311-6770327 + +#> [1971] chrY 23130567-23130583 + +#> [1972] chrY 42512399-42512415 - +#> [1973] chrY 79048175-79048191 - +#> [1974] chrY 89126493-89126509 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/right_flank.html b/public/reference/right_flank.html index 574174ad3846fcb7bbc967d7de9b474227555f16..f2c26d215db149220453c9905f96ce88232e72c9 100644 --- a/public/reference/right_flank.html +++ b/public/reference/right_flank.html @@ -1,200 +1,200 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Right flank — right_flank • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Right flank — right_flank" /> - -<meta property="og:description" content="Right flank" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Right flank</h1> - - <div class="hidden name"><code>right_flank.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Right flank</p> - - </div> - - <pre class="usage"><span class='fu'>right_flank</span>(<span class='no'>granges</span>, <span class='kw'>rightstart</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>200</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>data.table(chr, start, end)</p></td> - </tr> - <tr> - <th>rightstart</th> - <td><p>flank start relative to range start</p></td> - </tr> - <tr> - <th>rightend</th> - <td><p>flank end relative to range start</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>)</div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>) <span class='kw'>%>%</span> <span class='fu'>right_flank</span>()</div><div class='output co'>#> <span class='message'> 1 right flanks : [end+1, end+200]</span></div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712644-4712843 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Right flank — right_flank • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Right flank — right_flank" /> + +<meta property="og:description" content="Right flank" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Right flank</h1> + + <div class="hidden name"><code>right_flank.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Right flank</p> + + </div> + + <pre class="usage"><span class='fu'>right_flank</span>(<span class='no'>granges</span>, <span class='kw'>rightstart</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>200</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>data.table(chr, start, end)</p></td> + </tr> + <tr> + <th>rightstart</th> + <td><p>flank start relative to range start</p></td> + </tr> + <tr> + <th>rightend</th> + <td><p>flank end relative to range start</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>)</div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>) <span class='kw'>%>%</span> <span class='fu'>right_flank</span>()</div><div class='output co'>#> <span class='message'> 1 right flanks : [end+1, end+200]</span></div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712644-4712843 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/score_cas9ranges.html b/public/reference/score_cas9ranges.html index a2af59739d29e7e7ede925c97948758a1e59a649..23909111d76e9b6a5648f3b4ba564c1ef47878bb 100644 --- a/public/reference/score_cas9ranges.html +++ b/public/reference/score_cas9ranges.html @@ -1,234 +1,234 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Score cas9ranges — score_contextseqs • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Score cas9ranges — score_contextseqs" /> - -<meta property="og:description" content="Score cas9ranges using ruleset1 (Doench 2014) or ruleset2 (Doench 2016)" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Score cas9ranges</h1> - - <div class="hidden name"><code>score_cas9ranges.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Score cas9ranges using ruleset1 (Doench 2014) or ruleset2 (Doench 2016)</p> - - </div> - - <pre class="usage"><span class='fu'>score_contextseqs</span>(<span class='no'>contextseqs</span>, <span class='kw'>ruleset</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>python</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>virtualenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>condaenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>) - -<span class='fu'>score_cas9ranges</span>(<span class='no'>cas9ranges</span>, <span class='kw'>ruleset</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>python</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>virtualenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>condaenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>contextseqs</th> - <td><p>character vector with 4-23-3 contextseqs</p></td> - </tr> - <tr> - <th>ruleset</th> - <td><p>1 (default) or 2 (only if python module -github/MicrosoftResearch/azimuth is installed)</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - <tr> - <th>python</th> - <td><p>NULL (ruleset=1) or path to a python binary (ruleset=2). See details.</p></td> - </tr> - <tr> - <th>virtualenv</th> - <td><p>NULL (ruleset=1) or directory containing python virtualenv (ruleset=2). See details.</p></td> - </tr> - <tr> - <th>condaenv</th> - <td><p>NULL (ruleset=1) or name of condaenv (ruleset=2). See details.</p></td> - </tr> - <tr> - <th>cas9ranges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>numeric vector</p> - - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p>ruleset1 is readily available. ruleset2 is accessible after installing -the python module [azimuth](https://github.com/MicrosoftResearch/Azimuth), -and specifying a value for either 'python' (python binary path), -'virtualenv' (python virtual environment dir) or -'condaenv' (python conda environment).</p> - - <h2 class="hasAnchor" id="references"><a class="anchor" href="#references"></a>References</h2> - - <p>Doench 2014, Rational design of highly active sgRNAs for -CRISPR-Cas9-mediated gene inactivation. Nature Biotechnology, -doi: 10.1038/nbt.3026</p> -<p>Doench 2016, Optimized sgRNA design to maximize activity and minimize -off-target effects of CRISPR-Cas9. Nature Biotechnology, -doi: 10.1038/nbt.3437</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'> -<span class='co'># Get cas9ranges</span> - <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) - <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> - <span class='no'>cas9ranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> - <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>() <span class='kw'>%>%</span> - <span class='fu'><a href='find_cas9ranges.html'>find_cas9ranges</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='output co'>#> <span class='message'> Find N{20}NGG cas9seqs</span></div><div class='output co'>#> <span class='message'> Rm 10 targetranges with no cas9sites</span></div><div class='output co'>#> <span class='message'> 9922 cas9 seqs across 33518 targetranges</span></div><div class='input'><span class='co'># Score</span> - <span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'>score_cas9ranges</span>()</div><div class='output co'>#> <span class='message'> Score contextseqs (4-23-3) with ruleset1</span></div><div class='output co'>#> [1] 0.01708623 0.72298446 0.06796563</div><div class='input'> <span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'><a href='contextseqs.html'>contextseqs</a></span>() <span class='kw'>%>%</span> <span class='fu'>score_contextseqs</span>()</div><div class='output co'>#> <span class='message'> Score contextseqs (4-23-3) with ruleset1</span></div><div class='output co'>#> [1] 0.01708623 0.72298446 0.06796563</div><div class='input'> -</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#details">Details</a></li> - - <li><a href="#references">References</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Score cas9ranges — score_contextseqs • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Score cas9ranges — score_contextseqs" /> + +<meta property="og:description" content="Score cas9ranges using ruleset1 (Doench 2014) or ruleset2 (Doench 2016)" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Score cas9ranges</h1> + + <div class="hidden name"><code>score_cas9ranges.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Score cas9ranges using ruleset1 (Doench 2014) or ruleset2 (Doench 2016)</p> + + </div> + + <pre class="usage"><span class='fu'>score_contextseqs</span>(<span class='no'>contextseqs</span>, <span class='kw'>ruleset</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>python</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>virtualenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>condaenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>) + +<span class='fu'>score_cas9ranges</span>(<span class='no'>cas9ranges</span>, <span class='kw'>ruleset</span> <span class='kw'>=</span> <span class='fl'>1</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>python</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>virtualenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, <span class='kw'>condaenv</span> <span class='kw'>=</span> <span class='kw'>NULL</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>contextseqs</th> + <td><p>character vector with 4-23-3 contextseqs</p></td> + </tr> + <tr> + <th>ruleset</th> + <td><p>1 (default) or 2 (only if python module +github/MicrosoftResearch/azimuth is installed)</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + <tr> + <th>python</th> + <td><p>NULL (ruleset=1) or path to a python binary (ruleset=2). See details.</p></td> + </tr> + <tr> + <th>virtualenv</th> + <td><p>NULL (ruleset=1) or directory containing python virtualenv (ruleset=2). See details.</p></td> + </tr> + <tr> + <th>condaenv</th> + <td><p>NULL (ruleset=1) or name of condaenv (ruleset=2). See details.</p></td> + </tr> + <tr> + <th>cas9ranges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>numeric vector</p> + + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p>ruleset1 is readily available. ruleset2 is accessible after installing +the python module [azimuth](https://github.com/MicrosoftResearch/Azimuth), +and specifying a value for either 'python' (python binary path), +'virtualenv' (python virtual environment dir) or +'condaenv' (python conda environment).</p> + + <h2 class="hasAnchor" id="references"><a class="anchor" href="#references"></a>References</h2> + + <p>Doench 2014, Rational design of highly active sgRNAs for +CRISPR-Cas9-mediated gene inactivation. Nature Biotechnology, +doi: 10.1038/nbt.3026</p> +<p>Doench 2016, Optimized sgRNA design to maximize activity and minimize +off-target effects of CRISPR-Cas9. Nature Biotechnology, +doi: 10.1038/nbt.3437</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'> +<span class='co'># Get cas9ranges</span> + <span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) + <span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> + <span class='no'>cas9ranges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>) <span class='kw'>%>%</span> + <span class='fu'><a href='flank_fourways.html'>flank_fourways</a></span>() <span class='kw'>%>%</span> + <span class='fu'><a href='find_cas9ranges.html'>find_cas9ranges</a></span>()</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='output co'>#> <span class='message'> Flank fourways</span></div><div class='output co'>#> <span class='message'> 1974 left flanks : [start-200, start-1]</span></div><div class='output co'>#> <span class='message'> 1974 right flanks : [end+1, end+200]</span></div><div class='output co'>#> <span class='message'> 3948 combined (left + right)</span></div><div class='output co'>#> <span class='message'> 7896 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 7306 after merging overlaps</span></div><div class='output co'>#> <span class='message'> Find N{20}NGG cas9seqs</span></div><div class='output co'>#> <span class='message'> Rm 10 targetranges with no cas9sites</span></div><div class='output co'>#> <span class='message'> 9922 cas9 seqs across 33518 targetranges</span></div><div class='input'><span class='co'># Score</span> + <span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'>score_cas9ranges</span>()</div><div class='output co'>#> <span class='message'> Score contextseqs (4-23-3) with ruleset1</span></div><div class='output co'>#> [1] 0.01708623 0.72298446 0.06796563</div><div class='input'> <span class='no'>cas9ranges</span>[<span class='fl'>1</span>:<span class='fl'>3</span>] <span class='kw'>%>%</span> <span class='fu'><a href='contextseqs.html'>contextseqs</a></span>() <span class='kw'>%>%</span> <span class='fu'>score_contextseqs</span>()</div><div class='output co'>#> <span class='message'> Score contextseqs (4-23-3) with ruleset1</span></div><div class='output co'>#> [1] 0.01708623 0.72298446 0.06796563</div><div class='input'> +</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#details">Details</a></li> + + <li><a href="#references">References</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/seqs.html b/public/reference/seqs.html index aee8e5e33185dfb316993fdf2494cdc943ff9895..48bf72d5aa769e24f8d8f6a46f8f8b8563adbd41 100644 --- a/public/reference/seqs.html +++ b/public/reference/seqs.html @@ -1,834 +1,834 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Get sequence values — seqs • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Get sequence values — seqs" /> - -<meta property="og:description" content="Get sequence values" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Get sequence values</h1> - - <div class="hidden name"><code>seqs.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Get sequence values</p> - - </div> - - <pre class="usage"><span class='fu'>seqs</span>(<span class='no'>granges</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>DNAStringSet (get) or GRanges (set)</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='fu'>seqs</span>(<span class='no'>granges</span>)</div><div class='output co'>#> [1] "AGACAATATAAGGGCAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [4] "AGACAATATAAGGACAT" "CCACCAAATATGGGCTT" "CAGCCCAGAGATGGTCC" -#> [7] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TCACCTTAGAAGGAATA" -#> [10] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [13] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [16] "AGACAATATAAGGACAT" "GCACCCAAATAAGGGAA" "ACAGCTTATAAGGAGAA" -#> [19] "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [22] "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" "GAGACAATATAAGGACG" -#> [25] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [28] "TCCCCTTAAAAGGTCAC" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [31] "GAGACAATATAAGGACA" "TTGAACATATATGAGAC" "TTGACAATATTTGGAAT" -#> [34] "GAGACAATATAAGGACA" "TGCCAGAATAAGGACAG" "GAGACAATATAAGGACA" -#> [37] "TGGCTATATATGGGATG" "TTACTATATATGTGATG" "AGACAATATAAGGACAT" -#> [40] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [43] "GAGACAATATAAGGACA" "TCACCCATATATGAAGA" "TCGCCCATAGATGGCGC" -#> [46] "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [49] "AGACAATATAAGGACAT" "GTCTCTATATAAGGAGT" "TTCCCACATTAGGTTAA" -#> [52] "GTGACCATGTAAGGTAA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [55] "AGCCCAAATTAGGCCTG" "TTGCCGTATTTGGTCTC" "AGACAATATAAGGACAT" -#> [58] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" -#> [61] "TTACCATAGAGGGAGAA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [64] "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" -#> [67] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "TTGACAATATTTGGAAT" -#> [70] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [73] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [76] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [79] "TTGACAATATTTGGAAT" "CAGACAATATAAGGACA" "TTCCCTTAAAAGGCCTC" -#> [82] "GTTCCCTTAAAAGGCCT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [85] "CTGCCTATATATGATGG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [88] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "CAGCCTCTATATGGCCA" -#> [91] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [94] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [97] "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [100] "GAGACAATATAAGGACA" "TAGCCAGATATGCTCAT" "GAGACAATATAAGGACA" -#> [103] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" -#> [106] "TCCACCAAACATGGGCT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [109] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [112] "AGACAATATAAGGACAT" "AGACCATATAAGGACAT" "GAGACAATATAAGGACA" -#> [115] "TCCACCAAACATGGGCT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [118] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" -#> [121] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "TGTGCTTATAAGGGGGA" -#> [124] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [127] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [130] "GAGACAATATAAGGACA" "AAACAATATAAGGACAT" "CGAGTATATAAGGTCTT" -#> [133] "TTAGCCATACAAGGAGT" "TCCACCAAACATGGGCT" "AGACAATATAAGGACAT" -#> [136] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGAAAATATAAGGACA" -#> [139] "ATGTCCCTATATTGTCT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" -#> [142] "GTGTGCAGATAAGGGCC" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [145] "GTACCATATATCGAGCG" "GAGACAATATAAGGATA" "AGACAATATAAGGACAT" -#> [148] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" -#> [151] "AGCCTATGTATGGGCTT" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [154] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [157] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [160] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "GAGACAATATAAGGACA" -#> [163] "GTGGTCATAGATGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [166] "TGTGCTTATAAGGGGCC" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [169] "GAGACAATATAAGGACA" "TTGTCAATGTAAGGTCA" "GAGACAATATAAGGACA" -#> [172] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [175] "AGAGCAGATATGGAAAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [178] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" -#> [181] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [184] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [187] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "CGAGCCAGATAAGGAAA" -#> [190] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" -#> [193] "AGACAATATAAGGACAT" "AGACTATATAAGGACAT" "TGCTTATATAAGGTCTG" -#> [196] "GAGACAATATAAGGACA" "GAGACAATATAAGGAAA" "GAGACAATATAAGGACA" -#> [199] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" -#> [202] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" -#> [205] "GAGACAATATAAGGACA" "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" -#> [208] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" -#> [211] "GAGACAATATAAGGACA" "TGGCCAGATGTGGGAAA" "AGACAATATAAGGACAT" -#> [214] "GAGACAATATCAGGACA" "AGACAATATAAGGACAT" "GGTAGCAAATATGGGGT" -#> [217] "ATGGCCAAATATGTGGA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [220] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [223] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [226] "GAGACAATATAAGGACA" "TGCCCATATATGGACTG" "GAGACAATATAAGGACA" -#> [229] "TCCACCAAACATGGGCT" "GGCCAATATATGGGCAT" "AGACAATATAAGGACAT" -#> [232] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" -#> [235] "AGACCATTTAAGGACAT" "AGACAATATAAGGACAT" "TCCCCAAAGAAGGCCAC" -#> [238] "TCTCCAGATATGGAAAA" "TGGGCGTATATGGGAGT" "AGACAATATAAGGACAT" -#> [241] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [244] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [247] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [250] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" -#> [253] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "CCACCAAATATGGGCTT" -#> [256] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [259] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" -#> [262] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "ATTACCAAACATGGAGA" -#> [265] "CTGCCCATATAAGGAAG" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [268] "TTAACCAAATAAGGGTT" "CTCCCCTATGTGGGCAG" "TTTCCCATATAAGGCCG" -#> [271] "CTGTCTAAATAAGGAAT" "TTGCCCATACTAGGGAG" "GAGACAATATAAGGACA" -#> [274] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [277] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [280] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [283] "TGACTATATTTGGAATG" "GAGACAATATAAGCACA" "AGACAATATAAGGACAT" -#> [286] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TCAACATATTAGGGCAC" -#> [289] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [292] "GAGACAATATAAGGACA" "GGGACCATATAAGAGAA" "GAGACAATATAAGGACA" -#> [295] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACTATATTTGGAAT" -#> [298] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" -#> [301] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [304] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [307] "AGACAATATAAGGACTT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [310] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "GTCACTATAGAAGGAAA" -#> [313] "GTAGCTTATAAGGTCTA" "ATGCCCAAATATGGCAC" "GAGACAATATAAGGACA" -#> [316] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CGGCCCATTTAAGGGTG" -#> [319] "TGACTATATTTGGAATG" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" -#> [322] "GAGACAATATAAGGACA" "TCACCACATAAGGGATT" "AGACAATATAAGGACAT" -#> [325] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [328] "TATGCCTTATAAGGGTC" "CATCCCAGCTAAGGTCA" "TTCCCGGATAAGGAAAT" -#> [331] "TGCCCTAATAAGGTTCT" "CTTCCCACATGTGGTCT" "ACCACCCTATAAGGCGT" -#> [334] "ACTTCCTTATAAGGAAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [337] "ATTGCCACATAAGGAAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [340] "TTGCCCATACTAGGAAG" "GAGACAATATAAGGACA" "TTACCTTAGAAGGAATA" -#> [343] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [346] "TGACTATATTTGGAATG" "AGTCCCAGATATGGCAC" "TCGCCATATATGGACAT" -#> [349] "AGACAATATAAGGACAT" "GACACCAAGTATGGGGA" "AGACAATATAAGGACAT" -#> [352] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "GAGACAATATAAGGACA" -#> [355] "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [358] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "ATACCAATTAAGGCCAT" -#> [361] "GAGACAATATAAGGACA" "TTGCCACATATGGTGGC" "AGACAATATAAGGACAT" -#> [364] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [367] "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" -#> [370] "ATTTCTAAATAAGGCCA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [373] "TCACCATAGATGCTCTT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACC" -#> [376] "AGACAATATAAGGACAT" "GTTGCCACATATGGTGG" "GAGACAATATAAGGACA" -#> [379] "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" "AGCCCATATTAGGTGGA" -#> [382] "AGCCCATATTAGGTGGA" "TGCCCCTCTAAGGTCTC" "CTCCCAAATAAGCGAAG" -#> [385] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [388] "TGACAATATTTGGAATG" "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" -#> [391] "GAGACAATATAAGGACA" "ACGCCCAAACAAGGTCA" "GAGACAATATAAGGACA" -#> [394] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [397] "GAGACAATATAAGGACA" "TGGACTATATAAGGACT" "GAGACAATATAAGGACA" -#> [400] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAGTATAAGGACA" -#> [403] "AGTCCATGTAAGGACTT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [406] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "AATACCAATTAAGGCCA" -#> [409] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "CCGCCCATATTAGGAGG" -#> [412] "TAGCTCAGATAAGGTCA" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" -#> [415] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [418] "GCGACCAAATAAGGCTG" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [421] "ATGTCCATATTAGGACA" "TTTCCAAATATGGGCAG" "ACACTTTATAAGGAATA" -#> [424] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AGACAATATAAGGACAT" -#> [427] "GAGACAATATAAGGACT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [430] "AGACAATATAAGGACAT" "GGCCTATATAAGGAGCA" "GAGACAATATAAGGACA" -#> [433] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "AGACAATATAAGGACAT" -#> [436] "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" -#> [439] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [442] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" -#> [445] "AATACCAATTAAGGCCA" "GTGAGCTTATAAGGGGG" "CGACCATATTTGTTGAG" -#> [448] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" -#> [451] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [454] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTGACTATATATGGGAT" -#> [457] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [460] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" -#> [463] "AGACAATATAAGGACAT" "GGACCAAATGTGGGCAC" "CTACCCAGACAAGGGCA" -#> [466] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [469] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [472] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGATAATATAAGGACAT" -#> [475] "AGATAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [478] "CCACCAAACATGGGCTT" "GAGACAATATAAGGACA" "TTGAGCATAAATGGCCT" -#> [481] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [484] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [487] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [490] "GTACCATATATCGAGCG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [493] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [496] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TCCCCAAATAAAGCCTC" -#> [499] "GAGACAATATAAGGACA" "TTGCCCATATGACGTCA" "AGACTATATAAGGACAT" -#> [502] "AGACTATATAAGGACAT" "AGACTATATAAGGACAT" "GAGACAATATAAGGACA" -#> [505] "ATTCCAGATATGTGCAG" "CACCCCAAATAAAGGAA" "TTGTGCCTATATGGGAC" -#> [508] "AGACAATATAAGGACAT" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [511] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [514] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [517] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [520] "GAGACAATATAAGGACA" "TTCCCATAGGTGGGAAG" "AGACAATATAAGGACAT" -#> [523] "TGACTATATTTGGAATG" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [526] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [529] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [532] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [535] "TGACAATATTTGGAATG" "AATACCAATTAAGGCCA" "TGGCTATATAAGATCAT" -#> [538] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [541] "GAGACCATATAAGGACA" "GAGACAATATAAGGACA" "CCACCAAATATGGGCTT" -#> [544] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" -#> [547] "TCCCCTTTTAAGGAGAA" "GGTCTATATAAGAACAC" "AGGCCTATATAAGAACA" -#> [550] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [553] "GAGACAATATAAGGACA" "TTCCTATATAAGAACTC" "GGCCTATATAAGAACAC" -#> [556] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" -#> [559] "AGACAATATAAGGACAT" "AGGCCTATATAAAGACA" "TGGACCAAATAAAGGCG" -#> [562] "GGACCAAATAAAGGCGA" "AGGCCTATATAAGAACA" "GGCCTATATAAAGACAG" -#> [565] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGGCCTATATAAGAACA" -#> [568] "ATTCCTATATAAGAACT" "AGGCCTATATAAGAACA" "GGCCTATATAAGAACAA" -#> [571] "AGGCCTATATAAGAACA" "GAGACAATATAAGGACA" "AGGCCTATATAAGAACA" -#> [574] "AGGCCTATATAAGAACA" "GGCCTATATAAAGACAG" "AGCGCCATATATGGCCT" -#> [577] "TTCCCAAATAATGCCAC" "GGCGCCATATATGGCCT" "GCGCCATATATGGCCTG" -#> [580] "GGCGCCATATATGGCCT" "GCGCCATATATGGCCTG" "CAGGCCATATATGGTGC" -#> [583] "GCGCCATATATGGCCTG" "GCGCCATATATGGCCTG" "AGACAATATAAGGACAT" -#> [586] "TCCACCAAATATGGACT" "GAGACAATATAAGGACA" "CTGTCCCTATAAGTTGA" -#> [589] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "CAGGCCATATATGGTGC" -#> [592] "ATGCCCTTATAAGGAGC" "CACCCATATATGGTATG" "GTTGCCCTCTATGGGCA" -#> [595] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [598] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "GGGCCCAATAAGGGAAC" -#> [601] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [604] "GAGACAATATAAGGACA" "TTGCCCATACTAGGGAG" "AGACAATATAAGGACAT" -#> [607] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" -#> [610] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" -#> [613] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [616] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [619] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TGACCAGAAAAGGACTC" -#> [622] "GGACCATATATGGGTAT" "AGACAATATAAGGACAT" "TTTCCCAAATTTGGATC" -#> [625] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [628] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [631] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [634] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [637] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [640] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [643] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [646] "GAGACAATATAAGGACA" "TACCCAAACAAGGGGAA" "TGCCCATACTAGGGAGA" -#> [649] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [652] "AGACAATATAAGGACAT" "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" -#> [655] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [658] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [661] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "ATGACCTTATAAGGGGA" -#> [664] "GAGACAATATAAGGACA" "AATACCATAAAAGGAAA" "GTCTCCATATTTGTACA" -#> [667] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [670] "GAGACAATATAAGGACA" "TTTTCCTTATAAGAGTT" "AGGCCTATATAAGGAAC" -#> [673] "AGGCCTATATAAGGAAC" "AGGCCTATATAAGGAAC" "AGGCCTATATAAGGAAC" -#> [676] "AGGCCTATATAAGGAAC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [679] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [682] "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [685] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [688] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [691] "GAGACAATATAAGGACA" "ATGGCCAAATATGTGGA" "GAGACAATATAAGGACA" -#> [694] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [697] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [700] "CCACCAAATATGGACTT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [703] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [706] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [709] "TGGCCCTATTAGGGAGG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [712] "ATACCAATTAAGGCCAC" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [715] "GAGACAATATAAGGACA" "TGCCCCTTTAAGGGCGG" "AGACAATATAAGGACAT" -#> [718] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [721] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [724] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CCTCCAGATAAGGGTAA" -#> [727] "GAGACAATATAAGGACA" "AGACCATATAAGGACAT" "GAGACAATATAAGGACA" -#> [730] "CTGGCCATATAAGGTAA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [733] "GAGACAATATAAGGACA" "AGTCCCAGATATGGCAC" "GAGACAATATAAGGACA" -#> [736] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [739] "AGACAAAATAAGGACAT" "GAGACAATATAAGGACA" "GTAAGCATACATGGACA" -#> [742] "GAGACAATATAAGGACA" "TGTCCATGTAAGGTATG" "AGACAATATAAGGACAT" -#> [745] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATATGGACAT" -#> [748] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [751] "TTAACCATATAAGAGGG" "AGACAATATAAGGACAT" "TTAGCATACAAGGTAAC" -#> [754] "AGACAATTTAAGGACAT" "AGACAATATAAGGACAT" "ATGGCCAAATATGTGGA" -#> [757] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [760] "TGACAATATTTGGAATG" "CCACCAAACATGGGCTT" "AGTCCCAGATATGGCAC" -#> [763] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [766] "AGACAATATAAGGACAT" "GAGACCATATAAAAACA" "GTACCATATATCGAGCG" -#> [769] "GTGACGATATATGGGAC" "AGACAATATAAGGAGAT" "GAGACAATATAAGGACA" -#> [772] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [775] "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" "TGACAATATTTGGAATG" -#> [778] "CGACCCTACAAGGTCAG" "TGTCCCTTATAAGGTCA" "CCACCAAATATGGACTT" -#> [781] "GAGACAATATAAGGACA" "CACCCATAGATGGGCGG" "CACCCCCAATAAGGCCA" -#> [784] "AGACAATATAAGGACAT" "ATCACCATGTAAGGGCT" "TGCCTATACATAGTCAA" -#> [787] "CCTCCCCTATGTGGGCA" "CCTCCCCTATGTGGGCA" "CCGCCCATATCAGGGTG" -#> [790] "GACCCATATAAAGACCC" "GTCACCATGGATGGCCA" "GAGACAATATAAGGACA" -#> [793] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [796] "AGACCATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [799] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [802] "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [805] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "TCCACCAAACATGGGCT" -#> [808] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [811] "TTAGCAAAGATGGTCAG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [814] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "TTACCCAATATGGAACC" -#> [817] "AGACAATATAAGGACAT" "AGACCATATAAGGACAT" "GAGGCCCAATAAGGGAA" -#> [820] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" -#> [823] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "GTCCCAGATATGGCACC" -#> [826] "AGACAATATAAGGACAT" "TGCCTAGATTTGGGAAG" "GAGACAATATAAGGACA" -#> [829] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [832] "GAGACAATATAAGGACA" "TGACCATATGAGGTCAG" "CGCCCTATATAAGGCGA" -#> [835] "CCCCCCATATAAAGAGA" "TCGCCATAAAAGGAAAC" "TCGCCATATAAGGAGCG" -#> [838] "AGACGATGTAAGGACAT" "AGACAATATAAGGACAT" "AGACAACATAAGGACAT" -#> [841] "TCACCTTAGAAGGAATA" "AAGACCAAAGAAGGGCT" "CGACAATATAAGGACAT" -#> [844] "TCCACCAAACATGGGCT" "GAGACAATATAAGGACA" "TCACCAAATATGGGCTT" -#> [847] "CGCCCAAAGAAGGCCAG" "AATACCAATTAAGGCCA" "AGACAATATAAGGACAT" -#> [850] "CTGCCCTAAGAAGGGCA" "GTCACCACAGAAGGGCA" "CCACCGAATATGGACTT" -#> [853] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "TTGAGCATATATGGCCT" -#> [856] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAAGACA" -#> [859] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [862] "AGACAATATAAGGACAA" "GAGACAATATAAGGACA" "CTGCCCACATAAGGGAG" -#> [865] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "TTTACCTTAGAAGGAAT" -#> [868] "GAGACAATATAAGGACA" "TGGCCATAAATGGCCTC" "AGACAATATAAGGACAT" -#> [871] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" -#> [874] "AGACAATATAAGGACAT" "ATACCAAATATGGCCAC" "GTACCATATATCGAGCG" -#> [877] "GAGACAATATAAGGACA" "CGGCCAAATATAGTATT" "GAGACAATATAAGGACA" -#> [880] "AGACCATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [883] "AGACAATATAAGGACAT" "AACGCCATATAAGGAGC" "TGCCCAAATAAGGTCTG" -#> [886] "ACTCCATATAAGGCGCT" "CCTTCCATATTAGGGCT" "TGGCCATATATGGGAAG" -#> [889] "AATCCAAATAAGGTCAG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [892] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [895] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGGCCAAATATGTGGAA" -#> [898] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGAGCCTATAAGGACCA" -#> [901] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [904] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [907] "TTCACCTTAGAAGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [910] "AGACCATCTAAGGACAT" "AGACCATCTAAGGACAT" "TGACTATATCTGGAATA" -#> [913] "TGACTATATCTGGAATA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [916] "TGTACCATATATCGAGC" "GAGACTATATAAGGACA" "AGACCAAAGAAGGAAAG" -#> [919] "ATGCCCTAATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [922] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [925] "TCCACCAAATATGGACT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [928] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [931] "TGACTATATTTGGAATG" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [934] "TGTACCATATATCGAGC" "TTCACCTTAGAAGGAAT" "GAGACAATATAAGGACA" -#> [937] "GAGACAATATAAGGACA" "AGTCCCAGATATGGCAC" "GTACCATATATCGAGCG" -#> [940] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [943] "AGACAATATAAGGACAT" "TTGCCCATACAAGGGCG" "AGACAATATAAGGACAT" -#> [946] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [949] "TGCCCATATAAGGCCAA" "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" -#> [952] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [955] "CTTCCCAAATTAGGAGA" "TACCCCAATAAGGCCAC" "TCACCATAGATGGAGAA" -#> [958] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "TGACAATATTTGGAATG" -#> [961] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [964] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" -#> [967] "CACGCCCTATAAGGGGT" "GAGACAATATAAGGACA" "TTGCCTATATGTGGAAA" -#> [970] "TTCCTATGTATGGGAGT" "ACGACCATAGATAGACA" "GAGACCATATAAGGACA" -#> [973] "TTTCCCAAATGTGGTCC" "TGGCCATATTTGAAATG" "ATATGCATATATGGCCA" -#> [976] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [979] "TACCCAGAGAAGGGAAT" "GAGACAATATAAGGACA" "TCACCTTAGAAGGAATA" -#> [982] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [985] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GCTCCATAAAAGGGGAG" -#> [988] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [991] "GAGACAATATAAGGACA" "GAGACAATATAAAGACA" "GAGACAATATAAGGACA" -#> [994] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [997] "AGACAATATAAGGACAT" "GTGACCTTATGAGGAGA" "AGACAATATAAGGACAT" -#> [1000] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1003] "TTTGCCATAAAAGGAGG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1006] "TGACCATATAATTTGTC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1009] "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" -#> [1012] "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" -#> [1015] "GGGACAATATAAGGACA" "ATGGCCAAATATGTGGA" "AGACAATATAAGGACAT" -#> [1018] "GAGACCATATAAGGACA" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" -#> [1021] "TTGACAATATTTGGAAT" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [1024] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "CCACCAAATAAGGGCTC" -#> [1027] "TGACCATTTTAGGGAAT" "AGACAATATAAGGACAT" "TTACCCAAACAAGGGAA" -#> [1030] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" -#> [1033] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" -#> [1036] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GTACCATATATCGAGCG" -#> [1039] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1042] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" -#> [1045] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1048] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" -#> [1051] "CGCCCAGATAAGGGGCG" "TGTACCATATATCGAGT" "TCCCCTTTTAAGGAGAA" -#> [1054] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "AAACAATATAAGGACAT" -#> [1057] "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" "AAACAATATAAGGACAT" -#> [1060] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [1063] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1066] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TCCCCTTTTAAGGAGAA" -#> [1069] "GAGACAATATAAGGACA" "CCCGCCGTATATGGGAG" "TGCCCATACATGGAAGT" -#> [1072] "CCGCCCCTATATGGGCC" "TGGTCAAATATGGTCAA" "AGACAATATAAGGACAT" -#> [1075] "GTACCATATATCGAGCG" "CTACCAAATAGGGACTA" "AGACAATATAAGGACAT" -#> [1078] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "TGAGCCTATAAGGGCTT" -#> [1081] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "TTGACAATATTTGGAAT" -#> [1084] "AGGTCTATATAAGGAAG" "TGGTCCCTATGTGGTCA" "AGACAATATAAGGACAT" -#> [1087] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1090] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1093] "GAGACAATATAAGGACA" "AGGACGATATAAGCGCA" "AGGCCTATATAAGGAGC" -#> [1096] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" -#> [1099] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1102] "TCAACCAAATAAGGATT" "TGACTATATATGAGATG" "GTGTGCTTATAAGGGGG" -#> [1105] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [1108] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1111] "GAGACAATATAAGGACA" "AGCCCAGAGATGGTCCC" "AGACAATATAAGGACAT" -#> [1114] "TCCACCAAATATAGACT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1117] "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1120] "GTACCATATATCGAGCG" "CATACCATATGTGTTCT" "AGACAATATAAGGACAT" -#> [1123] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TCACCTTAGAAGGAATA" -#> [1126] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1129] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [1132] "TGACTATATTTGGAATG" "AGACCAAATATGGTCAC" "AGACCATATAAGGACAT" -#> [1135] "TGGCCAAATATGTGGAA" "GTAACTGTATATGGGAT" "AGACAATATAAGGACAT" -#> [1138] "GAGACAATATAAGGACA" "TGAGTATAGATGGTCAA" "CTGCCTAGATAAGGTGA" -#> [1141] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTGACGTCATAAGGTCA" -#> [1144] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" -#> [1147] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" -#> [1150] "TGACTATATTTGGAATG" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" -#> [1153] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GACGCCAGATATGGAAG" -#> [1156] "AGACAATATAAGGACAT" "TTTTCCATAGAAGAGCT" "TCCACCAAATATGGGCT" -#> [1159] "GAGACACTATAAGGACA" "AGGCCTATATATGGAAT" "AGGACCATATAGGAGCT" -#> [1162] "AAGCCTATATAAGCACT" "AGCCTATATAAGCACAT" "AGCCTATATAAGCACAT" -#> [1165] "AATACCAATTAAGGCCA" "GAGCCTATATAAGCACA" "GGCCTATATAAGCACAT" -#> [1168] "GAGCCTATATAAGCACA" "GAGCCTATATAAGCACA" "CTACCATATAAGTCTAG" -#> [1171] "ATGACCTTAAAAGGAAT" "CCACCATATAAGTCTAG" "ATGGCCTTAAAAGGAAT" -#> [1174] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TTCCCGTAAAAGGGGAA" -#> [1177] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [1180] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1183] "AGACAATATAAGGACAT" "GTCCCCAAAGATGGTCA" "GGCCTACATAAGGTCAC" -#> [1186] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [1189] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GTGTCCGTATATGGTCT" -#> [1192] "GAGACAATATAAGGACA" "TGTGTATATATGGGCAG" "GAGACAATATAAGGACA" -#> [1195] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "AGACCATATAAAGCTCA" -#> [1198] "GAGACAATATAAGGACA" "GTACCATATATCGAGCC" "GAGACAATATAAGGACA" -#> [1201] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGAAAATATAAGGACA" -#> [1204] "TCCACCAAACATGGGCT" "AGTGCCTGATAAGGTCA" "GAGACAATATAAGGACA" -#> [1207] "TCCACCAAATATGGACT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1210] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1213] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "ATTCCCGTATATGTTCC" -#> [1216] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [1219] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [1222] "GAGACAATATAAGGACA" "CTGGCCATATGATGTCA" "AGACAATATAAGGACAT" -#> [1225] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" -#> [1228] "ACACCATATATGAGACC" "GAGACCATATAAGGACA" "GAGACAATATAAGGACA" -#> [1231] "AATACCAATTAAGGCCA" "GCTGCATATATGGCCTT" "AGACAATATAAGGACAT" -#> [1234] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [1237] "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" "ATCTCCAGATAAGGGTC" -#> [1240] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1243] "AGACAATATATGGACAT" "AGACAATATATGGACAT" "GTACCATATATCGAGCG" -#> [1246] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1249] "GGCCCCTACATGGCCAG" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [1252] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" -#> [1255] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [1258] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1261] "GTACCATATATCGAGCG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1264] "GAGACAATATAAGGACA" "TGCCCATAGAGGGTGTG" "TGGTCCACATAAGGGCA" -#> [1267] "GCACCGTATAAGGGAAT" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" -#> [1270] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTGCATCTAAGGAAAA" -#> [1273] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [1276] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [1279] "GAGACAATATAAGGACA" "AGACAATATAAGGACAC" "GTCTCCAGATAAGGGTC" -#> [1282] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAC" "GTCTCCAGATAAGGGTC" -#> [1285] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GCTGCCATGTAAGGCCT" -#> [1288] "CTGCCCTAGATGGTCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1291] "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [1294] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [1297] "GAGACAATATAAGGACA" "AAGACCATAAAAGGGAC" "AGGCCTATATAAGGAGC" -#> [1300] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [1303] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1306] "AGACAATATAAGGACAT" "TGTACTATATAAGGAAG" "AGACAATATAAGGACAT" -#> [1309] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" -#> [1312] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CTCCCCATAGAAGGTAA" -#> [1315] "TTGAGCATGTATGGACT" "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1318] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1321] "CTGTCCATATCAGGTAA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1324] "AGTCCATAAAAGGGCTG" "TGGCCAAATATGTGGAA" "GAGACAATATAAGGACT" -#> [1327] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [1330] "TGCCAAAATATGGTGAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1333] "TGGACCTTTTAAGGACT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1336] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" -#> [1339] "AGACAATATAAGGACAT" "CTGCCCAAATAAGGAGC" "GTGACCATAGATGGTCA" -#> [1342] "ATAACCTTAGAAGGTAT" "GATGGCAAATATGGACT" "AGCCCAAAGATGGGTAG" -#> [1345] "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" "AGGAGTATATAAGGACT" -#> [1348] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" -#> [1351] "GATGCCATATAAGGCAA" "GTGTGCATATATGTGTA" "GAGACAATATAAGGACA" -#> [1354] "TTACCATATTAGGGCTC" "TCTCTATCTAAGGTCAG" "TGGCCCTATTTGGAGTA" -#> [1357] "CTCACGATGTAAGGACA" "CGCTCAAATATGGGCTC" "ATCCCTAATAAGGTGCA" -#> [1360] "AGACAATATAAGGACAT" "AGACCATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1363] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1366] "AGACAATATAAGGACAT" "AAGACTATAAATGGGCT" "TAGCCCATGGATGGGCA" -#> [1369] "TGGCCATAACTGGACAA" "AGTCCCAGATATGGCAC" "AATACCAATTAAGGCCA" -#> [1372] "TCCCCGTACATGGGCAG" "TTGACAATATTTGGAAT" "AGACAATATAAGGACAT" -#> [1375] "AGACCCATATAAGGACA" "TCCACCAAATATGGACT" "TGTCCATGTTAGGTAAG" -#> [1378] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" -#> [1381] "GAGACAATATAAGGACA" "TGACAATATTTGGAATG" "TTGCCATATTTGAGCTG" -#> [1384] "GAGACAATATAAGGACA" "TCGTCCCTATATGGTGG" "GAGACCATATAAGGACA" -#> [1387] "TGACTATATATGGTCAA" "AGACAATATAAGGACAT" "TCACCTTAGAAGGAATA" -#> [1390] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TGCCCATACTAGGGAGA" -#> [1393] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [1396] "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" -#> [1399] "CTCACAAATAAGGTCAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1402] "GAGACAATATAAGGACA" "GAGACCATATAAGGACA" "AGACAATATAAGGACAT" -#> [1405] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [1408] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1411] "AGTCCCAGATATGGCAC" "GAGACAATATAAGGATA" "GAGACAATATAAGGACA" -#> [1414] "GTGACCGGATACGGGAA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1417] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1420] "GTGTGCTTATAAGGGGG" "CCCACCAAATATGGGCT" "AGACAATATAAGGACAT" -#> [1423] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [1426] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1429] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [1432] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1435] "AATACCAATTAAGGCCA" "AGACAATATAAGGACAT" "TGCCCATAGATGGCTGA" -#> [1438] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1441] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "TACTCAAATAAGGCCAC" -#> [1444] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GGACTATACAAGGGCAG" -#> [1447] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1450] "GCGCCTATATACGGCCT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1453] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "TAGCCCATACTAGGGCT" -#> [1456] "AGACAATATAAGGACAT" "TCGCGATATATAGACAC" "AGACAATATAAGGACAT" -#> [1459] "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" -#> [1462] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1465] "TCACCAAATTAGGCAAG" "ATTACCATAAAAGGCAA" "GTGACAATATAAGGAAG" -#> [1468] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAAACAATATAAGGACA" -#> [1471] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1474] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1477] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATACAAGGACAT" -#> [1480] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1483] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" -#> [1486] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AGACCATACAAGGAGCG" -#> [1489] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AGACAATATAAGGACAT" -#> [1492] "GATCCAGATAAGGACAG" "AGACAATATAAGGACAT" "TGGCCGTATATGTGCTC" -#> [1495] "TGATTATATAAGGTCTT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1498] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1501] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1504] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" -#> [1507] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "TTGGGCATGTAAGGAAA" -#> [1510] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" -#> [1513] "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1516] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1519] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [1522] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "TGTGCTTATAAGGGGGA" -#> [1525] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" -#> [1528] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1531] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1534] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1537] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1540] "TCCACCAAACATGGGCT" "AGACAATATAAGGACAT" "CCCGCAGATATGGTCAG" -#> [1543] "GCACCAAATTAGGACAG" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" -#> [1546] "CTAACCATACAAGTTCA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1549] "CCTGCCTTATAAGGGGA" "CTGGCTGTATATGGGTT" "GGACCAAATAACGGATT" -#> [1552] "GGCACCATAAAAGGTCT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1555] "GAGACAATATAAGGACG" "GAGACAATATAAGGACA" "TTGACTATATTTGGAAT" -#> [1558] "GAGACAATATAAGGACA" "GTGGCTAAACATGGGCA" "CTTCCCACATAAGGTAC" -#> [1561] "GAGACCATATAAGGACA" "TCCCCTTAAAAGGACAA" "AGACAATATAAGGACAT" -#> [1564] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AAGCCCTTATAAGGAGC" -#> [1567] "GATCGCATATTTGGACT" "AGACAATATAAGGACAT" "TATCCGTATTAGGTGAG" -#> [1570] "TTGCCATACATGGTGTG" "TCCACCAAACATGGGCT" "TCCACCAAACATGGGCT" -#> [1573] "GAGACAATATAAGGACA" "TCCACCAAATATGGACT" "GTACCATATATCGAGCG" -#> [1576] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1579] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [1582] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1585] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1588] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "TTAGCATAGATGGAGAA" -#> [1591] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TAGAGCAAATAAGGATA" -#> [1594] "TAGACAATATAAGGTCT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" -#> [1597] "AGACAATATAAGGACAT" "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" -#> [1600] "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" -#> [1603] "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" -#> [1606] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1609] "ATACCAATTAAGGCCAC" "GAGACAATATAAGGACA" "GAGACCAAATACGTGCA" -#> [1612] "TACCCATAGATGGGCCT" "TGCCCAAATAAGGAAGG" "TTAGCCATATAAGGAGC" -#> [1615] "TGACAATATTTGGAATG" "AATACCAATTAAGGCCA" "AGATAATATAAGGACAT" -#> [1618] "AGACAATATAAGGACAT" "CGACCATACAAGGAAAA" "GCCCCATAAAAGGAGAA" -#> [1621] "CCACCAAACATGGGCTT" "TCCACCAAACATGGGCT" "TTGACTATATTTGGAAT" -#> [1624] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAAACAATATAAGGACA" -#> [1627] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "CTGCCTTACAAGGGCAC" -#> [1630] "AAGGCCAAAAAAGGGCA" "TCGCCCAAAGATGGGGT" "AGACAATATAAGGACAT" -#> [1633] "TGTACCATATATCGAGC" "GCTACCATATTTGAACA" "AGACAATATAAGGACAT" -#> [1636] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" -#> [1639] "TCACCTTAGAAGGAATA" "TTGCCCCGATATGGCCC" "AGACAATATAAGGACAT" -#> [1642] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGGCAATATAAGGACAT" -#> [1645] "GAGACAATATAAGGACA" "ATTCCCTATATGGCTAG" "GGCCCATAAAAGGAGGG" -#> [1648] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" -#> [1651] "TGTACCATATATCGAGC" "CCACCAAATATGGGCTT" "TGTACCATATATCGAGC" -#> [1654] "AGACAATATAAGGACAT" "GTGCCATTATAAGGGAT" "AGACAATATAAGGACAT" -#> [1657] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" -#> [1660] "AGACAATATAAGGACAT" "CCTTCCACATAAGGCCA" "GAGACAATATAAGGACA" -#> [1663] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1666] "GAGACTGTATAAGGACA" "GCATCCCTATAAGGTCA" "AGACAATATAAGGACAT" -#> [1669] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACCATATAAGGACAT" -#> [1672] "AAAACCAAATATGAACA" "TTAGCCATACAAGGGAA" "AGAGCATACATGGGCTG" -#> [1675] "CTAACCTTGTAAGGAGA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [1678] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "CTTTCCAAAGAAGGACG" -#> [1681] "GAGACAATATAAGGACA" "GTCTCCAAGTAAGGGCA" "AGACAATATAAGGACAT" -#> [1684] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1687] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTACCATATATCGAGCG" -#> [1690] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1693] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" -#> [1696] "AGACAATATAAGGACAT" "CTGCCCACATAAGCGCT" "GAGACAATATAAGGACA" -#> [1699] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" -#> [1702] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1705] "TCCACCAAATATGGACT" "TTCCCAGATATGCAGAG" "AGACAATATAAGGACAT" -#> [1708] "TCCACCAAATATGGAAC" "CTCCTATACAAGGGCAT" "GAGACAATATAAGGACA" -#> [1711] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1714] "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" -#> [1717] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "CAGACCATAAAAGAACA" -#> [1720] "GAGACAATATAAGGATT" "CTGTCCATGTAAGACCA" "TGTCCATGTAAGACCAT" -#> [1723] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAATGACAT" -#> [1726] "AGACAATATAAGGACAT" "CTTCCTATGTATGGTCA" "AGACAATATAAGGACAT" -#> [1729] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1732] "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" "ATGCCCATATAAGGTGA" -#> [1735] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1738] "GAGACAATATGAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [1741] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1744] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTCCTATATATTGTGAC" -#> [1747] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [1750] "GAGACAATATAAGGACA" "TGTCCTTATAAGAGTTG" "GAGACAATATAAGGACA" -#> [1753] "CTTCCCTATATGGGCGT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1756] "TCCCCATATAAGACTTC" "AGACAATATAAGGACAT" "GAGACAATAGAAGGACA" -#> [1759] "CCCTCCAGATAAGGAAA" "ATGCCCATATAAGAACA" "AGGCCCATATATGGGCA" -#> [1762] "GCACCCATATTAGGGCA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1765] "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" "GTCCCCAAATAAGGAAA" -#> [1768] "GGGGCCATATGTGGGCG" "GCGCCCATAAAAGGTAC" "AGACAATATAAGGACAT" -#> [1771] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1774] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGTGC" -#> [1777] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1780] "GAGCCCAGATATGGGAG" "GCTCCATACAAGGGCGT" "AGGCCAAATAAGGCAGG" -#> [1783] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "CGCCCCTATGTGGGCAG" -#> [1786] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "CTATCCCTATTTGGTCA" -#> [1789] "AGTCCCAGATATGGCAC" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1792] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GAGACCATATAAGGACA" -#> [1795] "TGGCCATAGCTGGACTC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1798] "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" "GTCCCAGATATGGCACC" -#> [1801] "AGACAATATAAGGACAT" "TTACCTTAGAAGGAATA" "GAGACAATATAAGGACA" -#> [1804] "CGCCCCATAGAAGGGAG" "CCACCAAATATGGACTT" "AGACAATATAAGGACAT" -#> [1807] "TGACTATATTTGGAATG" "AGACAATATCAGGACAT" "TGACTATATTTGGAATG" -#> [1810] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAAGACA" -#> [1813] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1816] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1819] "GCGGCCATATAAGGCAG" "TTGAGCAAATTTGGTCT" "AGACAATATAAGGACAT" -#> [1822] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "TGTCCATAAATGGAGAA" -#> [1825] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1828] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" -#> [1831] "CAACCAGATATGGGCGT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1834] "GTGACCATATAAGAGCA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" -#> [1837] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GTCCCAGATATGGCACC" -#> [1840] "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" -#> [1843] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TTCACCTTAGAAGGAAT" -#> [1846] "ACACCATATAAGGCCCG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1849] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" -#> [1852] "ACTCCATATAAGACATT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1855] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1858] "GAGACAATATAAGGACA" "GTAGCCATAGATGGGCG" "TCACCAAATTAGGCCTT" -#> [1861] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" -#> [1864] "AGACAATATAAGGACAT" "TGTCTATTTAAGGTCAG" "GAGACAATATAAGGACA" -#> [1867] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [1870] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "TTGACAATATTTGGAAT" -#> [1873] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" -#> [1876] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1879] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1882] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" -#> [1885] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" -#> [1888] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" -#> [1891] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" -#> [1894] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1897] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" -#> [1900] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" -#> [1903] "GGGACCCTATTTGGTGT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1906] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GCCTCCAGATAAGGGTA" -#> [1909] "GAGACAATATAAGGACA" "CCTCCAGATAAGGGTAA" "GAGACAATATAAGGACA" -#> [1912] "AGACAATACAAGGACAT" "AGACAATATAAGGACAT" "ATGACCACAAATGGTCC" -#> [1915] "CCGCCTATATAAGGCGT" "AATACCAATTAAGGCCA" "TTCACCTTAGAAGGAAT" -#> [1918] "GAGACAATATAAGGACA" "ATGGCCAAATATGTGGA" "TGTACCATATATCGAGC" -#> [1921] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" -#> [1924] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1927] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" -#> [1930] "CTCCCAAAGAAGGTGAA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1933] "GAGACAATATAAGGACA" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" -#> [1936] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1939] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" -#> [1942] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" -#> [1945] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" -#> [1948] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" -#> [1951] "GAGACAATATAAGGTTG" "TTGACTATATTTGGAAT" "GAGACAATATAAGGGTA" -#> [1954] "AGACAATATAAGGACCT" "AGACAATATAAGGACAT" "TATGCAAATAAGGTATA" -#> [1957] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1960] "TGTGCTTATAAGGGGGG" "AGACAATATAAGGACAT" "AGACAATATAAGGACGT" -#> [1963] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" -#> [1966] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTACCATATATCGAGCG" -#> [1969] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" -#> [1972] "TGGCCAAATATGTGGAA" "AGACAATATAAGGACAT" "TGCCCATACTAGGGAGA"</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Get sequence values — seqs • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Get sequence values — seqs" /> + +<meta property="og:description" content="Get sequence values" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Get sequence values</h1> + + <div class="hidden name"><code>seqs.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Get sequence values</p> + + </div> + + <pre class="usage"><span class='fu'>seqs</span>(<span class='no'>granges</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>DNAStringSet (get) or GRanges (set)</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='fu'>seqs</span>(<span class='no'>granges</span>)</div><div class='output co'>#> [1] "AGACAATATAAGGGCAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [4] "AGACAATATAAGGACAT" "CCACCAAATATGGGCTT" "CAGCCCAGAGATGGTCC" +#> [7] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TCACCTTAGAAGGAATA" +#> [10] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [13] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [16] "AGACAATATAAGGACAT" "GCACCCAAATAAGGGAA" "ACAGCTTATAAGGAGAA" +#> [19] "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [22] "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" "GAGACAATATAAGGACG" +#> [25] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [28] "TCCCCTTAAAAGGTCAC" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [31] "GAGACAATATAAGGACA" "TTGAACATATATGAGAC" "TTGACAATATTTGGAAT" +#> [34] "GAGACAATATAAGGACA" "TGCCAGAATAAGGACAG" "GAGACAATATAAGGACA" +#> [37] "TGGCTATATATGGGATG" "TTACTATATATGTGATG" "AGACAATATAAGGACAT" +#> [40] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [43] "GAGACAATATAAGGACA" "TCACCCATATATGAAGA" "TCGCCCATAGATGGCGC" +#> [46] "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [49] "AGACAATATAAGGACAT" "GTCTCTATATAAGGAGT" "TTCCCACATTAGGTTAA" +#> [52] "GTGACCATGTAAGGTAA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [55] "AGCCCAAATTAGGCCTG" "TTGCCGTATTTGGTCTC" "AGACAATATAAGGACAT" +#> [58] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" +#> [61] "TTACCATAGAGGGAGAA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [64] "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" +#> [67] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "TTGACAATATTTGGAAT" +#> [70] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [73] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [76] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [79] "TTGACAATATTTGGAAT" "CAGACAATATAAGGACA" "TTCCCTTAAAAGGCCTC" +#> [82] "GTTCCCTTAAAAGGCCT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [85] "CTGCCTATATATGATGG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [88] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "CAGCCTCTATATGGCCA" +#> [91] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [94] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [97] "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [100] "GAGACAATATAAGGACA" "TAGCCAGATATGCTCAT" "GAGACAATATAAGGACA" +#> [103] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" +#> [106] "TCCACCAAACATGGGCT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [109] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [112] "AGACAATATAAGGACAT" "AGACCATATAAGGACAT" "GAGACAATATAAGGACA" +#> [115] "TCCACCAAACATGGGCT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [118] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" +#> [121] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "TGTGCTTATAAGGGGGA" +#> [124] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [127] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [130] "GAGACAATATAAGGACA" "AAACAATATAAGGACAT" "CGAGTATATAAGGTCTT" +#> [133] "TTAGCCATACAAGGAGT" "TCCACCAAACATGGGCT" "AGACAATATAAGGACAT" +#> [136] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGAAAATATAAGGACA" +#> [139] "ATGTCCCTATATTGTCT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" +#> [142] "GTGTGCAGATAAGGGCC" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [145] "GTACCATATATCGAGCG" "GAGACAATATAAGGATA" "AGACAATATAAGGACAT" +#> [148] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" +#> [151] "AGCCTATGTATGGGCTT" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [154] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [157] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [160] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "GAGACAATATAAGGACA" +#> [163] "GTGGTCATAGATGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [166] "TGTGCTTATAAGGGGCC" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [169] "GAGACAATATAAGGACA" "TTGTCAATGTAAGGTCA" "GAGACAATATAAGGACA" +#> [172] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [175] "AGAGCAGATATGGAAAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [178] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" +#> [181] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [184] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [187] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "CGAGCCAGATAAGGAAA" +#> [190] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" +#> [193] "AGACAATATAAGGACAT" "AGACTATATAAGGACAT" "TGCTTATATAAGGTCTG" +#> [196] "GAGACAATATAAGGACA" "GAGACAATATAAGGAAA" "GAGACAATATAAGGACA" +#> [199] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" +#> [202] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" +#> [205] "GAGACAATATAAGGACA" "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" +#> [208] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" +#> [211] "GAGACAATATAAGGACA" "TGGCCAGATGTGGGAAA" "AGACAATATAAGGACAT" +#> [214] "GAGACAATATCAGGACA" "AGACAATATAAGGACAT" "GGTAGCAAATATGGGGT" +#> [217] "ATGGCCAAATATGTGGA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [220] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [223] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [226] "GAGACAATATAAGGACA" "TGCCCATATATGGACTG" "GAGACAATATAAGGACA" +#> [229] "TCCACCAAACATGGGCT" "GGCCAATATATGGGCAT" "AGACAATATAAGGACAT" +#> [232] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" +#> [235] "AGACCATTTAAGGACAT" "AGACAATATAAGGACAT" "TCCCCAAAGAAGGCCAC" +#> [238] "TCTCCAGATATGGAAAA" "TGGGCGTATATGGGAGT" "AGACAATATAAGGACAT" +#> [241] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [244] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [247] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [250] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" +#> [253] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "CCACCAAATATGGGCTT" +#> [256] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [259] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" +#> [262] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "ATTACCAAACATGGAGA" +#> [265] "CTGCCCATATAAGGAAG" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [268] "TTAACCAAATAAGGGTT" "CTCCCCTATGTGGGCAG" "TTTCCCATATAAGGCCG" +#> [271] "CTGTCTAAATAAGGAAT" "TTGCCCATACTAGGGAG" "GAGACAATATAAGGACA" +#> [274] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [277] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [280] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [283] "TGACTATATTTGGAATG" "GAGACAATATAAGCACA" "AGACAATATAAGGACAT" +#> [286] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TCAACATATTAGGGCAC" +#> [289] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [292] "GAGACAATATAAGGACA" "GGGACCATATAAGAGAA" "GAGACAATATAAGGACA" +#> [295] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACTATATTTGGAAT" +#> [298] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" +#> [301] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [304] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [307] "AGACAATATAAGGACTT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [310] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "GTCACTATAGAAGGAAA" +#> [313] "GTAGCTTATAAGGTCTA" "ATGCCCAAATATGGCAC" "GAGACAATATAAGGACA" +#> [316] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CGGCCCATTTAAGGGTG" +#> [319] "TGACTATATTTGGAATG" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" +#> [322] "GAGACAATATAAGGACA" "TCACCACATAAGGGATT" "AGACAATATAAGGACAT" +#> [325] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [328] "TATGCCTTATAAGGGTC" "CATCCCAGCTAAGGTCA" "TTCCCGGATAAGGAAAT" +#> [331] "TGCCCTAATAAGGTTCT" "CTTCCCACATGTGGTCT" "ACCACCCTATAAGGCGT" +#> [334] "ACTTCCTTATAAGGAAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [337] "ATTGCCACATAAGGAAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [340] "TTGCCCATACTAGGAAG" "GAGACAATATAAGGACA" "TTACCTTAGAAGGAATA" +#> [343] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [346] "TGACTATATTTGGAATG" "AGTCCCAGATATGGCAC" "TCGCCATATATGGACAT" +#> [349] "AGACAATATAAGGACAT" "GACACCAAGTATGGGGA" "AGACAATATAAGGACAT" +#> [352] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "GAGACAATATAAGGACA" +#> [355] "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [358] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "ATACCAATTAAGGCCAT" +#> [361] "GAGACAATATAAGGACA" "TTGCCACATATGGTGGC" "AGACAATATAAGGACAT" +#> [364] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [367] "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" +#> [370] "ATTTCTAAATAAGGCCA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [373] "TCACCATAGATGCTCTT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACC" +#> [376] "AGACAATATAAGGACAT" "GTTGCCACATATGGTGG" "GAGACAATATAAGGACA" +#> [379] "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" "AGCCCATATTAGGTGGA" +#> [382] "AGCCCATATTAGGTGGA" "TGCCCCTCTAAGGTCTC" "CTCCCAAATAAGCGAAG" +#> [385] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [388] "TGACAATATTTGGAATG" "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" +#> [391] "GAGACAATATAAGGACA" "ACGCCCAAACAAGGTCA" "GAGACAATATAAGGACA" +#> [394] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [397] "GAGACAATATAAGGACA" "TGGACTATATAAGGACT" "GAGACAATATAAGGACA" +#> [400] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAGTATAAGGACA" +#> [403] "AGTCCATGTAAGGACTT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [406] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "AATACCAATTAAGGCCA" +#> [409] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "CCGCCCATATTAGGAGG" +#> [412] "TAGCTCAGATAAGGTCA" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" +#> [415] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [418] "GCGACCAAATAAGGCTG" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [421] "ATGTCCATATTAGGACA" "TTTCCAAATATGGGCAG" "ACACTTTATAAGGAATA" +#> [424] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AGACAATATAAGGACAT" +#> [427] "GAGACAATATAAGGACT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [430] "AGACAATATAAGGACAT" "GGCCTATATAAGGAGCA" "GAGACAATATAAGGACA" +#> [433] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "AGACAATATAAGGACAT" +#> [436] "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" +#> [439] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [442] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" +#> [445] "AATACCAATTAAGGCCA" "GTGAGCTTATAAGGGGG" "CGACCATATTTGTTGAG" +#> [448] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" +#> [451] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [454] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTGACTATATATGGGAT" +#> [457] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [460] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" +#> [463] "AGACAATATAAGGACAT" "GGACCAAATGTGGGCAC" "CTACCCAGACAAGGGCA" +#> [466] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [469] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [472] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGATAATATAAGGACAT" +#> [475] "AGATAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [478] "CCACCAAACATGGGCTT" "GAGACAATATAAGGACA" "TTGAGCATAAATGGCCT" +#> [481] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [484] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [487] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [490] "GTACCATATATCGAGCG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [493] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [496] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TCCCCAAATAAAGCCTC" +#> [499] "GAGACAATATAAGGACA" "TTGCCCATATGACGTCA" "AGACTATATAAGGACAT" +#> [502] "AGACTATATAAGGACAT" "AGACTATATAAGGACAT" "GAGACAATATAAGGACA" +#> [505] "ATTCCAGATATGTGCAG" "CACCCCAAATAAAGGAA" "TTGTGCCTATATGGGAC" +#> [508] "AGACAATATAAGGACAT" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [511] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [514] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [517] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [520] "GAGACAATATAAGGACA" "TTCCCATAGGTGGGAAG" "AGACAATATAAGGACAT" +#> [523] "TGACTATATTTGGAATG" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [526] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [529] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [532] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [535] "TGACAATATTTGGAATG" "AATACCAATTAAGGCCA" "TGGCTATATAAGATCAT" +#> [538] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [541] "GAGACCATATAAGGACA" "GAGACAATATAAGGACA" "CCACCAAATATGGGCTT" +#> [544] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" +#> [547] "TCCCCTTTTAAGGAGAA" "GGTCTATATAAGAACAC" "AGGCCTATATAAGAACA" +#> [550] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [553] "GAGACAATATAAGGACA" "TTCCTATATAAGAACTC" "GGCCTATATAAGAACAC" +#> [556] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" +#> [559] "AGACAATATAAGGACAT" "AGGCCTATATAAAGACA" "TGGACCAAATAAAGGCG" +#> [562] "GGACCAAATAAAGGCGA" "AGGCCTATATAAGAACA" "GGCCTATATAAAGACAG" +#> [565] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGGCCTATATAAGAACA" +#> [568] "ATTCCTATATAAGAACT" "AGGCCTATATAAGAACA" "GGCCTATATAAGAACAA" +#> [571] "AGGCCTATATAAGAACA" "GAGACAATATAAGGACA" "AGGCCTATATAAGAACA" +#> [574] "AGGCCTATATAAGAACA" "GGCCTATATAAAGACAG" "AGCGCCATATATGGCCT" +#> [577] "TTCCCAAATAATGCCAC" "GGCGCCATATATGGCCT" "GCGCCATATATGGCCTG" +#> [580] "GGCGCCATATATGGCCT" "GCGCCATATATGGCCTG" "CAGGCCATATATGGTGC" +#> [583] "GCGCCATATATGGCCTG" "GCGCCATATATGGCCTG" "AGACAATATAAGGACAT" +#> [586] "TCCACCAAATATGGACT" "GAGACAATATAAGGACA" "CTGTCCCTATAAGTTGA" +#> [589] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "CAGGCCATATATGGTGC" +#> [592] "ATGCCCTTATAAGGAGC" "CACCCATATATGGTATG" "GTTGCCCTCTATGGGCA" +#> [595] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [598] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "GGGCCCAATAAGGGAAC" +#> [601] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [604] "GAGACAATATAAGGACA" "TTGCCCATACTAGGGAG" "AGACAATATAAGGACAT" +#> [607] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" +#> [610] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" +#> [613] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [616] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [619] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TGACCAGAAAAGGACTC" +#> [622] "GGACCATATATGGGTAT" "AGACAATATAAGGACAT" "TTTCCCAAATTTGGATC" +#> [625] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [628] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [631] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [634] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [637] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [640] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [643] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [646] "GAGACAATATAAGGACA" "TACCCAAACAAGGGGAA" "TGCCCATACTAGGGAGA" +#> [649] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [652] "AGACAATATAAGGACAT" "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" +#> [655] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [658] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [661] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "ATGACCTTATAAGGGGA" +#> [664] "GAGACAATATAAGGACA" "AATACCATAAAAGGAAA" "GTCTCCATATTTGTACA" +#> [667] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [670] "GAGACAATATAAGGACA" "TTTTCCTTATAAGAGTT" "AGGCCTATATAAGGAAC" +#> [673] "AGGCCTATATAAGGAAC" "AGGCCTATATAAGGAAC" "AGGCCTATATAAGGAAC" +#> [676] "AGGCCTATATAAGGAAC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [679] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [682] "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [685] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [688] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [691] "GAGACAATATAAGGACA" "ATGGCCAAATATGTGGA" "GAGACAATATAAGGACA" +#> [694] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [697] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [700] "CCACCAAATATGGACTT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [703] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [706] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [709] "TGGCCCTATTAGGGAGG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [712] "ATACCAATTAAGGCCAC" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [715] "GAGACAATATAAGGACA" "TGCCCCTTTAAGGGCGG" "AGACAATATAAGGACAT" +#> [718] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [721] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [724] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CCTCCAGATAAGGGTAA" +#> [727] "GAGACAATATAAGGACA" "AGACCATATAAGGACAT" "GAGACAATATAAGGACA" +#> [730] "CTGGCCATATAAGGTAA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [733] "GAGACAATATAAGGACA" "AGTCCCAGATATGGCAC" "GAGACAATATAAGGACA" +#> [736] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [739] "AGACAAAATAAGGACAT" "GAGACAATATAAGGACA" "GTAAGCATACATGGACA" +#> [742] "GAGACAATATAAGGACA" "TGTCCATGTAAGGTATG" "AGACAATATAAGGACAT" +#> [745] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATATGGACAT" +#> [748] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [751] "TTAACCATATAAGAGGG" "AGACAATATAAGGACAT" "TTAGCATACAAGGTAAC" +#> [754] "AGACAATTTAAGGACAT" "AGACAATATAAGGACAT" "ATGGCCAAATATGTGGA" +#> [757] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [760] "TGACAATATTTGGAATG" "CCACCAAACATGGGCTT" "AGTCCCAGATATGGCAC" +#> [763] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [766] "AGACAATATAAGGACAT" "GAGACCATATAAAAACA" "GTACCATATATCGAGCG" +#> [769] "GTGACGATATATGGGAC" "AGACAATATAAGGAGAT" "GAGACAATATAAGGACA" +#> [772] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [775] "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" "TGACAATATTTGGAATG" +#> [778] "CGACCCTACAAGGTCAG" "TGTCCCTTATAAGGTCA" "CCACCAAATATGGACTT" +#> [781] "GAGACAATATAAGGACA" "CACCCATAGATGGGCGG" "CACCCCCAATAAGGCCA" +#> [784] "AGACAATATAAGGACAT" "ATCACCATGTAAGGGCT" "TGCCTATACATAGTCAA" +#> [787] "CCTCCCCTATGTGGGCA" "CCTCCCCTATGTGGGCA" "CCGCCCATATCAGGGTG" +#> [790] "GACCCATATAAAGACCC" "GTCACCATGGATGGCCA" "GAGACAATATAAGGACA" +#> [793] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [796] "AGACCATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [799] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [802] "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [805] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "TCCACCAAACATGGGCT" +#> [808] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [811] "TTAGCAAAGATGGTCAG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [814] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "TTACCCAATATGGAACC" +#> [817] "AGACAATATAAGGACAT" "AGACCATATAAGGACAT" "GAGGCCCAATAAGGGAA" +#> [820] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" +#> [823] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "GTCCCAGATATGGCACC" +#> [826] "AGACAATATAAGGACAT" "TGCCTAGATTTGGGAAG" "GAGACAATATAAGGACA" +#> [829] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [832] "GAGACAATATAAGGACA" "TGACCATATGAGGTCAG" "CGCCCTATATAAGGCGA" +#> [835] "CCCCCCATATAAAGAGA" "TCGCCATAAAAGGAAAC" "TCGCCATATAAGGAGCG" +#> [838] "AGACGATGTAAGGACAT" "AGACAATATAAGGACAT" "AGACAACATAAGGACAT" +#> [841] "TCACCTTAGAAGGAATA" "AAGACCAAAGAAGGGCT" "CGACAATATAAGGACAT" +#> [844] "TCCACCAAACATGGGCT" "GAGACAATATAAGGACA" "TCACCAAATATGGGCTT" +#> [847] "CGCCCAAAGAAGGCCAG" "AATACCAATTAAGGCCA" "AGACAATATAAGGACAT" +#> [850] "CTGCCCTAAGAAGGGCA" "GTCACCACAGAAGGGCA" "CCACCGAATATGGACTT" +#> [853] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "TTGAGCATATATGGCCT" +#> [856] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAAGACA" +#> [859] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [862] "AGACAATATAAGGACAA" "GAGACAATATAAGGACA" "CTGCCCACATAAGGGAG" +#> [865] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "TTTACCTTAGAAGGAAT" +#> [868] "GAGACAATATAAGGACA" "TGGCCATAAATGGCCTC" "AGACAATATAAGGACAT" +#> [871] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" +#> [874] "AGACAATATAAGGACAT" "ATACCAAATATGGCCAC" "GTACCATATATCGAGCG" +#> [877] "GAGACAATATAAGGACA" "CGGCCAAATATAGTATT" "GAGACAATATAAGGACA" +#> [880] "AGACCATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [883] "AGACAATATAAGGACAT" "AACGCCATATAAGGAGC" "TGCCCAAATAAGGTCTG" +#> [886] "ACTCCATATAAGGCGCT" "CCTTCCATATTAGGGCT" "TGGCCATATATGGGAAG" +#> [889] "AATCCAAATAAGGTCAG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [892] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [895] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGGCCAAATATGTGGAA" +#> [898] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGAGCCTATAAGGACCA" +#> [901] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [904] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [907] "TTCACCTTAGAAGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [910] "AGACCATCTAAGGACAT" "AGACCATCTAAGGACAT" "TGACTATATCTGGAATA" +#> [913] "TGACTATATCTGGAATA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [916] "TGTACCATATATCGAGC" "GAGACTATATAAGGACA" "AGACCAAAGAAGGAAAG" +#> [919] "ATGCCCTAATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [922] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [925] "TCCACCAAATATGGACT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [928] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [931] "TGACTATATTTGGAATG" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [934] "TGTACCATATATCGAGC" "TTCACCTTAGAAGGAAT" "GAGACAATATAAGGACA" +#> [937] "GAGACAATATAAGGACA" "AGTCCCAGATATGGCAC" "GTACCATATATCGAGCG" +#> [940] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [943] "AGACAATATAAGGACAT" "TTGCCCATACAAGGGCG" "AGACAATATAAGGACAT" +#> [946] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [949] "TGCCCATATAAGGCCAA" "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" +#> [952] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [955] "CTTCCCAAATTAGGAGA" "TACCCCAATAAGGCCAC" "TCACCATAGATGGAGAA" +#> [958] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "TGACAATATTTGGAATG" +#> [961] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [964] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" +#> [967] "CACGCCCTATAAGGGGT" "GAGACAATATAAGGACA" "TTGCCTATATGTGGAAA" +#> [970] "TTCCTATGTATGGGAGT" "ACGACCATAGATAGACA" "GAGACCATATAAGGACA" +#> [973] "TTTCCCAAATGTGGTCC" "TGGCCATATTTGAAATG" "ATATGCATATATGGCCA" +#> [976] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [979] "TACCCAGAGAAGGGAAT" "GAGACAATATAAGGACA" "TCACCTTAGAAGGAATA" +#> [982] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [985] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GCTCCATAAAAGGGGAG" +#> [988] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [991] "GAGACAATATAAGGACA" "GAGACAATATAAAGACA" "GAGACAATATAAGGACA" +#> [994] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [997] "AGACAATATAAGGACAT" "GTGACCTTATGAGGAGA" "AGACAATATAAGGACAT" +#> [1000] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1003] "TTTGCCATAAAAGGAGG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1006] "TGACCATATAATTTGTC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1009] "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" +#> [1012] "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" "GGGACAATATAAGGACA" +#> [1015] "GGGACAATATAAGGACA" "ATGGCCAAATATGTGGA" "AGACAATATAAGGACAT" +#> [1018] "GAGACCATATAAGGACA" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" +#> [1021] "TTGACAATATTTGGAAT" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [1024] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "CCACCAAATAAGGGCTC" +#> [1027] "TGACCATTTTAGGGAAT" "AGACAATATAAGGACAT" "TTACCCAAACAAGGGAA" +#> [1030] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" +#> [1033] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" +#> [1036] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GTACCATATATCGAGCG" +#> [1039] "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1042] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" +#> [1045] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1048] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" +#> [1051] "CGCCCAGATAAGGGGCG" "TGTACCATATATCGAGT" "TCCCCTTTTAAGGAGAA" +#> [1054] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "AAACAATATAAGGACAT" +#> [1057] "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" "AAACAATATAAGGACAT" +#> [1060] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [1063] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1066] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TCCCCTTTTAAGGAGAA" +#> [1069] "GAGACAATATAAGGACA" "CCCGCCGTATATGGGAG" "TGCCCATACATGGAAGT" +#> [1072] "CCGCCCCTATATGGGCC" "TGGTCAAATATGGTCAA" "AGACAATATAAGGACAT" +#> [1075] "GTACCATATATCGAGCG" "CTACCAAATAGGGACTA" "AGACAATATAAGGACAT" +#> [1078] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "TGAGCCTATAAGGGCTT" +#> [1081] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "TTGACAATATTTGGAAT" +#> [1084] "AGGTCTATATAAGGAAG" "TGGTCCCTATGTGGTCA" "AGACAATATAAGGACAT" +#> [1087] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1090] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1093] "GAGACAATATAAGGACA" "AGGACGATATAAGCGCA" "AGGCCTATATAAGGAGC" +#> [1096] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" +#> [1099] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1102] "TCAACCAAATAAGGATT" "TGACTATATATGAGATG" "GTGTGCTTATAAGGGGG" +#> [1105] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [1108] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1111] "GAGACAATATAAGGACA" "AGCCCAGAGATGGTCCC" "AGACAATATAAGGACAT" +#> [1114] "TCCACCAAATATAGACT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1117] "AATACCAATTAAGGCCA" "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1120] "GTACCATATATCGAGCG" "CATACCATATGTGTTCT" "AGACAATATAAGGACAT" +#> [1123] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TCACCTTAGAAGGAATA" +#> [1126] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1129] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [1132] "TGACTATATTTGGAATG" "AGACCAAATATGGTCAC" "AGACCATATAAGGACAT" +#> [1135] "TGGCCAAATATGTGGAA" "GTAACTGTATATGGGAT" "AGACAATATAAGGACAT" +#> [1138] "GAGACAATATAAGGACA" "TGAGTATAGATGGTCAA" "CTGCCTAGATAAGGTGA" +#> [1141] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTGACGTCATAAGGTCA" +#> [1144] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" +#> [1147] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" +#> [1150] "TGACTATATTTGGAATG" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" +#> [1153] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GACGCCAGATATGGAAG" +#> [1156] "AGACAATATAAGGACAT" "TTTTCCATAGAAGAGCT" "TCCACCAAATATGGGCT" +#> [1159] "GAGACACTATAAGGACA" "AGGCCTATATATGGAAT" "AGGACCATATAGGAGCT" +#> [1162] "AAGCCTATATAAGCACT" "AGCCTATATAAGCACAT" "AGCCTATATAAGCACAT" +#> [1165] "AATACCAATTAAGGCCA" "GAGCCTATATAAGCACA" "GGCCTATATAAGCACAT" +#> [1168] "GAGCCTATATAAGCACA" "GAGCCTATATAAGCACA" "CTACCATATAAGTCTAG" +#> [1171] "ATGACCTTAAAAGGAAT" "CCACCATATAAGTCTAG" "ATGGCCTTAAAAGGAAT" +#> [1174] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TTCCCGTAAAAGGGGAA" +#> [1177] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [1180] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1183] "AGACAATATAAGGACAT" "GTCCCCAAAGATGGTCA" "GGCCTACATAAGGTCAC" +#> [1186] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [1189] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GTGTCCGTATATGGTCT" +#> [1192] "GAGACAATATAAGGACA" "TGTGTATATATGGGCAG" "GAGACAATATAAGGACA" +#> [1195] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "AGACCATATAAAGCTCA" +#> [1198] "GAGACAATATAAGGACA" "GTACCATATATCGAGCC" "GAGACAATATAAGGACA" +#> [1201] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGAAAATATAAGGACA" +#> [1204] "TCCACCAAACATGGGCT" "AGTGCCTGATAAGGTCA" "GAGACAATATAAGGACA" +#> [1207] "TCCACCAAATATGGACT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1210] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1213] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "ATTCCCGTATATGTTCC" +#> [1216] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [1219] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [1222] "GAGACAATATAAGGACA" "CTGGCCATATGATGTCA" "AGACAATATAAGGACAT" +#> [1225] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" +#> [1228] "ACACCATATATGAGACC" "GAGACCATATAAGGACA" "GAGACAATATAAGGACA" +#> [1231] "AATACCAATTAAGGCCA" "GCTGCATATATGGCCTT" "AGACAATATAAGGACAT" +#> [1234] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [1237] "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" "ATCTCCAGATAAGGGTC" +#> [1240] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1243] "AGACAATATATGGACAT" "AGACAATATATGGACAT" "GTACCATATATCGAGCG" +#> [1246] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1249] "GGCCCCTACATGGCCAG" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [1252] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" +#> [1255] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [1258] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1261] "GTACCATATATCGAGCG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1264] "GAGACAATATAAGGACA" "TGCCCATAGAGGGTGTG" "TGGTCCACATAAGGGCA" +#> [1267] "GCACCGTATAAGGGAAT" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" +#> [1270] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTGCATCTAAGGAAAA" +#> [1273] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [1276] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [1279] "GAGACAATATAAGGACA" "AGACAATATAAGGACAC" "GTCTCCAGATAAGGGTC" +#> [1282] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAC" "GTCTCCAGATAAGGGTC" +#> [1285] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GCTGCCATGTAAGGCCT" +#> [1288] "CTGCCCTAGATGGTCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1291] "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [1294] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [1297] "GAGACAATATAAGGACA" "AAGACCATAAAAGGGAC" "AGGCCTATATAAGGAGC" +#> [1300] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [1303] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1306] "AGACAATATAAGGACAT" "TGTACTATATAAGGAAG" "AGACAATATAAGGACAT" +#> [1309] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" +#> [1312] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CTCCCCATAGAAGGTAA" +#> [1315] "TTGAGCATGTATGGACT" "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1318] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1321] "CTGTCCATATCAGGTAA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1324] "AGTCCATAAAAGGGCTG" "TGGCCAAATATGTGGAA" "GAGACAATATAAGGACT" +#> [1327] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [1330] "TGCCAAAATATGGTGAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1333] "TGGACCTTTTAAGGACT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1336] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "TGTACCATATATCGAGC" +#> [1339] "AGACAATATAAGGACAT" "CTGCCCAAATAAGGAGC" "GTGACCATAGATGGTCA" +#> [1342] "ATAACCTTAGAAGGTAT" "GATGGCAAATATGGACT" "AGCCCAAAGATGGGTAG" +#> [1345] "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" "AGGAGTATATAAGGACT" +#> [1348] "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" +#> [1351] "GATGCCATATAAGGCAA" "GTGTGCATATATGTGTA" "GAGACAATATAAGGACA" +#> [1354] "TTACCATATTAGGGCTC" "TCTCTATCTAAGGTCAG" "TGGCCCTATTTGGAGTA" +#> [1357] "CTCACGATGTAAGGACA" "CGCTCAAATATGGGCTC" "ATCCCTAATAAGGTGCA" +#> [1360] "AGACAATATAAGGACAT" "AGACCATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1363] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1366] "AGACAATATAAGGACAT" "AAGACTATAAATGGGCT" "TAGCCCATGGATGGGCA" +#> [1369] "TGGCCATAACTGGACAA" "AGTCCCAGATATGGCAC" "AATACCAATTAAGGCCA" +#> [1372] "TCCCCGTACATGGGCAG" "TTGACAATATTTGGAAT" "AGACAATATAAGGACAT" +#> [1375] "AGACCCATATAAGGACA" "TCCACCAAATATGGACT" "TGTCCATGTTAGGTAAG" +#> [1378] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" +#> [1381] "GAGACAATATAAGGACA" "TGACAATATTTGGAATG" "TTGCCATATTTGAGCTG" +#> [1384] "GAGACAATATAAGGACA" "TCGTCCCTATATGGTGG" "GAGACCATATAAGGACA" +#> [1387] "TGACTATATATGGTCAA" "AGACAATATAAGGACAT" "TCACCTTAGAAGGAATA" +#> [1390] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TGCCCATACTAGGGAGA" +#> [1393] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [1396] "ATACCAATTAAGGCCAC" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" +#> [1399] "CTCACAAATAAGGTCAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1402] "GAGACAATATAAGGACA" "GAGACCATATAAGGACA" "AGACAATATAAGGACAT" +#> [1405] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [1408] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1411] "AGTCCCAGATATGGCAC" "GAGACAATATAAGGATA" "GAGACAATATAAGGACA" +#> [1414] "GTGACCGGATACGGGAA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1417] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1420] "GTGTGCTTATAAGGGGG" "CCCACCAAATATGGGCT" "AGACAATATAAGGACAT" +#> [1423] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [1426] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1429] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [1432] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1435] "AATACCAATTAAGGCCA" "AGACAATATAAGGACAT" "TGCCCATAGATGGCTGA" +#> [1438] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1441] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "TACTCAAATAAGGCCAC" +#> [1444] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GGACTATACAAGGGCAG" +#> [1447] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1450] "GCGCCTATATACGGCCT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1453] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "TAGCCCATACTAGGGCT" +#> [1456] "AGACAATATAAGGACAT" "TCGCGATATATAGACAC" "AGACAATATAAGGACAT" +#> [1459] "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" +#> [1462] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1465] "TCACCAAATTAGGCAAG" "ATTACCATAAAAGGCAA" "GTGACAATATAAGGAAG" +#> [1468] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAAACAATATAAGGACA" +#> [1471] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1474] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1477] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATACAAGGACAT" +#> [1480] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1483] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" +#> [1486] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AGACCATACAAGGAGCG" +#> [1489] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AGACAATATAAGGACAT" +#> [1492] "GATCCAGATAAGGACAG" "AGACAATATAAGGACAT" "TGGCCGTATATGTGCTC" +#> [1495] "TGATTATATAAGGTCTT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1498] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1501] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1504] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "GAGACAATATAAGGACA" +#> [1507] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "TTGGGCATGTAAGGAAA" +#> [1510] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" +#> [1513] "AGACAATATAAGGACAT" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1516] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1519] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [1522] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "TGTGCTTATAAGGGGGA" +#> [1525] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" +#> [1528] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1531] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1534] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1537] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1540] "TCCACCAAACATGGGCT" "AGACAATATAAGGACAT" "CCCGCAGATATGGTCAG" +#> [1543] "GCACCAAATTAGGACAG" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" +#> [1546] "CTAACCATACAAGTTCA" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1549] "CCTGCCTTATAAGGGGA" "CTGGCTGTATATGGGTT" "GGACCAAATAACGGATT" +#> [1552] "GGCACCATAAAAGGTCT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1555] "GAGACAATATAAGGACG" "GAGACAATATAAGGACA" "TTGACTATATTTGGAAT" +#> [1558] "GAGACAATATAAGGACA" "GTGGCTAAACATGGGCA" "CTTCCCACATAAGGTAC" +#> [1561] "GAGACCATATAAGGACA" "TCCCCTTAAAAGGACAA" "AGACAATATAAGGACAT" +#> [1564] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "AAGCCCTTATAAGGAGC" +#> [1567] "GATCGCATATTTGGACT" "AGACAATATAAGGACAT" "TATCCGTATTAGGTGAG" +#> [1570] "TTGCCATACATGGTGTG" "TCCACCAAACATGGGCT" "TCCACCAAACATGGGCT" +#> [1573] "GAGACAATATAAGGACA" "TCCACCAAATATGGACT" "GTACCATATATCGAGCG" +#> [1576] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1579] "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [1582] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1585] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1588] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "TTAGCATAGATGGAGAA" +#> [1591] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "TAGAGCAAATAAGGATA" +#> [1594] "TAGACAATATAAGGTCT" "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" +#> [1597] "AGACAATATAAGGACAT" "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" +#> [1600] "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" +#> [1603] "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" "CTGCCCAGACAAGGTAT" +#> [1606] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1609] "ATACCAATTAAGGCCAC" "GAGACAATATAAGGACA" "GAGACCAAATACGTGCA" +#> [1612] "TACCCATAGATGGGCCT" "TGCCCAAATAAGGAAGG" "TTAGCCATATAAGGAGC" +#> [1615] "TGACAATATTTGGAATG" "AATACCAATTAAGGCCA" "AGATAATATAAGGACAT" +#> [1618] "AGACAATATAAGGACAT" "CGACCATACAAGGAAAA" "GCCCCATAAAAGGAGAA" +#> [1621] "CCACCAAACATGGGCTT" "TCCACCAAACATGGGCT" "TTGACTATATTTGGAAT" +#> [1624] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAAACAATATAAGGACA" +#> [1627] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "CTGCCTTACAAGGGCAC" +#> [1630] "AAGGCCAAAAAAGGGCA" "TCGCCCAAAGATGGGGT" "AGACAATATAAGGACAT" +#> [1633] "TGTACCATATATCGAGC" "GCTACCATATTTGAACA" "AGACAATATAAGGACAT" +#> [1636] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" +#> [1639] "TCACCTTAGAAGGAATA" "TTGCCCCGATATGGCCC" "AGACAATATAAGGACAT" +#> [1642] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGGCAATATAAGGACAT" +#> [1645] "GAGACAATATAAGGACA" "ATTCCCTATATGGCTAG" "GGCCCATAAAAGGAGGG" +#> [1648] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "CCACCAAACATGGGCTT" +#> [1651] "TGTACCATATATCGAGC" "CCACCAAATATGGGCTT" "TGTACCATATATCGAGC" +#> [1654] "AGACAATATAAGGACAT" "GTGCCATTATAAGGGAT" "AGACAATATAAGGACAT" +#> [1657] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" +#> [1660] "AGACAATATAAGGACAT" "CCTTCCACATAAGGCCA" "GAGACAATATAAGGACA" +#> [1663] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1666] "GAGACTGTATAAGGACA" "GCATCCCTATAAGGTCA" "AGACAATATAAGGACAT" +#> [1669] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACCATATAAGGACAT" +#> [1672] "AAAACCAAATATGAACA" "TTAGCCATACAAGGGAA" "AGAGCATACATGGGCTG" +#> [1675] "CTAACCTTGTAAGGAGA" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [1678] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "CTTTCCAAAGAAGGACG" +#> [1681] "GAGACAATATAAGGACA" "GTCTCCAAGTAAGGGCA" "AGACAATATAAGGACAT" +#> [1684] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1687] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTACCATATATCGAGCG" +#> [1690] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1693] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" +#> [1696] "AGACAATATAAGGACAT" "CTGCCCACATAAGCGCT" "GAGACAATATAAGGACA" +#> [1699] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" +#> [1702] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1705] "TCCACCAAATATGGACT" "TTCCCAGATATGCAGAG" "AGACAATATAAGGACAT" +#> [1708] "TCCACCAAATATGGAAC" "CTCCTATACAAGGGCAT" "GAGACAATATAAGGACA" +#> [1711] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1714] "CCACCAAACATGGGCTT" "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" +#> [1717] "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" "CAGACCATAAAAGAACA" +#> [1720] "GAGACAATATAAGGATT" "CTGTCCATGTAAGACCA" "TGTCCATGTAAGACCAT" +#> [1723] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAATGACAT" +#> [1726] "AGACAATATAAGGACAT" "CTTCCTATGTATGGTCA" "AGACAATATAAGGACAT" +#> [1729] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1732] "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" "ATGCCCATATAAGGTGA" +#> [1735] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1738] "GAGACAATATGAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [1741] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1744] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "TTCCTATATATTGTGAC" +#> [1747] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [1750] "GAGACAATATAAGGACA" "TGTCCTTATAAGAGTTG" "GAGACAATATAAGGACA" +#> [1753] "CTTCCCTATATGGGCGT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1756] "TCCCCATATAAGACTTC" "AGACAATATAAGGACAT" "GAGACAATAGAAGGACA" +#> [1759] "CCCTCCAGATAAGGAAA" "ATGCCCATATAAGAACA" "AGGCCCATATATGGGCA" +#> [1762] "GCACCCATATTAGGGCA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1765] "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" "GTCCCCAAATAAGGAAA" +#> [1768] "GGGGCCATATGTGGGCG" "GCGCCCATAAAAGGTAC" "AGACAATATAAGGACAT" +#> [1771] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1774] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GAGACAATATAAGGTGC" +#> [1777] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1780] "GAGCCCAGATATGGGAG" "GCTCCATACAAGGGCGT" "AGGCCAAATAAGGCAGG" +#> [1783] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "CGCCCCTATGTGGGCAG" +#> [1786] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "CTATCCCTATTTGGTCA" +#> [1789] "AGTCCCAGATATGGCAC" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1792] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "GAGACCATATAAGGACA" +#> [1795] "TGGCCATAGCTGGACTC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1798] "GAGACAATATAAGGACA" "TGTACCATATATCGAGC" "GTCCCAGATATGGCACC" +#> [1801] "AGACAATATAAGGACAT" "TTACCTTAGAAGGAATA" "GAGACAATATAAGGACA" +#> [1804] "CGCCCCATAGAAGGGAG" "CCACCAAATATGGACTT" "AGACAATATAAGGACAT" +#> [1807] "TGACTATATTTGGAATG" "AGACAATATCAGGACAT" "TGACTATATTTGGAATG" +#> [1810] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAAGACA" +#> [1813] "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1816] "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1819] "GCGGCCATATAAGGCAG" "TTGAGCAAATTTGGTCT" "AGACAATATAAGGACAT" +#> [1822] "TTGACTATATTTGGAAT" "GAGACAATATAAGGACA" "TGTCCATAAATGGAGAA" +#> [1825] "TGACTATATTTGGAATG" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1828] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "TGTACCATATATCGAGC" +#> [1831] "CAACCAGATATGGGCGT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1834] "GTGACCATATAAGAGCA" "GAGACAATATAAGGACA" "TTGACAATATTTGGAAT" +#> [1837] "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" "GTCCCAGATATGGCACC" +#> [1840] "AGACAATATAAGGACAT" "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" +#> [1843] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TTCACCTTAGAAGGAAT" +#> [1846] "ACACCATATAAGGCCCG" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1849] "AATACCAATTAAGGCCA" "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" +#> [1852] "ACTCCATATAAGACATT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1855] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1858] "GAGACAATATAAGGACA" "GTAGCCATAGATGGGCG" "TCACCAAATTAGGCCTT" +#> [1861] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" +#> [1864] "AGACAATATAAGGACAT" "TGTCTATTTAAGGTCAG" "GAGACAATATAAGGACA" +#> [1867] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [1870] "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" "TTGACAATATTTGGAAT" +#> [1873] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "AATACCAATTAAGGCCA" +#> [1876] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1879] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1882] "AGACAATATAAGGACAT" "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" +#> [1885] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" +#> [1888] "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" +#> [1891] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "TGACTATATTTGGAATG" +#> [1894] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1897] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" +#> [1900] "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" "GAGACAATATAAGGACA" +#> [1903] "GGGACCCTATTTGGTGT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1906] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GCCTCCAGATAAGGGTA" +#> [1909] "GAGACAATATAAGGACA" "CCTCCAGATAAGGGTAA" "GAGACAATATAAGGACA" +#> [1912] "AGACAATACAAGGACAT" "AGACAATATAAGGACAT" "ATGACCACAAATGGTCC" +#> [1915] "CCGCCTATATAAGGCGT" "AATACCAATTAAGGCCA" "TTCACCTTAGAAGGAAT" +#> [1918] "GAGACAATATAAGGACA" "ATGGCCAAATATGTGGA" "TGTACCATATATCGAGC" +#> [1921] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AATACCAATTAAGGCCA" +#> [1924] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1927] "GAGACAATATAAGGACA" "GTACCATATATCGAGCG" "GAGACAATATAAGGACA" +#> [1930] "CTCCCAAAGAAGGTGAA" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1933] "GAGACAATATAAGGACA" "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" +#> [1936] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1939] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "ATACCAATTAAGGCCAC" +#> [1942] "TGTACCATATATCGAGC" "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" +#> [1945] "TGACAATATTTGGAATG" "AGACAATATAAGGACAT" "GAGACAATATAAGGACA" +#> [1948] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "AGACAATATAAGGACAT" +#> [1951] "GAGACAATATAAGGTTG" "TTGACTATATTTGGAAT" "GAGACAATATAAGGGTA" +#> [1954] "AGACAATATAAGGACCT" "AGACAATATAAGGACAT" "TATGCAAATAAGGTATA" +#> [1957] "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1960] "TGTGCTTATAAGGGGGG" "AGACAATATAAGGACAT" "AGACAATATAAGGACGT" +#> [1963] "TGACAATATTTGGAATG" "ATACCAATTAAGGCCAC" "AGACAATATAAGGACAT" +#> [1966] "AGACAATATAAGGACAT" "AGACAATATAAGGACAT" "GTACCATATATCGAGCG" +#> [1969] "TTGACAATATTTGGAAT" "GAGACAATATAAGGACA" "GAGACAATATAAGGACA" +#> [1972] "TGGCCAAATATGTGGAA" "AGACAATATAAGGACAT" "TGCCCATACTAGGGAGA"</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/slop.html b/public/reference/slop.html index d972ae7ced3b5abe499fda8a56f1090bd282c5b3..992043f3ee22ba2da2ac450d37ff4dff33421e6c 100644 --- a/public/reference/slop.html +++ b/public/reference/slop.html @@ -1,200 +1,200 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Slop (i.e. extend left/right) — slop • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Slop (i.e. extend left/right) — slop" /> - -<meta property="og:description" content="Slop (i.e. extend left/right)" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Slop (i.e. extend left/right)</h1> - - <div class="hidden name"><code>slop.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Slop (i.e. extend left/right)</p> - - </div> - - <pre class="usage"><span class='fu'>slop</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>22</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>22</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - <tr> - <th>leftstart</th> - <td><p>flank start relative to range start</p></td> - </tr> - <tr> - <th>rightend</th> - <td><p>flank end relative to range start</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>)</div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>) <span class='kw'>%>%</span> <span class='fu'>slop</span>()</div><div class='output co'>#> <span class='message'> 1 slopped granges: [start-22, end+22]</span></div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712605-4712665 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Slop (i.e. extend left/right) — slop • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Slop (i.e. extend left/right) — slop" /> + +<meta property="og:description" content="Slop (i.e. extend left/right)" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Slop (i.e. extend left/right)</h1> + + <div class="hidden name"><code>slop.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Slop (i.e. extend left/right)</p> + + </div> + + <pre class="usage"><span class='fu'>slop</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>22</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>22</span>, <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + <tr> + <th>leftstart</th> + <td><p>flank start relative to range start</p></td> + </tr> + <tr> + <th>rightend</th> + <td><p>flank end relative to range start</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>)</div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span>(<span class='fl'>1</span>) <span class='kw'>%>%</span> <span class='fu'>slop</span>()</div><div class='output co'>#> <span class='message'> 1 slopped granges: [start-22, end+22]</span></div><div class='output co'>#> GRanges object with 1 range and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712605-4712665 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/slop_fourways.html b/public/reference/slop_fourways.html index 53188c375e3d150d293630af52963b1c1d8a13ed..95db5ba7ddf7268bc86c6d61fa5f8afbb2c02de6 100644 --- a/public/reference/slop_fourways.html +++ b/public/reference/slop_fourways.html @@ -1,221 +1,221 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Slop granges for both strands, merging overlaps — slop_fourways • multicrispr</title> - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - -<meta property="og:title" content="Slop granges for both strands, merging overlaps — slop_fourways" /> - -<meta property="og:description" content="Slop granges for both strands, merging overlaps" /> -<meta name="twitter:card" content="summary" /> - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/using_multicrispr.html">Using multicrispr</a> - </li> - </ul> -</li> - </ul> - - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Slop granges for both strands, merging overlaps</h1> - - <div class="hidden name"><code>slop_fourways.Rd</code></div> - </div> - - <div class="ref-description"> - - <p>Slop granges for both strands, merging overlaps</p> - - </div> - - <pre class="usage"><span class='fu'>slop_fourways</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>22</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>22</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>granges</th> - <td><p>GenomicRanges::GRanges</p></td> - </tr> - <tr> - <th>leftstart</th> - <td><p>numeric(1)</p></td> - </tr> - <tr> - <th>rightend</th> - <td><p>numeric(1)</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>logical(1)</p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>GenomicRanges::GRanges</p> - - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> -<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712627-4712643 - -#> [2] chr1 5250211-5250227 - -#> [3] chr1 5250451-5250467 - -#> [4] chr1 5256192-5256208 - -#> [5] chr1 5985727-5985743 - -#> ... ... ... ... -#> [1970] chrY 6770311-6770327 + -#> [1971] chrY 23130567-23130583 + -#> [1972] chrY 42512399-42512415 - -#> [1973] chrY 79048175-79048191 - -#> [1974] chrY 89126493-89126509 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'>slop_fourways</span>()</div><div class='output co'>#> <span class='message'> Slop fourways</span></div><div class='output co'>#> <span class='message'> 1974 slopped granges: [start-22, end+22]</span></div><div class='output co'>#> <span class='message'> 3948 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 3932 after merging overlaps</span></div><div class='output co'>#> GRanges object with 3932 ranges and 0 metadata columns: -#> seqnames ranges strand -#> <Rle> <IRanges> <Rle> -#> [1] chr1 4712605-4712665 + -#> [2] chr1 5250189-5250249 + -#> [3] chr1 5250429-5250489 + -#> [4] chr1 5256170-5256230 + -#> [5] chr1 5985705-5985765 + -#> ... ... ... ... -#> [3928] chrY 6770289-6770349 - -#> [3929] chrY 23130545-23130605 - -#> [3930] chrY 42512377-42512437 - -#> [3931] chrY 79048153-79048213 - -#> [3932] chrY 89126471-89126531 - -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - - <li><a href="#value">Value</a></li> - - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Slop granges for both strands, merging overlaps — slop_fourways • multicrispr</title> + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + +<meta property="og:title" content="Slop granges for both strands, merging overlaps — slop_fourways" /> + +<meta property="og:description" content="Slop granges for both strands, merging overlaps" /> +<meta name="twitter:card" content="summary" /> + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.0.1</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/using_multicrispr.html">Using multicrispr</a> + </li> + </ul> +</li> + </ul> + + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Slop granges for both strands, merging overlaps</h1> + + <div class="hidden name"><code>slop_fourways.Rd</code></div> + </div> + + <div class="ref-description"> + + <p>Slop granges for both strands, merging overlaps</p> + + </div> + + <pre class="usage"><span class='fu'>slop_fourways</span>(<span class='no'>granges</span>, <span class='kw'>leftstart</span> <span class='kw'>=</span> -<span class='fl'>22</span>, <span class='kw'>rightend</span> <span class='kw'>=</span> <span class='fl'>22</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>granges</th> + <td><p>GenomicRanges::GRanges</p></td> + </tr> + <tr> + <th>leftstart</th> + <td><p>numeric(1)</p></td> + </tr> + <tr> + <th>rightend</th> + <td><p>numeric(1)</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>logical(1)</p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>GenomicRanges::GRanges</p> + + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF_sites.bed'</span>, <span class='kw'>package</span> <span class='kw'>=</span> <span class='st'>'multicrispr'</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Mmusculus.UCSC.mm10</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Mmusculus.UCSC.mm10/man/package.html'>Mmusculus</a></span> +<span class='no'>granges</span> <span class='kw'><-</span> <span class='fu'><a href='read_bed.html'>read_bed</a></span>(<span class='no'>bedfile</span>, <span class='no'>bsgenome</span>)</div><div class='output co'>#> <span class='message'> Read C:/Users/abhagwa/Documents/multicrispr/inst/extdata/SRF_sites.bed</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='output co'>#> <span class='message'> 17 NT wide</span></div><div class='output co'>#> <span class='message'> 0 - 36535760 NT apart</span></div><div class='input'><span class='no'>granges</span></div><div class='output co'>#> GRanges object with 1974 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712627-4712643 - +#> [2] chr1 5250211-5250227 - +#> [3] chr1 5250451-5250467 - +#> [4] chr1 5256192-5256208 - +#> [5] chr1 5985727-5985743 - +#> ... ... ... ... +#> [1970] chrY 6770311-6770327 + +#> [1971] chrY 23130567-23130583 + +#> [1972] chrY 42512399-42512415 - +#> [1973] chrY 79048175-79048191 - +#> [1974] chrY 89126493-89126509 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'><span class='no'>granges</span> <span class='kw'>%>%</span> <span class='fu'>slop_fourways</span>()</div><div class='output co'>#> <span class='message'> Slop fourways</span></div><div class='output co'>#> <span class='message'> 1974 slopped granges: [start-22, end+22]</span></div><div class='output co'>#> <span class='message'> 3948 after adding strand-complements</span></div><div class='output co'>#> <span class='message'> 3932 after merging overlaps</span></div><div class='output co'>#> GRanges object with 3932 ranges and 0 metadata columns: +#> seqnames ranges strand +#> <Rle> <IRanges> <Rle> +#> [1] chr1 4712605-4712665 + +#> [2] chr1 5250189-5250249 + +#> [3] chr1 5250429-5250489 + +#> [4] chr1 5256170-5256230 + +#> [5] chr1 5985705-5985765 + +#> ... ... ... ... +#> [3928] chrY 6770289-6770349 - +#> [3929] chrY 23130545-23130605 - +#> [3930] chrY 42512377-42512437 - +#> [3931] chrY 79048153-79048213 - +#> [3932] chrY 89126471-89126531 - +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + + <li><a href="#value">Value</a></li> + + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat, Mette Bentsen, Jens Preussner, Mario Looso.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.3.0.9100.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/public/reference/up_flank-1.png b/public/reference/up_flank-1.png index eaa35d5026f855166aa90ad07c4779f55a496406..f9dffbd6790d848d615146ec4f3e0b2cdbb4e8c2 100644 Binary files a/public/reference/up_flank-1.png and b/public/reference/up_flank-1.png differ diff --git a/public/reference/up_flank-10.png b/public/reference/up_flank-10.png index dce3b23d23bf0aff313199dde51755db0a20a332..5ef1c0856f0916b664ad4476792f5440d7c9347c 100644 Binary files a/public/reference/up_flank-10.png and b/public/reference/up_flank-10.png differ diff --git a/public/reference/up_flank-2.png b/public/reference/up_flank-2.png index 25ff4a326917424bfa586cff7474369cf0308b3e..6470cd955d515ec6dd55ac90c01fde8b77a1faa2 100644 Binary files a/public/reference/up_flank-2.png and b/public/reference/up_flank-2.png differ diff --git a/public/reference/up_flank-3.png b/public/reference/up_flank-3.png index c1c1891621657d63853440fddc8b164ec0cd3ca1..c6982859478fb9a0c2b9e507f00597ef30ca81c7 100644 Binary files a/public/reference/up_flank-3.png and b/public/reference/up_flank-3.png differ diff --git a/public/reference/up_flank-4.png b/public/reference/up_flank-4.png index e979fd4f89fb70e57567dbe797381d60112c2a91..5593f9c3a362b66b924f2fe41a9b15f1cec3145a 100644 Binary files a/public/reference/up_flank-4.png and b/public/reference/up_flank-4.png differ diff --git a/public/reference/up_flank-5.png b/public/reference/up_flank-5.png index a80d5677b57f90a2f11f049467c53b260976d012..841a290675a994bf2caed4637b38578886cee6dc 100644 Binary files a/public/reference/up_flank-5.png and b/public/reference/up_flank-5.png differ diff --git a/public/reference/up_flank-6.png b/public/reference/up_flank-6.png index abb0d4160c65e31fb7230e19645062e566ceb1bb..6a10fc871a4ecc1529e23c8811b3602f49f5be0a 100644 Binary files a/public/reference/up_flank-6.png and b/public/reference/up_flank-6.png differ diff --git a/public/reference/up_flank-7.png b/public/reference/up_flank-7.png index 2fa9dd21011d9aa61c2a5d26172ac121a09e78f3..f7ac80ffc8c47fd48735082a7978c4c3f9ab887a 100644 Binary files a/public/reference/up_flank-7.png and b/public/reference/up_flank-7.png differ diff --git a/public/reference/up_flank-8.png b/public/reference/up_flank-8.png index 85e7b50706ee1502ae7cdde0011fc29f97a48c7f..c11f5fc7696e13354c3d9ec6c9f7a5c0c8b26d41 100644 Binary files a/public/reference/up_flank-8.png and b/public/reference/up_flank-8.png differ diff --git a/public/reference/up_flank-9.png b/public/reference/up_flank-9.png index c6c80e014606bca22659a65567fa34924823451c..2bab70f3f19b56d4a852977fed19b568c0b312fe 100644 Binary files a/public/reference/up_flank-9.png and b/public/reference/up_flank-9.png differ diff --git a/public/reference/up_flank.html b/public/reference/up_flank.html index 2dc71da6bf4e2d09e6a88b8bcf4604ca853c7ef4..a98a42950d395da4703ee8ee65edb1a23aa27f15 100644 --- a/public/reference/up_flank.html +++ b/public/reference/up_flank.html @@ -1,390 +1,390 @@ -<!-- Generated by pkgdown: do not edit by hand --> -<!DOCTYPE html> -<html lang="en"> - <head> - <meta charset="utf-8"> -<meta http-equiv="X-UA-Compatible" content="IE=edge"> -<meta name="viewport" content="width=device-width, initial-scale=1.0"> - -<title>Extend or Flank GRanges — up_flank • multicrispr</title> - - -<!-- jquery --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> -<!-- Bootstrap --> - -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> - -<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> - -<!-- Font Awesome icons --> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> -<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> - -<!-- clipboard.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> - -<!-- headroom.js --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> - -<!-- pkgdown --> -<link href="../pkgdown.css" rel="stylesheet"> -<script src="../pkgdown.js"></script> - - - - -<meta property="og:title" content="Extend or Flank GRanges — up_flank" /> -<meta property="og:description" content="Returns extensions, upstream flanks, or downstream flanks" /> -<meta name="twitter:card" content="summary" /> - - - - -<!-- mathjax --> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> -<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> - -<!--[if lt IE 9]> -<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> -<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> -<![endif]--> - - - - </head> - - <body> - <div class="container template-reference-topic"> - <header> - <div class="navbar navbar-default navbar-fixed-top" role="navigation"> - <div class="container"> - <div class="navbar-header"> - <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> - <span class="sr-only">Toggle navigation</span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - <span class="icon-bar"></span> - </button> - <span class="navbar-brand"> - <a class="navbar-link" href="../index.html">multicrispr</a> - <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> - </span> - </div> - - <div id="navbar" class="navbar-collapse collapse"> - <ul class="nav navbar-nav"> - <li> - <a href="../index.html"> - <span class="fas fa fas fa-home fa-lg"></span> - - </a> -</li> -<li> - <a href="../reference/index.html">Reference</a> -</li> -<li class="dropdown"> - <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> - Articles - - <span class="caret"></span> - </a> - <ul class="dropdown-menu" role="menu"> - <li> - <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> - </li> - </ul> -</li> - </ul> - <ul class="nav navbar-nav navbar-right"> - - </ul> - - </div><!--/.nav-collapse --> - </div><!--/.container --> -</div><!--/.navbar --> - - - - </header> - -<div class="row"> - <div class="col-md-9 contents"> - <div class="page-header"> - <h1>Extend or Flank GRanges</h1> - - <div class="hidden name"><code>up_flank.Rd</code></div> - </div> - - <div class="ref-description"> - <p>Returns extensions, upstream flanks, or downstream flanks</p> - </div> - - <pre class="usage"><span class='fu'>up_flank</span>( - <span class='no'>gr</span>, - <span class='kw'>start</span> <span class='kw'>=</span> -<span class='fl'>200</span>, - <span class='kw'>end</span> <span class='kw'>=</span> -<span class='fl'>1</span>, - <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, - <span class='no'>...</span> -) - -<span class='fu'>down_flank</span>( - <span class='no'>gr</span>, - <span class='kw'>start</span> <span class='kw'>=</span> <span class='fl'>1</span>, - <span class='kw'>end</span> <span class='kw'>=</span> <span class='fl'>200</span>, - <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, - <span class='no'>...</span> -) - -<span class='fu'>extend</span>( - <span class='no'>gr</span>, - <span class='kw'>start</span> <span class='kw'>=</span> -<span class='fl'>22</span>, - <span class='kw'>end</span> <span class='kw'>=</span> <span class='fl'>22</span>, - <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, - <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, - <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, - <span class='no'>...</span> -)</pre> - - <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> - <table class="ref-arguments"> - <colgroup><col class="name" /><col class="desc" /></colgroup> - <tr> - <th>gr</th> - <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> - </tr> - <tr> - <th>start</th> - <td><p>(pos or neg) number: relative start position (see details)</p></td> - </tr> - <tr> - <th>end</th> - <td><p>(pos or neg) number: relative end position (see details)</p></td> - </tr> - <tr> - <th>strandaware</th> - <td><p>TRUE (default) or FALSE: consider strand information?</p></td> - </tr> - <tr> - <th>bsgenome</th> - <td><p>NULL (default) or <code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code>. -Required to update gr$seq if present.</p></td> - </tr> - <tr> - <th>verbose</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - <tr> - <th>plot</th> - <td><p>TRUE or FALSE (default)</p></td> - </tr> - <tr> - <th>linetype_var</th> - <td><p>string: gr var mapped to linetype</p></td> - </tr> - <tr> - <th>...</th> - <td><p>passed to <code><a href='plot_intervals.html'>plot_intervals</a></code></p></td> - </tr> - </table> - - <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> - - <p>a <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> - <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> - - <p><code>up_flank</code> returns upstream flanks, in relation to start(gr). -<code>down_flank</code> returns downstream flanks, in relation to end(gr). -<code>extend</code> returns extensions, in relation to start(gr) and end(gr)</p> - - <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> - <pre class="examples"><div class='input'><span class='co'># PE example</span> -<span class='co'>#-----------</span> -<span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) -<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> -<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> - <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> - <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> - <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>),<span class='co'># ins</span> - <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='no'>bsgenome</span>) -<span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>up_flank</span>( -<span class='fl'>22</span>, -<span class='fl'>1</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>facet_var</span><span class='kw'>=</span><span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>'targetname'</span>, <span class='st'>'seqnames'</span>))</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699578-4699599 + | PRNP 4699600 4699600 -#> HBB chr11 5227003-5227024 - | HBB 5227002 5227002 -#> HEXA chr15 72346584-72346605 - | HEXA 72346580 72346583 -#> CFTR chr7 117559571-117559592 + | CFTR 117559593 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>up_flank</span>( -<span class='fl'>22</span>, -<span class='fl'>1</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>strandaware</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699578-4699599 + | PRNP 4699600 4699600 -#> HBB chr11 5226980-5227001 - | HBB 5227002 5227002 -#> HEXA chr15 72346558-72346579 - | HEXA 72346580 72346583 -#> CFTR chr7 117559571-117559592 + | CFTR 117559593 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>down_flank</span>(+<span class='fl'>1</span>, +<span class='fl'>22</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-3.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699601-4699622 + | PRNP 4699600 4699600 -#> HBB chr11 5226980-5227001 - | HBB 5227002 5227002 -#> HEXA chr15 72346558-72346579 - | HEXA 72346580 72346583 -#> CFTR chr7 117559596-117559617 + | CFTR 117559593 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>down_flank</span>(+<span class='fl'>1</span>, +<span class='fl'>22</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>strandaware</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-4.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699601-4699622 + | PRNP 4699600 4699600 -#> HBB chr11 5227003-5227024 - | HBB 5227002 5227002 -#> HEXA chr15 72346584-72346605 - | HEXA 72346580 72346583 -#> CFTR chr7 117559596-117559617 + | CFTR 117559593 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>extend</span>( -<span class='fl'>10</span>, +<span class='fl'>20</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-5.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699590-4699620 + | PRNP 4699600 4699600 -#> HBB chr11 5226982-5227012 - | HBB 5227002 5227002 -#> HEXA chr15 72346560-72346593 - | HEXA 72346580 72346583 -#> CFTR chr7 117559583-117559615 + | CFTR 117559593 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>extend</span>( -<span class='fl'>10</span>, +<span class='fl'>20</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>strandaware</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-6.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: -#> seqnames ranges strand | targetname targetstart targetend -#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> -#> PRNP chr20 4699590-4699620 + | PRNP 4699600 4699600 -#> HBB chr11 5226992-5227022 - | HBB 5227002 5227002 -#> HEXA chr15 72346570-72346603 - | HEXA 72346580 72346583 -#> CFTR chr7 117559583-117559615 + | CFTR 117559593 117559595 -#> ------- -#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> -<span class='co'># TFBS example</span> -<span class='co'>#-------------</span> - <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) - <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='up_flank-7.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>extend</span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-8.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: -#> seqnames ranges strand | name score targetname -#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> -#> T0001 chr1 4712606-4712665 - | SRF_MA0083.3 10.49542 T0001 -#> T0002 chr1 5250190-5250249 - | SRF_MA0083.3 9.7378 T0002 -#> T0003 chr1 5250430-5250489 - | SRF_MA0083.3 5.92033 T0003 -#> T0004 chr1 5256171-5256230 - | SRF_MA0083.3 9.7378 T0004 -#> T0005 chr1 5985706-5985765 - | SRF_MA0083.3 9.44821 T0005 -#> ... ... ... ... . ... ... ... -#> T1970 chrY 6770290-6770349 + | SRF_MA0083.3 9.7378 T1970 -#> T1971 chrY 23130546-23130605 + | SRF_MA0083.3 9.7378 T1971 -#> T1972 chrY 42512378-42512437 - | SRF_MA0083.3 6.59053 T1972 -#> T1973 chrY 79048154-79048213 - | SRF_MA0083.3 9.7378 T1973 -#> T1974 chrY 89126472-89126531 - | SRF_MA0083.3 4.54393 T1974 -#> targetstart targetend -#> <integer> <integer> -#> T0001 4712628 4712643 -#> T0002 5250212 5250227 -#> T0003 5250452 5250467 -#> T0004 5256193 5256208 -#> T0005 5985728 5985743 -#> ... ... ... -#> T1970 6770312 6770327 -#> T1971 23130568 23130583 -#> T1972 42512400 42512415 -#> T1973 79048176 79048191 -#> T1974 89126494 89126509 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> <span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>up_flank</span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-9.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: -#> seqnames ranges strand | name score targetname -#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> -#> T0001 chr1 4712644-4712843 - | SRF_MA0083.3 10.49542 T0001 -#> T0002 chr1 5250228-5250427 - | SRF_MA0083.3 9.7378 T0002 -#> T0003 chr1 5250468-5250667 - | SRF_MA0083.3 5.92033 T0003 -#> T0004 chr1 5256209-5256408 - | SRF_MA0083.3 9.7378 T0004 -#> T0005 chr1 5985744-5985943 - | SRF_MA0083.3 9.44821 T0005 -#> ... ... ... ... . ... ... ... -#> T1970 chrY 6770112-6770311 + | SRF_MA0083.3 9.7378 T1970 -#> T1971 chrY 23130368-23130567 + | SRF_MA0083.3 9.7378 T1971 -#> T1972 chrY 42512416-42512615 - | SRF_MA0083.3 6.59053 T1972 -#> T1973 chrY 79048192-79048391 - | SRF_MA0083.3 9.7378 T1973 -#> T1974 chrY 89126510-89126709 - | SRF_MA0083.3 4.54393 T1974 -#> targetstart targetend -#> <integer> <integer> -#> T0001 4712628 4712643 -#> T0002 5250212 5250227 -#> T0003 5250452 5250467 -#> T0004 5256193 5256208 -#> T0005 5985728 5985743 -#> ... ... ... -#> T1970 6770312 6770327 -#> T1971 23130568 23130583 -#> T1972 42512400 42512415 -#> T1973 79048176 79048191 -#> T1974 89126494 89126509 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> <span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>down_flank</span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-10.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: -#> seqnames ranges strand | name score targetname -#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> -#> T0001 chr1 4712428-4712627 - | SRF_MA0083.3 10.49542 T0001 -#> T0002 chr1 5250012-5250211 - | SRF_MA0083.3 9.7378 T0002 -#> T0003 chr1 5250252-5250451 - | SRF_MA0083.3 5.92033 T0003 -#> T0004 chr1 5255993-5256192 - | SRF_MA0083.3 9.7378 T0004 -#> T0005 chr1 5985528-5985727 - | SRF_MA0083.3 9.44821 T0005 -#> ... ... ... ... . ... ... ... -#> T1970 chrY 6770328-6770527 + | SRF_MA0083.3 9.7378 T1970 -#> T1971 chrY 23130584-23130783 + | SRF_MA0083.3 9.7378 T1971 -#> T1972 chrY 42512200-42512399 - | SRF_MA0083.3 6.59053 T1972 -#> T1973 chrY 79047976-79048175 - | SRF_MA0083.3 9.7378 T1973 -#> T1974 chrY 89126294-89126493 - | SRF_MA0083.3 4.54393 T1974 -#> targetstart targetend -#> <integer> <integer> -#> T0001 4712628 4712643 -#> T0002 5250212 5250227 -#> T0003 5250452 5250467 -#> T0004 5256193 5256208 -#> T0005 5985728 5985743 -#> ... ... ... -#> T1970 6770312 6770327 -#> T1971 23130568 23130583 -#> T1972 42512400 42512415 -#> T1973 79048176 79048191 -#> T1974 89126494 89126509 -#> ------- -#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> - </div> - <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> - <h2>Contents</h2> - <ul class="nav nav-pills nav-stacked"> - <li><a href="#arguments">Arguments</a></li> - <li><a href="#value">Value</a></li> - <li><a href="#details">Details</a></li> - <li><a href="#examples">Examples</a></li> - </ul> - - </div> -</div> - - - <footer> - <div class="copyright"> - <p>Developed by Aditya Bhagwat.</p> -</div> - -<div class="pkgdown"> - <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> -</div> - - </footer> - </div> - - - - - </body> -</html> - - +<!-- Generated by pkgdown: do not edit by hand --> +<!DOCTYPE html> +<html lang="en"> + <head> + <meta charset="utf-8"> +<meta http-equiv="X-UA-Compatible" content="IE=edge"> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> + +<title>Extend or Flank GRanges — up_flank • multicrispr</title> + + +<!-- jquery --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script> +<!-- Bootstrap --> + +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha256-916EbMg70RQy9LHiGkXzG8hSg9EdNy97GazNG/aiY1w=" crossorigin="anonymous" /> + +<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha256-U5ZEeKfGNOja007MMD3YBI0A3OSZOQbeG6z2f2Y0hu8=" crossorigin="anonymous"></script> + +<!-- Font Awesome icons --> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/all.min.css" integrity="sha256-nAmazAk6vS34Xqo0BSrTb+abbtFlgsFK7NKSi6o7Y78=" crossorigin="anonymous" /> +<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.7.1/css/v4-shims.min.css" integrity="sha256-6qHlizsOWFskGlwVOKuns+D1nB6ssZrHQrNj1wGplHc=" crossorigin="anonymous" /> + +<!-- clipboard.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.4/clipboard.min.js" integrity="sha256-FiZwavyI2V6+EXO1U+xzLG3IKldpiTFf3153ea9zikQ=" crossorigin="anonymous"></script> + +<!-- headroom.js --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/headroom.min.js" integrity="sha256-DJFC1kqIhelURkuza0AvYal5RxMtpzLjFhsnVIeuk+U=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.9.4/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script> + +<!-- pkgdown --> +<link href="../pkgdown.css" rel="stylesheet"> +<script src="../pkgdown.js"></script> + + + + +<meta property="og:title" content="Extend or Flank GRanges — up_flank" /> +<meta property="og:description" content="Returns extensions, upstream flanks, or downstream flanks" /> +<meta name="twitter:card" content="summary" /> + + + + +<!-- mathjax --> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script> + +<!--[if lt IE 9]> +<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script> +<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> +<![endif]--> + + + + </head> + + <body> + <div class="container template-reference-topic"> + <header> + <div class="navbar navbar-default navbar-fixed-top" role="navigation"> + <div class="container"> + <div class="navbar-header"> + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false"> + <span class="sr-only">Toggle navigation</span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + <span class="icon-bar"></span> + </button> + <span class="navbar-brand"> + <a class="navbar-link" href="../index.html">multicrispr</a> + <span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">0.1.0</span> + </span> + </div> + + <div id="navbar" class="navbar-collapse collapse"> + <ul class="nav navbar-nav"> + <li> + <a href="../index.html"> + <span class="fas fa fas fa-home fa-lg"></span> + + </a> +</li> +<li> + <a href="../reference/index.html">Reference</a> +</li> +<li class="dropdown"> + <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false"> + Articles + + <span class="caret"></span> + </a> + <ul class="dropdown-menu" role="menu"> + <li> + <a href="../articles/designing_grna_libraries.html">Using multicrispr for gRNA design</a> + </li> + </ul> +</li> + </ul> + <ul class="nav navbar-nav navbar-right"> + + </ul> + + </div><!--/.nav-collapse --> + </div><!--/.container --> +</div><!--/.navbar --> + + + + </header> + +<div class="row"> + <div class="col-md-9 contents"> + <div class="page-header"> + <h1>Extend or Flank GRanges</h1> + + <div class="hidden name"><code>up_flank.Rd</code></div> + </div> + + <div class="ref-description"> + <p>Returns extensions, upstream flanks, or downstream flanks</p> + </div> + + <pre class="usage"><span class='fu'>up_flank</span>( + <span class='no'>gr</span>, + <span class='kw'>start</span> <span class='kw'>=</span> -<span class='fl'>200</span>, + <span class='kw'>end</span> <span class='kw'>=</span> -<span class='fl'>1</span>, + <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, + <span class='no'>...</span> +) + +<span class='fu'>down_flank</span>( + <span class='no'>gr</span>, + <span class='kw'>start</span> <span class='kw'>=</span> <span class='fl'>1</span>, + <span class='kw'>end</span> <span class='kw'>=</span> <span class='fl'>200</span>, + <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, + <span class='no'>...</span> +) + +<span class='fu'>extend</span>( + <span class='no'>gr</span>, + <span class='kw'>start</span> <span class='kw'>=</span> -<span class='fl'>22</span>, + <span class='kw'>end</span> <span class='kw'>=</span> <span class='fl'>22</span>, + <span class='kw'>strandaware</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>, + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='kw'>NULL</span>, + <span class='kw'>verbose</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>FALSE</span>, + <span class='kw'>linetype_var</span> <span class='kw'>=</span> <span class='st'>"set"</span>, + <span class='no'>...</span> +)</pre> + + <h2 class="hasAnchor" id="arguments"><a class="anchor" href="#arguments"></a>Arguments</h2> + <table class="ref-arguments"> + <colgroup><col class="name" /><col class="desc" /></colgroup> + <tr> + <th>gr</th> + <td><p><code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p></td> + </tr> + <tr> + <th>start</th> + <td><p>(pos or neg) number: relative start position (see details)</p></td> + </tr> + <tr> + <th>end</th> + <td><p>(pos or neg) number: relative end position (see details)</p></td> + </tr> + <tr> + <th>strandaware</th> + <td><p>TRUE (default) or FALSE: consider strand information?</p></td> + </tr> + <tr> + <th>bsgenome</th> + <td><p>NULL (default) or <code><a href='https://rdrr.io/pkg/BSgenome/man/BSgenome-class.html'>BSgenome-class</a></code>. +Required to update gr$seq if present.</p></td> + </tr> + <tr> + <th>verbose</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + <tr> + <th>plot</th> + <td><p>TRUE or FALSE (default)</p></td> + </tr> + <tr> + <th>linetype_var</th> + <td><p>string: gr var mapped to linetype</p></td> + </tr> + <tr> + <th>...</th> + <td><p>passed to <code><a href='plot_intervals.html'>plot_intervals</a></code></p></td> + </tr> + </table> + + <h2 class="hasAnchor" id="value"><a class="anchor" href="#value"></a>Value</h2> + + <p>a <code><a href='https://rdrr.io/pkg/GenomicRanges/man/GRanges-class.html'>GRanges-class</a></code></p> + <h2 class="hasAnchor" id="details"><a class="anchor" href="#details"></a>Details</h2> + + <p><code>up_flank</code> returns upstream flanks, in relation to start(gr). +<code>down_flank</code> returns downstream flanks, in relation to end(gr). +<code>extend</code> returns extensions, in relation to start(gr) and end(gr)</p> + + <h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2> + <pre class="examples"><div class='input'><span class='co'># PE example</span> +<span class='co'>#-----------</span> +<span class='fu'><a href='https://rdrr.io/r/base/library.html'>require</a></span>(<span class='no'>magrittr</span>) +<span class='no'>bsgenome</span> <span class='kw'><-</span> <span class='kw pkg'>BSgenome.Hsapiens.UCSC.hg38</span><span class='kw ns'>::</span><span class='no'><a href='https://rdrr.io/pkg/BSgenome.Hsapiens.UCSC.hg38/man/package.html'>BSgenome.Hsapiens.UCSC.hg38</a></span> +<span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='char_to_granges.html'>char_to_granges</a></span>(<span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='kw'>PRNP</span> <span class='kw'>=</span> <span class='st'>'chr20:4699600:+'</span>, <span class='co'># snp</span> + <span class='kw'>HBB</span> <span class='kw'>=</span> <span class='st'>'chr11:5227002:-'</span>, <span class='co'># snp</span> + <span class='kw'>HEXA</span> <span class='kw'>=</span> <span class='st'>'chr15:72346580-72346583:-'</span>, <span class='co'># del</span> + <span class='kw'>CFTR</span> <span class='kw'>=</span> <span class='st'>'chr7:117559593-117559595:+'</span>),<span class='co'># ins</span> + <span class='kw'>bsgenome</span> <span class='kw'>=</span> <span class='no'>bsgenome</span>) +<span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>up_flank</span>( -<span class='fl'>22</span>, -<span class='fl'>1</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>facet_var</span><span class='kw'>=</span><span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span>(<span class='st'>'targetname'</span>, <span class='st'>'seqnames'</span>))</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-1.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699578-4699599 + | PRNP 4699600 4699600 +#> HBB chr11 5227003-5227024 - | HBB 5227002 5227002 +#> HEXA chr15 72346584-72346605 - | HEXA 72346580 72346583 +#> CFTR chr7 117559571-117559592 + | CFTR 117559593 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>up_flank</span>( -<span class='fl'>22</span>, -<span class='fl'>1</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>strandaware</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-2.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699578-4699599 + | PRNP 4699600 4699600 +#> HBB chr11 5226980-5227001 - | HBB 5227002 5227002 +#> HEXA chr15 72346558-72346579 - | HEXA 72346580 72346583 +#> CFTR chr7 117559571-117559592 + | CFTR 117559593 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>down_flank</span>(+<span class='fl'>1</span>, +<span class='fl'>22</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-3.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699601-4699622 + | PRNP 4699600 4699600 +#> HBB chr11 5226980-5227001 - | HBB 5227002 5227002 +#> HEXA chr15 72346558-72346579 - | HEXA 72346580 72346583 +#> CFTR chr7 117559596-117559617 + | CFTR 117559593 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>down_flank</span>(+<span class='fl'>1</span>, +<span class='fl'>22</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>strandaware</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-4.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699601-4699622 + | PRNP 4699600 4699600 +#> HBB chr11 5227003-5227024 - | HBB 5227002 5227002 +#> HEXA chr15 72346584-72346605 - | HEXA 72346580 72346583 +#> CFTR chr7 117559596-117559617 + | CFTR 117559593 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>extend</span>( -<span class='fl'>10</span>, +<span class='fl'>20</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-5.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699590-4699620 + | PRNP 4699600 4699600 +#> HBB chr11 5226982-5227012 - | HBB 5227002 5227002 +#> HEXA chr15 72346560-72346593 - | HEXA 72346580 72346583 +#> CFTR chr7 117559583-117559615 + | CFTR 117559593 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'><span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>extend</span>( -<span class='fl'>10</span>, +<span class='fl'>20</span>, <span class='kw'>plot</span><span class='kw'>=</span><span class='fl'>TRUE</span>, <span class='kw'>strandaware</span><span class='kw'>=</span><span class='fl'>FALSE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-6.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 4 ranges and 3 metadata columns: +#> seqnames ranges strand | targetname targetstart targetend +#> <Rle> <IRanges> <Rle> | <character> <integer> <integer> +#> PRNP chr20 4699590-4699620 + | PRNP 4699600 4699600 +#> HBB chr11 5226992-5227022 - | HBB 5227002 5227002 +#> HEXA chr15 72346570-72346603 - | HEXA 72346580 72346583 +#> CFTR chr7 117559583-117559615 + | CFTR 117559593 117559595 +#> ------- +#> seqinfo: 455 sequences (1 circular) from hg38 genome</div><div class='input'> +<span class='co'># TFBS example</span> +<span class='co'>#-------------</span> + <span class='no'>bedfile</span> <span class='kw'><-</span> <span class='fu'><a href='https://rdrr.io/r/base/system.file.html'>system.file</a></span>(<span class='st'>'extdata/SRF.bed'</span>, <span class='kw'>package</span><span class='kw'>=</span><span class='st'>'multicrispr'</span>) + <span class='no'>gr</span> <span class='kw'><-</span> <span class='fu'><a href='bed_to_granges.html'>bed_to_granges</a></span>(<span class='no'>bedfile</span>, <span class='kw'>genome</span> <span class='kw'>=</span> <span class='st'>'mm10'</span>)</div><div class='output co'>#> <span class='message'> Read SRF.bed into GRanges</span></div><div class='output co'>#> <span class='message'> 1974 ranges on 21 chromosomes</span></div><div class='img'><img src='up_flank-7.png' alt='' width='700' height='433' /></div><div class='input'> <span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>extend</span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-8.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: +#> seqnames ranges strand | name score targetname +#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> +#> T0001 chr1 4712606-4712665 - | SRF_MA0083.3 10.49542 T0001 +#> T0002 chr1 5250190-5250249 - | SRF_MA0083.3 9.7378 T0002 +#> T0003 chr1 5250430-5250489 - | SRF_MA0083.3 5.92033 T0003 +#> T0004 chr1 5256171-5256230 - | SRF_MA0083.3 9.7378 T0004 +#> T0005 chr1 5985706-5985765 - | SRF_MA0083.3 9.44821 T0005 +#> ... ... ... ... . ... ... ... +#> T1970 chrY 6770290-6770349 + | SRF_MA0083.3 9.7378 T1970 +#> T1971 chrY 23130546-23130605 + | SRF_MA0083.3 9.7378 T1971 +#> T1972 chrY 42512378-42512437 - | SRF_MA0083.3 6.59053 T1972 +#> T1973 chrY 79048154-79048213 - | SRF_MA0083.3 9.7378 T1973 +#> T1974 chrY 89126472-89126531 - | SRF_MA0083.3 4.54393 T1974 +#> targetstart targetend +#> <integer> <integer> +#> T0001 4712628 4712643 +#> T0002 5250212 5250227 +#> T0003 5250452 5250467 +#> T0004 5256193 5256208 +#> T0005 5985728 5985743 +#> ... ... ... +#> T1970 6770312 6770327 +#> T1971 23130568 23130583 +#> T1972 42512400 42512415 +#> T1973 79048176 79048191 +#> T1974 89126494 89126509 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> <span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>up_flank</span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-9.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: +#> seqnames ranges strand | name score targetname +#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> +#> T0001 chr1 4712644-4712843 - | SRF_MA0083.3 10.49542 T0001 +#> T0002 chr1 5250228-5250427 - | SRF_MA0083.3 9.7378 T0002 +#> T0003 chr1 5250468-5250667 - | SRF_MA0083.3 5.92033 T0003 +#> T0004 chr1 5256209-5256408 - | SRF_MA0083.3 9.7378 T0004 +#> T0005 chr1 5985744-5985943 - | SRF_MA0083.3 9.44821 T0005 +#> ... ... ... ... . ... ... ... +#> T1970 chrY 6770112-6770311 + | SRF_MA0083.3 9.7378 T1970 +#> T1971 chrY 23130368-23130567 + | SRF_MA0083.3 9.7378 T1971 +#> T1972 chrY 42512416-42512615 - | SRF_MA0083.3 6.59053 T1972 +#> T1973 chrY 79048192-79048391 - | SRF_MA0083.3 9.7378 T1973 +#> T1974 chrY 89126510-89126709 - | SRF_MA0083.3 4.54393 T1974 +#> targetstart targetend +#> <integer> <integer> +#> T0001 4712628 4712643 +#> T0002 5250212 5250227 +#> T0003 5250452 5250467 +#> T0004 5256193 5256208 +#> T0005 5985728 5985743 +#> ... ... ... +#> T1970 6770312 6770327 +#> T1971 23130568 23130583 +#> T1972 42512400 42512415 +#> T1973 79048176 79048191 +#> T1974 89126494 89126509 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div><div class='input'> <span class='no'>gr</span> <span class='kw'>%>%</span> <span class='fu'>down_flank</span>(<span class='kw'>plot</span> <span class='kw'>=</span> <span class='fl'>TRUE</span>)</div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='output co'>#> <span class='warning'>Warning: Zeichenbreite unbekannt für das Zeichen 0x9</span></div><div class='img'><img src='up_flank-10.png' alt='' width='700' height='433' /></div><div class='output co'>#> GRanges object with 1974 ranges and 5 metadata columns: +#> seqnames ranges strand | name score targetname +#> <Rle> <IRanges> <Rle> | <character> <numeric> <character> +#> T0001 chr1 4712428-4712627 - | SRF_MA0083.3 10.49542 T0001 +#> T0002 chr1 5250012-5250211 - | SRF_MA0083.3 9.7378 T0002 +#> T0003 chr1 5250252-5250451 - | SRF_MA0083.3 5.92033 T0003 +#> T0004 chr1 5255993-5256192 - | SRF_MA0083.3 9.7378 T0004 +#> T0005 chr1 5985528-5985727 - | SRF_MA0083.3 9.44821 T0005 +#> ... ... ... ... . ... ... ... +#> T1970 chrY 6770328-6770527 + | SRF_MA0083.3 9.7378 T1970 +#> T1971 chrY 23130584-23130783 + | SRF_MA0083.3 9.7378 T1971 +#> T1972 chrY 42512200-42512399 - | SRF_MA0083.3 6.59053 T1972 +#> T1973 chrY 79047976-79048175 - | SRF_MA0083.3 9.7378 T1973 +#> T1974 chrY 89126294-89126493 - | SRF_MA0083.3 4.54393 T1974 +#> targetstart targetend +#> <integer> <integer> +#> T0001 4712628 4712643 +#> T0002 5250212 5250227 +#> T0003 5250452 5250467 +#> T0004 5256193 5256208 +#> T0005 5985728 5985743 +#> ... ... ... +#> T1970 6770312 6770327 +#> T1971 23130568 23130583 +#> T1972 42512400 42512415 +#> T1973 79048176 79048191 +#> T1974 89126494 89126509 +#> ------- +#> seqinfo: 66 sequences (1 circular) from mm10 genome</div></pre> + </div> + <div class="col-md-3 hidden-xs hidden-sm" id="sidebar"> + <h2>Contents</h2> + <ul class="nav nav-pills nav-stacked"> + <li><a href="#arguments">Arguments</a></li> + <li><a href="#value">Value</a></li> + <li><a href="#details">Details</a></li> + <li><a href="#examples">Examples</a></li> + </ul> + + </div> +</div> + + + <footer> + <div class="copyright"> + <p>Developed by Aditya Bhagwat.</p> +</div> + +<div class="pkgdown"> + <p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.4.1.</p> +</div> + + </footer> + </div> + + + + + </body> +</html> + + diff --git a/tests/testthat.R b/tests/testthat.R index f9f8d8980c49ffb69b0792a09023ea65f0994ef1..c367e48cf756162c0ee5fdc4b126b75b72660fed 100644 --- a/tests/testthat.R +++ b/tests/testthat.R @@ -1,4 +1,4 @@ -library(testthat) -library(multicrispr) - -test_check("multicrispr") +library(testthat) +library(multicrispr) + +test_check("multicrispr") diff --git a/tests/testthat/test_extend.R b/tests/testthat/test_extend.R index 022bf147ac32a2bcc637335f6042bca84c1c0d5e..4de6613411dc27b9d6a5614cbaed4bf0b4942539 100644 --- a/tests/testthat/test_extend.R +++ b/tests/testthat/test_extend.R @@ -1,27 +1,27 @@ -# Create example granges -bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -granges <- GenomicRanges::GRanges('chr1', - '100-200', - strand = '-', - seqinfo = seqinfo(bsgenome)) -chrlength <- GenomeInfoDb::seqlengths(bsgenome)[['chr1']] - -# Test -context('extend') - -test_that('extend works', { - expect_equal( - start(extend(granges, -5, 5)), - start(granges) - 5) - expect_equal( - end(extend(granges, -5, 5)), - end(granges) + 5) -}) - -test_that('extend warns for coordinates < 1', { - expect_warning(extend(granges, -500)) -}) - -test_that('extend warns for coordinates > chrlength', { - expect_warning(extend(granges, 1, 1 + chrlength, plot = FALSE)) -}) +# Create example granges +bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +granges <- GenomicRanges::GRanges('chr1', + '100-200', + strand = '-', + seqinfo = seqinfo(bsgenome)) +chrlength <- GenomeInfoDb::seqlengths(bsgenome)[['chr1']] + +# Test +context('extend') + +test_that('extend works', { + expect_equal( + start(extend(granges, -5, 5)), + start(granges) - 5) + expect_equal( + end(extend(granges, -5, 5)), + end(granges) + 5) +}) + +test_that('extend warns for coordinates < 1', { + expect_warning(extend(granges, -500)) +}) + +test_that('extend warns for coordinates > chrlength', { + expect_warning(extend(granges, 1, 1 + chrlength, plot = FALSE)) +}) diff --git a/tests/testthat/test_flank.R b/tests/testthat/test_flank.R index a318ea2e052b30bc88a761766017466f6cb9c7f3..46ef2fdbf798219bb1b91dd0bb1ded3c08583540 100644 --- a/tests/testthat/test_flank.R +++ b/tests/testthat/test_flank.R @@ -1,51 +1,51 @@ - -# Create example granges -bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 -granges <- GenomicRanges::GRanges( - 'chr1', '100-200', strand = '-', targetname = 'T01', - seqinfo = seqinfo(bsgenome)) -chrlength <- GenomeInfoDb::seqlengths(bsgenome)[['chr1']] - -# Test -context('up_flank and down_flank') - -test_that('up_flank works', { - expect_equal( - start( up_flank(granges, -10, -1)), - end(granges) + 1 ) - - expect_equal( - end( up_flank(granges, -10, -1)), - end(granges) + 10 ) -}) - -test_that('down_flank works', { - expect_equal( - start( down_flank(granges, 1, 10)), - start(granges) - 10) - - expect_equal( - end( down_flank(granges, 1, 10)), - start(granges) - 1) -}) - -test_that('up_flank throws error for coordinates < 1', { - expect_error( - up_flank(granges, +500)) -}) - -test_that('down_flank warns error for coordinates < 1', { - expect_warning( - down_flank(granges, -500)) -}) - -test_that('up_flank warns for coordinates > chrlength', { - expect_warning( - up_flank( granges, 1, 1 + chrlength)) -}) - -test_that('down_flank warns for coordinates > chrlength', { - expect_warning( - down_flank(granges, 1, 1 + chrlength)) -}) - + +# Create example granges +bsgenome <- BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10 +granges <- GenomicRanges::GRanges( + 'chr1', '100-200', strand = '-', targetname = 'T01', + seqinfo = seqinfo(bsgenome)) +chrlength <- GenomeInfoDb::seqlengths(bsgenome)[['chr1']] + +# Test +context('up_flank and down_flank') + +test_that('up_flank works', { + expect_equal( + start( up_flank(granges, -10, -1)), + end(granges) + 1 ) + + expect_equal( + end( up_flank(granges, -10, -1)), + end(granges) + 10 ) +}) + +test_that('down_flank works', { + expect_equal( + start( down_flank(granges, 1, 10)), + start(granges) - 10) + + expect_equal( + end( down_flank(granges, 1, 10)), + start(granges) - 1) +}) + +test_that('up_flank throws error for coordinates < 1', { + expect_error( + up_flank(granges, +500)) +}) + +test_that('down_flank warns error for coordinates < 1', { + expect_warning( + down_flank(granges, -500)) +}) + +test_that('up_flank warns for coordinates > chrlength', { + expect_warning( + up_flank( granges, 1, 1 + chrlength)) +}) + +test_that('down_flank warns for coordinates > chrlength', { + expect_warning( + down_flank(granges, 1, 1 + chrlength)) +}) + diff --git a/tests/testthat/test_read.R b/tests/testthat/test_read.R index 7f7cea287fd9b482f1c11b5dcf38b0fd20e86a95..daff9ede3690d76adc6a32895bad686ec455c611 100644 --- a/tests/testthat/test_read.R +++ b/tests/testthat/test_read.R @@ -1,7 +1,7 @@ - - -context('bed_to_granges') -test_that('bed_to_granges returns a GRanges', { - bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') - expect_s4_class(bed_to_granges(bedfile, 'mm10', plot = FALSE), 'GRanges') -}) + + +context('bed_to_granges') +test_that('bed_to_granges returns a GRanges', { + bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') + expect_s4_class(bed_to_granges(bedfile, 'mm10', plot = FALSE), 'GRanges') +}) diff --git a/vignettes/designing_grna_libraries.Rmd b/vignettes/designing_grna_libraries.Rmd index 476ad64ec878efed6609783a9aca73542cd3906d..f9556d78349b01920eb266f1dcc67e4f808ae4de 100644 --- a/vignettes/designing_grna_libraries.Rmd +++ b/vignettes/designing_grna_libraries.Rmd @@ -1,231 +1,231 @@ ---- -title: "Using multicrispr for gRNA design" -author: "Aditya M Bhagwat" -date: "`r Sys.Date()`" -output: BiocStyle::html_document -vignette: > - %\VignetteIndexEntry{designing_grna_libraries} - %\VignetteEngine{knitr::rmarkdown} - %\VignetteEncoding{UTF-8} ---- - -```{r, include=TRUE, echo=FALSE, message=FALSE} -knitr::opts_chunk$set(echo = TRUE, collapse = TRUE, cache = FALSE) -#str(knitr::opts_chunk$get()) -``` - -<!--  --> - -# Background - -## Crispr/Cas9 and Prime Editing - -**Crispr/Cas9** is a prokaryotic immune system turned into a genome engineering tool, with a Cas9/gRNA complex at the heart of its functioning. The **gRNA** (guide RNA) contains a 20 nucleotide (proto)**spacer** which guides the complex to a genomic locus with identical sequence, but only when followed by an *NGG* **PAM** (protospacer adjacent motif (see Figure 1A). The **Cas9** enzyme performs some effector action at that locus: *wildtype Cas9* cuts both strands after spacer nucleotide 17, *Cas9Nickase* cuts only a single strand (two variants exist, cutting respectively each of the strands), while catalytically dead *dCas9*, fused to some effector domain (KRAB, VPR, APEX) performs some alternative action (e.g. KRAB represses, VPR activates, APEX biotinylates). - -**Prime Editing** (Anzalone et al., 2019) extends this further, by coupling Cas9 to a Reverse Transcriptase (RT). As shown in Figure 1, the guide RNA is extended with a 3' extension that contains primer binding site (binding a complementary DNA region that acts as a primer for reverse transcription) and reverse transcription template (the template used for reverse transcription). The spacer still acts as targeting agent, guiding the Cas9/RT complex to targeted genomic locus. - - -```{r, fig.small = TRUE, echo = FALSE, fig.cap = 'gRNAs for Crispr/Cas9 (A) and Prime Editing'} -knitr::include_graphics("../inst/extdata/pe.png") -``` - - -## Guide RNA design - -**Guide RNA design** involves finding good guide RNAs to hit the targets of interest. Plasmids with guide RNA scaffolds, ready for cloning desired spacers into, can be readily ordered from AddGene. The actual task, therefore, boils down to finding good spacers for the targets of interest. For prime editing, it additionally involves finding appropriate primer binding site and reverse transcription template to edit the target site of interest. - -A **good spacer** needs to fulfill two requirements. - -1. **Minimal off-target** (mis)matches, so that only intended targets are hit. - - - Crispr gRNAs can hit exact (with identical and alternate NGG pam), as well as (up-to 2) mismatch offtargets. - - Prime Editing is much more specific, hitting only exact offtargets. - -2. **Maximal on-target** efficiency. Over the years, several sequence-to-efficiency prediction models have been developed, of which the Doench 2016 score has currently become the community standard. The score is not perfect, and examples can be found where the prediction and the actual outcome differ. Yet, to-date it is the best heuristic to predict on-target efficiency, worth making use of. - - -# Multicrispr - -Multicrispr was developed to make guide RNA design easier. As shown below, it contains functions to **define** and **transform** targets, **find spacers**, compute/add **offtarget counts** and **efficiency scores** (Doench 2016), and finally return all of this as a **GRanges** object. - -```{r overview, fig.wide = TRUE, out.width = "80%", echo = FALSE } -knitr::include_graphics("../inst/extdata/readme_portrait.png") -``` - -## Install - - -Installing **multicrispr** is simple: - -```{r, eval = FALSE} -url <- 'https://gitlab.gwdg.de/loosolab/software/multicrispr.git' -remotes::install_git(url, repos = BiocManager::repositories()) -``` - -Doench et al. (2016) 's python package **azimuth** for on-target efficiency prediction using their method can be easily installed and activated using reticulate: - -```{r, eval = FALSE} -# Install once - # reticulate::conda_create('azienv', 'python=2.7') - # reticulate::conda_install('azienv', 'azimuth', pip = TRUE) - # reticulate::conda_install('azienv', 'scikit-learn==0.17.1', pip = TRUE) -# Then activate - reticulate::use_condaenv('azienv') -``` - -Bowtie-indexed genomes for quick offtarget analysis can be installed using `index_genome`. For the two genomes used in the examples, mm10 and hg38, the functions downloads pre-build indexes from our data server, allowing a quick exploration (set `download=FALSE` to build index anew): - -```{r, eval = FALSE} -index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) -index_genome(BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 ) -``` - -<!-- 1. Install conda for python 2.7 --> -<!-- 2. Create a new conda environment: `conda create --name azimuthenv python=2.7` --> -<!-- 3. Activate conda environment: `conda activate azimuthenv` --> -<!-- 4. Install module azimuth: `pip install azimuth` --> -<!-- 5. Install scikit-learn: `pip install scikit-learn==0.17.1` --> - - -```{r, echo = FALSE, results = FALSE, message=FALSE} - # Not required - # Done to load dependencies silently - keeping focus - #require(GenomicRanges) - #require(Biostrings) - #require(dplyr) - #require(dbplyr) - #require(htmltools) - #require(htmlwidgets) -``` - -## Define targets - -```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } -knitr::include_graphics("../inst/extdata/01_define_targets.png") -``` - -`bed_to_granges` converts a (0-based) BED coordinate file into a (1-based) GRanges. -An example is loading the 1974 binding sites of the transcription factor SRF: - -```{r} -require(magrittr) -require(multicrispr) -bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') -tfbs0 <- bed_to_granges(bedfile, genome = 'mm10') -``` - - -`genes_to_granges` and `genefile_to_granges` convert entrez/ensembl gene identifiers into GRanges using `txdb` gene models. -An example that loads of a small subset of the 1974 SRF binding sites: - -```{r} -require(multicrispr) -entrezfile <- system.file('extdata/SRF.entrez', package = 'multicrispr') -txdb <- TxDb.Mmusculus.UCSC.mm10.knownGene::TxDb.Mmusculus.UCSC.mm10.knownGene -sometfbs0 <- genefile_to_granges(entrezfile, txdb, complement = TRUE) -``` - - -`char_to_granges` uses a 1-based coordinate vector to specify the GRanges. -It can be used to define four prime editing sites mentioned by Anzalone et al. (2019): - -```{r, fig.width=3.5, fig.height=1.5} -# char_to_granges: Anzalone et al. (2019) prime editing targets -bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -pe0 <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) -plot_intervals(pe0) -``` - -## Transform targets - -```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } -knitr::include_graphics("../inst/extdata/02_transform.png") -``` - -As a second step, the original targets may require transformation. The functions `extend`, `up_flank` (upstream flanks), `down_flank` (downstream flanks), and `double_flank` (double flanks) can be used to update the target ranges as required. - -```{r, fig.width=4, fig.height=2, out.width="65%"} -# Extend -targets <- pe0 -invisible(extend(targets, -22, 22, plot = TRUE)) -# Up flank -invisible(up_flank( targets, -200, -1, plot = TRUE)) -# Down flank -invisible(down_flank( targets, 1, 200, plot = TRUE)) -# Double flank -invisible(double_flank(targets, -200, -1, +1, +200, plot = TRUE)) -``` - - -## Find spacers - -```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } -knitr::include_graphics("../inst/extdata/03_find.png") -``` - -The next step is to find N20 spacers followed by NGG pam sites. -This can be done with `find_spacers`, after extending target range(s) to prime editing neighbourhood(s): - -```{r, fig.width=3, fig.height=1.5} -bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 -neighbourhood <- extend_for_pe(targets, bsgenome) -spacers <- find_spacers(neighbourhood, bsgenome, complement = FALSE) -``` - -For prime editing, however, it is better to use `find_pe_spacers`, which performs target to neighbourhood extension implicitly, and also adds 3' extension (Fig 1) to returned spacer GRanges. - -```{r, fig.width=3.3, fig.height=1.7} -spacers <- find_pe_spacers(targets, bsgenome=bsgenome) -``` - -This finds prime editing sites that follow Anzalone et al. (2019)'s recommended default settings: a 13-nucleotide primer and a 16-nucleotide reverse transcription template. These settings can be easily altered (e.g. Anzalone et al. report success with reverse transcription templates of up to 48 nucleotides) by: - -```{r, fig.width=3.6, fig.height=2.1} -spacers <- find_pe_spacers(targets, bsgenome=bsgenome, nrt = 48) -``` - - -## Add offtargets - -```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } -knitr::include_graphics("../inst/extdata/04_offtargets.png") -``` - -```{r, fig.width=3.6, fig.height=2.1} -if (has_been_indexed(bsgenome)){ - spacers %<>% add_offtargets(bsgenome, mismatch = 0, plot = TRUE) -} -``` - -## Add efficiency - -```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } -knitr::include_graphics("../inst/extdata/05_efficiency.png") -``` - -Not all N~20~NGG gRNA sequences target equally well (even when matching sequence perfectly). For each position in the 23-bp gRNA sequence, the nucleotide present in current, previous and next position has an effect on targeting efficiency. The current community standard for on-target efficiency prediction is that of Doench et al. (2016), which can be computed and added with `add_efficiency`: - -```{r, fig.width=3.6, fig.height=2.1} -if (reticulate::py_module_available('azimuth')){ - spacers %<>% add_efficiency(bsgenome, 'Doench2016') -} -``` - -## Return spacer GRanges - -```{r} - spacers -``` - -# References {-} - -Anzalone, A.V., Randolph, P.B., Davis, J.R. et al. Search-and-replace genome editing without double-strand breaks or donor DNA. Nature 576, 149–157 (2019). https://doi.org/10.1038/s41586-019-1711-4 - -Doench et al. (2016). Optimized sgRNA design to maximize activity and minimize off-target effects of CRISPR-Cas9. Nature Biotechnology, 34(7), doi:10.1038/nbt.3437 - - - - - - - +--- +title: "Using multicrispr for gRNA design" +author: "Aditya M Bhagwat" +date: "`r Sys.Date()`" +output: BiocStyle::html_document +vignette: > + %\VignetteIndexEntry{designing_grna_libraries} + %\VignetteEngine{knitr::rmarkdown} + %\VignetteEncoding{UTF-8} +--- + +```{r, include=TRUE, echo=FALSE, message=FALSE} +knitr::opts_chunk$set(echo = TRUE, collapse = TRUE, cache = FALSE) +#str(knitr::opts_chunk$get()) +``` + +<!--  --> + +# Background + +## Crispr/Cas9 and Prime Editing + +**Crispr/Cas9** is a prokaryotic immune system turned into a genome engineering tool, with a Cas9/gRNA complex at the heart of its functioning. The **gRNA** (guide RNA) contains a 20 nucleotide (proto)**spacer** which guides the complex to a genomic locus with identical sequence, but only when followed by an *NGG* **PAM** (protospacer adjacent motif (see Figure 1A). The **Cas9** enzyme performs some effector action at that locus: *wildtype Cas9* cuts both strands after spacer nucleotide 17, *Cas9Nickase* cuts only a single strand (two variants exist, cutting respectively each of the strands), while catalytically dead *dCas9*, fused to some effector domain (KRAB, VPR, APEX) performs some alternative action (e.g. KRAB represses, VPR activates, APEX biotinylates). + +**Prime Editing** (Anzalone et al., 2019) extends this further, by coupling Cas9 to a Reverse Transcriptase (RT). As shown in Figure 1, the guide RNA is extended with a 3' extension that contains primer binding site (binding a complementary DNA region that acts as a primer for reverse transcription) and reverse transcription template (the template used for reverse transcription). The spacer still acts as targeting agent, guiding the Cas9/RT complex to targeted genomic locus. + + +```{r, fig.small = TRUE, echo = FALSE, fig.cap = 'gRNAs for Crispr/Cas9 (A) and Prime Editing'} +knitr::include_graphics("../inst/extdata/pe.png") +``` + + +## Guide RNA design + +**Guide RNA design** involves finding good guide RNAs to hit the targets of interest. Plasmids with guide RNA scaffolds, ready for cloning desired spacers into, can be readily ordered from AddGene. The actual task, therefore, boils down to finding good spacers for the targets of interest. For prime editing, it additionally involves finding appropriate primer binding site and reverse transcription template to edit the target site of interest. + +A **good spacer** needs to fulfill two requirements. + +1. **Minimal off-target** (mis)matches, so that only intended targets are hit. + + - Crispr gRNAs can hit exact (with identical and alternate NGG pam), as well as (up-to 2) mismatch offtargets. + - Prime Editing is much more specific, hitting only exact offtargets. + +2. **Maximal on-target** efficiency. Over the years, several sequence-to-efficiency prediction models have been developed, of which the Doench 2016 score has currently become the community standard. The score is not perfect, and examples can be found where the prediction and the actual outcome differ. Yet, to-date it is the best heuristic to predict on-target efficiency, worth making use of. + + +# Multicrispr + +Multicrispr was developed to make guide RNA design easier. As shown below, it contains functions to **define** and **transform** targets, **find spacers**, compute/add **offtarget counts** and **efficiency scores** (Doench 2016), and finally return all of this as a **GRanges** object. + +```{r overview, fig.wide = TRUE, out.width = "80%", echo = FALSE } +knitr::include_graphics("../inst/extdata/readme_portrait.png") +``` + +## Install + + +Installing **multicrispr** is simple: + +```{r, eval = FALSE} +url <- 'https://gitlab.gwdg.de/loosolab/software/multicrispr.git' +remotes::install_git(url, repos = BiocManager::repositories()) +``` + +Doench et al. (2016) 's python package **azimuth** for on-target efficiency prediction using their method can be easily installed and activated using reticulate: + +```{r, eval = FALSE} +# Install once + # reticulate::conda_create('azienv', 'python=2.7') + # reticulate::conda_install('azienv', 'azimuth', pip = TRUE) + # reticulate::conda_install('azienv', 'scikit-learn==0.17.1', pip = TRUE) +# Then activate + reticulate::use_condaenv('azienv') +``` + +Bowtie-indexed genomes for quick offtarget analysis can be installed using `index_genome`. For the two genomes used in the examples, mm10 and hg38, the functions downloads pre-build indexes from our data server, allowing a quick exploration (set `download=FALSE` to build index anew): + +```{r, eval = FALSE} +index_genome(BSgenome.Mmusculus.UCSC.mm10::BSgenome.Mmusculus.UCSC.mm10) +index_genome(BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 ) +``` + +<!-- 1. Install conda for python 2.7 --> +<!-- 2. Create a new conda environment: `conda create --name azimuthenv python=2.7` --> +<!-- 3. Activate conda environment: `conda activate azimuthenv` --> +<!-- 4. Install module azimuth: `pip install azimuth` --> +<!-- 5. Install scikit-learn: `pip install scikit-learn==0.17.1` --> + + +```{r, echo = FALSE, results = FALSE, message=FALSE} + # Not required + # Done to load dependencies silently - keeping focus + #require(GenomicRanges) + #require(Biostrings) + #require(dplyr) + #require(dbplyr) + #require(htmltools) + #require(htmlwidgets) +``` + +## Define targets + +```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } +knitr::include_graphics("../inst/extdata/01_define_targets.png") +``` + +`bed_to_granges` converts a (0-based) BED coordinate file into a (1-based) GRanges. +An example is loading the 1974 binding sites of the transcription factor SRF: + +```{r} +require(magrittr) +require(multicrispr) +bedfile <- system.file('extdata/SRF.bed', package = 'multicrispr') +tfbs0 <- bed_to_granges(bedfile, genome = 'mm10') +``` + + +`genes_to_granges` and `genefile_to_granges` convert entrez/ensembl gene identifiers into GRanges using `txdb` gene models. +An example that loads of a small subset of the 1974 SRF binding sites: + +```{r} +require(multicrispr) +entrezfile <- system.file('extdata/SRF.entrez', package = 'multicrispr') +txdb <- TxDb.Mmusculus.UCSC.mm10.knownGene::TxDb.Mmusculus.UCSC.mm10.knownGene +sometfbs0 <- genefile_to_granges(entrezfile, txdb, complement = TRUE) +``` + + +`char_to_granges` uses a 1-based coordinate vector to specify the GRanges. +It can be used to define four prime editing sites mentioned by Anzalone et al. (2019): + +```{r, fig.width=3.5, fig.height=1.5} +# char_to_granges: Anzalone et al. (2019) prime editing targets +bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +pe0 <- char_to_granges(c(HBB = 'chr11:5227002:-'), bsgenome) +plot_intervals(pe0) +``` + +## Transform targets + +```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } +knitr::include_graphics("../inst/extdata/02_transform.png") +``` + +As a second step, the original targets may require transformation. The functions `extend`, `up_flank` (upstream flanks), `down_flank` (downstream flanks), and `double_flank` (double flanks) can be used to update the target ranges as required. + +```{r, fig.width=4, fig.height=2, out.width="65%"} +# Extend +targets <- pe0 +invisible(extend(targets, -22, 22, plot = TRUE)) +# Up flank +invisible(up_flank( targets, -200, -1, plot = TRUE)) +# Down flank +invisible(down_flank( targets, 1, 200, plot = TRUE)) +# Double flank +invisible(double_flank(targets, -200, -1, +1, +200, plot = TRUE)) +``` + + +## Find spacers + +```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } +knitr::include_graphics("../inst/extdata/03_find.png") +``` + +The next step is to find N20 spacers followed by NGG pam sites. +This can be done with `find_spacers`, after extending target range(s) to prime editing neighbourhood(s): + +```{r, fig.width=3, fig.height=1.5} +bsgenome <- BSgenome.Hsapiens.UCSC.hg38::BSgenome.Hsapiens.UCSC.hg38 +neighbourhood <- extend_for_pe(targets, bsgenome) +spacers <- find_spacers(neighbourhood, bsgenome, complement = FALSE) +``` + +For prime editing, however, it is better to use `find_pe_spacers`, which performs target to neighbourhood extension implicitly, and also adds 3' extension (Fig 1) to returned spacer GRanges. + +```{r, fig.width=3.3, fig.height=1.7} +spacers <- find_pe_spacers(targets, bsgenome=bsgenome) +``` + +This finds prime editing sites that follow Anzalone et al. (2019)'s recommended default settings: a 13-nucleotide primer and a 16-nucleotide reverse transcription template. These settings can be easily altered (e.g. Anzalone et al. report success with reverse transcription templates of up to 48 nucleotides) by: + +```{r, fig.width=3.6, fig.height=2.1} +spacers <- find_pe_spacers(targets, bsgenome=bsgenome, nrt = 48) +``` + + +## Add offtargets + +```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } +knitr::include_graphics("../inst/extdata/04_offtargets.png") +``` + +```{r, fig.width=3.6, fig.height=2.1} +if (has_been_indexed(bsgenome)){ + spacers %<>% add_offtargets(bsgenome, mismatch = 0, plot = TRUE) +} +``` + +## Add efficiency + +```{r, fig.small = TRUE, out.width = "70%", echo = FALSE } +knitr::include_graphics("../inst/extdata/05_efficiency.png") +``` + +Not all N~20~NGG gRNA sequences target equally well (even when matching sequence perfectly). For each position in the 23-bp gRNA sequence, the nucleotide present in current, previous and next position has an effect on targeting efficiency. The current community standard for on-target efficiency prediction is that of Doench et al. (2016), which can be computed and added with `add_efficiency`: + +```{r, fig.width=3.6, fig.height=2.1} +if (reticulate::py_module_available('azimuth')){ + spacers %<>% add_efficiency(bsgenome, 'Doench2016') +} +``` + +## Return spacer GRanges + +```{r} + spacers +``` + +# References {-} + +Anzalone, A.V., Randolph, P.B., Davis, J.R. et al. Search-and-replace genome editing without double-strand breaks or donor DNA. Nature 576, 149–157 (2019). https://doi.org/10.1038/s41586-019-1711-4 + +Doench et al. (2016). Optimized sgRNA design to maximize activity and minimize off-target effects of CRISPR-Cas9. Nature Biotechnology, 34(7), doi:10.1038/nbt.3437 + + + + + + +