Nothing
stop2 = function(...) {
a = lapply(list(...), toString)
a = append(a, list(call. = FALSE))
do.call(stop, a)
}
# Test that input is a positive (or similar) integer.
isCount = function(x, minimum = 1) {
isTRUE(length(x) == 1 &&
(is.integer(x) || (is.numeric(x) && x == as.integer(x))) &&
x >= minimum)
}
`%||%` = function(x, y) {
if(is.null(x)) y else x
}
`%na%` = function(x, y) {
if(length(x) == 1 && is.na(x)) y else x
}
.mysetdiff = function(x, y) {
unique.default(x[match(x, y, 0L) == 0L])
}
# Fast intersection. NB: assumes no duplicates!
.myintersect = function (x, y) {
y[match(x, y, 0L)]
}
# Stripped version of expand.grid
fastGrid = function(argslist, as.list = FALSE) {
nargs = length(argslist)
orep = nr = prod(lengths(argslist))
if (nargs == 0L || nr == 0L)
return(matrix(ncol = 0, nrow = 0))
rep.fac = 1L
res = NULL
for (x in argslist) {
nx = length(x)
orep = orep/nx
res = c(res, x[rep.int(rep.int(seq_len(nx), rep.int(rep.fac, nx)), orep)]) #this is res[, i]
rep.fac = rep.fac * nx
}
dim(res) = c(nr, nargs)
if (as.list)
res = lapply(seq_len(nr), function(r) res[r, ])
res
}
log_or_not = function(x, logbase) {
if (is.numeric(logbase))
log(x, logbase)
else x
}
# Fast version of t(combn(n, 2))
.comb2 = function(n) {
if (n < 2)
return(matrix(nrow = 0, ncol = 2))
v1 = rep.int(seq_len(n - 1), (n - 1):1)
v2 = sequence.default((n - 1):1, 2:n)
cbind(v1, v2, deparse.level = 0)
}
#' Hardy-Weinberg probabilities
#'
#' @param allele1,allele2 Vectors of equal length, containing alleles in the
#' form of indices of `afreq`
#' @param afreq A numeric vector with allele frequencies
#' @param f A single number in `[0, 1]`; the inbreeding coefficient
#'
#' @return A numeric vector of the same length as `allele1` and `allele2`
#'
#' @examples
#' p = 0.1; q = 1-p
#' hw = HWprob(c(1,1,2), c(1,2,2), c(p, q))
#' stopifnot(all.equal(hw, c(p^2, 2*p*q, q^2)))
#'
#' @export
HWprob = function(allele1, allele2, afreq, f = 0) {
homoz = allele1 == allele2
hw = afreq[allele1] * afreq[allele2] * (2 - homoz)
if(!is.na(f) && f > 0)
hw = afreq[allele1] * homoz * f + hw * (1 - f)
as.numeric(hw) # remove names; slightly faster than unname
}
#' Genotype matrix
#'
#' An autosomal marker with `n` alleles has `choose(n+1, 2)` possible
#' unordered genotypes. This function returns these as rows in a
#' matrix.
#'
#' @param n A positive integer.
#' @return An integer matrix with two columns and `choose(n+1, 2)` rows.
#'
#' @examples
#' allGenotypes(3)
#'
#' @export
allGenotypes = function(n) {
# Version of .comb2(n) with homozygotes on top
if (n < 1)
return(matrix(integer(0), ncol = 2))
v1 = rep.int(seq_len(n), n:1)
v2 = sequence.default(n:1, seq_len(n))
cbind(v1, v2, deparse.level = 0)
}
# Debug tool, pretty-print "startdata" probs
pasteGenoProb = function(g) {
p = g$prob
names(p) = paste(g$pat, g$mat, sep="/")
p
}
#' @importFrom pedmut isStationary sexEqual
hasStationaryModel = function(m) {
mut = attr(m, 'mutmod')
if(is.null(mut)) return(TRUE)
afr = afreq(m)
isStationary(mut$male, afr) &&
(sexEqual(mut) || isStationary(mut$female, afr))
}
fixMerlinLog = function(a, logbase = NULL) {
if(!is.null(logbase)) {
if(length(logbase) != 1 || !is.numeric(logbase) || logbase <= 0)
stop2("`logbase` must be a positive number: ", logbase)
if(logbase == exp(1))
res = a
else
res = round(a/log(logbase),3)
}
else {
res = signif(exp(a), digits = 3)
uflow = res == 0 & a > -Inf
if(any(uflow))
warning("Underflow!\nSome lnLikelihoods reported by MERLIN are too small to be exp'ed.",
immediate. = TRUE, call. = FALSE)
oflow = res == Inf & a < Inf
if(any(oflow))
warning("Overflow!\nSome lnLikelihoods reported by MERLIN are too large to be exp'ed.",
immediate. = TRUE, call. = FALSE)
}
res
}
checkRho = function(rho, max = 0.5) {
if(is.null(rho))
stop2("Argument `rho` is missing")
if(!is.numeric(rho))
stop2("Argument `rho` should be a number, not: ", class(rho))
if(length(rho) != 1)
stop2("Argument `rho` must have length 1: ", rho)
if(rho < 0)
stop2("Argument `rho` cannot be negative: ", rho)
if(rho > max)
stop2(sprintf("Argument `rho` cannot exceed %f: %f", max, rho))
}
# Sort genotypes (single marker object)
.sortGeno = function(marker) {
swp = marker[,1] > marker[,2]
if(any(swp))
marker[swp, 1:2] = marker[swp, 2:1]
marker
}
# For use in `genoCombinations`
fastGridRestricted = function(argslist, linkedWith, compatible) {
# argslist: list of vectors of positive integers
# linkedWith: list of length nargs, dependencies for each index (no symmetries!)
# compatible: Compatible integers for each i = 1,..,max(unlist(argslist)).
linked = which(lengths(linkedWith) > 0)
# Normal grid of unrestricted indivs
argsTmp = argslist
argsTmp[linked] = 0
res = fastGrid(argsTmp)
# Add columns with restrictions
for (i in linked) {
x = argslist[[i]]
links = linkedWith[[i]]
compatx = lapply(compatible, function(a) .myintersect(a, x))
#intersect with first link column
compati = compatx[res[, links[1]]]
# intersect with further links
for(k in links[-1]) {
compatk = compatx[res[, k]]
compati = lapply(seq_along(compati), function(j) .myintersect(compati[[j]], compatk[[j]]))
}
nCompat = lengths(compati)
rowExp = rep.int(seq_along(nCompat), nCompat)
res = res[rowExp, , drop = FALSE]
res[, i] = unlist(compati, use.names = FALSE)
}
res
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.