knitr::opts_chunk$set(echo = TRUE, comment = ">")
library(cholera)

overview

"The Voronoi region of a site s is the set of points in the plane for which s is the closest site among all the sites."^[Steven Fortune. 1987. "A Sweepline Algorithm for Voronoi Diagrams". Algorithmica. 2:153-174.] Given this definition, you might wonder why there's both a neighborhoodEuclidean() and a neighborhoodVoronoi() function. First, by definition, you need at least two sites to create a Voronoi diagram so neighborhoodVoronoi(7) will return an error but neighorhoodEuclidean() will not. This also what allows you to create star plots that are centered on a single pump.

plot(neighborhoodEuclidean(7))

Second, neighborhoodEuclidean() allows you to add a small dose of "realism". With Voronoi tessellation, all that matters is the location of the pumps. All other data, be it buildings, roads or the location of fatalities, simply do not matter. But with neighborhoodEuclidean(case.set = "expected"), we can use case.location = "nominal" or case.location = "address".

The former uses the nominal coordinates of the expected or simulated cases from regular.cases. Doing so effectively replicates the Voronoi diagram:

plot(cholera::neighborhoodEuclidean(case.set = "expected",
  case.location = "nominal"), type = "area.points")
cholera::addVoronoi(case.location = "nominal", color = "white", lwd = 2)

The latter impose a constraint that the starting point must be a street address (i.e., people must leave their homes from the front door).^[These "addresses" are based on orthogonal projection from the case's nominal location to the nearest street segment. See simulateFatalities() for details.] This produces an alternate picture of pump neighborhoods:

plot(cholera::neighborhoodEuclidean(case.set = "expected",
  case.location = "address"), type = "area.points")
cholera::addVoronoi(case.location = "address", color = "white", lwd = 2)

notes



lindbrook/cholera documentation built on Jan. 13, 2025, 3:49 p.m.