Algoritmo de triangulación voraz

método de cálculo geométrico De Wikipedia, la enciclopedia libre

Algoritmo de triangulación voraz

El Algoritmo de Triangulación Voraz es un método para calcular una triangulación de un polígono o de una nube de puntos mediante un método voraz, que consiste en añadir aristas a la solución de una en una uniendo el par de vértices más próximos entre sí, con la condición de que una nueva arista no puede cortar a otra previamente añadida al resultado. [1][2]

Datos rápidos Tipo, Problema que resuelve ...
Algoritmo de Triangulación Voraz
Thumb
Triangulación del interior de un polígono paso a paso mediante el algoritmo voraz que escoge la diagonal más corta.
Tipo Algoritmo voraz
Problema que resuelve Triangulación de un polígono
Estructura de datos
Clase de complejidad P
Tiempo de ejecución
Peor caso
Mejor caso
Cerrar

Propiedades

Resumir
Contexto

Las triangulaciones calculadas mediante el algoritmo de triangulación voraz tienen las siguientes propiedades:

  • Son una buena aproximación de la triangulación de peso mínimo de un polígono o nube de puntos, aunque no siempre coinciden.
  • Frecuentemente, aunque no siempre, suelen coincidir con la triangulación de Delaunay de los mismos datos de entrada.
  • Si la entrada es una nube de puntos, todas las aristas del cierre convexo pertenecen a la triangulación voraz.
  • Si la entrada es un polígono, las aristas de la triangulación son un subconjunto de las diagonales internas del polígono.
  • La implementación por fuerza bruta del algoritmo es de orden para un conjunto de entrada de puntos.[3]
  • Existen implementaciones capaces de calcular la triangulación voraz en tiempo empleando estructuras adicionales para comprobar los cruces entre aristas.[2]
  • La triangulación voraz puede calcularse a partir de la triangulación de Delaunay añadiendo una cantidad de tiempo lineal.[4]


Pseudoalgoritmo

Resumir
Contexto

Existen varias posibles estrategias para implementar el algoritmo de triangulación voraz. Tal vez, la más sencilla de todas sea la siguiente:

Algoritmo triangulación voraz
1 Crear un solución inicial con las aristas del polígono de entrada (o vacía, en caso de nubes de puntos)
2 Crear una lista de aristas candidatas, combinando todos los vértices de entrada dos a dos.
3 Ordenar la lista de candidatas anterior de menor a mayor longitud de arista.
4 Mientras la lista de candidatas no sea vacía.
4.1 Obtener la primera arista de la lista (la más corta) y borrarla de la lista de candidatas.
4.2 Si la arista candidata no se cruza con ninguna otra de la triangulación, insertarla en la triangulación.

Sin embargo, existen soluciones alternativas que pueden acelerar mucho la construcción en caso de que la entrada tenga un tamaño considerable.[2] Especialmente si el número de vértices en la entrada es grande, se debería evitar la comparación de todos los vértices de entrada dos a dos, ya que es un problema de orden . Para ello debería emplearse alguna versión eficiente del Problema del par de puntos más cercanos (que puede resolverse en tiempo ),[5][6] o bien emplear una triangulación de Delaunay como paso intermedio.[4]

Referencias

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.