From 429ec1481257a796e8831c1a7ccea420c9123a03 Mon Sep 17 00:00:00 2001 From: percyfal Date: Tue, 19 Dec 2023 08:55:32 +0000 Subject: [PATCH] =?UTF-8?q?Deploying=20to=20gh-pages=20from=20@=20NBISwede?= =?UTF-8?q?n/genecovr@c5fcd375a416c771b0cc7fe93355313d31ee66c8=20?= =?UTF-8?q?=F0=9F=9A=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- articles/genecovr.html | 37 ++++++----- ...gbc-plot-depth-by-breadth-by-contigs-1.png | Bin 42805 -> 43453 bytes index.html | 62 ++++++++++++++++-- pkgdown.yml | 2 +- reference/readPsl.html | 2 +- search.json | 2 +- 6 files changed, 77 insertions(+), 28 deletions(-) diff --git a/articles/genecovr.html b/articles/genecovr.html index f6bfb40..1c54ae3 100644 --- a/articles/genecovr.html +++ b/articles/genecovr.html @@ -106,14 +106,14 @@

On object repr

genecovr has functionality to read pairwise sequence alignment files and converts the pairwise alignments to -AlignmentPairs objects. An AlignmentPairs -object is a subclass of the Bioconductor class -S4Vectors::Pairs. A Pairs object in turn +genecovr::AlignmentPairs objects. An +AlignmentPairs object is a subclass of the Bioconductor +class S4Vectors::Pairs. A Pairs object in turn aligns two vectors along slot names first and second, and the AlignmentPairs object adds slots for the query and subject, and possibly extra slots related to additional information in the alignment file. The query and subject are -GRanges objects or objects derived from the +GenomicRanges::GRanges objects or objects derived from the GRangesclass.

@@ -127,10 +127,11 @@

Analysing gene body coverageGenomeInfoDb::Seqinfo objects that can be used to set +sequence information on the parsed output. We load the fasta indices and +parse the psl files with genecovr::readPsl, storing the +results in an genecovr::AlignmentPairsList for +convenience.

 assembly_fai_fn <- list(
   nonpol = system.file("extdata", "nonpolished.fai",
@@ -186,7 +187,7 @@ 

Plot ratio matches to

Plot summary indel and match distributions

We can also select multiple columns to plot in the -AlignmentPairsList.

+genecovr::AlignmentPairsList.

 cnames <- c("misMatches", "query.NumInsert", "query.BaseInsert")
 plot(apl, aes(x = id, y = get_expr(enquo(cnames))), which = "violin") +
@@ -204,10 +205,10 @@ 

Plot summary indel and match

Plot number of indels

-

The function insertionSummary summarizes the number of -insertions, either at the transcript level (default) or per alignment. -The intuition is that as assembly quality improves, the number of indels -go down.

+

The function genecovr::insertionSummary summarizes the +number of insertions, either at the transcript level (default) or per +alignment. The intuition is that as assembly quality improves, the +number of indels go down.

First we show a plot with the number of insertions per alignment. A consequence of this is that as a transcript may be split in multiple alignments, the bars are of unequal height.

@@ -232,15 +233,15 @@

Plot number of indels

Gene body coverage

-

The function geneBodyCoverage takes an +

The function genecovr::geneBodyCoverage takes an AlignmentPairs object and summarizes breadth of coverage and number of subject hits per transcript.

 gbc <- lapply(apl, geneBodyCoverage, min.match = 0.1)

A summary can be obtained with the -summarizeGeneBodyCoverage function. We define a range of -minimum match hit cutoffs to filter out hits with too few matches in the -aligned region.

+genecovr::summarizeGeneBodyCoverage function. We define a +range of minimum match hit cutoffs to filter out hits with too few +matches in the aligned region.

 min.match <- c(0.25, 0.5, 0.75, 0.9)
 names(min.match) <- min.match
@@ -273,7 +274,7 @@ 

Number of contigs per transcript

A fragmented assembly will lead to more transcripts mapping to several contigs. We calculate the number of subjects by coverage cutoff -with the function countSubjectsByCoverage

+with the function
genecovr::countSubjectsByCoverage

 data <- dplyr::bind_rows(
   lapply(
diff --git a/articles/genecovr_files/figure-html/gbc-plot-depth-by-breadth-by-contigs-1.png b/articles/genecovr_files/figure-html/gbc-plot-depth-by-breadth-by-contigs-1.png
index 5edb7d0fc1b6429ee4e1ba62b612b23d37f5c84e..8e57022fd666579781375ed73263357a3e8ac148 100644
GIT binary patch
literal 43453
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 z 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

  • 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 T()d|~V1TrQym+yw;j8}zM0S1d diff --git a/index.html b/index.html index 286b133..02a2162 100644 --- a/index.html +++ b/index.html @@ -61,18 +61,22 @@
  • -

    Perform gene body coverage analyses in R to evaluate genome assembly quality.

    +

    genecovr is an R package that provides plotting functions that summarize gene transcript to genome alignments. The main purpose is to assess the effect of polishing and scaffolding operations has on the quality of a genome assembly. The gene transcript set is a large sequence set consisting of assembled transcripts from RNA-seq data generated in relation to a genome assembly project. Therefore, genecovr serves as a complement to software such as BUSCO, which evaluates genome assembly quality using a smaller set of well-defined single-copy orthologs.

    Installation

    You can install the released version of genecovr from NBIS GitHub with:

    -# install.packages("devtools")
    +# If necessary, uncomment to install devtools
    +# install.packages("devtools")
     devtools::install_github("NBISweden/genecovr")
    -

    Quick usage +

    Usage

    +
    +

    genecovr script quick start +

    There is a helper script for generating basic plots located in PACKAGE_DIR/bin/genecovr. Create a data input csv-delimited file with columns

    1. data label
    2. @@ -82,11 +86,55 @@

      Quick usagePACKAGE_DIR/bin/genecovr indata.csv

    +
    +

    Example +

    +

    There are example files located in PACKAGE_DIR/inst/extdata consisting of two psl alignment files containing gmap alignments and fasta indices for the transcript sequences and two for different assembly versions:

    +
      +
    • nonpolished.fai - fasta index for raw assembly
    • +
    • polished.fai - fasta index for polished assembly
    • +
    • transcripts.fai - fasta index for transcript sequences
    • +
    • transcripts2nonpolished.psl - gmap alignments, transcripts to raw assembly
    • +
    • transcripts2polished.psl - gmap alignments, transcripts to polished assembly
    • +
    +

    Using these files and the labels non and pol for the different assemblies, a genecovr input file (called e.g., assemblies.csv) would look as follows:

    +
    nonpol,transcripts2nonpolished.psl,nonpolished.fai,transcripts.fai
    +pol,transcripts2polished.psl,polished.fai,transcripts.fai
    +

    and the command to run would be:

    +
    genecovr assemblies.csv
    +
    +
    +

    genecovr options +

    +

    To list genecovr script options, type ’genecovr -h`:

    +
    usage: genecovr [-h] [-v] [-p number]
    +                             [-d OUTPUT_DIRECTORY] [--height HEIGHT]
    +                             [--width WIDTH]
    +                             csvfile
    +
    +positional arguments:
    +  csvfile               csv-delimited file with columns
    +                            1. data label
    +                            2. mapping file (supported formats: psl)
    +                            3. assembly file (fasta or fasta index)
    +                            4. transcript file (fasta or fasta index)
    +
    +optional arguments:
    +  -h, --help            show this help message and exit
    +  -v, --verbose         print extra output
    +  -p number, --cpus number
    +                        number of cpus [default 1]
    +  -d OUTPUT_DIRECTORY, --output-directory OUTPUT_DIRECTORY
    +                        output directory
    +  --height HEIGHT       figure height in inches [default 6.0]
    +  --width WIDTH         figure width in inches [default 6.0]
    +
    +
    +
    +

    R package vignette +

    +

    Alternatively, import the library in an R script and use the package functions. See Get started or run vignette("genecovr") for a minimum working example.

    -
    -

    Vignette -

    -

    Alternatively, import the library as usual in an R script and use the package functions. See the vignette for a minimum working example.

    diff --git a/search.json b/search.json index ee5a4de..8320773 100644 --- a/search.json +++ b/search.json @@ -1 +1 @@ -[{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":null,"dir":"","previous_headings":"","what":"GNU General Public License","title":"GNU General Public License","text":"Version 3, 29 June 2007Copyright © 2007 Free Software Foundation, Inc.  Everyone permitted copy distribute verbatim copies license document, changing allowed.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"preamble","dir":"","previous_headings":"","what":"Preamble","title":"GNU General Public License","text":"GNU General Public License free, copyleft license software kinds works. licenses software practical works designed take away freedom share change works. contrast, GNU General Public License intended guarantee freedom share change versions program–make sure remains free software users. , Free Software Foundation, use GNU General Public License software; applies also work released way authors. can apply programs, . speak free software, referring freedom, price. General Public Licenses designed make sure freedom distribute copies free software (charge wish), receive source code can get want , can change software use pieces new free programs, know can things. protect rights, need prevent others denying rights asking surrender rights. Therefore, certain responsibilities distribute copies software, modify : responsibilities respect freedom others. example, distribute copies program, whether gratis fee, must pass recipients freedoms received. must make sure , , receive can get source code. must show terms know rights. Developers use GNU GPL protect rights two steps: (1) assert copyright software, (2) offer License giving legal permission copy, distribute /modify . developers’ authors’ protection, GPL clearly explains warranty free software. users’ authors’ sake, GPL requires modified versions marked changed, problems attributed erroneously authors previous versions. devices designed deny users access install run modified versions software inside , although manufacturer can . fundamentally incompatible aim protecting users’ freedom change software. systematic pattern abuse occurs area products individuals use, precisely unacceptable. Therefore, designed version GPL prohibit practice products. problems arise substantially domains, stand ready extend provision domains future versions GPL, needed protect freedom users. Finally, every program threatened constantly software patents. States allow patents restrict development use software general-purpose computers, , wish avoid special danger patents applied free program make effectively proprietary. prevent , GPL assures patents used render program non-free. precise terms conditions copying, distribution modification follow.","code":""},{"path":[]},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_0-definitions","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"0. Definitions","title":"GNU General Public License","text":"“License” refers version 3 GNU General Public License. “Copyright” also means copyright-like laws apply kinds works, semiconductor masks. “Program” refers copyrightable work licensed License. licensee addressed “”. “Licensees” “recipients” may individuals organizations. “modify” work means copy adapt part work fashion requiring copyright permission, making exact copy. resulting work called “modified version” earlier work work “based ” earlier work. “covered work” means either unmodified Program work based Program. “propagate” work means anything , without permission, make directly secondarily liable infringement applicable copyright law, except executing computer modifying private copy. Propagation includes copying, distribution (without modification), making available public, countries activities well. “convey” work means kind propagation enables parties make receive copies. Mere interaction user computer network, transfer copy, conveying. interactive user interface displays “Appropriate Legal Notices” extent includes convenient prominently visible feature (1) displays appropriate copyright notice, (2) tells user warranty work (except extent warranties provided), licensees may convey work License, view copy License. interface presents list user commands options, menu, prominent item list meets criterion.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_1-source-code","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"1. Source Code","title":"GNU General Public License","text":"“source code” work means preferred form work making modifications . “Object code” means non-source form work. “Standard Interface” means interface either official standard defined recognized standards body, , case interfaces specified particular programming language, one widely used among developers working language. “System Libraries” executable work include anything, work whole, () included normal form packaging Major Component, part Major Component, (b) serves enable use work Major Component, implement Standard Interface implementation available public source code form. “Major Component”, context, means major essential component (kernel, window system, ) specific operating system () executable work runs, compiler used produce work, object code interpreter used run . “Corresponding Source” work object code form means source code needed generate, install, (executable work) run object code modify work, including scripts control activities. However, include work’s System Libraries, general-purpose tools generally available free programs used unmodified performing activities part work. example, Corresponding Source includes interface definition files associated source files work, source code shared libraries dynamically linked subprograms work specifically designed require, intimate data communication control flow subprograms parts work. Corresponding Source need include anything users can regenerate automatically parts Corresponding Source. Corresponding Source work source code form work.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_2-basic-permissions","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"2. Basic Permissions","title":"GNU General Public License","text":"rights granted License granted term copyright Program, irrevocable provided stated conditions met. License explicitly affirms unlimited permission run unmodified Program. output running covered work covered License output, given content, constitutes covered work. License acknowledges rights fair use equivalent, provided copyright law. may make, run propagate covered works convey, without conditions long license otherwise remains force. may convey covered works others sole purpose make modifications exclusively , provide facilities running works, provided comply terms License conveying material control copyright. thus making running covered works must exclusively behalf, direction control, terms prohibit making copies copyrighted material outside relationship . Conveying circumstances permitted solely conditions stated . Sublicensing allowed; section 10 makes unnecessary.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_3-protecting-users-legal-rights-from-anti-circumvention-law","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"3. Protecting Users’ Legal Rights From Anti-Circumvention Law","title":"GNU General Public License","text":"covered work shall deemed part effective technological measure applicable law fulfilling obligations article 11 WIPO copyright treaty adopted 20 December 1996, similar laws prohibiting restricting circumvention measures. convey covered work, waive legal power forbid circumvention technological measures extent circumvention effected exercising rights License respect covered work, disclaim intention limit operation modification work means enforcing, work’s users, third parties’ legal rights forbid circumvention technological measures.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_4-conveying-verbatim-copies","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"4. Conveying Verbatim Copies","title":"GNU General Public License","text":"may convey verbatim copies Program’s source code receive , medium, provided conspicuously appropriately publish copy appropriate copyright notice; keep intact notices stating License non-permissive terms added accord section 7 apply code; keep intact notices absence warranty; give recipients copy License along Program. may charge price price copy convey, may offer support warranty protection fee.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_5-conveying-modified-source-versions","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"5. Conveying Modified Source Versions","title":"GNU General Public License","text":"may convey work based Program, modifications produce Program, form source code terms section 4, provided also meet conditions: ) work must carry prominent notices stating modified , giving relevant date. b) work must carry prominent notices stating released License conditions added section 7. requirement modifies requirement section 4 “keep intact notices”. c) must license entire work, whole, License anyone comes possession copy. License therefore apply, along applicable section 7 additional terms, whole work, parts, regardless packaged. License gives permission license work way, invalidate permission separately received . d) work interactive user interfaces, must display Appropriate Legal Notices; however, Program interactive interfaces display Appropriate Legal Notices, work need make . compilation covered work separate independent works, nature extensions covered work, combined form larger program, volume storage distribution medium, called “aggregate” compilation resulting copyright used limit access legal rights compilation’s users beyond individual works permit. Inclusion covered work aggregate cause License apply parts aggregate.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_6-conveying-non-source-forms","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"6. Conveying Non-Source Forms","title":"GNU General Public License","text":"may convey covered work object code form terms sections 4 5, provided also convey machine-readable Corresponding Source terms License, one ways: ) Convey object code , embodied , physical product (including physical distribution medium), accompanied Corresponding Source fixed durable physical medium customarily used software interchange. b) Convey object code , embodied , physical product (including physical distribution medium), accompanied written offer, valid least three years valid long offer spare parts customer support product model, give anyone possesses object code either (1) copy Corresponding Source software product covered License, durable physical medium customarily used software interchange, price reasonable cost physically performing conveying source, (2) access copy Corresponding Source network server charge. c) Convey individual copies object code copy written offer provide Corresponding Source. alternative allowed occasionally noncommercially, received object code offer, accord subsection 6b. d) Convey object code offering access designated place (gratis charge), offer equivalent access Corresponding Source way place charge. need require recipients copy Corresponding Source along object code. place copy object code network server, Corresponding Source may different server (operated third party) supports equivalent copying facilities, provided maintain clear directions next object code saying find Corresponding Source. Regardless server hosts Corresponding Source, remain obligated ensure available long needed satisfy requirements. e) Convey object code using peer--peer transmission, provided inform peers object code Corresponding Source work offered general public charge subsection 6d. separable portion object code, whose source code excluded Corresponding Source System Library, need included conveying object code work. “User Product” either (1) “consumer product”, means tangible personal property normally used personal, family, household purposes, (2) anything designed sold incorporation dwelling. determining whether product consumer product, doubtful cases shall resolved favor coverage. particular product received particular user, “normally used” refers typical common use class product, regardless status particular user way particular user actually uses, expects expected use, product. product consumer product regardless whether product substantial commercial, industrial non-consumer uses, unless uses represent significant mode use product. “Installation Information” User Product means methods, procedures, authorization keys, information required install execute modified versions covered work User Product modified version Corresponding Source. information must suffice ensure continued functioning modified object code case prevented interfered solely modification made. convey object code work section , , specifically use , User Product, conveying occurs part transaction right possession use User Product transferred recipient perpetuity fixed term (regardless transaction characterized), Corresponding Source conveyed section must accompanied Installation Information. requirement apply neither third party retains ability install modified object code User Product (example, work installed ROM). requirement provide Installation Information include requirement continue provide support service, warranty, updates work modified installed recipient, User Product modified installed. Access network may denied modification materially adversely affects operation network violates rules protocols communication across network. Corresponding Source conveyed, Installation Information provided, accord section must format publicly documented (implementation available public source code form), must require special password key unpacking, reading copying.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_7-additional-terms","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"7. Additional Terms","title":"GNU General Public License","text":"“Additional permissions” terms supplement terms License making exceptions one conditions. Additional permissions applicable entire Program shall treated though included License, extent valid applicable law. additional permissions apply part Program, part may used separately permissions, entire Program remains governed License without regard additional permissions. convey copy covered work, may option remove additional permissions copy, part . (Additional permissions may written require removal certain cases modify work.) may place additional permissions material, added covered work, can give appropriate copyright permission. Notwithstanding provision License, material add covered work, may (authorized copyright holders material) supplement terms License terms: ) Disclaiming warranty limiting liability differently terms sections 15 16 License; b) Requiring preservation specified reasonable legal notices author attributions material Appropriate Legal Notices displayed works containing ; c) Prohibiting misrepresentation origin material, requiring modified versions material marked reasonable ways different original version; d) Limiting use publicity purposes names licensors authors material; e) Declining grant rights trademark law use trade names, trademarks, service marks; f) Requiring indemnification licensors authors material anyone conveys material (modified versions ) contractual assumptions liability recipient, liability contractual assumptions directly impose licensors authors. non-permissive additional terms considered “restrictions” within meaning section 10. Program received , part , contains notice stating governed License along term restriction, may remove term. license document contains restriction permits relicensing conveying License, may add covered work material governed terms license document, provided restriction survive relicensing conveying. add terms covered work accord section, must place, relevant source files, statement additional terms apply files, notice indicating find applicable terms. Additional terms, permissive non-permissive, may stated form separately written license, stated exceptions; requirements apply either way.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_8-termination","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"8. Termination","title":"GNU General Public License","text":"may propagate modify covered work except expressly provided License. attempt otherwise propagate modify void, automatically terminate rights License (including patent licenses granted third paragraph section 11). However, cease violation License, license particular copyright holder reinstated () provisionally, unless copyright holder explicitly finally terminates license, (b) permanently, copyright holder fails notify violation reasonable means prior 60 days cessation. Moreover, license particular copyright holder reinstated permanently copyright holder notifies violation reasonable means, first time received notice violation License (work) copyright holder, cure violation prior 30 days receipt notice. Termination rights section terminate licenses parties received copies rights License. rights terminated permanently reinstated, qualify receive new licenses material section 10.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_9-acceptance-not-required-for-having-copies","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"9. Acceptance Not Required for Having Copies","title":"GNU General Public License","text":"required accept License order receive run copy Program. Ancillary propagation covered work occurring solely consequence using peer--peer transmission receive copy likewise require acceptance. However, nothing License grants permission propagate modify covered work. actions infringe copyright accept License. Therefore, modifying propagating covered work, indicate acceptance License .","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_10-automatic-licensing-of-downstream-recipients","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"10. Automatic Licensing of Downstream Recipients","title":"GNU General Public License","text":"time convey covered work, recipient automatically receives license original licensors, run, modify propagate work, subject License. responsible enforcing compliance third parties License. “entity transaction” transaction transferring control organization, substantially assets one, subdividing organization, merging organizations. propagation covered work results entity transaction, party transaction receives copy work also receives whatever licenses work party’s predecessor interest give previous paragraph, plus right possession Corresponding Source work predecessor interest, predecessor can get reasonable efforts. may impose restrictions exercise rights granted affirmed License. example, may impose license fee, royalty, charge exercise rights granted License, may initiate litigation (including cross-claim counterclaim lawsuit) alleging patent claim infringed making, using, selling, offering sale, importing Program portion .","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_11-patents","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"11. Patents","title":"GNU General Public License","text":"“contributor” copyright holder authorizes use License Program work Program based. work thus licensed called contributor’s “contributor version”. contributor’s “essential patent claims” patent claims owned controlled contributor, whether already acquired hereafter acquired, infringed manner, permitted License, making, using, selling contributor version, include claims infringed consequence modification contributor version. purposes definition, “control” includes right grant patent sublicenses manner consistent requirements License. contributor grants non-exclusive, worldwide, royalty-free patent license contributor’s essential patent claims, make, use, sell, offer sale, import otherwise run, modify propagate contents contributor version. following three paragraphs, “patent license” express agreement commitment, however denominated, enforce patent (express permission practice patent covenant sue patent infringement). “grant” patent license party means make agreement commitment enforce patent party. convey covered work, knowingly relying patent license, Corresponding Source work available anyone copy, free charge terms License, publicly available network server readily accessible means, must either (1) cause Corresponding Source available, (2) arrange deprive benefit patent license particular work, (3) arrange, manner consistent requirements License, extend patent license downstream recipients. “Knowingly relying” means actual knowledge , patent license, conveying covered work country, recipient’s use covered work country, infringe one identifiable patents country reason believe valid. , pursuant connection single transaction arrangement, convey, propagate procuring conveyance , covered work, grant patent license parties receiving covered work authorizing use, propagate, modify convey specific copy covered work, patent license grant automatically extended recipients covered work works based . patent license “discriminatory” include within scope coverage, prohibits exercise , conditioned non-exercise one rights specifically granted License. may convey covered work party arrangement third party business distributing software, make payment third party based extent activity conveying work, third party grants, parties receive covered work , discriminatory patent license () connection copies covered work conveyed (copies made copies), (b) primarily connection specific products compilations contain covered work, unless entered arrangement, patent license granted, prior 28 March 2007. Nothing License shall construed excluding limiting implied license defenses infringement may otherwise available applicable patent law.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_12-no-surrender-of-others-freedom","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"12. No Surrender of Others’ Freedom","title":"GNU General Public License","text":"conditions imposed (whether court order, agreement otherwise) contradict conditions License, excuse conditions License. convey covered work satisfy simultaneously obligations License pertinent obligations, consequence may convey . example, agree terms obligate collect royalty conveying convey Program, way satisfy terms License refrain entirely conveying Program.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_13-use-with-the-gnu-affero-general-public-license","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"13. Use with the GNU Affero General Public License","title":"GNU General Public License","text":"Notwithstanding provision License, permission link combine covered work work licensed version 3 GNU Affero General Public License single combined work, convey resulting work. terms License continue apply part covered work, special requirements GNU Affero General Public License, section 13, concerning interaction network apply combination .","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_14-revised-versions-of-this-license","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"14. Revised Versions of this License","title":"GNU General Public License","text":"Free Software Foundation may publish revised /new versions GNU General Public License time time. new versions similar spirit present version, may differ detail address new problems concerns. version given distinguishing version number. Program specifies certain numbered version GNU General Public License “later version” applies , option following terms conditions either numbered version later version published Free Software Foundation. Program specify version number GNU General Public License, may choose version ever published Free Software Foundation. Program specifies proxy can decide future versions GNU General Public License can used, proxy’s public statement acceptance version permanently authorizes choose version Program. Later license versions may give additional different permissions. However, additional obligations imposed author copyright holder result choosing follow later version.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_15-disclaimer-of-warranty","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"15. Disclaimer of Warranty","title":"GNU General Public License","text":"WARRANTY PROGRAM, EXTENT PERMITTED APPLICABLE LAW. EXCEPT OTHERWISE STATED WRITING COPYRIGHT HOLDERS /PARTIES PROVIDE PROGRAM “” WITHOUT WARRANTY KIND, EITHER EXPRESSED IMPLIED, INCLUDING, LIMITED , IMPLIED WARRANTIES MERCHANTABILITY FITNESS PARTICULAR PURPOSE. ENTIRE RISK QUALITY PERFORMANCE PROGRAM . PROGRAM PROVE DEFECTIVE, ASSUME COST NECESSARY SERVICING, REPAIR CORRECTION.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_16-limitation-of-liability","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"16. Limitation of Liability","title":"GNU General Public License","text":"EVENT UNLESS REQUIRED APPLICABLE LAW AGREED WRITING COPYRIGHT HOLDER, PARTY MODIFIES /CONVEYS PROGRAM PERMITTED , LIABLE DAMAGES, INCLUDING GENERAL, SPECIAL, INCIDENTAL CONSEQUENTIAL DAMAGES ARISING USE INABILITY USE PROGRAM (INCLUDING LIMITED LOSS DATA DATA RENDERED INACCURATE LOSSES SUSTAINED THIRD PARTIES FAILURE PROGRAM OPERATE PROGRAMS), EVEN HOLDER PARTY ADVISED POSSIBILITY DAMAGES.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_17-interpretation-of-sections-15-and-16","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"17. Interpretation of Sections 15 and 16","title":"GNU General Public License","text":"disclaimer warranty limitation liability provided given local legal effect according terms, reviewing courts shall apply local law closely approximates absolute waiver civil liability connection Program, unless warranty assumption liability accompanies copy Program return fee. END TERMS CONDITIONS","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"how-to-apply-these-terms-to-your-new-programs","dir":"","previous_headings":"","what":"How to Apply These Terms to Your New Programs","title":"GNU General Public License","text":"develop new program, want greatest possible use public, best way achieve make free software everyone can redistribute change terms. , attach following notices program. safest attach start source file effectively state exclusion warranty; file least “copyright” line pointer full notice found. Also add information contact electronic paper mail. program terminal interaction, make output short notice like starts interactive mode: hypothetical commands show w show c show appropriate parts General Public License. course, program’s commands might different; GUI interface, use “box”. also get employer (work programmer) school, , sign “copyright disclaimer” program, necessary. information , apply follow GNU GPL, see . GNU General Public License permit incorporating program proprietary programs. program subroutine library, may consider useful permit linking proprietary applications library. want , use GNU Lesser General Public License instead License. first, please read .","code":" Copyright (C) 2020 Per Unneberg This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . genecovr Copyright (C) 2020 Per Unneberg This program comes with ABSOLUTELY NO WARRANTY; for details type 'show w'. This is free software, and you are welcome to redistribute it under certain conditions; type 'show c' for details."},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"about","dir":"Articles","previous_headings":"","what":"About","title":"Gene body coverage analysis in R","text":"vignette describes analyses gene body coverage genome assembly evaluation metrics R using genecovr package. genecovr contains functionality parsing alignment files, calculating gene body coverages, generating simple QC metrics assess assembly quality output. start example analysis, describe genecovr represents pairwise alignments.","code":""},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"r-setup","dir":"Articles","previous_headings":"About","what":"R setup","title":"Gene body coverage analysis in R","text":"","code":"library(genecovr) library(ggplot2) library(S4Vectors) library(tidyr) library(rlang) library(viridis) library(RColorBrewer) bw <- theme_bw(base_size = 18) %+replace% theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) theme_set(bw) color_pal_4 <- brewer.pal(name = \"Paired\", n = 4) psize <- 3"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"on-object-representation-of-pairwise-sequence-alignments","dir":"Articles","previous_headings":"About","what":"On object representation of pairwise sequence alignments","title":"Gene body coverage analysis in R","text":"genecovr functionality read pairwise sequence alignment files converts pairwise alignments AlignmentPairs objects. AlignmentPairs object subclass Bioconductor class S4Vectors::Pairs. Pairs object turn aligns two vectors along slot names first second, AlignmentPairs object adds slots query subject, possibly extra slots related additional information alignment file. query subject GRanges objects objects derived GRangesclass.","code":""},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"analysing-gene-body-coverage","dir":"Articles","previous_headings":"","what":"Analysing gene body coverage","title":"Gene body coverage analysis in R","text":"section analyse mapping transcriptome non-polished polished assembly. mapping results consist two gmap files psl format, transcripts2nonpolished.psl transcripts2polished.psl. addition fasta index files assemblies (nonpolished.fai polished.fai) transcriptome (transcripts.fai). fasta indices used generate Seqinfo objects can used set sequence information parsed output. load fasta indices parse psl files readPsl, storing results AlignmentPairsList convenience.","code":"assembly_fai_fn <- list( nonpol = system.file(\"extdata\", \"nonpolished.fai\", package = \"genecovr\" ), pol = system.file(\"extdata\", \"polished.fai\", package = \"genecovr\" ) ) transcripts_fai_fn <- list( nonpol = system.file(\"extdata\", \"transcripts.fai\", package = \"genecovr\" ), pol = system.file(\"extdata\", \"transcripts.fai\", package = \"genecovr\" ) ) assembly_sinfo <- endoapply(assembly_fai_fn, readFastaIndex) transcripts_sinfo <- endoapply(transcripts_fai_fn, readFastaIndex) psl_fn <- list( nonpol = system.file(\"extdata\", \"transcripts2nonpolished.psl\", package = \"genecovr\" ), pol = system.file(\"extdata\", \"transcripts2polished.psl\", package = \"genecovr\" ) ) apl <- AlignmentPairsList( lapply(names(psl_fn), function(x) { readPsl(psl_fn[[x]], seqinfo.sbjct = assembly_sinfo[[x]], seqinfo.query = transcripts_sinfo[[x]] ) }) ) names(apl) <- names(psl_fn)"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"plot-ratio-matches-to-width-of-alignment-regions","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Plot ratio matches to width of alignment regions","title":"Gene body coverage analysis in R","text":"first plot ratio matches width alignments respect transcripts. clear shift higher percentage matches polished assembly, expected.","code":"plot(apl, aes(x = id, y = matches / query.width, fill = id), which = \"violin\") + ylim(0.8, 1) + scale_fill_viridis_d()"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"plot-summary-indel-and-match-distributions","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Plot summary indel and match distributions","title":"Gene body coverage analysis in R","text":"can also select multiple columns plot AlignmentPairsList.","code":"cnames <- c(\"misMatches\", \"query.NumInsert\", \"query.BaseInsert\") plot(apl, aes(x = id, y = get_expr(enquo(cnames))), which = \"violin\") + facet_wrap(. ~ name, scales = \"free\") plot(apl, aes(x = id, y = get_expr(enquo(cnames))), which = \"boxplot\") + facet_wrap(. ~ name, scales = \"free\") plot(apl, aes(x = id, y = get_expr(enquo(cnames))), which = \"boxplot\") + facet_wrap(. ~ name, scales = \"free\") + scale_y_continuous(trans = \"log10\")"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"plot-number-of-indels","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Plot number of indels","title":"Gene body coverage analysis in R","text":"function insertionSummary summarizes number insertions, either transcript level (default) per alignment. intuition assembly quality improves, number indels go . First show plot number insertions per alignment. consequence transcript may split multiple alignments, bars unequal height. alternative summarize number insertions transcript. Currently, consideration taken overlapping alignments, meaning insertions may counted . improvement use non-overlapping set alignments fewest number insertions.","code":"x <- insertionSummary(apl, reduce = FALSE) ggplot(x, aes(id)) + geom_bar(aes(fill = cuts)) + scale_fill_viridis_d(name = \"qNumInsert\", begin = 1, end = 0) x <- insertionSummary(apl) ggplot(x, aes(id)) + geom_bar(aes(fill = cuts)) + scale_fill_viridis_d(name = \"qNumInsert\", begin = 1, end = 0)"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"gene-body-coverage","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Gene body coverage","title":"Gene body coverage analysis in R","text":"function geneBodyCoverage takes AlignmentPairs object summarizes breadth coverage number subject hits per transcript. summary can obtained summarizeGeneBodyCoverage function. define range minimum match hit cutoffs filter hits matches aligned region. combine data plot resulting coverages","code":"gbc <- lapply(apl, geneBodyCoverage, min.match = 0.1) min.match <- c(0.25, 0.5, 0.75, 0.9) names(min.match) <- min.match gbc_summary <- lapply(apl, function(x) { y <- do.call(\"rbind\", lapply(min.match, function(mm) { summarizeGeneBodyCoverage(x, min.match = mm) })) }) library(dplyr) data <- dplyr::bind_rows(lapply(gbc_summary, data.frame), .id = \"dataset\") h <- max(data$total) hmax <- ceiling(h / 100) * 100 ggplot( subset(data, min.match == 0.25), aes(x = min.coverage, y = count, group = dataset, color = dataset) ) + geom_abline(slope = 0, intercept = h) + geom_point(aes(shape = dataset, color = dataset), size = psize) + geom_line() + scale_color_viridis_d() + scale_y_continuous(breaks = c(pretty(data$count)), limits = c(0, hmax))"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"number-of-contigs-per-transcript","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Number of contigs per transcript","title":"Gene body coverage analysis in R","text":"fragmented assembly lead transcripts mapping several contigs. calculate number subjects coverage cutoff function countSubjectsByCoverage plot results","code":"data <- dplyr::bind_rows( lapply( lapply(apl, countSubjectsByCoverage), data.frame ), .id = \"dataset\" ) ggplot(data = data, aes( x = factor(min.coverage), y = Freq, fill = n.subjects )) + geom_bar(stat = \"identity\", position = position_stack()) + scale_fill_viridis_d(begin = 1, end = 0) + facet_wrap(. ~ dataset, nrow = 1, labeller = label_both)"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"duplicated-versus-split-transcripts","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Duplicated versus split transcripts","title":"Gene body coverage analysis in R","text":"Transcripts map one contig anything split contigs duplicated entirely subjects. One way investigate whether trancripts split duplicated plot depth coverage divided breadth coverage length-normalized coverage. First combine data: plot ratio depthOfCoverage / breadthOfCoverage length-normalized coverage Alternatively can make jitter plot depthOfCoverage breadthOfCoverage number subjects. similar picture obtained via histogram plot. Finally, assess whether length bias ratio condition number subjects per transcript.","code":"data <- dplyr::bind_rows( lapply( lapply(apl, geneBodyCoverage), data.frame ), .id = \"dataset\" ) ggplot(data = data, aes( x = coverage, y = depthOfCoverage / breadthOfCoverage, color = factor(n.subjects) )) + geom_point(size = psize) + scale_color_viridis_d(alpha = .8) + xlim(0, 1) + ylim(0, 5) + facet_wrap(. ~ dataset) ggplot( data = subset(data, n.subjects > 1), aes(x = factor(dataset), y = depthOfCoverage / breadthOfCoverage) ) + geom_jitter(size = psize, alpha = .6) + facet_wrap(. ~ n.subjects) ggplot( data = subset(data, n.subjects > 1), aes(depthOfCoverage / breadthOfCoverage) ) + geom_histogram() + facet_grid(vars(dataset)) ggplot( data = subset(data, n.subjects > 1), aes(x = factor(dataset), y = seqlengths) ) + geom_boxplot() + facet_grid(. ~ n.subjects)"},{"path":"https://nbisweden.github.io/genecovr/authors.html","id":null,"dir":"","previous_headings":"","what":"Authors","title":"Authors and Citation","text":"Per Unneberg. Author, maintainer.","code":""},{"path":"https://nbisweden.github.io/genecovr/authors.html","id":"citation","dir":"","previous_headings":"","what":"Citation","title":"Authors and Citation","text":"Unneberg P (2023). genecovr: Gene body coverage analysis evaluate genome assemblies. R package version 0.1.0, https://nbisweden.github.io/genecovr/.","code":"@Manual{, title = {genecovr: Gene body coverage analysis to evaluate genome assemblies}, author = {Per Unneberg}, year = {2023}, note = {R package version 0.1.0}, url = {https://nbisweden.github.io/genecovr/}, }"},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"genecovr","dir":"","previous_headings":"","what":"Gene body coverage analysis to evaluate genome assemblies","title":"Gene body coverage analysis to evaluate genome assemblies","text":"Perform gene body coverage analyses R evaluate genome assembly quality.","code":""},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"installation","dir":"","previous_headings":"","what":"Installation","title":"Gene body coverage analysis to evaluate genome assemblies","text":"can install released version genecovr NBIS GitHub :","code":"# install.packages(\"devtools\") devtools::install_github(\"NBISweden/genecovr\")"},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"quick-usage","dir":"","previous_headings":"","what":"Quick usage","title":"Gene body coverage analysis to evaluate genome assemblies","text":"helper script generating basic plots located PACKAGE_DIR/bin/genecovr. Create data input csv-delimited file columns data label mapping file (supported formats: psl) assembly file (fasta fasta index) transcript file (fasta fasta index) Columns 3 4 can set missing value (NA) case sequence sizes inferred alignment files. run script generate plots:","code":"PACKAGE_DIR/bin/genecovr indata.csv"},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"vignette","dir":"","previous_headings":"","what":"Vignette","title":"Gene body coverage analysis to evaluate genome assemblies","text":"Alternatively, import library usual R script use package functions. See vignette minimum working example.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":null,"dir":"Reference","previous_headings":"","what":"Representation of an alignment pair — AlignmentPairs-class","title":"Representation of an alignment pair — AlignmentPairs-class","text":"Pairs subclass Constructor AlignmentPairs","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Representation of an alignment pair — AlignmentPairs-class","text":"","code":"AlignmentPairs(query, subject, ...) # S4 method for GRanges,GRanges AlignmentPairs(query, subject, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Representation of an alignment pair — AlignmentPairs-class","text":"query vectorized object representing query subject vectorized object representing subject ... Arguments pass constructor","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Representation of an alignment pair — AlignmentPairs-class","text":"AlignmentPairs object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Representation of an alignment pair — AlignmentPairs-class","text":"AlignmentPairs class extends Pairs-class","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"constructor","dir":"Reference","previous_headings":"","what":"Constructor","title":"Representation of an alignment pair — AlignmentPairs-class","text":"AlignmentPairs(query, subject, ...): Constructs AlignmentPairs object aligning vectors query subject.","code":""},{"path":[]},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":null,"dir":"Reference","previous_headings":"","what":"List of AlignmentPairs instances — AlignmentPairsList-class","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"Subclass S4Vectors SimpleList, entry AlignmentPairs object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"","code":"AlignmentPairsList(obj, ...) # S4 method for list AlignmentPairsList(obj)"},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"obj list ... ellipsis","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"AlignmentPairsList object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"constructor","dir":"Reference","previous_headings":"","what":"Constructor","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"AlignmentPairsList(obj, ...): Constructs AlignmentPairsList object input","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":null,"dir":"Reference","previous_headings":"","what":"as.data.frame — as.data.frame,AlignmentPairsList-method","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"Convert AlignmentPairsList data.frame.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"","code":"# S4 method for AlignmentPairsList as.data.frame(x, ..., .id = \"id\")"},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"x AlignmentPairsList object ... additional parameters lapply .id name id column added dplyr::bind_rows","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"data.frame","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/autoplot.AlignmentPairsList.html","id":null,"dir":"Reference","previous_headings":"","what":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","title":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","text":"autoplot.AlignmentPairsList","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/autoplot.AlignmentPairsList.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","text":"","code":"# S3 method for AlignmentPairsList autoplot(object, aes, vars, ..., which = \"point\")"},{"path":"https://nbisweden.github.io/genecovr/reference/autoplot.AlignmentPairsList.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","text":"object AlignmentPairsList aes aes mapping vars variable mapping facet plots ... additional parameters ggplot function plot make. 'grid' option makes scatter plot marginal densities","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"breadthOfCoverage — breadthOfCoverage","title":"breadthOfCoverage — breadthOfCoverage","text":"Calculate breadth coverage sequence id","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"breadthOfCoverage — breadthOfCoverage","text":"","code":"breadthOfCoverage(x)"},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"breadthOfCoverage — breadthOfCoverage","text":"x GRangesList object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"breadthOfCoverage — breadthOfCoverage","text":"integer representing sum range widths","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/countSubjectsByCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"countSubjectsByCoverage — countSubjectsByCoverage","title":"countSubjectsByCoverage — countSubjectsByCoverage","text":"countSubjectsByCoverage","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/countSubjectsByCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"countSubjectsByCoverage — countSubjectsByCoverage","text":"","code":"countSubjectsByCoverage( x, min.coverage = seq(0.25, 1, 0.25), min.match = 0.9, nmax = 5 )"},{"path":"https://nbisweden.github.io/genecovr/reference/countSubjectsByCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"countSubjectsByCoverage — countSubjectsByCoverage","text":"x AlignmentPairs DataFrame object min.coverage coverage cutoffs apply transcripts min.match filter hits fraction matching bases less min.match nmax maximum number subjects count","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Get deletions from an alignment. — deletions","title":"Get deletions from an alignment. — deletions","text":"Get deletions alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get deletions from an alignment. — deletions","text":"","code":"deletions(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get deletions from an alignment. — deletions","text":"x Object representation sequence alignment ... Additional argument list","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get deletions from an alignment. — deletions","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Get divergence from an alignment — divergence","title":"Get divergence from an alignment — divergence","text":"Get divergence alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get divergence from an alignment — divergence","text":"","code":"divergence(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get divergence from an alignment — divergence","text":"x Object representation sequence alignment ... Additional argument list","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get divergence from an alignment — divergence","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"Get gene body coverage — geneBodyCoverage","title":"Get gene body coverage — geneBodyCoverage","text":"geneBodyCoverage(obj, ...): calculate gene body coverage input Calculate geneBodyCoverage query sequences","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get gene body coverage — geneBodyCoverage","text":"","code":"geneBodyCoverage(obj, ...) # S4 method for AlignmentPairs geneBodyCoverage(obj, min.match = 0.9) # S4 method for AlignmentPairsList geneBodyCoverage(obj, min.match = 0.9, bpparam = NULL)"},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get gene body coverage — geneBodyCoverage","text":"obj AlignmentPairs object ... additional parameters min.match filter hits fraction matching bases less min.match bpparam BiocParallel parameter object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get gene body coverage — geneBodyCoverage","text":"reduced filtered DataFrame object row transcript. See @details information seqnames seqlengths columns collected corresponding seqinfo object. breadthOfCoverage total width reduced regions transcript corresponds much transcript covered. Dividing breadthOfCoverage total transcript length gives coverage fraction. depthOfCoverage sums ranges estimate many times range present. Dividing depthOfCoverage breadthOfCoverage indicates multiplicity query. queries map multiple subjects, value close 1 indicates query split several subjects, whereas higher value indicates sequence duplication subject level.","code":"The revmap column maps the output ranges to the input ranges as lists of numerical ids. These ids can be used to retrieve the corresponding AlignmentPairs ranges providing a link to the subjects. The hitCoverage lists the width of each reduced hit, and hitStart and hitEnd provide the transcript coordinates of these hits."},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Get gene body coverage — geneBodyCoverage","text":"Given AlignmentPairs object, calculate gene body coverages query sequences. regions. instance, one hit spans coordinates 100-400 another 200-500, merge 100-500. function calculates many overlaps merged, rationale >1 overlaps seqname, sequence associated multiple distinct regions subject sequence. Thus, unit interest query, function seeks identify reduced disjoint regions query sequence map subject.","code":"The function returns a GRanges object with reduced regions, i.e. overlaps are merged. Information about matches and mismatches is currently dropped as it usually is not possible to infer where mismatches occur. Instead, the data column `coverage` simply holds the ratio of the width of the region to the transcript length. Summing up coverages from disjoint regions then gives total coverage of the transcript. The cutoff is used to filter regions based on the ratio of matches to the width of the region. Since the association between query and subject regions is removed, the return value is a GRanges object consisting of the reduced query ranges with a revmap and coverage attribute."},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":null,"dir":"Reference","previous_headings":"","what":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"Gene body coverage analysis evaluate genome assemblies.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"genecovr package provides functionality evaluating gene body coverage metrics genome assemblies. central measurement unit gene transcript model.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":"functions","dir":"Reference","previous_headings":"","what":"Functions","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"autoplot: plot GRanges objects gene body coverage metrics","code":""},{"path":[]},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"Maintainer: Per Unneberg per.unneberg@nbis.se (ORCID)","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Get insertions from an alignment — insertions","title":"Get insertions from an alignment — insertions","text":"Get insertions alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get insertions from an alignment — insertions","text":"","code":"insertions(x, ...) # S4 method for GRanges insertions(x, as.bases = FALSE, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get insertions from an alignment — insertions","text":"x Object representation sequence alignment ... Additional argument list .bases Get insertions base pairs","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get insertions from an alignment — insertions","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"matches — matches","title":"matches — matches","text":"Get matches alignment. Get mismatches alignment. Get matches parts repeats alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"matches — matches","text":"","code":"matches(x, ...) mismatches(x, ...) repmatches(x, ...) # S4 method for AlignmentPairs matches(x) # S4 method for AlignmentPairs mismatches(x) # S4 method for AlignmentPairs repmatches(x)"},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"matches — matches","text":"x Object representation sequence alignment ... Additional argument list","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"matches — matches","text":"numeric numeric numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/plot.AlignmentPairsList.html","id":null,"dir":"Reference","previous_headings":"","what":"plot — plot.AlignmentPairsList","title":"plot — plot.AlignmentPairsList","text":"plot AlignmentPairsList","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/plot.AlignmentPairsList.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"plot — plot.AlignmentPairsList","text":"","code":"# S3 method for AlignmentPairsList plot(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/plot.AlignmentPairsList.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"plot — plot.AlignmentPairsList","text":"x object plot ... additional arguments autoplot","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/psl-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"methods-psl — psl methods","title":"methods-psl — psl methods","text":"Methods dealing psl data","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/psl-methods.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"methods-psl — psl methods","text":"Methods dealing Pattern Space Layout (psl) file format. See http://genome.ucsc.edu/FAQ/FAQformat.html information.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Retrieve query from object — query","title":"Retrieve query from object — query","text":"object query slot retrieve query object. object query slot set query.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Retrieve query from object — query","text":"","code":"query(x, ...) query(x) <- value # S4 method for AlignmentPairs query(x) # S4 method for AlignmentPairs,GRanges query(x) <- value"},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Retrieve query from object — query","text":"x object representing alignment ... Additional arguments value object representing query","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Retrieve query from object — query","text":"query object object representing alignment updated query slot","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":null,"dir":"Reference","previous_headings":"","what":"readFastaIndex — readFastaIndex","title":"readFastaIndex — readFastaIndex","text":"Read fasta index file","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"readFastaIndex — readFastaIndex","text":"","code":"readFastaIndex(fai, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"readFastaIndex — readFastaIndex","text":"fai fasta index file ... additional parameters pass GenomeInfoDb::Seqinfo","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"readFastaIndex — readFastaIndex","text":"Seqinfo object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"readFastaIndex — readFastaIndex","text":"","code":"fai <- system.file(\"extdata\", \"polished.fai\", package=\"genecovr\") sinfo <- readFastaIndex(fai)"},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":null,"dir":"Reference","previous_headings":"","what":"readPsl — readPsl","title":"readPsl — readPsl","text":"Read psl output","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"readPsl — readPsl","text":"","code":"readPsl( filename, seqinfo.query = NULL, seqinfo.sbjct = NULL, metadata = list(), ... )"},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"readPsl — readPsl","text":"filename input filename seqinfo.query Seqinfo object query (transcripts) seqinfo.sbjct Seqinfo object subject (reference) metadata metadata AlignmentPairs result ... additional parameters","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"readPsl — readPsl","text":"AlignmentPairs object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"readPsl — readPsl","text":"Parse Pattern Space Layout (psl) file; see http://genome.ucsc.edu/FAQ/FAQformat.html information psl file format","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"readPsl — readPsl","text":"","code":"fn <- system.file(\"extdata\", \"transcripts2polished.psl\", package=\"genecovr\") ap <- readPsl(fn) #> reading file /home/runner/work/_temp/Library/genecovr/extdata/transcripts2polished.psl #> manually inferring seqinfo for query #> manually inferring seqinfo for subject #> Processed 239 lines in 0.081 secs"},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"reduceHitCoverage — reduceHitCoverage","title":"reduceHitCoverage — reduceHitCoverage","text":"Reduce hit coverage seqname","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"reduceHitCoverage — reduceHitCoverage","text":"","code":"reduceHitCoverage(x, min.match = 0.9)"},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"reduceHitCoverage — reduceHitCoverage","text":"x AlignmentPairs object min.match filter hits fraction matching bases less min.match","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"reduceHitCoverage — reduceHitCoverage","text":"reduced filtered GRanges object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"reduceHitCoverage — reduceHitCoverage","text":"Given AlignmentPairs object, reduce overlapping query regions. instance, one hit spans coordinates 100-400 another 200-500, merge 100-500. function calculates many overlaps merged, rationale >1 overlaps seqname, sequence associated multiple distinct regions subject sequence. Thus, unit interest query, function seeks identify reduced disjoint regions query sequence map subject.","code":"The function returns a GRanges object with reduced regions, i.e. overlaps are merged. Information about matches and mismatches is currently dropped as it usually is not possible to infer where mismatches occur. Instead, the data column `coverage` simply holds the ratio of the width of the region to the transcript length. Summing up coverages from disjoint regions then gives total coverage of the transcript. The cutoff is used to filter regions based on the ratio of matches to the width of the region. Since the association between query and subject regions is removed, the return value is a GRanges object consisting of the reduced query ranges with a revmap and coverage attribute."},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"reduceHitCoverage — reduceHitCoverage","text":"","code":"ranges <- IRanges::IRanges( start=c(100, 200, 700), end=c(400, 500, 1000) ) qry <- GenomicRanges::GRanges( ranges=ranges, seqnames=c(\"t1\"), seqinfo=GenomeInfoDb::Seqinfo(seqnames=c(\"t1\"), seqlengths=c(1050)) ) ranges <- IRanges::IRanges( start=c(1000, 1000, 1000), end=c(1300, 1300, 1300) ) sbj <- GenomicRanges::GRanges(ranges=ranges, seqnames=c(\"c1\", \"c2\", \"c1\")) x <- AlignmentPairs(query=qry, subject=sbj, matches=c(300, 290, 280)) if (FALSE) gr <- reduceHitCoverage(x, 0.1)"},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Retrieve subject from object — sbjct","title":"Retrieve subject from object — sbjct","text":"object subject slot retrieve subject object. object subject slot set subject.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Retrieve subject from object — sbjct","text":"","code":"sbjct(x, ...) sbjct(x) <- value # S4 method for AlignmentPairs sbjct(x) # S4 method for AlignmentPairs,GRanges sbjct(x) <- value"},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Retrieve subject from object — sbjct","text":"x object representing alignment ... Additional arguments value object representing subject","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Retrieve subject from object — sbjct","text":"object representing subject object representing alignment updated subject slot","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Retrieve score from object — score","title":"Retrieve score from object — score","text":"object score slot retrieve score object.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Retrieve score from object — score","text":"","code":"score(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Retrieve score from object — score","text":"x object representing alignment ... Additional arguments","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Retrieve score from object — score","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/sequence-data-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"methods-sequence-data — sequence data methods","title":"methods-sequence-data — sequence data methods","text":"Methods dealing sequence data","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/summarizeGeneBodyCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","title":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","text":"summarizeGeneBodyCoverage","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/summarizeGeneBodyCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","text":"","code":"summarizeGeneBodyCoverage(x, min.coverage = seq(0, 1, 0.05), min.match = 0.9)"},{"path":"https://nbisweden.github.io/genecovr/reference/summarizeGeneBodyCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","text":"x AlignmentPairs DataFrame object min.coverage coverage cutoffs apply transcripts min.match filter hits fraction matching bases less min.match","code":""}] +[{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":null,"dir":"","previous_headings":"","what":"GNU General Public License","title":"GNU General Public License","text":"Version 3, 29 June 2007Copyright © 2007 Free Software Foundation, Inc.  Everyone permitted copy distribute verbatim copies license document, changing allowed.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"preamble","dir":"","previous_headings":"","what":"Preamble","title":"GNU General Public License","text":"GNU General Public License free, copyleft license software kinds works. licenses software practical works designed take away freedom share change works. contrast, GNU General Public License intended guarantee freedom share change versions program–make sure remains free software users. , Free Software Foundation, use GNU General Public License software; applies also work released way authors. can apply programs, . speak free software, referring freedom, price. General Public Licenses designed make sure freedom distribute copies free software (charge wish), receive source code can get want , can change software use pieces new free programs, know can things. protect rights, need prevent others denying rights asking surrender rights. Therefore, certain responsibilities distribute copies software, modify : responsibilities respect freedom others. example, distribute copies program, whether gratis fee, must pass recipients freedoms received. must make sure , , receive can get source code. must show terms know rights. Developers use GNU GPL protect rights two steps: (1) assert copyright software, (2) offer License giving legal permission copy, distribute /modify . developers’ authors’ protection, GPL clearly explains warranty free software. users’ authors’ sake, GPL requires modified versions marked changed, problems attributed erroneously authors previous versions. devices designed deny users access install run modified versions software inside , although manufacturer can . fundamentally incompatible aim protecting users’ freedom change software. systematic pattern abuse occurs area products individuals use, precisely unacceptable. Therefore, designed version GPL prohibit practice products. problems arise substantially domains, stand ready extend provision domains future versions GPL, needed protect freedom users. Finally, every program threatened constantly software patents. States allow patents restrict development use software general-purpose computers, , wish avoid special danger patents applied free program make effectively proprietary. prevent , GPL assures patents used render program non-free. precise terms conditions copying, distribution modification follow.","code":""},{"path":[]},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_0-definitions","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"0. Definitions","title":"GNU General Public License","text":"“License” refers version 3 GNU General Public License. “Copyright” also means copyright-like laws apply kinds works, semiconductor masks. “Program” refers copyrightable work licensed License. licensee addressed “”. “Licensees” “recipients” may individuals organizations. “modify” work means copy adapt part work fashion requiring copyright permission, making exact copy. resulting work called “modified version” earlier work work “based ” earlier work. “covered work” means either unmodified Program work based Program. “propagate” work means anything , without permission, make directly secondarily liable infringement applicable copyright law, except executing computer modifying private copy. Propagation includes copying, distribution (without modification), making available public, countries activities well. “convey” work means kind propagation enables parties make receive copies. Mere interaction user computer network, transfer copy, conveying. interactive user interface displays “Appropriate Legal Notices” extent includes convenient prominently visible feature (1) displays appropriate copyright notice, (2) tells user warranty work (except extent warranties provided), licensees may convey work License, view copy License. interface presents list user commands options, menu, prominent item list meets criterion.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_1-source-code","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"1. Source Code","title":"GNU General Public License","text":"“source code” work means preferred form work making modifications . “Object code” means non-source form work. “Standard Interface” means interface either official standard defined recognized standards body, , case interfaces specified particular programming language, one widely used among developers working language. “System Libraries” executable work include anything, work whole, () included normal form packaging Major Component, part Major Component, (b) serves enable use work Major Component, implement Standard Interface implementation available public source code form. “Major Component”, context, means major essential component (kernel, window system, ) specific operating system () executable work runs, compiler used produce work, object code interpreter used run . “Corresponding Source” work object code form means source code needed generate, install, (executable work) run object code modify work, including scripts control activities. However, include work’s System Libraries, general-purpose tools generally available free programs used unmodified performing activities part work. example, Corresponding Source includes interface definition files associated source files work, source code shared libraries dynamically linked subprograms work specifically designed require, intimate data communication control flow subprograms parts work. Corresponding Source need include anything users can regenerate automatically parts Corresponding Source. Corresponding Source work source code form work.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_2-basic-permissions","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"2. Basic Permissions","title":"GNU General Public License","text":"rights granted License granted term copyright Program, irrevocable provided stated conditions met. License explicitly affirms unlimited permission run unmodified Program. output running covered work covered License output, given content, constitutes covered work. License acknowledges rights fair use equivalent, provided copyright law. may make, run propagate covered works convey, without conditions long license otherwise remains force. may convey covered works others sole purpose make modifications exclusively , provide facilities running works, provided comply terms License conveying material control copyright. thus making running covered works must exclusively behalf, direction control, terms prohibit making copies copyrighted material outside relationship . Conveying circumstances permitted solely conditions stated . Sublicensing allowed; section 10 makes unnecessary.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_3-protecting-users-legal-rights-from-anti-circumvention-law","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"3. Protecting Users’ Legal Rights From Anti-Circumvention Law","title":"GNU General Public License","text":"covered work shall deemed part effective technological measure applicable law fulfilling obligations article 11 WIPO copyright treaty adopted 20 December 1996, similar laws prohibiting restricting circumvention measures. convey covered work, waive legal power forbid circumvention technological measures extent circumvention effected exercising rights License respect covered work, disclaim intention limit operation modification work means enforcing, work’s users, third parties’ legal rights forbid circumvention technological measures.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_4-conveying-verbatim-copies","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"4. Conveying Verbatim Copies","title":"GNU General Public License","text":"may convey verbatim copies Program’s source code receive , medium, provided conspicuously appropriately publish copy appropriate copyright notice; keep intact notices stating License non-permissive terms added accord section 7 apply code; keep intact notices absence warranty; give recipients copy License along Program. may charge price price copy convey, may offer support warranty protection fee.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_5-conveying-modified-source-versions","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"5. Conveying Modified Source Versions","title":"GNU General Public License","text":"may convey work based Program, modifications produce Program, form source code terms section 4, provided also meet conditions: ) work must carry prominent notices stating modified , giving relevant date. b) work must carry prominent notices stating released License conditions added section 7. requirement modifies requirement section 4 “keep intact notices”. c) must license entire work, whole, License anyone comes possession copy. License therefore apply, along applicable section 7 additional terms, whole work, parts, regardless packaged. License gives permission license work way, invalidate permission separately received . d) work interactive user interfaces, must display Appropriate Legal Notices; however, Program interactive interfaces display Appropriate Legal Notices, work need make . compilation covered work separate independent works, nature extensions covered work, combined form larger program, volume storage distribution medium, called “aggregate” compilation resulting copyright used limit access legal rights compilation’s users beyond individual works permit. Inclusion covered work aggregate cause License apply parts aggregate.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_6-conveying-non-source-forms","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"6. Conveying Non-Source Forms","title":"GNU General Public License","text":"may convey covered work object code form terms sections 4 5, provided also convey machine-readable Corresponding Source terms License, one ways: ) Convey object code , embodied , physical product (including physical distribution medium), accompanied Corresponding Source fixed durable physical medium customarily used software interchange. b) Convey object code , embodied , physical product (including physical distribution medium), accompanied written offer, valid least three years valid long offer spare parts customer support product model, give anyone possesses object code either (1) copy Corresponding Source software product covered License, durable physical medium customarily used software interchange, price reasonable cost physically performing conveying source, (2) access copy Corresponding Source network server charge. c) Convey individual copies object code copy written offer provide Corresponding Source. alternative allowed occasionally noncommercially, received object code offer, accord subsection 6b. d) Convey object code offering access designated place (gratis charge), offer equivalent access Corresponding Source way place charge. need require recipients copy Corresponding Source along object code. place copy object code network server, Corresponding Source may different server (operated third party) supports equivalent copying facilities, provided maintain clear directions next object code saying find Corresponding Source. Regardless server hosts Corresponding Source, remain obligated ensure available long needed satisfy requirements. e) Convey object code using peer--peer transmission, provided inform peers object code Corresponding Source work offered general public charge subsection 6d. separable portion object code, whose source code excluded Corresponding Source System Library, need included conveying object code work. “User Product” either (1) “consumer product”, means tangible personal property normally used personal, family, household purposes, (2) anything designed sold incorporation dwelling. determining whether product consumer product, doubtful cases shall resolved favor coverage. particular product received particular user, “normally used” refers typical common use class product, regardless status particular user way particular user actually uses, expects expected use, product. product consumer product regardless whether product substantial commercial, industrial non-consumer uses, unless uses represent significant mode use product. “Installation Information” User Product means methods, procedures, authorization keys, information required install execute modified versions covered work User Product modified version Corresponding Source. information must suffice ensure continued functioning modified object code case prevented interfered solely modification made. convey object code work section , , specifically use , User Product, conveying occurs part transaction right possession use User Product transferred recipient perpetuity fixed term (regardless transaction characterized), Corresponding Source conveyed section must accompanied Installation Information. requirement apply neither third party retains ability install modified object code User Product (example, work installed ROM). requirement provide Installation Information include requirement continue provide support service, warranty, updates work modified installed recipient, User Product modified installed. Access network may denied modification materially adversely affects operation network violates rules protocols communication across network. Corresponding Source conveyed, Installation Information provided, accord section must format publicly documented (implementation available public source code form), must require special password key unpacking, reading copying.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_7-additional-terms","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"7. Additional Terms","title":"GNU General Public License","text":"“Additional permissions” terms supplement terms License making exceptions one conditions. Additional permissions applicable entire Program shall treated though included License, extent valid applicable law. additional permissions apply part Program, part may used separately permissions, entire Program remains governed License without regard additional permissions. convey copy covered work, may option remove additional permissions copy, part . (Additional permissions may written require removal certain cases modify work.) may place additional permissions material, added covered work, can give appropriate copyright permission. Notwithstanding provision License, material add covered work, may (authorized copyright holders material) supplement terms License terms: ) Disclaiming warranty limiting liability differently terms sections 15 16 License; b) Requiring preservation specified reasonable legal notices author attributions material Appropriate Legal Notices displayed works containing ; c) Prohibiting misrepresentation origin material, requiring modified versions material marked reasonable ways different original version; d) Limiting use publicity purposes names licensors authors material; e) Declining grant rights trademark law use trade names, trademarks, service marks; f) Requiring indemnification licensors authors material anyone conveys material (modified versions ) contractual assumptions liability recipient, liability contractual assumptions directly impose licensors authors. non-permissive additional terms considered “restrictions” within meaning section 10. Program received , part , contains notice stating governed License along term restriction, may remove term. license document contains restriction permits relicensing conveying License, may add covered work material governed terms license document, provided restriction survive relicensing conveying. add terms covered work accord section, must place, relevant source files, statement additional terms apply files, notice indicating find applicable terms. Additional terms, permissive non-permissive, may stated form separately written license, stated exceptions; requirements apply either way.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_8-termination","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"8. Termination","title":"GNU General Public License","text":"may propagate modify covered work except expressly provided License. attempt otherwise propagate modify void, automatically terminate rights License (including patent licenses granted third paragraph section 11). However, cease violation License, license particular copyright holder reinstated () provisionally, unless copyright holder explicitly finally terminates license, (b) permanently, copyright holder fails notify violation reasonable means prior 60 days cessation. Moreover, license particular copyright holder reinstated permanently copyright holder notifies violation reasonable means, first time received notice violation License (work) copyright holder, cure violation prior 30 days receipt notice. Termination rights section terminate licenses parties received copies rights License. rights terminated permanently reinstated, qualify receive new licenses material section 10.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_9-acceptance-not-required-for-having-copies","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"9. Acceptance Not Required for Having Copies","title":"GNU General Public License","text":"required accept License order receive run copy Program. Ancillary propagation covered work occurring solely consequence using peer--peer transmission receive copy likewise require acceptance. However, nothing License grants permission propagate modify covered work. actions infringe copyright accept License. Therefore, modifying propagating covered work, indicate acceptance License .","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_10-automatic-licensing-of-downstream-recipients","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"10. Automatic Licensing of Downstream Recipients","title":"GNU General Public License","text":"time convey covered work, recipient automatically receives license original licensors, run, modify propagate work, subject License. responsible enforcing compliance third parties License. “entity transaction” transaction transferring control organization, substantially assets one, subdividing organization, merging organizations. propagation covered work results entity transaction, party transaction receives copy work also receives whatever licenses work party’s predecessor interest give previous paragraph, plus right possession Corresponding Source work predecessor interest, predecessor can get reasonable efforts. may impose restrictions exercise rights granted affirmed License. example, may impose license fee, royalty, charge exercise rights granted License, may initiate litigation (including cross-claim counterclaim lawsuit) alleging patent claim infringed making, using, selling, offering sale, importing Program portion .","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_11-patents","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"11. Patents","title":"GNU General Public License","text":"“contributor” copyright holder authorizes use License Program work Program based. work thus licensed called contributor’s “contributor version”. contributor’s “essential patent claims” patent claims owned controlled contributor, whether already acquired hereafter acquired, infringed manner, permitted License, making, using, selling contributor version, include claims infringed consequence modification contributor version. purposes definition, “control” includes right grant patent sublicenses manner consistent requirements License. contributor grants non-exclusive, worldwide, royalty-free patent license contributor’s essential patent claims, make, use, sell, offer sale, import otherwise run, modify propagate contents contributor version. following three paragraphs, “patent license” express agreement commitment, however denominated, enforce patent (express permission practice patent covenant sue patent infringement). “grant” patent license party means make agreement commitment enforce patent party. convey covered work, knowingly relying patent license, Corresponding Source work available anyone copy, free charge terms License, publicly available network server readily accessible means, must either (1) cause Corresponding Source available, (2) arrange deprive benefit patent license particular work, (3) arrange, manner consistent requirements License, extend patent license downstream recipients. “Knowingly relying” means actual knowledge , patent license, conveying covered work country, recipient’s use covered work country, infringe one identifiable patents country reason believe valid. , pursuant connection single transaction arrangement, convey, propagate procuring conveyance , covered work, grant patent license parties receiving covered work authorizing use, propagate, modify convey specific copy covered work, patent license grant automatically extended recipients covered work works based . patent license “discriminatory” include within scope coverage, prohibits exercise , conditioned non-exercise one rights specifically granted License. may convey covered work party arrangement third party business distributing software, make payment third party based extent activity conveying work, third party grants, parties receive covered work , discriminatory patent license () connection copies covered work conveyed (copies made copies), (b) primarily connection specific products compilations contain covered work, unless entered arrangement, patent license granted, prior 28 March 2007. Nothing License shall construed excluding limiting implied license defenses infringement may otherwise available applicable patent law.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_12-no-surrender-of-others-freedom","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"12. No Surrender of Others’ Freedom","title":"GNU General Public License","text":"conditions imposed (whether court order, agreement otherwise) contradict conditions License, excuse conditions License. convey covered work satisfy simultaneously obligations License pertinent obligations, consequence may convey . example, agree terms obligate collect royalty conveying convey Program, way satisfy terms License refrain entirely conveying Program.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_13-use-with-the-gnu-affero-general-public-license","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"13. Use with the GNU Affero General Public License","title":"GNU General Public License","text":"Notwithstanding provision License, permission link combine covered work work licensed version 3 GNU Affero General Public License single combined work, convey resulting work. terms License continue apply part covered work, special requirements GNU Affero General Public License, section 13, concerning interaction network apply combination .","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_14-revised-versions-of-this-license","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"14. Revised Versions of this License","title":"GNU General Public License","text":"Free Software Foundation may publish revised /new versions GNU General Public License time time. new versions similar spirit present version, may differ detail address new problems concerns. version given distinguishing version number. Program specifies certain numbered version GNU General Public License “later version” applies , option following terms conditions either numbered version later version published Free Software Foundation. Program specify version number GNU General Public License, may choose version ever published Free Software Foundation. Program specifies proxy can decide future versions GNU General Public License can used, proxy’s public statement acceptance version permanently authorizes choose version Program. Later license versions may give additional different permissions. However, additional obligations imposed author copyright holder result choosing follow later version.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_15-disclaimer-of-warranty","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"15. Disclaimer of Warranty","title":"GNU General Public License","text":"WARRANTY PROGRAM, EXTENT PERMITTED APPLICABLE LAW. EXCEPT OTHERWISE STATED WRITING COPYRIGHT HOLDERS /PARTIES PROVIDE PROGRAM “” WITHOUT WARRANTY KIND, EITHER EXPRESSED IMPLIED, INCLUDING, LIMITED , IMPLIED WARRANTIES MERCHANTABILITY FITNESS PARTICULAR PURPOSE. ENTIRE RISK QUALITY PERFORMANCE PROGRAM . PROGRAM PROVE DEFECTIVE, ASSUME COST NECESSARY SERVICING, REPAIR CORRECTION.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_16-limitation-of-liability","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"16. Limitation of Liability","title":"GNU General Public License","text":"EVENT UNLESS REQUIRED APPLICABLE LAW AGREED WRITING COPYRIGHT HOLDER, PARTY MODIFIES /CONVEYS PROGRAM PERMITTED , LIABLE DAMAGES, INCLUDING GENERAL, SPECIAL, INCIDENTAL CONSEQUENTIAL DAMAGES ARISING USE INABILITY USE PROGRAM (INCLUDING LIMITED LOSS DATA DATA RENDERED INACCURATE LOSSES SUSTAINED THIRD PARTIES FAILURE PROGRAM OPERATE PROGRAMS), EVEN HOLDER PARTY ADVISED POSSIBILITY DAMAGES.","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"id_17-interpretation-of-sections-15-and-16","dir":"","previous_headings":"TERMS AND CONDITIONS","what":"17. Interpretation of Sections 15 and 16","title":"GNU General Public License","text":"disclaimer warranty limitation liability provided given local legal effect according terms, reviewing courts shall apply local law closely approximates absolute waiver civil liability connection Program, unless warranty assumption liability accompanies copy Program return fee. END TERMS CONDITIONS","code":""},{"path":"https://nbisweden.github.io/genecovr/LICENSE.html","id":"how-to-apply-these-terms-to-your-new-programs","dir":"","previous_headings":"","what":"How to Apply These Terms to Your New Programs","title":"GNU General Public License","text":"develop new program, want greatest possible use public, best way achieve make free software everyone can redistribute change terms. , attach following notices program. safest attach start source file effectively state exclusion warranty; file least “copyright” line pointer full notice found. Also add information contact electronic paper mail. program terminal interaction, make output short notice like starts interactive mode: hypothetical commands show w show c show appropriate parts General Public License. course, program’s commands might different; GUI interface, use “box”. also get employer (work programmer) school, , sign “copyright disclaimer” program, necessary. information , apply follow GNU GPL, see . GNU General Public License permit incorporating program proprietary programs. program subroutine library, may consider useful permit linking proprietary applications library. want , use GNU Lesser General Public License instead License. first, please read .","code":" Copyright (C) 2020 Per Unneberg This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . genecovr Copyright (C) 2020 Per Unneberg This program comes with ABSOLUTELY NO WARRANTY; for details type 'show w'. This is free software, and you are welcome to redistribute it under certain conditions; type 'show c' for details."},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"about","dir":"Articles","previous_headings":"","what":"About","title":"Gene body coverage analysis in R","text":"vignette describes analyses gene body coverage genome assembly evaluation metrics R using genecovr package. genecovr contains functionality parsing alignment files, calculating gene body coverages, generating simple QC metrics assess assembly quality output. start example analysis, describe genecovr represents pairwise alignments.","code":""},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"r-setup","dir":"Articles","previous_headings":"About","what":"R setup","title":"Gene body coverage analysis in R","text":"","code":"library(genecovr) library(ggplot2) library(S4Vectors) library(tidyr) library(rlang) library(viridis) library(RColorBrewer) bw <- theme_bw(base_size = 18) %+replace% theme(axis.text.x = element_text(angle = 45, hjust = 1, vjust = 1)) theme_set(bw) color_pal_4 <- brewer.pal(name = \"Paired\", n = 4) psize <- 3"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"on-object-representation-of-pairwise-sequence-alignments","dir":"Articles","previous_headings":"About","what":"On object representation of pairwise sequence alignments","title":"Gene body coverage analysis in R","text":"genecovr functionality read pairwise sequence alignment files converts pairwise alignments genecovr::AlignmentPairs objects. AlignmentPairs object subclass Bioconductor class S4Vectors::Pairs. Pairs object turn aligns two vectors along slot names first second, AlignmentPairs object adds slots query subject, possibly extra slots related additional information alignment file. query subject GenomicRanges::GRanges objects objects derived GRangesclass.","code":""},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"analysing-gene-body-coverage","dir":"Articles","previous_headings":"","what":"Analysing gene body coverage","title":"Gene body coverage analysis in R","text":"section analyse mapping transcriptome non-polished polished assembly. mapping results consist two gmap files psl format, transcripts2nonpolished.psl transcripts2polished.psl. addition fasta index files assemblies (nonpolished.fai polished.fai) transcriptome (transcripts.fai). fasta indices used generate GenomeInfoDb::Seqinfo objects can used set sequence information parsed output. load fasta indices parse psl files genecovr::readPsl, storing results genecovr::AlignmentPairsList convenience.","code":"assembly_fai_fn <- list( nonpol = system.file(\"extdata\", \"nonpolished.fai\", package = \"genecovr\" ), pol = system.file(\"extdata\", \"polished.fai\", package = \"genecovr\" ) ) transcripts_fai_fn <- list( nonpol = system.file(\"extdata\", \"transcripts.fai\", package = \"genecovr\" ), pol = system.file(\"extdata\", \"transcripts.fai\", package = \"genecovr\" ) ) assembly_sinfo <- endoapply(assembly_fai_fn, readFastaIndex) transcripts_sinfo <- endoapply(transcripts_fai_fn, readFastaIndex) psl_fn <- list( nonpol = system.file(\"extdata\", \"transcripts2nonpolished.psl\", package = \"genecovr\" ), pol = system.file(\"extdata\", \"transcripts2polished.psl\", package = \"genecovr\" ) ) apl <- AlignmentPairsList( lapply(names(psl_fn), function(x) { readPsl(psl_fn[[x]], seqinfo.sbjct = assembly_sinfo[[x]], seqinfo.query = transcripts_sinfo[[x]] ) }) ) names(apl) <- names(psl_fn)"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"plot-ratio-matches-to-width-of-alignment-regions","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Plot ratio matches to width of alignment regions","title":"Gene body coverage analysis in R","text":"first plot ratio matches width alignments respect transcripts. clear shift higher percentage matches polished assembly, expected.","code":"plot(apl, aes(x = id, y = matches / query.width, fill = id), which = \"violin\") + ylim(0.8, 1) + scale_fill_viridis_d()"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"plot-summary-indel-and-match-distributions","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Plot summary indel and match distributions","title":"Gene body coverage analysis in R","text":"can also select multiple columns plot genecovr::AlignmentPairsList.","code":"cnames <- c(\"misMatches\", \"query.NumInsert\", \"query.BaseInsert\") plot(apl, aes(x = id, y = get_expr(enquo(cnames))), which = \"violin\") + facet_wrap(. ~ name, scales = \"free\") plot(apl, aes(x = id, y = get_expr(enquo(cnames))), which = \"boxplot\") + facet_wrap(. ~ name, scales = \"free\") plot(apl, aes(x = id, y = get_expr(enquo(cnames))), which = \"boxplot\") + facet_wrap(. ~ name, scales = \"free\") + scale_y_continuous(trans = \"log10\")"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"plot-number-of-indels","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Plot number of indels","title":"Gene body coverage analysis in R","text":"function genecovr::insertionSummary summarizes number insertions, either transcript level (default) per alignment. intuition assembly quality improves, number indels go . First show plot number insertions per alignment. consequence transcript may split multiple alignments, bars unequal height. alternative summarize number insertions transcript. Currently, consideration taken overlapping alignments, meaning insertions may counted . improvement use non-overlapping set alignments fewest number insertions.","code":"x <- insertionSummary(apl, reduce = FALSE) ggplot(x, aes(id)) + geom_bar(aes(fill = cuts)) + scale_fill_viridis_d(name = \"qNumInsert\", begin = 1, end = 0) x <- insertionSummary(apl) ggplot(x, aes(id)) + geom_bar(aes(fill = cuts)) + scale_fill_viridis_d(name = \"qNumInsert\", begin = 1, end = 0)"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"gene-body-coverage","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Gene body coverage","title":"Gene body coverage analysis in R","text":"function genecovr::geneBodyCoverage takes AlignmentPairs object summarizes breadth coverage number subject hits per transcript. summary can obtained genecovr::summarizeGeneBodyCoverage function. define range minimum match hit cutoffs filter hits matches aligned region. combine data plot resulting coverages","code":"gbc <- lapply(apl, geneBodyCoverage, min.match = 0.1) min.match <- c(0.25, 0.5, 0.75, 0.9) names(min.match) <- min.match gbc_summary <- lapply(apl, function(x) { y <- do.call(\"rbind\", lapply(min.match, function(mm) { summarizeGeneBodyCoverage(x, min.match = mm) })) }) library(dplyr) data <- dplyr::bind_rows(lapply(gbc_summary, data.frame), .id = \"dataset\") h <- max(data$total) hmax <- ceiling(h / 100) * 100 ggplot( subset(data, min.match == 0.25), aes(x = min.coverage, y = count, group = dataset, color = dataset) ) + geom_abline(slope = 0, intercept = h) + geom_point(aes(shape = dataset, color = dataset), size = psize) + geom_line() + scale_color_viridis_d() + scale_y_continuous(breaks = c(pretty(data$count)), limits = c(0, hmax))"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"number-of-contigs-per-transcript","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Number of contigs per transcript","title":"Gene body coverage analysis in R","text":"fragmented assembly lead transcripts mapping several contigs. calculate number subjects coverage cutoff function genecovr::countSubjectsByCoverage plot results","code":"data <- dplyr::bind_rows( lapply( lapply(apl, countSubjectsByCoverage), data.frame ), .id = \"dataset\" ) ggplot(data = data, aes( x = factor(min.coverage), y = Freq, fill = n.subjects )) + geom_bar(stat = \"identity\", position = position_stack()) + scale_fill_viridis_d(begin = 1, end = 0) + facet_wrap(. ~ dataset, nrow = 1, labeller = label_both)"},{"path":"https://nbisweden.github.io/genecovr/articles/genecovr.html","id":"duplicated-versus-split-transcripts","dir":"Articles","previous_headings":"Analysing gene body coverage","what":"Duplicated versus split transcripts","title":"Gene body coverage analysis in R","text":"Transcripts map one contig anything split contigs duplicated entirely subjects. One way investigate whether trancripts split duplicated plot depth coverage divided breadth coverage length-normalized coverage. First combine data: plot ratio depthOfCoverage / breadthOfCoverage length-normalized coverage Alternatively can make jitter plot depthOfCoverage breadthOfCoverage number subjects. similar picture obtained via histogram plot. Finally, assess whether length bias ratio condition number subjects per transcript.","code":"data <- dplyr::bind_rows( lapply( lapply(apl, geneBodyCoverage), data.frame ), .id = \"dataset\" ) ggplot(data = data, aes( x = coverage, y = depthOfCoverage / breadthOfCoverage, color = factor(n.subjects) )) + geom_point(size = psize) + scale_color_viridis_d(alpha = .8) + xlim(0, 1) + ylim(0, 5) + facet_wrap(. ~ dataset) ggplot( data = subset(data, n.subjects > 1), aes(x = factor(dataset), y = depthOfCoverage / breadthOfCoverage) ) + geom_jitter(size = psize, alpha = .6) + facet_wrap(. ~ n.subjects) ggplot( data = subset(data, n.subjects > 1), aes(depthOfCoverage / breadthOfCoverage) ) + geom_histogram() + facet_grid(vars(dataset)) ggplot( data = subset(data, n.subjects > 1), aes(x = factor(dataset), y = seqlengths) ) + geom_boxplot() + facet_grid(. ~ n.subjects)"},{"path":"https://nbisweden.github.io/genecovr/authors.html","id":null,"dir":"","previous_headings":"","what":"Authors","title":"Authors and Citation","text":"Per Unneberg. Author, maintainer.","code":""},{"path":"https://nbisweden.github.io/genecovr/authors.html","id":"citation","dir":"","previous_headings":"","what":"Citation","title":"Authors and Citation","text":"Unneberg P (2023). genecovr: Gene body coverage analysis evaluate genome assemblies. R package version 0.1.0, https://nbisweden.github.io/genecovr/.","code":"@Manual{, title = {genecovr: Gene body coverage analysis to evaluate genome assemblies}, author = {Per Unneberg}, year = {2023}, note = {R package version 0.1.0}, url = {https://nbisweden.github.io/genecovr/}, }"},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"genecovr","dir":"","previous_headings":"","what":"Gene body coverage analysis to evaluate genome assemblies","title":"Gene body coverage analysis to evaluate genome assemblies","text":"genecovr R package provides plotting functions summarize gene transcript genome alignments. main purpose assess effect polishing scaffolding operations quality genome assembly. gene transcript set large sequence set consisting assembled transcripts RNA-seq data generated relation genome assembly project. Therefore, genecovr serves complement software BUSCO, evaluates genome assembly quality using smaller set well-defined single-copy orthologs.","code":""},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"installation","dir":"","previous_headings":"","what":"Installation","title":"Gene body coverage analysis to evaluate genome assemblies","text":"can install released version genecovr NBIS GitHub :","code":"# If necessary, uncomment to install devtools # install.packages(\"devtools\") devtools::install_github(\"NBISweden/genecovr\")"},{"path":[]},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"genecovr-script-quick-start","dir":"","previous_headings":"Usage","what":"genecovr script quick start","title":"Gene body coverage analysis to evaluate genome assemblies","text":"helper script generating basic plots located PACKAGE_DIR/bin/genecovr. Create data input csv-delimited file columns data label mapping file (supported formats: psl) assembly file (fasta fasta index) transcript file (fasta fasta index) Columns 3 4 can set missing value (NA) case sequence sizes inferred alignment files. run script generate plots:","code":"PACKAGE_DIR/bin/genecovr indata.csv"},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"example","dir":"","previous_headings":"Usage > genecovr script quick start","what":"Example","title":"Gene body coverage analysis to evaluate genome assemblies","text":"example files located PACKAGE_DIR/inst/extdata consisting two psl alignment files containing gmap alignments fasta indices transcript sequences two different assembly versions: nonpolished.fai - fasta index raw assembly polished.fai - fasta index polished assembly transcripts.fai - fasta index transcript sequences transcripts2nonpolished.psl - gmap alignments, transcripts raw assembly transcripts2polished.psl - gmap alignments, transcripts polished assembly Using files labels non pol different assemblies, genecovr input file (called e.g., assemblies.csv) look follows: command run :","code":"nonpol,transcripts2nonpolished.psl,nonpolished.fai,transcripts.fai pol,transcripts2polished.psl,polished.fai,transcripts.fai genecovr assemblies.csv"},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"genecovr-options","dir":"","previous_headings":"Usage > genecovr script quick start","what":"genecovr options","title":"Gene body coverage analysis to evaluate genome assemblies","text":"list genecovr script options, type ’genecovr -h`:","code":"usage: genecovr [-h] [-v] [-p number] [-d OUTPUT_DIRECTORY] [--height HEIGHT] [--width WIDTH] csvfile positional arguments: csvfile csv-delimited file with columns 1. data label 2. mapping file (supported formats: psl) 3. assembly file (fasta or fasta index) 4. transcript file (fasta or fasta index) optional arguments: -h, --help show this help message and exit -v, --verbose print extra output -p number, --cpus number number of cpus [default 1] -d OUTPUT_DIRECTORY, --output-directory OUTPUT_DIRECTORY output directory --height HEIGHT figure height in inches [default 6.0] --width WIDTH figure width in inches [default 6.0]"},{"path":"https://nbisweden.github.io/genecovr/index.html","id":"r-package-vignette","dir":"","previous_headings":"Usage","what":"R package vignette","title":"Gene body coverage analysis to evaluate genome assemblies","text":"Alternatively, import library R script use package functions. See Get started run vignette(\"genecovr\") minimum working example.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":null,"dir":"Reference","previous_headings":"","what":"Representation of an alignment pair — AlignmentPairs-class","title":"Representation of an alignment pair — AlignmentPairs-class","text":"Pairs subclass Constructor AlignmentPairs","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Representation of an alignment pair — AlignmentPairs-class","text":"","code":"AlignmentPairs(query, subject, ...) # S4 method for GRanges,GRanges AlignmentPairs(query, subject, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Representation of an alignment pair — AlignmentPairs-class","text":"query vectorized object representing query subject vectorized object representing subject ... Arguments pass constructor","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Representation of an alignment pair — AlignmentPairs-class","text":"AlignmentPairs object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Representation of an alignment pair — AlignmentPairs-class","text":"AlignmentPairs class extends Pairs-class","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairs-class.html","id":"constructor","dir":"Reference","previous_headings":"","what":"Constructor","title":"Representation of an alignment pair — AlignmentPairs-class","text":"AlignmentPairs(query, subject, ...): Constructs AlignmentPairs object aligning vectors query subject.","code":""},{"path":[]},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":null,"dir":"Reference","previous_headings":"","what":"List of AlignmentPairs instances — AlignmentPairsList-class","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"Subclass S4Vectors SimpleList, entry AlignmentPairs object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"","code":"AlignmentPairsList(obj, ...) # S4 method for list AlignmentPairsList(obj)"},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"obj list ... ellipsis","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"AlignmentPairsList object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/AlignmentPairsList-class.html","id":"constructor","dir":"Reference","previous_headings":"","what":"Constructor","title":"List of AlignmentPairs instances — AlignmentPairsList-class","text":"AlignmentPairsList(obj, ...): Constructs AlignmentPairsList object input","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":null,"dir":"Reference","previous_headings":"","what":"as.data.frame — as.data.frame,AlignmentPairsList-method","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"Convert AlignmentPairsList data.frame.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"","code":"# S4 method for AlignmentPairsList as.data.frame(x, ..., .id = \"id\")"},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"x AlignmentPairsList object ... additional parameters lapply .id name id column added dplyr::bind_rows","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/as.data.frame-AlignmentPairsList-method.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"as.data.frame — as.data.frame,AlignmentPairsList-method","text":"data.frame","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/autoplot.AlignmentPairsList.html","id":null,"dir":"Reference","previous_headings":"","what":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","title":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","text":"autoplot.AlignmentPairsList","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/autoplot.AlignmentPairsList.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","text":"","code":"# S3 method for AlignmentPairsList autoplot(object, aes, vars, ..., which = \"point\")"},{"path":"https://nbisweden.github.io/genecovr/reference/autoplot.AlignmentPairsList.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"autoplot.AlignmentPairsList — autoplot.AlignmentPairsList","text":"object AlignmentPairsList aes aes mapping vars variable mapping facet plots ... additional parameters ggplot function plot make. 'grid' option makes scatter plot marginal densities","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"breadthOfCoverage — breadthOfCoverage","title":"breadthOfCoverage — breadthOfCoverage","text":"Calculate breadth coverage sequence id","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"breadthOfCoverage — breadthOfCoverage","text":"","code":"breadthOfCoverage(x)"},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"breadthOfCoverage — breadthOfCoverage","text":"x GRangesList object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/breadthOfCoverage.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"breadthOfCoverage — breadthOfCoverage","text":"integer representing sum range widths","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/countSubjectsByCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"countSubjectsByCoverage — countSubjectsByCoverage","title":"countSubjectsByCoverage — countSubjectsByCoverage","text":"countSubjectsByCoverage","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/countSubjectsByCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"countSubjectsByCoverage — countSubjectsByCoverage","text":"","code":"countSubjectsByCoverage( x, min.coverage = seq(0.25, 1, 0.25), min.match = 0.9, nmax = 5 )"},{"path":"https://nbisweden.github.io/genecovr/reference/countSubjectsByCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"countSubjectsByCoverage — countSubjectsByCoverage","text":"x AlignmentPairs DataFrame object min.coverage coverage cutoffs apply transcripts min.match filter hits fraction matching bases less min.match nmax maximum number subjects count","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Get deletions from an alignment. — deletions","title":"Get deletions from an alignment. — deletions","text":"Get deletions alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get deletions from an alignment. — deletions","text":"","code":"deletions(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get deletions from an alignment. — deletions","text":"x Object representation sequence alignment ... Additional argument list","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/deletions-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get deletions from an alignment. — deletions","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Get divergence from an alignment — divergence","title":"Get divergence from an alignment — divergence","text":"Get divergence alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get divergence from an alignment — divergence","text":"","code":"divergence(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get divergence from an alignment — divergence","text":"x Object representation sequence alignment ... Additional argument list","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/divergence-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get divergence from an alignment — divergence","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"Get gene body coverage — geneBodyCoverage","title":"Get gene body coverage — geneBodyCoverage","text":"geneBodyCoverage(obj, ...): calculate gene body coverage input Calculate geneBodyCoverage query sequences","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get gene body coverage — geneBodyCoverage","text":"","code":"geneBodyCoverage(obj, ...) # S4 method for AlignmentPairs geneBodyCoverage(obj, min.match = 0.9) # S4 method for AlignmentPairsList geneBodyCoverage(obj, min.match = 0.9, bpparam = NULL)"},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get gene body coverage — geneBodyCoverage","text":"obj AlignmentPairs object ... additional parameters min.match filter hits fraction matching bases less min.match bpparam BiocParallel parameter object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get gene body coverage — geneBodyCoverage","text":"reduced filtered DataFrame object row transcript. See @details information seqnames seqlengths columns collected corresponding seqinfo object. breadthOfCoverage total width reduced regions transcript corresponds much transcript covered. Dividing breadthOfCoverage total transcript length gives coverage fraction. depthOfCoverage sums ranges estimate many times range present. Dividing depthOfCoverage breadthOfCoverage indicates multiplicity query. queries map multiple subjects, value close 1 indicates query split several subjects, whereas higher value indicates sequence duplication subject level.","code":"The revmap column maps the output ranges to the input ranges as lists of numerical ids. These ids can be used to retrieve the corresponding AlignmentPairs ranges providing a link to the subjects. The hitCoverage lists the width of each reduced hit, and hitStart and hitEnd provide the transcript coordinates of these hits."},{"path":"https://nbisweden.github.io/genecovr/reference/geneBodyCoverage.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"Get gene body coverage — geneBodyCoverage","text":"Given AlignmentPairs object, calculate gene body coverages query sequences. regions. instance, one hit spans coordinates 100-400 another 200-500, merge 100-500. function calculates many overlaps merged, rationale >1 overlaps seqname, sequence associated multiple distinct regions subject sequence. Thus, unit interest query, function seeks identify reduced disjoint regions query sequence map subject.","code":"The function returns a GRanges object with reduced regions, i.e. overlaps are merged. Information about matches and mismatches is currently dropped as it usually is not possible to infer where mismatches occur. Instead, the data column `coverage` simply holds the ratio of the width of the region to the transcript length. Summing up coverages from disjoint regions then gives total coverage of the transcript. The cutoff is used to filter regions based on the ratio of matches to the width of the region. Since the association between query and subject regions is removed, the return value is a GRanges object consisting of the reduced query ranges with a revmap and coverage attribute."},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":null,"dir":"Reference","previous_headings":"","what":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"Gene body coverage analysis evaluate genome assemblies.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"genecovr package provides functionality evaluating gene body coverage metrics genome assemblies. central measurement unit gene transcript model.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":"functions","dir":"Reference","previous_headings":"","what":"Functions","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"autoplot: plot GRanges objects gene body coverage metrics","code":""},{"path":[]},{"path":"https://nbisweden.github.io/genecovr/reference/genecovr-package.html","id":"author","dir":"Reference","previous_headings":"","what":"Author","title":"genecovr: Gene body coverage analysis to evaluate genome assemblies — genecovr-package","text":"Maintainer: Per Unneberg per.unneberg@nbis.se (ORCID)","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Get insertions from an alignment — insertions","title":"Get insertions from an alignment — insertions","text":"Get insertions alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Get insertions from an alignment — insertions","text":"","code":"insertions(x, ...) # S4 method for GRanges insertions(x, as.bases = FALSE, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Get insertions from an alignment — insertions","text":"x Object representation sequence alignment ... Additional argument list .bases Get insertions base pairs","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/insertions-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Get insertions from an alignment — insertions","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"matches — matches","title":"matches — matches","text":"Get matches alignment. Get mismatches alignment. Get matches parts repeats alignment.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"matches — matches","text":"","code":"matches(x, ...) mismatches(x, ...) repmatches(x, ...) # S4 method for AlignmentPairs matches(x) # S4 method for AlignmentPairs mismatches(x) # S4 method for AlignmentPairs repmatches(x)"},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"matches — matches","text":"x Object representation sequence alignment ... Additional argument list","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/matches-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"matches — matches","text":"numeric numeric numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/plot.AlignmentPairsList.html","id":null,"dir":"Reference","previous_headings":"","what":"plot — plot.AlignmentPairsList","title":"plot — plot.AlignmentPairsList","text":"plot AlignmentPairsList","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/plot.AlignmentPairsList.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"plot — plot.AlignmentPairsList","text":"","code":"# S3 method for AlignmentPairsList plot(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/plot.AlignmentPairsList.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"plot — plot.AlignmentPairsList","text":"x object plot ... additional arguments autoplot","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/psl-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"methods-psl — psl methods","title":"methods-psl — psl methods","text":"Methods dealing psl data","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/psl-methods.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"methods-psl — psl methods","text":"Methods dealing Pattern Space Layout (psl) file format. See http://genome.ucsc.edu/FAQ/FAQformat.html information.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Retrieve query from object — query","title":"Retrieve query from object — query","text":"object query slot retrieve query object. object query slot set query.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Retrieve query from object — query","text":"","code":"query(x, ...) query(x) <- value # S4 method for AlignmentPairs query(x) # S4 method for AlignmentPairs,GRanges query(x) <- value"},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Retrieve query from object — query","text":"x object representing alignment ... Additional arguments value object representing query","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/query-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Retrieve query from object — query","text":"query object object representing alignment updated query slot","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":null,"dir":"Reference","previous_headings":"","what":"readFastaIndex — readFastaIndex","title":"readFastaIndex — readFastaIndex","text":"Read fasta index file","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"readFastaIndex — readFastaIndex","text":"","code":"readFastaIndex(fai, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"readFastaIndex — readFastaIndex","text":"fai fasta index file ... additional parameters pass GenomeInfoDb::Seqinfo","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"readFastaIndex — readFastaIndex","text":"Seqinfo object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readFastaIndex.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"readFastaIndex — readFastaIndex","text":"","code":"fai <- system.file(\"extdata\", \"polished.fai\", package=\"genecovr\") sinfo <- readFastaIndex(fai)"},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":null,"dir":"Reference","previous_headings":"","what":"readPsl — readPsl","title":"readPsl — readPsl","text":"Read psl output","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"readPsl — readPsl","text":"","code":"readPsl( filename, seqinfo.query = NULL, seqinfo.sbjct = NULL, metadata = list(), ... )"},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"readPsl — readPsl","text":"filename input filename seqinfo.query Seqinfo object query (transcripts) seqinfo.sbjct Seqinfo object subject (reference) metadata metadata AlignmentPairs result ... additional parameters","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"readPsl — readPsl","text":"AlignmentPairs object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"readPsl — readPsl","text":"Parse Pattern Space Layout (psl) file; see http://genome.ucsc.edu/FAQ/FAQformat.html information psl file format","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/readPsl.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"readPsl — readPsl","text":"","code":"fn <- system.file(\"extdata\", \"transcripts2polished.psl\", package=\"genecovr\") ap <- readPsl(fn) #> reading file /home/runner/work/_temp/Library/genecovr/extdata/transcripts2polished.psl #> manually inferring seqinfo for query #> manually inferring seqinfo for subject #> Processed 239 lines in 0.078 secs"},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"reduceHitCoverage — reduceHitCoverage","title":"reduceHitCoverage — reduceHitCoverage","text":"Reduce hit coverage seqname","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"reduceHitCoverage — reduceHitCoverage","text":"","code":"reduceHitCoverage(x, min.match = 0.9)"},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"reduceHitCoverage — reduceHitCoverage","text":"x AlignmentPairs object min.match filter hits fraction matching bases less min.match","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"reduceHitCoverage — reduceHitCoverage","text":"reduced filtered GRanges object","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"details","dir":"Reference","previous_headings":"","what":"Details","title":"reduceHitCoverage — reduceHitCoverage","text":"Given AlignmentPairs object, reduce overlapping query regions. instance, one hit spans coordinates 100-400 another 200-500, merge 100-500. function calculates many overlaps merged, rationale >1 overlaps seqname, sequence associated multiple distinct regions subject sequence. Thus, unit interest query, function seeks identify reduced disjoint regions query sequence map subject.","code":"The function returns a GRanges object with reduced regions, i.e. overlaps are merged. Information about matches and mismatches is currently dropped as it usually is not possible to infer where mismatches occur. Instead, the data column `coverage` simply holds the ratio of the width of the region to the transcript length. Summing up coverages from disjoint regions then gives total coverage of the transcript. The cutoff is used to filter regions based on the ratio of matches to the width of the region. Since the association between query and subject regions is removed, the return value is a GRanges object consisting of the reduced query ranges with a revmap and coverage attribute."},{"path":"https://nbisweden.github.io/genecovr/reference/reduceHitCoverage.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"reduceHitCoverage — reduceHitCoverage","text":"","code":"ranges <- IRanges::IRanges( start=c(100, 200, 700), end=c(400, 500, 1000) ) qry <- GenomicRanges::GRanges( ranges=ranges, seqnames=c(\"t1\"), seqinfo=GenomeInfoDb::Seqinfo(seqnames=c(\"t1\"), seqlengths=c(1050)) ) ranges <- IRanges::IRanges( start=c(1000, 1000, 1000), end=c(1300, 1300, 1300) ) sbj <- GenomicRanges::GRanges(ranges=ranges, seqnames=c(\"c1\", \"c2\", \"c1\")) x <- AlignmentPairs(query=qry, subject=sbj, matches=c(300, 290, 280)) if (FALSE) gr <- reduceHitCoverage(x, 0.1)"},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Retrieve subject from object — sbjct","title":"Retrieve subject from object — sbjct","text":"object subject slot retrieve subject object. object subject slot set subject.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Retrieve subject from object — sbjct","text":"","code":"sbjct(x, ...) sbjct(x) <- value # S4 method for AlignmentPairs sbjct(x) # S4 method for AlignmentPairs,GRanges sbjct(x) <- value"},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Retrieve subject from object — sbjct","text":"x object representing alignment ... Additional arguments value object representing subject","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/sbjct-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Retrieve subject from object — sbjct","text":"object representing subject object representing alignment updated subject slot","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"Retrieve score from object — score","title":"Retrieve score from object — score","text":"object score slot retrieve score object.","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Retrieve score from object — score","text":"","code":"score(x, ...)"},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Retrieve score from object — score","text":"x object representing alignment ... Additional arguments","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/score-methods.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Retrieve score from object — score","text":"numeric","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/sequence-data-methods.html","id":null,"dir":"Reference","previous_headings":"","what":"methods-sequence-data — sequence data methods","title":"methods-sequence-data — sequence data methods","text":"Methods dealing sequence data","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/summarizeGeneBodyCoverage.html","id":null,"dir":"Reference","previous_headings":"","what":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","title":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","text":"summarizeGeneBodyCoverage","code":""},{"path":"https://nbisweden.github.io/genecovr/reference/summarizeGeneBodyCoverage.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","text":"","code":"summarizeGeneBodyCoverage(x, min.coverage = seq(0, 1, 0.05), min.match = 0.9)"},{"path":"https://nbisweden.github.io/genecovr/reference/summarizeGeneBodyCoverage.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"summarizeGeneBodyCoverage — summarizeGeneBodyCoverage","text":"x AlignmentPairs DataFrame object min.coverage coverage cutoffs apply transcripts min.match filter hits fraction matching bases less min.match","code":""}]