首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >R中同值像素的计数

R中同值像素的计数
EN

Stack Overflow用户
提问于 2022-05-14 15:45:18
回答 2查看 91关注 0票数 0

我需要帮助计算R中相同值的像素,我正在做一篇硕士论文,其中一部分是计算洪水前后某一区域的NDWI,这样我就可以计算水下地表。从NDWI的结果来看,洪水值在0以上的是水下的,0以下的不是。所以我被困在bcs里,我不知道如何计算0以上的所有像素。

EN

回答 2

Stack Overflow用户

发布于 2022-05-14 19:33:15

使用dropbox数据:

代码语言:javascript
复制
library(terra)
ndwi <- rast('Clip_ndwi_poslije1.tif')
ndwi_vec <- values(ndwi, mat = FALSE)
> length(which(ndwi_vec > 0))
[1] 21157
> length(which(ndwi_vec <= 0))
[1] 13217
> dim(ndwi)[1]
[1] 220
> dim(ndwi)[1]*dim(ndwi)[2]
[1] 58300
> sum(length(which(ndwi_vec > 0)), length(which(ndwi_vec <= 0)))
[1] 34374
> table(is.na(ndwi[])) #  see below

FALSE  TRUE 
34374 23926 

表方法来自SOF-GIS ?s,并让您开始。

票数 0
EN

Stack Overflow用户

发布于 2022-05-14 21:01:39

你的数据

代码语言:javascript
复制
library(terra)
r <- rast("Clip_ndwi_poslije1.tif")

您可以使用大于零(或不大于零)的值来计数单元格,如下所示:

代码语言:javascript
复制
freq(r > 0)
#     layer value count
#[1,]     1     0 13217
#[2,]     1     1 21157

TRUE == 1,所以您有21,157个单元,其值大于零。

但是,要精确计算这些单元格覆盖的面积,首先需要得到每个单元格的面积:

代码语言:javascript
复制
a <- cellSize(r)

然后把这些区域加起来

代码语言:javascript
复制
b <- ifel(r > 0, a, NA)
# or the equivalent
# b <- mask(a, r>0, maskvalue=0)

global(b, "sum", na.rm=TRUE)
#            sum
#ndwiii 19013036

在这种情况下,这类似于(错误地)假设名义空间分辨率对每个网格单元有效。

代码语言:javascript
复制
global(r > 0, "sum", na.rm=TRUE) * prod(res(r))
#             sum
#ndwiii 19041300
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72241777

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档