#' Export motifs as raw matrices.
#'
#' Write motifs as simple matrices with optional headers to file.
#'
#' @param motifs See [convert_motifs()] for acceptable formats.
#' @param file `character(1)` File name.
#' @param positions `character(1)` One of `c('columns', 'rows')`. Partial
#' matching allowed.
#' @param rownames `logical(1)` Include alphabet letters as rownames.
#' @param type `character(1)` One of `c('PCM', 'PPM', 'PWM', 'ICM')`. If missing
#' will use whatever type the motif is currently stored as.
#' @param sep `character(1)` Indicates how to separate individual motifs. Set as
#' `NULL` to have no seperating lines between motifs (the default is to
#' use a blank line).
#' @param headers `logical(1)`, `character(1)` Indicating if and how to write names.
#' @param overwrite `logical(1)` Overwrite existing file.
#' @param append `logical(1)` Add to an existing file.
#' @param digits `numeric(1)` Number of digits to use for motif positions.
#'
#' @return `NULL`, invisibly.
#'
#' @examples
#' motif <- create_motif()
#' write_matrix(motif, tempfile(), headers = ">")
#'
#' @family write_motifs
#' @seealso [read_matrix()]
#' @author Benjamin Jean-Marie Tremblay, \email{benjamin.tremblay@@uwaterloo.ca}
#' @export
write_matrix <- function(motifs, file, positions = "columns", rownames = FALSE,
type, sep = "", headers = TRUE, overwrite = FALSE,
append = FALSE, digits = 6) {
# param check --------------------------------------------
args <- as.list(environment())
char_check <- check_fun_params(list(file = args$file, positions = args$positions,
type = args$type, sep = args$sep),
numeric(), c(FALSE, FALSE, TRUE, TRUE),
TYPE_CHAR)
num_check <- check_fun_params(list(digits = args$digits),
numeric(), logical(), TYPE_NUM)
logi_check <- check_fun_params(list(rownames = args$rownames,
overwrite = args$overwrite,
append = args$append),
c(1, 1, 1), c(FALSE, FALSE, FALSE), TYPE_LOGI)
header_check <- character()
if (!is.logical(headers) && !is.character(headers)) {
header_check <- paste0(" * Incorrect type for 'headers': ",
"expected `logical` or `character`; got `",
class(headers), "`")
} else if (length(headers) != 1) {
header_check <- paste0(" * Incorrect vector length for 'headers': ",
"expected 1; got ", length(headers))
}
all_checks <- c(char_check, logi_check, header_check)
if (length(all_checks) > 0) stop(all_checks_collapse(all_checks))
#---------------------------------------------------------
positions <- match.arg(positions, c("columns", "rows"))
if (file.exists(file) && !overwrite && !append)
stop(wmsg("Existing file found, set `overwrite = TRUE` to continue."))
motifs <- convert_motifs(motifs)
if (!missing(type)) motifs <- convert_type_internal(motifs, type)
if (!is.list(motifs)) motifs <- list(motifs)
.write_matrix <- function(motifs, positions, rownames, sep, headers) {
motif <- motifs
lines_out <- vector()
if (!isFALSE(headers)) {
if (isTRUE(headers)) lines_out <- c(lines_out, motif@name) else {
lines_out <- c(lines_out, paste0(headers, motif@name))
}
}
switch(positions,
"columns" = {
for (i in seq_len(nrow(motif@motif))) {
pos <- motif@motif[i, ]
pos <- formatC(pos, format = "f", digits = digits)
if (rownames) pos <- c(rownames(motif@motif)[i], pos)
lines_out <- c(lines_out, paste0(pos, collapse = "\t"))
}
},
"rows" = {
if (rownames) lines_out <- c(lines_out, paste0(rownames(motif@motif),
collapse = "\t"))
for (i in seq_len(ncol(motif@motif))) {
pos <- motif@motif[, i]
pos <- formatC(pos, format = "f", digits = digits)
pos <- as.character(pos)
lines_out <- c(lines_out, paste0(pos, collapse = "\t"))
}
}
)
c(lines_out, sep)
}
lines_final <- lapply(motifs, .write_matrix, positions = positions,
rownames = rownames, sep = sep,
headers = headers) # not working??
lines_final <- unlist(lines_final)
if (append) {
cat(lines_final, sep = "\n", file = file, append = TRUE)
} else {
writeLines(lines_final, con <- file(file)); close(con)
}
invisible(NULL)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.