From c8667c916e5a96c23f2333d3403389d1674f3774 Mon Sep 17 00:00:00 2001 From: liamlelievre Date: Wed, 4 Dec 2024 13:00:25 +1300 Subject: [PATCH 01/35] Add EXTRACT_CDS feature to GFF_STORE workflow --- conf/modules.config | 12 ++++++++++++ subworkflows/local/gff_store.nf | 13 +++++++++++++ 2 files changed, 25 insertions(+) diff --git a/conf/modules.config b/conf/modules.config index ba2bb72..d68fac3 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -295,6 +295,18 @@ process { // SUBWORKFLOW: GFF_STORE saveAs: { filename -> filename.equals('versions.yml') ? null : filename }, ] } + + withName: '.*:GFF_STORE:EXTRACT_CDS' { + ext.args = '-x' + ext.prefix = { "${meta.id}.cds" } + + publishDir = [ + path: { "${params.outdir}/annotations/$meta.id" }, + mode: params.publish_dir_mode, + saveAs: { filename -> filename.equals('versions.yml') ? null : filename }, + ] + } + } process { // SUBWORKFLOW: FASTA_ORTHOFINDER diff --git a/subworkflows/local/gff_store.nf b/subworkflows/local/gff_store.nf index 2c877a9..48e89c9 100644 --- a/subworkflows/local/gff_store.nf +++ b/subworkflows/local/gff_store.nf @@ -2,6 +2,7 @@ import java.net.URLEncoder include { GT_GFF3 as FINAL_GFF_CHECK } from '../../modules/nf-core/gt/gff3/main' include { GFFREAD as EXTRACT_PROTEINS } from '../../modules/nf-core/gffread/main' +include { GFFREAD as EXTRACT_CDS } from '../../modules/nf-core/gffread/main' workflow GFF_STORE { take: @@ -133,9 +134,21 @@ workflow GFF_STORE { ch_final_proteins = EXTRACT_PROTEINS.out.gffread_fasta ch_versions = ch_versions.mix(EXTRACT_PROTEINS.out.versions.first()) +// MODULE: GFFREAD as EXTRACT_CDS + ch_cds_extraction_inputs = ch_final_gff | join(ch_fasta) + + EXTRACT_CDS( + ch_cds_extraction_inputs.map { meta, gff, fasta -> [ meta, gff ] }, + ch_cds_extraction_inputs.map { meta, gff, fasta -> fasta }, + ext.args: '-w' // Extract CDS + ) + + ch_final_cds = EXTRACT_CDS.out.gffread_fasta + ch_versions = ch_versions.mix(EXTRACT_CDS.out.versions.first()) emit: final_gff = ch_final_gff // [ meta, gff ] final_proteins = ch_final_proteins // [ meta, fasta ] + final_cds = ch_final_cds // [ meta, fasta ] versions = ch_versions // [ versions.yml ] } From dbebd7a7a61684df03d9a71e19affb0f33d60d5b Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 14:55:24 +1300 Subject: [PATCH 02/35] Update gff_store.nf Correct indents and whitespaces --- subworkflows/local/gff_store.nf | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/subworkflows/local/gff_store.nf b/subworkflows/local/gff_store.nf index 48e89c9..075863e 100644 --- a/subworkflows/local/gff_store.nf +++ b/subworkflows/local/gff_store.nf @@ -2,7 +2,7 @@ import java.net.URLEncoder include { GT_GFF3 as FINAL_GFF_CHECK } from '../../modules/nf-core/gt/gff3/main' include { GFFREAD as EXTRACT_PROTEINS } from '../../modules/nf-core/gffread/main' -include { GFFREAD as EXTRACT_CDS } from '../../modules/nf-core/gffread/main' +include { GFFREAD as EXTRACT_CDS } from '../../modules/nf-core/gffread/main' workflow GFF_STORE { take: @@ -134,7 +134,7 @@ workflow GFF_STORE { ch_final_proteins = EXTRACT_PROTEINS.out.gffread_fasta ch_versions = ch_versions.mix(EXTRACT_PROTEINS.out.versions.first()) -// MODULE: GFFREAD as EXTRACT_CDS + // MODULE: GFFREAD as EXTRACT_CDS ch_cds_extraction_inputs = ch_final_gff | join(ch_fasta) EXTRACT_CDS( From 203af9bd3852ad471fcede3ecb9511b745d182a8 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 15:20:45 +1300 Subject: [PATCH 03/35] Update gff_store.nf --- subworkflows/local/gff_store.nf | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/subworkflows/local/gff_store.nf b/subworkflows/local/gff_store.nf index 075863e..13eed6f 100644 --- a/subworkflows/local/gff_store.nf +++ b/subworkflows/local/gff_store.nf @@ -135,12 +135,12 @@ workflow GFF_STORE { ch_versions = ch_versions.mix(EXTRACT_PROTEINS.out.versions.first()) // MODULE: GFFREAD as EXTRACT_CDS - ch_cds_extraction_inputs = ch_final_gff | join(ch_fasta) + ch_cds_extraction_inputs = ch_final_gff + | join(ch_fasta) EXTRACT_CDS( ch_cds_extraction_inputs.map { meta, gff, fasta -> [ meta, gff ] }, - ch_cds_extraction_inputs.map { meta, gff, fasta -> fasta }, - ext.args: '-w' // Extract CDS + ch_cds_extraction_inputs.map { meta, gff, fasta -> fasta } ) ch_final_cds = EXTRACT_CDS.out.gffread_fasta @@ -149,6 +149,6 @@ workflow GFF_STORE { emit: final_gff = ch_final_gff // [ meta, gff ] final_proteins = ch_final_proteins // [ meta, fasta ] - final_cds = ch_final_cds // [ meta, fasta ] + final_cds = ch_final_cds // [ meta, fasta ] versions = ch_versions // [ versions.yml ] } From 13fe4e9cb55d79e86d1ed328848fda59fc9d90c1 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 15:39:50 +1300 Subject: [PATCH 04/35] add EXTRACT_CDNA to gff_store.nf --- subworkflows/local/gff_store.nf | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/subworkflows/local/gff_store.nf b/subworkflows/local/gff_store.nf index 13eed6f..120d768 100644 --- a/subworkflows/local/gff_store.nf +++ b/subworkflows/local/gff_store.nf @@ -3,6 +3,7 @@ import java.net.URLEncoder include { GT_GFF3 as FINAL_GFF_CHECK } from '../../modules/nf-core/gt/gff3/main' include { GFFREAD as EXTRACT_PROTEINS } from '../../modules/nf-core/gffread/main' include { GFFREAD as EXTRACT_CDS } from '../../modules/nf-core/gffread/main' +include { GFFREAD as EXTRACT_CDNA } from '../../modules/nf-core/gffread/main' workflow GFF_STORE { take: @@ -146,9 +147,21 @@ workflow GFF_STORE { ch_final_cds = EXTRACT_CDS.out.gffread_fasta ch_versions = ch_versions.mix(EXTRACT_CDS.out.versions.first()) + // MODULE: GFFREAD as EXTRACT_CDNA + ch_cdna_extraction_inputs = ch_final_gff + | join(ch_fasta) + + EXTRACT_CDNA( + ch_cdna_extraction_inputs.map { meta, gff, fasta -> [ meta, gff ] }, + ch_cdna_extraction_inputs.map { meta, gff, fasta -> fasta} + + ch_final_cdna = EXTRACT_CDNA.out.gffread_fasta + ch_versions = ch_versions.mix(EXTRACT_CDNA.out.versions.first()) + emit: final_gff = ch_final_gff // [ meta, gff ] final_proteins = ch_final_proteins // [ meta, fasta ] final_cds = ch_final_cds // [ meta, fasta ] + final_cdna = ch_final_cdna // [ meta, fasta ] versions = ch_versions // [ versions.yml ] } From c7bf40b1ac4d1c1e7c994bd7a0eb59b24f37775e Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 15:41:04 +1300 Subject: [PATCH 05/35] add GFF_STORE:EXTRACT_CDNA to modules.config --- conf/modules.config | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/conf/modules.config b/conf/modules.config index d68fac3..562b6a0 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -306,7 +306,16 @@ process { // SUBWORKFLOW: GFF_STORE saveAs: { filename -> filename.equals('versions.yml') ? null : filename }, ] } + withName: '.*:GFF_STORE:EXTRACT_CDNA' { + ext.args = '-w' + ext.prefix = { "${meta.id}.cdna" } + publishDir = [ + path: { "${params.outdir}/annotations/$meta.id" }, + mode: params.publish_dir_mode, + saveAs: { filename -> filename.equals('versions.yml') ? null : filename }, + ] + } } process { // SUBWORKFLOW: FASTA_ORTHOFINDER From f0699a60383a55cb606159ec069ce127ef704f41 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 15:42:55 +1300 Subject: [PATCH 06/35] Update gff_store.nf --- subworkflows/local/gff_store.nf | 1 + 1 file changed, 1 insertion(+) diff --git a/subworkflows/local/gff_store.nf b/subworkflows/local/gff_store.nf index 120d768..91f845d 100644 --- a/subworkflows/local/gff_store.nf +++ b/subworkflows/local/gff_store.nf @@ -154,6 +154,7 @@ workflow GFF_STORE { EXTRACT_CDNA( ch_cdna_extraction_inputs.map { meta, gff, fasta -> [ meta, gff ] }, ch_cdna_extraction_inputs.map { meta, gff, fasta -> fasta} + ) ch_final_cdna = EXTRACT_CDNA.out.gffread_fasta ch_versions = ch_versions.mix(EXTRACT_CDNA.out.versions.first()) From 563bd13cdd9e50d535875ed12ace09a1b59b7874 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 16:37:24 +1300 Subject: [PATCH 07/35] Add cdna and cds outputs to output.md --- docs/output.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/docs/output.md b/docs/output.md index 44e598a..6c4c9c8 100644 --- a/docs/output.md +++ b/docs/output.md @@ -168,7 +168,9 @@ If more than one genome is included in the pipeline, [ORTHOFINDER](https://githu - `annotations/` - `Y/` - `Y.gt.gff3`: Final annotation file for genome `Y` which contains gene models and their functional annotations - - `Y.pep.fasta`: Protein sequences for the gene models + - `Y.pep.fasta`: Protein sequences for the gene models\ + - 'Y.cdna.fasta': cDNA sequences for the gene models\ + - 'Y.cds.fasta': Coding sequences for the gene models\ From 79befa552c36e73826f83b24fa9057644389dbee Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 16:41:15 +1300 Subject: [PATCH 08/35] Add notes about cdna and cds update to CHANGELOG.md --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 79627bc..c4dc410 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -19,6 +19,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 10. Added an HTML report [#44](https://github.com/Plant-Food-Research-Open/genepal/issues/44) 11. Added content type as text/html for the MultiQC and genepal reports 12. Added sra-tools for RNASeq data download [#102](https://github.com/Plant-Food-Research-Open/genepal/issues/102) +13. Added cDNA and cds outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) ### `Fixed` From 47e2cf33e592b11764e1aad81b0f9cd0b0fc8700 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 16:48:57 +1300 Subject: [PATCH 09/35] Added liamlelievre to contributors - README.md --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index 766d5fe..5e68c75 100644 --- a/README.md +++ b/README.md @@ -139,6 +139,7 @@ The pipeline uses nf-core modules contributed by following authors: + ## Contributions and Support From 2a118be20202ef2ba9b6836f839159c8ed5a8227 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 17:02:15 +1300 Subject: [PATCH 10/35] Update output.md removed end of line "/" --- docs/output.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/docs/output.md b/docs/output.md index 6c4c9c8..f4793b5 100644 --- a/docs/output.md +++ b/docs/output.md @@ -168,9 +168,9 @@ If more than one genome is included in the pipeline, [ORTHOFINDER](https://githu - `annotations/` - `Y/` - `Y.gt.gff3`: Final annotation file for genome `Y` which contains gene models and their functional annotations - - `Y.pep.fasta`: Protein sequences for the gene models\ - - 'Y.cdna.fasta': cDNA sequences for the gene models\ - - 'Y.cds.fasta': Coding sequences for the gene models\ + - `Y.pep.fasta`: Protein sequences for the gene models + - 'Y.cdna.fasta': cDNA sequences for the gene models + - 'Y.cds.fasta': Coding sequences for the gene models From 216225c8d4977705315f6b1af539c9c79a522b0c Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 17:03:59 +1300 Subject: [PATCH 11/35] Added v0.6.0 notes to CHANGELOG.md --- CHANGELOG.md | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c4dc410..67872fc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,6 +3,12 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). +## v0.6.0 - [4-Dec-2024] + +### 'Added' + +1. Added cDNA and cds outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) + ## v0.5.0 - [21-Nov-2024] ### `Added` @@ -19,8 +25,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 10. Added an HTML report [#44](https://github.com/Plant-Food-Research-Open/genepal/issues/44) 11. Added content type as text/html for the MultiQC and genepal reports 12. Added sra-tools for RNASeq data download [#102](https://github.com/Plant-Food-Research-Open/genepal/issues/102) -13. Added cDNA and cds outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) - + ### `Fixed` 1. Now using `${meta.id}_trim` as prefix for `FASTQC` files From 74cd2b2fafd5af099f2fc34b5dc6219288662e14 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 17:08:40 +1300 Subject: [PATCH 12/35] removed trailing whitespace gff_store.nf --- subworkflows/local/gff_store.nf | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/subworkflows/local/gff_store.nf b/subworkflows/local/gff_store.nf index 91f845d..2ce008f 100644 --- a/subworkflows/local/gff_store.nf +++ b/subworkflows/local/gff_store.nf @@ -162,7 +162,7 @@ workflow GFF_STORE { emit: final_gff = ch_final_gff // [ meta, gff ] final_proteins = ch_final_proteins // [ meta, fasta ] - final_cds = ch_final_cds // [ meta, fasta ] + final_cds = ch_final_cds // [ meta, fasta ] final_cdna = ch_final_cdna // [ meta, fasta ] versions = ch_versions // [ versions.yml ] } From 81871ff0c7089047fb62de1d40c6fecc09790bd7 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 17:09:21 +1300 Subject: [PATCH 13/35] Removed trailing whitespace - modules.config --- conf/modules.config | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/conf/modules.config b/conf/modules.config index 562b6a0..9bf1c5f 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -295,7 +295,7 @@ process { // SUBWORKFLOW: GFF_STORE saveAs: { filename -> filename.equals('versions.yml') ? null : filename }, ] } - + withName: '.*:GFF_STORE:EXTRACT_CDS' { ext.args = '-x' ext.prefix = { "${meta.id}.cds" } From 3f898b0ee6f1a4fa7de22d5ec810629e79d73ce9 Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 17:11:55 +1300 Subject: [PATCH 14/35] rename params - modules.config params.add_attrs_to_proteins_fasta to params.add_attrs_to_gffread_fastas --- conf/modules.config | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/conf/modules.config b/conf/modules.config index 9bf1c5f..5d38b7d 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -286,7 +286,7 @@ process { // SUBWORKFLOW: GFF_STORE } withName: '.*:GFF_STORE:EXTRACT_PROTEINS' { - ext.args = params.add_attrs_to_proteins_fasta ? '-F -D -y' : '-y' + ext.args = params.add_attrs_to_gffread_fastas ? '-F -D -y' : '-y' ext.prefix = { "${meta.id}.pep" } publishDir = [ From 5af18c85a3597d6d13bb026c8a622a543af800bd Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 4 Dec 2024 17:15:10 +1300 Subject: [PATCH 15/35] Rename params - nextflow.config Rename params.add_attrs_to_proteins_fasta to params.add_attrs_to_gffread_fastas --- nextflow.config | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/nextflow.config b/nextflow.config index 665e6b3..91c9962 100644 --- a/nextflow.config +++ b/nextflow.config @@ -57,7 +57,7 @@ params { // Annotation output options braker_save_outputs = false - add_attrs_to_proteins_fasta = false + add_attrs_to_gffread_fastas = false // Evaluation options busco_skip = false From 841ea020b7bcf632f6ce5a5ff1e30c8438c9ae89 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Thu, 5 Dec 2024 12:21:32 +1300 Subject: [PATCH 16/35] Added code contributors --- README.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 5e68c75..0cc92ea 100644 --- a/README.md +++ b/README.md @@ -97,7 +97,7 @@ sbatch ./pfr_genepal plant-food-research-open/genepal workflows were originally scripted by Jason Shiller ([@jasonshiller](https://github.com/jasonshiller)). Usman Rashid ([@gallvp](https://github.com/gallvp)) wrote the Nextflow pipeline. -We thank the following people for their extensive assistance in the development of this pipeline: +We thank the following people for extensive assistance in the development of the pipeline, - Cecilia Deng [@CeciliaDeng](https://github.com/CeciliaDeng) - Charles David [@charlesdavid](https://github.com/charlesdavid) @@ -107,6 +107,10 @@ We thank the following people for their extensive assistance in the development - Susan Thomson [@cflsjt](https://github.com/cflsjt) - Ting-Hsuan Chen [@ting-hsuan-chen](https://github.com/ting-hsuan-chen) +and for contributions to the codebase, + +- Liam Le Lievre [@liamlelievre](https://github.com/liamlelievre) + The pipeline uses nf-core modules contributed by following authors: From e05a46915b363968f91777f2af47225adcca039c Mon Sep 17 00:00:00 2001 From: liamlelievre Date: Thu, 5 Dec 2024 14:24:52 +1300 Subject: [PATCH 17/35] Run nf-test successfully in minimal and stub --- .nf-core.yml | 2 +- CHANGELOG.md | 2 +- CITATION.cff | 2 +- assets/multiqc_config.yml | 2 +- conf/modules.config | 2 +- docs/parameters.md | 37 ++++++++++++++++++++------------- nextflow.config | 4 ++-- nextflow_schema.json | 12 +++++------ tests/minimal/main.nf.test.snap | 22 ++++++++++++++------ tests/stub/main.nf.test.snap | 26 +++++++++++++++++------ 10 files changed, 71 insertions(+), 40 deletions(-) diff --git a/.nf-core.yml b/.nf-core.yml index 260014a..1641b31 100644 --- a/.nf-core.yml +++ b/.nf-core.yml @@ -30,5 +30,5 @@ template: outdir: . skip_features: - igenomes - version: 0.5.0 + version: 0.6.0 update: null diff --git a/CHANGELOG.md b/CHANGELOG.md index 67872fc..ada72ae 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -25,7 +25,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 10. Added an HTML report [#44](https://github.com/Plant-Food-Research-Open/genepal/issues/44) 11. Added content type as text/html for the MultiQC and genepal reports 12. Added sra-tools for RNASeq data download [#102](https://github.com/Plant-Food-Research-Open/genepal/issues/102) - + ### `Fixed` 1. Now using `${meta.id}_trim` as prefix for `FASTQC` files diff --git a/CITATION.cff b/CITATION.cff index c5c6c26..4a2ad92 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -31,7 +31,7 @@ authors: - family-names: "Thomson" given-names: "Susan" title: "genepal: A Nextflow pipeline for genome and pan-genome annotation" -version: 0.5.0 +version: 0.6.0 date-released: 2024-11-21 url: "https://github.com/Plant-Food-Research-Open/genepal" doi: 10.5281/zenodo.14195006 diff --git a/assets/multiqc_config.yml b/assets/multiqc_config.yml index 8969c04..6682724 100644 --- a/assets/multiqc_config.yml +++ b/assets/multiqc_config.yml @@ -1,7 +1,7 @@ report_comment: > This report has been generated by the plant-food-research-open/genepal analysis pipeline. For information about how to interpret these results, please see the - documentation. + documentation. report_section_order: "plant-food-research-open-genepal-methods-description": diff --git a/conf/modules.config b/conf/modules.config index 5d38b7d..ca741e9 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -286,7 +286,7 @@ process { // SUBWORKFLOW: GFF_STORE } withName: '.*:GFF_STORE:EXTRACT_PROTEINS' { - ext.args = params.add_attrs_to_gffread_fastas ? '-F -D -y' : '-y' + ext.args = params.add_attrs_to_proteins_cds_fastas ? '-F -D -y' : '-y' ext.prefix = { "${meta.id}.pep" } publishDir = [ diff --git a/docs/parameters.md b/docs/parameters.md index 1c96a8b..c9eaa7e 100644 --- a/docs/parameters.md +++ b/docs/parameters.md @@ -4,17 +4,19 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## Input/output options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------- | -------------------------------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | -| `input` | Target assemblies listed in a CSV sheet | `string` | | True | | -| `protein_evidence` | Protein evidence provided as a fasta file or multiple fasta files listed in a plain txt file | `string` | | True | | -| `eggnogmapper_db_dir` | Eggnogmapper database directory | `string` | | | | -| `eggnogmapper_tax_scope` | Eggnogmapper taxonomy scopre. Eukaryota: 2759, Viridiplantae: 33090, Archaea: 2157, Bacteria: 2, root: 1 | `integer` | 1 | | | -| `rna_evidence` | FASTQ/BAM samples listed in a CSV sheet | `string` | | | | -| `liftoff_annotations` | Reference annotations listed in a CSV sheet | `string` | | | | -| `orthofinder_annotations` | Additional annotations for orthology listed in a CSV sheet | `string` | | | | -| `outdir` | The output directory where the results will be saved | `string` | | True | | -| `email` | Email address for completion summary. | `string` | | | True | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------ | -------------------------------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | +| `input` | Target assemblies listed in a CSV sheet | `string` | | True | | +| `protein_evidence` | Protein evidence provided as a fasta file or multiple fasta files listed in a plain txt file | `string` | | True | | +| `eggnogmapper_db_dir` | Eggnogmapper database directory | `string` | | | | +| `eggnogmapper_tax_scope` | Eggnogmapper taxonomy scopre. Eukaryota: 2759, Viridiplantae: 33090, Archaea: 2157, Bacteria: 2, root: 1 | `integer` | 1 | | + +| +| `rna_evidence` | FASTQ/BAM samples listed in a CSV sheet | `string` | | | | +| `liftoff_annotations` | Reference annotations listed in a CSV sheet | `string` | | | | +| `orthofinder_annotations` | Additional annotations for orthology listed in a CSV sheet | `string` | | | | +| `outdir` | The output directory where the results will be saved | `string` | | True | | +| `email` | Email address for completion summary. | `string` | | | True | ## Repeat annotation options @@ -68,10 +70,9 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## Annotation output options -| Parameter | Description | Type | Default | Required | Hidden | -| ----------------------------- | ------------------------------------ | --------- | ------- | -------- | ------ | -| `braker_save_outputs` | Save BRAKER files | `boolean` | | | | -| `add_attrs_to_proteins_fasta` | Add gff attributes to proteins fasta | `boolean` | | | | +| Parameter | Description | Type | Default | Required | Hidden | +| --------------------- | ----------------- | --------- | ------- | -------- | ------ | +| `braker_save_outputs` | Save BRAKER files | `boolean` | | | | ## Evaluation options @@ -104,3 +105,9 @@ Less common options for the pipeline, typically set in a config file. | `max_multiqc_email_size` | File size limit when attaching MultiQC reports to summary emails. | `string` | 25.MB | | True | | `monochrome_logs` | Do not use coloured log outputs. | `boolean` | | | True | | `hook_url` | Incoming hook URL for messaging service | `string` | | | True | + +## Other parameters + +| Parameter | Description | Type | Default | Required | Hidden | +| ----------------------------- | ----------- | --------- | ------- | -------- | ------ | +| `add_attrs_to_gffread_fastas` | | `boolean` | | | | diff --git a/nextflow.config b/nextflow.config index 91c9962..c91980e 100644 --- a/nextflow.config +++ b/nextflow.config @@ -57,7 +57,7 @@ params { // Annotation output options braker_save_outputs = false - add_attrs_to_gffread_fastas = false + add_attrs_to_proteins_cds_fastas = false // Evaluation options busco_skip = false @@ -261,7 +261,7 @@ manifest { description = """A Nextflow pipeline for consensus, phased and pan-genome annotation.""" mainScript = 'main.nf' nextflowVersion = '!>=24.04.2' - version = '0.5.0' + version = '0.6.0' doi = 'https://doi.org/10.5281/zenodo.14195006' } diff --git a/nextflow_schema.json b/nextflow_schema.json index 0258683..2cc3f8d 100644 --- a/nextflow_schema.json +++ b/nextflow_schema.json @@ -286,11 +286,6 @@ "type": "boolean", "description": "Save BRAKER files", "fa_icon": "fas fa-question-circle" - }, - "add_attrs_to_proteins_fasta": { - "type": "boolean", - "fa_icon": "fas fa-question-circle", - "description": "Add gff attributes to proteins fasta" } } }, @@ -438,5 +433,10 @@ { "$ref": "#/$defs/generic_options" } - ] + ], + "properties": { + "add_attrs_to_proteins_cds_fastas": { + "type": "boolean" + } + } } diff --git a/tests/minimal/main.nf.test.snap b/tests/minimal/main.nf.test.snap index 02c228f..b1f61c8 100644 --- a/tests/minimal/main.nf.test.snap +++ b/tests/minimal/main.nf.test.snap @@ -2,7 +2,7 @@ "profile - test": { "content": [ { - "successful tasks": 18, + "successful tasks": 20, "versions": { "AGAT_CONVERTSPGFF2GTF": { "agat": "v1.4.0" @@ -25,6 +25,12 @@ "CAT_PROTEIN_FASTAS": { "pigz": "2.3.4" }, + "EXTRACT_CDNA": { + "gffread": "0.12.7" + }, + "EXTRACT_CDS": { + "gffread": "0.12.7" + }, "EXTRACT_PROTEINS": { "gffread": "0.12.7" }, @@ -55,10 +61,12 @@ "tsebra": "1.1.2.5" }, "Workflow": { - "plant-food-research-open/genepal": "v0.5.0" + "plant-food-research-open/genepal": "v0.6.0" } }, "stable paths": [ + "a_thaliana.cdna.fasta:md5,12b9bef973e488640aec8c04ba3882fe", + "a_thaliana.cds.fasta:md5,b81060419355a590560f92aec8536281", "a_thaliana.gt.gff3:md5,8ab16549095f605ff8715ac4a3de58ed", "a_thaliana.pep.fasta:md5,4994c0393ca0245a1c57966d846d101e", "a_thaliana.gff3:md5,d23d16cd86499d48a30ffb981ed27891", @@ -67,6 +75,8 @@ "stable names": [ "annotations", "annotations/a_thaliana", + "annotations/a_thaliana/a_thaliana.cdna.fasta", + "annotations/a_thaliana/a_thaliana.cds.fasta", "annotations/a_thaliana/a_thaliana.gt.gff3", "annotations/a_thaliana/a_thaliana.pep.fasta", "etc", @@ -81,9 +91,9 @@ } ], "meta": { - "nf-test": "0.9.0", - "nextflow": "24.04.4" + "nf-test": "0.9.2", + "nextflow": "24.04.2" }, - "timestamp": "2024-11-19T11:35:02.477202" + "timestamp": "2024-12-05T07:51:43.818374" } -} +} \ No newline at end of file diff --git a/tests/stub/main.nf.test.snap b/tests/stub/main.nf.test.snap index 524ce21..3d3949b 100644 --- a/tests/stub/main.nf.test.snap +++ b/tests/stub/main.nf.test.snap @@ -2,7 +2,7 @@ "full - stub": { "content": [ { - "successful tasks": 154, + "successful tasks": 162, "versions": { "AGAT_CONVERTSPGFF2GTF": { "agat": "v1.4.0" @@ -55,6 +55,12 @@ "EGGNOGMAPPER": { "eggnog-mapper": "2.1.12" }, + "EXTRACT_CDNA": { + "gffread": "0.12.7" + }, + "EXTRACT_CDS": { + "gffread": "0.12.7" + }, "EXTRACT_PROTEINS": { "gffread": "0.12.7" }, @@ -143,25 +149,33 @@ "tsebra": "1.1.2.5" }, "Workflow": { - "plant-food-research-open/genepal": "v0.5.0" + "plant-food-research-open/genepal": "v0.6.0" } }, "stable paths": [ + "donghong.cdna.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", + "donghong.cds.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", "donghong.emapper.annotations:md5,d41d8cd98f00b204e9800998ecf8427e", "donghong.emapper.hits:md5,d41d8cd98f00b204e9800998ecf8427e", "donghong.emapper.seed_orthologs:md5,d41d8cd98f00b204e9800998ecf8427e", "donghong.gt.gff3:md5,d41d8cd98f00b204e9800998ecf8427e", "donghong.pep.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", + "red5_v2p1.cdna.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", + "red5_v2p1.cds.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v2p1.emapper.annotations:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v2p1.emapper.hits:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v2p1.emapper.seed_orthologs:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v2p1.gt.gff3:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v2p1.pep.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", + "red5_v3.cdna.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", + "red5_v3.cds.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v3.emapper.annotations:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v3.emapper.hits:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v3.emapper.seed_orthologs:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v3.gt.gff3:md5,d41d8cd98f00b204e9800998ecf8427e", "red5_v3.pep.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", + "red7_v5.cdna.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", + "red7_v5.cds.fasta:md5,d41d8cd98f00b204e9800998ecf8427e", "red7_v5.emapper.annotations:md5,d41d8cd98f00b204e9800998ecf8427e", "red7_v5.emapper.hits:md5,d41d8cd98f00b204e9800998ecf8427e", "red7_v5.emapper.seed_orthologs:md5,d41d8cd98f00b204e9800998ecf8427e", @@ -188,9 +202,9 @@ } ], "meta": { - "nf-test": "0.9.0", - "nextflow": "24.04.4" + "nf-test": "0.9.2", + "nextflow": "24.04.2" }, - "timestamp": "2024-11-21T12:34:14.056074" + "timestamp": "2024-12-05T07:56:38.915238" } -} +} \ No newline at end of file From d2ff47e882f580cdbccd6a18b53bfa66d50b9f3e Mon Sep 17 00:00:00 2001 From: liamlelievre Date: Thu, 5 Dec 2024 14:41:31 +1300 Subject: [PATCH 18/35] Run nf-test successfully in minimal and stub, renamed attr, updated docs --- docs/parameters.md | 142 ++++++++++++++++++++++++------------------- nextflow_schema.json | 12 ++-- 2 files changed, 84 insertions(+), 70 deletions(-) diff --git a/docs/parameters.md b/docs/parameters.md index c9eaa7e..ef2bce2 100644 --- a/docs/parameters.md +++ b/docs/parameters.md @@ -4,19 +4,20 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## Input/output options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------ | -------------------------------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | -| `input` | Target assemblies listed in a CSV sheet | `string` | | True | | -| `protein_evidence` | Protein evidence provided as a fasta file or multiple fasta files listed in a plain txt file | `string` | | True | | -| `eggnogmapper_db_dir` | Eggnogmapper database directory | `string` | | | | -| `eggnogmapper_tax_scope` | Eggnogmapper taxonomy scopre. Eukaryota: 2759, Viridiplantae: 33090, Archaea: 2157, Bacteria: 2, root: 1 | `integer` | 1 | | - -| -| `rna_evidence` | FASTQ/BAM samples listed in a CSV sheet | `string` | | | | -| `liftoff_annotations` | Reference annotations listed in a CSV sheet | `string` | | | | -| `orthofinder_annotations` | Additional annotations for orthology listed in a CSV sheet | `string` | | | | -| `outdir` | The output directory where the results will be saved | `string` | | True | | -| `email` | Email address for completion summary. | `string` | | | True | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------------------------ | ------------------------------------------------------------------------ | -------- | ------- | -------- | ------ | +| `input` | Target assemblies listed in a CSV sheet | `string` | | True | | +| `protein_evidence` | Protein evidence provided as a fasta file or multiple fasta files listed | +| in a plain txt file | `string` | | True | | +| `eggnogmapper_db_dir` | Eggnogmapper database directory | `string` | | | | +| `eggnogmapper_tax_scope` | Eggnogmapper taxonomy scopre. Eukaryota: 2759, Viridiplantae: | +| 33090, Archaea: 2157, Bacteria: 2, root: 1 | `integer` | 1 | | | +| `rna_evidence` | FASTQ/BAM samples listed in a CSV sheet | `string` | | | | +| `liftoff_annotations` | Reference annotations listed in a CSV sheet | `string` | | | | +| `orthofinder_annotations` | Additional annotations for orthology listed in a CSV sheet | +| `string` | | | | +| `outdir` | The output directory where the results will be saved | `string` | | True | | +| `email` | Email address for completion summary. | `string` | | | True | ## Repeat annotation options @@ -29,68 +30,84 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## RNASeq pre-processing options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------ | ------------------------------------------------------------------ | --------- | ----------------------------------------- | -------- | ------ | -| `fastqc_skip` | Skip FASTQC or not? | `boolean` | True | | | -| `fastp_skip` | Skip trimming by FASTQP or not? | `boolean` | | | | -| `min_trimmed_reads` | Exclude a sample if its reads after trimming are below this number | `integer` | 10000 | | | -| `fastp_extra_args` | Extra FASTP arguments | `string` | | | | -| `save_trimmed` | Save FASTQ files after trimming or not? | `boolean` | | | | -| `remove_ribo_rna` | Remove Ribosomal RNA or not? | `boolean` | | | | -| `save_non_ribo_reads` | Save FASTQ files after Ribosomal RNA removal or not? | `boolean` | | | | -| `ribo_database_manifest` | Ribosomal RNA fastas listed in a text sheet | `string` | ${projectDir}/assets/rrna-db-defaults.txt | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ----------------------------------------- | ------------------------------------------------------------------ | --------- | ------- | -------- | ------ | +| `fastqc_skip` | Skip FASTQC or not? | `boolean` | True | | | +| `fastp_skip` | Skip trimming by FASTQP or not? | `boolean` | | | | +| `min_trimmed_reads` | Exclude a sample if its reads after trimming are below this number | +| `integer` | 10000 | | | +| `fastp_extra_args` | Extra FASTP arguments | `string` | | | | +| `save_trimmed` | Save FASTQ files after trimming or not? | `boolean` | | | | +| `remove_ribo_rna` | Remove Ribosomal RNA or not? | `boolean` | | | | +| `save_non_ribo_reads` | Save FASTQ files after Ribosomal RNA removal or not? | `boolean` | | +| | +| `ribo_database_manifest` | Ribosomal RNA fastas listed in a text sheet | `string` | +| ${projectDir}/assets/rrna-db-defaults.txt | | | ## RNASeq alignment options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------ | ------------------------------------------------- | --------- | ------- | -------- | ------ | -| `star_max_intron_length` | Maximum intron length for STAR alignment | `integer` | 16000 | | | -| `star_align_extra_args` | EXTRA arguments for STAR | `string` | | | | -| `star_save_outputs` | Save BAM files from STAR or not? | `boolean` | | | | -| `save_cat_bam` | SAVE a concatenated BAM file per assembly or not? | `boolean` | | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------ | ---------------------------------------- | --------- | ------- | -------- | ------ | +| `star_max_intron_length` | Maximum intron length for STAR alignment | `integer` | 16000 | | + +| +| `star_align_extra_args` | EXTRA arguments for STAR | `string` | | | | +| `star_save_outputs` | Save BAM files from STAR or not? | `boolean` | | | | +| `save_cat_bam` | SAVE a concatenated BAM file per assembly or not? | `boolean` | | | | ## Annotation options -| Parameter | Description | Type | Default | Required | Hidden | -| --------------------- | --------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | -| `braker_extra_args` | Extra arguments for BRAKER | `string` | | | | -| `liftoff_coverage` | Liftoff coverage parameter | `number` | 0.9 | | | -| `liftoff_identity` | Liftoff identity parameter | `number` | 0.9 | | | -| `eggnogmapper_evalue` | Only report alignments below or equal the e-value threshold | `number` | 1e-05 | | | -| `eggnogmapper_pident` | Only report alignments above or equal to the given percentage of identity (0-100) | `integer` | 35 | | | +| Parameter | Description | Type | Default | Required | Hidden | +| --------------------- | ---------------------------------------------------------------- | -------- | ------- | -------- | ------ | +| `braker_extra_args` | Extra arguments for BRAKER | `string` | | | | +| `liftoff_coverage` | Liftoff coverage parameter | `number` | 0.9 | | | +| `liftoff_identity` | Liftoff identity parameter | `number` | 0.9 | | | +| `eggnogmapper_evalue` | Only report alignments below or equal the e-value threshold | `number` | +| 1e-05 | | | +| `eggnogmapper_pident` | Only report alignments above or equal to the given percentage of | +| identity (0-100) | `integer` | 35 | | | ## Post-annotation filtering options -| Parameter | Description | Type | Default | Required | Hidden | -| ----------------------------- | ----------------------------------------------------------------- | --------- | ------- | -------- | ------ | -| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | -| `enforce_full_intron_support` | Require every model to have external evidence for all its introns | `boolean` | True | | | -| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | | -| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | `boolean` | | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ----------------------------- | --------------------------------------------------------- | --------- | ------- | -------- | ------ | +| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | +| `enforce_full_intron_support` | Require every model to have external evidence for all its | +| introns | `boolean` | True | | | +| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | + +| +| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | +`boolean` | | | | ## Annotation output options -| Parameter | Description | Type | Default | Required | Hidden | -| --------------------- | ----------------- | --------- | ------- | -------- | ------ | -| `braker_save_outputs` | Save BRAKER files | `boolean` | | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ---------------------------------- | --------------------------------------------- | --------- | ------- | -------- | ------ | +| `braker_save_outputs` | Save BRAKER files | `boolean` | | | | +| `add_attrs_to_proteins_cds_fastas` | Add gff attributes to proteins/cDNA/cds fasta | `boolean` | +| | | | ## Evaluation options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------ | --------------------------------------------------------------------------- | --------- | --------------- | -------- | ------ | -| `busco_skip` | Skip evaluation by BUSCO | `boolean` | | | | -| `busco_lineage_datasets` | BUSCO lineages as a space-separated list: 'fungi_odb10 microsporidia_odb10' | `string` | eukaryota_odb10 | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------ | ------------------------------------------------------ | --------------- | ------- | -------- | ------ | +| `busco_skip` | Skip evaluation by BUSCO | `boolean` | | | | +| `busco_lineage_datasets` | BUSCO lineages as a space-separated list: 'fungi_odb10 | +| microsporidia_odb10' | `string` | eukaryota_odb10 | | | ## Institutional config options Parameters used to describe centralised config profiles. These should not be edited. -| Parameter | Description | Type | Default | Required | Hidden | -| ---------------------------- | ----------------------------------------- | -------- | -------------------------------------------------------- | -------- | ------ | -| `custom_config_version` | Git commit id for Institutional configs. | `string` | master | | True | -| `custom_config_base` | Base directory for Institutional configs. | `string` | https://raw.githubusercontent.com/nf-core/configs/master | | True | -| `config_profile_name` | Institutional config name. | `string` | | | True | -| `config_profile_description` | Institutional config description. | `string` | | | True | +| Parameter | Description | Type | Default | Required | Hidden | +| -------------------------------------------------------- | ----------------------------------------- | -------- | ------- | -------- | ------ | +| `custom_config_version` | Git commit id for Institutional configs. | `string` | master | | +| True | +| `custom_config_base` | Base directory for Institutional configs. | `string` | +| https://raw.githubusercontent.com/nf-core/configs/master | | True | +| `config_profile_name` | Institutional config name. | `string` | | | True | +| `config_profile_description` | Institutional config description. | `string` | | | True | ## Generic options @@ -99,15 +116,12 @@ Less common options for the pipeline, typically set in a config file. | Parameter | Description | Type | Default | Required | Hidden | | ------------------------ | ----------------------------------------------------------------- | --------- | ------- | -------- | ------ | | `version` | Display version and exit. | `boolean` | | | True | -| `publish_dir_mode` | Method used to save pipeline results to output directory. | `string` | copy | | True | -| `email_on_fail` | Email address for completion summary, only when pipeline fails. | `string` | | | True | +| `publish_dir_mode` | Method used to save pipeline results to output directory. | `string` | +| copy | | True | +| `email_on_fail` | Email address for completion summary, only when pipeline fails. | `string` | +| | True | | `plaintext_email` | Send plain-text email instead of HTML. | `boolean` | | | True | -| `max_multiqc_email_size` | File size limit when attaching MultiQC reports to summary emails. | `string` | 25.MB | | True | +| `max_multiqc_email_size` | File size limit when attaching MultiQC reports to summary emails. | +| `string` | 25.MB | | True | | `monochrome_logs` | Do not use coloured log outputs. | `boolean` | | | True | | `hook_url` | Incoming hook URL for messaging service | `string` | | | True | - -## Other parameters - -| Parameter | Description | Type | Default | Required | Hidden | -| ----------------------------- | ----------- | --------- | ------- | -------- | ------ | -| `add_attrs_to_gffread_fastas` | | `boolean` | | | | diff --git a/nextflow_schema.json b/nextflow_schema.json index 2cc3f8d..2092f00 100644 --- a/nextflow_schema.json +++ b/nextflow_schema.json @@ -286,6 +286,11 @@ "type": "boolean", "description": "Save BRAKER files", "fa_icon": "fas fa-question-circle" + }, + "add_attrs_to_proteins_cds_fastas": { + "type": "boolean", + "description": "Add gff attributes to proteins/cDNA/cds fasta", + "fa_icon": "fas fa-question-circle" } } }, @@ -433,10 +438,5 @@ { "$ref": "#/$defs/generic_options" } - ], - "properties": { - "add_attrs_to_proteins_cds_fastas": { - "type": "boolean" - } - } + ] } From d21d70e282f7dd6a05d30706bb807813f7099d9c Mon Sep 17 00:00:00 2001 From: liamlelievre Date: Thu, 5 Dec 2024 15:00:06 +1300 Subject: [PATCH 19/35] Add attributes option for -F -D to cds and cdna --- conf/modules.config | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/conf/modules.config b/conf/modules.config index ca741e9..8e98b4f 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -297,7 +297,7 @@ process { // SUBWORKFLOW: GFF_STORE } withName: '.*:GFF_STORE:EXTRACT_CDS' { - ext.args = '-x' + ext.args = params.add_attrs_to_proteins_cds_fastas ? '-F -D -x' : '-x' ext.prefix = { "${meta.id}.cds" } publishDir = [ @@ -307,7 +307,7 @@ process { // SUBWORKFLOW: GFF_STORE ] } withName: '.*:GFF_STORE:EXTRACT_CDNA' { - ext.args = '-w' + ext.args = params.add_attrs_to_proteins_cds_fastas ? '-F -D -w' : '-w' ext.prefix = { "${meta.id}.cdna" } publishDir = [ From 9be84b246b108972b5136ab8ec555969a24e7ec3 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Thu, 5 Dec 2024 16:35:03 +1300 Subject: [PATCH 20/35] Fixed linting issues --- .github/workflows/ci.yml | 2 +- CHANGELOG.md | 2 +- docs/parameters.md | 129 ++++++++++++++++----------------------- nextflow_schema.json | 2 +- 4 files changed, 57 insertions(+), 78 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a4e5cc9..5a59fb5 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -55,7 +55,7 @@ jobs: uses: actions/checkout@v4.2.1 - name: Install Nextflow - uses: nf-core/setup-nextflow@v2 + uses: nf-core/setup-nextflow@v2.0.0 with: version: "${{ matrix.NXF_VER }}" diff --git a/CHANGELOG.md b/CHANGELOG.md index ada72ae..1e2d164 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,7 +7,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### 'Added' -1. Added cDNA and cds outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) +1. Added cDNA and CDS outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) ## v0.5.0 - [21-Nov-2024] diff --git a/docs/parameters.md b/docs/parameters.md index ef2bce2..9297c4a 100644 --- a/docs/parameters.md +++ b/docs/parameters.md @@ -4,20 +4,17 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## Input/output options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------------------------ | ------------------------------------------------------------------------ | -------- | ------- | -------- | ------ | -| `input` | Target assemblies listed in a CSV sheet | `string` | | True | | -| `protein_evidence` | Protein evidence provided as a fasta file or multiple fasta files listed | -| in a plain txt file | `string` | | True | | -| `eggnogmapper_db_dir` | Eggnogmapper database directory | `string` | | | | -| `eggnogmapper_tax_scope` | Eggnogmapper taxonomy scopre. Eukaryota: 2759, Viridiplantae: | -| 33090, Archaea: 2157, Bacteria: 2, root: 1 | `integer` | 1 | | | -| `rna_evidence` | FASTQ/BAM samples listed in a CSV sheet | `string` | | | | -| `liftoff_annotations` | Reference annotations listed in a CSV sheet | `string` | | | | -| `orthofinder_annotations` | Additional annotations for orthology listed in a CSV sheet | -| `string` | | | | -| `outdir` | The output directory where the results will be saved | `string` | | True | | -| `email` | Email address for completion summary. | `string` | | | True | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------- | -------------------------------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | +| `input` | Target assemblies listed in a CSV sheet | `string` | | True | | +| `protein_evidence` | Protein evidence provided as a fasta file or multiple fasta files listed in a plain txt file | `string` | | True | | +| `eggnogmapper_db_dir` | Eggnogmapper database directory | `string` | | | | +| `eggnogmapper_tax_scope` | Eggnogmapper taxonomy scopre. Eukaryota: 2759, Viridiplantae: 33090, Archaea: 2157, Bacteria: 2, root: 1 | `integer` | 1 | | | +| `rna_evidence` | FASTQ/BAM samples listed in a CSV sheet | `string` | | | | +| `liftoff_annotations` | Reference annotations listed in a CSV sheet | `string` | | | | +| `orthofinder_annotations` | Additional annotations for orthology listed in a CSV sheet | `string` | | | | +| `outdir` | The output directory where the results will be saved | `string` | | True | | +| `email` | Email address for completion summary. | `string` | | | True | ## Repeat annotation options @@ -30,84 +27,69 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## RNASeq pre-processing options -| Parameter | Description | Type | Default | Required | Hidden | -| ----------------------------------------- | ------------------------------------------------------------------ | --------- | ------- | -------- | ------ | -| `fastqc_skip` | Skip FASTQC or not? | `boolean` | True | | | -| `fastp_skip` | Skip trimming by FASTQP or not? | `boolean` | | | | -| `min_trimmed_reads` | Exclude a sample if its reads after trimming are below this number | -| `integer` | 10000 | | | -| `fastp_extra_args` | Extra FASTP arguments | `string` | | | | -| `save_trimmed` | Save FASTQ files after trimming or not? | `boolean` | | | | -| `remove_ribo_rna` | Remove Ribosomal RNA or not? | `boolean` | | | | -| `save_non_ribo_reads` | Save FASTQ files after Ribosomal RNA removal or not? | `boolean` | | -| | -| `ribo_database_manifest` | Ribosomal RNA fastas listed in a text sheet | `string` | -| ${projectDir}/assets/rrna-db-defaults.txt | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------ | ------------------------------------------------------------------ | --------- | ----------------------------------------- | -------- | ------ | +| `fastqc_skip` | Skip FASTQC or not? | `boolean` | True | | | +| `fastp_skip` | Skip trimming by FASTQP or not? | `boolean` | | | | +| `min_trimmed_reads` | Exclude a sample if its reads after trimming are below this number | `integer` | 10000 | | | +| `fastp_extra_args` | Extra FASTP arguments | `string` | | | | +| `save_trimmed` | Save FASTQ files after trimming or not? | `boolean` | | | | +| `remove_ribo_rna` | Remove Ribosomal RNA or not? | `boolean` | | | | +| `save_non_ribo_reads` | Save FASTQ files after Ribosomal RNA removal or not? | `boolean` | | | | +| `ribo_database_manifest` | Ribosomal RNA fastas listed in a text sheet | `string` | ${projectDir}/assets/rrna-db-defaults.txt | | | ## RNASeq alignment options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------ | ---------------------------------------- | --------- | ------- | -------- | ------ | -| `star_max_intron_length` | Maximum intron length for STAR alignment | `integer` | 16000 | | - -| -| `star_align_extra_args` | EXTRA arguments for STAR | `string` | | | | -| `star_save_outputs` | Save BAM files from STAR or not? | `boolean` | | | | -| `save_cat_bam` | SAVE a concatenated BAM file per assembly or not? | `boolean` | | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------ | ------------------------------------------------- | --------- | ------- | -------- | ------ | +| `star_max_intron_length` | Maximum intron length for STAR alignment | `integer` | 16000 | | | +| `star_align_extra_args` | EXTRA arguments for STAR | `string` | | | | +| `star_save_outputs` | Save BAM files from STAR or not? | `boolean` | | | | +| `save_cat_bam` | SAVE a concatenated BAM file per assembly or not? | `boolean` | | | | ## Annotation options -| Parameter | Description | Type | Default | Required | Hidden | -| --------------------- | ---------------------------------------------------------------- | -------- | ------- | -------- | ------ | -| `braker_extra_args` | Extra arguments for BRAKER | `string` | | | | -| `liftoff_coverage` | Liftoff coverage parameter | `number` | 0.9 | | | -| `liftoff_identity` | Liftoff identity parameter | `number` | 0.9 | | | -| `eggnogmapper_evalue` | Only report alignments below or equal the e-value threshold | `number` | -| 1e-05 | | | -| `eggnogmapper_pident` | Only report alignments above or equal to the given percentage of | -| identity (0-100) | `integer` | 35 | | | +| Parameter | Description | Type | Default | Required | Hidden | +| --------------------- | --------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | +| `braker_extra_args` | Extra arguments for BRAKER | `string` | | | | +| `liftoff_coverage` | Liftoff coverage parameter | `number` | 0.9 | | | +| `liftoff_identity` | Liftoff identity parameter | `number` | 0.9 | | | +| `eggnogmapper_evalue` | Only report alignments below or equal the e-value threshold | `number` | 1e-05 | | | +| `eggnogmapper_pident` | Only report alignments above or equal to the given percentage of identity (0-100) | `integer` | 35 | | | ## Post-annotation filtering options -| Parameter | Description | Type | Default | Required | Hidden | -| ----------------------------- | --------------------------------------------------------- | --------- | ------- | -------- | ------ | -| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | -| `enforce_full_intron_support` | Require every model to have external evidence for all its | -| introns | `boolean` | True | | | -| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | - -| -| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | -`boolean` | | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ----------------------------- | ----------------------------------------------------------------- | --------- | ------- | -------- | ------ | +| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | +| `enforce_full_intron_support` | Require every model to have external evidence for all its introns | `boolean` | True | | | +| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | | +| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | `boolean` | | | | ## Annotation output options | Parameter | Description | Type | Default | Required | Hidden | | ---------------------------------- | --------------------------------------------- | --------- | ------- | -------- | ------ | | `braker_save_outputs` | Save BRAKER files | `boolean` | | | | -| `add_attrs_to_proteins_cds_fastas` | Add gff attributes to proteins/cDNA/cds fasta | `boolean` | -| | | | +| `add_attrs_to_proteins_cds_fastas` | Add gff attributes to proteins/cDNA/CDS fasta | `boolean` | | | | ## Evaluation options -| Parameter | Description | Type | Default | Required | Hidden | -| ------------------------ | ------------------------------------------------------ | --------------- | ------- | -------- | ------ | -| `busco_skip` | Skip evaluation by BUSCO | `boolean` | | | | -| `busco_lineage_datasets` | BUSCO lineages as a space-separated list: 'fungi_odb10 | -| microsporidia_odb10' | `string` | eukaryota_odb10 | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ------------------------ | --------------------------------------------------------------------------- | --------- | --------------- | -------- | ------ | +| `busco_skip` | Skip evaluation by BUSCO | `boolean` | | | | +| `busco_lineage_datasets` | BUSCO lineages as a space-separated list: 'fungi_odb10 microsporidia_odb10' | `string` | eukaryota_odb10 | | | ## Institutional config options Parameters used to describe centralised config profiles. These should not be edited. -| Parameter | Description | Type | Default | Required | Hidden | -| -------------------------------------------------------- | ----------------------------------------- | -------- | ------- | -------- | ------ | -| `custom_config_version` | Git commit id for Institutional configs. | `string` | master | | -| True | -| `custom_config_base` | Base directory for Institutional configs. | `string` | -| https://raw.githubusercontent.com/nf-core/configs/master | | True | -| `config_profile_name` | Institutional config name. | `string` | | | True | -| `config_profile_description` | Institutional config description. | `string` | | | True | +| Parameter | Description | Type | Default | Required | Hidden | +| ---------------------------- | ----------------------------------------- | -------- | -------------------------------------------------------- | -------- | ------ | +| `custom_config_version` | Git commit id for Institutional configs. | `string` | master | | True | +| `custom_config_base` | Base directory for Institutional configs. | `string` | https://raw.githubusercontent.com/nf-core/configs/master | | True | +| `config_profile_name` | Institutional config name. | `string` | | | True | +| `config_profile_description` | Institutional config description. | `string` | | | True | ## Generic options @@ -116,12 +98,9 @@ Less common options for the pipeline, typically set in a config file. | Parameter | Description | Type | Default | Required | Hidden | | ------------------------ | ----------------------------------------------------------------- | --------- | ------- | -------- | ------ | | `version` | Display version and exit. | `boolean` | | | True | -| `publish_dir_mode` | Method used to save pipeline results to output directory. | `string` | -| copy | | True | -| `email_on_fail` | Email address for completion summary, only when pipeline fails. | `string` | -| | True | +| `publish_dir_mode` | Method used to save pipeline results to output directory. | `string` | copy | | True | +| `email_on_fail` | Email address for completion summary, only when pipeline fails. | `string` | | | True | | `plaintext_email` | Send plain-text email instead of HTML. | `boolean` | | | True | -| `max_multiqc_email_size` | File size limit when attaching MultiQC reports to summary emails. | -| `string` | 25.MB | | True | +| `max_multiqc_email_size` | File size limit when attaching MultiQC reports to summary emails. | `string` | 25.MB | | True | | `monochrome_logs` | Do not use coloured log outputs. | `boolean` | | | True | | `hook_url` | Incoming hook URL for messaging service | `string` | | | True | diff --git a/nextflow_schema.json b/nextflow_schema.json index 2092f00..b7b5cc4 100644 --- a/nextflow_schema.json +++ b/nextflow_schema.json @@ -289,7 +289,7 @@ }, "add_attrs_to_proteins_cds_fastas": { "type": "boolean", - "description": "Add gff attributes to proteins/cDNA/cds fasta", + "description": "Add gff attributes to proteins/cDNA/CDS fasta", "fa_icon": "fas fa-question-circle" } } From 767239a0e048ade192c4ce35e1314de1a2bef541 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Thu, 5 Dec 2024 16:37:20 +1300 Subject: [PATCH 21/35] Updated snapshot --- tests/short/main.nf.test.snap | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/tests/short/main.nf.test.snap b/tests/short/main.nf.test.snap index 62a4ed3..46055d1 100644 --- a/tests/short/main.nf.test.snap +++ b/tests/short/main.nf.test.snap @@ -5,11 +5,11 @@ "successful tasks": 0, "versions": { "Workflow": { - "plant-food-research-open/genepal": "v0.5.0" + "plant-food-research-open/genepal": "v0.6.0" } }, "stable paths": [ - + ] } ], @@ -17,6 +17,6 @@ "nf-test": "0.9.0", "nextflow": "24.04.4" }, - "timestamp": "2024-10-22T11:39:43.110621" + "timestamp": "2024-12-05T16:37:07.37961" } -} +} \ No newline at end of file From e04261544864039eb2a0a5584d977f43d0031df4 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Thu, 5 Dec 2024 16:39:16 +1300 Subject: [PATCH 22/35] Fixed nextflow-setup version --- .github/workflows/download_pipeline.yml | 2 +- .github/workflows/linting.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/download_pipeline.yml b/.github/workflows/download_pipeline.yml index 713dc3e..4f109b3 100644 --- a/.github/workflows/download_pipeline.yml +++ b/.github/workflows/download_pipeline.yml @@ -30,7 +30,7 @@ jobs: runs-on: ubuntu-latest steps: - name: Install Nextflow - uses: nf-core/setup-nextflow@v2 + uses: nf-core/setup-nextflow@v2.0.0 - name: Disk space cleanup uses: jlumbroso/free-disk-space@54081f138730dfa15788a46383842cd2f914a1be # v1.3.1 diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index 6bfe937..9148360 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -34,7 +34,7 @@ jobs: uses: actions/checkout@0ad4b8fadaa221de15dcec353f45205ec38ea70b # v4 - name: Install Nextflow - uses: nf-core/setup-nextflow@v2 + uses: nf-core/setup-nextflow@v2.0.0 - uses: actions/setup-python@82c7e631bb3cdc910f68e0081d67478d79c6982d # v5 with: From 43742fb84e9ec41655ac4739e6e2fa95468cbdff Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Thu, 5 Dec 2024 16:43:05 +1300 Subject: [PATCH 23/35] Fixed indent --- nextflow.config | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/nextflow.config b/nextflow.config index c91980e..363f0c5 100644 --- a/nextflow.config +++ b/nextflow.config @@ -57,7 +57,7 @@ params { // Annotation output options braker_save_outputs = false - add_attrs_to_proteins_cds_fastas = false + add_attrs_to_proteins_cds_fastas = false // Evaluation options busco_skip = false From fb9a0f4498bda66825ebbd9e0204d4cc82ef3470 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Thu, 5 Dec 2024 12:59:36 +1300 Subject: [PATCH 24/35] Fixed an issue where TSEBRA failed because LIFTOFF lifted non-protein coding genes --- .github/workflows/branch.yml | 16 +-- .github/workflows/download_pipeline.yml | 6 +- CHANGELOG.md | 14 ++- README.md | 2 +- conf/modules.config | 4 +- .../main.nf} | 66 ++++++----- .../local/fasta_liftoff/tests/main.nf.test | 105 ++++++++++++++++++ .../fasta_liftoff/tests/main.nf.test.snap | 55 +++++++++ .../local/fasta_liftoff/tests/nextflow.config | 29 +++++ .../tests/testdata/GCF_019202715.1.fna.gz | Bin 0 -> 188920 bytes .../tests/testdata/GCF_019202715.1.gff.gz | Bin 0 -> 16035 bytes .../fasta_liftoff/tests/testdata/README.md | 1 + subworkflows/local/gff_store.nf | 6 +- workflows/genepal.nf | 2 +- 14 files changed, 256 insertions(+), 50 deletions(-) rename subworkflows/local/{fasta_liftoff.nf => fasta_liftoff/main.nf} (76%) create mode 100644 subworkflows/local/fasta_liftoff/tests/main.nf.test create mode 100644 subworkflows/local/fasta_liftoff/tests/main.nf.test.snap create mode 100644 subworkflows/local/fasta_liftoff/tests/nextflow.config create mode 100644 subworkflows/local/fasta_liftoff/tests/testdata/GCF_019202715.1.fna.gz create mode 100644 subworkflows/local/fasta_liftoff/tests/testdata/GCF_019202715.1.gff.gz create mode 100644 subworkflows/local/fasta_liftoff/tests/testdata/README.md diff --git a/.github/workflows/branch.yml b/.github/workflows/branch.yml index d1d686b..2980b4f 100644 --- a/.github/workflows/branch.yml +++ b/.github/workflows/branch.yml @@ -1,15 +1,15 @@ name: nf-core branch protection -# This workflow is triggered on PRs to master branch on the repository -# It fails when someone tries to make a PR against the nf-core `master` branch instead of `dev` +# This workflow is triggered on PRs to main branch on the repository +# It fails when someone tries to make a PR against the Plant-Food-Research-Open `main` branch instead of `dev` on: pull_request_target: - branches: [master] + branches: [main] jobs: test: runs-on: ubuntu-latest steps: - # PRs to the nf-core repo master branch are only ok if coming from the nf-core repo `dev` or any `patch` branches + # PRs to the nf-core repo main branch are only ok if coming from the nf-core repo `dev` or any `patch` branches - name: Check PRs if: github.repository == 'Plant-Food-Research-Open/genepal' run: | @@ -22,7 +22,7 @@ jobs: uses: mshick/add-pr-comment@b8f338c590a895d50bcbfa6c5859251edc8952fc # v2 with: message: | - ## This PR is against the `master` branch :x: + ## This PR is against the `main` branch :x: * Do not close this PR * Click _Edit_ and change the `base` to `dev` @@ -32,9 +32,9 @@ jobs: Hi @${{ github.event.pull_request.user.login }}, - It looks like this pull-request is has been made against the [${{github.event.pull_request.head.repo.full_name }}](https://github.com/${{github.event.pull_request.head.repo.full_name }}) `master` branch. - The `master` branch on nf-core repositories should always contain code from the latest release. - Because of this, PRs to `master` are only allowed if they come from the [${{github.event.pull_request.head.repo.full_name }}](https://github.com/${{github.event.pull_request.head.repo.full_name }}) `dev` branch. + It looks like this pull-request is has been made against the [${{github.event.pull_request.head.repo.full_name }}](https://github.com/${{github.event.pull_request.head.repo.full_name }}) `main` branch. + The `main` branch should always contain code from the latest release. + Because of this, PRs to `main` are only allowed if they come from the [${{github.event.pull_request.head.repo.full_name }}](https://github.com/${{github.event.pull_request.head.repo.full_name }}) `dev` branch. You do not need to close this PR, you can change the target branch to `dev` by clicking the _"Edit"_ button at the top of this page. Note that even after this, the test will continue to show as failing until you push a new commit. diff --git a/.github/workflows/download_pipeline.yml b/.github/workflows/download_pipeline.yml index 4f109b3..845b6ad 100644 --- a/.github/workflows/download_pipeline.yml +++ b/.github/workflows/download_pipeline.yml @@ -2,7 +2,7 @@ name: Test successful pipeline download with 'nf-core pipelines download' # Run the workflow when: # - dispatched manually -# - when a PR is opened or reopened to master branch +# - when a PR is opened or reopened to main branch # - the head branch of the pull request is updated, i.e. if fixes for a release are pushed last minute to dev. on: workflow_dispatch: @@ -17,10 +17,10 @@ on: - edited - synchronize branches: - - master + - main pull_request_target: branches: - - master + - main env: NXF_ANSI_LOG: false diff --git a/CHANGELOG.md b/CHANGELOG.md index 1e2d164..8d588ec 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,12 +3,24 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). -## v0.6.0 - [4-Dec-2024] +## v0.6.0 - [6-Dec-2024] ### 'Added' 1. Added cDNA and CDS outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) +### `Fixed` + +1. Fixed an issue where TSEBRA failed because LIFTOFF lifted non-protein coding genes [#121](https://github.com/Plant-Food-Research-Open/genepal/issues/121) +2. Switched branch name from `master` to `main` in the GHA CIs + +### `Dependencies` + +1. Nextflow!>=24.04.2 +2. nf-schema@2.1.1 + +### `Deprecated` + ## v0.5.0 - [21-Nov-2024] ### `Added` diff --git a/README.md b/README.md index 0cc92ea..51f3a3e 100644 --- a/README.md +++ b/README.md @@ -35,7 +35,7 @@ - Merge multi-reference liftoffs - Remove liftoff transcripts marked by _valid_ORF=False_ - Remove liftoff genes with any intron shorter than 10 bp - - Remove rRNA and tRNA from liftoff + - Remove rRNA, tRNA and other non-protein coding models from liftoff - Optionally, allow or remove iso-forms - Remove BRAKER models from Liftoff loci - Merge Liftoff and BRAKER models diff --git a/conf/modules.config b/conf/modules.config index 8e98b4f..44e6123 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -199,7 +199,7 @@ process { // SUBWORKFLOW: FASTA_LIFTOFF } withName: '.*:FASTA_LIFTOFF:GFFREAD_BEFORE_LIFTOFF' { - ext.args = '--no-pseudo --keep-genes' + ext.args = '--no-pseudo --keep-genes -C' } withName: '.*:FASTA_LIFTOFF:MERGE_LIFTOFF_ANNOTATIONS' { @@ -212,7 +212,7 @@ process { // SUBWORKFLOW: FASTA_LIFTOFF withName: '.*:FASTA_LIFTOFF:GFFREAD_AFTER_LIFTOFF' { ext.prefix = { "${meta.id}.liftoff" } - ext.args = '--keep-genes' + ext.args = '--no-pseudo --keep-genes -C' } withName: '.*:FASTA_LIFTOFF:GFF_TSEBRA_SPFILTERFEATUREFROMKILLLIST:AGAT_CONVERTSPGFF2GTF' { diff --git a/subworkflows/local/fasta_liftoff.nf b/subworkflows/local/fasta_liftoff/main.nf similarity index 76% rename from subworkflows/local/fasta_liftoff.nf rename to subworkflows/local/fasta_liftoff/main.nf index 0da2949..d1d818f 100644 --- a/subworkflows/local/fasta_liftoff.nf +++ b/subworkflows/local/fasta_liftoff/main.nf @@ -1,22 +1,22 @@ -include { GUNZIP as GUNZIP_FASTA } from '../../modules/nf-core/gunzip/main' -include { GUNZIP as GUNZIP_GFF } from '../../modules/nf-core/gunzip/main' -include { GFFREAD as GFFREAD_BEFORE_LIFTOFF } from '../../modules/nf-core/gffread/main' -include { LIFTOFF } from '../../modules/nf-core/liftoff/main' -include { AGAT_SPMERGEANNOTATIONS as MERGE_LIFTOFF_ANNOTATIONS } from '../../modules/nf-core/agat/spmergeannotations/main' -include { AGAT_SPFLAGSHORTINTRONS } from '../../modules/gallvp/agat/spflagshortintrons/main' -include { AGAT_SPFILTERFEATUREFROMKILLLIST } from '../../modules/nf-core/agat/spfilterfeaturefromkilllist/main' -include { GFFREAD as GFFREAD_AFTER_LIFTOFF } from '../../modules/nf-core/gffread/main' -include { GFF_TSEBRA_SPFILTERFEATUREFROMKILLLIST } from '../../subworkflows/local/gff_tsebra_spfilterfeaturefromkilllist' +include { GUNZIP as GUNZIP_FASTA } from '../../../modules/nf-core/gunzip/main' +include { GUNZIP as GUNZIP_GFF } from '../../../modules/nf-core/gunzip/main' +include { GFFREAD as GFFREAD_BEFORE_LIFTOFF } from '../../../modules/nf-core/gffread/main' +include { LIFTOFF } from '../../../modules/nf-core/liftoff/main' +include { AGAT_SPMERGEANNOTATIONS as MERGE_LIFTOFF_ANNOTATIONS } from '../../../modules/nf-core/agat/spmergeannotations/main' +include { AGAT_SPFLAGSHORTINTRONS } from '../../../modules/gallvp/agat/spflagshortintrons/main' +include { AGAT_SPFILTERFEATUREFROMKILLLIST } from '../../../modules/nf-core/agat/spfilterfeaturefromkilllist/main' +include { GFFREAD as GFFREAD_AFTER_LIFTOFF } from '../../../modules/nf-core/gffread/main' +include { GFF_TSEBRA_SPFILTERFEATUREFROMKILLLIST } from '../../../subworkflows/local/gff_tsebra_spfilterfeaturefromkilllist' workflow FASTA_LIFTOFF { take: - target_assemby // Channel: [ meta, fasta ] - xref_fasta // Channel: [ meta2, fasta ] - xref_gff // Channel: [ meta2, gff3 ] + target_assembly // Channel: [ meta, fasta ] + xref_fasta // Channel: [ meta2, fasta(.gz)? ] + xref_gff // Channel: [ meta2, gff3(.gz)? ] val_filter_liftoff_by_hints // val(true|false) braker_hints // [ meta, gff ] tsebra_config // Channel: [ cfg ] - allow_isoforms // val(true|false) + val_allow_isoforms // val(true|false) main: @@ -24,7 +24,7 @@ workflow FASTA_LIFTOFF { // MODULE: GUNZIP as GUNZIP_FASTA ch_xref_fasta_branch = xref_fasta - | branch { meta, file -> + | branch { _meta, file -> gz: "$file".endsWith(".gz") rest: !"$file".endsWith(".gz") } @@ -40,7 +40,7 @@ workflow FASTA_LIFTOFF { // MODULE: GUNZIP as GUNZIP_GFF ch_xref_gff_branch = xref_gff - | branch { meta, file -> + | branch { _meta, file -> gz: "$file".endsWith(".gz") rest: !"$file".endsWith(".gz") } @@ -61,7 +61,7 @@ workflow FASTA_LIFTOFF { ch_versions = ch_versions.mix(GFFREAD_BEFORE_LIFTOFF.out.versions.first()) // MODULE: LIFTOFF - ch_liftoff_inputs = target_assemby + ch_liftoff_inputs = target_assembly | combine( ch_xref_gunzip_fasta | join( @@ -72,7 +72,7 @@ workflow FASTA_LIFTOFF { [ [ id: "${meta.id}.from.${ref_meta.id}", - target_assemby: meta.id + target_assembly: meta.id ], target_fa, ref_fa, @@ -81,21 +81,21 @@ workflow FASTA_LIFTOFF { } LIFTOFF( - ch_liftoff_inputs.map { meta, target_fa, ref_fa, ref_gff -> [ meta, target_fa ] }, - ch_liftoff_inputs.map { meta, target_fa, ref_fa, ref_gff -> ref_fa }, - ch_liftoff_inputs.map { meta, target_fa, ref_fa, ref_gff -> ref_gff }, + ch_liftoff_inputs.map { meta, target_fa, _ref_fa, _ref_gff -> [ meta, target_fa ] }, + ch_liftoff_inputs.map { _meta, _target_fa, ref_fa, _ref_gff -> ref_fa }, + ch_liftoff_inputs.map { _meta, _target_fa, _ref_fa, ref_gff -> ref_gff }, [] ) ch_liftoff_gff3 = LIFTOFF.out.polished_gff3 - | map { meta, gff -> [ [ id: meta.target_assemby ], gff ] } + | map { meta, gff -> [ [ id: meta.target_assembly ], gff ] } | groupTuple ch_versions = ch_versions.mix(LIFTOFF.out.versions.first()) // MODULE: AGAT_SPMERGEANNOTATIONS as MERGE_LIFTOFF_ANNOTATIONS ch_merge_inputs = ch_liftoff_gff3 - | branch { meta, list_polished -> + | branch { _meta, list_polished -> one: list_polished.size() == 1 many: list_polished.size() > 1 } @@ -119,23 +119,29 @@ workflow FASTA_LIFTOFF { ch_flagged_gff = AGAT_SPFLAGSHORTINTRONS.out.gff ch_versions = ch_versions.mix(AGAT_SPFLAGSHORTINTRONS.out.versions.first()) - // COLLECTFILE: Kill list for valid_ORF=False transcripts - // tRNA, rRNA - // gene with any intron marked as 'pseudo=' by AGAT/SPFLAGSHORTINTRONS + // collectFile: Kill list for valid_ORF=False transcripts + // tRNA, rRNA, gene with any intron marked as + // 'pseudo=' by AGAT/SPFLAGSHORTINTRONS ch_kill_list = ch_flagged_gff | map { meta, gff -> def tx_from_gff = gff.readLines() .findAll { it -> + // Can't add to kill list if ( it.startsWith('#') ) { return false } def cols = it.split('\t') def feat = cols[2] - if ( feat in [ 'tRNA', 'rRNA' ] ) { return true } - if ( feat !in [ 'transcript', 'mRNA', 'gene' ] ) { return false } + // Add to kill list anything other than standard features + if ( feat !in [ 'gene', 'transcript', 'mRNA', 'exon', 'CDS', 'five_prime_UTR', 'three_prime_UTR' ] ) { return true } + + // Ignore [ 'exon', 'CDS', 'five_prime_UTR', 'three_prime_UTR' ] + if ( feat !in [ 'gene', 'transcript', 'mRNA' ] ) { return false } def attrs = cols[8] + + // Add [ 'gene', 'transcript', 'mRNA' ] with 'valid_ORF=False' or 'pseudo=' attributes to kill list ( attrs.contains('valid_ORF=False') || attrs.contains('pseudo=') ) } .collect { @@ -160,8 +166,8 @@ workflow FASTA_LIFTOFF { AGAT_SPFILTERFEATUREFROMKILLLIST( - ch_agat_kill_inputs.map { meta, gff, kill -> [ meta, gff ] }, - ch_agat_kill_inputs.map { meta, gff, kill -> kill }, + ch_agat_kill_inputs.map { meta, gff, _kill -> [ meta, gff ] }, + ch_agat_kill_inputs.map { _meta, _gff, kill -> kill }, [] // default config ) @@ -179,7 +185,7 @@ workflow FASTA_LIFTOFF { val_filter_liftoff_by_hints ? ch_attr_trimmed_gff : Channel.empty(), braker_hints, tsebra_config, - allow_isoforms, + val_allow_isoforms, 'liftoff' ) diff --git a/subworkflows/local/fasta_liftoff/tests/main.nf.test b/subworkflows/local/fasta_liftoff/tests/main.nf.test new file mode 100644 index 0000000..dabc023 --- /dev/null +++ b/subworkflows/local/fasta_liftoff/tests/main.nf.test @@ -0,0 +1,105 @@ +nextflow_workflow { + + name "Test Subworkflow FASTA_LIFTOFF" + script "../main.nf" + workflow "FASTA_LIFTOFF" + config './nextflow.config' + + tag "subworkflows" + tag "subworkflows_gallvp" + tag "subworkflows/fasta_liftoff" + tag "subworkflows/gff_tsebra_spfilterfeaturefromkilllist" + + tag "gunzip" + tag "gffread" + tag "liftoff" + tag "agat" + tag "agat/spmergeannotations" + tag "agat/spflagshortintrons" + tag "agat/spfilterfeaturefromkilllist" + + setup { + run('GUNZIP', alias: 'GUNZIP_GENOME_FASTA') { + script "../../../../modules/nf-core/gunzip" + + process { + """ + input[0] = [ + [ id:'test' ], + file(params.modules_testdata_base_path + 'genomics/eukaryotes/actinidia_chinensis/genome/chr1/genome.fasta.gz', checkIfExists: true) + ] + """ + } + } + + run('GUNZIP', alias: 'GUNZIP_BRAKER_HINTS') { + script "../../../../modules/nf-core/gunzip" + + process { + """ + input[0] = [ + [ id:'test' ], + file(params.modules_testdata_base_path + 'genomics/eukaryotes/actinidia_chinensis/genome/chr1/genome.hints.gff.gz', checkIfExists: true) + ] + """ + } + } + } + + + test("liftoff - GCF_019202715 - to - actinidia_chinensis") { + + when { + workflow { + """ + input[0] = GUNZIP_GENOME_FASTA.out.gunzip + + input[1] = Channel.of([ + [ id:'ref' ], + file ( "${baseDir}/subworkflows/local/fasta_liftoff/tests/testdata/GCF_019202715.1.fna.gz", checkIfExists: true ) + ]) + input[2] = Channel.of([ + [ id:'ref' ], + file ( "${baseDir}/subworkflows/local/fasta_liftoff/tests/testdata/GCF_019202715.1.gff.gz", checkIfExists: true ) + ]) + + input[3] = true // val_filter_liftoff_by_hints + + input[4] = GUNZIP_BRAKER_HINTS.out.gunzip + + input[5] = Channel.of ( file("${baseDir}/assets/tsebra-template.cfg", checkIfExists: true) ) + | map { cfg -> + def enforce_full_intron_support = true + def param_intron_support = enforce_full_intron_support ? '1.0' : '0.0' + + def param_e1 = params.allow_isoforms ? '0.1' : '0.0' + def param_e2 = params.allow_isoforms ? '0.5' : '0.0' + def param_e3 = params.allow_isoforms ? '0.05' : '0.0' + def param_e4 = params.allow_isoforms ? '0.2' : '0.0' + + [ + 'tsebra-config.cfg', + cfg + .text + .replace('PARAM_INTRON_SUPPORT', param_intron_support) + .replace('PARAM_E1', param_e1) + .replace('PARAM_E2', param_e2) + .replace('PARAM_E3', param_e3) + .replace('PARAM_E4', param_e4) + ] + } + | collectFile + + input[6] = false // val_allow_isoforms + """ + } + } + + then { + assertAll( + { assert workflow.success}, + { assert snapshot(workflow.out).match()} + ) + } + } +} diff --git a/subworkflows/local/fasta_liftoff/tests/main.nf.test.snap b/subworkflows/local/fasta_liftoff/tests/main.nf.test.snap new file mode 100644 index 0000000..2270b36 --- /dev/null +++ b/subworkflows/local/fasta_liftoff/tests/main.nf.test.snap @@ -0,0 +1,55 @@ +{ + "liftoff - GCF_019202715 - to - actinidia_chinensis": { + "content": [ + { + "0": [ + [ + { + "id": "test" + }, + "test.gff:md5,b2b6a54f44df1dc2a324e7c448f8703c" + ] + ], + "1": [ + "versions.yml:md5,19d093420a74661d71e3690828949796", + "versions.yml:md5,1b4c11d661d6f5415fba4c381299308b", + "versions.yml:md5,1cafcdb9de6b733da7979604133eae25", + "versions.yml:md5,3fa77145c369d5322ea24769c9222947", + "versions.yml:md5,441fcf0a52433b408072a27ece6ae016", + "versions.yml:md5,4cee921a63318a115b0b4ea63545efc4", + "versions.yml:md5,7a863df1624e9daeb1065a18723a7181", + "versions.yml:md5,7ce16ccb5b6a919500779dac3a3476cc", + "versions.yml:md5,90f389011e267060373c0e2810d6ca0f", + "versions.yml:md5,c1f60e3da5457e968b8689d5e43ebdac", + "versions.yml:md5,ee651692163b338557acdd094a5d2bb8" + ], + "gff3": [ + [ + { + "id": "test" + }, + "test.gff:md5,b2b6a54f44df1dc2a324e7c448f8703c" + ] + ], + "versions": [ + "versions.yml:md5,19d093420a74661d71e3690828949796", + "versions.yml:md5,1b4c11d661d6f5415fba4c381299308b", + "versions.yml:md5,1cafcdb9de6b733da7979604133eae25", + "versions.yml:md5,3fa77145c369d5322ea24769c9222947", + "versions.yml:md5,441fcf0a52433b408072a27ece6ae016", + "versions.yml:md5,4cee921a63318a115b0b4ea63545efc4", + "versions.yml:md5,7a863df1624e9daeb1065a18723a7181", + "versions.yml:md5,7ce16ccb5b6a919500779dac3a3476cc", + "versions.yml:md5,90f389011e267060373c0e2810d6ca0f", + "versions.yml:md5,c1f60e3da5457e968b8689d5e43ebdac", + "versions.yml:md5,ee651692163b338557acdd094a5d2bb8" + ] + } + ], + "meta": { + "nf-test": "0.9.0", + "nextflow": "24.04.4" + }, + "timestamp": "2024-12-05T12:49:44.433235" + } +} \ No newline at end of file diff --git a/subworkflows/local/fasta_liftoff/tests/nextflow.config b/subworkflows/local/fasta_liftoff/tests/nextflow.config new file mode 100644 index 0000000..6a94503 --- /dev/null +++ b/subworkflows/local/fasta_liftoff/tests/nextflow.config @@ -0,0 +1,29 @@ +process { + + withName: 'FASTA_LIFTOFF:GFFREAD_BEFORE_LIFTOFF' { + ext.args = '--no-pseudo --keep-genes -C' + } + + withName: 'FASTA_LIFTOFF:LIFTOFF' { + ext.args = [ + '-exclude_partial', + '-copies', + '-polish', + "-a 0.9", + "-s 0.9" + ].join(' ').trim() + } + + withName: 'FASTA_LIFTOFF:AGAT_SPFILTERFEATUREFROMKILLLIST' { + ext.prefix = { "${meta.id}.invalid.orf.purged" } + } + + withName: 'FASTA_LIFTOFF:GFFREAD_AFTER_LIFTOFF' { + ext.prefix = { "${meta.id}.liftoff" } + ext.args = '--no-pseudo --keep-genes -C' + } + + withName: 'FASTA_LIFTOFF:GFF_TSEBRA_SPFILTERFEATUREFROMKILLLIST:AGAT_CONVERTSPGFF2GTF' { + ext.args = '--gtf_version relax' + } +} diff --git a/subworkflows/local/fasta_liftoff/tests/testdata/GCF_019202715.1.fna.gz b/subworkflows/local/fasta_liftoff/tests/testdata/GCF_019202715.1.fna.gz new file mode 100644 index 0000000000000000000000000000000000000000..bf37bd97f4b2af88a8fc35ee297e5212b16c06db GIT binary patch literal 188920 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

#=Uq@S;Wa@pVj85@~n97>9vCN_uTp-Km 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

Se6TK7WH3?zn8C!Ngxeb~1cN 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%0ApA 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%0DD5e7m&6A(lY%E8e36n4TVuTQ-ZE|`8r6|V z-Z}r00=t`TV>8u`Vf6doN=r2vi_%Um4~=YD4#vIGUfVVGq%ZWWCM0PULdmNFB*zOP__p~U0j}a-!M2K~lqHn8 z>{zta7a?L~bDObf)#agc@hC`Gj(54`WopaFeU6Wwb&ot#-jg0hMs!ThNxDqUKvpa% z;Zl_(X*4B$J3+p@6Fc0Df3H-KDw&>jkUUe-lOAo<>_1RM(aW4m(IR?QSRL<}l=SL+ zvb|DUZxwphUy%w@=i>z1>E6&6Ie3`Uo)`K*`B;g!CPchuFyew`6c0LGsd|kZsWX$W zW)q=JdsEF6r{ttCkzurw_#i+THcUO4{oTKyoOD?ZTD4+Ig#AwSB)&{SNZmnc(!}We zAL$@IR!F;|p$!f=7XyZ|9PwDlZF*0>AV+b2x%j*N6!zHYKca*GisDeiING=)PZzuZ zAtuW+MxZ>~Co2*8`(;n}xi3vJ5OeEim#|UMH_0H1C8#CI;(Y!(vK8g9OxUU-;WbHMvIe{FDb-|Opz zW7lsMmg=;jFTa0R*E&!C6HiKt+=)*D6W?gZeKzW@F3x$ zxH{ho0t7s}9EU_<(Y928&^tlpI?_DJ7G~TEM}4wG+&qVUbYg#AgLl%BCn`Up*nPm` z!6E$#IJ;QVrm8E^RDXhE;Sk`+8AoUnR9BR;35uK&9O3JOeh1rC)@_6_AVVRP>!>Ge zT&gKBiW@G)Facz-Egq;vkp&Q$da6+xo>9fPjPD=3x5dL`O?TN-rOeo#mfX#FW3?!r z9x_bjL}4&IZ|jE`7_f7SQi-lQnfSl$E;r?Nr-uT$@7`@2q~%@K)9H-V?PT+bv#td3 z;_n(5Uq-lmp5c$fF-uFAnBn-(li@#43dl1oeSxgwRh1la^Y~s&(|qhu{T15&@#-$; zw*FT3!+E_dB?s6%RnlyAoFPU!C|v_N(LPi0A}lvkseHlh(;bmc8E2U=T?-H`{Se|# zGwnT1PaFMOFUEfI^H+g`+V>=U^rzgMm)nWxHz_CslK~#9RQAPZOxsz!%5YWgd)69-eQ0;a5Rs@uLf9T^4QoLdI6}UMy zZu$MgU!NKBe#q0o9WX7n&nmwY`l$tUIs(^cK4-LFb@qgQg@aMY6C_BqX0{c6C4d&j zZ6{Xd0D8+w67&|kK7<*y%xiO-zHlF-*AQtsK*Fh@0^wlHgONcNdI&_2U*;GxPEpw@Dx|={MT%7%FYpg*pZrXM=f^x^ypRVyj9oIbx3_d4{nbu`l)c!lhASf*a)DqAl- zBvxS&= Date: Thu, 5 Dec 2024 13:36:49 +1300 Subject: [PATCH 25/35] Updated snapshots --- tests/minimal/main.nf.test.snap | 2 +- tests/short/main.nf.test.snap | 4 ++-- tests/stub/main.nf.test.snap | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/tests/minimal/main.nf.test.snap b/tests/minimal/main.nf.test.snap index b1f61c8..48dae90 100644 --- a/tests/minimal/main.nf.test.snap +++ b/tests/minimal/main.nf.test.snap @@ -96,4 +96,4 @@ }, "timestamp": "2024-12-05T07:51:43.818374" } -} \ No newline at end of file +} diff --git a/tests/short/main.nf.test.snap b/tests/short/main.nf.test.snap index 46055d1..7bba642 100644 --- a/tests/short/main.nf.test.snap +++ b/tests/short/main.nf.test.snap @@ -9,7 +9,7 @@ } }, "stable paths": [ - + ] } ], @@ -19,4 +19,4 @@ }, "timestamp": "2024-12-05T16:37:07.37961" } -} \ No newline at end of file +} diff --git a/tests/stub/main.nf.test.snap b/tests/stub/main.nf.test.snap index 3d3949b..4516d50 100644 --- a/tests/stub/main.nf.test.snap +++ b/tests/stub/main.nf.test.snap @@ -207,4 +207,4 @@ }, "timestamp": "2024-12-05T07:56:38.915238" } -} \ No newline at end of file +} From 7d1f3185e9578d5a33837c01e355d6cf253909ff Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Fri, 6 Dec 2024 10:36:58 +1300 Subject: [PATCH 26/35] Updated changelog --- CHANGELOG.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8d588ec..93c3522 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### 'Added' 1. Added cDNA and CDS outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) +2. Added parameter `add_attrs_to_proteins_cds_fastas` ### `Fixed` @@ -21,6 +22,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### `Deprecated` +1. Removed parameter `add_attrs_to_proteins_fasta` + ## v0.5.0 - [21-Nov-2024] ### `Added` From b9b7d376a4fc683741c2645904db5d18d06cdfed Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Tue, 10 Dec 2024 15:34:55 +1300 Subject: [PATCH 27/35] Fixed issues in genepal-report --- CHANGELOG.md | 4 +++- bin/genepal_report.Rmd | 29 +++++++++++++++++++++++++---- conf/base.config | 3 +++ 3 files changed, 31 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 93c3522..e4d0ca6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,7 +3,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). -## v0.6.0 - [6-Dec-2024] +## v0.6.0 - [10-Dec-2024] ### 'Added' @@ -14,6 +14,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 1. Fixed an issue where TSEBRA failed because LIFTOFF lifted non-protein coding genes [#121](https://github.com/Plant-Food-Research-Open/genepal/issues/121) 2. Switched branch name from `master` to `main` in the GHA CIs +3. Fixed an issue in `genepal_report.Rmd` which caused the pangene matrix plot to fail when the number of clusters exceeded 65536 [#124](https://github.com/Plant-Food-Research-Open/genepal/issues/124) +4. Fixed an issue where `GENEPALREPORT` process failed due to OOM kill signal from SLURM [#123](https://github.com/Plant-Food-Research-Open/genepal/issues/123) ### `Dependencies` diff --git a/bin/genepal_report.Rmd b/bin/genepal_report.Rmd index d85ee12..5d0ac38 100755 --- a/bin/genepal_report.Rmd +++ b/bin/genepal_report.Rmd @@ -190,22 +190,43 @@ cat("
") ```{r pheatmap, eval=(exists("n0_df") && !is.null(n0_df$heatmap)), results='hide', fig.align='center', fig.cap="Heatmap showing number of proteins present in each orthocluster (clusters where all individuals have 1 copy are excluded). Columns = Orthologue cluster, Row = Individual", fig.width=7, fig.height=7, dpi=150, warning=FALSE} -pheatmap(n0_df$heatmap, + +# Max 65536 allowed +# https://github.com/Plant-Food-Research-Open/genepal/issues/124 + +n_cols <- ncol(n0_df$heatmap) +max_cols_allowed <- min(n_cols, 5000) + +# Approach 1: Random selection of columns +# selected_cols <- sample(n_cols, max_cols_allowed) + +# Approach 2: First N largest clusters +selected_cols <- order(colSums(n0_df$heatmap), decreasing = TRUE)[seq(1, max_cols_allowed)] + +prefix_text <- "" + +if ( n_cols != max_cols_allowed ) { + prefix_text <- paste0("Top ", max_cols_allowed, " ") +} + +pheatmap(n0_df$heatmap[, selected_cols], show_colnames = FALSE, - main = "Orthologue clusters containing accessory proteins", + main = paste0(prefix_text, "Orthologue clusters"), legend = TRUE, legend_labels = TRUE, border_color = "white" ) -pheatmap(n0_df$heatmap, +pheatmap(n0_df$heatmap[, selected_cols], filename = file.path(outputs_folder, "pangene.matrix.heatmap.pdf"), show_colnames = FALSE, - main = "Orthologue clusters containing accessory proteins", + main = paste0(prefix_text, "Orthologue clusters"), legend = TRUE, legend_labels = TRUE, border_color = "white" ) + +write.csv(x = transform_hogs(n0o), file = file.path(outputs_folder, "pangenome.matrix.csv"), row.names = FALSE) ``` diff --git a/conf/base.config b/conf/base.config index d0173d1..408a69d 100644 --- a/conf/base.config +++ b/conf/base.config @@ -74,4 +74,7 @@ process { cpus = { 8 * task.attempt } time = { 7.days * task.attempt } } + withName:GENEPALREPORT { + memory = { 20.GB * task.attempt } + } } From 3114adb0783494b4ebf36e3ada9c66ce2d90a15f Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Tue, 10 Dec 2024 21:09:25 +1300 Subject: [PATCH 28/35] Added parameter filter_genes_by_aa_length --- CHANGELOG.md | 1 + README.md | 1 + conf/modules.config | 4 + docs/output.md | 4 +- docs/parameters.md | 13 +-- modules.json | 5 + .../agat/spfilterbyorfsize/environment.yml | 7 ++ modules/gallvp/agat/spfilterbyorfsize/main.nf | 60 +++++++++++ .../gallvp/agat/spfilterbyorfsize/meta.yml | 67 ++++++++++++ .../agat/spfilterbyorfsize/tests/main.nf.test | 62 +++++++++++ .../spfilterbyorfsize/tests/main.nf.test.snap | 100 ++++++++++++++++++ nextflow.config | 1 + nextflow_schema.json | 7 ++ subworkflows/local/gff_merge_cleanup.nf | 23 +++- workflows/genepal.nf | 3 +- 15 files changed, 345 insertions(+), 13 deletions(-) create mode 100644 modules/gallvp/agat/spfilterbyorfsize/environment.yml create mode 100644 modules/gallvp/agat/spfilterbyorfsize/main.nf create mode 100644 modules/gallvp/agat/spfilterbyorfsize/meta.yml create mode 100644 modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test create mode 100644 modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap diff --git a/CHANGELOG.md b/CHANGELOG.md index e4d0ca6..33813b7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 1. Added cDNA and CDS outputs to /annotations/ directory [#118](https://github.com/Plant-Food-Research-Open/genepal/issues/118) 2. Added parameter `add_attrs_to_proteins_cds_fastas` +3. Added parameter `filter_genes_by_aa_length` with default set to `24` which allows removal of genes with ORFs shorter than 24 [#125](https://github.com/Plant-Food-Research-Open/genepal/issues/125) ### `Fixed` diff --git a/README.md b/README.md index 51f3a3e..177e8f5 100644 --- a/README.md +++ b/README.md @@ -39,6 +39,7 @@ - Optionally, allow or remove iso-forms - Remove BRAKER models from Liftoff loci - Merge Liftoff and BRAKER models + - Optionally, remove models with ORFs shorter than `N` amino acids - Optionally, remove models without any EggNOG-mapper hits - [EggNOG-mapper](https://github.com/eggnogdb/eggnog-mapper): Add functional annotation to gff - [GenomeTools](https://github.com/genometools/genometools): GFF format validation diff --git a/conf/modules.config b/conf/modules.config index 44e6123..fbb5f52 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -240,6 +240,10 @@ process { // SUBWORKFLOW: GFF_MERGE_CLEANUP ext.prefix = { "${meta.id}.liftoff.braker" } } + withName: '.*:GFF_MERGE_CLEANUP:AGAT_SPFILTERBYORFSIZE' { + ext.args = params.filter_genes_by_aa_length ? "-s ${params.filter_genes_by_aa_length}" : '' + } + withName: '.*:GFF_MERGE_CLEANUP:GT_GFF3' { ext.args = '-tidy -retainids -sort' } diff --git a/docs/output.md b/docs/output.md index f4793b5..40b546c 100644 --- a/docs/output.md +++ b/docs/output.md @@ -169,8 +169,8 @@ If more than one genome is included in the pipeline, [ORTHOFINDER](https://githu - `Y/` - `Y.gt.gff3`: Final annotation file for genome `Y` which contains gene models and their functional annotations - `Y.pep.fasta`: Protein sequences for the gene models - - 'Y.cdna.fasta': cDNA sequences for the gene models - - 'Y.cds.fasta': Coding sequences for the gene models + - `Y.cdna.fasta`: cDNA sequences for the gene models + - `Y.cds.fasta`: Coding sequences for the gene models diff --git a/docs/parameters.md b/docs/parameters.md index 9297c4a..0c2bb09 100644 --- a/docs/parameters.md +++ b/docs/parameters.md @@ -59,12 +59,13 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## Post-annotation filtering options -| Parameter | Description | Type | Default | Required | Hidden | -| ----------------------------- | ----------------------------------------------------------------- | --------- | ------- | -------- | ------ | -| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | -| `enforce_full_intron_support` | Require every model to have external evidence for all its introns | `boolean` | True | | | -| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | | -| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | `boolean` | | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ----------------------------- | -------------------------------------------------------------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | +| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | +| `enforce_full_intron_support` | Require every model to have external evidence for all its introns | `boolean` | True | | | +| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | | +| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | `boolean` | | | | +| `filter_genes_by_aa_length` | Filter genes with open reading frames shorter than the specified number of amino acids. If set to `null`, this filter step is skipped. | `integer` | 24 | | | ## Annotation output options diff --git a/modules.json b/modules.json index da05f16..6b9d74a 100644 --- a/modules.json +++ b/modules.json @@ -15,6 +15,11 @@ "git_sha": "a8939d36280e7d9037c7cf164eeede19e46546a4", "installed_by": ["gxf_fasta_agat_spaddintrons_spextractsequences"] }, + "agat/spfilterbyorfsize": { + "branch": "main", + "git_sha": "a0054cdffbd84f002fb6582b28575b699e01098e", + "installed_by": ["modules"] + }, "agat/spflagshortintrons": { "branch": "main", "git_sha": "d8f08700c82a3bd14811a3dfe7e7d63838130693", diff --git a/modules/gallvp/agat/spfilterbyorfsize/environment.yml b/modules/gallvp/agat/spfilterbyorfsize/environment.yml new file mode 100644 index 0000000..2c3daab --- /dev/null +++ b/modules/gallvp/agat/spfilterbyorfsize/environment.yml @@ -0,0 +1,7 @@ +--- +# yaml-language-server: $schema=https://raw.githubusercontent.com/nf-core/modules/master/modules/environment-schema.json +channels: + - conda-forge + - bioconda +dependencies: + - "bioconda::agat=1.4.2" diff --git a/modules/gallvp/agat/spfilterbyorfsize/main.nf b/modules/gallvp/agat/spfilterbyorfsize/main.nf new file mode 100644 index 0000000..502a9cd --- /dev/null +++ b/modules/gallvp/agat/spfilterbyorfsize/main.nf @@ -0,0 +1,60 @@ +process AGAT_SPFILTERBYORFSIZE { + tag "$meta.id" + label 'process_single' + + conda "${moduleDir}/environment.yml" + container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? + 'https://depot.galaxyproject.org/singularity/agat:1.4.2--pl5321hdfd78af_0': + 'biocontainers/agat:1.4.2--pl5321hdfd78af_0' }" + + input: + tuple val(meta), path(gxf) + path config + + output: + tuple val(meta), path("*.passed.gff") , emit: passed_gff + tuple val(meta), path("*.failed.gff") , emit: failed_gff + path "versions.yml" , emit: versions + + when: + task.ext.when == null || task.ext.when + + script: + def args = task.ext.args ?: '' + def prefix = task.ext.prefix ?: "${meta.id}" + def config_arg = config ? "-c $config" : '' + if( "$gxf" in [ "${prefix}.passed.gff", "${prefix}.failed.gff" ] ) error "Input and output names are the same, use \"task.ext.prefix\" to disambiguate!" + """ + agat_sp_filter_by_ORF_size.pl \\ + -g $gxf \\ + $args \\ + $config_arg \\ + -o $prefix + + mv \\ + ${prefix}_NOT* \\ + "${prefix}.failed.gff" + + mv \\ + ${prefix}_* \\ + "${prefix}.passed.gff" + + cat <<-END_VERSIONS > versions.yml + "${task.process}": + agat: \$(agat_sp_flag_short_introns.pl -h | sed -n 's/.*(AGAT) - Version: \\(.*\\) .*/\\1/p') + END_VERSIONS + """ + + stub: + def prefix = task.ext.prefix ?: "${meta.id}" + if( "$gxf" in [ "${prefix}.passed.gff", "${prefix}.failed.gff" ] ) error "Input and output names are the same, use \"task.ext.prefix\" to disambiguate!" + """ + touch ${prefix}.passed.gff + touch ${prefix}.failed.gff + + cat <<-END_VERSIONS > versions.yml + "${task.process}": + agat: \$(agat_sp_flag_short_introns.pl -h | sed -n 's/.*(AGAT) - Version: \\(.*\\) .*/\\1/p') + END_VERSIONS + """ +} diff --git a/modules/gallvp/agat/spfilterbyorfsize/meta.yml b/modules/gallvp/agat/spfilterbyorfsize/meta.yml new file mode 100644 index 0000000..cf399da --- /dev/null +++ b/modules/gallvp/agat/spfilterbyorfsize/meta.yml @@ -0,0 +1,67 @@ +# yaml-language-server: $schema=https://raw.githubusercontent.com/nf-core/modules/master/modules/meta-schema.json +name: "agat_spfilterbyorfsize" +description: The script reads a gff annotation file, and create two output files, + one contains the gene models with ORF passing the test, the other contains the rest. + By default the test is "> 100" that means all gene models that have ORF longer than + 100 Amino acids, will pass the test. +keywords: + - genomics + - GFF/GTF + - filter + - annotation +tools: + - "agat": + description: "Another Gff Analysis Toolkit (AGAT). Suite of tools to handle gene + annotations in any GTF/GFF format." + homepage: "https://agat.readthedocs.io/en/latest/" + documentation: "https://agat.readthedocs.io/en/latest/" + tool_dev_url: "https://github.com/NBISweden/AGAT" + doi: "10.5281/zenodo.3552717" + licence: ["GPL v3"] + identifier: biotools:AGAT + +input: + - - meta: + type: map + description: | + Groovy Map containing sample information + e.g. `[ id:'sample1' ]` + - gxf: + type: file + description: Input GFF3/GTF file + pattern: "*.{gff,gff3,gtf}" + - - config: + type: file + description: | + Input agat config file. By default AGAT takes as input agat_config.yaml file from the working directory if any, + otherwise it takes the orignal agat_config.yaml shipped with AGAT. To get the agat_config.yaml locally type: "agat config --expose". + The --config option gives you the possibility to use your own AGAT config file (located elsewhere or named differently). + pattern: "*.yaml" +output: + - passed_gff: + - meta: + type: map + description: | + Groovy Map containing sample information + e.g. `[ id:'sample1' ] + - "*.passed.gff": + type: file + description: GFF file with gene models which pass the filter test + - failed_gff: + - meta: + type: map + description: | + Groovy Map containing sample information + e.g. `[ id:'sample1' ] + - "*.failed.gff": + type: file + description: GFF file with remaining gene models + - versions: + - versions.yml: + type: file + description: File containing software versions + pattern: "versions.yml" +authors: + - "@GallVp" +maintainers: + - "@GallVp" diff --git a/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test b/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test new file mode 100644 index 0000000..4a6e1fc --- /dev/null +++ b/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test @@ -0,0 +1,62 @@ +nextflow_process { + + name "Test Process AGAT_SPFILTERBYORFSIZE" + script "../main.nf" + process "AGAT_SPFILTERBYORFSIZE" + + tag "modules" + tag "modules_gallvp" + tag "agat" + tag "agat/spfilterbyorfsize" + + test("actinidia_chinensis - genome - gtf") { + + + when { + process { + """ + input[0] = [ + [ id:'test' ], // meta map + file(params.modules_testdata_base_path + 'genomics/eukaryotes/actinidia_chinensis/genome/chr1/genome.gtf.gz', checkIfExists: true) + ] + input[1] = [] + """ + } + } + + then { + assertAll( + { assert process.success }, + { assert snapshot(process.out).match() } + ) + } + + } + + test("homo_sapiens - genome - gtf - stub") { + + options '-stub' + + when { + process { + """ + input[0] = [ + [ id:'test' ], // meta map + file(params.modules_testdata_base_path + 'genomics/homo_sapiens/genome/chr1/genome.gtf', checkIfExists: true) + ] + input[1] = [] + """ + } + } + + then { + assertAll( + { assert process.success }, + { assert snapshot(process.out).match() } + ) + } + + } + + +} diff --git a/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap b/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap new file mode 100644 index 0000000..22b26fe --- /dev/null +++ b/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap @@ -0,0 +1,100 @@ +{ + "homo_sapiens - genome - gtf - stub": { + "content": [ + { + "0": [ + [ + { + "id": "test" + }, + "test.passed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" + ] + ], + "1": [ + [ + { + "id": "test" + }, + "test.failed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" + ] + ], + "2": [ + "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" + ], + "failed_gff": [ + [ + { + "id": "test" + }, + "test.failed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" + ] + ], + "passed_gff": [ + [ + { + "id": "test" + }, + "test.passed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" + ] + ], + "versions": [ + "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" + ] + } + ], + "meta": { + "nf-test": "0.9.2", + "nextflow": "24.04.4" + }, + "timestamp": "2024-12-10T17:07:11.619928" + }, + "actinidia_chinensis - genome - gtf": { + "content": [ + { + "0": [ + [ + { + "id": "test" + }, + "test.passed.gff:md5,e2558c89e50df32d654f19f9a69e46a3" + ] + ], + "1": [ + [ + { + "id": "test" + }, + "test.failed.gff:md5,d7eb6ae1c3dc30675138029b513073eb" + ] + ], + "2": [ + "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" + ], + "failed_gff": [ + [ + { + "id": "test" + }, + "test.failed.gff:md5,d7eb6ae1c3dc30675138029b513073eb" + ] + ], + "passed_gff": [ + [ + { + "id": "test" + }, + "test.passed.gff:md5,e2558c89e50df32d654f19f9a69e46a3" + ] + ], + "versions": [ + "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" + ] + } + ], + "meta": { + "nf-test": "0.9.2", + "nextflow": "24.04.4" + }, + "timestamp": "2024-12-10T17:07:06.829402" + } +} \ No newline at end of file diff --git a/nextflow.config b/nextflow.config index 363f0c5..c3ce861 100644 --- a/nextflow.config +++ b/nextflow.config @@ -54,6 +54,7 @@ params { enforce_full_intron_support = true filter_liftoff_by_hints = true eggnogmapper_purge_nohits = false + filter_genes_by_aa_length = 24 // Annotation output options braker_save_outputs = false diff --git a/nextflow_schema.json b/nextflow_schema.json index b7b5cc4..abe26a9 100644 --- a/nextflow_schema.json +++ b/nextflow_schema.json @@ -272,6 +272,13 @@ "type": "boolean", "description": "Purge transcripts which do not have a hit against eggnog", "fa_icon": "fas fa-question-circle" + }, + "filter_genes_by_aa_length": { + "type": "integer", + "default": 24, + "fa_icon": "fas fa-hashtag", + "description": "Filter genes with open reading frames shorter than the specified number of amino acids. If set to `null`, this filter step is skipped.", + "minimum": 3 } } }, diff --git a/subworkflows/local/gff_merge_cleanup.nf b/subworkflows/local/gff_merge_cleanup.nf index fc6c75e..fbdea37 100644 --- a/subworkflows/local/gff_merge_cleanup.nf +++ b/subworkflows/local/gff_merge_cleanup.nf @@ -1,18 +1,20 @@ include { AGAT_SPMERGEANNOTATIONS } from '../../modules/nf-core/agat/spmergeannotations/main' include { GT_GFF3 } from '../../modules/nf-core/gt/gff3/main' +include { AGAT_SPFILTERBYORFSIZE } from '../../modules/gallvp/agat/spfilterbyorfsize/main' include { AGAT_CONVERTSPGXF2GXF } from '../../modules/nf-core/agat/convertspgxf2gxf/main' workflow GFF_MERGE_CLEANUP { take: ch_braker_gff // Channel: [ meta, gff ] ch_liftoff_gff // Channel: [ meta, gff ] + val_filter_by_aa_length // val(null|Integer) main: ch_versions = Channel.empty() ch_gff_branch = ch_braker_gff | join(ch_liftoff_gff, remainder:true) - | branch { meta, braker_gff, liftoff_gff -> + | branch { _meta, braker_gff, liftoff_gff -> both : ( braker_gff && liftoff_gff ) braker_only : ( braker_gff && ( ! liftoff_gff ) ) liftoff_only: ( ( ! braker_gff ) && liftoff_gff ) @@ -25,12 +27,25 @@ workflow GFF_MERGE_CLEANUP { ) ch_merged_gff = AGAT_SPMERGEANNOTATIONS.out.gff - | mix ( ch_gff_branch.liftoff_only.map { meta, braker_gff, liftoff_gff -> [ meta, liftoff_gff ] } ) - | mix ( ch_gff_branch.braker_only.map { meta, braker_gff, liftoff_gff -> [ meta, braker_gff ] } ) + | mix ( ch_gff_branch.liftoff_only.map { meta, _braker_gff, liftoff_gff -> [ meta, liftoff_gff ] } ) + | mix ( ch_gff_branch.braker_only.map { meta, braker_gff, _liftoff_gff -> [ meta, braker_gff ] } ) ch_versions = ch_versions.mix(AGAT_SPMERGEANNOTATIONS.out.versions.first()) + // MODULE: AGAT_SPFILTERBYORFSIZE + ch_filter_input = ch_merged_gff + | branch { + filter: val_filter_by_aa_length != null + pass: val_filter_by_aa_length == null + } + + AGAT_SPFILTERBYORFSIZE ( ch_filter_input.filter, [] ) + + ch_filtered_gff = AGAT_SPFILTERBYORFSIZE.out.passed_gff + | mix ( ch_filter_input.pass ) + ch_versions = ch_versions.mix(AGAT_SPFILTERBYORFSIZE.out.versions.first()) + // MODULE: GT_GFF3 - GT_GFF3 ( ch_merged_gff ) + GT_GFF3 ( ch_filtered_gff ) ch_gt_gff = GT_GFF3.out.gt_gff3 ch_versions = ch_versions.mix(GT_GFF3.out.versions.first()) diff --git a/workflows/genepal.nf b/workflows/genepal.nf index 538fcfe..6ee525b 100644 --- a/workflows/genepal.nf +++ b/workflows/genepal.nf @@ -178,7 +178,8 @@ workflow GENEPAL { // SUBWORKFLOW: GFF_MERGE_CLEANUP GFF_MERGE_CLEANUP( ch_braker_purged_gff, - ch_liftoff_gff3 + ch_liftoff_gff3, + params.filter_genes_by_aa_length ) ch_merged_gff = GFF_MERGE_CLEANUP.out.gff From d694431b94985b425e9212c1078975d6020a2006 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Wed, 11 Dec 2024 06:37:33 +1300 Subject: [PATCH 29/35] Updated snapshots --- pfr/params.json | 3 ++- tests/minimal/main.nf.test.snap | 11 +++++++---- tests/stub/main.nf.test.snap | 11 +++++++---- 3 files changed, 16 insertions(+), 9 deletions(-) diff --git a/pfr/params.json b/pfr/params.json index 7e993bf..9983398 100644 --- a/pfr/params.json +++ b/pfr/params.json @@ -32,8 +32,9 @@ "enforce_full_intron_support": true, "filter_liftoff_by_hints": true, "eggnogmapper_purge_nohits": false, + "filter_genes_by_aa_length": 24, "braker_save_outputs": false, - "add_attrs_to_proteins_fasta": false, + "add_attrs_to_proteins_cds_fastas": false, "busco_skip": false, "busco_lineage_datasets": "embryophyta_odb10" } diff --git a/tests/minimal/main.nf.test.snap b/tests/minimal/main.nf.test.snap index 48dae90..f4b2aba 100644 --- a/tests/minimal/main.nf.test.snap +++ b/tests/minimal/main.nf.test.snap @@ -2,7 +2,7 @@ "profile - test": { "content": [ { - "successful tasks": 20, + "successful tasks": 21, "versions": { "AGAT_CONVERTSPGFF2GTF": { "agat": "v1.4.0" @@ -16,6 +16,9 @@ "AGAT_SPEXTRACTSEQUENCES": { "agat": "v1.4.0" }, + "AGAT_SPFILTERBYORFSIZE": { + "agat": "v1.4.1" + }, "BRAKER3": { "braker3": "3.0.8", "augustus": "3.5.0", @@ -92,8 +95,8 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.04.2" + "nextflow": "24.04.4" }, - "timestamp": "2024-12-05T07:51:43.818374" + "timestamp": "2024-12-11T06:36:01.956188" } -} +} \ No newline at end of file diff --git a/tests/stub/main.nf.test.snap b/tests/stub/main.nf.test.snap index 4516d50..1548c96 100644 --- a/tests/stub/main.nf.test.snap +++ b/tests/stub/main.nf.test.snap @@ -2,7 +2,7 @@ "full - stub": { "content": [ { - "successful tasks": 162, + "successful tasks": 166, "versions": { "AGAT_CONVERTSPGFF2GTF": { "agat": "v1.4.0" @@ -16,6 +16,9 @@ "AGAT_SPEXTRACTSEQUENCES": { "agat": "v1.4.0" }, + "AGAT_SPFILTERBYORFSIZE": { + "agat": "v1.4.1" + }, "AGAT_SPFILTERFEATUREFROMKILLLIST": { "agat": "v1.4.0" }, @@ -203,8 +206,8 @@ ], "meta": { "nf-test": "0.9.2", - "nextflow": "24.04.2" + "nextflow": "24.04.4" }, - "timestamp": "2024-12-05T07:56:38.915238" + "timestamp": "2024-12-10T21:52:10.308719" } -} +} \ No newline at end of file From 0f7784ccf5ecd7fcf14798145086afd912458745 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Wed, 11 Dec 2024 21:18:26 +1300 Subject: [PATCH 30/35] Added test to verify that GFFREAD can filter mRNA by CDS length --- modules/local/tests/gffread/main.nf.test | 38 +++++++++++++++ modules/local/tests/gffread/main.nf.test.snap | 47 +++++++++++++++++++ modules/local/tests/gffread/nextflow.config | 5 ++ modules/local/tests/gffread/testdata/t.gff | 47 +++++++++++++++++++ subworkflows/local/gff_eggnogmapper.nf | 8 ++-- 5 files changed, 141 insertions(+), 4 deletions(-) create mode 100644 modules/local/tests/gffread/main.nf.test create mode 100644 modules/local/tests/gffread/main.nf.test.snap create mode 100644 modules/local/tests/gffread/nextflow.config create mode 100644 modules/local/tests/gffread/testdata/t.gff diff --git a/modules/local/tests/gffread/main.nf.test b/modules/local/tests/gffread/main.nf.test new file mode 100644 index 0000000..60e588b --- /dev/null +++ b/modules/local/tests/gffread/main.nf.test @@ -0,0 +1,38 @@ +nextflow_process { + + name "Test Process GFFREAD" + script "../../../nf-core/gffread/main.nf" + config "./nextflow.config" + process "GFFREAD" + + tag "gffread" + tag "modules_nfcore" + tag "modules" + + test("filter by length") { + + when { + process { + """ + input[0] = [ + [id: 'test'], + file("$baseDir" + '/modules/local/tests/gffread/testdata/t.gff', checkIfExists: true) + ] + input[1] = [] + """ + } + } + + then { + assertAll ( + { assert process.success }, + { assert snapshot(process.out).match() }, + { assert file(process.out.gffread_gff[0][1]).text.contains('gene19851') }, + { assert file(process.out.gffread_gff[0][1]).text.contains('gene19851.t1') }, + { assert ! file(process.out.gffread_gff[0][1]).text.contains('gene19851.t2') } // This is the only transcript which is being knocked out + ) + } + + } + +} diff --git a/modules/local/tests/gffread/main.nf.test.snap b/modules/local/tests/gffread/main.nf.test.snap new file mode 100644 index 0000000..261f436 --- /dev/null +++ b/modules/local/tests/gffread/main.nf.test.snap @@ -0,0 +1,47 @@ +{ + "filter by length": { + "content": [ + { + "0": [ + + ], + "1": [ + [ + { + "id": "test" + }, + "test.gff3:md5,59a7d6ff7123589ef2b90b20043a347c" + ] + ], + "2": [ + + ], + "3": [ + "versions.yml:md5,05f671c6c6e530acedad0af0a5948dbd" + ], + "gffread_fasta": [ + + ], + "gffread_gff": [ + [ + { + "id": "test" + }, + "test.gff3:md5,59a7d6ff7123589ef2b90b20043a347c" + ] + ], + "gtf": [ + + ], + "versions": [ + "versions.yml:md5,05f671c6c6e530acedad0af0a5948dbd" + ] + } + ], + "meta": { + "nf-test": "0.9.2", + "nextflow": "24.04.4" + }, + "timestamp": "2024-12-11T21:11:59.953464" + } +} \ No newline at end of file diff --git a/modules/local/tests/gffread/nextflow.config b/modules/local/tests/gffread/nextflow.config new file mode 100644 index 0000000..734d066 --- /dev/null +++ b/modules/local/tests/gffread/nextflow.config @@ -0,0 +1,5 @@ +process { + withName: GFFREAD { + ext.args = '--no-pseudo --keep-genes -C -l 72' + } +} diff --git a/modules/local/tests/gffread/testdata/t.gff b/modules/local/tests/gffread/testdata/t.gff new file mode 100644 index 0000000..6b1c076 --- /dev/null +++ b/modules/local/tests/gffread/testdata/t.gff @@ -0,0 +1,47 @@ +##gff-version 3 +### +chr23 AUGUSTUS gene 16515075 16516672 . - . ID=gene19849;description=Protein%20of%20unknown%20function%20%28DUF1635%29 +chr23 AUGUSTUS mRNA 16515075 16516597 1 - . ID=gene19849.t1;Parent=gene19849;description=Protein%20of%20unknown%20function%20%28DUF1635%29 +chr23 AUGUSTUS exon 16515075 16515794 . - . ID=gene19849.t1.exon1;Parent=gene19849.t1 +chr23 AUGUSTUS CDS 16515075 16515794 1 - 0 ID=gene19849.t1.cds1;Parent=gene19849.t1 +chr23 AUGUSTUS exon 16516562 16516597 . - . ID=gene19849.t1.exon2;Parent=gene19849.t1 +chr23 AUGUSTUS CDS 16516562 16516597 1 - 0 ID=gene19849.t1.cds2;Parent=gene19849.t1 +chr23 gmst mRNA 16515075 16516672 . - . ID=gene19849.t2;Parent=gene19849;description=Protein%20of%20unknown%20function%20%28DUF1635%29 +chr23 gmst exon 16515075 16515794 50.2 - 0 ID=gene19849.t2.exon1;Parent=gene19849.t2 +chr23 gmst CDS 16515075 16515794 50.2 - 0 ID=gene19849.t2.cds1;Parent=gene19849.t2 +chr23 gmst exon 16516562 16516672 50.2 - 0 ID=gene19849.t2.exon2;Parent=gene19849.t2 +chr23 gmst CDS 16516562 16516672 50.2 - 0 ID=gene19849.t2.cds2;Parent=gene19849.t2 +### +chr23 gmst gene 16530414 16531453 . - . ID=gene19850;description=Myb-like%20DNA-binding%20domain +chr23 gmst mRNA 16530414 16531453 . - . ID=gene19850.t1;Parent=gene19850;description=Myb-like%20DNA-binding%20domain +chr23 gmst exon 16530414 16531041 42.7 - 1 ID=gene19850.t1.exon1;Parent=gene19850.t1 +chr23 gmst CDS 16530414 16531041 42.7 - 1 ID=gene19850.t1.cds1;Parent=gene19850.t1 +chr23 gmst exon 16531197 16531453 42.7 - 0 ID=gene19850.t1.exon2;Parent=gene19850.t1 +chr23 gmst CDS 16531197 16531453 42.7 - 0 ID=gene19850.t1.cds2;Parent=gene19850.t1 +### +chr23 AUGUSTUS gene 16530414 16531542 . - . ID=gene19851;description=Differing%20isoform%20descriptions +chr23 AUGUSTUS mRNA 16530414 16531542 1 - . ID=gene19851.t1;Parent=gene19851;description=Myb-like%20DNA-binding%20domain +chr23 AUGUSTUS exon 16530414 16530721 . - . ID=gene19851.t1.exon1;Parent=gene19851.t1 +chr23 AUGUSTUS CDS 16530414 16530721 1 - 2 ID=gene19851.t1.cds1;Parent=gene19851.t1 +chr23 AUGUSTUS exon 16530824 16531041 . - . ID=gene19851.t1.exon2;Parent=gene19851.t1 +chr23 AUGUSTUS CDS 16530824 16531041 1 - 1 ID=gene19851.t1.cds2;Parent=gene19851.t1 +chr23 AUGUSTUS exon 16531197 16531326 . - . ID=gene19851.t1.exon3;Parent=gene19851.t1 +chr23 AUGUSTUS CDS 16531197 16531326 1 - 2 ID=gene19851.t1.cds3;Parent=gene19851.t1 +chr23 AUGUSTUS exon 16531428 16531542 . - . ID=gene19851.t1.exon4;Parent=gene19851.t1 +chr23 AUGUSTUS CDS 16531428 16531542 1 - 0 ID=gene19851.t1.cds4;Parent=gene19851.t1 +chr23 GeneMark.hmm3 mRNA 16531514 16531542 . - . ID=gene19851.t2;Parent=gene19851;description=Hypothetical%20protein%20%7C%20no%20eggnog%20hit +chr23 GeneMark.hmm3 exon 16531514 16531542 . - 0 ID=gene19851.t2.exon1;Parent=gene19851.t2 +chr23 GeneMark.hmm3 CDS 16531514 16531542 . - 0 ID=gene19851.t2.cds1;Parent=gene19851.t2 +### +chr23 AUGUSTUS gene 16539401 16545431 . + . ID=gene19852;description=nuclease%20HARBI1 +chr23 AUGUSTUS mRNA 16539401 16545431 1 + . ID=gene19852.t1;Parent=gene19852;description=nuclease%20HARBI1 +chr23 AUGUSTUS exon 16539401 16539509 . + . ID=gene19852.t1.exon1;Parent=gene19852.t1 +chr23 AUGUSTUS CDS 16539401 16539509 1 + 0 ID=gene19852.t1.cds1;Parent=gene19852.t1 +chr23 AUGUSTUS exon 16544386 16545431 . + . ID=gene19852.t1.exon2;Parent=gene19852.t1 +chr23 AUGUSTUS CDS 16544386 16545431 1 + 2 ID=gene19852.t1.cds2;Parent=gene19852.t1 +### +chr23 AUGUSTUS gene 16556338 16556796 . + . ID=gene19853;description=Zinc%20finger%20protein +chr23 AUGUSTUS mRNA 16556338 16556796 1 + . ID=gene19853.t1;Parent=gene19853;description=Zinc%20finger%20protein +chr23 AUGUSTUS exon 16556338 16556796 . + . ID=gene19853.t1.exon1;Parent=gene19853.t1 +chr23 AUGUSTUS CDS 16556338 16556796 1 + 0 ID=gene19853.t1.cds1;Parent=gene19853.t1 +### diff --git a/subworkflows/local/gff_eggnogmapper.nf b/subworkflows/local/gff_eggnogmapper.nf index 841a243..8e402d4 100644 --- a/subworkflows/local/gff_eggnogmapper.nf +++ b/subworkflows/local/gff_eggnogmapper.nf @@ -16,8 +16,8 @@ workflow GFF_EGGNOGMAPPER { | join(ch_fasta) GFF2FASTA_FOR_EGGNOGMAPPER( - ch_gffread_inputs.map { meta, gff, fasta -> [ meta, gff ] }, - ch_gffread_inputs.map { meta, gff, fasta -> fasta } + ch_gffread_inputs.map { meta, gff, _fasta -> [ meta, gff ] }, + ch_gffread_inputs.map { _meta, _gff, fasta -> fasta } ) ch_gffread_fasta = GFF2FASTA_FOR_EGGNOGMAPPER.out.gffread_fasta @@ -30,9 +30,9 @@ workflow GFF_EGGNOGMAPPER { | combine(Channel.fromPath(db_folder)) EGGNOGMAPPER( - ch_eggnogmapper_inputs.map { meta, fasta, db -> [ meta, fasta ] }, + ch_eggnogmapper_inputs.map { meta, fasta, _db -> [ meta, fasta ] }, [], - ch_eggnogmapper_inputs.map { meta, fasta, db -> db }, + ch_eggnogmapper_inputs.map { _meta, _fasta, db -> db }, [ [], [] ] ) From f9807724bace7b0d2b3a9b3ce892dc49c887996d Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Wed, 11 Dec 2024 21:55:17 +1300 Subject: [PATCH 31/35] Updated snapshots --- conf/modules.config | 4 +- modules.json | 5 - .../agat/spfilterbyorfsize/environment.yml | 7 -- modules/gallvp/agat/spfilterbyorfsize/main.nf | 60 ----------- .../gallvp/agat/spfilterbyorfsize/meta.yml | 67 ------------ .../agat/spfilterbyorfsize/tests/main.nf.test | 62 ----------- .../spfilterbyorfsize/tests/main.nf.test.snap | 100 ------------------ subworkflows/local/gff_merge_cleanup.nf | 10 +- tests/minimal/main.nf.test.snap | 12 +-- tests/stub/main.nf.test.snap | 8 +- 10 files changed, 17 insertions(+), 318 deletions(-) delete mode 100644 modules/gallvp/agat/spfilterbyorfsize/environment.yml delete mode 100644 modules/gallvp/agat/spfilterbyorfsize/main.nf delete mode 100644 modules/gallvp/agat/spfilterbyorfsize/meta.yml delete mode 100644 modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test delete mode 100644 modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap diff --git a/conf/modules.config b/conf/modules.config index fbb5f52..dd15d6c 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -240,8 +240,8 @@ process { // SUBWORKFLOW: GFF_MERGE_CLEANUP ext.prefix = { "${meta.id}.liftoff.braker" } } - withName: '.*:GFF_MERGE_CLEANUP:AGAT_SPFILTERBYORFSIZE' { - ext.args = params.filter_genes_by_aa_length ? "-s ${params.filter_genes_by_aa_length}" : '' + withName: '.*:GFF_MERGE_CLEANUP:FILTER_BY_ORF_SIZE' { + ext.args = params.filter_genes_by_aa_length ? "--no-pseudo --keep-genes -C -l ${params.filter_genes_by_aa_length * 3}" : '' } withName: '.*:GFF_MERGE_CLEANUP:GT_GFF3' { diff --git a/modules.json b/modules.json index 6b9d74a..da05f16 100644 --- a/modules.json +++ b/modules.json @@ -15,11 +15,6 @@ "git_sha": "a8939d36280e7d9037c7cf164eeede19e46546a4", "installed_by": ["gxf_fasta_agat_spaddintrons_spextractsequences"] }, - "agat/spfilterbyorfsize": { - "branch": "main", - "git_sha": "a0054cdffbd84f002fb6582b28575b699e01098e", - "installed_by": ["modules"] - }, "agat/spflagshortintrons": { "branch": "main", "git_sha": "d8f08700c82a3bd14811a3dfe7e7d63838130693", diff --git a/modules/gallvp/agat/spfilterbyorfsize/environment.yml b/modules/gallvp/agat/spfilterbyorfsize/environment.yml deleted file mode 100644 index 2c3daab..0000000 --- a/modules/gallvp/agat/spfilterbyorfsize/environment.yml +++ /dev/null @@ -1,7 +0,0 @@ ---- -# yaml-language-server: $schema=https://raw.githubusercontent.com/nf-core/modules/master/modules/environment-schema.json -channels: - - conda-forge - - bioconda -dependencies: - - "bioconda::agat=1.4.2" diff --git a/modules/gallvp/agat/spfilterbyorfsize/main.nf b/modules/gallvp/agat/spfilterbyorfsize/main.nf deleted file mode 100644 index 502a9cd..0000000 --- a/modules/gallvp/agat/spfilterbyorfsize/main.nf +++ /dev/null @@ -1,60 +0,0 @@ -process AGAT_SPFILTERBYORFSIZE { - tag "$meta.id" - label 'process_single' - - conda "${moduleDir}/environment.yml" - container "${ workflow.containerEngine == 'singularity' && !task.ext.singularity_pull_docker_container ? - 'https://depot.galaxyproject.org/singularity/agat:1.4.2--pl5321hdfd78af_0': - 'biocontainers/agat:1.4.2--pl5321hdfd78af_0' }" - - input: - tuple val(meta), path(gxf) - path config - - output: - tuple val(meta), path("*.passed.gff") , emit: passed_gff - tuple val(meta), path("*.failed.gff") , emit: failed_gff - path "versions.yml" , emit: versions - - when: - task.ext.when == null || task.ext.when - - script: - def args = task.ext.args ?: '' - def prefix = task.ext.prefix ?: "${meta.id}" - def config_arg = config ? "-c $config" : '' - if( "$gxf" in [ "${prefix}.passed.gff", "${prefix}.failed.gff" ] ) error "Input and output names are the same, use \"task.ext.prefix\" to disambiguate!" - """ - agat_sp_filter_by_ORF_size.pl \\ - -g $gxf \\ - $args \\ - $config_arg \\ - -o $prefix - - mv \\ - ${prefix}_NOT* \\ - "${prefix}.failed.gff" - - mv \\ - ${prefix}_* \\ - "${prefix}.passed.gff" - - cat <<-END_VERSIONS > versions.yml - "${task.process}": - agat: \$(agat_sp_flag_short_introns.pl -h | sed -n 's/.*(AGAT) - Version: \\(.*\\) .*/\\1/p') - END_VERSIONS - """ - - stub: - def prefix = task.ext.prefix ?: "${meta.id}" - if( "$gxf" in [ "${prefix}.passed.gff", "${prefix}.failed.gff" ] ) error "Input and output names are the same, use \"task.ext.prefix\" to disambiguate!" - """ - touch ${prefix}.passed.gff - touch ${prefix}.failed.gff - - cat <<-END_VERSIONS > versions.yml - "${task.process}": - agat: \$(agat_sp_flag_short_introns.pl -h | sed -n 's/.*(AGAT) - Version: \\(.*\\) .*/\\1/p') - END_VERSIONS - """ -} diff --git a/modules/gallvp/agat/spfilterbyorfsize/meta.yml b/modules/gallvp/agat/spfilterbyorfsize/meta.yml deleted file mode 100644 index cf399da..0000000 --- a/modules/gallvp/agat/spfilterbyorfsize/meta.yml +++ /dev/null @@ -1,67 +0,0 @@ -# yaml-language-server: $schema=https://raw.githubusercontent.com/nf-core/modules/master/modules/meta-schema.json -name: "agat_spfilterbyorfsize" -description: The script reads a gff annotation file, and create two output files, - one contains the gene models with ORF passing the test, the other contains the rest. - By default the test is "> 100" that means all gene models that have ORF longer than - 100 Amino acids, will pass the test. -keywords: - - genomics - - GFF/GTF - - filter - - annotation -tools: - - "agat": - description: "Another Gff Analysis Toolkit (AGAT). Suite of tools to handle gene - annotations in any GTF/GFF format." - homepage: "https://agat.readthedocs.io/en/latest/" - documentation: "https://agat.readthedocs.io/en/latest/" - tool_dev_url: "https://github.com/NBISweden/AGAT" - doi: "10.5281/zenodo.3552717" - licence: ["GPL v3"] - identifier: biotools:AGAT - -input: - - - meta: - type: map - description: | - Groovy Map containing sample information - e.g. `[ id:'sample1' ]` - - gxf: - type: file - description: Input GFF3/GTF file - pattern: "*.{gff,gff3,gtf}" - - - config: - type: file - description: | - Input agat config file. By default AGAT takes as input agat_config.yaml file from the working directory if any, - otherwise it takes the orignal agat_config.yaml shipped with AGAT. To get the agat_config.yaml locally type: "agat config --expose". - The --config option gives you the possibility to use your own AGAT config file (located elsewhere or named differently). - pattern: "*.yaml" -output: - - passed_gff: - - meta: - type: map - description: | - Groovy Map containing sample information - e.g. `[ id:'sample1' ] - - "*.passed.gff": - type: file - description: GFF file with gene models which pass the filter test - - failed_gff: - - meta: - type: map - description: | - Groovy Map containing sample information - e.g. `[ id:'sample1' ] - - "*.failed.gff": - type: file - description: GFF file with remaining gene models - - versions: - - versions.yml: - type: file - description: File containing software versions - pattern: "versions.yml" -authors: - - "@GallVp" -maintainers: - - "@GallVp" diff --git a/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test b/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test deleted file mode 100644 index 4a6e1fc..0000000 --- a/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test +++ /dev/null @@ -1,62 +0,0 @@ -nextflow_process { - - name "Test Process AGAT_SPFILTERBYORFSIZE" - script "../main.nf" - process "AGAT_SPFILTERBYORFSIZE" - - tag "modules" - tag "modules_gallvp" - tag "agat" - tag "agat/spfilterbyorfsize" - - test("actinidia_chinensis - genome - gtf") { - - - when { - process { - """ - input[0] = [ - [ id:'test' ], // meta map - file(params.modules_testdata_base_path + 'genomics/eukaryotes/actinidia_chinensis/genome/chr1/genome.gtf.gz', checkIfExists: true) - ] - input[1] = [] - """ - } - } - - then { - assertAll( - { assert process.success }, - { assert snapshot(process.out).match() } - ) - } - - } - - test("homo_sapiens - genome - gtf - stub") { - - options '-stub' - - when { - process { - """ - input[0] = [ - [ id:'test' ], // meta map - file(params.modules_testdata_base_path + 'genomics/homo_sapiens/genome/chr1/genome.gtf', checkIfExists: true) - ] - input[1] = [] - """ - } - } - - then { - assertAll( - { assert process.success }, - { assert snapshot(process.out).match() } - ) - } - - } - - -} diff --git a/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap b/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap deleted file mode 100644 index 22b26fe..0000000 --- a/modules/gallvp/agat/spfilterbyorfsize/tests/main.nf.test.snap +++ /dev/null @@ -1,100 +0,0 @@ -{ - "homo_sapiens - genome - gtf - stub": { - "content": [ - { - "0": [ - [ - { - "id": "test" - }, - "test.passed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" - ] - ], - "1": [ - [ - { - "id": "test" - }, - "test.failed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" - ] - ], - "2": [ - "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" - ], - "failed_gff": [ - [ - { - "id": "test" - }, - "test.failed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" - ] - ], - "passed_gff": [ - [ - { - "id": "test" - }, - "test.passed.gff:md5,d41d8cd98f00b204e9800998ecf8427e" - ] - ], - "versions": [ - "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" - ] - } - ], - "meta": { - "nf-test": "0.9.2", - "nextflow": "24.04.4" - }, - "timestamp": "2024-12-10T17:07:11.619928" - }, - "actinidia_chinensis - genome - gtf": { - "content": [ - { - "0": [ - [ - { - "id": "test" - }, - "test.passed.gff:md5,e2558c89e50df32d654f19f9a69e46a3" - ] - ], - "1": [ - [ - { - "id": "test" - }, - "test.failed.gff:md5,d7eb6ae1c3dc30675138029b513073eb" - ] - ], - "2": [ - "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" - ], - "failed_gff": [ - [ - { - "id": "test" - }, - "test.failed.gff:md5,d7eb6ae1c3dc30675138029b513073eb" - ] - ], - "passed_gff": [ - [ - { - "id": "test" - }, - "test.passed.gff:md5,e2558c89e50df32d654f19f9a69e46a3" - ] - ], - "versions": [ - "versions.yml:md5,bc298e3688f3f90f287f56ee6929bd29" - ] - } - ], - "meta": { - "nf-test": "0.9.2", - "nextflow": "24.04.4" - }, - "timestamp": "2024-12-10T17:07:06.829402" - } -} \ No newline at end of file diff --git a/subworkflows/local/gff_merge_cleanup.nf b/subworkflows/local/gff_merge_cleanup.nf index fbdea37..8a77eda 100644 --- a/subworkflows/local/gff_merge_cleanup.nf +++ b/subworkflows/local/gff_merge_cleanup.nf @@ -1,6 +1,6 @@ include { AGAT_SPMERGEANNOTATIONS } from '../../modules/nf-core/agat/spmergeannotations/main' include { GT_GFF3 } from '../../modules/nf-core/gt/gff3/main' -include { AGAT_SPFILTERBYORFSIZE } from '../../modules/gallvp/agat/spfilterbyorfsize/main' +include { GFFREAD as FILTER_BY_ORF_SIZE } from '../../modules/nf-core/gffread/main' include { AGAT_CONVERTSPGXF2GXF } from '../../modules/nf-core/agat/convertspgxf2gxf/main' workflow GFF_MERGE_CLEANUP { @@ -31,18 +31,18 @@ workflow GFF_MERGE_CLEANUP { | mix ( ch_gff_branch.braker_only.map { meta, braker_gff, _liftoff_gff -> [ meta, braker_gff ] } ) ch_versions = ch_versions.mix(AGAT_SPMERGEANNOTATIONS.out.versions.first()) - // MODULE: AGAT_SPFILTERBYORFSIZE + // MODULE: GFFREAD as FILTER_BY_ORF_SIZE ch_filter_input = ch_merged_gff | branch { filter: val_filter_by_aa_length != null pass: val_filter_by_aa_length == null } - AGAT_SPFILTERBYORFSIZE ( ch_filter_input.filter, [] ) + FILTER_BY_ORF_SIZE ( ch_filter_input.filter, [] ) - ch_filtered_gff = AGAT_SPFILTERBYORFSIZE.out.passed_gff + ch_filtered_gff = FILTER_BY_ORF_SIZE.out.gffread_gff | mix ( ch_filter_input.pass ) - ch_versions = ch_versions.mix(AGAT_SPFILTERBYORFSIZE.out.versions.first()) + ch_versions = ch_versions.mix(FILTER_BY_ORF_SIZE.out.versions.first()) // MODULE: GT_GFF3 GT_GFF3 ( ch_filtered_gff ) diff --git a/tests/minimal/main.nf.test.snap b/tests/minimal/main.nf.test.snap index f4b2aba..e0f2ce3 100644 --- a/tests/minimal/main.nf.test.snap +++ b/tests/minimal/main.nf.test.snap @@ -16,9 +16,6 @@ "AGAT_SPEXTRACTSEQUENCES": { "agat": "v1.4.0" }, - "AGAT_SPFILTERBYORFSIZE": { - "agat": "v1.4.1" - }, "BRAKER3": { "braker3": "3.0.8", "augustus": "3.5.0", @@ -40,6 +37,9 @@ "FASTAVALIDATOR": { "py_fasta_validator": 0.6 }, + "FILTER_BY_ORF_SIZE": { + "gffread": "0.12.7" + }, "FINAL_GFF_CHECK": { "genometools": "1.6.5" }, @@ -70,9 +70,9 @@ "stable paths": [ "a_thaliana.cdna.fasta:md5,12b9bef973e488640aec8c04ba3882fe", "a_thaliana.cds.fasta:md5,b81060419355a590560f92aec8536281", - "a_thaliana.gt.gff3:md5,8ab16549095f605ff8715ac4a3de58ed", + "a_thaliana.gt.gff3:md5,528459cf9596523bf66de99d24c37e20", "a_thaliana.pep.fasta:md5,4994c0393ca0245a1c57966d846d101e", - "a_thaliana.gff3:md5,d23d16cd86499d48a30ffb981ed27891", + "a_thaliana.gff3:md5,30adac1b21d7aaed6ca7fb71ab33f32d", "summary_stats.json:md5,007ba5cf2b7a2fd395a27d9458ca2d2e" ], "stable names": [ @@ -97,6 +97,6 @@ "nf-test": "0.9.2", "nextflow": "24.04.4" }, - "timestamp": "2024-12-11T06:36:01.956188" + "timestamp": "2024-12-11T21:49:09.751422" } } \ No newline at end of file diff --git a/tests/stub/main.nf.test.snap b/tests/stub/main.nf.test.snap index 1548c96..7ed6f6e 100644 --- a/tests/stub/main.nf.test.snap +++ b/tests/stub/main.nf.test.snap @@ -16,9 +16,6 @@ "AGAT_SPEXTRACTSEQUENCES": { "agat": "v1.4.0" }, - "AGAT_SPFILTERBYORFSIZE": { - "agat": "v1.4.1" - }, "AGAT_SPFILTERFEATUREFROMKILLLIST": { "agat": "v1.4.0" }, @@ -73,6 +70,9 @@ "FASTP": { "fastp": "0.23.4" }, + "FILTER_BY_ORF_SIZE": { + "gffread": "0.12.7" + }, "FINAL_GFF_CHECK": { "genometools": "1.6.5" }, @@ -208,6 +208,6 @@ "nf-test": "0.9.2", "nextflow": "24.04.4" }, - "timestamp": "2024-12-10T21:52:10.308719" + "timestamp": "2024-12-11T21:51:12.841395" } } \ No newline at end of file From ab3ae3755423e16218e95c7e1de64d94adbd6a15 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Thu, 12 Dec 2024 09:58:01 +1300 Subject: [PATCH 32/35] Updated README and snapshot --- README.md | 5 +++-- tests/minimal/main.nf.test | 3 +++ tests/minimal/main.nf.test.snap | 17 +++++++++++++++-- 3 files changed, 21 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 177e8f5..af463db 100644 --- a/README.md +++ b/README.md @@ -39,11 +39,12 @@ - Optionally, allow or remove iso-forms - Remove BRAKER models from Liftoff loci - Merge Liftoff and BRAKER models - - Optionally, remove models with ORFs shorter than `N` amino acids - Optionally, remove models without any EggNOG-mapper hits - [EggNOG-mapper](https://github.com/eggnogdb/eggnog-mapper): Add functional annotation to gff - [GenomeTools](https://github.com/genometools/genometools): GFF format validation -- [GffRead](https://github.com/gpertea/gffread): Extraction of protein sequences +- [GffRead](https://github.com/gpertea/gffread) + - Extraction of protein sequences + - Optionally, remove models with ORFs shorter than `N` amino acids - [OrthoFinder](https://github.com/davidemms/OrthoFinder): Perform phylogenetic orthology inference across genomes - [GffCompare](https://github.com/gpertea/gffcompare): Compare and benchmark against an existing annotation - [BUSCO](https://gitlab.com/ezlab/busco): Completeness statistics for genome and annotation through proteins diff --git a/tests/minimal/main.nf.test b/tests/minimal/main.nf.test index cce8a77..5f1d1af 100644 --- a/tests/minimal/main.nf.test +++ b/tests/minimal/main.nf.test @@ -38,6 +38,8 @@ nextflow_pipeline { ['**'] ) + def summary_stats = (Map) new groovy.json.JsonSlurper().parseText(file("$outputDir/genepal_data/summary_stats.json").text) + assertAll( { assert workflow.success}, { assert snapshot( @@ -46,6 +48,7 @@ nextflow_pipeline { 'versions': removeNextflowVersion("$outputDir/pipeline_info/genepal_software_mqc_versions.yml"), 'stable paths': stable_path, 'stable names': getRelativePath(stable_name, outputDir), + 'summary_stats': summary_stats ] ).match() } ) diff --git a/tests/minimal/main.nf.test.snap b/tests/minimal/main.nf.test.snap index e0f2ce3..96c8444 100644 --- a/tests/minimal/main.nf.test.snap +++ b/tests/minimal/main.nf.test.snap @@ -90,13 +90,26 @@ "genepal_report.html", "multiqc_report.html", "pipeline_info" - ] + ], + "summary_stats": { + "stats": [ + { + "ID": "a_thaliana", + "Genes": 252, + "mRNA": 265, + "CDS": 1340, + "Exons": 1340, + "Intron": 1075, + "Non canon splice sites": 18 + } + ] + } } ], "meta": { "nf-test": "0.9.2", "nextflow": "24.04.4" }, - "timestamp": "2024-12-11T21:49:09.751422" + "timestamp": "2024-12-12T09:36:52.952048" } } \ No newline at end of file From c65ebaac0bd81f29c38391be1fd46cf46170284e Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Mon, 16 Dec 2024 10:04:21 +1300 Subject: [PATCH 33/35] Added 1 to filter_genes_by_aa_length to exclude stop codon from filter length --- CHANGELOG.md | 2 +- conf/modules.config | 2 +- docs/parameters.md | 14 +++++++------- nextflow_schema.json | 2 +- 4 files changed, 10 insertions(+), 10 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 33813b7..9937888 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,7 +3,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). -## v0.6.0 - [10-Dec-2024] +## v0.6.0 - [16-Dec-2024] ### 'Added' diff --git a/conf/modules.config b/conf/modules.config index dd15d6c..2a14621 100644 --- a/conf/modules.config +++ b/conf/modules.config @@ -241,7 +241,7 @@ process { // SUBWORKFLOW: GFF_MERGE_CLEANUP } withName: '.*:GFF_MERGE_CLEANUP:FILTER_BY_ORF_SIZE' { - ext.args = params.filter_genes_by_aa_length ? "--no-pseudo --keep-genes -C -l ${params.filter_genes_by_aa_length * 3}" : '' + ext.args = params.filter_genes_by_aa_length ? "--no-pseudo --keep-genes -C -l ${ ( params.filter_genes_by_aa_length + 1 ) * 3 }" : '' } withName: '.*:GFF_MERGE_CLEANUP:GT_GFF3' { diff --git a/docs/parameters.md b/docs/parameters.md index 0c2bb09..7ccd67a 100644 --- a/docs/parameters.md +++ b/docs/parameters.md @@ -59,13 +59,13 @@ A Nextflow pipeline for consensus, phased and pan-genome annotation. ## Post-annotation filtering options -| Parameter | Description | Type | Default | Required | Hidden | -| ----------------------------- | -------------------------------------------------------------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | -| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | -| `enforce_full_intron_support` | Require every model to have external evidence for all its introns | `boolean` | True | | | -| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | | -| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | `boolean` | | | | -| `filter_genes_by_aa_length` | Filter genes with open reading frames shorter than the specified number of amino acids. If set to `null`, this filter step is skipped. | `integer` | 24 | | | +| Parameter | Description | Type | Default | Required | Hidden | +| ----------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------- | ------- | -------- | ------ | +| `allow_isoforms` | Allow multiple isoforms for gene models | `boolean` | True | | | +| `enforce_full_intron_support` | Require every model to have external evidence for all its introns | `boolean` | True | | | +| `filter_liftoff_by_hints` | Use BRAKER hints to filter Liftoff models | `boolean` | True | | | +| `eggnogmapper_purge_nohits` | Purge transcripts which do not have a hit against eggnog | `boolean` | | | | +| `filter_genes_by_aa_length` | Filter genes with open reading frames shorter than the specified number of amino acids excluding the stop codon. If set to `null`, this filter step is skipped. | `integer` | 24 | | | ## Annotation output options diff --git a/nextflow_schema.json b/nextflow_schema.json index abe26a9..1012531 100644 --- a/nextflow_schema.json +++ b/nextflow_schema.json @@ -277,7 +277,7 @@ "type": "integer", "default": 24, "fa_icon": "fas fa-hashtag", - "description": "Filter genes with open reading frames shorter than the specified number of amino acids. If set to `null`, this filter step is skipped.", + "description": "Filter genes with open reading frames shorter than the specified number of amino acids excluding the stop codon. If set to `null`, this filter step is skipped.", "minimum": 3 } } From fa28176af60ff15e1bb0edf9e8a5a4b77113ec36 Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Mon, 16 Dec 2024 13:28:31 +1300 Subject: [PATCH 34/35] Fixed post-liftoff merge --- CHANGELOG.md | 1 + subworkflows/local/fasta_liftoff/main.nf | 21 ++++++++++++++++++++- tests/stub/main.nf.test.snap | 22 ++-------------------- 3 files changed, 23 insertions(+), 21 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9937888..a274d90 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,6 +17,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 2. Switched branch name from `master` to `main` in the GHA CIs 3. Fixed an issue in `genepal_report.Rmd` which caused the pangene matrix plot to fail when the number of clusters exceeded 65536 [#124](https://github.com/Plant-Food-Research-Open/genepal/issues/124) 4. Fixed an issue where `GENEPALREPORT` process failed due to OOM kill signal from SLURM [#123](https://github.com/Plant-Food-Research-Open/genepal/issues/123) +5. Fixed an issue where Gff merge after liftoff failed when one of the Gff files did not contain any genes ### `Dependencies` diff --git a/subworkflows/local/fasta_liftoff/main.nf b/subworkflows/local/fasta_liftoff/main.nf index d1d818f..559c0b2 100644 --- a/subworkflows/local/fasta_liftoff/main.nf +++ b/subworkflows/local/fasta_liftoff/main.nf @@ -88,7 +88,26 @@ workflow FASTA_LIFTOFF { ) ch_liftoff_gff3 = LIFTOFF.out.polished_gff3 - | map { meta, gff -> [ [ id: meta.target_assembly ], gff ] } + | map { meta, gff -> + + def gene_count = gff.readLines() + .findAll { it -> + if ( it.startsWith('#') ) { return false } + + def cols = it.split('\t') + def feat = cols[2] + + if ( feat != 'gene' ) { return false } + + return true + }.size() + + // To avoid failure in AGAT_SPMERGEANNOTATIONS + // when one of the GFF files is empty + if ( gene_count < 1 ) { return null } + + [ [ id: meta.target_assembly ], gff ] + } | groupTuple ch_versions = ch_versions.mix(LIFTOFF.out.versions.first()) diff --git a/tests/stub/main.nf.test.snap b/tests/stub/main.nf.test.snap index 7ed6f6e..d96bf68 100644 --- a/tests/stub/main.nf.test.snap +++ b/tests/stub/main.nf.test.snap @@ -2,7 +2,7 @@ "full - stub": { "content": [ { - "successful tasks": 166, + "successful tasks": 126, "versions": { "AGAT_CONVERTSPGFF2GTF": { "agat": "v1.4.0" @@ -16,15 +16,6 @@ "AGAT_SPEXTRACTSEQUENCES": { "agat": "v1.4.0" }, - "AGAT_SPFILTERFEATUREFROMKILLLIST": { - "agat": "v1.4.0" - }, - "AGAT_SPFLAGSHORTINTRONS": { - "agat": "v1.4.1" - }, - "AGAT_SPMERGEANNOTATIONS": { - "agat": "v1.4.0" - }, "BENCHMARK": { "gffcompare": "0.12.6" }, @@ -46,9 +37,6 @@ "CAT_PROTEIN_FASTAS": { "pigz": "2.3.4" }, - "COMPARE_BRAKER_TO_LIFTOFF": { - "gffcompare": "0.12.6" - }, "CUSTOM_SRATOOLSNCBISETTINGS": { "sratools": "3.0.8" }, @@ -79,9 +67,6 @@ "GFF2FASTA_FOR_EGGNOGMAPPER": { "gffread": "0.12.7" }, - "GFFREAD_AFTER_LIFTOFF": { - "gffread": "0.12.7" - }, "GFFREAD_BEFORE_LIFTOFF": { "gffread": "0.12.7" }, @@ -106,9 +91,6 @@ "LIFTOFF": { "liftoff": "v1.6.3" }, - "MERGE_LIFTOFF_ANNOTATIONS": { - "agat": "v1.4.0" - }, "ORTHOFINDER": { "orthofinder": "2.5.5" }, @@ -208,6 +190,6 @@ "nf-test": "0.9.2", "nextflow": "24.04.4" }, - "timestamp": "2024-12-11T21:51:12.841395" + "timestamp": "2024-12-16T13:24:49.69503" } } \ No newline at end of file From 3459b4036a063a7d8b8e38b1303d3a796e406aea Mon Sep 17 00:00:00 2001 From: Usman Rashid Date: Fri, 20 Dec 2024 12:21:26 +1300 Subject: [PATCH 35/35] Fixed short intron crash --- CHANGELOG.md | 3 +- modules.json | 2 +- .../main.nf | 24 +- .../main.nf.test | 39 + .../main.nf.test.snap | 53 + .../nextflow.config | 6 + .../testdata/README.md | 1 + .../testdata/scaffold_4.fasta | 2001 +++++++++++++++++ .../testdata/scaffold_4.gff | 17 + 9 files changed, 2134 insertions(+), 12 deletions(-) create mode 100644 subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test create mode 100644 subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test.snap create mode 100644 subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/nextflow.config create mode 100644 subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/README.md create mode 100644 subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.fasta create mode 100644 subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.gff diff --git a/CHANGELOG.md b/CHANGELOG.md index a274d90..bf6289b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,7 +3,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). -## v0.6.0 - [16-Dec-2024] +## v0.6.0 - [20-Dec-2024] ### 'Added' @@ -18,6 +18,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 3. Fixed an issue in `genepal_report.Rmd` which caused the pangene matrix plot to fail when the number of clusters exceeded 65536 [#124](https://github.com/Plant-Food-Research-Open/genepal/issues/124) 4. Fixed an issue where `GENEPALREPORT` process failed due to OOM kill signal from SLURM [#123](https://github.com/Plant-Food-Research-Open/genepal/issues/123) 5. Fixed an issue where Gff merge after liftoff failed when one of the Gff files did not contain any genes +6. Fixed an issue where `gxf_fasta_agat_spaddintrons_spextractsequences` crashed due to short introns [#89](https://github.com/Plant-Food-Research-Open/genepal/issues/89) ### `Dependencies` diff --git a/modules.json b/modules.json index da05f16..4a840e4 100644 --- a/modules.json +++ b/modules.json @@ -111,7 +111,7 @@ }, "gxf_fasta_agat_spaddintrons_spextractsequences": { "branch": "main", - "git_sha": "7bf6fbca23edc94490ffa6709f52b2f71c6fb130", + "git_sha": "ed4146008dbdcfd4823252b456de32059e2d07f4", "installed_by": ["subworkflows"] } } diff --git a/subworkflows/gallvp/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf b/subworkflows/gallvp/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf index 57c9297..a52acbd 100644 --- a/subworkflows/gallvp/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf +++ b/subworkflows/gallvp/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf @@ -30,9 +30,9 @@ workflow GXF_FASTA_AGAT_SPADDINTRONS_SPEXTRACTSEQUENCES { | collectFile | map { gxf -> [ gxf.baseName.replace('.nointrons', ''), gxf ] } | join( - ch_gxf.map { meta, gxf -> [ meta.id, meta ] } + ch_gxf.map { meta, _gxf -> [ meta.id, meta ] } ) - | map { id, gxf, meta -> [ meta, gxf ] } + | map { _id, gxf, meta -> [ meta, gxf ] } // MODULE: AGAT_SPADDINTRONS AGAT_SPADDINTRONS ( ch_gxf_purged, [] ) @@ -46,11 +46,11 @@ workflow GXF_FASTA_AGAT_SPADDINTRONS_SPEXTRACTSEQUENCES { | join( ch_fasta.map { meta2, fasta -> [ meta2.id, fasta ] } ) - | map { id, meta, gff3, fasta -> [ meta, gff3, fasta ] } + | map { _id, meta, gff3, fasta -> [ meta, gff3, fasta ] } AGAT_SPEXTRACTSEQUENCES( - ch_gxf_fasta.map { meta, gff3, fasta -> [ meta, gff3 ] }, - ch_gxf_fasta.map { meta, gff3, fasta -> fasta }, + ch_gxf_fasta.map { meta , gff3 , _fasta -> [ meta, gff3 ] }, + ch_gxf_fasta.map { _meta, _gff3 , fasta -> fasta }, [] // config ) @@ -61,16 +61,20 @@ workflow GXF_FASTA_AGAT_SPADDINTRONS_SPEXTRACTSEQUENCES { ch_splice_motifs = ch_intron_sequences | map { meta, fasta -> def splice_motifs = fasta.splitFasta ( record: [id: true, seqString: true] ) - .collect { el -> [ el.id, "${el.seqString[0..1]}${el.seqString[-2..-1]}" ].join('\t') } + .collect { el -> + el.seqString.size() < 4 + ? [ el.id, '-' ].join('\t') + : [ el.id, "${el.seqString[0..1]}${el.seqString[-2..-1]}" ].join('\t') + } [ "${meta.id}.motifs.tsv", splice_motifs.join('\n') ] } | collectFile | map { tsv -> [ tsv.baseName.replace('.motifs', ''), tsv ] } | join( - ch_gxf_purged.map { meta, gxf -> [ meta.id, meta ] } + ch_gxf_purged.map { meta, _gxf -> [ meta.id, meta ] } ) - | map { id, tsv, meta -> [ meta, tsv ] } + | map { _id, tsv, meta -> [ meta, tsv ] } // collectFile: Mark gff3 ch_marked_gff3 = ch_introns_gff @@ -106,9 +110,9 @@ workflow GXF_FASTA_AGAT_SPADDINTRONS_SPEXTRACTSEQUENCES { | collectFile | map { gff3 -> [ gff3.baseName.replace('.marked', ''), gff3 ] } | join( - ch_gxf_purged.map { meta, gxf -> [ meta.id, meta ] } + ch_gxf_purged.map { meta, _gxf -> [ meta.id, meta ] } ) - | map { id, gff3, meta -> [ meta, gff3 ] } + | map { _id, gff3, meta -> [ meta, gff3 ] } emit: motifs_tsv = ch_splice_motifs // channel: [ val(meta), tsv ] diff --git a/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test new file mode 100644 index 0000000..6841339 --- /dev/null +++ b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test @@ -0,0 +1,39 @@ +nextflow_workflow { + + name "Test Subworkflow GXF_FASTA_AGAT_SPADDINTRONS_SPEXTRACTSEQUENCES" + script "../../../gallvp/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf" + workflow "GXF_FASTA_AGAT_SPADDINTRONS_SPEXTRACTSEQUENCES" + config './nextflow.config' + + tag "subworkflows" + tag "subworkflows_gallvp" + tag "subworkflows/gxf_fasta_agat_spaddintrons_spextractsequences" + tag "modules/nf-core/gunzip" + tag "agat/spextractsequences" + tag "agat/spaddintrons" + + test("scaffold_4 - fasta - gff3") { + + when { + workflow { + """ + input[0] = Channel.of ( [ + [ id:'test' ], + file("$baseDir" + '/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.gff', checkIfExists: true) + ] ) + input[1] = Channel.of ( [ + [ id:'test' ], + file("$baseDir" + '/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.fasta', checkIfExists: true) + ] ) + """ + } + } + + then { + assertAll( + { assert workflow.success}, + { assert snapshot(workflow.out).match()} + ) + } + } +} diff --git a/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test.snap b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test.snap new file mode 100644 index 0000000..4c2356f --- /dev/null +++ b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/main.nf.test.snap @@ -0,0 +1,53 @@ +{ + "scaffold_4 - fasta - gff3": { + "content": [ + { + "0": [ + [ + { + "id": "test" + }, + "test.motifs.tsv:md5,b0a99a7a7bf598bbf1e25ca3690567c6" + ] + ], + "1": [ + [ + { + "id": "test" + }, + "test.marked.gff3:md5,f464b2e0dc24238e69c3e9e1419c1b3b" + ] + ], + "2": [ + "versions.yml:md5,1befbe41bc7abbf49767b8dc68877bc7", + "versions.yml:md5,65042e008b2466984150cb219a05291c" + ], + "marked_gff3": [ + [ + { + "id": "test" + }, + "test.marked.gff3:md5,f464b2e0dc24238e69c3e9e1419c1b3b" + ] + ], + "motifs_tsv": [ + [ + { + "id": "test" + }, + "test.motifs.tsv:md5,b0a99a7a7bf598bbf1e25ca3690567c6" + ] + ], + "versions": [ + "versions.yml:md5,1befbe41bc7abbf49767b8dc68877bc7", + "versions.yml:md5,65042e008b2466984150cb219a05291c" + ] + } + ], + "meta": { + "nf-test": "0.9.2", + "nextflow": "24.10.3" + }, + "timestamp": "2024-12-20T12:00:17.861955" + } +} \ No newline at end of file diff --git a/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/nextflow.config b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/nextflow.config new file mode 100644 index 0000000..456093c --- /dev/null +++ b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/nextflow.config @@ -0,0 +1,6 @@ +process { + + withName: AGAT_SPEXTRACTSEQUENCES { + ext.args = '-t intron' + } +} diff --git a/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/README.md b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/README.md new file mode 100644 index 0000000..e9deb73 --- /dev/null +++ b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/README.md @@ -0,0 +1 @@ +This test data is from an _Actinidia_ genome. To minify the data, the gene coordinates have been shifted back by 630000. The Gff file has a single bp intron which is not flagged by `agat_sp_flag_short_introns.pl` from version `quay.io/biocontainers/agat:1.4.1--pl5321hdfd78af_0`. See issue for further details. diff --git a/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.fasta b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.fasta new file mode 100644 index 0000000..e3950f7 --- /dev/null +++ b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.fasta @@ -0,0 +1,2001 @@ +>scaffold_4 +TGTATAGGGGCGAAAGACTAATCGAACCGTCTAGTAGCTGGTTCCCTCCGAAGTTTCCCT +CAGGATAGCTGGAGCCCGTGTGCGAGTTCTATCGGGTAAAGCCAATGATTAGAGGCATCG +GGGGCGCAACGCCCTCGACCTATTCTCAAACTTTAAATAGGTAGGACGGCGCGGCTGCTT +TGTTGAGCCGCGCCACGGAATCGAGAGCTCCAAGTGGGCCATTTTTGGTAAGCAGAACTG +GCGATGCGGGATGAACCGGAAGCCGGGTTACGGTGCCTAACTGCGCGCTAACCTAGAACC +CACAAAGGGTGTTGGTCGATTAAGACAGCAGGACGGTGGTCATGGAAGTCGAAATCCGCT +AAGGAGTGTGTAACAACTCACCTGCCGAATCAACTAGCCCCGAAAATGGATGGCGCTGAA +GCGCGCGACCTATACCCGGCCGTCGAGGCAAGTGCTAGGCCCCGATGAGTAGGAGGGCGC +AGCGGTCGCTGCAAAACCTTGGGCGTGAGCCCGGGCGGAGCGGCCGTTGGTGCGGATCTT +GGTGGTAGTAGCAAATATTCAAATGAGAACTTTGAAGGCCGAAGAGGGGAAAGGTTCCAT +GTGAACGGCACTTGCACATGGGTTAGTCGATCCTAAGAGTCGGGGGAAGCCCGACAGAGA +GCGCGTTCAGCGCGAACTTCGAAAGGGAATCGGGTTAAAATTCCTGAACCGGGACGTGGC +GGCTGACGGCAACGTTAGGGAGTCCGGAGACGTCGGCGGGGGCCTCGGGAAGAGTTATCT +TTTCTGTTTAACAGCCTGCCCACCCTGGAAACGGCTCAGCCGGAGGTAGGGTCCAGCGGC +TGGAAGAGCACCGCACGTCGCGTGGTGTCCGGTGCGCCCCCGGCGGCCCTTGAAAATCCG +GAGGACCGAGTGCCTTCCACGCCCGGTCGTACTCATAACCGCATCAGGTCTCCAAGGTGA +ACAGCCTCTGGTCGATGGAACAATGTAGGCAAGGGAAGTCGGCAAAATGGATCCGTAACT +TCGGGAAAAGGATTGGCTCTGAGGGCTGGGCACGGGGGTCCCAGTCCCGAACCCGTCGGC +TGTCGGTGGACTGCTCGAGCTGCTCCCGCGGCGAGAGCGGGTCACCGCGTGCCGGCCGGG +GGACGGACTGGGAACGGCTCCTCACGGGGCCTTCCCCGGGCGTCGAACAGTCAGACTCAG +AACTGGTACGGACAAGGGGAATCCGACTGTTTAATTAAAACAAAGCATTGCGATGGTCCC +TGCGGATGCTAACGCAATGTGATTTCTGCCCAGTGCTCTGAATGTCAAAGTGAAGAAATT +CAACCAAGCGCGGGTAAACGGCGGGAGTAACTATGACTCTCTTAAGGTAGCCAAATGCCT +CGTCATCTAATTAGTGACGCGCATGAATGGATTAACGAGATTCCCACTGTCCCTGTCTAC +TATCCAGCGAAACCACAGCCAAGGGAACGGGCTTGGCAGAATCAGCGGGGAAAGAAGACC +CTGTTGAGCTTGACTCTAGTCCGACTTTGTGAAATGACTTGAGAGGTGTAGGATAAGTGG +GAGCCGGAAACGGCAAAAGTGAAATACCACTACTTTTAACGTTATTTTACTTATTCCGTG +AATCGGAGGCGGGGCACTGCCCCTCTTTTTGGACCGAAGGCCAGCCTCGGCGGGCCGATC +CGGGCGGAAGACATTGTCAGGTGGGGAGTTTGGCTGGGGCGGCACATCTGTTAAAAGATA +ACGCAGGTGTCCTAAGATGAGCTCAACGAGAACAGAAATCTCGTGTGGAACAGAAGGGTA +AAAGCTCGTTTGATTCTGATTTCCAGTACGAATACGAACCGTGAAAGCGTGGCCTAACGA +TCCTTTAGACCTTCGGAATTTGAAGCTAGAGGTGTCAGAAAAGTTACCACAGGGATAACT +GGCTTGTGGCAGCCAAGCGTTCATAGCGACGTTGCTTTTTGATCCTTCGATGTCGGCTCT +TCCTATCATTGTGAAGCAGAATTCACCAAGTGTTGGATTGTTCACCCACCAATAGGGAAC +GTGAGCTGGGTTTAGACCGTCGTGAGACAGGTTAGTTTTACCCTACTGATGATAGTGTCG +CAATAGTAATTCAACCTAGTACGAGAGGAACCGTTGATTCGCACAATTGGTCATCGCGCT +TGGTTGAAAAGCCAGTGGCGCGAAGCTACCGTGCGTCGGATTATGACTGAACGCCTCTAA +GTCAGAATCCGGGCTAGAAGCGACGCATGTGCCCGCCGCCCGTTTGCCGACCCGCAGTAG +GGGCCATTCGGCCCCCAAAGGCACGTGTCGTTGGTGAAGCCGTGCGGTGGATGAGCCGTG +CGGGCCGCCTTGAAGTATAATTCCTACCGAGCGGCGGGTAGAATCCTTTGCAGACGACTT +AAATACGCGACGGGGTATTGTAAGTGGCAGAGTGGCCTTGCTGCCACGATCCACTGAGAT +TCAGCCCTGTGTCGCTTCGATTCGTCCCTCCCCCTTCAACATAAAAAAAATCTTTTTCCC +TTCCGATCCCAGAGGTTTCACCTTACAAGGAGGACCTTGGAACTTACGCTACACATAAGA +ATAGTGTGTAACGCGATTTACAACTATTACTAAGTGGCCGAACAATATGCACAAGTGTAT +GCCCAAAATTAAAGCAAAGTATCTAAAAAGTGCACAAGGCTGCCCAATGTTTTCCATATA +ACTGCACAAGGTGGCGAAAGTGCAAGCCTGCAGTGCCTATGTTTGTGCCTAAAGCTTCCC +AACGACTTGACTTGGCTGCCCATTGATGGGTAAACATGTGCGAAGAACTTTCCAATGCTG +CCCCATGGCTGGGCAAATGCGTGCCAATGACTTGCCATGGCTGCCCATTGGTAGGCAATT +ATGTGGCAACGACTTGCCAATGCAGCCCCATGGCTGGGCAATTGTGTGCCATCGACATGC +CAATGCAGCCCCATGACAGGGCAATTGTGTGCCATGGACATGCCAATGCTGCCCCATTGC +TGGCCCAATTGTGCCATCGACTTGAGAAAATTGGGCCATTGCTGGGCATATTGTGTGCCA +ACTACTTGACATGTCCGCCCATTGGTAGACGATTGTGTGCCATCGATTGCCAAGGCTGGG +CAATTATTTGCAGGTTGCCTAGAAAATGTGTGGCATTGCCCAGAAATTTGAGCCATGGCT +GGCCATTGCCGAGAAATCTGAGCCATGGGTGGGCATTTGTGTGCAAAGACAGATCATTGC +CCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAAT +TGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATT +GCTGCCCATTGCCTAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTTCCA +TTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAATCTGAGCCATGGCCGGGCAA +ATGCGTGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAGCC +ATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCAAATGTGTGCCACGGCTGA +TCATTGCCCAGACAATGTGAGCCATTGCCGACGAATTTGAGCCATGGCAGCCCATTGCCC +CGAAAAATGAGTGCCATGGCCGAGCATGTGTTCCAAGGCTGCCCATTGCCGAGAAATATG +AGCCATGGCCGGGCAAATGTGTGCCATGTCTGCCCATTGCCCAGAAATTGTGAGCCATGG +CTGCCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAATTGTGAGCCATGGCTGGCCAG +TGCCGAGAAATGTGAGCCACGGCTGGACAATTGCCGAGAAAATTGGGCCATTGCCCATAA +ATTTGAGTCATGGCTGGCCATTGCCGAGAAATGTTGTTCCATTGCCGAGAAAATTGGGCC +ATGGCTGGCCCATTGCCGACAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGC +CCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAACATTGGGCATGGCTGC +CCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCG +AGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCC +GAGAAATCTGAGCCATGGCTGGGCAAATGTGTGCCATGGCCGCCCATTGCCGAGAAATTG +TGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATTTTGTGCCATT +GCCTAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAA +TGGGAGCCATTGCTCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCA +TTGCCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAGAAATTTAAGGCATGGCCGGGCA +AATGCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAAC +CATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTG +ATCATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCC +GAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAAATG +TGAGCCATTGCCCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCATT +GCCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAGAATTTAAGGCATGGCCGGGCAAAT +GCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCAT +GGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTGATC +ATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAG +AAATCTGAGCCATGGCCTGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGA +GCCCTTGCCCAGAATTTTGAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCC +TGGAAATGTGAGCCCTGGCTGGGCAATTGCCGAGAAATGTGAGCCATTGCCCAGAAATTT +TAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTTG +CTGGGCAATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAAATTTGTGCCAT +TGCCGAGAAAATTGGGCCACGGCTGGCCATTGCCGAGAAATTGTTAGCCATTGCTGCCCA +TTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGTTGCCCATTGCCGAGG +AAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAGTTGCCGAGAAAATTGGG +CCATGGCTGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCT +GGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGT +CGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGG +CCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCAT +GGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGA +AATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGC +CATGGCTGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCTG +GCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCC +GAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGGC +CGGGCAAATGTGTGCCATTGCTGCCCATGGCCGAGAAATTGTGAGCCATTGCTGCCCATG +GCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGAA +ATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCC +ATGGCTGGGCATTTGTGTGCCAAGGCAGATCATTGCCCAGAAATTTGAGCCATGGCTGGC +CATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTTGGGCCATTGCCGGGCAAATGTGT +GCCATTGCTGCCCATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCT +GCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGC +CGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGTTGGGCATTG +TGTGCCAATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATG +TTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATG +GCCGGGCAAATTTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCA +TTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGA +AATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAAC +CATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCTG +CCCATTGCCGAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTG +CCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGC +CGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCTGATCATTGCCCAGAAATT +TGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTGGGCCATGG +CTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTGGCCATT +GCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCAATGGCTGCCCATTGCCGAGAAA +TCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCC +ATTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTGCCGAG +AAAATTAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATTGCCGA +GAAATCTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTG +AGCCATTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTGC +CGAGAAAATTAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATTG +CCGAGAAATCTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAAA +TGTGTGCTGTGCCATTGCCCAGAAAATGTGTGCCATTGCCCAGAAATTTAAGCCTTGGCT +GCCCATTGCTGGGCAATTGTGCGCCATCCACACCAAGGCCCAATGGGGTCTTGGTAAAAA +CAAGCATTTTTTGCGAAATGAGGTTGCGCGGGGCCCCGCTCGTTGTAAATTGCAATCTCA +AGGTGAACAAATGTGAAGGACGAGGCCCACACACCATGGGCAATCGAGACCCGATCCAAG +GGCAAGAAATTTAAATTAAAAGTCGACACCCGCGTTAGGTGCATATGCCAAGACCTACGG +CGGACACCCCGTGGCTCGACGTAAGCCGATGAGAATCCTAAGACAAAACCTTCCATTACC +CGTTTCCGTTCTCAAAACACGTATCCATGCTCAACATCTAAAAAAAAAGTTCCCCCAAGG +AACCGTTGCTCCTTTTGAACATCCCCATTCAATTCGATATTTTGATAACCAAACTACGTC +TTCATTTTTATGCGGCTCAAACCTATATGTAAACTAATCTAAATGTTTATCACTTCACCC +GGCCCCTCATTCTCAAAAATTTTTGTTTTTTCCCTTAATTTTTTTTATTTTCAATTAATT +TTTCAAAAAATATCGTATTTTTTTTTATGTGTTTCATCTTAAATATGAACTATATATATT +ATAAACCTCATTAAAAACATTCTCCATATTTTTCCATATTTATTACTATTTTTCCCTATT +TTTTACTATTTTTTAACTATTTTTTTGGTAATTAATTAAAATAAATTTTTTCGGATCTCA +AAAAATTATAAATTTTTTTCATGTTGTGCTATTATTTATTATTTTAAGATTTGAATTCAA +TTTTCATAAAAATAACTTATCCTTTTTAAAAAAAAACCATTATGACTCCTCAAGCATGGG +CAATGTTTCCTCCTGACATTTTCAGAAAAGCTCATATAGCATATATAAGGGGGGGTGTAT +GCCCAGGCCTCCCCTTACCCAGCATGGGTCAAGACTGGGCATGCATGGCCGCGCGCGTTG +GTTGGCAATTGGCAAGCATTGCCGCGCGCATGGGTTTGGCATTTTGGACGCGTGGGTTGG +CAATGGAAAGGCATTGTCGCACGTGTGTCTCGGCAATAGTTAGCCATGGCTCAAATTTCT +CGGCAATGGCACCAATTTTCTCGGCAATGGCACAAGTTTTCTCGGCAATGGCACATCTTT +TCTCGGCAATGACACATATTTTCTAGGCAATGGTTTGCCAAGGCACACAATTGCCCAGAA +AGCGTTGCCGAGCTTTGTTGAGAAGGCATTGCCGCGTGGGTTGGTTCGCTGTAGGCTTGC +ATTGATGCTGCGCATGTTGGTGGGAAATAGGCAAAGCGTTGCCGAGCGTGTTTGCTGGCA +GCACGCAGGCATTGCTGCGCATGTTGGCTGGAAATAAAGCTTGCATTGCCGAGCTCGTTG +GTAGGCAAGGGGCAGGCATGGCCGTGTGCATGGCTATGTTTGCCAGCTGCGTGTGTTGGC +AATGGGCAGGCATTGCTGCACGCTTGGGTGACCGGGAGGGGTTGCCTTTTGGCTTGTTGT +TGGGCATTCTTCGCAAGAGAAAGCTTGGACAATGGCCATGGGCAGCCAAGTCCAACATTG +GTCTATCGATTGATGCATGGGGTGGTGGGAGGGGATGTTGTGGAGCTTCCTTTGGGCTAG +TTGGGCATTCTTTGCAAGGCTTTCTTGCGCATGCAAGGGCCTAGACAATGCTTCAAGAAG +CCATGGGCAGCCCCACCGCTCATCCCACTGCCCTCATGCTTAGGTTGACAATGGACAATT +GGGATGCGTTGCCATGGTCTAGCAAGGGTGCTTGCTTGCATGTTCAAGTGTGCAAATGGG +TTTGTCAAATGTGGCCGATGTCCTCGCCATGCTAGAAAATTGTGTGGAATGACTTTGGGC +ATGCTATTGCTAGCTCATCGTTTGCCTATGCAACTAGTAGGGTGTGGCGATGTCATGGGC +TCGAGGGACATTCCTTAATGCTGGCTGGGTCATGTTTGTATGCTACTGTTGCTTGACAAT +GGCGTTGCATCGCTCATGGATGTTGCACAACACATTGTGCTCTGTTGGAAAAATGTGAAA +TCATGTCCCTTGAATTTTCGTGCCTATCGGTGCTTTGTTCTGTCTCTTCTCGATGTAATT +GCATTATTGTCGGTCAATATTTTGATCGATGGGGTGTGATTCAATTGGGGGAGTCGGGGC +ATAGTGTACGTAGTGGTGCGTGGGTGGTGTTTGGCCTGTGCGAGTTTGATGTTTCCTTGC +TTTGTGCAACGAATTCATCTCGTGCATTCCTCTTCAGTTATATCTTCAAGAGTAATAATA +ATTACTACCTTGAGTGTCCCATGGGTTCCTGTGTTGTATACCTCTGATGCAATGGAATTT +TCTCTGTAAAGACCCTATTTCGCTTTTGCACCACTCTGTGGTGCAAGTGAACCTCAAAGT +ATCACTCATGTCCCATGTGTGCCTCGCATTGAAGTTGCATGCATGGCTCATGGGTGCTTT +ACTCGTGCTCTCGGATGCGGAAATCTTTTGAGGGAAATTGGTCTTCTGACCTTTTTACCT +GTAAAGCGTTCGACCCTTAATTTGGAAGACTGTTGTGCTCGTCTTTGACCTATCCGATTG +CTCGGCTAGGCTCATGCGGTGCCAACGTCGCAAAGGAATGCTACCTGGTTGATCCTGCCA +GTAGTCATATGCTTGTCTCAAAGATTAAGCCATGCATGTGTAAGTATGAACTAATTCAGA +CTGTGAAACTGCGAATGGCTCATTAAATCAGTTATAGTTTGTTTGATGGTATTTGCTACT +CGGATAACCGTAGTAATTCTAGAGCTAATACGTGCAACAAACCCCGACTTCTGGAAGGGA +TGCATTTATTAGATAAAAGGTCGACGCGGGCTTTGCCCGTTGCTCTGATGATTCATGATA +ACTCGACGGATCGCACGGCCTTCGTGCCGGCGACGCATCATTCAAATTTCTGCCCTATCA +ACTTTCGATGGTAGGATAGTGGCCTACTATGGTGTTAACGGGTGACGGAGAATTAGGGTT +CGATTCCGGAGAGGGAGCCTGAGAAACGGCTACCACATCCAAGGAAGGCAGCAGGCGCGC +AAATTACCCAATCCTGACACGGGGAGGTAGTGACAATAAATAACAATACCGGGCTCATTG +AGTCTGGTAATTGGAATGAGTACAATCTAAATCCCTTAACGAGGATCCATTGGAGGGCAA +GTCTGGTGCCAGCAGCCGCGGTAATTCCAGCTCCAATAGCGTATATTTAAGTTGTTGCAG +TTAAAAAGCTCGTAGTTGGATTTTGGGTTGGGCCGACCGGTCCGCCTTCAGGTGTGCACC +GGTCGTCTCGTCCCTTCTGCCGGCGATGCGCTCCTAGCCTTAACTGGCCGGGTCGTGCCT +CCGGCGCTGTTACTTTGAAGAAATTAGAGTGCTCAAAGCAAGCCTACGCTCTGGATACAT +TAGCATGGGATAACATCATAGGATTTCGATCCTATTCTGTTGGCCTTCGGGATCGGAGTA +ATGATTAACAGGGACAGTCGGGGGCATTCGTATTTCATAGTCAGAGGTGAAATTCTTGGA +TTTATGAAAGACGAACAACTGCGAAAGCATTTGCCAAGGATGTTTTCATTAATCAAGAAC +GAAAGTTGGGGGCTCGAAGACGATCAGATACCGTCCTAGTCTCAACCATAAACGATGCCG +ACCAGGGATCAGCGGATGTTACTTTTAGGACTCCGCTGGCACCTTATGAGAAATCAAAGT +TTTTGGGTTCCGGGGGGAGTATGGTCGCAAGGCTGAAACTTAAAGGAATTGACGGAAGGG +CACCACCAGGAGTGGAGCCTGCGGCTTAATTTGACTCAACACGGGGAAACTTACCAGGTC +CAGACATAGTAAGGATTGACAGACTGAGAGCTCTTTCTTGATTCTATGGGTGGTGGTGCA +TGGCCGTTCTTAGTTGGTGGAGCGATTTGTCTGGTTAATTCCGTTAACGAACGAGACCTC +AGCCTGCTAACTAGCTATGTGGAGGTGACCCTCCACAGCTAGCTTCTTAGAGGGACTATG +GCCCTTCAGGCCACGGAAGTTTGAGGCAATAACAGGTCTGTGATGCCCTTAGATGTTCTG +GGCCGCACGCGCGCTACACTGATGTATTCAACGAGTTTATAGCCTTGGCCGACAGGCCCG +GGTAATCTTTGAAATTTCATCGTGATGGGGATAGATCATTGCAATTGTTGGTCTTCAACG +AGGAATTCCTAGTAAGCGCGAGTCATCAGCTCGCGTTGACTACGTCCCTGCCCTTTGTAC +ACACCGCCCGTCGCTCCTACCGATTGAATGGTCCGGTGAAGTGTTCGGATCGCGGCGACG +TGGGCGGTTCGCTGCCGGCGACGTCGCGAGAAGTCCACTGAACCTTATCATTTAGAGGAA +GGAGAAGTCGTAACAAGGTTTCCGTAGGTGAACCTGCGGAAGGATCATTGTCGAAACCTG +CCTAGCAGAATGACCCGCGAACTTGTATAATACCATCGGGGAAGCAAAAGTTTGGTTTTT +ATAGCCTACTTTTTCTTCCCTTTGCCGGGTGTGCTCGTGTTGCCCCATGGGTGACACTCT +CATTCCCCGGTCAAACAACGAACCCCGGCGCGAAACGCGTCAAGGAACTTGAACAAGAAT +GCAACATCCATGCCCCGTTTTTGGGTGCTTGTGGTGCTTGCTCTCTCATGAACGAAACGA +CTCTCGGCAACGGATATCTCGGCTCTCGCATCGATGAAGAACGTAGCGAAATGCGATACT +TGGTGTGAATTGCAGAATCCCGTGAACCATCGAGTTTTTGAACGCAAGTTGCGCCTGAAG +CCATTAGGCCGAGGGCACGTCTGCCTGGGCGTCACGCATTGTGTCGCCCACCCAACTCAA +GCCTTACCAAGGATTGGGTGTGGGTGGGCGGATATTGGCCCCCCGTGCACATTAGTGAAC +GGTCGGCCTAAAAATGAAGTCCTTGGCAATGGACGTCACAACAAGTGGTGGTTGACAAAC +CGTTGCGTCCTGTTGTGCTTGCCCCCATTGCTAATGGTTTACTTTTGACCCTAATGTGCC +GTTATCACGGCTTCGATCGCGACCCCAGGTCAGGCGGGATTACCCGCTGAGTTTAAGCAT +ATCAATAAGCGGAGGAAAAGAAACTTACAAGGATTCCCTTAGTAACGGCGAGCGAACCGG +GAATAGCCCAGCTTGAAAATCGGGCGATCTCGTTGTCCGAATTGTAGTCTGGAGAAGCGT +CCTCAGCGGCGGACCGGGCCCAAGTCCCCTGGAAGGGGGCGCCAGAGAGGGTGAGAGCCC +CGTCGTGCCCGGACCCTGTCGCACCACGAGGCGCTGTCGACGAGTCGGGTTGTTTGGGAA +TGCAGCCCCAATCGGGCGGTAAATTCCGTCCAAGGCTAAATATGGGCGAGAGACCGATAG +CAAACAAGTACCGCGAGGGAAAGATGAAAAGGACTTTGAAAAGAGAGTCAAAGAGTGCTT +GAAATTGTCGGGAGGGAAGCGGATGGGGGCCGGCGATGCGCCTCGGTCGGATGTGGAACG +GTTAATAGCCGGTCTGCCGATCGACTCGGGGCGTGGATCGGTGCGGATTGGGGCGGAGGC +CAAAGCCCGGGCAGTTGTTACGCCTGTGGAGACGCCTTTGCCTCGATCGTGGCTGGCAGC +GCGCGCCTTTGGCGTGCTTCGGCATCTGCGCGCTCCTGGCACCGGCCTGCGGGCTCCCCA +TTCGGCCCGTCTTGAAACACGGACCAAGGAGTCTGACATGTGTGCGAGTCAACGGGCGAG +TAAACCCGTAAGGCGTAAGGAAGCTGATTGGCGGGATCCCCTAGCGGGTTGCACCGCCGA +CCGACCTTGATCTTCTGAGAAGGGTTCGAGTGTGAGCATGCCTGTCGGGACCCGAAAGAT +GGTGAACTATGCCTGAGCGGGGCGAAGCCAGAGGAAACTCTGGTGGAGGCCCGCAGCGAT +ACTGACGTGCAAATCGTTCGTCTGACTTGGGTATAGGGGCGAAAGACTAATCGAACCGTC +TAGTAGCTGGTTCCCTCCGAAGTTTCCCTCAGGATAGCTGGAGCCCGTGTGCGAGTTCTA +TCGGGTAAAGCCAATGATTAGAGGCATCGGGGGCGCAACGCCCTCGACCTATTCTCAAAC +TTTAAATAGGTAGGACGGCGCGGCTGCTTTGTTGAGCCGCGCCACGGAATCGAGAGCTCC +AAGTGGGCCATTTTTGGTAAGCAGAACTGGCGATGCGGGATGAACCGGAAGCCGGGTTAC +GGTGCCTAACTGCGCGCTAACCTAGAACCCACAAAGGGTGTTGGTCGATTAAGACAGCAG +GACGGTGGTCATGGAAGTCGAAATCCGCTAAGGAGTGTGTAACAACTCACCTGCCGAATC +AACTAGCCCCGAAAATGGATGGCGCTGAAGCGCGCGACCTATACCCGGCCGTCGAGGCAA +GTGCTAGGCCCCGATGAGTAGGAGGGCGCAGCGGTCGCTGCAAAACCTTGGGCGTGAGCC +CGGGCGGAGCGGCCGTTGGTGCGGATCTTGGTGGTAGTAGCAAATATTCAAATGAGAACT +TTGAAGGCCGAAGAGGGGAAAGGTTCCATGTGAACGGCACTTGCACATGGGTTAGTCGAT +CCTAAGAGTCGGGGGAAGCCCGACAGAGAGCGCGTTCAGCGCGAACTTCGAAAGGGAATC +GGGTTAAAATTCCTGAACCGGGACGTGGCGGCTGACGGCAACGTTAGGGAGTCCGGAGAC +GTCGGCGGGGGCCTCGGGAAGAGTTATCTTTTCTGTTTAACAGCCTGCCCACCCTGGAAA +CGGCTCAGCCGGAGGTAGGGTCCAGCGGCTGGAAGAGCACCGCACGTCGCGTGGTGTCCG +GTGCGCCCCCGGCGGCCCTTGAAAATCCGGAGGACCGAGTGCCTTCCACGCCCGGTCGTA +CTCATAACCGCATCAGGTCTCCAAGGTGAACAGCCTCTGGTCGATGGAACAATGTAGGCA +AGGGAAGTCGGCAAAATGGATCCGTAACTTCGGGAAAAGGATTGGCTCTGAGGGCTGGGC +ACGGGGGTCCCAGTCCCGAACCCGTCGGCTGTCGGTGGACTGCTCGAGCTGCTCCCGCGG +CGAGAGCGGGTCACCGCGTGCCGGCCGGGGGACGGACTGGGAACGGCTCCTCACGGGGCC +TTCCCCGGGCGTCGAACAGTCAGACTCAGAACTGGTACGGACAAGGGGAATCCGACTGTT +TAATTAAAACAAAGCATTGCGATGGTCCCTGCGGATGCTAACGCAATGTGATTTCTGCCC +AGTGCTCTGAATGTCAAAGTGAAGAAATTCAACCAAGCGCGGGTAAACGGCGGGAGTAAC +TATGACTCTCTTAAGGTAGCCAAATGCCTCGTCATCTAATTAGTGACGCGCATGAATGGA +TTAACGAGATTCCCACTGTCCCTGTCTACTATCCAGCGAAACCACAGCCAAGGGAACGGG +CTTGGCAGAATCAGCGGGGAAAGAAGACCCTGTTGAGCTTGACTCTAGTCCGACTTTGTG +AAATGACTTGAGAGGTGTAGGATAAGTGGGAGCCGGAAACGGCAAAAGTGAAATACCACT +ACTTTTAACGTTATTTTACTTATTCCGTGAATCGGAGGCGGGGCACTGCCCCTCTTTTTG +GACCGAAGGCCAGCCTCGGCGGGCCGATCCGGGCGGAAGACATTGTCAGGTGGGGAGTTT +GGCTGGGGCGGCACATCTGTTAAAAGATAACGCAGGTGTCCTAAGATGAGCTCAACGAGA +ACAGAAATCTCGTGTGGAACAGAAGGGTAAAAGCTCGTTTGATTCTGATTTCCAGTACGA +ATACGAACCGTGAAAGCGTGGCCTAACGATCCTTTAGACCTTCGGAATTTGAAGCTAGAG +GTGTCAGAAAAGTTACCACAGGGATAACTGGCTTGTGGCAGCCAAGCGTTCATAGCGACG +TTGCTTTTTGATCCTTCGATGTCGGCTCTTCCTATCATTGTGAAGCAGAATTCACCAAGT +GTTGGATTGTTCACCCACCAATAGGGAACGTGAGCTGGGTTTAGACCGTCGTGAGACAGG +TTAGTTTTACCCTACTGATGATAGTGTCGCAATAGTAATTCAACCTAGTACGAGAGGAAC +CGTTGATTCGCACAATTGGTCATCGCGCTTGGTTGAAAAGCCAGTGGCGCGAAGCTACCG +TGCGTCGGATTATGACTGAACGCCTCTAAGTCAGAATCCGGGCTAGAAGCGACGCATGTG +CCCGCCGCCCGTTTGCCGACCCGCAGTAGGGGCCATTCGGCCCCCAAAGGCACGTGTCGT +TGGTGAAGCCCGTGCGGTGGATGAGCCGTGCGGGCCGCCTTGAAGTATAATTCCTACCGA +GCGGCGGGTAGAATCCTTTGCAGACGACTTAAATACGCGACGGGGTATTGTAAGTGGCAG +AGTGGCCTTGCTGCCACGATCCACTGAGATTCAGCCCTGTGTCGCTTCGATTCGTCCCTC +CCCCTTCAACATAAAAAAAATCTTTTTCCCTTCCGATCCCAGAGGTTTCACCTTACAAGG +AGGACCTTGGAACTTACGCTACACATAAGAATAGTGTGTAACGCGATTTACAACTATTAC +TAAGTGGCCGAACAATATGCACAAGTGTATGCCCAAAATTAAAGCAAAGTATCTAAAAAG +TGCACAAGGCTGCCCAATGTTTTCCATATAACTGCACAAGGTGGCGAAAGTGCAAGCCTG +CAGTGCCTATGTTTGTGCCTAAAGCTTCCCAACGACTTGACTTGGCTGCCCATTGATGGG +TAAACATGTGCGAAGAACTTTCCAATGCTGCCCCATGGCTGGGCAAATGCGTGCCAATGA +CTTGCCATGGCTGCCCATTGGTAGGCAATTATGTGGCAACGACTTGCCAATGCAGCCCCA +TGGCTGGGCAATTGTGTGCCATCGACATGCCAATGCAGCCCCATGACAGGGCAATTGTGT +GCCATGGACATGCCAATGCTGCCCCATTGCTGGCCCAATTGTGCCATCGACTTGAGAAAA +TTGGGCCATTGCTGGGCATATTGTGTGCCAACTACTTGACATGTCCGCCCATTGGTAGAC +GATTGTGTGCCATCGATTGCCAAGGCTGGGCAATTATTTGCAGGTTGCCTAGAAAATGTG +TGGCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATCTGAGCCATGGGT +GGGCATTTGTGTGCAAAGACAGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGC +CGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATC +TGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCTAGAAATTGTGAGCCAT +TGCTGCCCATTGCCGAGAAATTTTGTTCCATTGCCGAGAAAATTGGGCCATGGCTGCCCA +TTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGG +AAATGAGTGCCATTGCCGAGAAATGTGAGCCATGGCTGGGCAATTGCCGAGAAAATTGGG +CCATGGCTGGGCAAATGTGTGCCACGGCTGATCATTGCCCAGACAATGTGAGCCATTGCC +GACGAATTTGAGCCATGGCAGCCCATTGCCCCGAAAAATGAGTGCCATGGCCGAGCATGT +GTTCCAAGGCTGCCCATTGCCGAGAAATATGAGCCATGGCCGGGCAAATGTGTGCCATGT +CTGCCCATTGCCCAGAAATTGTGAGCCATGGCTGCCCCATTGCCGAGAAATCTGAGCCAT +GGCCGGGCAATTGTGAGCCATGGCTGGCCAGTGCCGAGAAATGTGAGCCACGGCTGGACA +ATTGCCGAGAAAATTGGGCCATTGCCCATAAATTTGAGTCATGGCTGGCCATTGCCGAGA +AATGTTGTTCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGACAAATCTGAGC +CATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTG +CCCATTGCCGAGAACATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCG +GGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGC +CGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATG +TGTGCCATGGCCGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATG +GCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTGCCCAT +TGCCGAGAAATCTGAGCCATGGCCGGGCAAATGGGAGCCATTGCTCAGAAATTTTAGCCA +TGGCTGCCCATTGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCCC +ATTGCCGAGAAATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGAG +GAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGG +GCCATGGCTGGGCATTTGTGTGCCTAGTGTCACGGGCTTAAAATCTGATCACCTCGACCC +GTGCGGCACTTAGTCGCTTTTCCCGCAAAAGTCGCTAAGTAAGCCTTAAGACAACCGAAA +GGAAGGCTAAGGAACCAAGTGTGCAACAAGGAAGTTTTTAGAGAGAGAGAGAGTTTGGGA +GAATGCCTTTGATTTCTCAAAACTTGGATGATTTACAAATGAGGGGGTTGCCCCCTTTAT +ATACAAGTTGGCCTTTTTCTAGAATATTCTACCTAGAATGTTCTATGTATAAGAATTTCC +TAGAAGCCTCCACCAAGGTCTAGAATCTTCCACCATGATCTAGAATTCTCCATACCCTTC +TAGCATGTGGGAGAGTCTTCTAGAACCATCTCCTAGCTTCCGGAAGTCCCATGAGAGACC +TAGAATATTCTAGGCTCTTCCAAGCAACTTGGCCCTCCTTAGGCCTAATTTTTGGGTCAA +GTGAGTGAGCATGTAACACTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTGCCCAGA +AATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGC +CATGGCTGCCCATTGCCTAGAAAATGTGAGCCATTGCCCAGAAATTTTAGCCATGGCTGC +CCATTGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCCCATTGCCG +AGAAATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGAGGAAATGA +GTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGG +CTGGGCATTTGTGTGCCTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTGCCCAGAAA +TTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCTGGCAAATGCGTGCCA +TGGCTGCCCATTGCCGAGAAATTGTGAGCCCTTGCCCAGAATTTTGAGCCATGGCTGGCC +ATTGCCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTGGCTGGGCAATTGCCGA +GAAATGTGAGCCATTGCCCAGAAATTTTAGCCATGGCTGGCCATTGCCGAGAAATGATGT +GCCATTGCCTGGAAATGTGAGCCCTTGCTGGGCAATTGCCCAGAAATTTGAGCCATGGCT +GCCCATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCACGGCTGGCCATTGC +CGAGAAATTGTTAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCGAGAAAA +TTGGGCCATGGTTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCAT +GGCTGGGCAGTTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGGCTGATC +ATTGCCTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGA +GAAAATTGGGCCATGGCTGCCCATTGTCGAGAAATTTGAGCCATGGCCGGGCAAATGTGT +GCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCC +GAGAAATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGAGAAAAT +TGGGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATG +GCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGGCTGATCA +TTGCCTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAG +AAAATTGGGCCATGGCTGCCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTG +CCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATGGCCG +AGAAATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGAGAAAATT +GGGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGG +CTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCAAGGCAGATCAT +TGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAA +ATTTGGGCCATTGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGAAAATTTGTGC +CATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCC +CATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCG +AGAAAATTGGGCCATGGTTGGGCATTTGTGTGCCAATGCTGATCATTGCCCAGAAATTTG +AGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGC +TGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATTTGTGCCATTGCTGCCCATTG +CCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCGAGAAA +ATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAA +ATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCC +ATGGCTGGGCATTTGTGTGCAAATGCTGCCCATTGCCGAGAAATTTGAGCCATGGCTGCC +CATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGA +GAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTG +TGCAAATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTT +GTGCCATTGCCGAGAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCC +GGGCAAATGTGTGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAAT +TGGGCAATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATG +GCTGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAAGGCTGCCCAT +TGCCGAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCATTGCCGAGAA +ATTGTGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGCGTGC +CATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAAGGCTGC +CCATTGCCGAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCATTGCCG +AGAAATTGTGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGC +GTGCCATGGCTGCCCATTGCCTAGAAAATGTGTGCTGTGCCATTGCCCAGAAAATGTGTG +CCATTGCCCAGAAATTTAAGCCTTGGCTGCCCATTGCTGGGCAATTGTGCGCCATCCACA +CCAAGGCCCAATGGGGTCTTGGTAAAAACAAGCATTTTTTGCGAAATGAGGTTGCGCGGG +GCCCCGCTCGTTGTAAATTGCAATCTCAAGGTGAACAAATGTGAAGGACGAGGCCCACAC +ACCATGGGCAATCGAGACCCGATCCAAGGGCAAGAAATTTAAATTAAAAGTCGACACCCG +CGTTAGGTGCATATGCCAAGACCTACGGCGGACACCCCGTGGCTCGACGTAAGCCGATGA +GAATCCTAAGACAAAACCTTCCATTACCCGTTTCCGTTCTCAAAACACGTATCCATGCTC +AACATCTAAAAAAAAAGTTCCCCCAAGGAACCGTTGCTCCTTTTGAACATCCCCATTCAA +TTCGATATTTTGATAACCAAACTACGTCTTCATTTTTATGCGGCTCAAACCTATATGTAA +ACTAATCTAAATGTTTATCACTTCACCCGGCCCCTCATTCTCAAAAATTTTTGTTTTTTC +CCTTAATTTTTTTTATTTTCAATTAATTTTTCAAAAAATATCGTATTTTTTTTTATGTGT +TTCATCTTAAATATGAACTATATATATTATAAACCTCATTAAAAACATTCTCCATATTTT +TCCATATTTATTACTATTTTTCCCTATTTTTTACTATTTTTTAACTATTTTTTTGGTAAT +TAATTAAAATAAATTTTTTCGGATCTCAAAAAATTATAAATTTTTTTCATGTTGTGCTAT +TATTTATTATTTTAAGATTTGAATTCAATTTTCATAAAAATAACTTATCCTTTTTAAAAA +AAAACCATTATGACTCCTCAAGCATGGGCAATGTTTCCTCCTGACATTTTCAGAAAAGCT +CATATAGCATATATAAGGGGGGGTGTATGCCCAGGCCTCCCCTTACCCAGCATGGGTCAA +GACTGGGCATGCATGGCCGCGCGCGTTGGTTGGCAATTGGCAAGCATTGCCGCGCGCATG +GGTTTGGCATTTTGGACGCGTGGGTTGGCAATGGAAAGGCATTGTCGCACGTGTGTCTCG +GCAATAGTTAGCCATGGCTCAAATTTCTCGGCAATGGCACCAATTTTCTCGGCAATGGCA +CAAGTTTTCTCGGCAATGGCACATCTTTTCTCGGCAATGACACATATTTTCTAGGCAATG +GTTTGCCAAGGCACACAATTGCCCAGAAAGCGTTGCCGAGCTTTGTTGAGAAGGCATTGC +CGCGTGGGTTGGTTCGCTGTAGGCTTGCATTGATGCTGCGCATGTTGGTGGGAAATAGGC +AAAGCGTTGCCGAGCGTGTTTGCTGGCAGCACGCAGGCATTGCTGCGCATGTTGGCTGGA +AATAAAGCTTGCATTGCCGAGCTCGTTGGTAGGCAAGGGGCAGGCATGGCCGTGTGCATG +GCTATGTTTGCCAGCTGCGTGTGTTGGCAATGGGCAGGCATTGCTGCACGCTTGGGTGAC +CGGGAGGGGTTGCCTTTTGGCTTGTTGTTGGGCATTCTTCGCAAGAGAAAGCTTGGACAA +TGGCCATGGGCAGCCAAGTCCAACATTGGTCTATCGATTGATGCATGGGGTGGTGGGAGG +GGATGTTGTGGAGCTTCCTTTGGGCTAGTTGGGCATTCTTTGCAAGGCTTTCTTGCGCAT +GCAAGGGCCTAGACAATGCTTCAAGAAGCCATGGGCAGCCCCACCGCTCATCCCACTGCC +CTCATGCTTAGGTTGACAATGGACAATTGGGATGCGTTGCCATGGTCTAGCAAGGGTGCT +TGCTTGCATGTTCAAGTGTGCAAATGGGTTTGTCAAATGTGGCCGATGTCCTCGCCATGC +TAGAAAATTGTGTGGAATGACTTTGGGCATGCTATTGCTAGCTCATCGTTTGCCTATGCA +ACTAGTAGGGTGTGGCGATGTCATGGGCTCGAGGGACATTCCTTAATGCTGGCTGGGTCA +TGTTTGTATGCTACTGTTGCTTGACAATGGCGTTGCATCGCTCATGGATGTTGCACAACA +CATTGTGCTCTGTTGGAAAAATGTGAAATCATGTCCCTTGAATTTTCGTGCCTATCGGTG +CTTTGTTCTGTCTCTTCTCGATGTAATTGCATTATTGTCGGTCAATATTTTGATCGATGG +GGTGTGATTCAATTGGGGGAGTCGGGGCATAGTGTACGTAGTGGTGCGTGGGTGGTGTTT +GGCCTGTGCGAGTTTGATGTTTCCTTGCTTTGTGCAACGAATTCATCTCGTGCATTCCTC +TTCAGTTATATCTTCAAGAGTAATAATAATTACTACCTTGAGTGTCCCATGGGTTCCTGT +GTTGTATACCTCTGATGCAATGGAATTTTCTCTGTAAAGACCCTATTTCGCTTTTGCACC +ACTCTGTGGTGCAAGTGAACCTCAAAGTATCACTCATGTCCCATGTGTGCCTCGCATTGA +AGTTGCATGCATGGCTCATGGGTGCTTTACTCGTGCTCTCGGATGCGGAAATCTTTTGAG +GGAAATTGGTCTTCTGACCTTTTTACCTGTAAAGCGTTCGACCCTTAATTTGGAAGACTG +TTGTGCTCGTCTTTGACCTATCCGATTGCTCGGCTAGGCTCATGCGGTGCCAACGTCGCA +AAGGAATGCTACCTGGTTGATCCTGCCAGTAGTCATATGCTTGTCTCAAAGATTAAGCCA +TGCATGTGTAAGTATGAACTAATTCAGACTGTGAAACTGCGAATGGCTCATTAAATCAGT +TATAGTTTGTTTGATGGTATTTGCTACTCGGATAACCGTAGTAATTCTAGAGCTAATACG +TGCAACAAACCCCGACTTCTGGAAGGGATGCATTTATTAGATAAAAGGTCGACGCGGGCT +TTGCCCGTTGCTCTGATGATTCATGATAACTCGACGGATCGCACGGCCTTCGTGCCGGCG +ACGCATCATTCAAATTTCTGCCCTATCAACTTTCGATGGTAGGATAGTGGCCTACTATGG +TGTTAACGGGTGACGGAGAATTAGGGTTCGATTCCGGAGAGGGAGCCTGAGAAACGGCTA +CCACATCCAAGGAAGGCAGCAGGCGCGCAAATTACCCAATCCTGACACGGGGAGGTAGTG +ACAATAAATAACAATACCGGGCTCATTGAGTCTGGTAATTGGAATGAGTACAATCTAAAT +CCCTTAACGAGGATCCATTGGAGGGCAAGTCTGGTGCCAGCAGCCGCGGTAATTCCAGCT +CCAATAGCGTATATTTAAGTTGTTGCAGTTAAAAAGCTCGTAGTTGGATTTTGGGTTGGG +CCGACCGGTCCGCCTTCAGGTGTGCACCGGTCGTCTCGTCCCTTCTGCCGGCGATGCGCT +CCTAGCCTTAACTGGCCGGGTCGTGCCTCCGGCGCTGTTACTTTGAAGAAATTAGAGTGC +TCAAAGCAAGCCTACGCTCTGGATACATTAGCATGGGATAACATCATAGGATTTCGATCC +TATTCTGTTGGCCTTCGGGATCGGAGTAATGATTAACAGGGACAGTCGGGGGCATTCGTA +TTTCATAGTCAGAGGTGAAATTCTTGGATTTATGAAAGACGAACAACTGCGAAAGCATTT +GCCAAGGATGTTTTCATTAATCAAGAACGAAAGTTGGGGGCTCGAAGACGATCAGATACC +GTCCTAGTCTCAACCATAAACGATGCCGACCAGGGATCAGCGGATGTTACTTTTAGGACT +CCGCTGGCACCTTATGAGAAATCAAAGTTTTTGGGTTCCGGGGGGAGTATGGTCGCAAGG +CTGAAACTTAAAGGAATTGACGGAAGGGCACCACCAGGAGTGGAGCCTGCGGCTTAATTT +GACTCAACACGGGGAAACTTACCAGGTCCAGACATAGTAAGGATTGACAGACTGAGAGCT +CTTTCTTGATTCTATGGGTGGTGGTGCATGGCCGTTCTTAGTTGGTGGAGCGATTTGTCT +GGTTAATTCCGTTAACGAACGAGACCTCAGCCTGCTAACTAGCTATGTGGAGGTGACCCT +CCACAGCTAGCTTCTTAGAGGGACTATGGCCCTTCAGGCCACGGAAGTTTGAGGCAATAA +CAGGTCTGTGATGCCCTTAGATGTTCTGGGCCGCACGCGCGCTACACTGATGTATTCAAC +GAGTTTATAGCCTTGGCCGACAGGCCCGGGTAATCTTTGAAATTTCATCGTGATGGGGAT +AGATCATTGCAATTGTTGGTCTTCAACGAGGAATTCCTAGTAAGCGCGAGTCATCAGCTC +GCGTTGACTACGTCCCTGCCCTTTGTACACACCGCCCGTCGCTCCTACCGATTGAATGGT +CCGGTGAAGTGTTCGGATCGCGGCGACGTGGGCGGTTCGCTGCCGGCGACGTCGCGAGAA +GTCCACTGAACCTTATCATTTAGAGGAAGGAGAAGTCGTAACAAGGTTTCCGTAGGTGAA +CCTGCGGAAGGATCATTGTCGAAACCTGCCTAGCAGAATGACCCGCGAACTTGTATAATA +CCATCGGGGAAGCAAAAGTTTGGTTTTTATAGCCTACTTTTTCTTCCCTTTGCCGGGTGT +GCTCGTGTTGCCCCATGGGTGACACTCTCATTCCCCGGTCAAACAACGAACCCCGGCGCG +AAACGCGTCAAGGAACTTGAACAAGAATGCAACATCCATGCCCCGTTTTTGGGTGCTTGT +GGTGCTTGCTCTCTCATGAACGAAACGACTCTCGGCAACGGATATCTCGGCTCTCGCATC +GATGAAGAACGTAGCGAAATGCGATACTTGGTGTGAATTGCAGAATCCCGTGAACCATCG +AGTTTTTGAACGCAAGTTGCGCCTGAAGCCATTAGGCCGAGGGCACGTCTGCCTGGGCGT +CACGCATTGTGTCGCCCACCCAACTCAAGCCTTACCAAGGATTGGGTGTGGGTGGGCGGA +TATTGGCCCCCCGTGCACATTAGTGAACGGTCGGCCTAAAAATGAAGTCCTTGGCAATGG +ACGTCACAACAAGTGGTGGTTGACAAACCGTTGCGTCCTGTTGTGCTTGCCCCCATTGCT +AATGGTTTACTTTTGACCCTAATGTGCCGTTATCACGGCTTCGATCGCGACCCCAGGTCA +GGCGGGATTACCCGCTGAGTTTAAGCATATCAATAAGCGGAGGAAAAGAAACTTACAAGG +ATTCCCTTAGTAACGGCGAGCGAACCGGGAATAGCCCAGCTTGAAAATCGGGCGATCTCG +TTGTCCGAATTGTAGTCTGGAGAAGCGTCCTCAGCGGCGGACCGGGCCCAAGTCCCCTGG +AAGGGGGCGCCAGAGAGGGTGAGAGCCCCGTCGTGCCCGGACCCTGTCGCACCACGAGGC +GCTGTCGACGAGTCGGGTTGTTTGGGAATGCAGCCCCAATCGGGCGGTAAATTCCGTCCA +AGGCTAAATATGGGCGAGAGACCGATAGCAAACAAGTACCGCGAGGGAAAGATGAAAAGG +ACTTTGAAAAGAGAGTCAAAGAGTGCTTGAAATTGTCGGGAGGGAAGCGGATGGGGGCCG +GCGATGCGCCTCGGTCGGATGTGGAACGGTTAATAGCCGGTCTGCCGATCGACTCGGGGC +GTGGATCGGTGCGGATTGGGGCGGAGGCCAAAGCCCGGGCAGTTGTTACGCCTGTGGAGA +CGCCTTTGCCTCGATCGTGGCTGGCAGCGCGCGCCTTTGGCGTGCTTCGGCATCTGCGCG +CTCCTGGCACCGGCCTGCGGGCTCCCCATTCGGCCCGTCTTGAAACACGGACCAAGGAGT +CTGACATGTGTGCGAGTCAACGGGCGAGTAAACCCGTAAGGCGTAAGGAAGCTGATTGGC +GGGATCCCCTAGCGGGTTGCACCGCCGACCGACCTTGATCTTCTGAGAAGGGTTCGAGTG +TGAGCATGCCTGTCGGGACCCGAAAGATGGTGAACTATGCCTGAGCGGGGCGAAGCCAGA +GGAAACTCTGGTGGAGGCCCGCAGCGATACTGACGTGCAAATCGTTCGTCTGACTTGGGT +ATAGGGGCGAAAGACTAATCGAACCGTCTAGTAGCTGGTTCCCTCCGAAGTTTCCCTCAG +GATAGCTGGAGCCCGTGTGCGAGTTCTATCGGGTAAAGCCAATGATTAGAGGCATCGGGG +GCGCAACGCCCTCGACCTATTCTCAAACTTTAAATAGGTAGGACGGCGCGGCTGCTTTGT +TGAGCCGCGCCACGGAATCGAGAGCTCCAAGTGGGCCATTTTTGGTAAGCAGAACTGGCG +ATGCGGGATGAACCGGAAGCCGGGTTACGGTGCCTAACTGCGCGCTAACCTAGAACCCAC +AAAGGGTGTTGGTCGATTAAGACAGCAGGACGGTGGTCATGGAAGTCGAAATCCGCTAAG +GAGTGTGTAACAACTCACCTGCCGAATCAACTAGCCCCGAAAATGGATGGCGCTGAAGCG +CGCGACCTATACCCGGCCGTCGAGGCAAGTGCTAGGCCCCGATGAGTAGGAGGGCGCAGC +GGTCGCTGCAAAACCTTGGGCGTGAGCCCGGGCGGAGCGGCCGTTGGTGCGGATCTTGGT +GGTAGTAGCAAATATTCAAATGAGAACTTTGAAGGCCGAAGAGGGGAAAGGTTCCATGTG +AACGGCACTTGCACATGGGTTAGTCGATCCTAAGAGTCGGGGGAAGCCCGACAGAGAGCG +CGTTCAGCGCGAACTTCGAAAGGGAATCGGGTTAAAATTCCTGAACCGGGACGTGGCGGC +TGACGGCAACGTTAGGGAGTCCGGAGACGTCGGCGGGGGCCTCGGGAAGAGTTATCTTTT +CTGTTTAACAGCCTGCCCACCCTGGAAACGGCTCAGCCGGAGGTAGGGTCCAGCGGCTGG +AAGAGCACCGCACGTCGCGTGGTGTCCGGTGCGCCCCCGGCGGCCCTTGAAAATCCGGAG +GACCGAGTGCCTTCCACGCCCGGTCGTACTCATAACCGCATCAGGTCTCCAAGGTGAACA +GCCTCTGGTCGATGGAACAATGTAGGCAAGGGAAGTCGGCAAAATGGATCCGTAACTTCG +GGAAAAGGATTGGCTCTGAGGGCTGGGCACGGGGGTCCCAGTCCCGAACCCGTCGGCTGT +CGGTGGACTGCTCGAGCTGCTCCCGCGGCGAGAGCGGGTCACCGCGTGCCGGCCGGGGGA +CGGACTGGGAACGGCTCCTCACGGGGCCTTCCCCGGGCGTCGAACAGTCAGACTCAGAAC +TGGTACGGACAAGGGGAATCCGACTGTTTAATTAAAACAAAGCATTGCGATGGTCCCTGC +GGATGCTAACGCAATGTGATTTCTGCCCAGTGCTCTGAATGTCAAAGTGAAGAAATTCAA +CCAAGCGCGGGTAAACGGCGGGAGTAACTATGACTCTCTTAAGGTAGCCAAATGCCTCGT +CATCTAATTAGTGACGCGCATGAATGGATTAACGAGATTCCCACTGTCCCTGTCTACTAT +CCAGCGAAACCACAGCCAAGGGAACGGGCTTGGCAGAATCAGCGGGGAAAGAAGACCCTG +TTGAGCTTGACTCTAGTCCGACTTTGTGAAATGACTTGAGAGGTGTAGGATAAGTGGGAG +CCGGAAACGGCAAAAGTGAAATACCACTACTTTTAACGTTATTTTACTTATTCCGTGAAT +CGGAGGCGGGGCACTGCCCCTCTTTTTGGACCGAAGGCCAGCCTCGGCGGGCCGATCCGG +GCGGAAGACATTGTCAGGTGGGGAGTTTGGCTGGGGCGGCACATCTGTTAAAAGATAACG +CAGGTGTCCTAAGATGAGCTCAACGAGAACAGAAATCTCGTGTGGAACAGAAGGGTAAAA +GCTCGTTTGATTCTGATTTCCAGTACGAATACGAACCGTGAAAGCGTGGCCTAACGATCC +TTTAGACCTTCGGAATTTGAAGCTAGAGGTGTCAGAAAAGTTACCACAGGGATAACTGGC +TTGTGGCAGCCAAGCGTTCATAGCGACGTTGCTTTTTGATCCTTCGATGTCGGCTCTTCC +TATCATTGTGAAGCAGAATTCACCAAGTGTTGGATTGTTCACCCACCAATAGGGAACGTG +AGCTGGGTTTAGACCGTCGTGAGACAGGTTAGTTTTACCCTACTGATGATAGTGTCGCAA +TAGTAATTCAACCTAGTACGAGAGGAACCGTTGATTCGCACAATTGGTCATCGCGCTTGG +TTGAAAAGCCAGTGGCGCGAAGCTACCGTGCGTCGGATTATGACTGAACGCCTCTAAGTC +AGAATCCGGGCTAGAAGCGACGCATGTGCCCGCCGCCCGTTTGCCGACCCGCAGTAGGGG +CCATTCGGCCCCCAAAGGCACGTGTCGTTGGTGAAGCCCGTGCGGTGGATGAGCCGTGCG +GGCCGCCTTGAAGTATAATTCCTACCGAGCGGCGGGTAGAATCCTTTGCAGACGACTTAA +ATACGCGACGGGGTATTGTAAGTGGCAGAGTGGCCTTGCTGCCACGATCCACTGAGATTC +AGCCCTGTGTCGCTTCGATTCGTCCCTCCCCCTTCAACATAAAAAAAATCTTTTTCCCTT +CCGATCCCAGAGGTTTCACCTTACAAGGAGGACCTTGGAACTTACGCTACACATAAGAAT +AGTGTGTAACGCGATTTACAACTATTACTAAGTGGCCGAACAATATGCACAAGTGTATGC +CCAAAATTAAAGCAAAGTATCTAAAAAGTGCACAAGGCTGCCCAATGTTTTCCATATAAC +TGCACAAGGTGGCGAAAGTGCAAGCCTGCAGTGCCTATGTTTGTGCCTAAAGCTTCCCAA +CGACTTGACTTGGCTGCCCATTGATGGGTAAACATGTGCGAAGAACTTTCCAATGCTGCC +CCATGGCTGGGCAAATGCGTGCCAATGACTTGCCATGGCTGCCCATTGGTAGGCAATTAT +GTGGCAACGACTTGCCAATGCAGCCCCATGGCTGGGCAATTGTGTGCCATCGACATGCCA +ATGCAGCCCCATGACAGGGCAATTGTGTGCCATGGACATGCCAATGCTGCCCCATTGCTG +GCCCAATTGTGCCATCGACTTGAGAAAATTGGGCCATTGCTGGGCATATTGTGTGCCAAC +TACTTGACATGTCCGCCCATTGGTAGACGATTGTGTGCCATCGATTGCCAAGGCTGGGCA +ATTATTTGCAGGTTGCCTAGAAAATGTGTGGCATTGCCCAGAAATTTGAGCCATGGCTGG +CCATTGCCGAGAAATCTGAGCCATGGGTGGGCATTTGTGTGCAAAGACAGATCATTGCCC +AGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTG +GGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATTGC +TGCCCATTGCCTAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTTCCATT +GCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAA +TGCGTGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAGCCA +TGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCAAATGTGTGCCACGGCTGAT +CATTGCCCAGACAATGTGAGCCATTGCCGACGAATTTGAGCCATGGCAGCCCATTGCCCC +GAAAAATGAGTGCCATGGCCGAGCATGTGTTCCAAGGCTGCCCATTGCCGAGAAATATGA +GCCATGGCCGGGCAAATGTGTGCCATGTCTGCCCATTGCCCAGAAATTGTGAGCCATGGC +TGCCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAATTGTGAGCCATGGCTGGCCAGT +GCCGAGAAATGTGAGCCACGGCTGGACAATTGCCGAGAAAATTGGGCCATTGCCCATAAA +TTTGAGTCATGGCTGGCCATTGCCGAGAAATGTTGTTCCATTGCCGAGAAAATTGGGCCA +TGGCTGCCCATTGCCGACAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCC +ATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAACATTGGGCCATGGCTGCC +CATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGA +GAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCG +AGAAATCTGAGCCATGGCTGGGCAAATGTGTGCCATGGCCGCCCATTGCCGAGAAATTGT +GAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATTTTGTGCCATTG +CCTAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAAT +GGGAGCCATTGCTCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCAT +TGCCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAGAAATTTAAGGCATGGCCGGGCAA +ATGCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACC +ATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTGA +TCATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCG +AGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAAATGT +GAGCCATTGCCCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCATTG +CCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAGAAATTTAAGGCATGGCCGGGCAAAT +GCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCAT +GGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTGATC +ATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAG +AAATCTGAGCCATGGCCTGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGA +GCCCTTGCCCAGAATTTTGAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCC +TGGAAATGTGAGCCCTGGCTGGGCAATTGCCGAGAAATGTGAGCCATTGCCCAGAAATTT +TAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTTG +CTGGGCAATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAAATTTGTGCCAT +TGCCGAGAAAATTGGGCCACGGCTGGCCATTGCCGAGAAATTGTTAGCCATTGCTGCCCA +TTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGTTGCCCATTGCCGAGG +AAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAGTTGCCGAGAAAATTGGG +CCATGGCTGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCT +GGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGT +CGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGG +CCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCAT +GGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGA +AATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGC +CATGGCTGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCTG +GCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCC +GAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGGC +CGGGCAAATGTGTGCCATTGCTGCCCATGGCCGAGAAATTGTGAGCCATTGCTGCCCATG +GCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGAA +ATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCC +ATGGCTGGGCATTTGTGTGCCAAGGCAGATCATTGCCCAGAAATTTGAGCCATGGCTGGC +CATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTTGGGCCATTGCCGGGCAAATGTGT +GCCATTGCTGCCCATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCT +GCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGC +CGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGTTGGGCATTT +GTGTGCCAATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAAT +GTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCAT +GGCCGGGCAAATTTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCC +ATTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAG +AAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAA +CCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCT +GCCCATTGCCGAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCT +GCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTG +CCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCTGATCATTGCCCAGAAAT +TTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTGGGCCATG +GCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTGGCCAT +TGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCAATGGCTGCCCATTGCCGAGAA +ATCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGC +CATTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTGCCGA +GAAAATTAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATTGCCG +AGAAATCTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGT +GAGCCATTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTG +CCGAGAAAATTAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATT +GCCGAGAAATCTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAA +ATGTGTGCTGTGCCATTGCCCAGAAAATGTGTGCCATTGCCCAGAAATTTAAGCCTTGGC +TGCCCATTGCTGGGCAATTGTGCGCCATCCACACCAAGGCCCAATGGGGTCTTGGTAAAA +ACAAGCATTTTTTGCGAAATGAGGTTGCGCGGGCCCCGCTCGTTGTAAATTGCAATCTCA +AGGTGAACAAATGTGAAGGACGAGGCCCACACACCATGGGCAATCGAGACCCGATCCAAG +GGCAAGAAATTTAAATTAAAGTCGACACCCGCGTTAGGTGCATATGCCAAGACCTACGGC +GGACACCCCGTGGCTCGACGTAAGCCGATGAGAATCCTAAGACAAAACCTTCCATTACCC +GTTTCCGTTCTCAAAACACGTATCCATGCTCAACATCTAAAAAAAAAGTTCCCCCAAGGA +ACCGTTGCTCCTTTTGAACATCCCCATTCAATTCGATATTTTGATAACCAAACTACGTCT +TCATTTTTATGCGGCTCAAACCTATATGTAAACTAATCTAAATGTTTATCACTTCACCCG +GCCCCTCATTCTCAAAAATTTTTGTTTTTTCCCTTAATTTTTTTTATTTTCAATTAATTT +TTCAAAAAATATCGTATTTTTTTTTATGTGTTTCATCTTAAATATGAACTATATATATTA +TAAACCTCATTAAAAACATTCTCCATATTTTTCCATATTTATTACTATTTTTCCCTATTT +TTTACTATTTTTTAACTATTTTTTTGGTAATTAATTAAAATAAATTTTTTCGGATCTCAA +AAAATTATAAATTTTTTTCATGTTGTGCTATTATTTATTATTTTAAGATTGAATTCAATT +TTCATAAAAATAACTTATCCTTTTTAAAAAAAAACCATTATGACTCCTCAAGCATGGGCA +ATGTTTCCTCCTGACATTTTCAGAAAAGCTCATATAGCATATATAAGGGGGGGTGTATGC +CCAGGCCTCCCCTTACCCAGCATGGGTCAAGACTGGGCATGCATGGCCGCGCGCGTTGGT +TGGCAATTGGCAAGCATTGCCGCGCGCATGGGTTTGGCATTTTGGACGCGTGGGTTGGCA +ATGGAAAGGCATTGTCGCACGTGTGTCTCGGCAATAGTTAGCCATGGCTCAAATTTCTCG +CAATGGCACCAATTTTCTCGGCAATGGCACAAGTTTTCTCGGCAATGGCACATCTTTTCT +CGGCAATGACACATATTTTCTAGGCAATGGTTTGCCAAGGCACACAATTGCCCAGAAAGC +GTTGCCGAGCTTTGTTGAGAAGGCATTGCCGCGANNNNNNNNNNNNNNNNNNNNNNNNNN +NNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN +NNNNNNNNNNNNNNGTCGGCTGTCGGTGGACTGCTCGAGCTGCTCCCGCGGCGAGAGCGG +GTCACCGCGTGCCGGCCGGGGGACGGACTGGGAACGGCTCCTCACGGGGCCTTCCCCGGG +CGTCGAACAGTCAGACTCAGAACTGGTACGGACAAGGGGAATCCGACTGTTTAATTAAAA +CAAAGCATTGCGATGGTCCCTGCGGATGCTAACGCAATGTGATTTCTGCCCAGTGCTCTG +AATGTCAAAGTGAAGAAATTCAACCAAGCGCGGGTAAACGGCGGGAGTAACTATGACTCT +CTTAAGGTAGCCAAATGCCTCGTCATCTAATTAGTGACGCGCATGAATGGATTAACGAGA +TTCCCACTGTCCCTGTCTACTATCCAGCGAAACCACAGCCAAGGGAACGGGCTTGGCAGA +ATCAGCGGGGAAAGAAGACCCTGTTGAGCTTGACTCTAGTCCGACTTTGTGAAATGACTT +GAGAGGTGTAGGATAAGTGGGAGCCGGAAACGGCAAAAGTGAAATACCACTACTTTTAAC +GTTATTTTACTTATTCCGTGAATCGGAGGCGGGGCACTGCCCCTCTTTTTGGACCGAAGG +CCAGCCTCGGCGGGCCGATCCGGGCGGAAGACATTGTCAGGTGGGGAGTTTGGCTGGGGC +GGCACATCTGTTAAAAGATAACGCAGGTGTCCTAAGATGAGCTCAACGAGAACAGAAATC +TCGTGTGGAACAGAAGGGTAAAAGCTCGTTTGATTCTGATTTCCAGTACGAATACGAACC +GTGAAAGCGTGGCCTAACGATCCTTTAGACCTTCGGAATTTGAAGCTAGAGGTGTCAGAA +AAGTTACCACAGGGATAACTGGCTTGTGGCAGCCAAGCGTTCATAGCGACGTTGCTTTTT +GATCCTTCGATGTCGGCTCTTCCTATCATTGTGAAGCAGAATTCACCAAGTGTTGGATTG +TTCACCCACCAATAGGGAACGTGAGCTGGGTTTAGACCGTCGTGAGACAGGTTAGTTTTA +CCCTACTGATGATAGTGTCGCAATAGTAATTCAACCTAGTACGAGAGGAACCGTTGATTC +GCACAATTGGTCATCGCGCTTGGTTGAAAAGCCAGTGGCGCGAAGCTACCGTGCGTCGGA +TTATGACTGAACGCCTCTAAGTCAGAATCCGGGCTAGAAGCGACGCATGTGCCCGCCGCC +CGTTTGCCGACCCGCAGTAGGGGCCATTCGGCCCCCAAAGGCACGTGTCGTTGGTGAAGC +CCGTGCGGTGGATGAGCCGTGCGGGCCGCCTTGAAGTATAATTCCTACCGAGCGGCGGGT +AGAATCCTTTGCAGACGACTTAAATACGCGACGGGGTATTGTAAGTGGCAGAGTGGCCTT +GCTGCCACGATCCACTGAGATTCAGCCCTGTGTCGCTTCGATTCGTCCCTCCCCCTTCAA +CATAAAAAAAATCTTTTTCCCTTCCGATCCCAGAGGTTTCACCTTACAAGGAGGACCTTG +GAACTTACGCTACACATAAGAATAGTGTGTAACGCGATTTACAACTATTACTAAGTGGCC +GAACAATATGCACAAGTGTATGCCCAAAATTAAAGCAAAGTATCTAAAAAGTGCACAAGG +CTGCCCAATGTTTTCCATATAACTGCACAAGGTGGCGAAAGTGCAAGCCTGCAGTGCCTA +TGTTTGTGCCTAAAGCTTCCCAACGACTTGACTTGGCTGCCCATTGATGGGTAAACATGT +GCGAAGAACTTTCCAATGCTGCCCCATGGCTGGGCAAATGCGTGCCAATGACTTGCCATG +GCTGCCCATTGGTAGGCAATTATGTGGCAACGACTTGCCAATGCAGCCCCATGGCTGGGC +AATTGTGTGCCATCGACATGCCAATGCAGCCCCATGACAGGGCAATTGTGTGCCATGGAC +ATGCCAATGCTGCCCCATTGCTGGCCCAATTGTGCCATCGACTTGAGAAAATTGGGCCAT +TGCTGGGCATATTGTGTGCCAACTACTTGACATGTCCGCCCATTGGTAGACGATTGTGTG +CCATCGATTGCCAAGGCTGGGCAATTATTTGCAGGTTGCCTAGAAAATGTGTGGCATTGC +CCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATCTGAGCCATGGGTGGGCATTTG +TGTGCAAAGACAGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATG +TTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATG +GCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCTAGAAATTGTGAGCCATTGCTGCCCA +TTGCCGAGAAATTTTGTTCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGA +AATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGGAAATGAGTG +CCATTGCCGAGAAATGTGAGCCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTG +GGCAAATGTGTGCCACGGCTGATCATTGCCCAGACAATGTGAGCCATTGCCGACGAATTT +GAGCCATGGCAGCCCATTGCCCCGAAAAATGAGTGCCATGGCCGAGCATGTGTTCCAAGG +CTGCCCATTGCCGAGAAATATGAGCCATGGCCGGGCAAATGTGTGCCATGTCTGCCCATT +GCCCAGAAATTGTGAGCCATGGCTGCCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCA +ATTGTGAGCCATGGCTGGCCAGTGCCGAGAAATGTGAGCCACGGCTGGACAATTGCCGAG +AAAATTGGGCCATTGCCCATAAATTTGAGTCATGGCTGGCCATTGCCGAGAAATGTTGTT +CCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGACAAATCTGAGCCATGGCCGG +GCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCC +GAGAACATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGC +GTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAAAT +TGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGTGTGCCATG +GCCGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCAT +TGCCGAGAAATTTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAA +ATCTGAGCCATGGCCGGGCAAATGGGAGCCATTGCTCAGAAATTTTAGCCATGGCTGCCC +ATTGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAG +AAATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGT +GCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCT +GGGCATTTGTGTGCCTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATT +TGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATG +GCTGCCCATTGCCTAGAAAATGTGAGCCATTGCCCAGAAATTTTAGCCATGGCTGCCCAT +TGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAGAA +ATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGTGC +CATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGG +GCATTTGTGTGCCTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATTTG +AGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCTGGCAAATGCGTGCCATGGC +TGCCCATTGCCGAGAAATTGTGAGCCCTTGCCCAGAATTTTGAGCCATGGCTGGCCATTG +CCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTGGCTGGGCAATTGCCGAGAAA +TGTGAGCCATTGCCCAGAAATTTTAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCA +TTGCCTGGAAATGTGAGCCCTTGCTGGGCAATTGCCCAGAAATTTGAGCCATGGCTGCCC +ATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCACGGCTGGCCATTGCCGAG +AAATTGTTAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTGG +GCCATGGTTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCT +GGGCAGTTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGGCTGATCATTG +CCTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAA +ATTGGGCCATGGCTGCCCATTGTCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCA +TTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGA +AATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGG +CCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTG +GGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGGCTGATCATTGC +CTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAA +TTGGGCCATGGCTGCCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCAT +TGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATGGCCGAGAA +ATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGC +CATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGG +GCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCAAGGCAGATCATTGCC +CAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTT +GGGCCATTGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGAAAATTTGTGCCATT +GCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATT +GCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAA +AATTGGGCCATGGTTGGGCATTTGTGTGCCAATGCTGATCATTGCCCAGAAATTTGAGCC +ATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCC +CATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATTTGTGCCATTGCTGCCCATTGCCGA +GAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTG +GGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGA +GTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGG +CTGGGCATTTGTGTGCAAATGCTGCCCATTGCCGAGAAATTTGAGCCATGGCTGCCCATT +GCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAA +TGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCA +AATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGC +CATTGCCGAGAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGC +AAATGTGTGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGG +CAATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTG +CCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCC +GAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCATTGCCGAGAAATTG +TGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGCGTGCCATG +GCTGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAAGGCTGCCCAT +TGCCGAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCATTGCCGAGAA +ATTGTGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGCGTGC +CATGGCTGCCCATTGCCTAGAAAATGTGTGCTGTGCCATTGCCCAGAAAATGTGTGCCAT +TGCCCAGAAATTTAAGCCTTGGCTGCCCATTGCTGGGCAATTGTGCGCCATCCACACCAA +GGCCCAATGGGGTCTTGGTAAAAACAAGCATTTTTTGCGAAATGAGGTTGCGCGGGGCCC +CGCTCGTTGTAAATTGCAATCTCAAGGTGAACAAATGTGAAGGACGAGGCCCACACACCA +TGGGCAATCGAGACCCGATCCAAGGGCAAGAAATTTAAATTAAAAGTCGACACCCGCGTT +AGGTGCATATGCCAAGACCTACGGCGGACACCCCGTGGCTCGACGTAAGCCGATGAGAAT +CCTAAGACAAAACCTTCCATTACCCGTTTCCGTTCTCAAAACACGTATCCATGCTCAACA +TCTAAAAAAAAAGTTCCCCCAAGGAACCGTTGCTCCTTTTGAACATCCCCATTCAATTCG +ATATTTTGATAACCAAACTACGTCTTCATTTTTATGCGGCTCAAACCTATATGTAAACTA +ATCTAAATGTTTATCACTTCACCCGGCCCCTCATTCTCAAAAATTTTTGTTTTTTCCCTT +AATTTTTTTTATTTTCAATTAATTTTTCAAAAAATATCGTATTTTTTTTTATGTGTTTCA +TCTTAAATATGAACTATATATATTATAAACCTCATTAAAAACATTCTCCATATTTTTCCA +TATTTATTACTATTTTTCCCTATTTTTTACTATTTTTTAACTATTTTTTTGGTAATTAAT +TAAAATAAATTTTTTCGGATCTCAAAAAATTATAAATTTTTTTCATGTTGTGCTATTATT +TATTATTTTAAGATTTGAATTCAATTTTCATAAAAATAACTTATCCTTTTTAAAAAAAAA +CCATTATGACTCCTCAAGCATGGGCAATGTTTCCTCCTGACATTTTCAGAAAAGCTCATA +TAGCATATATAAGGGGGGGTGTATGCCCAGGCCTCCCCTTACCCAGCATGGGTCAAGACT +GGGCATGCATGGCCGCGCGCGTTGGTTGGCAATTGGCAAGCATTGCCGCGCGCATGGGTT +TGGCATTTTGGACGCGTGGGTTGGCAATGGAAAGGCATTGTCGCACGTGTGTCTCGGCAA +TAGTTAGCCATGGCTCAAATTTCTCGGCAATGGCACCAATTTTCTCGGCAATGGCACAAG +TTTTCTCGGCAATGGCACATCTTTTCTCGGCAATGACACATATTTTCTAGGCAATGGTTT +GCCAAGGCACACAATTGCCCAGAAAGCGTTGCCGAGCTTTGTTGAGAAGGCATTGCCGCG +TGGGTTGGTTCGCTGTAGGCTTGCATTGATGCTGCGCATGTTGGTGGGAAATAGGCAAAG +CGTTGCCGAGCGTGTTTGCTGGCAGCACGCAGGCATTGCTGCGCATGTTGGCTGGAAATA +AAGCTTGCATTGCCGAGCTCGTTGGTAGGCAAGGGGCAGGCATGGCCGTGTGCATGGCTA +TGTTTGCCAGCTGCGTGTGTTGGCAATGGGCAGGCATTGCTGCACGCTTGGGTGACCGGG +AGGGGTTGCCTTTTGGCTTGTTGTTGGGCATTCTTCGCAAGAGAAAGCTTGGACAATGGC +CATGGGCAGCCAAGTCCAACATTGGTCTATCGATTGATGCATGGGGTGGTGGGAGGGGAT +GTTGTGGAGCTTCCTTTGGGCTAGTTGGGCATTCTTTGCAAGGCTTTCTTGCGCATGCAA +GGGCCTAGACAATGCTTCAAGAAGCCATGGGCAGCCCCACCGCTCATCCCACTGCCCTCA +TGCTTAGGTTGACAATGGACAATTGGGATGCGTTGCCATGGTCTAGCAAGGGTGCTTGCT +TGCATGTTCAAGTGTGCAAATGGGTTTGTCAAATGTGGCCGATGTCCTCGCCATGCTAGA +AAATTGTGTGGAATGACTTTGGGCATGCTATTGCTAGCTCATCGTTTGCCTATGCAACTA +GTAGGGTGTGGCGATGTCATGGGCTCGAGGGACATTCCTTAATGCTGGCTGGGTCATGTT +TGTATGCTACTGTTGCTTGACAATGGCGTTGCATCGCTCATGGATGTTGCACAACACATT +GTGCTCTGTTGGAAAAATGTGAAATCATGTCCCTTGAATTTTCGTGCCTATCGGTGCTTT +GTTCTGTCTCTTCTCGATGTAATTGCATTATTGTCGGTCAATATTTTGATCGATGGGGTG +TGATTCAATTGGGGGAGTCGGGGCATAGTGTACGTAGTGGTGCGTGGGTGGTGTTTGGCC +TGTGCGAGTTTGATGTTTCCTTGCTTTGTGCAACGAATTCATCTCGTGCATTCCTCTTCA +GTTATATCTTCAAGAGTAATAATAATTACTACCTTGAGTGTCCCATGGGTTCCTGTGTTG +TATACCTCTGATGCAATGGAATTTTCTCTGTAAAGACCCTATTTCGCTTTTGCACCACTC +TGTGGTGCAAGTGAACCTCAAAGTATCACTCATGTCCCATGTGTGCCTCGCATTGAAGTT +GCATGCATGGCTCATGGGTGCTTTACTCGTGCTCTCGGATGCGGAAATCTTTTGAGGGAA +ATTGGTCTTCTGACCTTTTTACCTGTAAAGCGTTCGACCCTTAATTTGGAAGACTGTTGT +GCTCGTCTTTGACCTATCCGATTGCTCGGCTAGGCTCATGCGGTGCCAACGTCGCAAAGG +AATGCTACCTGGTTGATCCTGCCAGTAGTCATATGCTTGTCTCAAAGATTAAGCCATGCA +TGTGTAAGTATGAACTAATTCAGACTGTGAAACTGCGAATGGCTCATTAAATCAGTTATA +GTTTGTTTGATGGTATTTGCTACTCGGATAACCGTAGTAATTCTAGAGCTAATACGTGCA +ACAAACCCCGACTTCTGGAAGGGATGCATTTATTAGATAAAAGGTCGACGCGGGCTTTGC +CCGTTGCTCTGATGATTCATGATAACTCGACGGATCGCACGGCCTTCGTGCCGGCGACGC +ATCATTCAAATTTCTGCCCTATCAACTTTCGATGGTAGGATAGTGGCCTACTATGGTGTT +AACGGGTGACGGAGAATTAGGGTTCGATTCCGGAGAGGGAGCCTGAGAAACGGCTACCAC +ATCCAAGGAAGGCAGCAGGCGCGCAAATTACCCAATCCTGACACGGGGAGGTAGTGACAA +TAAATAACAATACCGGGCTCATTGAGTCTGGTAATTGGAATGAGTACAATCTAAATCCCT +TAACGAGGATCCATTGGAGGGCAAGTCTGGTGCCAGCAGCCGCGGTAATTCCAGCTCCAA +TAGCGTATATTTAAGTTGTTGCAGTTAAAAAGCTCGTAGTTGGATTTTGGGTTGGGCCGA +CCGGTCCGCCTTCAGGTGTGCACCGGTCGTCTCGTCCCTTCTGCCGGCGATGCGCTCCTA +GCCTTAACTGGCCGGGTCGTGCCTCCGGCGCTGTTACTTTGAAGAAATTAGAGTGCTCAA +AGCAAGCCTACGCTCTGGATACATTAGCATGGGATAACATCATAGGATTTCGATCCTATT +CTGTTGGCCTTCGGGATCGGAGTAATGATTAACAGGGACAGTCGGGGGCATTCGTATTTC +ATAGTCAGAGGTGAAATTCTTGGATTTATGAAAGACGAACAACTGCGAAAGCATTTGCCA +AGGATGTTTTCATTAATCAAGAACGAAAGTTGGGGGCTCGAAGACGATCAGATACCGTCC +TAGTCTCAACCATAAACGATGCCGACCAGGGATCAGCGGATGTTACTTTTAGGACTCCGC +TGGCACCTTATGAGAAATCAAAGTTTTTGGGTTCCGGGGGGAGTATGGTCGCAAGGCTGA +AACTTAAAGGAATTGACGGAAGGGCACCACCAGGAGTGGAGCCTGCGGCTTAATTTGACT +CAACACGGGGAAACTTACCAGGTCCAGACATAGTAAGGATTGACAGACTGAGAGCTCTTT +CTTGATTCTATGGGTGGTGGTGCATGGCCGTTCTTAGTTGGTGGAGCGATTTGTCTGGTT +AATTCCGTTAACGAACGAGACCTCAGCCTGCTAACTAGCTATGTGGAGGTGACCCTCCAC +AGCTAGCTTCTTAGAGGGACTATGGCCCTTCAGGCCACGGAAGTTTGAGGCAATAACAGG +TCTGTGATGCCCTTAGATGTTCTGGGCCGCACGCGCGCTACACTGATGTATTCAACGAGT +TTATAGCCTTGGCCGACAGGCCCGGGTAATCTTTGAAATTTCATCGTGATGGGGATAGAT +CATTGCAATTGTTGGTCTTCAACGAGGAATTCCTAGTAAGCGCGAGTCATCAGCTCGCGT +TGACTACGTCCCTGCCCTTTGTACACACCGCCCGTCGCTCCTACCGATTGAATGGTCCGG +TGAAGTGTTCGGATCGCGGCGACGTGGGCGGTTCGCTGCCGGCGACGTCGCGAGAAGTCC +ACTGAACCTTATCATTTAGAGGAAGGAGAAGTCGTAACAAGGTTTCCGTAGGTGAACCTG +CGGAAGGATCATTGTCGAAACCTGCCTAGCAGAATGACCCGCGAACTTGTATAATACCAT +CGGGGAAGCAAAAGTTTGGTTTTTATAGCCTACTTTTTCTTCCCTTTGCCGGGTGTGCTC +GTGTTGCCCCATGGGTGACACTCTCATTCCCCGGTCAAACAACGAACCCCGGCGCGAAAC +GCGTCAAGGAACTTGAACAAGAATGCAACATCCATGCCCCGTTTTTGGGTGCTTGTGGTG +CTTGCTCTCTCATGAACGAAACGACTCTCGGCAACGGATATCTCGGCTCTCGCATCGATG +AAGAACGTAGCGAAATGCGATACTTGGTGTGAATTGCAGAATCCCGTGAACCATCGAGTT +TTTGAACGCAAGTTGCGCCTGAAGCCATTAGGCCGAGGGCACGTCTGCCTGGGCGTCACG +CATTGTGTCGCCCACCCAACTCAAGCCTTACCAAGGATTGGGTGTGGGTGGGCGGATATT +GGCCCCCCGTGCACATTAGTGAACGGTCGGCCTAAAAATGAAGTCCTTGGCAATGGACGT +CACAACAAGTGGTGGTTGACAAACCGTTGCGTCCTGTTGTGCTTGCCCCCATTGCTAATG +GTTTACTTTTGACCCTAATGTGCCGTTATCACGGCTTCGATCGCGACCCCAGGTCAGGCG +GGATTACCCGCTGAGTTTAAGCATATCAATAAGCGGAGGAAAAGAAACTTACAAGGATTC +CCTTAGTAACGGCGAGCGAACCGGGAATAGCCCAGCTTGAAAATCGGGCGATCTCGTTGT +CCGAATTGTAGTCTGGAGAAGCGTCCTCAGCGGCGGACCGGGCCCAAGTCCCCTGGAAGG +GGGCGCCAGAGAGGGTGAGAGCCCCGTCGTGCCCGGACCCTGTCGCACCACGAGGCGCTG +TCGACGAGTCGGGTTGTTTGGGAATGCAGCCCCAATCGGGCGGTAAATTCCGTCCAAGGC +TAAATATGGGCGAGAGACCGATAGCAAACAAGTACCGCGAGGGAAAGATGAAAAGGACTT +TGAAAAGAGAGTCAAAGAGTGCTTGAAATTGTCGGGAGGGAAGCGGATGGGGGCCGGCGA +TGCGCCTCGGTCGGATGTGGAACGGTTAATAGCCGGTCTGCCGATCGACTCGGGGCGTGG +ATCGGTGCGGATTGGGGCGGAGGCCAAAGCCCGGGCAGTTGTTACGCCTGTGGAGACGCC +TTTGCCTCGATCGTGGCTGGCAGCGCGCCTTTGGCGTGCTTCGGCATCTGCGCGCTCCTG +GCACCGGCCTGCGGGCTCCCCATTCGGCCCGTCTTGAAACACGGACCAAGGAGTCTGACA +TGTGTGCGAGTCAACGGGCGAGTAAACCCGTAAGGCGTAAGGAAGCTGATTGGCGGGATC +CCCTAGCGGGTTGCACCGCCGACCGACCTTGATCTTCTGAGAAGGGTTCGAGTGTGAGCA +TGCCTGTCGGGACCCGAAAGATGGTGAACTATGCCTGAGCGGGGCGAAGCCAGAGGAAAC +TCTGGTGGAGGCCCGCAGCGATACTGACGTGCAAATCGTTCGTCTGACTTGGGTATAGGG +GCGAAAGACTAATCGAACCGTCTAGTAGCTGGTTCCCTCCGAAGTTTCCCTCAGGATAGC +TGGAGCCCGTGTGCGAGTTCTATCGGGTAAAGCCAATGATTAGAGGCATCGGGGGCGCAA +CGCCCTCGACCTATTCTCAAACTTTAAATAGGTAGGACGGCGCGGCTGCTTTGTTGAGCC +GCGCCACGGAATCGAGAGCTCCAAGTGGGCCATTTTTGGTAAGCAGAACTGGCGATGCGG +GATGAACCGGAAGCCGGGTTACGGTGCCTAACTGCGCGCTAACCTAGAACCCACAAAGGG +TGTTGGTCGATTAAGACAGCAGGACGGTGGTCATGGAAGTCGAAATCCGCTAAGGAGTGT +GTAACAACTCACCTGCCGAATCAACTAGCCCCGAAAATGGATGGCGCTGAAGCGCGCGAC +CTATACCCGGCCGTCGAGGCAAGTGCTAGGCCCCGATGAGTAGGAGGGCGCAGCGGTCGC +TGCAAAACCTTGGGCGTGAGCCCGGGCGGAGCGGCCGTTGGTGCGGATCTTGGTGGTAGT +AGCAAATATTCAAATGAGAACTTTGAAGGCCGAAGAGGGGAAAGGTTCCATGTGAACGGC +ACTTGCACATGGGTTAGTCGATCCTAAGAGTCGGGGGAAGCCCGACAGAGAGCGCGTTCA +GCGCGAACTTCGAAAGGGAATCGGGTTAAAATTCCTGAACCGGGACGTGGCGGCTGACGG +CAACGTTAGGGAGTCCGGAGACGTCGGCGGGGGCCTCGGGAAGAGTTATCTTTTCTGTTT +AACAGCCTGCCCACCCTGGAAACGGCTCAGCCGGAGGTAGGGTCCAGCGGCTGGAAGAGC +ACCGCACGTCGCGTGGTGTCCGGTGCGCCCCCGGCGGCCCTTGAAAATCCGGAGGACCGA +GTGCCTTCCACGCCCGGTCGTACTCATAACCGCATCAGGTCTCCAAGGTGAACAGCCTCT +GGTCGATGGAACAATGTAGGCAAGGGAAGTCGGCAAAATGGATCCGTAACTTCGGGAAAA +GGATTGGCTCTGAGGGCTGGGCACGGGGGTCCCAGTCCCGAACCCGTCGGCTGTCGGTGG +ACTGCTCGAGCTGCTCCCGCGGCGAGAGCGGGTCACCGCGTGCCGGCCGGGGGACGGACT +GGGAACGGCTCCTCACGGGGCCTTCCCCGGGCGTCGAACAGTCAGACTCAGAACTGGTAC +GGACAAGGGGAATCCGACTGTTTAATTAAAACAAAGCATTGCGATGGTCCCTGCGGATGC +TAACGCAATGTGATTTCTGCCCAGTGCTCTGAATGTCAAAGTGAAGAAATTCAACCAAGC +GCGGGTAAACGGCGGGAGTAACTATGACTCTCTTAAGGTAGCCAAATGCCTCGTCATCTA +ATTAGTGACGCGCATGAATGGATTAACGAGATTCCCACTGTCCCTGTCTACTATCCAGCG +AAACCACAGCCAAGGGAACGGGCTTGGCAGAATCAGCGGGGAAAGAAGACCCTGTTGAGC +TTGACTCTAGTCCGACTTTGTGAAATGACTTGAGAGGTGTAGGATAAGTGGGAGCCGGAA +ACGGCAAAAGTGAAATACCACTACTTTTAACGTTATTTTACTTATTCCGTGAATCGGAGG +CGGGGCACTGCCCCTCTTTTTGGACCGAAGGCCAGCCTCGGCGGGCCGATCCGGGCGGAA +GACATTGTCAGGTGGGGAGTTTGGCTGGGGCGGCACATCTGTTAAAAGATAACGCAGGTG +TCCTAAGATGAGCTCAACGAGAACAGAAATCTCGTGTGGAACAGAAGGGTAAAAGCTCGT +TTGATTCTGATTTCCAGTACGAATACGAACCGTGAAAGCGTGGCCTAACGATCCTTTAGA +CCTTCGGAATTTGAAGCTAGAGGTGTCAGAAAAGTTACCACAGGGATAACTGGCTTGTGG +CAGCCAAGCGTTCATAGCGACGTTGCTTTTTGATCCTTCGATGTCGGCTCTTCCTATCAT +TGTGAAGCAGAATTCACCAAGTGTTGGATTGTTCACCCACCAATAGGGAACGTGAGCTGG +GTTTAGACCGTCGTGAGACAGGTTAGTTTTACCCTACTGATGATAGTGTCGCAATAGTAA +TTCAACCTAGTACGAGAGGAACCGTTGATTCGCACAATTGGTCATCGCGCTTGGTTGAAA +AGCCAGTGGCGCGAAGCTACCGTGCGTCGGATTATGACTGAACGCCTCTAAGTCAGAATC +CGGGCTAGAAGCGACGCATGTGCCCGCCGCCCGTTTGCCGACCCGCAGTAGGGGCCATTC +GGCCCCCAAAGGCACGTGTCGTTGGTGAAGCCCGTGCGGTGGATGAGCCGTGCGGGCCGC +CTTGAAGTATAATTCCTACCGAGCGGCGGGTAGAATCCTTTGCAGACGACTTAAATACGC +GACGGGGTATTGTAAGTGGCAGAGTGGCCTTGCTGCCACGATCCACTGAGATTCAGCCCT +GTGTCGCTTCGATTCGTCCCTCCCCCTTCAACATAAAAAAAATCTTTTTCCCTTCCGATC +CCAGAGGTTTCACCTTACAAGGAGGACCTTGGAACTTACGCTACACATAAGAATAGTGTG +TAACGCGATTTACAACTATTACTAAGTGGCCGAACAATATGCACAAGTGTATGCCCAAAA +TTAAAGCAAAGTATCTAAAAAGTGCACAAGGCTGCCCAATGTTTTCCATATAACTGCACA +AGGTGGCGAAAGTGCAAGCCTGCAGTGCCTATGTTTGTGCCTAAAGCTTCCCAACGACTT +GACTTGGCTGCCCATTGATGGGTAAACATGTGCGAAGAACTTTCCAATGCTGCCCCATGG +CTGGGCAAATGCGTGCCAATGACTTGCCATGGCTGCCCATTGGTAGGCAATTATGTGGCA +ACGACTTGCCAATGCAGCCCCATGGCTGGGCAATTGTGTGCCATCGACATGCCAATGCAG +CCCCATGACAGGGCAATTGTGTGCCATGGACATGCCAATGCTGCCCCATTGCTGGCCCAA +TTGTGCCATCGACTTGAGAAAATTGGGCCATTGCTGGGCATATTGTGTGCCAACTACTTG +ACATGTCCGCCCATTGGTAGACGATTGTGTGCCATCGATTGCCAAGGCTGGGCAATTATT +TGCAGGTTGCCTAGAAAATGTGTGGCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTG +CCGAGAAATCTGAGCCATGGGTGGGCATTTGTGTGCAAAGACAGATCATTGCCCAGAAAT +TTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCAT +GGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCA +TTGCCTAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTTCCATTGCCGAG +AAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTG +CCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAGCCATGGCTG +GGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCAAATGTGTGCCACGGCTGATCATTGC +CCAGACAATGTGAGCCATTGCCGACGAATTTGAGCCATGGCAGCCCATTGCCCCGAAAAA +TGAGTGCCATGGCCGAGCATGTGTTCCAAGGCTGCCCATTGCCGAGAAATATGAGCCATG +GCCGGGCAAATGTGTGCCATGTCTGCCCATTGCCCAGAAATTGTGAGCCATGGCTGCCCC +ATTGCCGAGAAATCTGAGCCATGGCCGGGCAATTGTGAGCCATGGCTGGCCAGTGCCGAG +AAATGTGAGCCACGGCTGGACAATTGCCGAGAAAATTGGGCCATTGCCCATAAATTTGAG +TCATGGCTGGCCATTGCCGAGAAATGTTGTTCCATTGCCGAGAAAATTGGGCCATGGCTG +CCCATTGCCGACAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCC +GAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAACATTGGGCCATGGCTGCCCATTGC +CGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATT +GTGAGCCATTGCTGCCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAAT +CTGAGCCATGGCTGGGCAAATGTGTGCCATGGCCGCCCATTGCCGAGAAATTGTGAGCCA +TTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCTAGA +AAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGGGAGC +CATTGCTCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCATTGCCTA +GAAAATTGGGCCATGGCTTCCCATTGCCGAGAAATTTAAGGCATGGCCGGGCAAATGCGT +GGCATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCT +GGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTGATCATTG +CCTAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAAT +CTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAAATGTGAGCCA +TTGCCCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCATTGCCTAGA +AAATTGGGCCATGGCTTCCCATTGCCGAGAAATTTAAGGCATGGCCGGGCAAATGCGTGG +CATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGG +GCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTGATCATTGCC +TAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATCT +GAGCCATGGCCTGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCCTT +GCCCAGAATTTTGAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCCTGGAAA +TGTGAGCCCTGGCTGGGCAATTGCCGAGAAATGTGAGCCATTGCCCAGAAATTTTAGCCA +TGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTTGCTGGGC +AATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAAATTTGTGCCATTGCCGA +GAAAATTGGGCCACGGCTGGCCATTGCCGAGAAATTGTTAGCCATTGCTGCCCATTGCCG +AGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGTTGCCCATTGCCGAGGAAATGA +GTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAGTTGCCGAGAAAATTGGGCCATGG +CTGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCTGGCCAT +TGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGTCGAGAA +ATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGGCCGGGC +AAATGTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATGGCCGA +GAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGAAATGAG +TGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGC +TGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCTGGCCATT +GCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAA +TTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGGCCGGGCA +AATGTGTGCCATTGCTGCCCATGGCCGAGAAATTGTGAGCCATTGCTGCCCATGGCCGAG +AAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGAAATGAGT +GCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCT +GGGCATTTGTGTGCCAAGGCAGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGC +CGAGAAATGTTGTGCCATTGCCGAGAAATTTGGGCCATTGCCGGGCAAATGTGTGCCATT +GCTGCCCATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCAT +TGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAA +ATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGTTGGGCATTTGTGTGC +CAATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTG +CCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGG +GCAAATTTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCC +GAGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCT +GAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGG +CTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCTGCCCAT +TGCCGAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCAT +TGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGA +AAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCTGATCATTGCCCAGAAATTTGAGC +CATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTGGGCCATGGCTGCC +CATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTGGCCATTGCCGA +GAAATGTTGTGCCATTGCCGAGAAAATTGGGCAATGGCTGCCCATTGCCGAGAAATCTGA +GCCATGGCCGGGCAAATGTGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGC +CCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTGCCGAGAAAAT +TAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATTGCCGAGAAAT +CTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCA +TTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTGCCGAGA +AAATTAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATTGCCGAG +AAATCTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAAATGTGT +GCTGTGCCATTGCCCAGAAAATGTGTGCCATTGCCCAGAAATTTAAGCCTTGGCTGCCCA +TTGCTGGGCAATTGTGCGCCATCCACACCAAGGCCCAATGGGGTCTTGGTAAAAACAAGC +ATTTTTTGCGAAATGAGGTTGCGCGGGGCCCCGCTCGTTGTAAATTGCAATCTCAAGGTG +AACAAATGTGAAGGACGAGGCCCACACACCATGGGCAATCGAGACCCGATCCAAGGGCAA +GAAATTTAAATTAAAAGTCGACACCCGCGTTAGGTGCATATGCCAAGACCTACGGCGGAC +ACCCCGTGGCTCGACGTAAGCCGATGAGAATCCTAAGACAAAACCTTCCATTACCCGTTT +CCGTTCTCAAAACACGTATCCATGCTCAACATCTAAAAAAAAAGTTCCCCCAAGGAACCG +TTGCTCCTTTTGAACATCCCCATTCAATTCGATATTTTGATAACCAAACTACGTCTTCAT +TTTTATGCGGCTCAAACCTATATGTAAACTAATCTAAATGTTTATCACTTCACCCGGCCC +CTCATTCTCAAAAATTTTTGTTTTTTCCCTTAATTTTTTTTATTTTCAATTAATTTTTCA +AAAAATATCGTATTTTTTTTTATGTGTTTCATCTTAAATATGAACTATATATATTATAAA +CCTCATTAAAAACATTCTCCATATTTTTCCATATTTATTACTATTTTTCCCTATTTTTTA +CTATTTTTTAACTATTTTTTTGGTAATTAATTAAAATAAATTTTTTCGGATCTCAAAAAA +TTATAAATTTTTTTCATGTTGTGCTATTATTTATTATTTTAAGATTTGAATTCAATTTTC +ATAAAAATAACTTATCCTTTTTAAAAAAAAACCATTATGACTCCTCAAGCATGGGCAATG +TTTCCTCCTGACATTTTCAGAAAAGCTCATATAGCATATATAAGGGGGGGTGTATGCCCA +GGCCTCCCCTTACCCAGCATGGGTCAAGACTGGGCATGCATGGCCGCGCGCGTTGGTTGG +CAATTGGCAAGCATTGCCGCGCGCATGGGTTTGGCATTTTGGACGCGTGGGTTGGCAATG +GAAAGGCATTGTCGCACGTGTGTCTCGGCAATAGTTAGCCATGGCTCAAATTTCTCGGCA +ATGGCACCAATTTTCTCGGCAATGGCACAAGTTTTCTCGGCAATGGCACATCTTTTCTCG +GCAATGACACATATTTTCTAGGCAATGGTTTGCCAAGGCACACAATTGCCCAGAAAGCGT +TGCCGAGCTTTGTTGAGAAGGCATTGCCGCGTGGGTTGGTTCGCTGTAGGCTTGCATTGA +TGCTGCGCATGTTGGTGGGAAATAGGCAAAGCGTTGCCGAGCGTGTTTGCTGGCAGCACG +CAGGCATTGCTGCGCATGTTGGCTGGAAATAAAGCTTGCATTGCCGAGCTCGTTGGTAGG +CAAGGGGCAGGCATGGCCGTGTGCATGGCTATGTTTGCCAGCTGCGTGTGTTGGCAATGG +GCAGGCATTGCTGCACGCTTGGGTGACCGGGAGGGGTTGCCTTTTGGCTTGTTGTTGGGC +ATTCTTCGCAAGAGAAAGCTTGGACAATGGCCATGGGCAGCCAAGTCCAACATTGGTCTA +TCGATTGATGCATGGGGTGGTGGGAGGGGATGTTGTGGAGCTTCCTTTGGGCTAGTTGGG +CATTCTTTGCAAGGCTTTCTTGCGCATGCAAGGGCCTAGACAATGCTTCAAGAAGCCATG +GGCAGCCCCACCGCTCATCCCACTGCCCTCATGCTTAGGTTGACAATGGACAATTGGGAT +GCGTTGCCATGGTCTAGCAAGGGTGCTTGCTTGCATGTTCAAGTGTGCAAATGGGTTTGT +CAAATGTGGCCGATGTCCTCGCCATGCTAGAAAATTGTGTGGAATGACTTTGGGCATGCT +ATTGCTAGCTCATCGTTTGCCTATGCAACTAGTAGGGTGTGGTGATGTCATGGGCTCGAG +GGACATTCCTTAATGCTGGCTGGGTCATGTTTGTATGCTACTGTTGCTTGACAATGGCGT +TGCATCGCTCATGGATGTTGCACAACACATTGTGCTCTGTTGGAAAAATGTGAAATCATG +TCCCTTGAATTTTCGTGCCTATCGGTGCTTTGTTCTGTCTCTTCTCGATGTAATTGCATT +ATTGTCGGTCAATATTTTGATCGATGGGGTGTGATTCAATTGGGGGAGTCGGGGCATAGT +GTACGTAGTGGTGCGTGGGTGGTGTTTGGCCTGTGCGAGTTTGATGTTTCCTTGCTTTGT +GCAACGAATTCATCTCGTGCATTCCTCTTCAGTTATATCTTCAAGAGTAATAATAATTAC +TACCTTGAGTGTCCCATGGGTTCCTGTGTTGTATACCTCTGATGCAATGGAATTTTCTCT +GTAAAGACCCTATTTCGCTTTTGCACCACTCTGTGGTGCAAGTGAACCTCAAAGTATCAC +TCATGTCCCATGTGTGCCTCGCATTGAAGTTGCATGCATGGCTCATGGGTGCTTTACTCG +TGCTCTCGGATGCGGAAATCTTTTGAGGGAAATTGGTCTTCTGACCTTTTTACCTGTAAA +GCGTTCGACCCTTAATTTGGAAGACTGTTGTGCTCGTCTTTGACCTATCCGATTGCTCGG +CTAGGCTCATGCGGTGCCAACGTCGCAAAGGAATGCTACCTGGTTGATCCTGCCAGTAGT +CATATGCTTGTCTCAAAGATTAAGCCATGCATGTGTAAGTATGAACTAATTCAGACTGTG +AAACTGCGAATGGCTCATTAAATCAGTTATAGTTTGTTTGATGGTATTTGCTACTCGGAT +AACCGTAGTAATTCTAGAGCTAATACGTGCAACAAACCCCGACTTCTGGAAGGGATGCAT +TTATTAGATAAAAGGTCGACGCGGGCTTTGCCCGTTGCTCTGATGATTCATGATAACTCG +ACGGATCGCACGGCCTTCGTGCCGGCGACGCATCATTCAAATTTCTGCCCTATCAACTTT +CGATGGTAGGATAGTGGCCTACTATGGTGTTAACGGGTGACGGAGAATTAGGGTTCGATT +CCGGAGAGGGAGCCTGAGAAACGGCTACCACATCCAAGGAAGGCAGCAGGCGCGCAAATT +ACCCAATCCTGACACGGGGAGGTAGTGACAATAAATAACAATACCGGGCTCATTGAGTCT +GGTAATTGGAATGAGTACAATCTAAATCCCTTAACGAGGATCCATTGGAGGGCAAGTCTG +GTGCCAGCAGCCGCGGTAATTCCAGCTCCAATAGCGTATATTTAAGTTGTTGCAGTTAAA +AAGCTCGTAGTTGGATTTTGGGTTGGGCCGACCGGTCCGCCTTCAGGTGTGCACCGGTCG +TCTCGTCCCTTCTGCCGGCGATGCGCTCCTAGCCTTAACTGGCCGGGTCGTGCCTCCGGC +GCTGTTACTTTGAAGAAATTAGAGTGCTCAAAGCAAGCCTACGCTCTGGATACATTAGCA +TGGGATAACATCATAGGATTTCGATCCTATTCTGTTGGCCTTCGGGATCGGAGTAATGAT +TAACAGGGACAGTCGGGGGCATTCGTATTTCATAGTCAGAGGTGAAATTCTTGGATTTAT +GAAAGACGAACAACTGCGAAAGCATTTGCCAAGGATGTTTTCATTAATCAAGAACGAAAG +TTGGGGGCTCGAAGACGATCAGATACCGTCCTAGTCTCAACCATAAACGATGCCGACCAG +GGATCAGCGGATGTTACTTTTAGGACTCCGCTGGCACCTTATGAGAAATCAAAGTTTTTG +GGTTCCGGGGGGAGTATGGTCGCAAGGCTGAAACTTAAAGGAATTGACGGAAGGGCACCA +CCAGGAGTGGAGCCTGCGGCTTAATTTGACTCAACACGGGGAAACTTACCAGGTCCAGAC +ATAGTAAGGATTGACAGACTGAGAGCTCTTTCTTGATTCTATGGGTGGTGGTGCATGGCC +GTTCTTAGTTGGTGGAGCGATTTGTCTGGTTAATTCCGTTAACGAACGAGACCTCAGCCT +GCTAACTAGCTATGTGGAGGTGACCCTCCACAGCTAGCTTCTTAGAGGGACTATGGCCCT +TCAGGCCACGGAAGTTTGAGGCAATAACAGGTCTGTGATGCCCTTAGATGTTCTGGGCCG +CACGCGCGCTACACTGATGTATTCAACGAGTTTATAGCCTTGGCCGACAGGCCCGGGTAA +TCTTTGAAATTTCATCGTGATGGGGATAGATCATTGCAATTGTTGGTCTTCAACGAGGAA +TTCCTAGTAAGCGCGAGTCATCAGCTCGCGTTGACTACGTCCCTGCCCTTTGTACACACC +GCCCGTCGCTCCTACCGATTGAATGGTCCGGTGAAGTGTTCGGATCGCGGCGACGTGGGC +GGTTCGCTGCCGGCGACGTCGCGAGAAGTCCACTGAACCTTATCATTTAGAGGAAGGAGA +AGTCGTAACAAGGTTTCCGTAGGTGAACCTGCGGAAGGATCATTGTCGAAACCTGCCTAG +CAGAATGACCCGCGAACTTGTATAATACCATCGGGGAAGCAAAAGTTTGGTTTTTATAGC +CTACTTTTTCTTCCCTTTGCCGGGTGTGCTCGTGTTGCCCCATGGGTGACACTCTCATTC +CCCGGTCAAACAACGAACCCCGGCGCGAAACGCGTCAAGGAACTTGAACAAGAATGCAAC +ATCCATGCCCCGTTTTTGGGTGCTTGTGGTGCTTGCTCTCTCATGAACGAAACGACTCTC +GGCAACGGATATCTCGGCTCTCGCATCGATGAAGAACGTAGCGAAATGCGATACTTGGTG +TGAATTGCAGAATCCCGTGAACCATCGAGTTTTTGAACGCAAGTTGCGCCTGAAGCCATT +AGGCCGAGGGCACGTCTGCCTGGGCGTCACGCATTGTGTCGCCCACCCAACTCAAGCCTT +ACCAAGGATTGGGTGTGGGTGGGCGGATATTGGCCCCCCGTGCACATTAGTGAACGGTCG +GCCTAAAAATGAAGTCCTTGGCAATGGACGTCACAACAAGTGGTGGTTGACAAACCGTTG +CGTCCTGTTGTGCTTGCCCCCATTGCTAATGGTTTACTTTTGACCCTAATGTGCCGTTAT +CACGGCTTCGATCGCGACCCCAGGTCAGGCGGGATTACCCGCTGAGTTTAAGCATATCAA +TAAGCGGAGGAAAAGAAACTTACAAGGATTCCCTTAGTAACGGCGAGCGAACCGGGAATA +GCCCAGCTTGAAAATCGGGCGATCTCGTTGTCCGAATTGTAGTCTGGAGAAGCGTCCTCA +GCGGCGGACCGGGCCCAAGTCCCCTGGAAGGGGGCGCCAGAGAGGGTGAGAGCCCCGTCG +TGCCCGGACCCTGTCGCACCACGAGGCGCTGTCGACGAGTCGGGTTGTTTGGGAATGCAG +CCCCAATCGGGCGGTAAATTCCGTCCAAGGCTAAATATGGGCGAGAGACCGATAGCAAAC +AAGTACCGCGAGGGAAAGATGAAAAGGACTTTGAAAAGAGAGTCAAAGAGTGCTTGAAAT +TGTCGGGAGGGAAGCGGATGGGGGCCGGCGATGCGCCTCGGTCGGATGTGGAACGGTTAA +TAGCCGGTCTGCCGATCGACTCGGGGCGTGGATCGGTGCGGATTGGGGCGGAGGCCAAAG +CCCGGGCAGTTGTTACGCCTGTGGAGACGCCTTTGCCTCGATCGTGGCTGGCAGCGCGCG +CCTTTGGCGTGCTTCGGCATCTGCGCGCTCCTGGCACCGGCCTGCGGGCTCCCCATTCGG +CCCGTCTTGAAACACGGACCAAGGAGTCTGACATGTGTGCGAGTCAACGGGCGAGTAAAC +CCGTAAGGCGTAAGGAAGCTGATTGGCGGGATCCCCTAGCGGGTTGCACCGCCGACCGAC +CTTGATCTTCTGAGAAGGGTTCGAGTGTGAGCATGCCTGTCGGGACCCGAAAGATGGTGA +ACTATGCCTGAGCGGGGCGAAGCCAGAGGAAACTCTGGTGGAGGCCCGCAGCGATACTGA +CGTGCAAATCGTTCGTCTGACTTGGGTATAGGGGCGAAAGACTAATCGAACCGTCTAGTA +GCTGGTTCCCTCCGAAGTTTCCCTCAGGATAGCTGGAGCCCGTGTGCGAGTTCTATCGGG +TAAAGCCAATGATTAGAGGCATCGGGGGCGCAACGCCCTCGACCTATTCTCAAACTTTAA +ATAGGTAGGACGGCGCGGCTGCTTTGTTGAGCCGCGCCACGGAATCGAGAGCTCCAAGTG +GGCCATTTTTGGTAAGCAGAACTGGCGATGCGGGATGAACCGGAAGCCGGGTTACGGTGC +CTAACTGCGCGCTAACCTAGAACCCACAAAGGGTGTTGGTCGATTAAGACAGCAGGACGG +TGGTCATGGAAGTCGAAATCCGCTAAGGAGTGTGTAACAACTCACCTGCCGAATCAACTA +GCCCCGAAAATGGATGGCGCTGAAGCGCGCGACCTATACCCGGCCGTCGAGGCAAGTGCT +AGGCCCCGATGAGTAGGAGGGCGCAGCGGTCGCTGCAAAACCTTGGGCGTGAGCCCGGGC +GGAGCGGCCGTTGGTGCGGATCTTGGTGGTAGTAGCAAATATTCAAATGAGAACTTTGAA +GGCCGAAGAGGGGAAAGGTTCCATGTGAACGGCACTTGCACATGGGTTAGTCGATCCTAA +GAGTCGGGGGAAGCCCGACAGAGAGCGCGTTCAGCGCGAACTTCGAAAGGGAATCGGGTT +AAAATTCCTGAACCGGGACGTGGCGGCTGACGGCAACGTTAGGGAGTCCGGAGACGTCGG +CGGGGGCCTCGGGAAGAGTTATCTTTTCTGTTTAACAGCCTGCCCACCCTGGAAACGGCT +CAGCCGGAGGTAGGGTCCAGCGGCTGGAAGAGCACCGCACGTCGCGTGGTGTCCGGTGCG +CCCCCGGCGGCCCTTGAAAATCCGGAGGACCGAGTGCCTTCCACGCCCGGTCGTACTCAT +AACCGCATCAGGTCTCCAAGGTGAACAGCCTCTGGTCGATGGAACAATGTAGGCAAGGGA +AGTCGGCAAAATGGATCCGTAACTTCGGGAAAAGGATTGGCTCTGAGGGCTGGGCACGGG +GGTCCCAGTCCCGAACCCGTCGGCTGTCGGTGGACTGCTCGAGCTGCTCCCGCGGCGAGA +GCGGGTCACCGCGTGCCGGCCGGGGGACGGACTGGGAACGGCTCCTCACGGGGCCTTCCC +CGGGCGTCGAACAGTCAGACTCAGAACTGGTACGGACAAGGGGAATCCGACTGTTTAATT +AAAACAAAGCATTGCGATGGTCCCTGCGGATGCTAACGCAATGTGATTTCTGCCCAGTGC +TCTGAATGTCAAAGTGAAGAAATTCAACCAAGCGCGGGTAAACGGCGGGAGTAACTATGA +CTCTCTTAAGGTAGCCAAATGCCTCGTCATCTAATTAGTGACGCGCATGAATGGATTAAC +GAGATTCCCACTGTCCCTGTCTACTATCCAGCGAAACCACAGCCAAGGGAACGGGCTTGG +CAGAATCAGCGGGGAAAGAAGACCCTGTTGAGCTTGACTCTAGTCCGACTTTGTGAAATG +ACTTGAGAGGTGTAGGATAAGTGGGAGCCGGAAACGGCAAAAGTGAAATACCACTACTTT +TAACGTTATTTTACTTATTCCGTGAATCGGAGGCGGGGCACTGCCCCTCTTTTTGGACCG +AAGGCCAGCCTCGGCGGGCCGATCCGGGCGGAAGACATTGTCAGGTGGGGAGTTTGGCTG +GGGCGGCACATCTGTTAAAAGATAACGCAGGTGTCCTAAGATGAGCTCAACGAGAACAGA +AATCTCGTGTGGAACAGAAGGGTAAAAGCTCGTTTGATTCTGATTTCCAGTACGAATACG +AACCGTGAAAGCGTGGCCTAACGATCCTTTAGACCTTCGGAATTTGAAGCTAGAGGTGTC +AGAAAAGTTACCACAGGGATAACTGGCTTGTGGCAGCCAAGCGTTCATAGCGACGTTGCT +TTTTGATCCTTCGATGTCGGCTCTTCCTATCATTGTGAAGCAGAATTCACCAAGTGTTGG +ATTGTTCACCCACCAATAGGGAACGTGAGCTGGGTTTAGACCGTCGTGAGACAGGTTAGT +TTTACCCTACTGATGATAGTGTCGCAATAGTAATTCAACCTAGTACGAGAGGAACCGTTG +ATTCGCACAATTGGTCATCGCGCTTGGTTGAAAAGCCAGTGGCGCGAAGCTACCGTGCGT +CGGATTATGACTGAACGCCTCTAAGTCAGAATCCGGGCTAGAAGCGACGCATGTGCCCGC +CGCCCGTTTGCCGACCCGCAGTAGGGGCCATTCGGCCCCCAAAGGCACGTGTCGTTGGTG +AAGCCCGTGCGGTGGATGAGCCGTGCGGGCCGCCTTGAAGTATAATTCCTACCGAGCGGC +GGGTAGAATCCTTTGCAGACGACTTAAATACGCGACGGGGTATTGTAAGTGGCAGAGTGG +CCTTGCTGCCACGATCCACTGAGATTCAGCCCTGTGTCGCTTCGATTCGTCCCTCCCCCT +TCAACATAAAAAAAATCTTTTTCCCTTCCGATCCCAGAGGTTTCACCTTACAAGGAGGAC +CTTGGAACTTACGCTACACATAAGAATAGTGTGTAACGCGATTTACAACTATTACTAAGT +GGCCGAACAATATGCACAAGTGTATGCCCAAAATTAAAGCAAAGTATCTAAAAAGTGCAC +AAGGCTGCCCAATGTTTTCCATATAACTGCACAAGGTGGCGAAAGTGCAAGCCTGCAGTG +CCTATGTTTGTGCCTAAAGCTTCCCAACGACTTGACTTGGCTGCCCATTGATGGGTAAAC +ATGTGCGAAGAACTTTCCAATGCTGCCCCATGGCTGGGCAAATGCGTGCCAATGACTTGC +CATGGCTGCCCATTGGTAGGCAATTATGTGGCAACGACTTGCCAATGCAGCCCCATGGCT +GGGCAATTGTGTGCCATCGACATGCCAATGCAGCCCCATGACAGGGCAATTGTGTGCCAT +GGACATGCCAATGCTGCCCCATTGCTGGCCCAATTGTGCCATCGACTTGAGAAAATTGGG +CCATTGCTGGGCATATTGTGTGCCAACTACTTGACATGTCCGCCCATTGGTAGACGATTG +TGTGCCATCGATTGCCAAGGCTGGGCAATTATTTGCAGGTTGCCTAGAAAATGTGTGGCA +TTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATCTGAGCCATGGGTGGGCA +TTTGTGTGCAAAGACAGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGA +AATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGC +CATGGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCTAGAAATTGTGAGCCATTGCTG +CCCATTGCCGAGAAATTTTGTTCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCC +GAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGGAAATG +AGTGCCATTGCCGAGAAATGTGAGCCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATG +GCTGGGCAAATGTGTGCCACGGCTGATCATTGCCCAGACAATGTGAGCCATTGCCGACGA +ATTTGAGCCATGGCAGCCCATTGCCCCGAAAAATGAGTGCCATGGCCGAGCATGTGTTCC +AAGGCTGCCCATTGCCGAGAAATATGAGCCATGGCCGGGCAAATGTGTGCCATGTCTGCC +CATTGCCCAGAAATTGTGAGCCATGGCTGCCCCATTGCCGAGAAATCTGAGCCATGGCCG +GGCAATTGTGAGCCATGGCTGGCCAGTGCCGAGAAATGTGAGCCACGGCTGGACAATTGC +CGAGAAAATTGGGCCATTGCCCATAAATTTGAGTCATGGCTGGCCATTGCCGAGAAATGT +TGTTCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGACAAATCTGAGCCATGG +CCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCAT +TGCCGAGAACATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAA +ATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGA +AAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGTGTGC +CATGGCCGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGC +CCATTGCCGAGAAATTTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTGCCCATTGCCG +AGAAATCTGAGCCATGGCCGGGCAAATGGGAGCCATTGCTCAGAAATTTTAGCCATGGCT +GCCCATTGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCCCATTGC +CGAGAAATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGAGGAAAT +GAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCAT +GGCTGGGCATTTGTGTGCCTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTGCCCAGA +AATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGC +CATGGCTGCCCATTGCCTAGAAAATGTGAGCCATTGCCCAGAAATTTTAGCCATGGCTGC +CCATTGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCCCATTGCCG +AGAAATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGAGGAAATGA +GTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGG +CTGGGCATTTGTGTGCCTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTGCCCAGAAA +TTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCTGGCAAATGCGTGCCA +TGGCTGCCCATTGCCGAGAAATTGTGAGCCCTTGCCCAGAATTTTGAGCCATGGCTGGCC +ATTGCCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTGGCTGGGCAATTGCCGA +GAAATGTGAGCCATTGCCCAGAAATTTTAGCCATGGCTGGCCATTGCCGAGAAATGATGT +GCCATTGCCTGGAAATGTGAGCCCTTGCTGGGCAATTGCCCAGAAATTTGAGCCATGGCT +GCCCATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCACGGCTGGCCATTGC +CGAGAAATTGTTAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCGAGAAAA +TTGGGCCATGGTTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCAT +GGCTGGGCAGTTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGGCTGATC +ATTGCCTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGA +GAAAATTGGGCCATGGCTGCCCATTGTCGAGAAATTTGAGCCATGGCCGGGCAAATGTGT +GCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCC +GAGAAATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGAGAAAAT +TGGGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATG +GCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGGCTGATCA +TTGCCTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAG +AAAATTGGGCCATGGCTGCCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTG +CCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATGGCCG +AGAAATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGAGAAAATT +GGGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGG +CTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCAAGGCAGATCAT +TGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAA +ATTTGGGCCATTGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGAAAATTTGTGC +CATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCC +CATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCG +AGAAAATTGGGCCATGGTTGGGCATTTGTGTGCCAATGCTGATCATTGCCCAGAAATTTG +AGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGC +TGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATTTGTGCCATTGCTGCCCATTG +CCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCGAGAAA +ATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAA +ATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCC +ATGGCTGGGCATTTGTGTGCAAATGCTGCCCATTGCCGAGAAATTTGAGCCATGGCTGCC +CATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGA +GAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTG +TGCAAATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTT +GTGCCATTGCCGAGAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCC +GGGCAAATGTGTGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAAT +TGGGCAATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATG +GCTGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAAGGCTGCCCAT +TGCCGAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCATTGCCGAGAA +ATTGTGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGCGTGC +CATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAAGGCTGC +CCATTGCCGAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCATTGCCG +AGAAATTGTGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAATGC +GTGCCATGGCTGCCCATTGCCTAGAAAATGTGTGCTGTGCCATTGCCCAGAAAATGTGTG +CCATTGCCCAGAAATTTAAGCCTTGGCTGCCCATTGCTGGGCAATTGTGCGCCATCCACA +CCAAGGCCCAATGGGGTCTTGGTAAAAACAAGCATTTTTTGCGAAATGAGGTTGCGCGGG +GCCCCGCTCGTTGTAAATTGCAATCTCAAGGTGAACAAATGTGAAGGACGAGGCCCACAC +ACCATGGGCAATCGAGACCCGATCCAAGGGCAAGAAATTTAAATTAAAAGTCGACACCCG +CGTTAGGTGCATATGCCAAGACCTACGGCGGACACCCCGTGGCTCGACGTAAGCCGATGA +GAATCCTAAGACAAAACCTTCCATTACCCGTTTCCGTTCTCAAAACACGTATCCATGCTC +AACATCTAAAAAAAAAGTTCCCCCAAGGAACCGTTGCTCCTTTTGAACATCCCCATTCAA +TTCGATATTTTGATAACCAAACTACGTCTTCATTTTTATGCGGCTCAAACCTATATGTAA +ACTAATCTAAATGTTTATCACTTCACCCGGCCCCTCATTCTCAAAAATTTTTGTTTTTTC +CCTTAATTTTTTTTATTTTCAATTAATTTTTCAAAAAATATCGTATTTTTTTTTATGTGT +TTCATCTTAAATATGAACTATATATATTATAAACCTCATTAAAAACATTCTCCATATTTT +TCCATATTTATTACTATTTTTCCCTATTTTTTACTATTTTTTAACTATTTTTTTGGTAAT +TAATTAAAATAAATTTTTTCGGATCTCAAAAAATTATAAATTTTTTTCATGTTGTGCTAT +TATTTATTATTTTAAGATTTGAATTCAATTTTCATAAAAATAACTTATCCTTTTTAAAAA +AAAACCATTATGACTCCTCAAGCATGGGCAATGTTTCCTCCTGACATTTTCAGAAAAGCT +CATATAGCATATATAAGGGGGGGTGTATGCCCAGGCCTCCCCTTACCCAGCATGGGTCAA +GACTGGGCATGCATGGCCGCGCGCGTTGGTTGGCAATTGGCAAGCATTGCCGCGCGCATG +GGTTTGGCATTTTGGACGCGTGGGTTGGCAATGGAAAGGCATTGTCGCACGTGTGTCTCG +GCAATAGTTAGCCATGGCTCAAATTTCTCGGCAATGGCACCAATTTTCTCGGCAATGGCA +CAAGTTTTCTCGGCAATGGCACATCTTTTCTCGGCAATGACACATATTTTCTAGGCAATG +GTTTGCCAAGGCACACAATTGCCCAGAAAGCGTTGCCGAGCTTTGTTGAGAAGGCATTGC +CGCGTGGGTTGGTTCGCTGTAGGCTTGCATTGATGCTGCGCATGTTGGTGGGAAATAGGC +AAAGCGTTGCCGAGCGTGTTTGCTGGCAGCACGCAGGCATTGCTGCGCATGTTGGCTGGA +AATAAAGCTTGCATTGCCGAGCTCGTTGGTAGGCAAGGGGCAGGCATGGCCGTGTGCATG +GCTATGTTTGCCAGCTGCGTGTGTTGGCAATGGGCAGGCATTGCTGCACGCTTGGGTGAC +CGGGAGGGGTTGCCTTTTGGCTTGTTGTTGGGCATTCTTCGCAAGAGAAAGCTTGGACAA +TGGCCATGGGCAGCCAAGTCCAACATTGGTCTATCGATTGATGCATGGGGTGGTGGGAGG +GGATGTTGTGGAGCTTCCTTTGGGCTAGTTGGGCATTCTTTGCAAGGCTTTCTTGCGCAT +GCAAGGGCCTAGACAATGCTTCAAGAAGCCATGGGCAGCCCCACCGCTCATCCCACTGCC +CTCATGCTTAGGTTGACAATGGACAATTGGGATGCGTTGCCATGGTCTAGCAAGGGTGCT +TGCTTGCATGTTCAAGTGTGCAAATGGGTTTGTCAAATGTGGCCGATGTCCTCGCCATGC +TAGAAAATTGTGTGGAATGACTTTGGGCATGCTATTGCTAGCTCATCGTTTGCCTATGCA +ACTAGTAGGGTGTGGCGATGTCATGGGCTCGAGGGACATTCCTTAATGCTGGCTGGGTCA +TGTTTGTATGCTACTGTTGCTTGACAATGGCGTTGCATCGCTCATGGATGTTGCACAACA +CATTGTGCTCTGTTGGAAAAATGTGAAATCATGTCCCTTGAATTTTCGTGCCTATCGGTG +CTTTGTTCTGTCTCTTCTCGATGTAATTGCATTATTGTCGGTCAATATTTTGATCGATGG +GGTGTGATTCAATTGGGGGAGTCGGGGCATAGTGTACGTAGTGGTGCGTGGGTGGTGTTT +GGCCTGTGCGAGTTTGATGTTTCCTTGCTTTGTGCAACGAATTCATCTCGTGCATTCCTC +TTCAGTTATATCTTCAAGAGTAATAATAATTACTACCTTGAGTGTCCCATGGGTTCCTGT +GTTGTATACCTCTGATGCAATGGAATTTTCTCTGTAAAGACCCTATTTCGCTTTTGCACC +ACTCTGTGGTGCAAGTGAACCTCAAAGTATCACTCATGTCCCATGTGTGCCTCGCATTGA +AGTTGCATGCATGGCTCATGGGTGCTTTACTCGTGCTCTCGGATGCGGAAATCTTTTGAG +GGAAATTGGTCTTCTGACCTTTTTACCTGTAAAGCGTTCGACCCTTAATTTGGAAGACTG +TTGTGCTCGTCTTTGACCTATCCGATTGCTCGGCTAGGCTCATGCGGTGCCAACGTCGCA +AAGGAATGCTACCTGGTTGATCCTGCCAGTAGTCATATGCTTGTCTCAAAGATTAAGCCA +TGCATGTGTAAGTATGAACTAATTCAGACTGTGAAACTGCGAATGGCTCATTAAATCAGT +TATAGTTTGTTTGATGGTATTTGCTACTCGGATAACCGTAGTAATTCTAGAGCTAATACG +TGCAACAAACCCCGACTTCTGGAAGGGATGCATTTATTAGATAAAAGGTCGACGCGGGCT +TTGCCCGTTGCTCTGATGATTCATGATAACTCGACGGATCGCACGGCCTTCGTGCCGGCG +ACGCATCATTCAAATTTCTGCCCTATCAACTTTCGATGGTAGGATAGTGGCCTACTATGG +TGTTAACGGGTGACGGAGAATTAGGGTTCGATTCCGGAGAGGGAGCCTGAGAAACGGCTA +CCACATCCAAGGAAGGCAGCAGGCGCGCAAATTACCCAATCCTGACACGGGGAGGTAGTG +ACAATAAATAACAATACCGGGCTCATTGAGTCTGGTAATTGGAATGAGTACAATCTAAAT +CCCTTAACGAGGATCCATTGGAGGGCAAGTCTGGTGCCAGCAGCCGCGGTAATTCCAGCT +CCAATAGCGTATATTTAAGTTGTTGCAGTTAAAAAGCTCGTAGTTGGATTTTGGGTTGGG +CCGACCGGTCCGCCTTCAGGTGTGCACCGGTCGTCTCGTCCCTTCTGCCGGCGATGCGCT +CCTAGCCTTAACTGGCCGGGTCGTGCCTCCGGCGCTGTTACTTTGAAGAAATTAGAGTGC +TCAAAGCAAGCCTACGCTCTGGATACATTAGCATGGGATAACATCATAGGATTTCGATCC +TATTCTGTTGGCCTTCGGGATCGGAGTAATGATTAACAGGGACAGTCGGGGGCATTCGTA +TTTCATAGTCAGAGGTGAAATTCTTGGATTTATGAAAGACGAACAACTGCGAAAGCATTT +GCCAAGGATGTTTTCATTAATCAAGAACGAAAGTTGGGGGCTCGAAGACGATCAGATACC +GTCCTAGTCTCAACCATAAACGATGCCGACCAGGGATCAGCGGATGTTACTTTTAGGACT +CCGCTGGCACCTTATGAGAAATCAAAGTTTTTGGGTTCCGGGGGGAGTATGGTCGCAAGG +CTGAAACTTAAAGGAATTGACGGAAGGGCACCACCAGGAGTGGAGCCTGCGGCTTAATTT +GACTCAACACGGGGAAACTTACCAGGTCCAGACATAGTAAGGATTGACAGACTGAGAGCT +CTTTCTTGATTCTATGGGTGGTGGTGCATGGCCGTTCTTAGTTGGTGGAGCGATTTGTCT +GGTTAATTCCGTTAACGAACGAGACCTCAGCCTGCTAACTAGCTATGTGGAGGTGACCCT +CCACAGCTAGCTTCTTAGAGGGACTATGGCCCTTCAGGCCACGGAAGTTTGAGGCAATAA +CAGGTCTGTGATGCCCTTAGATGTTCTGGGCCGCACGCGCGCTACACTGATGTATTCAAC +GAGTTTATAGCCTTGGCCGACAGGCCCGGGTAATCTTTGAAATTTCATCGTGATGGGGAT +AGATCATTGCAATTGTTGGTCTTCAACGAGGAATTCCTAGTAAGCGCGAGTCATCAGCTC +GCGTTGACTACGTCCCTGCCCTTTGTACACACCGCCCGTCGCTCCTACCGATTGAATGGT +CCGGTGAAGTGTTCGGATCGCGGCGACGTGGGCGGTTCGCTGCCGGCGACGTCGCGAGAA +GTCCACTGAACCTTATCATTTAGAGGAAGGAGAAGTCGTAACAAGGTTTCCGTAGGTGAA +CCTGCGGAAGGATCATTGTCGAAACCTGCCTAGCAGAATGACCCGCGAACTTGTATAATA +CCATCGGGGAAGCAAAAGTTTGGTTTTTATAGCCTACTTTTTCTTCCCTTTGCCGGGTGT +GCTCGTGTTGCCCCATGGGTGACACTCTCATTCCCCGGTCAAACAACGAACCCCGGCGCG +AAACGCGTCAAGGAACTTGAACAAGAATGCAACATCCATGCCCCGTTTTTGGGTGCTTGT +GGTGCTTGCTCTCTCATGAACGAAACGACTCTCGGCAACGGATATCTCGGCTCTCGCATC +GATGAAGAACGTAGCGAAATGCGATACTTGGTGTGAATTGCAGAATCCCGTGAACCATCG +AGTTTTTGAACGCAAGTTGCGCCTGAAGCCATTAGGCCGAGGGCACGTCTGCCTGGGCGT +CACGCATTGTGTCGCCCACCCAACTCAAGCCTTACCAAGGATTGGGTGTGGGTGGGCGGA +TATTGGCCCCCCGTGCACATTAGTGAACGGTCGGCCTAAAAATGAAGTCCTTGGCAATGG +ACGTCACAACAAGTGGTGGTTGACAAACCGTTGCGTCCTGTTGTGCTTGCCCCCATTGCT +AATGGTTTACTTTTGACCCTAATGTGCCGTTATCACGGTTTCGATCGCGACCCCAGGTCA +GGCGGGATTACCCGCTGAGTTTAAGCATATCAATAAGCGGAGGAAAAGAAACTTACAAGG +ATTCCCTTAGTAACGGCGAGCGAACCGGGAATAGCCCAGCTTGAAAATCGGGCGATCTCG +TTGTCCGAATTGTAGTCTGGAGAAGCGTCCTCAGCGGCGGACCGGGCCCAAGTCCCCTGG +AAGGGGGCGCCAGAGAGGGTGAGAGCCCCGTCGTGCCCGGACCCTGTCGCACCACGAGGC +GCTGTCGACGAGTCGGGTTGTTTGGGAATGCAGCCCCAATCGGGCGGTAAATTCCGTCCA +AGGCTAAATATGGGCGAGAGACCGATAGCAAACAAGTACCGCGAGGGAAAGATGAAAAGG +ACTTTGAAAAGAGAGTCAAAGAGTGCTTGAAATTGTCGGGAGGGAAGCGGATGGGGGCCG +GCGATGCGCCTCGGTCGGATGTGGAACGGTTAATAGCCGGTCTGCCGATCGACTCGGGGC +GTGGATCGGTGCGGATTGGGGCGGAGGCCAAAGCCCGGGCAGTTGTTACGCCTGTGGAGA +CGCCTTTGCCTCGATCGTGGCTGGCAGCGCGCGCCTTTGGCGTGCTTCGGCATCTGCGCG +CTCCTGGCACCGGCCTGCGGGCTCCCCATTCGGCCCGTCTTGAAACACGGACCAAGGAGT +CTGACATGTGTGCGAGTCAACGGGCGAGTAAACCCGTAAGGCGTAAGGAAGCTGATTGGC +GGGATCCCCTAGCGGGTTGCACCGCCGACCGACCTTGATCTTCTGAGAAGGGTTCGAGTG +TGAGCATGCCTGTCGGGACCCGAAAGATGGTGAACTATGCCTGAGCGGGGCGAAGCCAGA +GGAAACTCTGGTGGAGGCCCGCAGCGATACTGACGTGCAAATCGTTCGTCTGACTTGGGT +ATAGGGGCGAAAGACTAATCGAACCGTCTAGTAGCTGGTTCCCTCCGAAGTTTCCCTCAG +GATAGCTGGAGCCCGTGTGCGAGTTCTATCGGGTAAAGCCAATGATTAGAGGCATCGGGG +GCGCAACGCCCTCGACCTATTCTCAAACTTTAAATAGGTAGGACGGCGCGGCTGCTTTGT +TGAGCCGCGCCACGGAATCGAGAGCTCCAAGTGGGCCATTTTTGGTAAGCAGAACTGGCG +ATGCGGGATGAACCGGAAGCCGGGTTACGGTGCCTAACTGCGCGCTAACCTAGAACCCAC +AAAGGGTGTTGGTCGATTAAGACAGCAGGACGGTGGTCATGGAAGTCGAAATCCGCTAAG +GAGTGTGTAACAACTCACCTGCCGAATCAACTAGCCCCGAAAATGGATGGCGCTGAAGCG +CGCGACTTATACCCGGCCGTCGAGGCAAGTGCTAGGCCCCGATGAGTAGGAGGGCGCAGC +GGTCGCTGCAAAACCTTGGGCGTGAGCCCGGGCGGAGCGGCCGTTGGTGCGGATCTTGGT +GGTAGTAGCAAATATTCAAATGAGAACTTTGAAGGCCGAAGAGGGGAAAGGTTCCATGTG +AACGGCACTTGCACATGGGTTAGTCGATCCTAAGAGTCGGGGGAAGCCCGACAGAGAGCG +CGTTCAGCGCGAACTTCGAAAGGGAATCGGGTTAAAATTCCTGAACCGGGACGTGGCGGC +TGACGGCAACGTTAGGGAGTCCGGAGACGTCGGCGGGGGCCTCGGGAAGAGTTATCTTTT +CTGTTTAACAGCCTGCCCACCCTGGAAACGGCTCAGCCGGAGGTAGGGTCCAGCGGCTGG +AAGAGCACCGCACGTCGCGTGGTGTCCGGTGCGCCCCCGGCGGCCCTTGAAAATCCGGAG +GACCGAGTGCCTTCCACGCCCGGTCGTACTCATAACCGCATCAGGTCTCCAAGGTGAACA +GCCTCTGGTCGATGGAACAATGTAGGCAAGGGAAGTCGGCAAAATGGATCCGTAACTTCG +GGAAAAGGATTGGCTCTGAGGGCTGGGCACGGGGGTCCCAGTCCCGAACCCGTCGGCTGT +CGGTGGACTGCTCGAGCTGCTCCCGCGGCGAGAGCGGGTCACCGCGTGCCGGCCGGGGGA +CGGACTGGGAACGGCTCCTCACGGGGCCTTCCCCGGGCGTCGAACAGTCAGACTCAGAAC +TGGTACGGACAAGGGGAATCCGACTGTTTAATTAAAACAAAGCATTGCGATGGTCCCTGC +GGATGCTAACGCAATGTGATTTCTGCCCAGTGCTCTGAATGTCAAAGTGAAGAAATTCAA +CCAAGCGCGGGTAAACGGCGGGAGTAACTATGACTCTCTTAAGGTAGCCAAATGCCTCGT +CATCTAATTAGTGACGCGCATGAATGGATTAACGAGATTCCCACTGTCCCTGTCTACTAT +CCAGCGAAACCACAGCCAAGGGAACGGGCTTGGCAGAATCAGCGGGGAAAGAAGACCCTG +TTGAGCTTGACTCTAGTCCGACTTTGTGAAATGACTTGAGAGGTGTAGGATAAGTGGGAG +CCGGAAACGGCAAAAGTGAAATACCACTACTTTTAACGTTATTTTACTTATTCCGTGAAT +CGGAGGCGGGGCACTGCCCCTCTTTTTGGACCGAAGGCCAGCCTCGGCGGGCCGATCCGG +GCGGAAGACATTGTCAGGTGGGGAGTTTGGCTGGGGCGGCACATCTGTTAAAAGATAACG +CAGGTGTCCTAAGATGAGCTCAACGAGAACAGAAATCTCGTGTGGAACAGAAGGGTAAAA +GCTCGTTTGATTCTGATTTCCAGTACGAATACGAACCGTGAAAGCGTGGCCTAACGATCC +TTTAGACCTTCGGAATTTGAAGCTAGAGGTGTCAGAAAAGTTACCACAGGGATAACTGGC +TTGTGGCAGCCAAGCGTTCATAGCGACGTTGCTTTTTGATCCTTCGATGTCGGCTCTTCC +TATCATTGTGAAGCAGAATTCACCAAGTGTTGGATTGTTCACCCACCAATAGGGAACGTG +AGCTGGGTTTAGACCGTCGTGAGACAGGTTAGTTTTACCCTACTGATGATAGTGTCGCAA +TAGTAATTCAACCTAGTACGAGAGGAACCGTTGATTCGCACAATTGGTCATCGCGCTTGG +TTGAAAAGCCAGTGGCGCGAAGCTACCGTGCGTCGGATTATGACTGAACGCCTCTAAGTC +AGAATCCGGGCTAGAAGCGACGCATGTGCCCGCCGCCCGTTTGCCGACCCGCAGTAGGGG +CCATTCGGCCCCCAAAGGCACGTGTCGTTGGTGAAGCCCGTGCGGTGGATGAGCCGTGCG +GGCCGCCTTGAAGTATAATTCCTACCGAGCGGCGGGTAGAATCCTTTGCAGACGACTTAA +ATACGCGACGGGGTATTGTAAGTGGCAGAGTGGCCTTGCTGCCACGATCCACTGAGATTC +AGCCCTGTGTCGCTTCGATTCGTCCCTCCCCCTTCAACATAAAAAAAATCTTTTTCCCTT +CCGATCCCAGAGGTTTCACCTTACAAGGAGGACCTTGGAACTTACGCTACACATAAGAAT +AGTGTGTAACGCGATTTACAACTATTACTAAGTGGCCGAACAATATGCACAAGTGTATGC +CCAAAATTAAAGCAAAGTATCTAAAAAGTGCACAAGGCTGCCCAATGTTTTCCATATAAC +TGCACAAGGTGGCGAAAGTGCAAGCCTGCAGTGCCTATGTTTGTGCCTAAAGCTTCCCAA +CGACTTGACTTGGCTGCCCATTGATGGGTAAACATGTGCGAAGAACTTTCCAATGCTGCC +CCATGGCTGGGCAAATGCGTGCCAATGACTTGCCATGGCTGCCCATTGGTAGGCAATTAT +GTGGCAACGACTTGCCAATGCAGCCCCATGGCTGGGCAATTGTGTGCCATCGACATGCCA +ATGCAGCCCCATGACAGGGCAATTGTGTGCCATGGACATGCCAATGCTGCCCCATTGCTG +GCCCAATTGTGCCATCGACTTGAGAAAATTGGGCCATTGCTGGGCATATTGTGTGCCAAC +TACTTGACATGTCCGCCCATTGGTAGACGATTGTGTGCCATCGATTGCCAAGGCTGGGCA +ATTATTTGCAGGTTGCCTAGAAAATGTGTGGCATTGCCCAGAAATTTGAGCCATGGCTGG +CCATTGCCGAGAAATCTGAGCCATGGGTGGGCATTTGTGTGCAAAGACAGATCATTGCCC +AGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTG +GGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATTGC +TGCCCATTGCCTAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTTCCATT +GCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAA +TGCGTGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAGCCA +TGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCAAATGTGTGCCACGGCTGAT +CATTGCCCAGACAATGTGAGCCATTGCCGACGAATTTGAGCCATGGCAGCCCATTGCCCC +GAAAAATGAGTGCCATGGCCGAGCATGTGTTCCAAGGCTGCCCATTGCCGAGAAATATGA +GCCATGGCCGGGCAAATGTGTGCCATGTCTGCCCATTGCCCAGAAATTGTGAGCCATGGC +TGCCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAATTGTGAGCCATGGCTGGCCAGT +GCCGAGAAATGTGAGCCACGGCTGGACAATTGCCGAGAAAATTGGGCCATTGCCCATAAA +TTTGAGTCATGGCTGGCCATTGCCGAGAAATGTTGTTCCATTGCCGAGAAAATTGGGCCA +TGGCTGCCCATTGCCGACAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCC +ATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAACATTGGGCCATGGCTGCC +CATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGA +GAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCG +AGAAATCTGAGCCATGGCTGGGCAAATGTGTGCCATGGCCGCCCATTGCCGAGAAATTGT +GAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATTTTGTGCCATTG +CCTAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAAT +GGGAGCCATTGCTCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCAT +TGCCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAGAAATTTAAGGCATGGCCGGGCAA +ATGCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACC +ATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTGA +TCATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCG +AGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAAATGT +GAGCCATTGCCCAGAAATTTTAGCCATGGCTGCCCATTGCCAAGAAATGTTGTGCCATTG +CCTAGAAAATTGGGCCATGGCTTCCCATTGCCGAGAAATTTAAGGCATGGCCGGGCAAAT +GCGTGGCATGGCTGGCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCAT +GGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCTAGGCTGATC +ATTGCCTAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAG +AAATCTGAGCCATGGCCTGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGA +GCCCTTGCCCAGAATTTTGAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCC +TGGAAATGTGAGCCCTGGCTGGGCAATTGCCGAGAAATGTGAGCCATTGCCCAGAAATTT +TAGCCATGGCTGGCCATTGCCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTTG +CTGGGCAATTGCCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAAATTTGTGCCAT +TGCCGAGAAAATTGGGCCACGGCTGGCCATTGCCGAGAAATTGTTAGCCATTGCTGCCCA +TTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGTTGCCCATTGCCGAGG +AAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAGTTGCCGAGAAAATTGGG +CCATGGCTGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCT +GGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGT +CGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGG +CCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCAT +GGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGA +AATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGC +CATGGCTGGGCATTTGTGTGCCACGGCTGATCATTGCCTAGAAAATTTGAGCCATGGCTG +GCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCC +GAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCCGAGAAATTTGAGCCATGGC +CGGGCAAATGTGTGCCATTGCTGCCCATGGCCGAGAAATTGTGAGCCATTGCTGCCCATG +GCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGGAA +ATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCC +ATGGCTGGGCATTTGTGTGCCAAGGCAGATCATTGCCCAGAAATTTGAGCCATGGCTGGC +CATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTTGGGCCATTGCCGGGCAAATGTGT +GCCATTGCTGCCCATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCATGGCT +GCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGC +CGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGTTGGGCATTT +GTGTGCCAATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAAT +GTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCAT +GGCCGGGCAAATTTGTGCCATTGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCC +ATTGCCGAGAAATTTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAG +AAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAA +CCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCT +GCCCATTGCCGAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCT +GCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTG +CCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCAAATGCTGATCATTGCCCAGAAAT +TTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAATTGGGCCATG +GCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTGGCCAT +TGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCAATGGCTGCCCATTGCCGAGAA +ATCTGAGCCATGGCCGGGCAAATGTGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGC +CATTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTGCCGA +GAAAATTAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATTGCCG +AGAAATCTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGT +GAGCCATTGCCCAGAAAATTGGGCCAAGGCTGCCCATTGCCGAGAAATTGTGTGCCATTG +CCGAGAAAATTAGGCCATGGCTGCCCATTGCCGAGAAATTGTGTGCCACGGCTGCCCATT +GCCGAGAAATCTGAGCCATGGCTGGGCAAATGCGTGCCATGGCTGCCCATTGCCTAGAAA +ATGTGTGCTGTGCCATTGCCCAGAAAATGTGTGCCATTGCCCAGAAATTTAAGCCTTGGC +TGCCCATTGCTGGGCAATTGTGCGCCATCCACACCAAGGCCCAATGGGGTCTTGGTAAAA +ACAAGCATTTTTTGCGAAATGAGGTTGCGCGGGGCCCCGCTCGTTGTAAATTGCAATCTC +AAGGTGAACAAATGTGAAGGACGAGGCCCACACACCATGGGCAATCGAGACCCGATCCAA +GGGCAAGAAATTTAAATTAAAAGTCGACACCCGCGTTAGGTGCATATGCCAAGACCTACG +GCGGACACCCCGTGGCTCGACGTAAGCCGATGAGAATCCTAAGACAAAACCTTCCATTAC +CCGTTTCCGTTCTCAAAACACGTATCCATGCTCAACATCTAAAAAAAAAGTTCCCCCAAG +GAACCGTTGCTCCTTTTGAACATCCCCATTCAATTCGATATTTTGATAACCAAACTACGT +CTTCATTTTTATGCGGCTCAAACCTATATGTAAACTAATCTAAATGTTTATCACTTCACC +CGGCCCCTCATTCTCAAAAATTTTTGTTTTTTCCCTTAATTTTTTTTATTTTCAATTAAT +TTTTCAAAAAATATCGTATTTTTTTTTATGTGTTTCATCTTAAATATGAACTATATATAT +TATAAACCTCATTAAAAACATTCTCCATATTTTTCCATATTTATTACTATTTTTCCCTAT +TTTTTACTATTTTTTAACTATTTTTTTGGTAATTAATTAAAATAAATTTTTTCGGATCTC +AAAAAATTATAAATTTTTTTCATGTTGTGCTATTATTTATTATTTTAAGATTTGAATTCA +ATTTTCATAAAAATAACTTATCCTTTTTAAAAAAAAACCATTATGACTCCTCAAGCATGG +ACAATGTTTCCTCCTGACATTTTCAGAAAAGCTCATATAGCATATATAAGGGGGGGTGTA +TGCCCAGGCCTCCCCTTACCCAGCATGGGTCAAGACTGGGCATGCATGGCCGCGCGCGTT +GGTTGGCAATTGGCAAGCATTGCCGCGCGCATGGGTTTGGCATTTTGGACGCGTGGGTTG +GCAATGGAAAGGCATTGTCGCACGTGTGTCTCGGCAATAGTTAGCCATGGCTCAAATTTC +TCGGCAATGGCACCAATTTTCTCGGCAATGGCACAAGTTTTCTCGGCAATGGCACATCTT +TTCTCGGCAATGACACATATTTTCTAGGCAATGGTTTGCCAAGGCACACAATTGCCCAGA +AAGCGTTGCCGAGCTTTGTTGAGAAGGCATTGCCGCGTGGGTTGGTTCGCTGTAGGCTTG +CATTGATGCTGCGCATGTTGGTGGGAAATAGGCAAAGCGTTGCCGAGCGTGTTTGCTGGC +AGCACGCAGGCATTGCTGCGCATGTTGGCTGGAAATAAAGCTTGCATTGCCGAGCTCGTT +GGTAGGCAAGGGGCAGGCATGGCCGTGTGCATGGCTATGTTTGCCAGCTGCGTGTGTTGG +CAATGGGCAGGCATTGCTGCACGCTTGGGTGACCGGGAGGGGTTGCCTTTTGGCTTGTTG +TTGGGCATTCTTCGCAAGAGAAAGCTTGGACAATGGCCATGGGCAGCCAAGTCCAACATT +GGTCTATCGATTGATGCATGGGGTGGTGGGAGGGGATGTTGTGGAGCTTCCTTTGGGCTA +GTTGGGCATTCTTTGCAAGGCTTTCTTGCGCATGCAAGGGCCTAGACAATGCTTCAAGAA +GCCATGGGCAGCCCCACCGCTCATCCCACTGCCCTCATGCTTAGGTTGACAATGGACAAT +TGGGATGCGTTGCCATGGTCTAGCAAGGGTGCTTGCTTGCATGTTCAAGTGTGCAAATGG +GTTTGTCAAATGTGGCCGATGTCCTCGCCATGCTAGAAAATTGTGTGGAATGACTTTGGG +CATGCTATTGCTAGCTCATCGTTTGCCTATGCAACTAGTAGGGTGTGGCGATGTCATGGG +CTCGAGGGACATTCCTTAATGCTGGCTGGGTCATGTTTGTATGCTACTGTTGCTTGACAA +TGGCGTTGCATCGCTCATGGATGTTGCACAACACATTGTGCTCTGTTGGAAAAATGTGAA +ATCATGTCCCTTGAATTTTCGTGCCTATCGGTGCTTTGTTCTGTCTCTTCTCGATGTAAT +TGCATTATTGTCGGTCAATATTTTGATCGATGGGGTGTGATTCAATTGGGGGAGTCGGGG +CATAGTGTACGTAGTGGTGCGTGGGTGGTGTTTGGCCTGTGCGAGTTTGATGTTTCCTTG +CTTTGTGCAACGAATTCATCTCGTGCATTCCTCTTCAGTTATATCTTCAAGAGTAATAAT +AATTACTACCTTGAGTGTCCCATGGGTTCCTGTGTTGTATACCTCTGATGCAATGGAATT +TTCTCTGTAAAGACCCTATTTCGCTTTTGCACCACTCTGTGGTGCAAGTGAACCTCAAAG +TATCACTCATGTCCCATGTGTGCCTCGCATTGAAGTTGCATGCATGGCTCATGGGTGCTT +TACTCGTGCTCTCGGATGCGGAAATCTTTTGAGGGAAATTGGTCTTCTGACCTTTTTACC +TGTAAAGCGTTCGACCCTTAATTTGGAAGACTGTTGTGCTCGTCTTTGACCTATCCGATT +GCTCGGCTAGGCTCATGCGGTGCCAACGTCGCAAAGGAATGCTACCTGGTTGATCCTGCC +AGTAGTCATATGCTTGTCTCAAAGATTAAGCCATGCATGTGTAAGTATGAACTAATTCAG +ACTGTGAAACTGCGAATGGCTCATTAAATCAGTTATAGTTTGTTTGATGGTATTTGCTAC +TCGGATAACCGTAGTAATTCTAGAGCTAATACGTGCAACAAACCCCGACTTCTGGAAGGG +ATGCATTTATTAGATAAAAGGTCGACGCGGGCTTTGCCCGTTGCTCTGATGATTCATGAT +AACTCGACGGATCGCACGGCCTTCGTGCCGGCGACGCATCATTCAAATTTCTGCCCTATC +AACTTTCGATGGTAGGATAGTGGCCTACTATGGTGTTAACGGGTGACGGAGAATTAGGGT +TCGATTCCGGAGAGGGAGCCTGAGAAACGGCTACCACATCCAAGGAAGGCAGCAGGCGCG +CAAATTACCCAATCCTGACACGGGGAGGTAGTGACAATAAATAACAATACCGGGCTCATT +GAGTCTGGTAATTGGAATGAGTACAATCTAAATCCCTTAACGAGGATCCATTGGAGGGCA +AGTCTGGTGCCAGCAGCCGCGGTAATTCCAGCTCCAATAGCGTATATTTAAGTTGTTGCA +GTTAAAAAGCTCGTAGTTGGATTTTGGGTTGGGCCGACCGGTCCGCCTTCAGGTGTGCAC +CGGTCGTCTCGTCCCTTCTGCCGGCGATGCGCTCCTAGCCTTAACTGGCCGGGTCGTGCC +TCCGGCGCTGTTACTTTGAAGAAATTAGAGTGCTCAAAGCAAGCCTACGCTCTGGATACA +TTAGCATGGGATAACATCATAGGATTTCGATCCTATTCTGTTGGCCTTCGGGATCGGAGT +AATGATTAACAGGGACAGTCGGGGGCATTCGTATTTCATAGTCAGAGGTGAAATTCTTGG +ATTTATGAAAGACGAACAACTGCGAAAGCATTTGCCAAGGATGTTTTCATTAATCAAGAA +CGAAAGTTGGGGGCTCGAAGACGATCAGATACCGTCCTAGTCTCAACCATAAACGATGCC +GACCAGGGATCAGCGGATGTTACTTTTAGGACTCCGCTGGCACCTTATGAGAAATCAAAG +TTTTTGGGTTCCGGGGGGAGTATGGTCGCAAGGCTGAAACTTAAAGGAATTGACGGAAGG +GCACCACCAGGAGTGGAGCCTGCGGCTTAATTTGACTCAACACGGGGAAACTTACCAGGT +CCAGACATAGTAAGGATTGACAGACTGAGAGCTCTTTCTTGATTCTATGGGTGGTGGTGC +ATGGCCGTTCTTAGTTGGTGGAGCGATTTGTCTGGTTAATTCCGTTAACGAACGAGACCT +CAGCCTGCTAACTAGCTATGTGGAGGTGACCCTCCACAGCTAGCTTCTTAGAGGGACTAT +GGCCCTTCAGGCCACGGAAGTTTGAGGCAATAACAGGTCTGTGATGCCCTTAGATGTTCT +GGGCCGCACGCGCGCTACACTGATGTATTCAACGAGTTTATAGCCTTGGCCGACAGGCCC +GGGTAATCTTTGAAATTTCATCGTGATGGGGATAGATCATTGCAATTGTTGGTCTTCAAC +GAGGAATTCCTAGCAAGCGCGAGTCATCAGCTCGCGTTGACTACGTCCCTGCCCTTTGTA +CACACCGCCCGTCGCTCCTACCGATTGAATGGTCCGGTGAAGTGTTCGGATCGCGGCGAC +GTGGGCGGTTCGCTGCCGGCGACGTCGCGAGAAGTCCACTGAACCTTATCATTTAGAGGA +AGGAGAAGTCGTAACAAGGTTTCCGTAGGTGAACCTGCGGAAGGATCATTGTCGAAACCT +GCCTAGCAGAATGACCCGCGAACTTGTATAATACCATCGGGGAAGCAAAAGTTTGGTTTT +TATAGCCTACTTTTTCTTCCCTTTGCCGGGTGTGCTCGTGTTGCCCCATGGGTGACACTC +TCATTCCCCGGTCAAACAACGAACCCCGGCGCGAAACGCGTCAAGGAACTTGAACAAGAA +TGCAACATCCATGCCCCGTTTTTGGGTGCTTGTGGTGCTTGCTCTCTCATGAACGAAACG +ACTCTCGGCAACGGATATCTCGGCTCTCGCATCGATGAAGAACGTAGCGAAATGCGATAC +TTGGTGTGAATTGCAGAATCCCGTGAACCATCGAGTTTTTGAACGCAAGTTGCGCCTGAA +GCCATTAGGCCGAGGGCACGTCTGCCTGGGCGTCACGCATTGTGTCGCCCACCCAACTCA +AGCCTTACCAAGGATTGGGTGTGGGTGGGCGGATATTGGCCCCCCGTGCACATTAGTGAA +CGGTCGGCCTAAAAATGAAGTCCTTGGCAATGGACGTCACAACAAGTGGTGGTTGACAAA +CCGTTGCGTCCTGTTGTGCTTGCCCCCATTGCTAATGGTTTACTTTTGACCCTAATGTGC +CGTTATCACGGCTTCGATCGCGACCCCAGGTCAGGCGGGATTACCCGCTGAGTTTAAGCA +TATCAATAAGCGGAGGAAAAGAAACTTACAAGGATTCCCTTAGTAACGGCGAGCGAACCG +GGAATAGCCCAGCTTGAAAATCGGGCGATCTCGTTGTCCGAATTGTAGTCTGGAGAAGCG +TCCTCAGCGGCGGACCGGGCCCAAGTCCCCTGGAAGGGGGCGCCAGAGAGGGTGAGAGCC +CCGTCGTGCCCGGACCCTGTCGCACCACGAGGCGCTGTCGACGAGTCGGGTTGTTTGGGA +ATGCAGCCCCAATCGGGCGGTAAATTCCGTCCAAGGCTAAATATGGGCGAGAGACCGATA +GCAAACAAGTACCGCGAGGGAAAGATGAAAAGGACTTTGAAAAGAGAGTCAAAGAGTGCT +TGAAATTGTCGGGAGGGAAGCGGATGGGGGCCGGCGATGCGCCTCGGTCGGATGTGGAAC +GGTTAATAGCCGGTCTGCCGATCGACTCGGGGCGTGGATCGGTGCGGATTGGGGCGGAGG +CCAAAGCCCGGGCAGTTGTTACGCCTGTGGAGACGCCTTTGCCTCGATCGTGGCTGGCAG +CGCGCGCCTTTGGCGTGCTTCGGCATCTGCGCGCTCCTGGCACCGGCCTGCGGGCTCCCC +ATTCGGCCCGTCTTGAAACACGGACCAAGGAGTCTGACATGTGTGCGAGTCAACGGGCGA +GTAAACCCGTAAGGCGTAAGGAAGCTGATTGGCGGGATCCCCTAGCGGGTTGCACCGCCG +ACCGACCTTGATCTTCTGAGAAGGGTTCGAGTGTGAGCATGCCTGTCGGGACCCGAAAGA +TGGTGAACTATGCCTGAGTGGGGCGAAGCCAGAGGAAACTCTGGTGGAGGCCCGCAGCGA +TACTGACGTGCAAATCGTTCGTCTGACTTGGGTATAGGGGCGAAAGACTAATCGAACCGT +CTAGTAGCTGGTTCCCTCCGAAGTTTCCCTCAGGATAGCTGGAGCCCGTGTGCGAGTTCT +ATCGGGTAAAGCCAATGATTAGAGGCATCGGGGGCGCAACGCCCTCGACCTATTCTCAAA +CTTTAAATAGGTAGGACGGCGCGGCTGCTTTGTTGAGCCGCGCCACGGAATCGAGAGCTC +CAAGTGGGCCATTTTTGGTAAGCAGAACTGGCGATGCGGGATGAACCGGAAGCCGGGTTA +CGGTGCCTAACTGCGCGCTAACCTAGAACCCACAAAGGGTGTTGGTCGATTAAGACAGCA +GGACGGTGGTCATGGAAGTCGAAATCCGCTAAGGAGTGTGTAACAACTCACCTGCCGAAT +CAACTAGCCCCGAAAATGGATGGCGCTGAAGCGCGCGACCTATACCCGGCCGTCGAGGCA +AGTGCTAGGCCCCGATGAGTAGGAGGGCGCAGCGGTCGCTGCAAAACCTTGGGCGTGAGC +CCGGGCGGAGCGGCCGTTGGTGCGGATCTTGGTGGTAGTAGCAAATATTCAAATGAGAAC +TTTGAAGGCCGAAGAGGGGAAAGGTTCCATGTGAACGGCACTTGCACATGGGTTAGTCGA +TCCTAAGAGTCGGGGGAAGCCCGACAGAGAGCGCGTTCAGCGCGAACTTCGAAAGGGAAT +CGGGTTAAAATTCCTGAACCGGGACGTGGCGGCTGACGGCAACGTTAGGGAGTCCGGAGA +CGTCGGCGGGGGCCTCGGGAAGAGTTATCTTTTCTGTTTAACAGCCTGCCCACCCTGGAA +ACGGCTCAGCCGGAGGTAGGGTCCAGCGGCTGGAAGAGCACCGCACGTCGCGTGGTGTCC +GGTGCGCCCCCGGCGGCCCTTGAAAATCCGGAGGACCGAGTGCCTTCCACGCCCGGTCGT +ACTCATAACCGCATCAGGTCTCCAAGGTGAACAGCCTCTGGTCGATGGAACAATGTAGGC +AAGGGAAGTCGGCAAAATGGATCCGTAACTTCGGGAAAAGGATTGGCTCTGAGGGCTGGG +CACGGGGGTCCCAGTCCCGAACCCGTCGGCTGTCGGTGGACTGCTCGAGCTGCTCCCGCG +GCGAGAGCGGGTCACCGCGTGCCGGCCGGGGGACGGACTGGGAACGGCTCCTCACGGGGC +CTTCCCCGGGCGTCGAACAGTCAGACTCAGAACTGGTACGGACAAGGGGAATCCGACTGT +TTAATTAAAACAAAGCATTGCGATGGTCCCTGCGGATGCTAACGCAATGTGATTTCTGCC +CAGTGCTCTGAATGTCAAAGTGAAGAAATTCAACCAAGCGCGGGTAAACGGCGGGAGTAA +CTATGACTCTCTTAAGGTAGCCAAATGCCTCGTCATCTAATTAGTGACGCGCATGAATGG +ATTAACGAGATTCCCACTGTCCCTGTCTACTATCCAGCGAAACCACAGCCAAGGGAACGG +GCTTGGCAGAATCAGCGGGGAAAGAAGACCCTGTTGAGCTTGACTCTAGTCCGACTTTGT +GAAATGACTTGAGAGGTGTAGGATAAGTGGGAGCCGGAAACGGCAAAAGTGAAATACCAC +TACTTTTAACGTTATTTTACTTATTCCGTGAATCGGAGGCGGGGCACTGCCCCTCTTTTT +GGACCGAAGGCCAGCCTCGGCGGGCCGATCCGGGCGGAAGACATTGTCAGGTGGGGAGTT +TGGCTGGGGCGGCACATCTGTTAAAAGATAACGCAGGTGTCCTAAGATGAGCTCAACGAG +AACAGAAATCTCGTGTGGAACAGAAGGGTAAAAGCTCGTTTGATTCTGATTTCCAGTACG +AATACGAACCGTGAAAGCGTGGCCTAACGATCCTTTAGACCTTCGGAATTTGAAGCTAGA +GGTGTCAGAAAAGTTACCACAGGGATAACTGGCTTGTGGCAGCCAAGCGTTCATAGCGAC +GTTGCTTTTTGATCCTTCGATGTCGGCTCTTCCTATCATTGTGAAGCAGAATTCACCAAG +TGTTGGATTGTTCACCCACCAATAGGGAACGTGAGCTGGGTTTAGACCGTCGTGAGACAG +GTTAGTTTTACCCTACTGATGATAGTGTCGCAATAGTAATTCAACCTAGTACGAGAGGAA +CCGTTGATTCGCACAATTGGTCATCGCGCTTGGTTGAAAAGCCAGTGGCGCGAAGCTACC +GTGCGTCGGATTATGACTGAACGCCTCTAAGTCAGAATCCGGGCTAGAAGCGACGCATGT +GCCCGCCGCCCGTTTGCCGACCCGCAGTAGGGGCCATTCGGCCCCCAAAGGCACGTGTCG +TTGGTGAAGCCCGTGCGGTGGATGAGCCGTGCGGGCCGCCTTGAAGTATAATTCCTACCG +AGCGGCGGGTAGAATCCTTTGCAGACGACTTAAATACGCGACGGGGTATTGTAAGTGGCA +GAGTGGCCTTGCTGCCACGATCCACTGAGATTCAGCCCTGTGTCGCTTCGATTCGTCCCT +CCCCCTTCAACATAAAAAAAATCTTTTTCCCTTCCGATCCCAGAGGTTTCACCTTACAAG +GAGGACCTTGGAACTTACGCTACACATAAGAATAGTGTGTAACGCGATTTACAACTATTA +CTAAGTGGCCGAACAATATGCACAAGTGTATGCCCAAAATTAAAGCAAAGTATCTAAAAA +GTGCACAAGGCTGCCCAATGTTTTCCATATAACTGCACAAGGTGGCGAAAGTGCAAGCCT +GCAGTGCCTATGTTTGTGCCTAAAGCTTCCCAACGACTTGACTTGGCTGCCCATTGATGG +GTAAACATGTGCGAAGAACTTTCCAATGCTGCCCCATGGCTGGGCAAATGCGTGCCAATG +ACTTGCCATGGCTGCCCATTGGTAGGCAATTATGTGGCAACGACTTGCCAATGCAGCCCC +ATGGCTGGGCAATTGTGTGCCATCGACATGCCAATGCAGCCCCATGACAGGGCAATTGTG +TGCCATGGACATGCCAATGCTGCCCCATTGCTGGCCCAATTGTGCCATCGACTTGAGAAA +ATTGGGCCATTGCTGGGCATATTGTGTGCCAACTACTTGACATGTCCGCCCATTGGTAGA +CGATTGTGTGCCATCGATTGCCAAGGCTGGGCAATTATTTGCAGGTTGCCTAGAAAATGT +GTGGCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATCTGAGCCATGGG +TGGGCATTTGTGTGCAAAGACAGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTG +CCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAAT +CTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCTAGAAATTGTGAGCCA +TTGCTGCCCATTGCCGAGAAATTTTGTTCCATTGCCGAGAAAATTGGGCCATGGCTGCCC +ATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAG +GAAATGAGTGCCATTGCCGAGAAATGTGAGCCATGGCTGGGCAATTGCCGAGAAAATTGG +GCCATGGCTGGGCAAATGTGTGCCACGGCTGATCATTGCCCAGACAATGTGAGCCATTGC +CGACGAATTTGAGCCATGGCAGCCCATTGCCCCGAAAAATGAGTGCCATGGCCGAGCATG +TGTTCCAAGGCTGCCCATTGCCGAGAAATATGAGCCATGGCCGGGCAAATGTGTGCCATG +TCTGCCCATTGCCCAGAAATTGTGAGCCATGGCTGCCCCATTGCCGAGAAATCTGAGCCA +TGGCCGGGCAATTGTGAGCCATGGCTGGCCAGTGCCGAGAAATGTGAGCCACGGCTGGAC +AATTGCCGAGAAAATTGGGCCATTGCCCATAAATTTGAGTCATGGCTGGCCATTGCCGAG +AAATGTTGTTCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGACAAATCTGAG +CCATGGCCGGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCT +GCCCATTGCCGAGAACATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCC +GGGCAAATGCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTG +CCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAAT +GTGTGCCATGGCCGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAATTTGAGCCAT +GGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTGCCCA +TTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGGGAGCCATTGCTCAGAAATTTTAGCC +ATGGCTGCCCATTGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCC +CATTGCCGAGAAATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGA +GGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTG +GGCCATGGCTGGGCATTTGTGTGCCTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTG +CCCAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAAT +GCGTGCCATGGCTGCCCATTGCCTAGAAAATGTGAGCCATTGCCCAGAAATTTTAGCCAT +GGCTGCCCATTGCCAAGAAATGTTGTGCCATTGCCTAGAAAATTGGGCCATGGCTTCCCA +TTGCCGAGAAATTTAAGGCATGGCCGGGCAAATGCGTGGCATGGCTGGCCATTGCCGAGG +AAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGG +CCATGGCTGGGCATTTGTGTGCCTAGGCTGATCATTGCCTAGAAATTGTGAGCCATTGCC +CAGAAATTTGAGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCTGGCAAATGC +GTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCCTTGCCCAGAATTTTGAGCCATGG +CTGGCCATTGCCGAGAAATGATGTGCCATTGCCTGGAAATGTGAGCCCTGGCTGGGCAAT +TGCCGAGAAATGTGAGCCATTGCCCAGAAATTTTAGCCATGGCTGGCCATTGCCGAGAAA +TGATGTGCCATTGCCTGGAAATGTGAGCCCTTGCTGGGCAATTGCCCAGAAATTTGAGCC +ATGGCTGCCCATTGCCGAGAAAATTTGTGCCATTGCCGAGAAAATTGGGCCACGGCTGGC +CATTGCCGAGAAATTGTTAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCCG +AGAAAATTGGGCCATGGTTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTG +AACCATGGCTGGGCAGTTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGG +CTGATCATTGCCTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCAT +TGCCGAGAAAATTGGGCCATGGCTGCCCATTGTCGAGAAATTTGAGCCATGGCCGGGCAA +ATGTGTGCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCC +ATTGCCGAGAAATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGA +GAAAATTGGGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGA +ACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCACGGC +TGATCATTGCCTAGAAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATT +GCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAA +TGTGTGCCATTGCCGAGAAATTTGAGCCATGGCCGGGCAAATGTGTGCCATTGCTGCCCA +TGGCCGAGAAATTGTGAGCCATTGCTGCCCATGGCCGAGAAAATTTGTGCCATTGCCGAG +AAAATTGGGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAA +CCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCATTTGTGTGCCAAGGCA +GATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGC +CGAGAAATTTGGGCCATTGCCGGGCAAATGTGTGCCATTGCTGCCCATTGCCGAGAAAAT +TTGTGCCATTGCCGAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATG +GCTGCCCATTGCCGAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAA +TTGCCGAGAAAATTGGGCCATGGTTGGGCATTTGTGTGCCAATGCTGATCATTGCCCAGA +AATTTGAGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGAGAAAATTGGGC +CATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATTTGTGCCATTGCTGC +CCATTGCCGAGAAATTGTGAGCCATTGCTGCCCATTGCCGAGAAATTTTGTGCCATTGCC +GAGAAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCC +GAGGAAATGAGTGCCATTGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAAT +TGGGCCATGGCTGGGCATTTGTGTGCAAATGCTGCCCATTGCCGAGAAATTTGAGCCATG +GCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGCCCATTGCCGAGGAAATGAGTGCCAT +TGCCGAGAAATGTGAACCATGGCTGGGCAATTGCCGAGAAAATTGGGCCATGGCTGGGCA +TTTGTGTGCAAATGCTGATCATTGCCCAGAAATTTGAGCCATGGCTGGCCATTGCCGAGA +AATGTTGTGCCATTGCCGAGAAATTGGGCCATGGCTGCCCATTGCCGAGAAATCTGAGCC +ATGGCCGGGCAAATGTGTGCCATGGCTGGCCATTGCCGAGAAATGTTGTGCCATTGCCGA +GAAAATTGGGCAATGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCCGGGCAAATGTGT +GCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAAGGCT +GCCCATTGCCGAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCATTGC +CGAGAAATTGTGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGCAAAT +GCGTGCCATGGCTGCCCATTGCCGAGAAATTGTGAGCCATTGCCCAGAAAATTGGGCCAA +GGCTGCCCATTGCCGAGAAATTGTGTGCCATTGCCGAGAAAATTAGGCCATGGCTGCCCA +TTGCCGAGAAATTGTGTGCCACGGCTGCCCATTGCCGAGAAATCTGAGCCATGGCTGGGC +AAATGCGTGCCATGGCTGCCCATTGCCTAGAAAATGTGTGCTGTGCCATTGCCCAGAAAA +TGTGTGCCATTGCCCAGAAATTTAAGCCTTGGCTGCCCATTGCTGGGCAATTGTGCGCCA +TCCACACCAAGGCCCAATGGGGTCTTGGTAAAAACAAGCATTTTTTGCGAAATGAGGTTG +CGCGGGGCCCCGCTCGTTGTAAATTGCAATCTCAAGGTGAACAAATGTGAAGGACGAGGC +CCACACACCATGGGCAATCGAGACCCGATCCAAGGGCAAGAAATTTAAATTAAAAGTCGA +CACCCGCGTTAGGTGCATATGCCAAGACCTACGGCGGACACCCCGTGGCTCGACGTAAGC +CGATGAGAATCCTAAGACAAAACCTTCCATTACCCGTTTCCGTTCTCAAAACACGTATCC +ATGCTCAACATCTAAAAAAAAAGTTCCCCCAAGGAACCGTTGCTCCTTTTGAACATCCCC +ATTCAATTCGATATTTTGATAACCAAACTACGTCTTCATTTTTATGCGGCTCAAACCTAT +ATGTAAACTAATCTAAATGTTTATCACTTCACCCGGCCCCTCATTCTCAAAAATTTTTGT +TTTTTCCCTTAATTTTTTTTATTTTCAATTAATTTTTCAAAAAATATCGTATTTTTTTTT +ATGTGTTTCATCTTAAATATGAACTATATATATTATAAACCTCATTAAAAACATTCTCCA +TATTTTTCCATATTTATTACTATTTTTCCCTATTTTTTACTATTTTTTAACTATTTTTTT +GGTAATTAATTAAAATAAATTTTTTCGGATCTCAAAAAATTATAAATTTTTTTCATGTTG +TGCTATTATTTATTATTTTAAGATTTGAATTCAATTTTCATAAAAATAACTTATCCTTTT +TAAAAAAAAACCATTATGACTCCTCAAGCATGGGCAATGTTTCCTCCTGACATTTTCAGA +AAAGCTCATATAGCATATATAAGGGGGGGTGTATGCCCAGGCCTCCCCTTACCCAGCATG +GGTCAAGACTGGGCATGCATGGCCGCGCGCGTTGGTTGGCAATTGGCAAGCATTGCCGCG +CGCATGGGTTTGGCATTTTGGACGCGTGGGTTGGCAATGGAAAGGCATTGTCGCACGTGT +GTCTCGGCAATAGTTAGCCATGGCTCAAATTTCTCGGCAATGGCACCAATTTTCTCGGCA +ATGGCACAAGTTTTCTCGGCAATGGCACATCTTTTCTCGGCAATGACACATATTTTCTAG +GCAATGGTTTGCCAAGGCACACAATTGCCCAGAAAGCGTTGCCGAGCTTTGTTGAGAAGG +CATTGCCGCGTGGGTTGGTTCGCTGTAGGCTTGCATTGATGCTGCGCATGTTGGTGGGAA +ATAGGCAAAGCGTTGCCGAGCGTGTTTGCTGGCAGCACGCAGGCATTGCTGCGCATGTTG +GCTGGAAATAAAGCTTGCATTGCCGAGCTCGTTGGTAGGCAAGGGGCAGGCATGGCCGTG +TGCATGGCTATGTTTGCCAGCTGCGTGTGTTGGCAATGGGCAGGCATTGCTGCACGCTTG +GGTGACCGGGAGGGGTTGCCTTTTGGCTTGTTGTTGGGCATTCTTCGCAAGAGAAAGCTT +GGACAATGGCCATGGGCAGCCAAGTCCAACATTGGTCTATCGATTGATGCATGGGGTGGT +GGGAGGGGATGTTGTGGAGCTTCCTTTGGGCTAGTTGGGCATTCTTTGCAAGGCTTTCTT +GCGCATGCAAGGGCCTAGACAATGCTTCAAGAAGCCATGGGCAGCCCCACCGCTCATCCC +ACTGCCCTCATGCTTAGGTTGACAATGGACAATTGGGATGCGTTGCCATGGTCTAGCAAG +GGTGCTTGCTTGCATGTTCAAGTGTGCAAATGGGTTTGTCAAATGTGGCCGATGTCCTCG +CCATGCTAGAAAATTGTGTGGAATGACTTTGGGCATGCTATTGCTAGCTCATCGTTTGCC +TATGCAACTAGTAGGGTGTGGCGATGTCATGGGCTCGAGGGACATTCCTTAATGCTGGCT +GGGTCATGTTTGTATGCTACTGTTGCTTGACAATGGCGTTGCATCGCTCATGGATGTTGC +ACAACACATTGTGCTCTGTTGGAAAAATGTGAAATCATGTCCCTTGAATTTTCGTGCCTA +TCGGTGCTTTGTTCTGTCTCTTCTCGATGTAATTGCATTATTGTCGGTCAATATTTTGAT +CGATGGGGTGTGATTCAATTGGGGGAGTCGGGGCATAGTGTACGTAGTGGTGCGTGGGTG +GTGTTTGGCCTGTGCGAGTTTGATGTTTCCTTGCTTTGTGCAACGAATTCATCTCGTGCA +TTCCTCTTCAGTTATATCTTCAAGAGTAATAATAATTACTACCTTGAGTGTCCCATGGGT +TCCTGTGTTGTATACCTCTGATGCAATGGAATTTTCTCTGTAAAGACCCTATTTCGCTTT +TGCACCACTCTGTGGTGCAAGTGAACCTCAAAGTATCACTCATGTCCCATGTGTGCCTCG +CATTGAAGTTGCATGCATGGCTCATGGGTGCTTTACTCGTGCTCTCGGATGCGGAAATCT +TTTGAGGGAAATTGGTCTTCTGACCTTTTTACCTGTAAAGCGTTCGACCCTTAATTTGGA +AGACTGTTGTGCTCGTCTTTGACCTATCCGATTGCTCGGCTAGGCTCATGCGGTGCCAAC +GTCGCAAAGGAATGCTACCTGGTTGATCCTGCCAGTAGTCATATGCTTGTCTCAAAGATT +AAGCCATGCATGTGTAAGTATGAACTAATTCAGACTGTGAAACTGCGAATGGCTCATTAA +ATCAGTTATAGTTTGTTTGATGGTATTTGCTACTCGGATAACCGTAGTAATTCTAGAGCT +AATACGTGCAACAAACCCCGACTTCTGGAAGGGATGCATTTATTAGATAAAAGGTCGACG +CGGGCTTTGCCCGTTGCTCTGATGATTCATGATAACTCGACGGATCGCACGGCCTTCGTG +CCGGCGACGCATCATTCAAATTTCTGCCCTATCAACTTTCGATGGTAGGATAGTGGCCTA +CTATGGTGTTAACGGGTGACGGAGAATTAGGGTTCGATTCCGGAGAGGGAGCCTGAGAAA +CGGCTACCACATCCAAGGAAGGCAGCAGGCGCGCAAATTACCCAATCCTGACACGGGGAG +GTAGTGACAATAAATAACAATACCGGGCTCATTGAGTCTGGTAATTGGAATGAGTACAAT +CTAAATCCCTTAACGAGGATCCATTGGAGGGCAAGTCTGGTGCCAGCAGCCGCGGTAATT +CCAGCTCCAATAGCGTATATTTAAGTTGTTGCAGTTAAAAAGCTCGTAGTTGGATTTTGG +GTTGGGCCGACCGGTCCGCCTTCAGGTGTGCACCGGTCGTCTCGTCCCTTCTGCCGGCGA +TGCGCTCCTAGCCTTAACTGGCCGGGTCGTGCCTCCGGCGCTGTTACTTTGAAGAAATTA +GAGTGCTCAAAGCAAGCCTACGCTCTGGATACATTAGCATGGGATAACATCATAGGATTT +CGATCCTATTCTGTTGGCCTTCGGGATCGGAGTAATGATTAACAGGGACAGTCGGGGGCA +TTCGTATTTCATAGTCAGAGGTGAAATTCTTGGATTTATGAAAGACGAACAACTGCGAAA +GCATTTGCCAAGGATGTTTTCATTAATCAAGAACGAAAGTTGGGGGCTCGAAGACGATCA +GATACCGTCCTAGTCTCAACCATAAACGATGCCGACCAGGGATCAGCGGATGTTACTTTT +AGGACTCCGCTGGCACCTTATGAGAAATCAAAGTTTTTGGGTTCCGGGGGGAGTATGGTC +GCAAGGCTGAAACTTAAAGGAATTGACGGAAGGGCACCACCAGGAGTGGAGCCTGCGGCT +TAATTTGACTCAACACGGGGAAACTTACCAGGTCCANNNNNNNNNNNNNNNNNNNNNNNN +NNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN +NNNNNNNNNNNNNNNNTGATTTCTCGGCAATGGGCAGCCATGGCCCAATTTTCTCGGCAA +TGGAACAAAATTTCTCGGCAATGGGCAGCAATGGCTCACAATTTCTAGGCAATGGGCAGC +AATGGCACACATTTGCCCGGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCCCA +ATTTTCTCGGCAATGGCACAACATTTCTCGGCAATGGCCAGCCATGGCTCAAATTTCTGG +GCAATGATCTGTCTTTGCACACAAATGCCCACCCATGGCTCAGATTTCTCGGCAATGGCC +AGCCATGGCTCAAATTTCTGGGCAATGCCACACATTTTCTAGGCAACCTGCAAATAATTG +CCCAGCCTTGGCAATCGATGGCACACAATCGTCTACCAATGGGCGGACATGTCAAGTAGT +TGGCACACAATATGCCCAGCAATGGCCCAATTTTCTCAAGTCGATGGCACAATTGGGCCA +GCAATGGGGCAGCATTGGCATGTCCATGGCACACAATTGCCCTGTCATGGGGCTGCATTG +GCATGTCGATGGCACACAATTGCCCAGCCATGGGGCTGCATTGGCAAGTCGTTGCCACAT +AATTGCCTACCAATGGGCAGCCATGGCAAGTCATTGGCACGCATTTGCCCAGCCATGGGG +CAGCATTGGAAAGTTCTTCGCACATGTTTACCCATCAATGGGCAGCCAAGTCAAGTCGTT +GGGAAGCTTTAGGCACAAACATAGGCACTGCAGGCTTGCACTTTCGCCACCTTGTGCAGT +TATATGGAAAACATTGGGCAGCCTTGTGCACTTTTTAGATACTTTGCTTTAATTTTGGGC +ATACACTTGTGCATATTGTTCGGCCACTTAGTAATAGTTGTAAATCGCGTTACACACTAT +TCTTATGTGTAGCGTAAGTTCCAAGGTCCTCCTTGTAAGGTGAAACCTCTGGGATCGGAA +GGGAAAAAGATTTTTTTTATGTTGAAGGGGGAGGGACGAATCGAAGCGACACAGGGCTGA +ATCTCAGTGGATCGTGGCAGCAAGGCCACTCTGCCACTTACAATACCCCGTCGCGTATTT +AAGTCGTCTGCAAAGGATTCTACCCGCCGCTCGGTAGGAATTATACTTCAAGGCGGCCCG +CACGGCTCATCCACCGCACGGGCTTCACCAACGACACGTGCCTTTGGGGGCCGAATGGCC +CCTACTGCGGGTCGGCAAACGGGCGGCGGGCACATGCGTCGCTTCTAGCCCGGATTCTGA +CTTAGAGGCGTTCAGTCATAATCCGACGCACGGTAGCTTCGCGCCACTGGCTTTTCAACC +AAGCGCGATGACCAATTGTGCGAATCAACGGTTCCTCTCGTACTAGGTTGAATTACTATT +GCGACACTATCATCAGTAGGGTAAAACTAACCTGTCTCACGACGGTCTAAACCCAGCTCA +CGTTCCCTATTGGTGGGTGAACAATCCAACACTTGGTGAATTCTGCTTCACAATGATAGG +AAGAGCCGACATCGAAGGATCAAAAAGCAACGTCGCTATGAACGCTTGGCTGCCACAAGC +CAGTTATCCCTGTGGTAACTTTTCTGACACCTCTAGCTTCAAATTCCGAAGGTCTAAAGG +ATCGTTAGGCCACGCTTTCACGGTTCGTATTCGTACTGGAAATCAGAATCAAACGAGCTT +TTACCCTTCTGTTCCACACGAGATTTCTGTTCTCGTTGAGCTCATCTTAGGACACCTGCG +TTATCTTTTAACAGATGTGCCGCCCCAGCCAAACTCCCCACCTGACAATGTCTTCCGCCC +GGATCGGCCCGCCGAGGCTGGCCTTCGGTCCAAAAAGAGGGGCAGTGCCCCGCCTCCGAT +TCACGGAATAAGTAAAATAACGTTAAAAGTAGTGGTATTTCACTTTTGCCGTTTCCGGCT +CCCACTTATCCTACACCTCTCAAGTCATTTCACAAAGTCGGACTAGAGTCAAGCTCAACA +GGGTCTTCTTTCCCCGCTGATTCTGCCAAGCCCGTTCCCTTGGCTGTGGTTTCGCTGGAT +AGTAGACAGGGACAGTGGGAATCTCGTTAATCCATTCATGCGCGTCACTAATTAGATGAC +GAGGCATTTGGCTACCTTAAGAGAGTCATAGTTACTCCCGCCGTTTACCCGCGCTTGGTT +GAATTTCTTCACTTTGACATTCAGAGCACTGGGCAGAAATCACATTGCGTTAGCATCCGC +AGGGACCATCGCAATGCTTTGTTTTAATTAAACAGTCGGATTCCCCTTGTCCGTACCAGT +TCTGAGTCTGACTGTTCGACGCCCGGGGAAGGCCCCGTGAGGAGCCGTTCCCAGTCCGTC +CCCCGGCCGGCACGCGGTGACCCGCTCTCGCCGCGGGAGCAGCTCGAGCAGTCCACCGAC +AGCCGACGGGTTCGGGACTGGGACCCCCGTGCCCAGCCCTCAGAGCCAATCCTTTTCCCG +AAGTTACGGATCCATTTTGCCGACTTCCCTTGCCTACATTGTTCCATCGACCAGAGGCTG +TTCACCTTGGAGACCTGATGCGGTTATGAGTACGACCGGGCGTGGAAGGCACTCGGTCCT +CCGGATTTTCAAGGGCCGCCGGGGGCGCACCGGACACCACGCGACGTGCGGTGCTCTTCC +AGCCGCTGGACCCTACCTCCGGCTGAGCCGTTTCCAGGGTGGGCAGGCTGTTAAACAGAA +AAGATAACTCTTCCCGAGGCCCCCGCCGACGTCTCCGGACTCCCTAACGTTGCCGTCAGC +CGCCACGTCCCGGTTCAGGAATTTTAACCCGATTCCCTTTCGAAGTTCGCGCTGAACGCG +CTCTCTGTCGGGCTTCCCCCGACTCTTAGGATCGACTAACCCATGTGCAAGTGCCGTTCA +CATGGAACCTTTCCCCTCTTCGGCCTTCAAAGTTCTCATTTGAATATTTGCTACTACCAC +CAAGATCCGCACCAACGGCCGCTCCGCCCGGGCTCACGCCCAAGGTTTTGCAGCGACCGC +TGCGCCCTCCTACTCATCGGGGCCTAGCACTTGCCTCGACGGCCGGGTATAGGTCGCGCG +CTTCAGCGCCATCCATTTTCGGGGCTAGTTGATTCGGCAGGTGAGTTGTTACACACTCCT +TAGCGGATTTTCGACTTCCATGACCACCGTCCTGCTGTCTTAATCGACCAACACCCTTTG +TGGGTTCTAGGTTAGCGCGCAGTTAGGCACCGTAACCCGGCTTCCGGTTCATCCCGCATC +GCCAGTTCTGCTTACCAAAAATGGCCCACTTGGAGCTCTCGATTCCGTGGCGCGGCTCAA +CAAAGCAGCCGCGCCGTCCTACCTATTTAAAGTTTGAGAATAGGTCGAGGGCGTTGCGCC +CCCGATGCCTCTAATCATTGGCTTTACCCGATAGAACTCGCACACGGGCTCCAGCTATCC +TGAGGGAAACTTCGGAGGGAACCAGCTACTAGACGGTTCGATTAGTCTTTCGCCCCTATA +CCCAAGTCAGACGAACGATTTGCACGTCAGTATCGCTGCGGGCCTCCACCAGAGTTTCCT +CTGGCTTCGCCCCGCTCAGGCATAGTTCACCATCTTTCGGGTCCCGACAGGCATGCTCAC +ACTCGAACCCTTCTCAGAAGATCAAGGTCGGTCGGCGGTGCAACCCGCTAGGGGATCCCG +CCAATCAGCTTCCTTACGCCTTACGGGTTTACTCGCCCGTTGACTCGCACACATGTCAGA +CTCCTTGGTCCGTGTTTCAAGACGGGCCGAATGGGGAGCCCGCAGGCCGGTGCCAGGAGC +GCGCAGATGCCGAAGCACGCCAAAGGCGCGCGCTGCCAGCCACGATCGAGGCAAAGGCGT +CTCCACAGGCGTAACAACTGCCCGGGCTTTGGCCTCCGCCCCAATCCGCACCGATCCACG +CCCCGAGTCGATCGGCAGACCGGCTATTAACCGTTCCACATCCGACCGAGGCGCATCGCC +GGCCCCCATCCGCTTCCCTCCCGACAATTTCAAGCACTCTTTGACTCTCTTTTCAAAGTC +CTTTTCATCTTTCCCTCGCGGTACTTGTTTGCTATCGGTCTCTCGCCCATATTTAGCCTT +GGACGGAATTTACCGCCCGATTGGGGCTGCATTCCCAAACAACCCGACTCGTCGACAGCG +CCTCGTGGTGCGACAGGGTCCGGGCACGACGGGGCTCTCACCCTCTCTGGCGCCCCCTTC +CAGGGGACTTGGGCCCGGTCCGCCGCTGAGGACGCTTCTCCAGACTACAATTCGGACAAC +GAGATCGCCCGATTTTCAAGCTGGGCTATTCCCGGTTCGCTCGCCGTTACTAAGGGAATC +CTTGTAAGTTTCTTTTCCTCCGCTTATTGATATGCTTAAACTCAGCGGGTAATCCCGCCT +GACCTGGGGTCGCGATCGAAGCCGTGATAACGGCACATTAGGGTCAAAAGTAAACCATTA +GCAATGGGGGCAAGCACAACAGGACGCAACGGTTTGTCAACCACCACTTGTTGTGACGTC +CATTGCCAAGGACTTCATTTTTAGGCCGACCGTTCACTAATGTGCACGGGGGGCCAATAT +CCGCCCACCCACACCCAATCCTTGGTAAGGCTTGAGTTGGGTGGGCGACACAATGCGTGA +CGCCCAGGCAGACGTGCCCTCGGCCTAATGGCTTCAGGCGCAACTTGCGTTCAAAAACTC +GATGGTTCACGGGATTCTGCAATTCACACCAAGTATCGCATTTCGCTACGTTCTTCATCG +ATGCGAGAGCCGAGATATCCGTTGCCGAGAGTCGTTTCGTTCATGAGAGAGCAAGCACCA +CAAGCACCCAAAAACGGGGCATGGATGTTGCATTCTTGTTCAAGTTCCTTGACGCGTTTC +GCGCCGGGGTTCGTTGTTTGACCGGGGAATGAGAGTGTCACCCATGGGGCAACACGAGCA +CACCCGGCAAAGGGAAGAAAAAGTAGGCTATAAAAACCAAACTTTTGCTTCCCCGATGGT +ATTATACAAGTTCGCGGGTCATTCTGCTAGGCAGGTTTCGACAATGATCCTTCCGCAGGT +TCACCTACGGAAACCTTGTTACGACTTCTCCTTCCTCTAAATGATAAGGTTCAGTGGACT +TCTCGCGACGTCGCCGGCAGCGAACCGCCCACGTCGCCGCGATCCGAACACTTCACCGGA +CCATTCAATCGGTAGGAGCGACGGGCGGTGTGTACAAAGGGCAGGGACGTAGTCAACGCG +AGCTGATGACTCGCGCTTACTAGGAATTCCTCGTTGAAGACCAACAATTGCAATGATCTA +TCCCCATCACGATGAAATTTCAAAGATTACCCGGGCCTGTCGGCCAAGGCTATAAACTCG +TTGAATACATCAGTGTAGCGCGCGTGCGGCCCAGAACATCTAAGGGCATCACAGACCTGT +TATTGCCTCAAACTTCCGTGGCCTGAAGGGCCATAGTCCCTCTAAGAAGCTAGCTGTGGA +GGGTCACCTCCACATAGCTAGTTAGCAGGCTGAGGTCTCGTTCGTTAACGGAATTAACCA +GACAAATCGCTCCACCAACTAAGAACGGCCATGCACCACCACCCATAGAATCAAGAAAGA +GCTCTCAGTCTGTCAATCCTTACTATGTCTGGACCTGGTAAGTTTCCCCGTGTTGAGTCA +AATTAAGCCGCAGGCTCCACTCCTGGTGGTGCCCTTCCGTCAATTCCTTTAAGTTTCAGC +CTTGCGACCATACTCCCCCCGGAACCCAAAAACTTTGATTTCTCATAAGGTGCCAGCGGA +GTCCTAAAAGTAACATCCGCTGATCCCTGGTCGGCATCGTTTATGGTTGAGACTAGGACG +GTATCTGATCGTCTTCGAGCCCCCAACTTTCGTTCTTGATTAATGAAAACATCCTTGGCA +AATGCTTTCGCAGTTGTTCGTCTTTCATAAATCCAAGAATTTCACCTCTGACTATGAAAT +ACGAATGCCCCCGACTGTCCCTGTTAATCATTACTCCGATCCCGAAGGCCAACAGAATAG +GATCGAAATCCTATGATGTTATCCCATGCTAATGTATCCAGAGCGTAGGCTTGCTTTGAG +CACTCTAATTTCTTCAAAGTAACAGCGCCGGAGGCACGACCCGGCCAGTTAAGGCTAGGA +GCGCATCGCCGGCAGAAGGGACGAGACGACCGGTGCACACCTGAAGGCGGACCGGTCGGC +CCAACCCAAAATCCAACTACGAGCTTTTTAACTGCAACAACTTAAATATACGCTATTGGA +GCTGGAATTACCGCGGCTGCTGGCACCAGACTTGCCCTCCAATGGATCCTCGTTAAGGGA +TTTAGATTGTACTCATTCCAATTACCAGACTCAATGAGCCCGGTATTGTTATTTATTGTC +ACTACCTCCCCGTGTCAGGATTGGGTAATTTGCGCGCCTGCTGCCTTCCTTGGATGTGGT +AGCCGTTTCTCAGGCTCCCTCTCCGGAATCGAACCCTAATTCTCCGTCACCCGTTAACAC +CATAGTAGGCCACTATCCTACCATCGAAAGTTGATAGGGCAGAAATTTGAATGATGCGTC +GCCGGCACGAAGGCCGTGCGATCCGTCGAGTTATCATGAATCATCAGAGCAACGGGCAAA +GCCCGCGTCGACCTTTTATCTAATAAATGCATCCCTTCCAGAAGTCGGGGTTTGTTGCAC +GTATTAGCTCTAGAATTACTACGGTTATCCGAGTAGCAAATACCATCAAACAAACTATAA +CTGATTTAATGAGCCATTCGCAGTTTCACAGTCTGAATTAGTTCATACTTACACATGCAT +GGCTTAATCTTTGAGACAAGCATATGACTACTGGCAGGATCAACCAGGTAGCATTCCTTT +GCGACGTTGGCACCGCATGAGCCTAGCCGAGCAATCGGATAGGTCAAAGACGAGCACAAC +AGTCTTCCAAATTAAGGGTCGAACGCTTTACAGGTAAAAAGGTCAGAAGACCAATTTCCC +TCAAAAGATTTCCGCATCCGAGAGCACGAGTAAAGCACCCATGAGCCATGCATGCAACTT +CAATGCGAGGCACACATGGGACATGAGTGATACTTTGAGGTTCACTTGCACCACAGAGTG +GTGCAAAAGCGAAATAGGGTCTTTACAGAGAAAATTCCATTGCATCAGAGGTATACAACA +CAGGAACCCATGGGACACTCAAGGTAGTAATTATTATTACTCTTGAAGATATAACTGAAG +AGGAATGCACGAGATGAATTCGTTGCACAAAGCAAGGAAACATCAAACTCGCACAGGCCA +AACACCACCCACGCACCACTACGTACACTATGCCCCGACTCCCCCAATTGAATCACACCC +CATCGATCAAAATATTGACCGACAATAATGCAATTACATCGAGAAGAGACAGAACAAAGC +ACCGATAGGCACGAAAATTCAAGGGACATGATTTCACATTTTTCCAACAGAGCACAATGT +GTTGTGCAACATCCATGAGCGATGCAACGCCATTGTCAAGCAACAGTAGCATACAAACAT +GACCCAGCCAGCATTAAGGAATGTCCCTCGAGCCCATGACATCGCCACACCCTACTAGTT +GCATAGGCAAACGATGAGCTAGCAATAGCATGCCCAAAGTCATTCCACACAATTTTCTAG +CATGGCGAGGACATCGGCCACATTTGACAAACCCATTTGCACACTTGAACATGCAAGCAA +GCACCCTTGCTAGACCATGGCAACGCATCCCAATTGTCCATTGTCAACCTAAGCATGAGG +GCAGTGGGATGAGCGGTGGGGCTGCCCATGGCTTCTTGAAGCATTGTCTAGGCCCTTGCA +TGCGCAAGAAAGCCTTGCAAAGAATGCCCAACTAGCCCAAAGGAAGCTCCACAACATCCC +CTCCCACCACCCCATGCATCAATCGATAGACCAATGTTGGACTTGGCTGCCCATGGCCAT +TGTCCAAGCTTTCTCTTGCGAAGAATGCCCAACAACAAGCCAAAAGGCAACCCCTCCCGG +TCACCCAAGCGTGCAGCAATGCCTGCCCATTGCCAACACACGCAGCTGGCAAACATAGCC +ATGCACACGGCCATGCCTGCCCCTTGCCTACCAACGAGCTCGGCAATGCAAGCTTTATTT +CCAGCCAACATGCGCAGCAATGCCTGCGTGCTGCCAGCAAACACGCTCGGCAACGCTTTG +CCTATTTCCCACCAACATGCGCAGCATCAATGCAAGCCTACAGCGAACCAACCCACGCGG +CAATGCCTTCTCAACAAAGCTCGGCAACGCTTTCTGGGCAATTGTGTGCCTTGGCAAACC +ATTGCCTAGAAAATATGTGTCATTGCCGAGAAAAGATGTGCCATTGCCGAGAAAACTTGT +GCCATTGCCGAGAAAATTGGTGCCATTGCCGAGAAATTTGAGCCATGGCTAACTATTGCC +GAGACACACGTGCGACAATGCCTTTCCATTGCCAACCCACGCGTCCAAAATGCCAAACCC +ATGCGCGCGGCAATGCTTGCCAATTGCCAACCAACGCGCGCGGCCATGCATGCCCAGTCT +TGACCCATGCTGGGTAAGGGGAGGCCTGGGCATACACCCCCCCTTATATATGCTATATGA +GCTTTTCTGAAAATGTCAGGAGGAAACATTGCCCATGCTTGAGGAGTCATAATGGTTTTT +TTTTAAAAAGGATAAGTTATTTTTATGAAAATTGAATTCAAATCTTAAAATAATAAATAA +TAGCACAACATGAAAAAAATTTATAATTTTTTGAGATCCGAAAAAATTTATTTTAATTAA +TTACCAAAAAAATAGTTAAAAAATAGTAAAAAATAGGGAAAAATAGTAATAAATATGGAA +AAATATGGAGAATGTTTTTAATGAGGTTTATAATATATATAGTTCATATTTAAGATGAAA +CACATAAAAAAAAATACGATATTTTTTGAAAAATTAATTGAAAATAAAAAAAATTAAGGG +AAAAAACAAAAATTTTTGAGAATGAGGGGCCGGGTGAAGTGATAAACATTTAGATTAGTT +TACATATAGGTTTGAGCCGCATAAAAATGAAGACGTAGTTTGGTTATCAAAATATCGAAT +TGAATGGGGATGTTCAAAAGGAGCAACGGTTCCTTGGGGGAACTTTTTTTTTAGATGTTG +AGCATGGATACGTGTTTTGAGAACGGAAACGGGTAATGGAAGGTTTTGTCTTAGGATTCT +CATCGGCTTACGTCGAGCCACGGGGTGTCCGCCGTAGGTCTTGGCATATGCACCTAACGC +GGGTGTCGACTTTTAATTTAAATTTCTTGCCCTTGGATCGGGTCTCGATTGCCCATGGTG +TGTGGGCCTCGTCCTTCACATTTGTTCACCTTGAGATTGCAATTTACAACGAGCGGGGCC +CCGCGCAACCTCATTTCGCAAAAAATGCTTGTTTTTACCAAGACCCCATTGGGCCTTGGT +GTGGATGGCGCACAATTGCCCAGCAATGGGCAGCCAAGGCTTAAATTTCTGGGCAATGGC +ACACATTTTCTGGGCAATGGCACAGCACACATTTTCTAGGCAATGGGCAGCCATGGCACG +CATTTGCCCAGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCGTGGCACACAATTTCTC +GGCAATGGGCAGCCATGGCCTAATTTTCTCGGCAATGGCACACAATTTCTCGGCAATGGG +CAGCCTTGGCCCAATTTTCTGGGCAATGGCTCACAATTTCTCGGCAATGGGCAGCCATGG +CACGCATTTGCCCAGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCGTGGCACACAATT +TCTCGGCAATGGGCAGCCATGGCCTAATTTTCTCGGCAATGGCACACAATTTCTCGGCAA +TGGGCAGCCTTGGCCCAATTTTCTGGGCAATGGCTCACAATTTCTCGGCAATGGGCAGCC +ATGGCACACATTTGCCCGGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATTGCCCAA +TTTTCTCGGCAATGGCACAACATTTCTCGGCAATGGCCAGCCATGGCACACATTTGCCCG +GCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCCCAATTTCTCGGCAATGGCACA +ACATTTCTCGGCAATGGCCAGCCATGGCTCAAATTTCTGGGCAATGATCAGCATTTGCAC +ACAAATGCCCAGCCATGGCCCAATTTTCTCGGCAATTGCCCAGCCATGGTTCACATTTCT +CGGCAATGGCACTCATTTCCTCGGCAATGGGCAGCCATGGCTCAGATTTCTCGGCAATGG +GCAGCCATGGCTCAAATTTCTCGGCAATGGGCAGCATTTGCACACAAATGCCCAGCCATG +GCCCAATTTTCTCGGCAATTGCCCAGCCATGGTTCACATTTCTCGGCAATGGCACTCATT +TCCTCGGCAATGGGCAGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCCCAATT +TTCTCGGCAATGGCACAAAATTTCTCGGCAATGGGCAGCAATGGCTCACAATTTCTCGGC +AATGGGCAGCAATGGCACAAATTTGCCCGGCCATGGCTCAGATTTCTCGGCAATGGGCAG +CCATGGCCCAATTTTCTCGGCAATGGCACAACATTTCTCGGCAATGGCCAGCCATGGCTC +AAATTTCTGGGCAATGATCAGCATTGGCACACAAATGCCCAACCATGGCCCAATTTTCTC +GGCAATTGCCCAGCCATGGTTCACATTTCTCGGCAATGGCACTCATTTCCTCGGCAATGG +GCAGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCCCAATTTTCTCGGCAATGG +CACAAATTTTCTCGGCAATGGGCAGCAATGGCACACATTTGCCCGGCAATGGCCCAAATT +TCTCGGCAATGGCACAACATTTCTCGGCAATGGCCAGCCATGGCTCAAATTTCTGGGCAA +TGATCTGCCTTGGCACACAAATGCCCAGCCATGGCCCAATTTTCTCGGCAATTGCCCAGC +CATGGTTCACATTTCTCGGCAATGGCACTCATTTCCTCGGCAATGGGCAGCCATGGCCCA +ATTTTCTCGGCAATGGCACAAATTTTCTCGGCCATGGGCAGCAATGGCTCACAATTTCTC +GGCCATGGGCAGCAATGGCACACATTTGCCCGGCCATGGCTCAAATTTCTCGGCAATGGC +ACACATTTGCCCGGCCATGGCTCAAATTTCTCGGCAATGGGCAGCCATGGCCCAATTTTC +TCGGCAATGGCACAACATTTCTCGGCAATGGCCAGCCATGGCTCAAATTTTCTAGGCAAT +GATCAGCCGTGGCACACAAATGCCCAGCCATGGCCCAATTTTCTCGGCAATTGCCCAGCC +ATGGTTCACATTTCTCGGCAATGGCACTCATTTCCTCGGCAATGGGCAGCCATGGCCCAA +TTTTCTCGGCAATGGCACAAATTTTCTCGGCCATGGGCAGCAATGGCTCACAATTTCTCG +GCAATGGGCAGCAATGGCACACATTTGCCCGGCCATGGCTCAAATTTCTCGGCAATGGCA +CACATTTGCCCGGCCATGGCTCAAATTTCTCGACAATGGGCAGCCATGGCCCAATTTTCT +CGGCAATGGCACAACATTTCTCGGCAATGGCCAGCCATGGCTCAAATTTTCTAGGCAATG +ATCAGCCGTGGCACACAAATGCCCAGCCATGGCCCAATTTTCTCGGCAACTGCCCAGCCA +TGGTTCACATTTCTCGGCAATGGCACTCATTTCCTCGGCAATGGGCAACCATGGCCCAAT +TTTCTCGGCAATGGCACAAAATTTCTCGGCAATGGGCAGCAATGGCTAACAATTTCTCGG +CAATGGCCAGCCGTGGCCCAATTTTCTCGGCAATGGCACAAATTTTCTCGGCAATGGGCA +GCCATGGCTCAAATTTCTGGGCAATTGCCCAGCAAGGGCTCACATTTCCAGGCAATGGCA +CATCATTTCTCGGCAATGGCCAGCCATGGCTAAAATTTCTGGGCAATGGCTCACATTTCT +CGGCAATTGCCCAGCCAGGGCTCACATTTCCAGGCAATGGCACATCATTTCTCGGCAATG +GCCAGCCATGGCTCAAAATTCTGGGCAAGGGCTCACAATTTCTCGGCAATGGGCAGCCAT +GGCACGCATTTGCCAGGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCTCAAAT +TTCTGGGCAATGGCTCACAATTTCTAGGCAATGATCAGCCTAGGCACACAAATGCCCAGC +CATGGCCCAATTTTCTCGGCAATTGCCCAGCCATGGTTCACATTTCTCGGCAATGGCACT +CATTTCCTCGGCAATGGCCAGCCATGCCACGCATTTGCCCGGCCATGCCTTAAATTTCTC +GGCAATGGGAAGCCATGGCCCAATTTTCTAGGCAATGGCACAACATTTCTTGGCAATGGG +CAGCCATGGCTAAAATTTCTGGGCAATGGCTCACATTTTCTAGGCAATGGGCAGCCATGG +CACGCATTTGCCCGGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCTCAAATTT +CTGGGCAATGGCTCACAATTTCTAGGCAATGATCAGCCTAGGCACACAAATGCCCAGCCA +TGGCCCAATTTTCTCGGCAATTGCCCAGCCATGGTTCACATTTCTCGGCAATGGCACTCA +TTTCCTCGGCAATGGCCAGCCATGCCACGCATTTGCCCGGCCATGCCTTAAATTTCTCGG +CAATGGGAAGCCATGGCCCAATTTTCTAGGCAATGGCACAACATTTCTTGGCAATGGGCA +GCCATGGCTAAAATTTCTGAGCAATGGCTCCCATTTGCCCGGCCATGGCTCAGATTTCTC +GGCAATGGGCAGCCATGGCCCAATTTTCTAGGCAATGGCACAAAATTTCTCGGCAATGGG +CAGCCATGGCTCAAATTTCTGGGCAATGGCTCACAATTTCTCGGCAATGGGCGGCCATGG +CACACATTTGCCCAGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCCCAATTTT +CTCGGCAATGGGCAGCAATGGCTCACAATTTCTCGGCAATGGGCAGCCATGGCACGCATT +TGCCCGGCCATGGCTCAGATTTCTCGGCAATGGGCAGCCATGGCCCAATGTTCTCGGCAA +TGGGCAGCAATGGCTCACAATTTCTCGGCAATGGGCAGCCATGGCACGCATTTGCCCGGC +CATGGCTCAGATTTGTCGGCAATGGGCAGCCATGGCCCAATTTTCTCGGCAATGGAACAA +CATTTCTCGGCAATGGCCAGCCATGACTCAAATTTATGGGCAATGGCCCAATTTTCTCGG +CAATTGTCCAGCCGTGGCTCACATTTCTCGGCACTGGCCAGCCATGGCTCACAATTGCCC +GGCCATGGCTCAGATTTCTCGGCAATGGGGCAGCCATGGCTCACAATTTCTGGGCAATGG +GCAGACATGGCACACATTTGCCCGGCCATGGCTCATATTTCTCGGCAATGGGCAGCCTTG +GAACACATGCTCGGCCATGGCACTCATTTTTCGGGGCAATGGGCTGCCATGGCTCAAATT +CGTCGGCAATGGCTCACATTGTCTGGGCAATGATCAGCCGTGGCACACATTTGCCCAGCC +ATGGCCCAATTTTCTCGGCAATTGCCCAGCCATGGCTCACATTTCTCGGCAATGGCACTC +ATTTCCTCGGCAATGGGCAGCCATGGCACGCATTTGCCCGGCCATGGCTCAGATTTCTCG +GCAATGGGCAGCCATGGCCCAATTTTCTCGGCAATGGAACAAAATTTCTCGGCAATGGGC +AGCAATGGCTCACAATTTCTAGGCAATGGGCAGCAATGGCACACATTTGCCCGGCCATGG +CTCAGATTTCTCGGCAATGGGCAGCCATGGCCCAATTTTCTCGGCAATGGCACAACATTT +CTCGGCAATGGCCAGCCATGGCTCAAATTTCTGGGCAATGATCTGTCTTTGCACACAAAT +GCCCACCCATGGCTCAGATTTCTCGGCAATGGCCAGCCATGGCTCAAATTTCTGGGCAAT +GCCACACATTTTCTAGGCAACCTGCAAATAATTGCCCAGCCTTGGCAATCGATGGCACAC +AATCGTCTACCAATGGGCGGACATGTCAAGTAGTTGGCACACAATATGCCCAGCAATGGC +CCAATTTTCTCAAGTCGATGGCACAATTGGGCCAGCAATGGGGCAGCATTGGCATGTCCA +TGGCACACAATTGCCCTGTCATGGGGCTGCATTGGCATGTCGATGGCACACAATTGCCCA +GCCATGGGGCTGCATTGGCAAGTCGTTGCCACATAATTGCCTACCAATGGGCAGCCATGG +CAAGTCATTGGCACGCATTTGCCCAGCCATGGGGCAGCATTGGAAAGTTCTTCGCACATG +TTTACCCATCAATGGGCAGCCAAGTCAAGTCGTTGGGAAGCTTTAGGCACAAACATAGGC +ACTGCAGGCTTGCACTTTCGCCACCTTGTGCAGTTATATGGAAAACATTGGGCAGCCTTG +TGCACTTTTTAGATACTTTGCTTTAATTTTGGGCATACACTTGTGCATATTGTTCGGCCA +CTTAGTAATAGTTGTAAATCGCGTTACACACTATTCTTATGTGTAGCGTAAGTTCCAAGG +TCCTCCTTGTAAGGTGAAACCTCTGGGATCGGAAGGGAAAAAGATTTTTTTTATGTTGAA +GGGGGAGGGACGAATCGAAGCGACACAGGGCTGAATCTCAGTGGATCGTGGCAGCAAGGC +CACTCTGCCACTTACAATACCCCGTCGCGTATTTAAGTCGTCTGCAAAGGATTCTACCCG +CCGCTCGGTAGGAATTATACTTCAAGGCGGCCCGCACGGCTCATCCACCGCACGGGCTTC +ACCAACGACACGTGCCTTTGGGGGCCGAATGGCCCCTACTGCGGGTCGGCAAACGGGCGG +CGGGCACATGCGTCGCTTCTAGCCCGGATTCTGACTTAGAGGCGTTCAGTCATAATCCGA +CGCACGGTAGCTTCGCGCCACTGGCTTTTCAACCAAGCGCGATGACCAATTGTGCGAATC +AACGGTTCCTCTCGTACTAGGTTGAATTACTATTGCGACACTATCATCAGTAGGGTAAAA +CTAACCTGTCTCACGACGGTCTAAACCCAGCTCACGTTCCCTATTGGTGGGTGAACAATC +CAACACTTGGTGAATTCTGCTTCACAATGATAGGAAGAGCCGACATCGAAGGATCAAAAA +GCAACGTCGCTATGAACGCTTGGCTGCCACAAGCCAGTTATCCCTGTGGTAACTTTTCTG +ACACCTCTAGCTTCAAATTCCGAAGGTCTAAAGGATCGTTAGGCCACGCTTTCACGGTTC +GTATTCGTACTGGAAATCAGAATCAAACGAGCTTTTACCCTTCTGTTCCACACGAGATTT +CTGTTCTCGTTGAGCTCATCTTAGGACACCTGCGTTATCTTTTAACAGATGTGCCGCCCC +AGCCAAACTCCCCACCTGACAATGTCTTCCGCCCGGATCGGCCCGCCGAGGCTGGCCTTC +GGTCCAAAAAGAGGGGCAGTGCCCCGCCTCCGATTCACGGAATAAGTAAAATAACGTTAA +AAGTAGTGGTATTTCACTTTTGCCGTTTCCGGCTCCCACTTATCCTACACCTCTCAAGTC +ATTTCACAAAGTCGGACTAGAGTCAAGCTCAACAGGGTCTTCTTTCCCCGCTGATTCTGC +CAAGCCCGTTCCCTTGGCTGTGGTTTCGCTGGATAGTAGACAGGGACAGTGGGAATCTCG +TTAATCCATTCATGCGCGTCACTAATTAGATGACGAGGCATTTGGCTACCTTAAGAGAGT +CATAGTTACTCCCGCCGTTTACCCGCGCTTGGTTGAATTTCTTCACTTTGACATTCAGAG +CACTGGGCAGAAATCACATTGCATTAGCATCCGCAGGGACCATCGCAATGCTTTGTTTTA +ATTAAACAGTCGGATTCCCCTTGTCCGTACCAGTTCTGAGTCTGACTGTTCGACGCCCGG +GGAAGGCCCCGTGAGGAGCCGTTCCCAGTCCGTCCCCCGGCCGGCACGCGGTGACCCGCT +CTCGCCGCGGGAGCAGCTCGAGCAGTCCACCGACAGCCGACGGGTTCGGGACTGGGACCC +CCGTGCCCAGCCCTCAGAGCCAATCCTTTTCCCGAAGTTACGGATCCATTTTGCCGACTT +CCCTTGCCTACATTGTTCCATCGACCAGAGGCTGTTCACCTTGGAGACCTGATGCGGTTA +TGAGTACGACCGGGCGTGGAAGGCACTCGGTCCTCCGGATTTTCAAGGGCCGCCGGGGGC +GCACCGGACACCACGCGACGTGCGGTGCTCTTCCAGCCGCTGGACCCTACCTCCGGCTGA +GCCGTTTCCAGGGTGGGCAGGCTGTTAAACAGAAAAGATAACTCTTCCCGAGGCCCCCGC +CGACGTCTCCGGACTCCCTAACGTTGCCGTCAGCCGCCACGTCCCGGTTCAGGAATTTTA +ACCCGATTCCCTTTCGAAGTTCGCGCTGAACGCGCTCTCTGTCGGGCTTCCCCCGACTCT +TAGGATCGACTAACCCATGTGCAAGTGCCGTTCACATGGAACCTTTCCCCTCTTCGGCCT +TCAAAGTTCTCATTTGAATATTTGCTACTACCACCAAGATCCGCACCAACGGCCGCTCCG +CCCGGGCTCACGCCCAAGGTTTTGCAGCGACCGCTGCGCCCTCCTACTCATCGGGGCCTA +GCACTTGCCTCGACGGCCGGGTATAGGTCGCGCGCTTCAGCGCCATCCATTTTCGGGGCT +AGTTGATTCGGCAGGTGAGTTGTTACACACTCCTTAGCGGATTTCGACTTCCATGACCAC +CGTCCTGCTGTCTTAATCGACCAACACCCTTTGTGGGTTCTAGGTTAGCGCGCAGTTAGG +CACCGTAACCCGGCTTCCGGTTCATCCCGCATCGCCAGTTCTGCTTACCAAAAATGGCCC +ACTTGGAGCTCTCGATTCCGTGGCGCGGCTCAACAAAGCAGCCGCGCCGTCCTACCTATT +TAAAGTTTGAGAATAGGTCGAGGGCGTTGCGCCCCCGATGCCTCTAATCATTGGCTTTAC +CCGATAGAACTCGCACACGGGCTCCAGCTATCCTGAGGGAAACTTCGGAGGGAACCAGCT +ACTAGACGGTTCGATTAGTCTTTCGCCCCTATACCCAAGTCAGACGAACGATTTGCACGT +CAGTATCGCTGCGGGCCTCCACCAGAGTTTCCTCTGGCTTCGCCCCGCTCAGGCATAGTT +CACCATCTTTCGGGTCCCGACAGGCATGCTCACACTCGAACCCTTCTCAGAAGATCAAGG +TCGGTCGGCGGTGCAACCCGCTAGGGGATCCCGCCAATCAGCTTCCTTACGCCTTACGGG +TTTACTCGCCCGTTGACTCGCACACATGTCAGACTCCTTGGTCCGTGTTTCAAGACGGGC +CGAATGGGGAGCCCGCAGGCCGGTGCCAGGAGCGCGCAGATGCCGAAGCACGCCAAAGGC +GCGCGCTGCCAGCCACGATCGAGGCAAAGGCGTCTCCACAGGCGTAACAACTGCCCGGGC diff --git a/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.gff b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.gff new file mode 100644 index 0000000..a50f37b --- /dev/null +++ b/subworkflows/local/tests/gxf_fasta_agat_spaddintrons_spextractsequences/testdata/scaffold_4.gff @@ -0,0 +1,17 @@ +##gff-version 3 +scaffold_4 AGAT gene 1766 5584 . + . ID=gene28773;description=Hypothetical protein | no eggnog hit +scaffold_4 Liftoff mRNA 1766 5584 . + . ID=gene28773.t1;Parent=gene28773;description=Hypothetical protein | no eggnog hit +scaffold_4 Liftoff exon 1766 4966 . + . ID=gene28773.t1.exon1;Parent=gene28773.t1 +scaffold_4 Liftoff exon 4968 5584 . + . ID=gene28773.t1.exon2;Parent=gene28773.t1 +scaffold_4 Liftoff CDS 2667 2951 . + 0 ID=gene28773.t1.cds1;Parent=gene28773.t1 +scaffold_4 AGAT five_prime_UTR 1766 2666 . + . ID=agat-five_prime_utr-1269;Parent=gene28773.t1 +scaffold_4 Liftoff intron 4967 4967 . + . ID=intron_added-90678;Parent=gene28773.t1 +scaffold_4 AGAT three_prime_UTR 2952 4966 . + . ID=agat-three_prime_utr-854;Parent=gene28773.t1 +scaffold_4 AGAT three_prime_UTR 4968 5584 . + . ID=agat-three_prime_utr-855;Parent=gene28773.t1 +scaffold_4 AUGUSTUS gene 90203 91055 . - . ID=gene28774;description=F-box kelch-repeat protein +scaffold_4 AUGUSTUS mRNA 90203 91055 0.53 - . ID=gene28774.t1;Parent=gene28774;description=F-box kelch-repeat protein +scaffold_4 AUGUSTUS exon 90203 90819 . - . ID=gene28774.t1.exon1;Parent=gene28774.t1 +scaffold_4 AUGUSTUS exon 90887 91055 . - . ID=gene28774.t1.exon2;Parent=gene28774.t1 +scaffold_4 AUGUSTUS CDS 90203 90819 . - 2 ID=gene28774.t1.cds1;Parent=gene28774.t1 +scaffold_4 AUGUSTUS CDS 90887 91055 . - 0 ID=gene28774.t1.cds2;Parent=gene28774.t1 +scaffold_4 AUGUSTUS intron 90820 90886 . - . ID=intron_added-90679;Parent=gene28774.t1