Polígonos de Thiessen

algoritmo de división espacial

Los polígonos de Thiessen, nombrados en honor al meteorólogo estadounidense Alfred H. Thiessen, son una construcción geométrica que permite construir una partición del plano euclídeo. Estos objetos también fueron estudiados por el matemático ucraniano Gueorgui Voronói en 1907, de donde toman el nombre alternativo de Diagramas de Voronoi o Teselación de Voronoi, y por el matemático alemán Gustav Lejeune Dirichlet en 1850, de donde toman el nombre de Teselación de Dirichlet.

20 puntos en el plano y su partición del plano en regiones de Voronoi.

Los Diagramas de Voronoi son uno de los métodos de interpolación más simples, basados en la distancia euclidiana, especialmente apropiada cuando los datos son cualitativos. Se crean al unir los puntos entre sí, trazando las mediatrices de los segmento de unión. Las intersecciones de estas mediatrices determinan una serie de polígonos en un espacio bidimensional alrededor de un conjunto de puntos de control, de manera que el perímetro de los polígonos generados sea equidistante a los puntos vecinos y designan su área de influencia.

Diagramas de Voronói en el plano euclidiano

editar

La forma más fácil e intuitiva de visualizar a los diagramas de Voronói es a través de su representación en el plano euclídeo. En la literatura clásica se supone el hecho de contar con un conjunto de establecimientos que se desean colocar sobre una cierta región geográfica de tal manera que las ubicaciones sean lo más rentables posible. Por tanto, se debe hallar una configuración que permita que el número de clientes atraídos sea el más factible. La suposición lógica indica que los clientes irían al establecimiento más cercano a su domicilio y no a aquellos que sean muy lejanos. Con base en esto, los diagramas de Voronói otorgan la configuración deseada por los establecimientos. El diagrama de Voronói induce una subdivisión del plano euclidiano (la región geográfica) en función de un conjunto de sitios (los establecimientos), donde a cada sitio se le asocia una y solamente una subdivisión. Además, cada subdivisión engloba todos los puntos más cercanos al sitio asociado a los sitios restantes, a esto se lo denomina un modelo de asignamiento de Voronói.[1]

Definición formal

editar
 
Los cuatro sitios más externos tiene asociados regiones de Voronói abiertas caracterizadas por las semi-aristas.

En primera instancia, denotemos a la distancia euclidiana entre dos puntos   y   por  . En el plano entonces se tiene:

 

 
Construcción de la región de Voronói de un sitio debido a la intersección de semi-planos.

Sea   el conjunto de   puntos distintos en el plano que son denominados como sitios. Se define el diagrama de Voronói de   como la subdivisión del plano en   regiones, una para cada  , cumpliendo la propiedad de proximidad en la que un punto   pertenece a la región de un sitio   si y sólo si   para cada  . Se denotará al diagrama de Voronói de   mediante  . Cada región que corresponde a un sitio   se denotará como   y será llamada región de Voronói de  .

La región de Voronói para un sitio   está construida a partir de las intersecciones de los semiplanos formados al trazar los bisectores de   hacia los sitios  . Tomando el caso donde únicamente hay dos sitios   y  , se traza el segmento de recta   y posteriormente se traza el bisector de  . Este bisector parte el plano en dos semiplanos, donde el semiplano que contiene a   (representado como  ) representa el lugar geométrico de todos los puntos más cercanos a   que a  ; y el semiplano que contiene a   ( ) alberga a todos los puntos más próximos a   que a  . De acuerdo con esto, entonces se puede establecer de forma general cómo se define la región de Voronói para un sitio  .

 


  está compuesta por la intersección de   semiplanos que conforman una región poligonal convexa que puede ser abierta o cerrada. La región está acotada por un máximo de   vértices y un máximo de   aristas. Se tienen estas cantidades de vértices y aristas debido a que los sitios más lejanos suelen tener asociados regiones de Voronói no acotadas conformadas por aristas y semi-aristas (aristas que tienen un vértice de inicio pero no uno final).

Propiedades

editar

A continuación se enunciarán un conjunto de propiedades[1][2]​ del Diagrama de Voronói donde se asume que no puede haber cuatro puntos del conjunto original   en posición cocircular. En caso de que esta situación no sea contemplada, entonces se deben considerar una gran cantidad de detalles que deben ser agregados a las diferentes propiedades.

  • Teorema 1. Sea   un conjunto de   sitios en el plano. Si todos los sitios son colineales, entonces   consiste de   líneas paralelas. De otra forma,   es conexo y sus aristas podrían ser segmentos o semi-líneas.
  • Teorema 2. Para  , el número de vértices en el diagrama de Voronói de un conjunto de  sitios en el plano es a lo más   y el número de aristas es a lo más  .

La siguiente propiedad ayuda a caracterizar los vértices y aristas que componen el diagrama de Voronói. Sin embargo, es necesario definir qué significa el círculo vacío más grande de  , denotado como  . Para un punto  ,   se define como el círculo más grande que tiene a   como su centro y no contiene ningún otro sitio de   en su interior.

  • Teorema 3. Para un diagrama de Voronói   de un conjunto de sitios   lo siguiente se cumple:
    • Un punto   es un vértice de   si y solo si su más grande círculo vacío   contiene tres o más sitios en su contorno.
    • El bisector entre los sitios   y   define una arista de   si y solo si hay un punto   sobre el bisector tal que   contiene tanto a   y a   en su contorno pero no otro sitio.
  • Teorema 4. Cada vecino más cercano del sitio   en   define una arista de  .
  • Teorema 5. La región de Voronói   es abierta si y solo si   es un punto en la envolvente convexa del conjunto  .
  • Teorema 6. La gráfica dual del diagrama de Voronói define la triangulación de Delaunay.

Algoritmos para la construcción del Diagrama de Voronói

editar

Algoritmo por fuerza bruta

editar

Una primera aproximación para la construcción del diagrama de Voronói consiste en explotar la geometría de cada región de Voronói. Por cada sitio   se construirá su región de Voronói mediante el cálculo explícito de los   semiplanos originados debido a los bisectores trazados con respecto a los demás sitios. Posteriormente, se computará la intersección de estos   semiplanos para, finalmente, dar origen a  .

Este algoritmo tiene muchas desventajas de entre las cuales se tienen las que a continuación se describen. En primera instancia, el cálculo explícito de los semi-planos y su intersección puede provocar problemas de precisión en la computadora generado, evidentemente, una versión incorrecta de  . El segundo inconveniente involucra que no se produce información inmediata y que se pueda aprovechar acerca del vecindario de cada sitio. Finalmente, dado que se trata del algoritmo de un algoritmo ineficiente, no resulta extraño descubrir que su complejidad computacional sea alta. El algoritmo está en el orden de  

Algoritmo divide y vencerás

editar

Este algoritmo está fundamentado sobre el paradigma de diseño de algoritmos divide y vencerás. Dado el problema de construir el diagrama de Voronói para el conjunto   de sitios, ahora se dividirá a este último en dos subconjuntos   y  , con aproximadamente el mismo tamaño, de los que se debe encontrar su diagrama de Voronoi independientemente. Finalmente,   y   deben ser unidos para poder obtener  . Sin embargo, ¿qué razón existe para que se crea que   y   tengan alguna relación con  ?

Para que se pueda contestar la última pregunta, es necesario definir construcciones geométricas que serán de vital importancia.

Definición 1. Dado una petición   de  , sea   el conjunto de aristas de Voronoi que son compartidas por pares de regiones de Voronoi   y  .

La colección de aristas   tiene las siguientes propiedades.

Teorema 7  es el conjunto de aristas de una subgráfica de   con las siguientes propiedades:

  •   consta de ciclos y cadenas de aristas disjuntas. Si una cadena tiene una sola arista, ésta es una línea recta; de otra forma sus dos aristas extremas son rayos semi-infiitos.
  • Si   y   son linealmente separados (si más de un punto pertenece a la línea de separación, todos estos puntos son asignados a un mismo conjunto de la partición), entonces   consiste de una sola cadena monotónica.

Con el fin de separar a   en dos subconjuntos se le deberá ordenar con respecto a las abcisas y tomar la recta   que pase por la mediana, de tal suerte que se tengan dos subconjuntos de aproximadamente el mismo tamaño. Adicionalmente, dada esta elección de recta de separación, se puede decir que   parte al plano en una porción izquierda   y una porción derecha  . Con base en esto, se tiene la siguiente propiedad:

Teorema 8. Si   y   son linealmente separados por una línea vertical con   a la izquierda y   a la derecha, entonces el diagrama de Voronoi   es la unión de   y  .

A partir del último teorema es que se puede responder la pregunta inicial acerca de cómo se vinculan dos diagramas de Voronoi de dos particiones para generar el diagrama de Voronoi de todo el conjunto de sitios. El siguiente algoritmo[2]​ establece la forma de calcular el diagrama de Voronoi mediante la técnica divide y vencerás.

Procedimiento DIAGRAMA DE VORONOI

Paso 1. Partir a   en dos subconjunto   y  , de aproximadamente el mismo tamaño, mediante la mediana en las coordenadas x.

Paso 2. Construir   y   recursivamente.

Paso 3. Construir la cadena polígona  , separando a   y  .

Paso 4. Descartar todas las aristas de   que estén a la izquierda de  . El resultado es  , el diagrama de Voronoi del diagrama entero.

Algoritmo de Fortune (barrido de recta)

editar
Inspiración
editar

El algoritmo de fuerza bruta previamente revisado tiene una complejidad   , sin embargo, debido al teorema 2, se puede suponer que hay una forma mucho más eficiente de encontrar el diagrama de Voronoi pues sus elementos constituyentes tienen complejidad  .[1]​ En efecto, existe este algoritmo y es llamado Algoritmo de Fortune[3] en honor a Steven Fortune quien lo inventó en 1986 y cuya complejidad es  .[1]

 
Cálculo del diagrama de Voronoi con ayuda de la técnica de barrido de recta. Se nota que conforme la recta se mueve, la línea de playa cambia generando las regiones de Voronoi de los sitios.

El algoritmo de Fortune está basado en una de las técnicas clave dentro de la geometría computacional denominada barrido de recta. La esencia de esta técnica yace en suponer que existe una recta   que recorre el plano de arriba hacia abajo (o de izquierda a derecha, incluso en direcciones opuestas) y que a lo largo de su recorrido se interseca con las estructuras que deseamos procesar. Cuando se da esta intersección, se guarda cierta información de tal forma que ayude en los cálculos. Es necesario que la información que se haya obtenido en regiones ya visitadas por la recta sea invariante. Es muy común que está técnica utilice dos tipos de estructuras de datos: cola de prioridades donde se guardan eventos que no son más que puntos donde la recta debe detenerse y un árbol binario de búsqueda donde se almacenan los elementos geométricos que se han intersecado con la recta y se necesita recordar para el procesamiento futuro. Cabe resaltar que debido a que en la computadora no se puede emular tal cual el movimiento continuo de la recta de barrido, se requiere idear una forma de discretización del movimiento de la recta que sea procesable en la computadora, de ahí que los eventos sean tal discretización.

Propiedades combinatorias
editar

Para aplicar el barrido de recta al diagrama de Voronoi, intuitivamente, se podría tomar al conjunto de sitios   como los eventos y de esta manera llevar la intersección de la recta de barrido con el diagrama de Voronoi. No obstante, debido a que el cálculo de   depende de la intersección de   planos, entonces no se podría mantener el invariante de la técnica ya que aun cuando   ya haya procesado un sitio, la información con respecto a su región de Voronoi seguirá cambiando debido a los sitios restantes por procesar. Con base en esto, es imperativo cambiar la perspectiva y en lugar de mantener la intersección de   con   se necesita mantener la información acerca de aquellos sitios sobre   que ya no podrá cambiar debido a los sitios debajo de  .

 
Línea de playa para el diagrama de Voronoi.

Se denotará al semi-plano cerrado sobre   como  . Se busca cuál es la parte del diagrama de Voronoi sobre   que ya no podrá cambiar jamás, para lo cual se tiene lo siguiente. Dado un punto  , la distancia de éste a cualquier punto debajo de   es más grande que la distancia de   a   propiamente. Además, el sitio más cercano   no puede estar debajo de   si   es al menos tan cercano a algún sitio   como   lo es a  . Por tanto, el lugar geométrico de puntos más cercanos de algún sitio que a   está limitado por una parábola. Siguiendo esta línea, el lugar geométrico de todos los puntos más cercanos a algún sitio sobre   que a   en sí misma está acotado por un conjunto de a lo más  [1]​ arcos parabólicos. Este conjunto de arcos se denomina línea de playa. Cada sitio   sobre la línea de barrido define una parábola completamente. La línea de playa cuenta con la propiedad de monotonicidad ya que si se hace pasar cualquier recta vertical por ella, ésta la interseca en exactamente un punto.[1]

Entonces, en lugar de mantener la intersección de   con  , se mantendrá la línea de playa conforme la línea de barrido se mueva. Evidentemente, no se puede representar explícitamente la línea de playa ya que es continua y se transforma cada que   cambia de posición.

 
Generación de un nuevo arco en la línea de playa.

Un arco puede aparecer en la línea de playa cuando   procesa un nuevo sitio, de ahí que esto tome el nombre de evento de sitio. En este momento una nueva parábola (en forma de línea vertical pues el lado recto es infinitesimalmente pequeño) rompe sobre la línea de playa. Conforme la línea de playa comienza a bajar, la recientemente creada parábola comienza a hacerse más amplía. Además, conforme va creciendo la parábola se generan intersecciones con otras parábolas en la línea de playa, lo cual comienza a trazar las aristas[1]​ del diagrama de Voronoi.

Un segundo evento de la línea de barrido surge cuando un arco   se hace tan pequeño que se convierte en un punto. Cuando se presenta esto, las intersecciones que tenía   con los otros arcos (  a la izquierda y   a la derecha) se juntan. Este encuentro de los puntos de intersección implica que dos aristas del diagrama se están encontrado. En consecuencia, se ha formado un vértice   del diagrama de Voronoi. Gráficamente,   es el centro de un círculo que pasa por los sitios   y   correspondientes a   y  , respectivamente. Cuando   alcanza el punto más bajo de este círculo, se ostenta un evento de círculo.

Estructuras de datos y algoritmo
editar

El algoritmo de Fortune necesita de tres tipos de estructuras de datos:

  1. Estructura de datos que ayude a guardar la porción del diagrama calculada hasta el momento. Para esto se emplea una lista doblemente conectada de aristas DCEL.[1]​ Se referirá a éste como  .
  2. Cola de prioridades   que permita guardar los eventos de sitio y de círculo que debe procesar la línea de barrido.
  3. Árbol de búsqueda binario balanceado   que guarde la línea de playa. Dado que no se puede guardar directamente la línea de playa debido a su naturaleza continua, se hace lo siguiente. En las hojas  , se guardan los arcos de la línea de playa, caracterizados por el sitio que los define, manteniendo el orden como el que se apreciaría en la línea de playa realmente. Por su parte los nodos intermedios representan los puntos de quiebre (donde un arco rompe en la línea de playa) como túpalas  , donde   denota la parábola a la izquierda y   la correspondiente a la derecha.

El siguiente pseudocódigo se basa en el que se presenta en la obra de Mark de Berg et al.[1]

Algoritmo  

Entrada. Conjunto de sitios   en el plano.

Salida   dentro de una caja de restricción en  .

Inicializar   con todos los sitios; inicializar   como vacío y una DCEL   vacía.
while   no esté vacía
Remover el evento con la coordenadana   más grande de  .
if el evento es un evento de sitio en   then
 
else  , donde   representa la hoja de   representando el arco que desaparecerá.
Computar caja de restricción que contenga todos los vértices de   dentro y una las semi-aristas hacia la caja.


 

Si   está vacío, insertar  . De lo contrario hacer los siguientes pasos.
Buscar en   el arco   verticalmente sobre  . Si la hoja   tiene un puntero hacia  , entonces es una falsa alarma y debe ser eliminado de  .
Reemplazar la hoja de   que representa a   con un subárbol con tres hojas. La hoja en el centro guarda el sitio   y otras dos guardan a   que originalmente estaba en  . Guardar las túplas   y   representando los nuevos puntos de quiebre.
Crear nuevos registros de semi-aristas en   para la arista que separa a   y  , que será trazada debido a los puntos de quiebre.
Checar las tripleta de arcos consecutivos donde el nuevo arco de   es el arco izquierdo para ver si los puntos de quiebre convergen.


 

Borrar la hoja   que representa el arco a desaparecer   de  . Actualizar túplas que representan los puntos de quiebre. Reebalancear  . Eliminar de   todos los eventos que involucren a  .
Añadir el centro del círculo causante del evento como un registro de vértice en  . Crear dos semi-aristas correspondientes a los nuevos puntos de quiebre de la línea de playa.
Checar la nueva triplete de arcos consecutivos que tenía a   en el medio si los dos puntos de quiebre convergen. De ser así, insertarlo el evento correspondiente en  . Hacer lo mismo para la triplete donde   estaba a la derecha.
Complejidad
editar

El algoritmo se ejecuta en   y usa   almacenamiento. Esto se debe a que las operaciones sobre   y en   toman  .[4]​ Las operaciones en la DCEL toman tiempo constante.[1]​ Cuando se procesa un evento se ejecuta un número constante de operaciones de tales operaciones. Y dado que se tiene   eventos (debido al teorema 2), entonces la complejidad es  . Por su parte, el almacenamiento es lineal nuevamente debido al teorema 2.

Generalización a

editar
 
Teselación de Voronói de un conjunto de puntos aleatorio sobre el plano.

Para cada conjunto topológico discreto S de puntos en un espacio euclídeo y para casi todo punto x, existe un punto de S que es el más cercano a x. (Aquí, el término casi se usa para indicar que existen excepciones en las cuales x puede equidistar de dos o más puntos de S.)

Si S contiene sólo dos puntos, a y b, entonces el conjunto de todos los puntos que equidistan de ambos es un hiperplano de codimensión 1. Ese hiperplano es la frontera entre los puntos más cercanos a a que a b, y los puntos más cercanos a b que a a. De hecho, ese hiperplano es el plano bisector del segmento que une a y b. Más en general, el conjunto de puntos más cercanos a un punto c de S que a ningún otro punto de S (cuenca de atracción de c) es el interior de un politopo convexo (posiblemente no acotado) llamado dominio de Dirichlet o celda de Voronói de c. El conjunto de todos esos politopos constituye una teselación completa del espacio euclídeo, llamada teselación de Voronói asociada a S.

Si la dimensión del espacio euclídeo es sólo 2, como en el plano euclídeo, entonces resulta muy sencillo dibujar teselaciones de Voronoi, como las de la figura adjunta.

Aplicaciones

editar
 
Proceso llevado a cabo en un Sistema de Información Geográfica (SIG) para la obtención de ejes de calles mediante el uso de polígonos de Thiessen

Los diagramas de Voronoi encuentran aplicaciones en áreas tales como gráficos por computadora, geografía, epidemiología, geofísica y meteorología. Un uso particularmente notable fue en el análisis de la epidemia de cólera de 1854 en Londres llevado a cabo por el médico John Snow, el cual determinó una fuerte correlación de muertes con la proximidad a una determinada bomba de agua —a la postre contaminada— en Broad Street (en el distrito de Soho).[5]​ Su conocido mapa del cólera constituye hoy en día uno de los ejemplos clásicos de uso del método geográfico.

Se han utilizado para el análisis de datos meteorológicos (estaciones pluviométricas), aunque en la actualidad también se aplican en estudios en los que hay que determinar áreas de servicio (centros hospitalarios, estaciones de bomberos, bocas de metro, centros comerciales, control del tráfico aéreo, telefonía móvil, análisis de poblaciones de especies vegetales, etcétera). Es una de las funciones de análisis básicas en los Sistemas de Información Geográfica (SIG).

Una aplicación más avanzada es la de su uso en el geomarketing y el análisis geoespacial, para hacerlo primero se deben recopilar datos de latitud y longitud de los puntos que se requieren a estudiar, luego por medio de algoritmos no supervisados de machine learning como K-Means en conjunto con Voronoi sea pueden obtener clusters de dicho algoritmo no supervisado pero con la diferencia de que estos estarán delimitados por una región de Voronoi, entonces se puede obtener la "dominancia del cluster". Caso similar también aplica para el marketing, por ejemplo, en lugar de tener «latitud» o «longitud» de datos geoespaciales podríamos tener una relación entre ingresos de un grupo de usuarios y lo que suelen gastar, de forma que se pueda optimizar la publicidad de forma más eficiente usando la región de Voronoi como una ayuda extra para delimitar una publicidad de marketing a un grupo de usuarios.[6]

Véase también

editar

Enlaces externos

editar

Referencias

editar
  1. a b c d e f g h i j de Berg, Mark; Cheong, Otfried; van Kreveld, Marc; Overmars, Mark (2008). «7». Computational Geometry: Algorithms and Applications (en inglés) (tercera edición). Springer-Verlag Berlín Heidelberg. pp. 147-171. ISBN 978-3-540-77973-5. 
  2. a b Preparata, Franco P.; Shamos, Michael Ian (1985). «5». En David Gries, ed. Computational Geometry: an introduction (en inglés). Springer-Verlag. pp. 204-223. ISBN 0-387-96131-3. 
  3. Steven Fortune. A sweepline algorithm for Voronoi diagrams. Proceedings of the second annual symposium on Computational geometry. Yorktown Heights, New York, United States, pp.313–322. 1986. ISBN 0-89791-194-6. ACM Digital LibrarySpringerLink
  4. Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Clifford, Stein (2009). Introduction to Algorithms (en inglés) (tercera edición). MIT Press. ISBN 978-0-262-03384-8. 
  5. http://mathworld.wolfram.com/VoronoiDiagram.html
  6. «▷ Análisis geoespacial en Python: Cluster K-Means, Voronoi y Open Street Map». 16 de enero de 2024. Consultado el 1 de marzo de 2024.