2021-12-16 13:01:44 +01:00
|
|
|
#' Score the mean distance of genes to the telomeres across species.
|
|
|
|
|
#'
|
|
|
|
|
#' A score will be given to each gene such that 0.0 corresponds to the maximal
|
|
|
|
|
#' mean distance across all genes and 1.0 corresponds to a distance of 0.
|
|
|
|
|
#'
|
|
|
|
|
#' @return An object of class `geposan_method`.
|
|
|
|
|
#'
|
|
|
|
|
#' @export
|
|
|
|
|
proximity <- function() {
|
|
|
|
|
method(
|
|
|
|
|
id = "proximity",
|
|
|
|
|
name = "Proximity",
|
|
|
|
|
description = "Proximity to telomeres",
|
|
|
|
|
function(preset, progress) {
|
|
|
|
|
species_ids <- preset$species_ids
|
|
|
|
|
gene_ids <- preset$gene_ids
|
2021-10-19 13:39:55 +02:00
|
|
|
|
2021-12-16 13:01:44 +01:00
|
|
|
cached("proximity", c(species_ids, gene_ids), {
|
|
|
|
|
# Prefilter distances by species and gene.
|
|
|
|
|
data <- geposan::distances[
|
|
|
|
|
species %chin% preset$species_ids &
|
|
|
|
|
gene %chin% preset$gene_ids
|
|
|
|
|
]
|
2021-10-19 13:39:55 +02:00
|
|
|
|
2021-12-16 13:01:44 +01:00
|
|
|
# Compute the score as described above.
|
|
|
|
|
data <- data[, .(mean_distance = mean(distance)), by = "gene"]
|
|
|
|
|
max_distance <- data[, max(mean_distance)]
|
|
|
|
|
data[, score := 1 - mean_distance / max_distance]
|
2021-10-19 15:03:10 +02:00
|
|
|
|
2021-12-16 13:01:44 +01:00
|
|
|
progress(1.0)
|
2021-10-21 17:25:44 +02:00
|
|
|
|
2021-12-16 13:01:44 +01:00
|
|
|
result(
|
|
|
|
|
method = "proximity",
|
|
|
|
|
scores = data[, .(gene, score)]
|
|
|
|
|
)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
)
|
2021-10-19 13:39:55 +02:00
|
|
|
}
|