Мне нравится вычислять оценки плотности ядра, используя функцию smooth_map пакета tmaptools.Я следую процедуре Криса Брансдона и Лекса Комбера из их учебника "Введение в R для пространственного анализа и картографирования".Из главы 6 я адаптировал приведенный ниже пример кода.
Я хочу извлечь оценку плотности ядра для каждой пары координат, из которой состоит smooth_map, но до сих пор не смог этого достичь.
# Load GISTools (for the data) and tmap (for the mapping)
require(GISTools)
require(tmap)
require(tmaptools)
# Get the data
data(newhaven)
# look at it
# select 'view' mode
tmap_mode('view')
# Create the map of blocks and incidents
tm_shape(blocks) + tm_borders() + tm_shape(breach) +
tm_dots(col='navyblue')
# Function to choose bandwidth according Bowman and Azzalini / Scott's rule
# for use with <smooth_map> in <tmaptools>
choose_bw <- function(spdf) {
X <- coordinates(spdf)
sigma <- c(sd(X[,1]),sd(X[,2])) * (2 / (3 * nrow(X))) ^ (1/6)
return(sigma/1000)
}
# Calculate kernel density
breach_dens <- smooth_map(breach,cover=blocks, bandwidth = choose_bw(breach))
# Plot resulting polygon map
tm_shape(breach_dens$polygons) + tm_fill(col='level',alpha=0.8)+
tm_shape(blocks) + tm_borders() + tm_shape(breach) +
tm_dots(col='navyblue')