如何对矢量进行区域变量栅格化?
我已经使用了很多次相同的栅格化过程,该过程效果很好:
raster <- rasterize(vect(shapefile.shp), base_grid, "my_variable")
栅格是栅格化的shapefile,shapefile.shp是原始的向量,base_grid是栅格骨架,而“我的变量”是要考虑的变量。 对于与多边形面积无关的变量,这种方法是令人满意的,因为它使用平均计算来重新排列数据(例如:人口,生产,产量,温度,降水)。
但是,现在我试图将矢量转换为具有可变收获区域的栅格多边形,这不是多边形的区域,但可以认为与总多边形面积成正比。在考虑收获区域(相应载体的3-4倍)时,上述方法会产生膨胀的值,这可能是因为多边形通常大于网格细胞。因此,一个具有100个单位的大多边形分为10个网格单元,每个单元将提供100个单位,而我希望它们每个单元具有10个单位(因为它是一个区域)。
我想我的方法是这样的:“在每个网格单元中,权重平均所有多边形都与它们在网格单元中的存在成比例值”,
但我正在寻找的是:“对于每个网格单元中的每个多边形部分,都计算网格单元内多边形的一部分(WRT到总多边形区域),并将网格单元内的所有值(因为它是区域单位)中的所有值”。
任何帮助将受到高度赞赏。
更新:
矢量数据的视图。抛射器实际上是很多因素,因为我有多年:
Simple feature collection with 9382 features and 3 fields
Geometry type: MULTIPOLYGON
Dimension: XYZ
Bounding box: xmin: -67.38379 ymin: -41.03791 xmax: -53.63737 ymax: -21.99877
z_range: zmin: 0 zmax: 0
Geodetic CRS: WGS 84
First 10 features:
ADM2_REF anio my_variable geometry
2 Tres Arroyos 1978 180 MULTIPOLYGON Z (((-60.16947...
3 Tres Arroyos 1979 0 MULTIPOLYGON Z (((-60.16947...
4 Tres Arroyos 1988 1000 MULTIPOLYGON Z (((-60.16947...
5 Tres Arroyos 1989 1000 MULTIPOLYGON Z (((-60.16947...
6 Tres Arroyos 1990 3000 MULTIPOLYGON Z (((-60.16947...
7 Tres Arroyos 1991 1500 MULTIPOLYGON Z (((-60.16947...
8 Tres Arroyos 1992 2800 MULTIPOLYGON Z (((-60.16947...
9 Tres Arroyos 1993 2800 MULTIPOLYGON Z (((-60.16947...
10 Tres Arroyos 1994 2500 MULTIPOLYGON Z (((-60.16947...
11 Tres Arroyos 1995 1250 MULTIPOLYGON Z (((-60.16947...
将上述数据框架转换为栅格的步骤是:
baserast <- rast(nrows=nrows, ncol=nrows,
extent= extent,
crs="+proj=longlat +datum=WGS84",
vals=NA)
rasters <- rast(lapply(1978:2019,
function(x)
rasterize(vect(shp.soy.yld.arg %>%
filter(anio==x)), baserast, "my variable")))
link 在一年的数据.gpkg中(整个年份都太大)。
I have used many times the same process of rasterization, which works fairly well:
raster <- rasterize(vect(shapefile.shp), base_grid, "my_variable")
where raster is the rasterized shapefile, shapefile.shp is the original vector, base_grid is the raster skeleton and "my variable" is the variable to be considered.
For variables that are not related to the area of the polygon, this approach is satisfactory, as it uses mean calculations to rearrange the data (for instance: population, production, yield, temperature, precipitation).
However, now I am trying to convert from vector to raster polygons that have as variable harvesting area, which is not the area of the polygon strictly, but that could be considered proportional to the total polygon area. The approach above produces inflated values when considering the harvesting area (3-4 times the corresponding vector), probably because the polygons are in general larger than the grid cells. So a large polygon with 100 unit is divided in 10 grid cells, and each will give 100 units, whereas I want them to have 10 units each (because it is an area).
I suppose the approach I have works like this: "In each grid cell, weight average all polygons values proportionally to their presence in the grid cell"
But what I am looking for is: "For each polygon part in each grid cell, calculate the fraction of the polygon inside the grid cell (wrt to the total polygon area) and SUM all values inside the grid cell (since it's an area unit)".
Any help is highly appreciated.
UPDATE:
view of the vector data. The rasters are actually manyfold because I have multiple years:
Simple feature collection with 9382 features and 3 fields
Geometry type: MULTIPOLYGON
Dimension: XYZ
Bounding box: xmin: -67.38379 ymin: -41.03791 xmax: -53.63737 ymax: -21.99877
z_range: zmin: 0 zmax: 0
Geodetic CRS: WGS 84
First 10 features:
ADM2_REF anio my_variable geometry
2 Tres Arroyos 1978 180 MULTIPOLYGON Z (((-60.16947...
3 Tres Arroyos 1979 0 MULTIPOLYGON Z (((-60.16947...
4 Tres Arroyos 1988 1000 MULTIPOLYGON Z (((-60.16947...
5 Tres Arroyos 1989 1000 MULTIPOLYGON Z (((-60.16947...
6 Tres Arroyos 1990 3000 MULTIPOLYGON Z (((-60.16947...
7 Tres Arroyos 1991 1500 MULTIPOLYGON Z (((-60.16947...
8 Tres Arroyos 1992 2800 MULTIPOLYGON Z (((-60.16947...
9 Tres Arroyos 1993 2800 MULTIPOLYGON Z (((-60.16947...
10 Tres Arroyos 1994 2500 MULTIPOLYGON Z (((-60.16947...
11 Tres Arroyos 1995 1250 MULTIPOLYGON Z (((-60.16947...
The steps to convert the dataframe above to a raster are:
baserast <- rast(nrows=nrows, ncol=nrows,
extent= extent,
crs="+proj=longlat +datum=WGS84",
vals=NA)
rasters <- rast(lapply(1978:2019,
function(x)
rasterize(vect(shp.soy.yld.arg %>%
filter(anio==x)), baserast, "my variable")))
Link for one year of the data .gpkg (it was too large for all years).
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
在这种情况下,您应该栅格化密度而不是面积
示例数据:
计算密度
栅格化
返回面积
检查数字是否合理(对于大面积/小像元,误差应该最小)。每个多边形的预期值为 100。
下面我展示了如何在多年的循环中执行此操作
示例数据:
解决方案
In cases like that you should rasterize density instead of area
Example data:
Compute density
Rasterize
Back to area
Check that the numbers are reasonable (error should be smallest for large areas / small cells). The expected value for each polygon is 100.
Below I show how to do this in a loop over multiple years
Example data:
Solution
如果我很好地理解你的问题(一个可重现的例子将不胜感激),你希望栅格化多边形中的所有像素总和为收获的值(代码中的“my_variable”)。
在这里,我创建了一个玩具示例来向您展示我的推理:
首先加载库
使用示例总面积和收获面积创建玩具数据
计算多边形覆盖的每个像素的分数
将每个覆盖分数除以多边形的总面积,然后乘以收获面积
<前><代码>库(sf)
库(光栅)
库(精确提取器)
rast <- 栅格::栅格(矩阵(rep(1,100), ncol=10), xmn=0, ymn=0, xmx=10, ymx=10)
pol <- sf::st_sfc(sf::st_polygon(列表(cbind(c(0.5,4,7,0.5),c(1,0,4,1)))))
pol <- st_sf(data.frame(area = st_area(pol),harvest=0.7, geom=pol))
光栅::绘图(拉斯特)
光栅::绘图(pol,add=T)
cov_frac <-exactextractr::coverage_fraction(rast, pol)[[1]]
栅格::绘图(cov_frac)
光栅::绘图(pol,add=T)
结果 <- cov_frac/st_area(pol)*pol$harvest
总和(值(结果))
如您所见,栅格化多边形中所有像素的总和等于收获面积
If I understand your question well (a reproducible example would have been appreciated), you want that all pixels in the rasterized polygons sum up to the harvested values ("my_variable" in your code).
Here I create a toy example to show you my reasoning:
first load the libraries
create toy data with an example total and harvested area
calculate the fraction of each pixel covered by the polygon
divide each cover fraction by the total area of the polygon and multiply it by the harvested area
As you can see the sum of all pixels in the rasterized polygon is equal to the harvested area