From 1ef9d9a9d65d260f390dab281fbdd061f1a765c4 Mon Sep 17 00:00:00 2001 From: EliseAld <40570458+EliseAld@users.noreply.github.com> Date: Thu, 5 Dec 2024 09:32:26 +0100 Subject: [PATCH] case for correlations with var=0 --- phase-1_2_3/scoring_program/scoring.R | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/phase-1_2_3/scoring_program/scoring.R b/phase-1_2_3/scoring_program/scoring.R index 6c42e88..9a91e65 100644 --- a/phase-1_2_3/scoring_program/scoring.R +++ b/phase-1_2_3/scoring_program/scoring.R @@ -53,9 +53,11 @@ prepare_A <- function(A_real, A_pred) { ######################### # Global Pearson/Spearman correlation coefficients correlationP_tot = function(A_real, A_pred) { + if (all(c(var(A_pred))==0)) {return(-1)} #worst case scenario where all cell types are predicted with the same proportions return(cor(c(A_real), c(A_pred), method = "pearson")) } correlationS_tot = function(A_real, A_pred) { + if (all(c(var(A_pred))==0)) {return(-1)} #worst case scenario where all cell types are predicted with the same proportions return(cor(c(A_real), c(A_pred), method = "spearman")) } @@ -70,6 +72,7 @@ correlationP_col = function(A_real, A_pred) { } res = res[!is.na(res)] print(paste0(length(res), " columns are kept for correlation analysis")) + if (length(res)==0) {return(-1)} return(mean(res)) } correlationS_col = function(A_real, A_pred) { @@ -81,6 +84,7 @@ correlationS_col = function(A_real, A_pred) { } res = res[!is.na(res)] print(paste0(length(res), " columns are kept for correlation analysis")) + if (length(res)==0) {return(-1)} return(mean(res)) } @@ -95,6 +99,7 @@ correlationP_row = function (A_real, A_pred) { } res = res[!is.na(res)] print(paste0(length(res), " rows are kept for correlation analysis")) + if (length(res)==0) {return(-1)} return(mean(res)) } correlationS_row = function (A_real, A_pred) { @@ -106,6 +111,7 @@ correlationS_row = function (A_real, A_pred) { } res = res[!is.na(res)] print(paste0(length(res), " rows are kept for correlation analysis")) + if (length(res)==0) {return(-1)} return(mean(res)) }