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 / coding / Perguntas / 79340152
Accepted
Sam
Sam
Asked: 2025-01-09 01:09:45 +0800 CST2025-01-09 01:09:45 +0800 CST 2025-01-09 01:09:45 +0800 CST

Como definir níveis de fator em uma pilha rast, usando terra, quando existem níveis diferentes em cada camada

  • 772

Tenho uma terra::rast()pilha de dados contínuos, que classifico em n classes, converto em fatores e ploto em uma escala discreta.

Mas quando o primeiro raster não tem todos os fatores presentes que alguns dos outros rasters têm (por exemplo, apenas 3 valores de classificação em vez de todo o conjunto de 10, convertidos em fatores), o gráfico fica um pouco confuso.

Estou procurando uma maneira de informar à pilha rast (ou plot) que os níveis de toda a pilha são mínimo e máximo da pilha, mas algumas camadas podem ter menos.

Curiosamente, se a primeira camada tiver todas as classes/fatores possíveis, as subsequentes estarão ok e o gráfico estará bom.

# dummy data
library(terra)
r1 <- rast(nrows = 10, ncols = 10, xmin = 0, xmax = 10, ymin = 0, ymax = 10)
r1[] <- runif(ncell(r1), min = 1, max = 5)  # Random values between 1 and 5

r2 <- rast(nrows = 10, ncols = 10, xmin = 0, xmax = 10, ymin = 0, ymax = 10)
r2[] <- runif(ncell(r2), min = 1, max = 5)

# Combine rasters into a stack
s <- c(r1/r1, r1/r2, r2/r1, r2/r2)
names(s) <- c("r1/r1", "r1/r2", "r2/r1", "r2/r2")

# Reclassify the raster stack
# Define reclassification matrix
m_rc <- matrix(c(0, 0.5, 1, 
                           0.5, 0.9, 2, 
                           0.9, 1.1, 3,
                           1.1, 2, 4,
                           2, max(global(s, max, na.rm=T)$max), 5), 
                         ncol = 3, byrow = TRUE)

# Apply reclassification
s_r <- classify(s, m_rc)

# Convert reclassified raster to factor for categorical plotting
s_r_f <- as.factor(s_r)

# Step 3: Plot using ggplot2 and tidyterra with custom legend labels
ggplot() +
  geom_spatraster(data = s_r_f) +
  facet_wrap(~lyr, nrow = 2) +  # Separate plots for each layer
  scale_fill_manual(
    values = c("blue","lightblue" , "white", "yellow", "red"),  # Assign custom colors
    na.value = "transparent",    # Transparent for NA values
    ) +
  labs(
    title = "Reclassified Raster Stack",
    labels = c("0 - 0.5","0.5 - 0.9","0.9 - 1.1","1.1 - 2","> 2"),
    fill = "Class"
  ) +
  theme_minimal()
  • 2 2 respostas
  • 51 Views

2 respostas

  • Voted
  1. Best Answer
    Robert Hijmans
    2025-01-09T02:41:01+08:002025-01-09T02:41:01+08:00

    Isso deve ser melhorado um pouco no pacote, mas agora você pode fazer isso:

    # set the same levels to all layers
    x <- categories(x, 0, levels(s_r_f)[[2]])
    
    panel(x, all_levels=TRUE, col = c("blue","lightblue", "white", "yellow", "red"), main=1:4)
    

    insira a descrição da imagem aqui


    Com a versão de desenvolvimento do terra (versão 1.8-9) agora você pode fazer

    panel(s_r_f, col = c("blue","lightblue", "white", "yellow", "red"))
    

    E para usar com tidyterra e ggplot você pode primeiro usarcombineLevels

    x <- combineLevels(s_r_f)
    
    library(tidyterra)
    library(ggplot2)
    
    ggplot() +
      geom_spatraster(data = x) +
      facet_wrap(~lyr, nrow = 2) +  # Separate plots for each layer
      scale_fill_manual(
        values = c("blue","lightblue" , "white", "yellow", "red"),  # Assign custom colors
        na.value = "transparent",    # Transparent for NA values
        ) +
      labs(
        title = "Reclassified Raster Stack",
        labels = c("0 - 0.5","0.5 - 0.9","0.9 - 1.1","1.1 - 2","> 2"),
        fill = "Class"
      ) +
      theme_minimal()
    

    insira a descrição da imagem aqui

    • 4
  2. dieghernan
    2025-01-09T23:22:00+08:002025-01-09T23:22:00+08:00

    Além da solução de Robert, que é perfeitamente boa, veja como isso pode ser controlado com algumas opções de ggplot(veja também ggplot2 stacked bar not order by manual-defined factor order ).

    Basicamente, dentro scale_fill_manualvocê pode atribuir manualmente a cor com um valor dado usando um par value-color in valuese alterar o default oder usando breaks. Eu também recodifiquei os valores na legenda, pois presumi que essa era sua intenção com esta linha:

        labels = c("0 - 0.5","0.5 - 0.9","0.9 - 1.1","1.1 - 2","> 2"),
    

    Veja o reprex completo:

    # dummy data
    library(terra)
    #> terra 1.8.5
    library(ggplot2)
    library(tidyterra)
    #> 
    #> Attaching package: 'tidyterra'
    #> The following object is masked from 'package:stats':
    #> 
    #>     filter
    
    set.seed(1234)
    
    r1 <- rast(nrows = 10, ncols = 10, xmin = 0, xmax = 10, ymin = 0, ymax = 10)
    r1[] <- runif(ncell(r1), min = 1, max = 5) # Random values between 1 and 5
    
    r2 <- rast(nrows = 10, ncols = 10, xmin = 0, xmax = 10, ymin = 0, ymax = 10)
    r2[] <- runif(ncell(r2), min = 1, max = 5)
    
    # Combine rasters into a stack
    s <- c(r1 / r1, r1 / r2, r2 / r1, r2 / r2)
    names(s) <- c("r1/r1", "r1/r2", "r2/r1", "r2/r2")
    
    # Reclassify the raster stack
    # Define reclassification matrix
    m_rc <- matrix(
      c(
        0, 0.5, 1,
        0.5, 0.9, 2,
        0.9, 1.1, 3,
        1.1, 2, 4,
        2, max(global(s, max, na.rm = T)$max), 5
      ),
      ncol = 3, byrow = TRUE
    )
    
    # Apply reclassification
    s_r <- classify(s, m_rc)
    
    # Convert reclassified raster to factor for categorical plotting
    s_r_f <- as.factor(s_r)
    
    
    
    # Step 3: Plot using ggplot2 and tidyterra with custom legend labels
    ggplot() +
      geom_spatraster(data = s_r_f) +
      facet_wrap(~lyr, nrow = 2) + # Separate plots for each layer
      scale_fill_manual(
        # Step 1: Identify color with values by name
        values = c(
          "1" = "blue", "2" = "lightblue", "3" = "white",
          "4" = "yellow", "5" = "red"
        ), # Assign custom colors
    
        # Step 2: Order the values in legend
        breaks = c("1", "2", "3", "4", "5"),
        # Step 3 (extra) Rename values in legend
        labels = c("0 - 0.5", "0.5 - 0.9", "0.9 - 1.1", "1.1 - 2", "> 2"),
        na.value = "transparent", # Transparent for NA values
      ) +
      labs(
        title = "Reclassified Raster Stack",
        fill = "Class"
      ) +
      theme_minimal()
    

    Trace a resposta de Robert para comparação (mesmo gráfico):

    
    # For comparison with Robert's answer
    # set the same levels to all layers
    x <- categories(s_r_f, layer = 0, value = levels(s_r_f)[[2]])
    
    panel(x, all_levels = TRUE, col = c(
      "blue", "lightblue", "white",
      "yellow", "red"
    ), main = 1:4)
    

    Criado em 2025-01-09 com reprex v2.1.1

    Informações da sessão
    sessioninfo::session_info()
    #> ─ Session info ───────────────────────────────────────────────────────────────
    #>  setting  value
    #>  version  R version 4.4.2 (2024-10-31)
    #>  os       Ubuntu 20.04.6 LTS
    #>  system   x86_64, linux-gnu
    #>  ui       X11
    #>  language (EN)
    #>  collate  C.UTF-8
    #>  ctype    C.UTF-8
    #>  tz       UTC
    #>  date     2025-01-09
    #>  pandoc   3.1.11 @ /usr/lib/rstudio-server/bin/quarto/bin/tools/ (via rmarkdown)
    #> 
    #> ─ Packages ───────────────────────────────────────────────────────────────────
    #>  package     * version  date (UTC) lib source
    #>  class         7.3-22   2023-05-03 [2] CRAN (R 4.4.1)
    #>  classInt      0.4-10   2023-09-05 [1] RSPM (R 4.4.0)
    #>  cli           3.6.3    2024-06-21 [1] RSPM (R 4.4.0)
    #>  codetools     0.2-20   2024-03-31 [2] CRAN (R 4.4.1)
    #>  colorspace    2.1-1    2024-07-26 [1] RSPM (R 4.4.0)
    #>  curl          6.1.0    2025-01-06 [1] RSPM (R 4.4.0)
    #>  data.table    1.16.4   2024-12-06 [1] RSPM (R 4.4.0)
    #>  DBI           1.2.3    2024-06-02 [1] RSPM (R 4.4.0)
    #>  digest        0.6.37   2024-08-19 [1] RSPM (R 4.4.0)
    #>  dplyr         1.1.4    2023-11-17 [1] RSPM (R 4.4.0)
    #>  e1071         1.7-16   2024-09-16 [1] RSPM (R 4.4.0)
    #>  evaluate      1.0.1    2024-10-10 [1] RSPM (R 4.4.0)
    #>  farver        2.1.2    2024-05-13 [1] RSPM (R 4.4.0)
    #>  fastmap       1.2.0    2024-05-15 [1] RSPM (R 4.4.0)
    #>  fs            1.6.5    2024-10-30 [1] RSPM (R 4.4.0)
    #>  generics      0.1.3    2022-07-05 [1] RSPM (R 4.4.0)
    #>  ggplot2     * 3.5.1    2024-04-23 [1] RSPM (R 4.4.0)
    #>  glue          1.8.0    2024-09-30 [1] RSPM (R 4.4.0)
    #>  gtable        0.3.6    2024-10-25 [1] RSPM (R 4.4.0)
    #>  htmltools     0.5.8.1  2024-04-04 [1] RSPM (R 4.4.0)
    #>  KernSmooth    2.23-24  2024-05-17 [2] CRAN (R 4.4.1)
    #>  knitr         1.49     2024-11-08 [1] RSPM (R 4.4.0)
    #>  lifecycle     1.0.4    2023-11-07 [1] RSPM (R 4.4.0)
    #>  magrittr      2.0.3    2022-03-30 [1] RSPM (R 4.4.0)
    #>  munsell       0.5.1    2024-04-01 [1] RSPM (R 4.4.0)
    #>  pillar        1.10.1   2025-01-07 [1] RSPM (R 4.4.0)
    #>  pkgconfig     2.0.3    2019-09-22 [1] RSPM (R 4.4.0)
    #>  proxy         0.4-27   2022-06-09 [1] RSPM (R 4.4.0)
    #>  purrr         1.0.2    2023-08-10 [1] RSPM (R 4.4.0)
    #>  R6            2.5.1    2021-08-19 [1] RSPM (R 4.4.0)
    #>  Rcpp          1.0.13-1 2024-11-02 [1] RSPM (R 4.4.0)
    #>  reprex        2.1.1    2024-07-06 [1] RSPM (R 4.4.0)
    #>  rlang         1.1.4    2024-06-04 [1] RSPM (R 4.4.0)
    #>  rmarkdown     2.29     2024-11-04 [1] RSPM (R 4.4.0)
    #>  rstudioapi    0.17.1   2024-10-22 [1] RSPM (R 4.4.0)
    #>  scales        1.3.0    2023-11-28 [1] RSPM (R 4.4.0)
    #>  sessioninfo   1.2.2    2021-12-06 [1] RSPM (R 4.4.0)
    #>  sf            1.0-19   2024-11-05 [1] RSPM (R 4.4.0)
    #>  terra       * 1.8-5    2024-12-12 [1] RSPM (R 4.4.0)
    #>  tibble        3.2.1    2023-03-20 [1] RSPM (R 4.4.0)
    #>  tidyr         1.3.1    2024-01-24 [1] RSPM (R 4.4.0)
    #>  tidyselect    1.2.1    2024-03-11 [1] RSPM (R 4.4.0)
    #>  tidyterra   * 0.6.1    2024-06-08 [1] RSPM (R 4.4.0)
    #>  units         0.8-5    2023-11-28 [1] RSPM (R 4.4.0)
    #>  vctrs         0.6.5    2023-12-01 [1] RSPM (R 4.4.0)
    #>  withr         3.0.2    2024-10-28 [1] RSPM (R 4.4.0)
    #>  xfun          0.50     2025-01-07 [1] RSPM (R 4.4.0)
    #>  xml2          1.3.6    2023-12-04 [1] RSPM (R 4.4.0)
    #>  yaml          2.3.10   2024-07-26 [1] RSPM (R 4.4.0)
    #> 
    #>  [1] /cloud/lib/x86_64-pc-linux-gnu-library/4.4
    #>  [2] /opt/R/4.4.1/lib/R/library
    #>  [3] /opt/R/4.4.2/lib/R/library
    #> 
    #> ──────────────────────────────────────────────────────────────────────────────
    
    • 1

relate perguntas

  • Adicionar número de série para atividade de cópia ao blob

  • A fonte dinâmica do empacotador duplica artefatos

  • Selecione linhas por grupo com 1s consecutivos

  • Lista de chamada de API de gráfico subscritoSkus estados Privilégios insuficientes enquanto os privilégios são concedidos

  • Função para criar DFs separados com base no valor da coluna

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