AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 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

当每层存在不同级别时,如何使用 terra 在 rast 堆栈中设置因子级别

  • 772

我有一堆terra::rast()连续数据,我将其分为 n 类,转换为因子并在离散尺度上绘制。

但是,当第一个栅格不具备其他栅格所具备的所有因子(例如,只有 3 个分类值,而不是全部 10 个,转换为因子)时,图就会变得有点混乱。

我正在寻找一种方法来告知 rast 堆栈(或图),整个堆栈的级别是堆栈的最小值 - 最大值,但某些层可能较少。

有趣的是,如果第一层包含所有可能的类/因素,那么后续层就可以了,并且情节也很好。

# 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 个回答
  • 51 Views

2 个回答

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

    软件包中应该对此进行一些改进,但是现在您可以这样做:

    # 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)
    

    在此处输入图片描述


    使用 terra 开发版本(版本 1.8-9),您现在可以

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

    要与 tidyterra 和 ggplot 一起使用,您可以先使用combineLevels

    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()
    

    在此处输入图片描述

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

    在罗伯特的解决方案之上,这是完全没问题的,看看如何通过一些选项来控制它ggplot(另请参阅ggplot2 堆积条形图不按手动定义的因子顺序排序)。

    基本上,在里面,scale_fill_manual您可以使用一对值颜色手动分配具有给定值的颜色values,并使用更改默认顺序breaks。我还在图例上重新编码了这些值,因为我假设这是您使用此行的意图:

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

    查看完整代表:

    # 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()
    

    绘制罗伯特的答案以供比较(相同情节):

    
    # 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)
    

    创建于 2025-01-09,使用reprex v2.1.1

    会话信息
    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

相关问题

  • 将复制活动的序列号添加到 Blob

  • Packer 动态源重复工件

  • 选择每组连续 1 的行

  • 图形 API 调用列表 subscribedSkus 状态权限不足,但已授予权限

  • 根据列值创建单独的 DF 的函数

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    重新格式化数字,在固定位置插入分隔符

    • 6 个回答
  • Marko Smith

    为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会?

    • 2 个回答
  • Marko Smith

    VScode 自动卸载扩展的问题(Material 主题)

    • 2 个回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Martin Hope
    Fantastic Mr Fox msvc std::vector 实现中仅不接受可复制类型 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant 使用 chrono 查找下一个工作日 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor 构造函数的成员初始化程序可以包含另一个成员的初始化吗? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský 为什么 C++20 概念会导致循环约束错误,而老式的 SFINAE 不会? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul C++20 是否进行了更改,允许从已知绑定数组“type(&)[N]”转换为未知绑定数组“type(&)[]”? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann 为什么 {2,3,10} 和 {x,3,10} (x=2) 的顺序不同? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST

热门标签

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

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve