R/DNAseq.r

Defines functions DNAseq validate_DNAseq new_DNAseq

Documented in DNAseq new_DNAseq validate_DNAseq

#' Build a new DNAseq class instance.
#'
#' @keywords internal
new_DNAseq = function(x = character(), name = character(), phred = NULL){
  stopifnot(is.character(x))
  stopifnot(is.character(name))
  if(length(x) == 0){
    stop("Must pass a DNA sequence.")
  }
  structure(list(name = name, raw = tolower(x), phred = phred) , class = "DNAseq")
}

#' Validate the new DNAseq class instance.
#'
#' @keywords internal
validate_DNAseq = function(new_instance){
  # take a new instance and run validation checks on the sequence
  # make sure the sequence has only ATGCN-
  # make sure the sequence has length greater than zero
  allowed = c("-", "a", "c", "g", "n","t")
  for(c in sort(unique(strsplit(new_instance$raw, "")[[1]]))){
    if(!c %in% allowed){
      stop(paste("Unallowed character in DNA string:", c,
                 "\nValid characters are: a t g c - n"))
    }
  }
  
  if(!is.null(new_instance$phred)){
    if(nchar(new_instance$raw) != nchar(new_instance$phred)){
      stop(paste("The length of the input DNA sequence and phred scores must match."))
    }
  }
  new_instance
}


#' Build a DNAseq object from a DNA sequence string.
#' 
#' This can optionally include the DNA sequence's corresponding PHRED quality values and a sequencer identifier as well.
#'
#' @param x a nucleotide string.
#' Valid characters within the nucleotide string are: a,t,g,c,-,n.
#' The nucleotide string can be input as upper case, but will be automatically converted to lower case.
#' @param name an optional character string. Identifier for the sequence.
#' @param phred an optional character string. The phred score string corresponding to the nucleotide string.
#' If passed then the input phred scores will be modified along with the nucleotides and carried through
#' to the sequence output. Default = NULL.
#'
#' @return an object of class \code{"coi5p"}
#' @examples
#' dat = DNAseq(example_nt_string)
#' #named DNAseq sequence
#' dat = DNAseq(example_nt_string, name = "example_seq1")
#' #components in output DNAseq object:
#' dat$raw
#' dat$name
#' @name DNAseq
#' @export
DNAseq = function(x = character(), name = character(), phred = NULL){
  validate_DNAseq(new_DNAseq(tolower(x), name, phred))
}

Try the debar package in your browser

Any scripts or data that you put into this service are public.

debar documentation built on May 29, 2024, 2:02 a.m.