El problema de determinar si un programa tiene 'rendimiento de optimización' A o 'rendimiento de optimización' B para casi cualquier definición de 'rendimiento de optimización' es indecidible en general (prueba a continuación). Esto implica que no existe un método único que siempre pueda decirle qué tan óptimo es un algoritmo.
Sin embargo, existen métodos que a menudo se aplican al analizar algoritmos de aproximación. A menudo, los algoritmos de aproximación son evaluados por sus garantías sobre qué tan lejos está su solución de la solución óptima. Daré un ejemplo de problema y aproximación, que probaré usando el método de 'límite inferior', que es un método muy comúnmente utilizado para probar proporciones.
El problema en cuestión es el problema de 'Carga de camiones': tenemos muchos camiones idénticos (tantos como queramos), cada uno capaz de transportar una carga que pesa como máximo T. Tenemos n objetos que deseamos cargar en estos camiones para transporte. Cada objeto i tiene un peso w_i, donde w_i <= T (por lo que no hay elementos que no puedan caber en un camión, incluso por sí mismos). Los artículos no se pueden dividir en partes. Nos gustaría llenar los camiones para que necesitemos la menor cantidad posible de camiones. Este problema es NP-completo.
Hay un algoritmo de aproximación muy fácil para este problema. Simplemente comenzamos a cargar un camión con artículos, hasta que el camión está tan lleno que el siguiente artículo no cabe. Luego tomamos otro camión y cargamos este camión con este artículo que no cabía en el camión anterior. No cargamos más artículos en este camión: en su lugar, tomamos un camión nuevo, lo llenamos con muchos artículos nuevamente hasta que ya no cabe, colocamos ese último artículo en su propio camión nuevamente y así sucesivamente.
Este algoritmo es una llamada aproximación 2 para el problema: utiliza como máximo el doble de camiones que la solución óptima necesitaría. El 'a lo sumo' es crucial: podríamos tener suerte y encontrar la solución óptima, pero al menos no lo haremos tan mal.
Para probar esto, primero definimos un límite inferior en la cantidad óptima de camiones que necesitamos. Para esto, imagine que se nos permite cortar elementos en partes: podríamos llenar fácilmente todos los camiones, excepto el último por completo. La cantidad de camiones que necesitaríamos si lo hiciéramos es un límite inferior para la cantidad de camiones que necesitamos para la pregunta original: en el 'mejor' caso, la solución óptima siempre llena cada camión por completo, en cuyo caso el número de camiones es igual, pero si las soluciones óptimas dejan los camiones sin llenar, entonces solo puede necesitar más camiones.
Ahora miramos nuestro algoritmo de aproximación. Tenga en cuenta que en cada paso, nosotros (parcialmente) llenamos dos camiones. También tenga en cuenta que, por cómo funciona el algoritmo, los artículos en el primer camión y el artículo en el segundo camión juntos no pueden caber en el primer camión, por lo que su suma es al menos T. Esto significa que en cada paso, cargamos al menos una carga completa valor del camión de artículos en dos camiones. Ahora compare esto con nuestro límite inferior: en ese caso, cargamos un camión completo de artículos en un camión. En otras palabras, nuestro algoritmo de aproximación calcula (en tiempo lineal) una solución que se parece mucho a nuestra 'solución' de límite inferior, pero utiliza dos camiones en lugar de uno. Por lo tanto, utilizamos como máximo el doble de camiones que el algoritmo óptimo, porque utilizamos como máximo el doble de camiones que nuestro límite inferior en el algoritmo óptimo.
Este algoritmo proporciona una aproximación de factor constante: es como máximo 2 veces más malo que la solución óptima. Algunos ejemplos de otras medidas: como máximo C más que la solución óptima (error aditivo, bastante infrecuente), como máximo c log n veces peor que la solución óptima, como máximo cn veces tan malo como la solución óptima, como máximo c 2 ^ (dn) veces tan malo como la solución óptima (muy malo; por ejemplo, el TSP general solo admite algoritmos con este tipo de garantías).
Por supuesto, si desea estar seguro de que el factor que prueba es el mejor factor que puede probar, debe intentar encontrar instancias en las que la solución que le brinda su algoritmo sea tan mala como sea posible.
También tenga en cuenta que a veces usamos algoritmos de aproximación en problemas que no son NP-hard.
Aprendí esto (entre muchos más) en el curso de algoritmos de aproximación en mi universidad.
Prueba de indecidibilidad: deje que P sea un problema y A y B sean algoritmos de aproximación para P donde A y B no tienen la misma 'óptima' para alguna definición sensata de 'óptima', y donde el tiempo de ejecución de A y B es omega (1) (estrictamente más lento que el tiempo constante, es decir, se vuelven más lentos para instancias más grandes) y donde A y B siempre se detienen.
Sea D un programa que afirme que puede calcular lo siguiente: dado que algún programa C calcula una aproximación para P, decida si es tan bueno como A o tan bueno como B para entradas suficientemente grandes (por lo tanto, puede usar esto para categorizar programas de acuerdo a su optimidad).
Entonces podemos usar D para resolver el problema de detención. Sea E un programa y F una entrada para este programa. Usaremos D para decidir si E se detendrá en la entrada F.
Diseñamos un programa G que hace lo siguiente: dada una entrada S para el problema P, ejecuta E en F y A en S en paralelo: ejecuta E por un tiempo, luego A, luego E nuevamente y así sucesivamente. Si E se detiene en F, deja de ejecutar A y en su lugar ejecuta B en S y devuelve el resultado de B. Si A se detiene antes de que E se detenga, devuelve el resultado de A.
El uso de D en G ahora decide si E se detiene en F: si E se detiene en F, entonces para entradas suficientemente grandes S, E se detiene en F antes de que A se detenga en S (porque el tiempo que tarda E en detenerse no depende del tamaño de la entrada, a diferencia de A). Por lo tanto, D informa que G tiene las características de optimización de B. Si E no se detiene en F, D informará que G tiene las características de optimización de A.