Корреляция Коррплот Конфигурация
Я новичок в сценариях R:-)
Мне нужно построить матрицу корреляции, и я пытаюсь настроить некоторые параметры для адаптации графика. Я использую corrplot
пакет.
Я построил матрицу corrplot таким образом:
corrplot(cor(d1[,2:14], d1[,2:14]), method=c("color"),
bg = "white", addgrid.col = "gray50",
tl.cex=1, type="lower", tl.col = "black",
col = colorRampPalette(c("red","white","blue"))(100))
Мне нужно показать значения корреляции в нижней матрице внутри цветовой матрицы, которую я построил. Как я могу это сделать?
Можно ли исключить основную диагональ из нижней матрицы? В этой диагонали всегда мы имеем идеальное соотношение.
Другое сомнение - я хочу показать значимые значения для корреляции, используя звезды вместо квадратов. лайк (*,, *). Является ли это возможным?
Можете ли вы помочь мне, ребята?
1 ответ
С небольшим количеством взлома вы можете сделать это в очень похожем пакете R, corrgram
, Это позволяет вам легко определять свои собственные функции панели, а также облегчает их просмотр в виде шаблонов. Вот код и рисунок:
set.seed(42)
library(corrgram)
# This panel adds significance starts, or NS for not significant
panel.signif <- function (x, y, corr = NULL, col.regions, digits = 2, cex.cor,
...) {
usr <- par("usr")
on.exit(par(usr))
par(usr = c(0, 1, 0, 1))
results <- cor.test(x, y, alternative = "two.sided")
est <- results$p.value
stars <- ifelse(est < 5e-4, "***",
ifelse(est < 5e-3, "**",
ifelse(est < 5e-2, "*", "NS")))
cex.cor <- 0.4/strwidth(stars)
text(0.5, 0.5, stars, cex = cex.cor)
}
# This panel combines edits the "shade" panel from the package
# to overlay the correlation value as requested
panel.shadeNtext <- function (x, y, corr = NULL, col.regions, ...)
{
if (is.null(corr))
corr <- cor(x, y, use = "pair")
ncol <- 14
pal <- col.regions(ncol)
col.ind <- as.numeric(cut(corr, breaks = seq(from = -1, to = 1,
length = ncol + 1), include.lowest = TRUE))
usr <- par("usr")
rect(usr[1], usr[3], usr[2], usr[4], col = pal[col.ind],
border = NA)
box(col = "lightgray")
on.exit(par(usr))
par(usr = c(0, 1, 0, 1))
r <- formatC(corr, digits = 2, format = "f")
cex.cor <- .8/strwidth("-X.xx")
text(0.5, 0.5, r, cex = cex.cor)
}
# Generate some sample data
sample.data <- matrix(rnorm(100), ncol=10)
# Call the corrgram function with the new panel functions
# NB: call on the data, not the correlation matrix
corrgram(sample.data, type="data", lower.panel=panel.shadeNtext,
upper.panel=panel.signif)
Код не очень чистый, так как в основном он объединяет функции из пакета, но он должен дать вам хорошее начало для получения желаемого сюжета. Возможно, вы можете принять аналогичный подход с corrplot
пакет тоже.
обновление: вот версия со звездами и кором на одном треугольнике:
panel.shadeNtext <- function (x, y, corr = NULL, col.regions, ...)
{
corr <- cor(x, y, use = "pair")
results <- cor.test(x, y, alternative = "two.sided")
est <- results$p.value
stars <- ifelse(est < 5e-4, "***",
ifelse(est < 5e-3, "**",
ifelse(est < 5e-2, "*", "")))
ncol <- 14
pal <- col.regions(ncol)
col.ind <- as.numeric(cut(corr, breaks = seq(from = -1, to = 1,
length = ncol + 1), include.lowest = TRUE))
usr <- par("usr")
rect(usr[1], usr[3], usr[2], usr[4], col = pal[col.ind],
border = NA)
box(col = "lightgray")
on.exit(par(usr))
par(usr = c(0, 1, 0, 1))
r <- formatC(corr, digits = 2, format = "f")
cex.cor <- .8/strwidth("-X.xx")
fonts <- ifelse(stars != "", 2,1)
# option 1: stars:
text(0.5, 0.4, paste0(r,"\n", stars), cex = cex.cor)
# option 2: bolding:
#text(0.5, 0.5, r, cex = cex.cor, font=fonts)
}
# Generate some sample data
sample.data <- matrix(rnorm(100), ncol=10)
# Call the corrgram function with the new panel functions
# NB: call on the data, not the correlation matrix
corrgram(sample.data, type="data", lower.panel=panel.shadeNtext,
upper.panel=NULL)
Также закомментирован еще один способ показать значимость, он будет выделяться жирным шрифтом ниже порога, а не с использованием звезд. Может быть, так будет яснее, в зависимости от того, что вы хотите показать.