Primero, un comentario. Su pregunta depende de cuán geométricamente pretenda que signifique la palabra "métrica". Es razonablemente común usar ultramétricos en semántica y análisis estático, pero los ultramétricos tienden a tener una interpretación combinatoria en lugar de geométrica. (Esta es una variante de la observación de que la teoría de dominio tiene el sabor de un uso combinatorio en lugar de geométrico de la topología).
Dicho esto, te daré un ejemplo de cómo surge esto en las pruebas de programa. Primero, recuerde que en una prueba de programa, queremos mostrar que una fórmula que describe un programa es válida. En general, esta fórmula no necesariamente debe interpretarse con los booleanos, sino que puede extraerse de los elementos de una red de valores de verdad. Entonces, una fórmula verdadera es solo una que es igual a la parte superior de la red.
Además, cuando se especifican programas muy autorreferenciales (por ejemplo, programas que hacen un uso extensivo del código de modificación automática), los asuntos pueden ser muy difíciles. Por lo general, queremos dar una especificación recursiva del programa, pero puede que no haya una estructura inductiva obvia sobre la cual colgar la definición. Para resolver este problema, a menudo es útil equipar la red de valores de verdad con una estructura métrica adicional. Entonces, si puede demostrar que el predicado cuyo punto fijo que desea es estrictamente contractual, puede recurrir al teorema del punto fijo de Banach para concluir que el predicado recursivo que desea está bien definido.
El caso con el que estoy más familiarizado se llama "indexación por pasos". En este contexto, tomamos nuestra red de valores de verdad como subconjuntos cerrados hacia abajo de N , cuyos elementos podemos interpretar libremente como "las longitudes de las secuencias de evaluación en las que se mantiene la propiedad". Las reuniones y las uniones son intersecciones y uniones, como de costumbre, y dado que la red está completa, también podemos definir la implicación de Heyting. La red también se puede equipar con una unidad ultramétrica al permitir que la distancia entre dos elementos de red sea 2 - n , donde n es el elemento más pequeño en un conjunto pero no en el otro.ΩN2−nn
Luego, el mapa de contracción de Banach nos dice que un predicado contractivo tiene un punto fijo único. Intuitivamente, esto dice que si podemos definir un predicado que se cumple para n + 1 pasos usando una versión que se cumple para n pasos, entonces tenemos una definición inequívoca de un predicado. Si luego mostramos que el predicado es igual a ⊤ = N , entonces sabemos que el predicado siempre es válido para el programa.p:Ω→Ωn+1n⊤=N