PICB - piRNA Cluster Builder
IntroductionPICB (piRNA Cluster Builder) is a flexible toolkit for assembling, prioritizing, and characterizing piRNA clusters.
Table of contentspiRNAs (PIWI-interacting RNAs) and their PIWI protein partners play a key role in fertility and maintaining genome integrity by restricting mobile genetic elements (transposons) in germ cells. piRNAs originate from genomic regions which are called piRNA clusters.
PICB identifies genomic regions with a high density of piRNAs. This construction of piRNA clusters is performed through stepwise integration of unique and multimapping piRNAs.
Figure 1: PICB considers unique mapping piRNAs (NH=1), primary alignments of multimapping piRNAs (NH>1), and all possible alignments stepwise to build seeds, cores, and clusters. Find additional information in our recent publication.
Only very limited programming knowledge is needed to run PICB. Check out our step-by-step instructions and our demonstration below.
Please visit our publication for full context.
Getting startedPICB runs in R versions ≥ 4.2. to 4.4.
It is possible to run PICB in RStudio, in an R script on your local machine or with High Performance Computing (HPC) resources or in Jupyter Notebook (using R). Keep in mind that as for any handling of large-scale sequencing data you need to have sufficient memory on your device (or cluster) allocated.
1. Load dependencies in R environment
You will need to install and load the following required R packages:
install.packages(c("data.table", "seqinr", "openxlsx", "dplyr")) if (!require("BiocManager", quietly = TRUE)) install.packages("BiocManager") BiocManager::install(c("IRanges", "GenomicRanges", "GenomicAlignments", "Rsamtools", "Biostrings", "GenomeInfoDb", "BSgenome", "rtracklayer"))
💡 In case you have not worked with GRanges yet, we recommend reading the following GRanges Introduction.
2. Install PICB
PICB is available to install from any of the following sources. If you choose to install from GitHub, make sure to have either devtools or remotes installed.
Where Source Command R GitHub From GitHub repository:devtools::install_github("HaaseLab/PICB")
or remotes::install_github("HaaseLab/PICB")
Web Browser GitHub Download GitHub repository here. Now unzip the file and run install.packages("Downloads/PICB-main", repos=NULL, type="source")
in R. Terminal GitHub From GitHub repository: Clone Source Code: git clone https://github.com/HaaseLab/PICB.git
Now load PICB in your R environment:
From now on it gets even easier.
How to run PICBThere are just two required inputs: the BAM File and the Reference Genome.
Checklist for having the right BAM File
PICB stops when these requirements are not met and provides a descriptive error message.
Four options for providing the Reference Genome
# Example for Drosophila melanogaster, replace with your own genome - previous installation of BSgenome required library(BSgenome.Dmelanogaster.UCSC.dm6) myGenome <- "BSgenome.Dmelanogaster.UCSC.dm6"
myGenome <- GenomeInfoDb::Seqinfo( seqnames = c("chr2L", "chr2R", "chr3L", "chr3R", "chr4", "chrX", "chrY"), seqlengths = c(23513712, 25286936, 28110227, 32079331, 1348131, 23542271, 3667352))
Or use an existing Seqinfo
object:
myGenome <- GenomeInfoDb::Seqinfo(genome = "dm6")
myGenome <- PICBloadfasta(FASTA.NAME="/path/to/your/genome.fa")
PICBload
myAlignments <- PICBload( BAMFILE = bam_file, REFERENCE.GENOME = myGenome )
PICBbuild
myClusters <- PICBbuild( IN.ALIGNMENTS = myAlignments, REFERENCE.GENOME = myGenome )$clusters
💡 Both
PICBload
andPICBbuild
allow wide-ranging adjustments: Read the below section Parameter adjustments to adapt to sparse reference genomes and specific limitations of the data set.
Parameter adjustments💡 As described here,
PICBbuild
integrates unique mapping (seeds), primary multimapping (cores) and secondary alignments stepwise. You can access the outputs of the previous steps by using$seeds
or$cores
instead of$clusters
.
PICB allows wide-ranging parameter adjustments to adapt to e.g. sparse reference genomes and specific limitations of the data set. Tables of adjustments for both functions are shown below.
Click to show / hide: Parameters forPICBload
Required parameters:
Adjustable parameters:
Parameter Name Possible Values Default Value Explanation VERBOSE TRUE, FALSE TRUE Allows disabling progress messages while runningPICBload
. IS.SECONDARY.ALIGNMENT TRUE, FALSE, NA NA (all alignments) Determines which alignment types (primary multimappers and secondary multimappers) will be loaded. SEQ.LEVELS.STYLE character "UCSC" Allows changing the style of chromosome names in the output. Supported styles are listed in GenomeInfoDb::genomeStyles(). NA allows keeping all chromosomes from REFERENCE.GENOME and does not filter by standard linear chromosome names. STANDARD.CONTIGS.ONLY TRUE, FALSE TRUE Determines whether alignments from non-standard contigs are used. FILTER.BY.FLAG TRUE, FALSE TRUE Allows only those alignments with flag values present in the vector of allowed flags SELECT.FLAG. Default values of SELECT.FLAG are 0, 16, 272 and 256 (primary and secondary alignments on plus and minus strands). If FALSE, includes all flags. USE.SIZE.FILTER TRUE, FALSE TRUE Allows filtering of alignments based on size. Default value is 18-50 nt. TAGS vector c("NH","NM") Indicates list of tags to be extracted from given bam file. The “NH” tag is required to deduce if the alignment is unique mapping or multimapping. The “NM” is required to identify mismatches if required in further analysis. GET.ORIGINAL.SEQUENCE TRUE, FALSE FALSE Allows extraction of original read sequence from the bam file. SIMPLE.CIGAR TRUE, FALSE TRUE Allows filtering out spliced alignments. PERFECT.MATCH.ONLY TRUE, FALSE FALSE Allows filtering out alignments with mismatches. WHAT vector c(“flag”) Allows importing flags. Corresponds to “what” from ScanBamParam-class [Morgan M, Pagès H, Obenchain V, Hayden N (2023). Rsamtools: Binary alignment (BAM), FASTA, variant call (BCF), and tabix file import] Click to show / hide: Parameters for PICBbuild
Required parameters:
PICBload
)PICBload
)The library size can be adjusted as shown in our PICB demo, however in most cases this is not necessary.
Parameter Name Possible Values Default Value Explanation LIBRARY.SIZE numeric number of unique mapping alignments + number of primary multimapping alignments number of reads in the library VERBOSITY 0,1,2,3 2 Allows choosing the quantity of progress messages while runningPICBbuild
. Depending on VERBOSITY's value, printed messages are missing (0), include current processing step (1), include additionally current processing sub-step (2) or include chosen parameters for PICBbuild
) PROVIDE.NON.NORMALIZED TRUE, FALSE FALSE Includes non-normalized statistics in the output annotations COMPUTE.1U.10A.FRACTIONS TRUE, FALSE FALSE Calculates the fractions of piRNAs with a 1U (Uridine at the 5' most piRNA position) and a 10A (adenine at position 10). Requirement: GET.ORIGINAL.SEQUENCE set to TRUE in PICBload
PICBbuild integrates unique mapping (seeds), primary multimapping (cores) and secondary alignments stepwise using the sliding window algorithm. Each step allows following parameter adjustments.
Adjustable parameters for processing unique mapping alignments:
Parameter Name Possible Values Default Value Explanation UNIQUEMAPPERS.SLIDING.WINDOW.WIDTH numeric 350 nt Sets length of sliding windows for uniquely mapping alignments. UNIQUEMAPPERS.SLIDING.WINDOW.STEP numeric UNIQUEMAPPERS.SLIDING. WINDOW.WIDTH divided by 10 and rounded to the nearest numeric Sets distance between starts of the windows for uniquely mapping alignments. MIN.UNIQUE.ALIGNMENTS.PER.WINDOW numeric Value corresponding to 2 FPKM Sets coverage threshold for seed discovery. Corresponds to normalized counts of uniquely mapping alignments throughout the window (in FPKM). MIN.UNIQUE.SEQUENCES.PER.WINDOW numeric 1 per 50 nt of window length or MIN.UNIQUE.ALIGNMENTS.PER.WINDOW whichever is smaller Minimum number of distinct piRNA sequences within the sliding window. This parameter allows identification of clusters supported by a diverse set of piRNA sequences rather than a high number of reads from one or a few piRNA sequences.The called windows are reduced into seeds and further filtered:
Parameter Name Possible Values Default Value Explanation THRESHOLD.SEEDS.GAP numeric 0 nt Removes gaps between seeds if below the given length value. MIN.SEED.LENGTH numeric 2 * UNIQUEMAPPERS.SLIDING. WINDOW.WIDTH + 100 nt = 800 nt Removes seeds below a certain length (Default requires an actual piRNA coverage of at least 100 nt: UNIQUEMAPPERS.SLIDING.WINDOW.WIDTH (see above, default: 350 nt) at both the 5’ end and the 3’ end, thus making a 350+350+100=800 nt long seed). MIN.COVERED.SEED.LENGTH numeric 0 nt Allows filtering by minimum number of seed bases covered by unique mapping alignments.The next step includes primary multimapping alignments using a similar but simplified algorithm. Following parameters can be adjusted:
Parameter Name Possible Values Default Value Explanation PRIMARY.MULTIMAPPERS.SLIDING.WINDOW.WIDTH numeric 350 nt Sets lengths of sliding windows for primary multimapping alignments. PRIMARY.MULTIMAPPERS.SLIDING.WINDOW.STEP numeric PRIMARY.MULTIMAPPERS. SLIDING.WINDOW.WIDTH divided by 10 and rounded to the nearest integer Sets distances between starts of windows for primary multimapping alignments. MIN.PRIMARY.MULTIMAPING.ALIGNMENTS.PER.WINDOW numeric Value corresponding to 4 FPKM Sets coverage threshold for calling primary multimapping alignments windows. Corresponds to normalized counts of primary multimapping alignments throughout the window (in FPKM).These resulting windows are being reduced into cores and are further filtered:
Parameter Name Possible Values Default Value Explanation THRESHOLD.CORES.GAP numeric 0 nt Removes gaps between cores if below the given length value.Seeds and primary multimapping windows overlapping seeds merge into cores. Standalone seeds are also considered cores. Cores not overlapping with a seed are being filtered out as their transcription cannot be verified.
In the next step secondary alignments are processed identically as primary multimapping alignments. This step is dependent on whether PICBload
loaded the secondary alignments (parameter IS.SECONDARY.ALIGNMENT).
Cores and secondary alignments overlapping cores merge into clusters. Standalone cores are also considered clusters. piRNA clusters were formed and include all alignment information.
OutputThe output of PICBbuild
includes seeds, cores and clusters, each in GenomicRanges format. In Running PICB, we extracted directly the clusters using $clusters
. Extracting the seeds and cores can be done similarly using $seeds
and $cores
.
The clusters follow GRanges convention including the genomic coordinates (seqnames, ranges, and strand) and metacolumns. There are in total 9 metacolumns when running PICB with default parameters:
Click to show / hide: Output columns of PICBYou can use PICBoptimize
to find the optimal parameters for PICBbuild
for your dataset. This is especially useful if you are not sure about the quality of your data or your reference genome. The goal is to find a set of parameters that maximize the number of piRNAs accomodated in the clusters while minimizing genomic space occupied by the clusters.
Make sure to provide the values for the parameters as a vector. An example is shown below:
parameterExploration <- PICBoptimize( IN.ALIGNMENTS = myAlignments, REFERENCE.GENOME=myGenome, MIN.UNIQUE.ALIGNMENTS.PER.WINDOW=c(1,2,3,4,5) )
This function works on numerical parameters and returns a dataframe with any combination of your chosen parameters and their corresponding number of clusters, the total width of the clusters in nucleotides, the number of reads explained by the clusters, the mean RPKM of the clusters, the fraction of reads explained by the clusters and fraction of genomic space occupied by the clusters.
Be aware that for most datasets, the default parameters will yield great results and you do not need to optimize parameters.
Next to the standard analysis, PICBstrandanalysis
allows strand-specific analysis of piRNA clusters. The function computes the sense/antisense ratio of piRNAs per cluster (non-collapsed) and adds this information to a new metadata column (s_as_ratio
).
myClustersWithStrandAnalysis <- PICBstrandanalysis( IN.ALIGNMENTS = myAlignments, IN.RANGES = myClusters )
To visualize the sense/antisense ratio of the clusters, you can plot the sense/antisense ratio of the clusters in a violin plot. Higher numbers indicate a higher ratio of sense to antisense piRNAs, while values close to 1 indicate an equal ratio of sense and antisense piRNAs.
Let's give it a try - An ExampleIn the following, we would like to show you how easy it is to run PICB!
We created a demo to show you the most basic workflow with PICB. Download the sample subset of mapped reads and the corresponding R-based code in R Script or Jupyter Notebook format from the folder demo
. Though, if you feel extra brave today, feel free to direcly use your own bam file!
Step 1: Getting started with PICB
Follow the steps in Getting started to install PICB. Do not forget to load PICB with library(PICB)
.
Step 2: Data preparation
We showed different ways on how to load your genome. In the following the variant with using the BSgenome package. You will need to install your specific genome first. In our demo it is the Drosophila melanogaster genome.
library("BSgenome.Dmelanogaster.UCSC.dm6")
Now, let's store the genome into the variable myGenome
.
myGenome <- "BSgenome.Dmelanogaster.UCSC.dm6"
Step 3: Running PICB
Load the alignments with PICBload
.
myAlignments <- PICBload( BAMFILE = system.file("extdata","Fly_Ov1_chr2L_20To21mb_filtered.bam", package="PICB"), REFERENCE.GENOME = myGenome)
Next, we want to form the piRNA clusters using the PICBbuild
function. Usually you would not need to include the size of the library (LIBRARY.SIZE
) since PICB calculates it automatically. However, just for this demo, please include this parameter to adjust to the subset we chose to create this demo.
myClusters <- PICBbuild( IN.ALIGNMENTS = myAlignments, REFERENCE.GENOME = myGenome, LIBRARY.SIZE = 12799826 #usually not necessary )$clustersWe note that ranking piRNA clusters is essential for proper interpretation.
Authors, Citation and Acknowledgments💡 Keep in mind that you just run a demo. These are not representative clusters! Though you can apply these steps to your organism of choice and sequencing data. Have fun with PICB and your piRNA clusters!
Special thanks to all contributors and supporters that starred this repository.
Our authors:
Our PICB-team:
Visit the lab website of Astrid D. Haase, M.D., Ph.D.
Our Co-authors and support:
This project is licensed under the CC0.1.0 license - see the LICENSE file for details.
Do you like this project? Please join us or give a ⭐. Let us make piRNA clusters more comparable and easy to build!
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4