Seqanswers Leaderboard Ad

Collapse

Announcement

Collapse
No announcement yet.
X
 
  • Filter
  • Time
  • Show
Clear All
new posts

  • Left-normalisation of variants using R

    I'm writing a mitochondrial haplotyping script in R, and one of the things I needed to do was left-normalisation of INDELs. Because of the way the variants were originally defined, I'm using the notation <ref><pos><alt> for variants (e.g. ACCCCCTCTA8280A to describe a 9bp deletion at location 8280). Here's my script:

    Code:
    ## left-normalise INDELs                                                                                                                 
    ## derived from pseudocode from http://genome.sph.umich.edu/wiki/Variant_Normalization                                                   
    leftNorm <- function(ref.seq, ref, pos = NULL, alt = NULL){
        if(any(grepl("[0-9]",ref))){
            leftNorm(ref.seq=ref.seq,
                     ref=sub("^(.*?)([0-9]+)(.*)$","\\1",ref),
                     pos=as.numeric(sub("^(.*?)([0-9]+)(.*)$","\\2",ref)),
                     alt=sub("^(.*?)([0-9]+)(.*)$","\\3",ref));
        } else {
            equalRights <- (substring(ref,nchar(ref)) == substring(alt,nchar(alt)));
            while(sum(equalRights) > 0){
                substring(ref,nchar(ref))[equalRights] <- "";
                substring(alt,nchar(alt))[equalRights] <- "";
                emptyAlleles <- ((nchar(ref) == 0) | (nchar(alt) == 0));
                pos[emptyAlleles] <- pos[emptyAlleles] - 1;
                ref[emptyAlleles] <- paste0(substring(as.character(ref.seq),pos[emptyAlleles],pos[emptyAlleles]),
                                            ref[emptyAlleles]);
                alt[emptyAlleles] <- paste0(substring(as.character(ref.seq),pos[emptyAlleles],pos[emptyAlleles]),
                                            alt[emptyAlleles]);
                equalRights <- (substring(ref,nchar(ref)) == substring(alt,nchar(alt)));
            }
            leftChangeable <- (substring(ref,1,1) == substring(alt,1,1)) & (nchar(ref) >= 2) & (nchar(alt) >= 2);
            while(sum(leftChangeable) > 0){
                substring(ref[leftChangeable],1,1) <- "";
                substring(alt[leftChangeable],1,1) <- "";
                pos[leftChangeable] <- pos[leftChangeable] + 1;
                leftChangeable <- (substring(ref,1,1) == substring(alt,1,1)) & (nchar(ref) >= 2) & (nchar(alt) >= 2);
            }
            paste0(ref,pos,alt);
        }
    }
    Here's a little test, using the example from here:

    Code:
    > all(leftNorm("GGGCACACACAGGG",c("CA8","CAC6C","GCACA3GCA","GGCA2GG","GCA3G")) == "GCA3G");
    [1] TRUE
    Note that the code uses vectorisable functions, so should work equally well on single values and vectors. A bit more tweaking is needed to get it to do the right thing on matrices.

Latest Articles

Collapse

  • seqadmin
    Recent Advances in Sequencing Analysis Tools
    by seqadmin


    The sequencing world is rapidly changing due to declining costs, enhanced accuracies, and the advent of newer, cutting-edge instruments. Equally important to these developments are improvements in sequencing analysis, a process that converts vast amounts of raw data into a comprehensible and meaningful form. This complex task requires expertise and the right analysis tools. In this article, we highlight the progress and innovation in sequencing analysis by reviewing several of the...
    Yesterday, 07:48 AM
  • seqadmin
    Essential Discoveries and Tools in Epitranscriptomics
    by seqadmin




    The field of epigenetics has traditionally concentrated more on DNA and how changes like methylation and phosphorylation of histones impact gene expression and regulation. However, our increased understanding of RNA modifications and their importance in cellular processes has led to a rise in epitranscriptomics research. “Epitranscriptomics brings together the concepts of epigenetics and gene expression,” explained Adrien Leger, PhD, Principal Research Scientist...
    04-22-2024, 07:01 AM

ad_right_rmr

Collapse

News

Collapse

Topics Statistics Last Post
Started by seqadmin, Today, 06:57 AM
0 responses
11 views
0 likes
Last Post seqadmin  
Started by seqadmin, Yesterday, 07:17 AM
0 responses
14 views
0 likes
Last Post seqadmin  
Started by seqadmin, 05-02-2024, 08:06 AM
0 responses
19 views
0 likes
Last Post seqadmin  
Started by seqadmin, 04-30-2024, 12:17 PM
0 responses
24 views
0 likes
Last Post seqadmin  
Working...
X