R/get_genome_seq_from_genome_id.R

Defines functions get_genome_seq_from_genome_id

Documented in get_genome_seq_from_genome_id

#' Get genome sequence from genome
#'
#' @description Get the linear string of letters representing the instruction
#' codes that make up the genome of a digital organism from the id of the genome
#' of a digital organism.
#'
#' @param genome_id  Integer or a list of integer values.
#'
#' @param triplestore Object of class triplestore_access which manages database
#' access.
#'
#' @return Data frame. Columns: "genome_id" "genome_seq"
#'
#' @examples
#'
#' # Create triplestore object
#' avidaDB <- triplestore_access$new()
#'
#' # Set access options
#' avidaDB$set_access_options(
#'   url = "https://graphdb.fortunalab.org",
#'   user = "public_avida",
#'   password = "public_avida",
#'   repository = "avidaDB_test"
#' )
#'
#' # Single genome
#' get_genome_seq_from_genome_id(1, triplestore = avidaDB)
#'
#' # More than one genome
#' get_genome_seq_from_genome_id(
#'   genome_id = c(1, 2, 3, 4),
#'   triplestore = avidaDB
#' )
#'
#' @export

get_genome_seq_from_genome_id <- function(genome_id, triplestore) {
  # Validate params
  validate_param(param = "genome_id", value = genome_id, types = 2)

  # Build query
  query <- paste0("
    PREFIX ONTOAVIDA: <", ontoavida_prefix(), ">
    SELECT distinct ?genome_id ?genome_seq WHERE {
        # genome
        #genome#
        ?genome_id ONTOAVIDA:00000122 ?genome_seq .

    }")

  # Replace params
  query <- replace_data(param = "genome", value = genome_id, query = query)

  # Submit query
  response <- triplestore$submit_query(query = query)

  if (is.null(response))
    return(invisible(NULL))
  
  if (nrow(response)>0) {
    # Remove prefixes
    response <- remove_prefix(prefix = ontoavida_prefix(), data = response)
  }

  # Return response
  return(response)
}

Try the avidaR package in your browser

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

avidaR documentation built on June 22, 2024, 9:21 a.m.