AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / user-21836289

Excelsior's questions

Martin Hope
Excelsior
Asked: 2025-04-08 18:43:48 +0800 CST

Por que wrap_plots() falha ao combinar sublayouts com larguras e alturas unit() em patchwork?

  • 6

Estou usando o patchworkpacote em R para organizar 6 gráficos em um layout de 3 linhas por 2 colunas, onde cada coluna tem gráficos empilhados verticalmente.

Cada coluna vertical funciona quando criada de forma independente, com larguras e alturas fixas usando unit()o gridpacote. Mas quando tento combinar as duas colunas encapsuladas com wrap_plots(), recebo este erro:

Erro: índice fora dos limites (subconjunto "unidade")

library(ggplot2)
library(patchwork)
library(grid)

# Dummy plots
p_tmp <- lapply(1:6, function(i) {
  ggplot(
    data = mtcars, 
    aes(mpg, wt)
    ) + 
    geom_point() + 
    labs(
      subtitle = paste("Plot", i)
      )
  })

# Individual columns work fine
col1 <- wrap_plots(
  p_tmp[1:3],
  ncol = 1,
  heights = unit(rep(2.5, 3), "cm"),
  widths = unit(2.5, "cm")
) +
  plot_annotation(
    "col1"
  )

col2 <- wrap_plots(
  p_tmp[4:6],
  ncol = 1,
  heights = unit(rep(2.5, 3), "cm"),
  widths = unit(9 / 16 * 2.5, "cm")
) +
  plot_annotation(
    "col2"
  )

# Combining both results in error
wrap_plots(col1, col2, ncol = 2)

Os gráficos de colunas individuais estão funcionando, mas ao combiná-los, recebo o erro mencionado.

col1 col2

Como posso combinar corretamente várias wrap_plots()colunas que usam dimensões fixas unit() widthse heights? Existe uma maneira de manter dimensões fixas e ainda combiná-las em um layout maior sem acionar esse erro?

Editar:

Para esclarecer o objetivo da pergunta: os 3 primeiros gráficos são idênticos geom_raster()e devem compartilhar uma legenda de preenchimento comum, enquanto os gráficos 4 a 6 permanecem os mesmos. A posição da legenda deve ser centralizada abaixo da primeira coluna, o que não acontece ao combinar todos os gráficos com um único wrap_plots()comando.

pentear todos

library(ggplot2)
library(patchwork)

# Create raster plot
df <- expand.grid(x = 1:20, y = 1:20)
df$z <- as.vector(matrix(runif(400), nrow = 20, ncol = 20))

raster_plot <- ggplot(
  data = df, 
  aes(x, y, fill = z)
  ) +
  geom_raster(
    interpolate = FALSE
    ) +
  scale_fill_viridis_c() +
  theme_minimal() +
  theme(
    legend.position = "bottom"
  )

# Define plots
p_tmp <- c(
  rep(list(raster_plot), 3),
  lapply(1:3, function(i) {
    ggplot(
      data = mtcars, 
      aes(mpg, wt)
      ) +  
      geom_point() +
      theme_minimal()
}))

heights <- unit(rep(2, 3), "cm")

# Column 1 – works alone
col1 <- wrap_plots(
  p_tmp[1:3],
  ncol = 1,
  heights = heights,
  widths = unit(2, "cm"),
  guides = "collect"
)

# Column 2 – works alone
col2 <- wrap_plots(
  p_tmp[4:6],
  ncol = 1,
  heights = heights,
  widths = unit(9 / 16 * 2, "cm")
)

# Combining both → error
# wrap_plots(col1, col2, ncol = 2)

# Combining all → no error
wrap_plots(
  p_tmp,
  ncol = 2,
  byrow = FALSE,
  heights = heights,
  widths = unit(c(2, 9 / 16 * 2), rep("cm", 2)),
  guides = "collect",
  axis_titles = "collect"
)
  • 1 respostas
  • 29 Views
Martin Hope
Excelsior
Asked: 2024-02-05 22:36:27 +0800 CST

remova uma entrada de legenda na legenda do dendograma

  • 6

Estou tendo problemas com as entradas da legenda de um dendograma. Estou utilizando o exemplo de código fornecido aqui .

library(ggplot2)
library(ggdendro)
library(plyr)
library(zoo)

df <- USArrests                       # really bad idea to muck up internal datasets
labs <- paste("sta_", 1:50, sep = "") # new labels
rownames(df) <- labs                  # set new row names

cut <- 4    # Number of clusters
hc <- hclust(dist(df), "ave")              # hierarchical clustering
dendr <- dendro_data(hc, type = "rectangle") 
clust <- cutree(hc, k = cut)               # find 'cut' clusters
clust.df <- data.frame(label = names(clust), cluster = clust)

# Split dendrogram into upper grey section and lower coloured section
height <- unique(dendr$segments$y)[order(unique(dendr$segments$y), decreasing = TRUE)]
cut.height <- mean(c(height[cut], height[cut-1]))
dendr$segments$line <- ifelse(dendr$segments$y == dendr$segments$yend &
                                dendr$segments$y > cut.height, 1, 2)
dendr$segments$line <- ifelse(dendr$segments$yend  > cut.height, 1, dendr$segments$line)

# Number the clusters
dendr$segments$cluster <- c(-1, diff(dendr$segments$line))
change <- which(dendr$segments$cluster == 1)
for (i in 1:cut) dendr$segments$cluster[change[i]] = i + 1
dendr$segments$cluster <-  ifelse(dendr$segments$line == 1, 1, 
                                  ifelse(dendr$segments$cluster == 0, NA, dendr$segments$cluster))
dendr$segments$cluster <- na.locf(dendr$segments$cluster) 

# Consistent numbering between segment$cluster and label$cluster
clust.df$label <- factor(clust.df$label, levels = levels(dendr$labels$label))
clust.df <- arrange(clust.df, label)
clust.df$cluster <- factor((clust.df$cluster), levels = unique(clust.df$cluster), labels = (1:cut) + 1)
dendr[["labels"]] <- merge(dendr[["labels"]], clust.df, by = "label")

# Plot the dendrogram
ggplot() + 
  geom_segment(data = segment(dendr), 
               aes(x=x, y=y, xend=xend, yend=yend, size=factor(line), colour=factor(cluster)), 
               lineend = "square", show.legend = FALSE) + 
  scale_colour_manual(values = c("grey60", rainbow(cut)),
                      labels = c("remove this entry", paste("cluster", (1:cut)))) +
  scale_size_manual(values = c(0.5, 0.5)) +
  geom_text(data = label(dendr), aes(x, y, label = label, colour = factor(cluster)), 
            hjust = -0.2, size = 3, key_glyph = "rect") +
  scale_y_reverse(expand = c(0.2, 0)) + 
  labs(x = NULL, y = "Height") +
  coord_flip() +
  theme(axis.line.y = element_blank(),
        axis.ticks.y = element_blank(),
        axis.text.y = element_blank(),
        axis.title.y = element_blank(),
        panel.background = element_rect(fill = "white"),
        panel.grid = element_blank())

muitas entradas

Estou recebendo uma entrada a mais que o número de clusters. O objetivo da linha scale_colour_manual(values = c("grey60", rainbow(cut)))é colorir apenas os clusters.

Adicionando

  scale_colour_manual(values = c("grey60", rainbow(cut)),
                      breaks = c(factor(1:cut+1)),
                      labels = c(paste("cluster", (1:cut))))

não funciona como pretendido.

ainda entradas erradas

Existe uma maneira de remover a entrada cinza?

  • 1 respostas
  • 17 Views

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve