From 69976cf99dadecd501c5385bca46b4a601f55139 Mon Sep 17 00:00:00 2001 From: Karl Broman Date: Fri, 5 Apr 2024 12:47:50 -0500 Subject: [PATCH] In scan1snps(), subset genoprobs and map to same positions (Issue #219) --- NEWS.md | 5 +++++ R/scan1snps.R | 37 +++++++++++++++++++++++-------------- 2 files changed, 28 insertions(+), 14 deletions(-) diff --git a/NEWS.md b/NEWS.md index e737d397..738d188f 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,5 +1,10 @@ ## qtl2 0.35-2 (2024-04-05) +### Minor changes + +- In `scan1snps()`, subset `genoprobs` and `map` to common positions, + if they have different markers. (Issue #219) + ### Bug fixes - Fixed a problem with `sdp_panel=TRUE` in `plot_snpasso()`. (Issue #232) diff --git a/R/scan1snps.R b/R/scan1snps.R index df6a4056..611293ff 100644 --- a/R/scan1snps.R +++ b/R/scan1snps.R @@ -113,21 +113,30 @@ scan1snps <- genoprobs <- genoprobs[,cchr] map <- map[cchr] - # check inputs - if(length(genoprobs) != length(map)) { - stop("length(genoprobs) != length(map)") - } - if(any(dim(genoprobs)[3,] != vapply(map, length, 1))) { - stop("genoprobs and map have different numbers of markers") - } - dn <- dimnames(genoprobs)[[3]] - different_names <- FALSE - for(i in seq_along(dn)) { - if(any(dn[[i]] != names(map[[i]]))) different_names <- TRUE - } - if(different_names) { # different marker names...give a warning (maybe should be an error) - warning("genoprobs and map have different marker names") + # check genoprobs and map have same markers in same order + # - subset to common markers if different + # - stop with error if different order + subset_markers <- FALSE + for(ichr in names(genoprobs)) { + markers_genoprobs <- dimnames(genoprobs[[ichr]])[[3]] + markers_map <- names(map[[ichr]]) + + if(length(markers_genoprobs) != length(markers_map) || + any(markers_genoprobs != markers_map)) { + subset_markers <- TRUE # later give warning + markers <- markers_genoprobs[markers_genoprobs %in% markers_map] + if(length(markers)==0) stop("No markers in common between genoprobs and map on chr ", ichr) + genoprobs[[ichr]] <- genoprobs[[ichr]][,,markers_genoprobs %in% markers,drop=FALSE] + map[[ichr]] <- map[[ichr]][markers_map %in% markers] + + markers_genoprobs <- dimnames(genoprobs[[ichr]])[[3]] + markers_map <- names(map[[ichr]]) + if(any(markers_genoprobs != markers_map)) + stop("Markers in different order between genoprobs and map on chr ", ichr) + } } + if(subset_markers) warning("Subset to common markers between genoprobs and map") + if(!is.null(snpinfo) && !is.null(query_func)) { warning("If snpinfo is provided, chr, start, end, and query_func are all ignored") }