R/map_to_grid.R

Defines functions map_to_grid

Documented in map_to_grid

# map_to_grid
#' Subset a map to positions on a grid
#'
#' Subset a map object to the locations on some grid.
#'
#' @param map A list of vectors of marker positions.
#' @param grid A list of logical vectors (aligned with
#' `map`), with TRUE indicating the position is on the grid.
#'
#' @return Same list as input, but subset to just include
#' pseudomarkers along a grid.
#'
#' @details This is generally for the case of a map created with
#' [insert_pseudomarkers()] with `step`>0 and
#' `stepwidth="fixed"`, so that the pseudomarkers form a grid
#' along each chromosome.
#'
#' @export
#' @keywords utilities
#' @seealso [calc_grid()], [probs_to_grid()]
#'
#' @examples
#' grav2 <- read_cross2(system.file("extdata", "grav2.zip", package="qtl2"))
#' map_w_pmar <- insert_pseudomarkers(grav2$gmap, step=1)
#' sapply(map_w_pmar, length)
#' grid <- calc_grid(grav2$gmap, step=1)
#' map_sub <- map_to_grid(map_w_pmar, grid)
#' sapply(map_sub, length)

map_to_grid <-
    function(map, grid)
{
    if(is.null(map)) stop("map is NULL")
    if(is.null(grid)) stop("grid is NULL")

    if(length(map) != length(grid))
        stop("length(grid) [", length(grid), "] != length(map) [", length(map), "]")

    for(i in seq(along=map)) {
        if(is.null(grid[[i]]) || all(grid[[i]])) next

        if(length(map[[i]]) != length(grid[[i]]))
            stop("length(grid) [", length(grid[[i]]), "] != length(map) [",
                 length(map[[i]]), "] for chr ", names(map)[i])

        # subset map
        map[[i]] <- map[[i]][grid[[i]]]
    }

    map
}

Try the qtl2 package in your browser

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

qtl2 documentation built on April 22, 2023, 1:10 a.m.