Для функции я хочу перепроецировать растровый ввод - сам вывод после использования кадрирования и маски - с использованием пользовательской CRS. Я думал, что проектирование с существующим crs ничего не даст и просто вернет входной растр. К моему удивлению, этого не произошло. Ниже воспроизводимый пример
Создайте фиктивный растр:
library(raster)
# Download country polygin, in this case Malawi
mwi <- raster::getData("GADM", country = "MWI", level = 0)
# Create dummy raster
grid <- raster::raster() # 1 degree raster
grid <- raster::disaggregate(grid, fact = 12) # 5 arcmin
grid <- raster::crop(grid, mwi)
values(grid) <- rep(1, ncell(grid)) # Set a value
# The input raster with dimensions 94,39,3666
grid <- raster::mask(grid, mwi)
plot(grid)
grid
# Reproject the raster using its own crs. I use ngb as it is a categorical variable.
# This raster has dimensions 102, 47, 4794 so it seems a lot of white space (NA) is added.
own_crs <- crs(grid)
grid_reproj <- raster::projectRaster(grid, crs = own_crs, method = "ngb")
plot(grid_reproj)
grid_reproj
# To remove the white space I use trim
# This results in a waster with dimensions 93, 39, 3627
grid_trim <- raster::trim(grid_reproj)
plot(grid_trim)
grid_trim
# I also decided to compare the maps visually with mapview
library(mapview)
# There seems to be a trim function in mapview which I set to FALSE
# Also use the browser for easy viewing
options(viewer = NULL)
mapviewOptions(trim = FALSE)
mapviewGetOption("trim")
mapview(grid, col.regions = "green", legend = F) +
mapview(grid_reproj, col.regions = "red", legend = F) +
mapview(grid_trim, col.regions = "blue", legend = F)
Сравнивая карты, я наблюдаю две вещи:
(1) grid и grid_trim почти идентичны, за исключением одной ячейки сетки наверху. Возможно это из-за округления,
(2) grid_reproj имеет гораздо большие размеры и разную степень. Также кажется, что карта немного сдвинута по сравнению с другими картами. Это исправляется обрезкой, поэтому я предполагаю, что на самом деле это ячейки NA, и разница может быть связана с тем, как mapview отображает карты.
Следовательно, мой главный вопрос: что происходит, когда rasterProject проектирует одинаковую степень? И почему результат отличается даже после обрезки?