stringtranslate.com

Máquina post-Turing

Una máquina Post-Turing [1] es una "formulación de programa" de un tipo de máquina de Turing , que comprende una variante del modelo de computación equivalente a Turing de Emil Post . El modelo de Post y el modelo de Turing, aunque muy similares entre sí, se desarrollaron de forma independiente. El artículo de Turing se recibió para su publicación en mayo de 1936, seguido por el de Post en octubre. Una máquina Post-Turing utiliza un alfabeto binario , una secuencia infinita de ubicaciones de almacenamiento binario y un lenguaje de programación primitivo con instrucciones para el movimiento bidireccional entre las ubicaciones de almacenamiento y la alteración de sus contenidos de uno en uno. Los nombres "programa Post-Turing" y "máquina Post-Turing" fueron utilizados por Martin Davis en 1973-1974 (Davis 1973, p. 69ff). Más tarde, en 1980, Davis utilizó el nombre "programa Turing-Post" (Davis, en Steen p. 241).

1936: Modelo de poste

En su artículo de 1936 "Procesos combinatorios finitos: Formulación 1", Emil Post describió un modelo que, según su conjetura, es " lógicamente equivalente a la recursividad ".

El modelo de cálculo de Post difiere del modelo de máquina de Turing en una "atomización" adicional de los actos que una "computadora" humana realizaría durante un cálculo. [2]

El modelo de Post emplea un " espacio simbólico " que consiste en una "secuencia infinita de espacios o casillas bidireccionales", cada casilla capaz de estar en cualquiera de dos posibles condiciones, a saber, "marcada" (por ejemplo, con un único trazo vertical) y "no marcada" (vacía). Inicialmente, un número finito de casillas están marcadas, mientras que el resto no lo están. Un "trabajador" debe moverse entonces entre las casillas, estando y operando en una sola casilla a la vez, de acuerdo con un "conjunto finito de direcciones" ( instrucciones ) fijo, que están numeradas en orden (1,2,3,..., n ). Comenzando en una casilla "señalada como punto de partida", el trabajador debe seguir el conjunto de instrucciones una a la vez, comenzando con la instrucción 1.

Hay cinco operaciones primitivas diferentes que el trabajador puede realizar:

(a) Marcar la caja en la que se encuentra, si está vacía
(b) Borrar la marca en la casilla en que se encuentra, si está marcada
(c) Moviéndose hacia el cuadro de su derecha
(d) Moviéndose hacia el cuadro de su izquierda
(e) Determinar si la caja en que se encuentra está o no marcada.

Entonces, la i -ésima "dirección" (instrucción) dada al trabajador debe ser una de las siguientes formas:

  1. Realizar la operación O i [ O i = (a), (b), (c) o (d)] y luego seguir la dirección j i
  2. Realizar la operación (e) y según la respuesta sea sí o no seguir correspondientemente la dirección j i o j i
  3. Detener .

(El texto sangrado y en cursiva arriba son como en el original.) Post comenta que esta formulación está "en sus etapas iniciales" de desarrollo, y menciona varias posibilidades para una "mayor flexibilidad" en su "forma definitiva" final, incluyendo

  1. reemplazando la infinidad de cajas por un espacio simbólico extensible finito, "extendiendo las operaciones primitivas para permitir la extensión necesaria del espacio simbólico finito dado a medida que avanza el proceso",
  2. utilizando un alfabeto de más de dos símbolos, "que tiene más de una forma de marcar una casilla",
  3. introduciendo un número finito de "objetos físicos que sirvan como indicadores, que el trabajador puede identificar y mover de una caja a otra".

1947: Reducción formal de Post de las 5-tuplas de Turing a 4-tuplas

Como se menciona brevemente en el artículo Máquina de Turing , Post, en su artículo de 1947 ( Recursive Unsolvability of a Problem of Thue ) atomizó las 5-tuplas de Turing en 4-tuplas:

"Nuestros cuatrillizos son quintillizos en el desarrollo de Turing. Es decir, donde nuestra instrucción estándar ordena una impresión (sobreimpresión) o un movimiento, izquierda o derecha, la instrucción estándar de Turing siempre ordena una impresión y un movimiento, derecha, izquierda o ninguno" (nota al pie 12, Undecidable , p. 300)

Al igual que Turing, definió el borrado como la impresión del símbolo "S0". Por eso su modelo admitía cuatrillizos de sólo tres tipos (cf. Undecidable , p. 294):

q yo S j L q l ,
q yo S j R q l ,
q yo Sj Sk q l

En ese momento todavía conservaba la convención de máquina de estados de Turing: no había formalizado la noción de una supuesta ejecución secuencial de pasos hasta que una prueba específica de un símbolo "ramificó" la ejecución en otra parte.

1954, 1957: Modelo Wang

Wang (1957, pero presentado a la ACM en 1954) es citado a menudo (cf. Minsky (1967), p. 200) como la fuente de la "formulación del programa" de las máquinas de Turing de cinta binaria que utilizan instrucciones numeradas del conjunto

escribe 0
escribe 1
moverse a la izquierda
moverse a la derecha
Si escanea 0, vaya a la instrucción i.
Si escanea 1, vaya a la instrucción j

Cualquier máquina de Turing de cinta binaria se convierte fácilmente en un "programa Wang" equivalente utilizando las instrucciones anteriores.

1974: primer modelo de Davis

Martin Davis fue alumno de Emil Post y, junto con Stephen Kleene, completó su doctorado con Alonzo Church (Davis (2000) 1.ª y 2.ª notas al pie, pág. 188).

El siguiente modelo lo presentó en una serie de conferencias en el Courant Institute de la Universidad de Nueva York en 1973-1974. Este es el modelo al que Davis aplicó formalmente el nombre de "máquina post-Turing" con su "lenguaje post-Turing". [2] Se supone que las instrucciones se ejecutan secuencialmente (Davis 1974, p. 71):

1978: segundo modelo de Davis

El siguiente modelo aparece como ensayo ¿Qué es un cálculo? en Steen, páginas 241 a 267. Por alguna razón, Davis ha rebautizado su modelo como "máquina de Turing-Post" (con un retroceso en la página 256).

En el siguiente modelo, Davis asigna los números "1" a la "marca/barra" de Post y "0" al cuadrado en blanco. Para citar a Davis: "Ahora estamos listos para presentar el lenguaje de programación Turing-Post. En este lenguaje hay siete tipos de instrucciones:

"IMPRESIÓN 1
"IMPRIMIR 0
"VE A LA DERECHA
"Vaya a la izquierda
"VAYA AL PASO i SI SE ESCANEÓ 1
"VAYA AL PASO i SI SE ESCANEÓ 0
"DETENER

"Un programa Turing-Post es entonces una lista de instrucciones, cada una de las cuales es de uno de estos siete tipos. Por supuesto, en un programa real, la letra i en un paso del quinto o sexto tipo debe ser reemplazada por un número definido (entero positivo)" (Davis en Steen, p. 247).

1994 (2.ª edición): Modelo de programa post-Turing de Davis-Sigal-Weyuker

"Aunque la formulación de Turing que hemos presentado es más cercana en espíritu a la que originalmente dio Emil Post, fue el análisis de la computación que hizo Turing lo que hizo que esta formulación pareciera tan apropiada. Este lenguaje ha jugado un papel fundamental en la ciencia informática teórica." (Davis et al. (1994) p. 129)

Este modelo permite la impresión de múltiples símbolos. El modelo permite B (blanco) en lugar de S 0 . La cinta es infinita en ambas direcciones. Tanto la cabeza como la cinta se mueven, pero sus definiciones de DERECHA e IZQUIERDA siempre especifican el mismo resultado en ambos casos (Turing utilizó la misma convención).

IMPRIMIR σ ;Reemplazar el símbolo escaneado con σ
SI σ GOTO L; SI el símbolo escaneado es σ ENTONCES va a la "primera" instrucción etiquetada L
DERECHA; Escanear el cuadrado inmediatamente a la derecha del cuadrado escaneado actualmente
IZQUIERDA; Escanear el cuadrado inmediatamente a la izquierda del cuadrado escaneado actualmente

Este modelo se reduce a las versiones binarias { 0, 1 } presentadas anteriormente, como se muestra aquí:

IMPRIMIR 0 = BORRAR; Reemplazar el símbolo escaneado con 0 = B = EN BLANCO
IMPRIMIR 1 ;Reemplazar el símbolo escaneado con 1
SI 0 GOTO L; SI el símbolo escaneado es 0 ENTONCES va a la "primera" instrucción etiquetada L
SI 1 GOTO L; SI el símbolo escaneado es 1 ENTONCES vaya a la "primera" instrucción etiquetada L
DERECHA; Escanear el cuadrado inmediatamente a la derecha del cuadrado escaneado actualmente
IZQUIERDA; Escanear el cuadrado inmediatamente a la izquierda del cuadrado escaneado actualmente

Ejemplos de la máquina post-Turing

La atomización de Turing se quintuplica en una secuencia de instrucciones Post–Turing

El siguiente método de "reducción" (descomposición, atomización) –de quintuplas de Turing de dos símbolos a una secuencia de instrucciones Post–Turing de dos símbolos– se puede encontrar en Minsky (1961). Afirma que esta reducción a "un programa ... una secuencia de instrucciones " está en el espíritu de la máquina B de Hao Wang (cursiva en el original, cf. Minsky (1961) p. 439).

(La reducción de Minsky a lo que él llama "una subrutina" da como resultado 5 instrucciones Post-Turing en lugar de 7. No atomizó Wi0: "Escribe el símbolo Si0; ve al nuevo estado Mi0", y Wi1: "Escribe el símbolo Si1; ve al nuevo estado Mi1". El siguiente método atomiza aún más Wi0 y Wi1; en todos los demás aspectos los métodos son idénticos.)

Esta reducción de 5-tuplas de Turing a instrucciones Post-Turing puede no resultar en un programa Post-Turing "eficiente", pero será fiel al programa de Turing original.

En el siguiente ejemplo, cada 5-tupla de Turing del castor ocupado de 2 estados se convierte en

  1. un "salto" condicional inicial (ir a, rama), seguido de
  2. 2 instrucciones de acción de cinta para el caso "0": Imprimir o Borrar o Ninguno, seguido de Izquierda o Derecha o Ninguno, seguido de
  3. un "salto" incondicional para el caso "0" a su siguiente instrucción
  4. 2 instrucciones de acción de cinta para el caso "1": Imprimir o Borrar o Ninguno, seguido de Izquierda o Derecha o Ninguno, seguido de
  5. un "salto" incondicional para el caso "1" a su siguiente instrucción

para un total de 1 + 2 + 1 + 2 + 1 = 7 instrucciones por estado de Turing.

Por ejemplo, el estado de Turing "A" del castor ocupado de dos estados, escrito como dos líneas de 5-tuplas, es:

La tabla representa una única "instrucción" de Turing, pero vemos que consta de dos líneas de 5-tuplas, una para el caso "símbolo de cinta bajo la cabeza = 1", la otra para el caso "símbolo de cinta bajo la cabeza = 0". Turing observó ( Undecidable , p. 119) que las dos columnas de la izquierda - "m-configuration" y "symbol" - representan la "configuración" actual de la máquina -su estado incluyendo tanto Tape como Table en ese instante - y las últimas tres columnas son su "comportamiento" posterior. Como la máquina no puede estar en dos "estados" a la vez, la máquina debe "ramificarse" a una u otra configuración:

Después de la "rama de configuración" (J1 xxx) o (J0 xxx), la máquina sigue uno de los dos "comportamientos" subsiguientes. Enumeramos estos dos comportamientos en una línea y los numeramos (o etiquetamos) secuencialmente (de manera única). Debajo de cada salto (rama, destino) colocamos su "número" de salto (dirección, ubicación):

Según las convenciones de la máquina Post-Turing, cada una de las instrucciones Imprimir, Borrar, Izquierda y Derecha constan de dos acciones:

  1. Acción de la cinta: {P, E, L, R}, luego
  2. Acción de tabla: ir a la siguiente instrucción en secuencia

Y según las convenciones de la máquina Post-Turing, los "saltos" condicionales J0xxx, J1xxx constan de dos acciones:

  1. Acción de la cinta: mira el símbolo en la cinta debajo de la cabeza
  2. Acción de la tabla: Si el símbolo es 0 (1) y J0 (J1), entonces vaya a xxx; de lo contrario, vaya a la siguiente instrucción en la secuencia.

Y según las convenciones de la máquina Post-Turing, el "salto" incondicional Jxxx consiste en una sola acción, o si queremos regularizar la secuencia de 2 acciones:

  1. Acción de la cinta: mira el símbolo en la cinta debajo de la cabeza
  2. Acción de tabla: si el símbolo es 0, entonces vaya a xxx; de lo contrario, si el símbolo es 1, entonces vaya a xxx.

¿Cuáles y cuántos saltos son necesarios? El salto incondicional J xxx es simplemente J0 seguido inmediatamente por J1 (o viceversa). Wang (1957) también demuestra que solo se requiere un salto condicional, es decir, J0 xxx o J1 xxx. Sin embargo, con esta restricción, resulta difícil escribir instrucciones para la máquina. A menudo, solo se utilizan dos, es decir,

  1. { J0xxx , J1xxx }
  2. { J1 xxx, J xxx }
  3. { J0 xxx, J xxx },

pero el uso de los tres { J0 xxx, J1 xxx, J xxx } elimina instrucciones adicionales. En el ejemplo de Busy Beaver de 2 estados, usamos solo { J1 xxx, J xxx }.

Castor ocupado de 2 estados

La misión del castor atareado es imprimir tantos unos como sea posible antes de detenerse. La instrucción "Imprimir" escribe un 1, la instrucción "Borrar" (no se utiliza en este ejemplo) escribe un 0 (es decir, es lo mismo que P0). La cinta se mueve "hacia la izquierda" o "hacia la derecha" (es decir, el "cabezal" permanece estacionario).

Tabla de estados para una máquina de Turing de dos estados :

Instrucciones para la versión post-Turing de un castor atareado de dos estados: observe que todas las instrucciones están en la misma línea y en secuencia. Esto es una desviación significativa de la versión "Turing" y tiene el mismo formato que lo que se denomina un "programa de computadora":

Como alternativa, podemos escribir la tabla como una cadena. El uso de los "separadores de parámetros" : " y los separadores de instrucciones "," son totalmente de nuestra elección y no aparecen en el modelo. No hay convenciones (pero véase Booth (1967) p. 374, y Boolos y Jeffrey (1974, 1999) p. 23), para algunas ideas útiles sobre cómo combinar las convenciones de los diagramas de estados con las instrucciones, es decir, utilizar flechas para indicar el destino de los saltos). En el ejemplo inmediatamente inferior, las instrucciones son secuenciales a partir de "1", y los parámetros/"operandos" se consideran parte de sus instrucciones/"códigos de operación":

J1:5, P, R, J:8, P, L, J:8, J1:12, P, L, J1:1, P, N, J:15, H
El diagrama de estados de un castor ocupado de dos estados (pequeño dibujo, esquina derecha) se convierte en la máquina Post-Turing equivalente con la sustitución de 7 instrucciones Post-Turing por cada estado "Turing".

Notas

  1. ^ Rajendra Kumar, Teoría de los autómatas , Tata McGraw-Hill Education, 2010, pág. 343.
  2. ^ ab En su capítulo XIII Funciones computables , Kleene adopta el modelo de Post; el modelo de Kleene utiliza un espacio en blanco y un símbolo "marca de conteo ¤" (Kleene p. 358), un "tratamiento más cercano en algunos aspectos a Post 1936. Post 1936 consideró el cálculo con una cinta infinita de dos vías y solo 1 símbolo" (Kleene p. 361). Kleene observa que el tratamiento de Post proporcionó una reducción adicional a "actos atómicos" (Kleene p. 357) del "acto de Turing" (Kleene p. 379). Como lo describe Kleene, "el acto de Turing" es la combinación de 3 acciones (secuenciales en el tiempo) especificadas en una línea en una tabla de Turing: (i) imprimir símbolo/borrar/no hacer nada seguido de (ii) mover cinta a la izquierda/mover cinta a la derecha/no hacer nada seguido de (iii) probar cinta-ir a la siguiente instrucción: por ejemplo, "s1Rq1" significa "Imprimir símbolo "¤", luego mover cinta a la derecha, luego si el símbolo de cinta es "¤", entonces ir al estado q1". (Véase el ejemplo de Kleene en la p. 358.) Kleene observa que Post atomizó estas 3 acciones aún más en dos tipos de 2 acciones. El primer tipo es una acción de "imprimir/borrar", el segundo es una acción de "mover la cinta a la izquierda/derecha": (1.i) imprimir símbolo/borrar/no hacer nada seguido de (1.ii) probar cinta-ir a la siguiente instrucción, O (2.ii) mover cinta a la izquierda/mover cinta a la derecha/no hacer nada seguido de (2.ii) probar cinta-ir a la siguiente instrucción. Pero Kleene observa que mientras
    "De hecho, se podría argumentar que el acto de la máquina de Turing ya es compuesto y consiste psicológicamente en una impresión y un cambio en el estado mental, seguido de un movimiento y otro estado mental [y] Post 1947 separa así el acto de Turing en dos; no lo hemos hecho aquí, principalmente porque ahorra espacio en las tablas de la máquina al no hacerlo." (Kleene p. 379)
    De hecho, el tratamiento de Post (1936) es ambiguo; tanto (1.1) como (2.1) podrían ir seguidos de "(.ii) ir a la siguiente instrucción en secuencia numérica". Esto representa una atomización adicional en tres tipos de instrucciones: (1) imprimir símbolo/borrar/no hacer nada y luego ir a la siguiente instrucción en secuencia numérica, (2) mover cinta a la izquierda/mover cinta a la derecha/no hacer nada y luego ir a la siguiente instrucción en secuencia numérica (3) probar cinta y luego ir a la instrucción-xxx-de lo contrario ir a la siguiente instrucción en secuencia numérica.

Referencias