A Máquina de Turing é um dispositivo teórico conhecido como máquina universal, que foi concebido pelo matemático britânico Alan Turing (1912-1954), muitos anos antes de existirem os modernos computadores digitais (o artigo de referência foi publicado em 1936). Num sentido preciso, é um modelo abstrato de um computador, que se restringe apenas aos aspectos lógicos do seu funcionamento (memória, estados e transições), e não a sua implementação física. Numa máquina de Turing pode-se modelar qualquer computador digital.
Turing também se envolveu na construção de máquinas físicas para quebrar os códigos secretos das comunicações alemãs durante a Segunda Guerra Mundial, tendo utilizado alguns dos conceitos teóricos desenvolvidos para o seu modelo de computador universal.
Definição
Descrição informal
Uma máquina de Turing consiste em:
Uma fita que é dividida em células, uma adjacente à outra. Cada célula contém um símbolo de algum alfabeto finito. O alfabeto contém um símbolo especial branco (aqui escrito como ¬) e um ou mais símbolos adicionais. Assume-se que a fita é arbitrariamente extensível para a esquerda e para a direita, isto é, a máquina de Turing possui tanta fita quanto é necessário para a computação. Assume-se também que células que ainda não foram escritas estão preenchidas com o símbolo branco.
Um cabeçote, que pode ler e escrever símbolos na fita e mover-se para a esquerda ou para a direita.
Um registrador de estados, que armazena o estado da máquina de Turing. O número de estados diferentes é sempre finito e há um estado especial denominado estado inicial com o qual o registrador de estado é inicializado.
Uma tabela de ação (ou função de transição) que diz à máquina que símbolo escrever, como mover o cabeçote ( para esquerda e para direita) e qual será seu novo estado, dados o símbolo que ele acabou de ler na fita e o estado em que se encontra. Se não houver entrada alguma na tabela para a combinação atual de símbolo e estado então a máquina para.
Note que cada parte da máquina é finita e sua quantidade de fita potencialmente ilimitada dá uma quantidade ilimitada de espaço de memória.
Definição formal
Máquina de Turing com uma fita
Mais formalmente, uma máquina de Turing (com uma fita) é perfeitamente definida como uma 7-upla , onde
é o alfabeto da fita (conjunto finito de símbolos)
é o estado inicial
é o símbolo branco (o único símbolo que se permite ocorrer na fita infinitamente em qualquer passo durante a computação)
é o conjunto dos estados finais
⇒ é uma função parcial chamada função de transição, onde é o movimento para a esquerda e é o movimento para a direita.
Definições na literatura às vezes diferem um pouco, para tornar argumentos ou provas mais fáceis ou mais claras, mas isto é sempre feito de maneira que a máquina resultante tem o mesmo poder computacional. Por exemplo, mudar o conjunto para , onde P permite ao cabeçote permanecer na mesma célula da fita em vez de mover-se para a esquerda ou direita, não aumenta o poder computacional da máquina, pois é possível simular o movimento P com o movimento sequenciado de e o que mantém o cabeçote no mesmo lugar.[1]
Máquina de Turing com k fitas
Uma máquina de Turing com k fitas também pode ser descrita como uma 7-upla , onde
é um conjunto finito de estados
é um alfabeto finito de símbolos
é o alfabeto da fita (conjunto finito de símbolos)
é o número de fitas
é o estado inicial
é o símbolo branco
é o conjunto dos estados finais
é uma função parcial chamada função de transição, onde é o movimento para a esquerda e é o movimento para a direita.
Observe que uma máquina de Turing com "k" fitas também não é mais poderosa que uma máquina de Turing tradicional de uma única fita, pois podemos organizar linearmente as "k" fitas e em uma única fita com um único cabeçote e registrar a posição dos "cabeçotes virtuais" por algum símbolo ou marcação nessa fita única, assim como funciona os ponteiros em uma memória linear.[1]
Detalhes adicionais requeridos para visualizar ou implementar máquinas de Turing
Nas palavras de Van Emde Boas (1990) p. 6: "O objeto do conjunto teórico [sua descrição formal sete-tupla similar ao acima] fornece apenas informação parcial sobre como a máquina agirá e com o que suas computações se parecerão."
Por exemplo,
Serão necessárias muitas decisões sobre com o que os símbolos realmente se parecem e uma forma de contraprovar símbolos de escrita e leitura indefinidamente.
As operações shift left e shift right podem deslocar a cabeça da fita sobre a fita, mas quando realmente construir uma máquina de Turing, isso é mais prático para fazer a fita deslizar para frente e para trás sob a cabeça em vez disso.
A fita pode ser finita, e automaticamente estendida com espaços em branco, conforme necessário (o qual é o mais próximo da definição matemática), mas isso é mais comum para pensar sobre isso como infinitamente alongado em ambos os lados e sendo preenchida com espaços em branco, exceto sobre o fragmento finito dado explicitamente onde a cabeça da fita está. (Isto não é, claro, implementável na prática.) A fita não pode ser fixada em comprimento, pois não corresponderia à definição dada e limitaria seriamente o alcance das computações que a máquina pode realizar àquelas do autômato linearmente limitado.
Definições alternativas
Para tornar as provas e argumentos mais fáceis ou mais claras, encontramos na literatura definições levemente diferentes, mas isso sempre é feito de tal maneira que a máquina resultante tenha o mesmo poder computacional. Por exemplo, modificando o conjunto para , onde N ("Nada" ou "Sem operação") permitiria a máquina ficar sobre a mesma célula da fita em vez de mover para a esquerda ou para direita, não aumenta o poder computacional das máquinas.
A convenção mais comum representa cada "instrução de Turing" na "tabela de Turing" por uma de nove 5-uplas, pela convenção de Turing/Davis (Turing (1936) em Undecidable, p. 126-127 e Davis (2000) p. 152):
(definição 1): (qi, Sj, Sk/E/N, L/R/N, qm)
( estado atual qi, símbolo escaneado Sj, símbolo de impressão Sk/apagar E/nada N, move_um_quadrado_da_fita esquerda L/ direita R/ nada N, novo estado qm)
Outros autores (Minsky (1967) p. 119, Hopcroft e Ullman (1979) p. 158, Stone (1972) p. 9) adotam uma convenção diferente, com um novo estado qm listado imediatamente depois do símbolo escaneado Sj:
(definição 2): (qi, Sj, qm, Sk/E/N, L/R/N)
( estado atual qi, símbolo escaneado Sj, novo estado qm, símbolo de impressão Sk/apagar E/nada N, move_um_quadrado_da_fita esquerda L/direita R/nada N)
Para o restante desse artigo a "definição 1" (a convenção de Turing/Davis) será utilizada.
Exemplo: tabela de estado para o problema do castor ocupado de 3 estados e 2 símbolos reduzido para 5-tuplas
Estado atual
Símbolo escaneado
Símbolo de impressão
Mover fita
Estado final(i.e. próximo)
5-tuplas
A
0
1
R
B
(A, 0, 1, R, B)
A
1
1
L
C
(A, 1, 1, L, C)
B
0
1
L
A
(B, 0, 1, L, A)
B
1
1
R
B
(B, 1, 1, R, B)
C
0
1
L
B
(C, 0, 1, L, B)
C
1
1
N
H
(C, 1, 1, N, H)
Na tabela seguinte, o modelo original de Turing permitiu apenas as primeiras três linhas, que ele chamou N1, N2, N3 (cf Turing em Undecidable, p. 126). Ele permitiu a rasura do "quadrado escaneado" nomeando o 0th símbolo S0 = "apagar" ou "branco", etc. Entretanto, ele não permitiu a não impressão, então toda linha de instrução inclui "símbolo de impressão Sk" ou "apagar" (cf nota de rodapé 12 em Post (1947), Undecidable p. 300). As abreviações são de Turing(Undecidable p. 119). Posteriormente ao paper original de Turing em 1936–1937, os modelos de máquina têm permitido todos os nove tipos possíveis de 5-tuplas:
Configuração atual m (Estado de Turing)
Símbolo da fita
Operação de impressão
Movimento na fita
Configuração final m (Estado de Turing)
5-tupla
Comentários da 5-tupla
4-tupla
N1
qi
Sj
Impressão(Sk)
Esquerda L
qm
(qi, Sj, Sk, L, qm)
"branco" = S0, 1=S1, etc.
N2
qi
Sj
Impressão(Sk)
Direita R
qm
(qi, Sj, Sk, R, qm)
"branco" = S0, 1=S1, etc.
N3
qi
Sj
Impressão(Sk)
Nada N
qm
(qi, Sj, Sk, N, qm)
"branco" = S0, 1=S1, etc.
(qi, Sj, Sk, qm)
4
qi
Sj
Nada N
Esquerda L
qm
(qi, Sj, N, L, qm)
(qi, Sj, L, qm)
5
qi
Sj
Nada N
Direita R
qm
(qi, Sj, N, R, qm)
(qi, Sj, R, qm)
6
qi
Sj
Nada N
Nada N
qm
(qi, Sj, N, N, qm)
"Salto" direto
(qi, Sj, N, qm)
7
qi
Sj
Apagar
Esquerda L
qm
(qi, Sj, E, L, qm)
8
qi
Sj
Apagar
Direita R
qm
(qi, Sj, E, R, qm)
9
qi
Sj
Apagar
Nada N
qm
(qi, Sj, E, N, qm)
(qi, Sj, E, qm)
Qualquer tabela de Turing (lista de instruções) pode ser construída a partir das nove 5-tuplas acima. Por razões técnicas, as três não-impressão ou instruções "N" (4, 5, 6) pode geralmente ser dispensadas. Para exemplos, veja exemplos de máquina de Turing.
Menos frequentemente, o uso de 4-tuplas são encontrados: estes representam uma outra atomização das instruções de Turing (cf Post (1947), Boolos & Jeffrey (1974, 1999), Davis-Sigal-Weyuker (1994)); também veja mais em Máquina de Post–Turing.
O "estado"
A palavra "estado" utilizada em contexto de máquinas de Turing pode ser uma fonte de confusão, como isso pode significar duas coisas. A maioria dos comentaristas depois de Turing utilizaram "estado" para denotar o nome/designador da instrução atual para ser realizada — i.e. , os conteúdos do registro de estado. Mas Turing (1936) fez uma distinção forte entre um registro do que ele chamou de m-configuração da máquina, (seu estado interno) e o "estado de progresso" da máquina (ou pessoa) através da computação - o estado atual do sistema total. O que Turing chamou "a fórmula do estado" inclui ambos a instrução atual e todos os símbolos sobre a fita:
Assim o estado de progresso da computação em qualquer estágio é completamente determinado pela nota de instruções e os símbolos sobre a fita. Isso é, o estado do sistema pode ser descrito por uma única expressão (sequência de símbolos) consistindo dos símbolos sobre a fita seguida por Δ (os quais supomos não aparecer em outro lugar) e então pelo nota de instruções. Essa expressão é chamada de 'fórmula de estado'.
— Undecidable, p.139–140, ênfase adicionada
Anteriormente em seu paper, Turing estendeu isto ainda mais: ele dá um exemplo onde ele posicionou um símbolo da configuração atual m —o rótulo da instrução— abaixo do quadrado escaneado, juntamente com todos os símbolos sobre a fita (Undecidable, p. 121); Isto ele chama "a configuração completa" (Undecidable, p. 118). Para imprimir a "configuração completa" sobre uma linha, ele posiciona o estado-rótulo/m-configuração para a esquerda do símbolo escaneado.
Uma variante disto é vista em Kleene (1952), onde Kleene mostra como escrever o número de Gödel de uma "situação" da máquina: ele posiciona o símbolo da "m-configuração" q4 sobre o quadrado escaneado em grosseiramente o centro dos 6 quadrados não-brancos sobre a fita ( veja a imagem da fita de Turing nesse artigo) e coloca isso para a direita do quadrado escaneado. Mas Kleene refere-se ao próprio "q4" como "o estado da máquina" (Kleene, p. 374-375). Hopcroft e Ullman chamam este composto a "descrição instantânea" e segue a convenção de Turing de colocar o "estado atual" (rótulo-instrução, m-configuração) para a esquerda do símbolo escaneado (p. 149).
Exemplo: estado total do problema do castor ocupado de 3 estados e 2 símbolos após 3 "movimentos" (pegando de exemplo "run" na figura abaixo):
1A1
Isso significa: após três movimentos, a fita tem ... 000110000 ... sobre esta, a cabeça está escaneando o 1 mais a direita, e o estado é A. Brancos (nesse caso, representado por "0"s) pode ser parte do estado total como mostrado aqui: B01; a fita possui um único 1 sobre esta, mas a cabeça está escaneando o 0 ("branco") para sua esquerda e o estado é B.
"Estado" no contexto de máquinas de Turing devem ser esclarecidas quanto ao que está sendo descrito: (i) a instrução atual, ou (ii) a lista de símbolos sobre a fita juntamente com a instrução atual, ou (iii) a lista de símbolos sobre a fita juntamente com a instrução atual posicionada pela esquerda do símbolo escaneado ou pela direita do símbolo escaneado.
O biógrafo de Turing, Andrew Hodges (1983: 107), tem notado e discutido esta confusão.
Exemplo
A máquina de Turing a seguir tem um alfabeto {¬, 1}, onde ¬ representa o símbolo branco. Ela espera uma série de 1's na fita, com o cabeçote inicialmente no 1 mais à esquerda, e duplica os 1's com um ¬ no meio. Por exemplo, "111" torna-se "111¬111".
O conjunto dos estados é {s1, s2, s3, s4, s5} e o estado inicial é s1.
A tabela de ação é dada a seguir.
A primeira linha desta tabela pode ser lida como: "Se a máquina estiver no estado s1 e o símbolo lido pelo cabeçote for 1, então escreva o símbolo ¬, mova uma posição para a direita e mude o estado para s2".
Uma computação nesta máquina de Turing pode ser, por exemplo: (a posição do cabeçote é indicada mostrando-se a célula em negrito)
O comportamento desta máquina pode ser descrito como um laço (loop): Ele inicia em s1, substitui o primeiro 1 com um ¬, então usa o s2 para mover para a direita, passando pelos 1's e pelo primeiro ¬ encontrado. S3 então passa pela próxima sequência de 1's (inicialmente há nenhuma) e substitui o primeiro ¬ que encontra por um 1. S4 move de volta para a esquerda, passando pelos 1's até encontrar um ¬ e vai para o estado s5. S5 então move para a esquerda, passando pelos 1's até achar o ¬ que foi originalmente escrito por s1. Ele substitui o ¬ por 1, move uma posição para a direita e entra no estado s1 novamente para outra execução do laço. Isso continua até s1 achar um ¬ (este é o ¬ que fica entre as duas cadeias de 1's), situação na qual a máquina pára.
Máquinas de Turing determinísticas e não-determinísticas
Se a tabela de ação tem no máximo uma entrada para cada combinação de símbolo e estado então a máquina é uma máquina de Turing determinística (MTD). Se a tabela de ação contém múltiplas entradas para uma combinação de símbolo e estado então a máquina é uma máquina de Turing não-determinística (MTND ou MTN).
Toda máquina de Turing computa uma certa função computávelparcial a partir da cadeia dada formada pelos símbolos do alfabeto. Neste sentido ela comporta-se como um computador com um programa fixo. No entanto, como Alan Turing descreveu, podemos codificar a tabela de ação de qualquer máquina de Turing em uma cadeia de símbolos. Portanto podemos tentar construir uma máquina de Turing que espera em sua fita uma cadeia descrevendo a tabela de ação seguida por uma cadeia descrevendo a fita de entrada, e então computa a fita que a máquina de Turing codificada teria computado.
Comparação com máquinas reais
Frequentemente diz-se que as máquinas de Turing, ao contrário de autômatos mais simples, são tão poderosas quanto máquinas reais, e são capazes de executar qualquer operação que um programa real executa. O que está faltando neste enunciado é que praticamente qualquer programa particular executando em uma máquina particular e dada uma entrada finita é, na verdade, nada além de um autômato finito determinístico, já que a máquina em que executa pode estar apenas em uma quantidade finita de configurações. Máquinas de Turing poderiam de fato ser equivalentes a uma máquina que tenha uma quantidade ilimitada de espaço de armazenamento. Podemos questionar então por que as máquinas de Turing são modelos úteis de computadores reais. Há várias maneiras de responder a isto:
A diferença está apenas na habilidade de uma máquina de Turing de manipular uma quantidade ilimitada de dados. No entanto, dada uma quantidade finita de tempo, uma máquina de Turing (como uma máquina real) pode apenas manipular uma quantidade finita de dados.
Como uma máquina de Turing, uma máquina real pode ter seu espaço de armazenamento aumentado conforme a necessidade, através da aquisição de mais discos ou outro meio de armazenamento. Se o suprimento destes for curto, a máquina de Turing pode se tornar menos útil como modelo. Mas o fato é que nem as máquinas de Turing nem as máquinas reais precisam de quantidades astronômicas de espaço de armazenamento para fazer a maior parte das computações que as pessoas normalmente querem que sejam feitas. Frequentemente o tempo de processamento requerido é o maior problema.
Máquinas reais são muito mais complexas que uma máquina de Turing. Por exemplo, uma máquina de Turing descrevendo um algoritmo pode ter algumas centenas de estados, enquanto o autômato finito determinístico equivalente em uma dada máquina real tem quadrilhões.
Máquinas de Turing descrevem algoritmos independentemente de quanta memória eles utilizam. Há um limite máximo na quantidade de memória que qualquer máquina que conhecemos tem, mas este limite pode crescer arbitrariamente no tempo. As máquinas de Turing nos permitem fazer enunciados sobre algoritmos que (teoricamente) valerão eternamente, independentemente dos avanços na arquitetura de computadores convencionais.
Máquinas de Turing simplificam o enunciado de algoritmos. Algoritmos executando em máquinas abstratas equivalentes a Turing são normalmente mais gerais que suas contrapartes executando em máquinas reais, porque elas têm tipos com precisão arbitrária disponíveis e nunca precisam tratar condições inesperadas (incluindo, mas não somente, acabar a memória).
Uma maneira em que máquinas de Turing são pobres modelos para programas é que muitos programas reais, tais como sistemas operacionais e processadores de texto, são escritos para receber entradas irrestritas através da execução, e portanto não param. Máquinas de Turing não modelam bem tal "computação contínua" (mas ainda podem modelar porções dela, tais como procedimentos individuais).
Outra limitação de máquinas de Turing é que elas não modelam a organização estrita de um problema específico. Por exemplo, computadores modernos são na verdade instâncias de uma forma mais específica de máquina de computação, conhecido como máquina de acesso aleatório. A principal diferença entre esta máquina e a máquina de Turing é que esta utiliza uma fita infinita, enquanto a máquina de acesso aleatório utiliza uma sequência indexada numericamente (tipicamente um campo inteiro). O resultado desta distinção é que há otimizações computacionais que podem ser executadas baseadas nos índices em memória, o que não é possível numa máquina de Turing geral. Assim, quando máquinas de Turing são utilizadas como base para tempo de execuções restritos, um "falso limite inferior" pode ser provado em determinados tempos de execução de algoritmos (graças à premissa falsa de simplificação da máquina de Turing). Um exemplo disto é uma "ordenação por contagem", o que aparentemente viola o limite inferior em algoritmos de ordenação.
Máquinas de Turing físicas
Não é difícil simular uma máquina de Turing num computador moderno (exceptuando pela quantidade de memória limitada existente nos computadores actuais). O site de busca Google, em comemoração aos 100 anos de Alan Turing, publicou um doodle dia 23 de junho de 2012, em forma de uma máquina de Turing.[2]
É possível construir uma máquina de Turing com base puramente mecânica. O matemático Karl Scherer construiu essa máquina em 1986, usando conjuntos de construção de metal, plástico e alguma madeira. A máquina, com 1,5 m de altura, usa puxões de fios para ler, movimentar e escrever informação, a qual é, por sua vez, representada por rolamentos. A máquina encontra-se atualmente em exibição na entrada do Departamento de Ciência de Computadores da Universidade de Heidelberg, na Alemanha.
O conceito de máquina de Turing foi usado como ferramenta educativa na obra de ficção científicaThe Diamond Age (1995), escrita por Neal Stephenson. A personagem principal, Nell, possui um livro interactivo que a ensina a pensar criativa e logicamente apresentando-lhe puzzles numa história, os quais, sendo máquinas de Turing, se tornam cada vez mais complexos à medida que a narrativa se desenvolve. Estes puzzles começam por ser simples aparelhos mecânicos e evoluem para processos econômicos abstractos, atingindo um ponto em que se assiste à interação entre completos reinos ficcionais.
História
Contexto histórico: máquinas computacionais
Robin Gandy (1919-1995), um estudante de Alan Turing (1912-1954) e seu amigo ao longo da vida, traça a linhagem da noção de "máquina de calcular" até a Babbage (em cerca de 1834) e, na verdade, propõe a "Tese de Babbage":
Que o desenvolvimento e análise de operações são agora capazes de serem executados por máquinas.
— (Itálico em Babbage como citados por Gandy, p. 54)
A análise de Gandy da Máquina Analítica de Babbage descreve as seguintes cinco operações (cf. p. 52-53):
As funções aritméticas +, -, ×, onde - indica subtração "apropriada" x - y = 0 se y ≥ x
Qualquer sequência de operações é uma operação
Iteração de uma operação (repetir n vezes uma operação P)
Iteração condicional (repetir n vezes uma operação P condicional sobre o "sucesso" do teste T)
... A ênfase está na programação de uma sequência fixa iterável de operações aritméticas. A importância fundamental da iteração condicional e transferência condicional para uma teoria geral da máquinas de calcular não é reconhecida...
— Gandy p. 55
O Entscheidungsproblem (o "problema de decisão"): O décimo problema de Hilbert de 1900
Com relação aos problemas de Hilbert propostos pelo famoso matemático David Hilbert em 1900, um aspecto do problema #10 tinha ficado flutuando por quase 30 anos antes de ser enquadrado com precisão. A expressão original de Hilbert para o 10º problema é a seguinte:
10. Determinação da solubilidade de uma equação Diofantina. Dada uma equação Diofantina com qualquer número de incógnitas e com coeficientes inteiros racionais: Elaborar um processo que com ele pode ser determinado em um número finito de operações se a equação é solúvel por números inteiros racionais. O Entscheidungsproblem [problema de decisão para a lógica de primeira ordem ] é resolvido quando sabemos que um procedimento que permite a qualquer expressão lógica dada decidir por um número finito de operações a sua validade ou satisfazibilidade ... O Entscheidungsproblem deve ser considerado o principal problema da lógica matemática.
— Citada, com esta tradução e o original em alemão, em Dershowitz e Gurevich de 2008
Em 1922, essa noção de " Entscheidungsproblem "desenvolveu-se um pouco, e H. Behmann afirmou que
... a forma mais geral do Entscheidungsproblem [é] como se segue:
Uma prescrição bem definida geralmente aplicável é necessária, ela permitirá decidir em um número finito de passos a veracidade ou falsidade de uma dada afirmação puramente lógica ...
— Gandy p. 57, citando Behmann
Behmann observa que ... o problema geral é equivalente ao problema de decidir quais proposições matemáticas são verdadeiras.
— Ibid.
Se alguém fosse capaz de resolver o Entscheidungsproblem então teria um "procedimento para a resolução de muitos (ou mesmo todos) problemas matemáticos".
— Ibid., p. 92
Até o Congresso Internacional de Matemáticos em 1928, Hilbert "fez suas perguntas bastante precisas. Primeiro, a matemática é completa ... Segundo, a matemática é consistente ... E terceiro, a matemática é decidível ? " (Hodges p. 91, Hawking p. 1121). As duas primeiras questões foram respondidas em 1930 por Kurt Gödel na mesma reunião onde Hilbert fez seu discurso de aposentadoria (para desgosto de Hilbert); o terceiro- o Entscheidungsproblem teve que esperar até meados de 1930.
O problema era que uma resposta primeiro exigia uma definição precisa de "prescrição definitiva geral aplicável", que o professor de Princeton Alonzo Church viria a chamar de " método efetivo ", que podemos chamar ainda de Algoritmo, e que em 1928 não existia tal definição. Mas ao longo dos próximos 6-7 anos Emil Post desenvolveu sua definição de um trabalhador passando de um cômodo para um outro cômodo escrevendo e apagando marcas em uma lista de instruções (Post 1936), assim como Church e os seus dois alunos Stephen Kleene e J. B. Rosser pelo uso do lambda-cálculo de Church e a teoria da recursão de Gödel (1934). O artigo de Church (publicado 15 de abril de 1936) mostrou que o Entscheidungsproblem era de fato "indecidível" e superou Turing por quase um ano (o artigo de Turing foi submetido em 28 de maio de 1936 e publicado em janeiro de 1937). Nesse meio tempo, Emil Post apresentou um breve artigo no outono de 1936, Turing, pelo menos, tinha prioridade sobre Post. Enquanto Church arbitrou o artigo de Turing, Turing teve tempo para estudar o artigo de Church e adicionar um Apêndice onde ele provava que o lambda-cálculo de Church e suas máquinas calculariam as mesmas funções.
Mas o que Church fez foi algo bastante diferente, e em certos sentidos mais fraco. ... A construção Turing foi mais direta, e dava um argumento a partir dos primeiros princípios, fechando a lacuna da demonstração de Church.
— Hodges-p. 112
E Post só havia proposto uma definição de calculabilidade e criticou a "definição" de Church, mas não tinha provado nada.
Alan Turing uma-máquina(-automática)
Na primavera de 1935, Turing como aluno de mestrado em Kings College Cambridge, Reino Unido, aceitou o desafio; ele tinha sido estimulado pelas palestras do lógico M. H. A. Newman "e aprendeu com elas do trabalho de Gödel e o Entscheidungsproblem ... Newman usou a palavra "mecânico" ... Em seu obituário de Turing em 1955 Newman escreveu:
Para a pergunta "o que é um processo "mecânico" ?" Turing retornou a resposta característica "Algo que pode ser feito por uma máquina" e ele embarcou na tarefa altamente congênita de analisar a noção geral de uma máquina de computação.
— Gandy, p. 74
Gandy afirma que:
Eu acho, mas não sei, que Turing, desde o início de seu trabalho, tinha como objetivo uma prova da indecidibilidade do Entscheidungsproblem. Ele me disse que a "ideia principal" do artigo veio a ele quando ele estava deitado nos prados de Grantchester no verão de 1935. A "ideia principal" poderia ter sido sua análise da computação ou a realização de que havia uma máquina universal, e assim um argumento de diagonalização para provar insolubilidade.
— Ibid, p. 76
Enquanto Gandy acredita que a declaração de Newman acima era "enganosa", esta opinião não era compartilhada por todos. Turing tinha um interesse ao longo da vida por máquinas: "Alan tinha sonhado de inventar máquinas de escrever quando menino; [sua mãe] Sra. Turing teve uma máquina de escrever, e ele poderia muito bem ter começado perguntando a si mesmo o que significava chamar uma máquina de escrever 'mecânica'" (Hodges, p. 96). Enquanto em Princeton em busca de seu PhD, Turing construiu um multiplicador com lógica booleana (veja abaixo). Sua tese de doutorado, intitulada "Sistemas de Lógica Baseado em ordinais", contém a seguinte definição de "uma função computável":
Foi dito acima que 'uma função é efetivamente calculável se os seus valores podem ser encontrados por algum processo puramente mecânico. Podemos assumir esta afirmação literalmente, a compreensão por um processo puramente mecânico, que pode ser realizada por uma máquina. É possível dar uma descrição matemática, numa certa forma normal, da estruturas destas máquinas. O desenvolvimento dessas ideias leva a definição do autor de uma função computável, e uma identificação de computabilidade com calculabilidade efetiva. Não é difícil, embora um tanto laboriosa, para provar que estas três definições [a terceira é a λ-cálculo] são equivalentes.
— Turing (1939) em The Undecidable, p. 160
Quando Turing retornou ao Reino Unido, ele acabou se tornando juntamente responsável por quebrar os códigos secretos alemães criados por máquinas de criptografia chamadas de "O Enigma", ele também se envolveu no projeto da ACE ( Automatic Computing Engine ), "a proposta ACE [de Turing] foi efetivamente independente, e as suas raízes não estava no EDVAC [iniciativa dos EUA], mas em sua própria máquina universal "(Hodges p. 318). Argumentos continuam sobre a origem e a natureza do que tem sido chamado por Kleene (1952) Tese de Turing. Mas o que Turing provou com seu modelo de máquina-computacional aparece em seu artigo On Computable Numbers, With an Application to the Entscheidungsproblem (1937):
[Que] o Hilbert Entscheidungsproblem pode não ter solução ... Proponho, portanto, para mostrar que não pode haver processo geral para determinar se uma dada fórmula U do cálculo funcional K é demonstrável, ou seja, não pode haver nenhuma máquina que, fornecido com qualquer um U dessas fórmulas, acabará por dizer se U é demonstrável.
— A partir do artigo de Turing como reimpresso The Undecidable, p. 145
De Turing exemplo (a sua segunda prova): Se alguém perguntar por um procedimento geral para nos dizer: "Será que esta máquina imprime 0", a pergunta é "indecidível".
1937-1970: O "computador digital", o nascimento da "ciência da computação"
Em 1937, enquanto em Princeton trabalhando em sua tese de doutorado, Turing construiu um multiplicador (lógico-booleano) digital do nada, fazendo seus próprios relés eletromecânicos (Hodges p. 138). "A tarefa de Alan foi para encarnar o projeto lógico de uma máquina de Turing em uma rede de relé-operacinados interruptores ..." (Hodges p. 138). Embora Turing pudesse estar inicialmente curioso e experimentando, trabalhos muito sérios, no mesmo sentido, estavam sendo desenvolvidos na Alemanha ( Konrad Zuse (1938)), e nos Estados Unidos ( Howard Aiken ) e George Stibitz (1937); os frutos do seus trabalhos foram usados pelos militares do Eixo e dos Aliados na Segunda Guerra Mundial (cf Hodges p. 298-299).No início e meados da década de 1950, Hao Wang e Marvin Minsky reduziram a máquina de Turing a uma forma mais simples (um precursor da máquina de Post-Turing de Martin Davis); simultaneamente pesquisadores europeus estavam reduzindo o novíssimo computador eletrônico a um computador como objeto teórico equivalente ao que estava sendo chamado de "máquina de Turing". No final dos anos 1950 e início dos anos 1960, os desenvolvimentos, coincidentemente paralelamente, Melzak e Lambek (1961), Minsky (1961), e Shepherdson e Sturgis (1961) continuaram o trabalho europeu e reduziram a máquina de Turing para uma máquina mais amigável, como um computador de modelo abstrato chamado de counter machine ; Elgot e Robinson (1964), Hartmanis (1971), Cook e Reckhow (1973) levaram este trabalho ainda mais com a máquina de registo e de acesso aleatório máquina modelos, mas basicamente todos são apenas máquinas multi-fita de Turing com um conjunto de instruções aritméticas.
1970-presente: a máquina de Turing como um modelo de computação
Hoje, o contador, registrador e máquinas de acesso aleatório e seu pai a máquina de Turing continuam a ser os modelos de escolha para os teóricos que investigam questões da teoria da computação. Em particular, a teoria da complexidade computacional faz uso da máquina de Turing;
Dependendo dos objetos um gosta de manipular os cálculos (números como inteiros não negativos ou cordas alfanuméricos), dois modelos têm obtido uma posição dominante na teoria da complexidade baseada em máquina:
a máquina off-line multi-fita de Turing ..., que representa o modelo padrão para a computação orientada a cadeia, e
a máquina de acesso aleatório (RAM), como introduzida por Cook e Reckhow ..., que modela o estilo de computador idealizado por Von Neumann.
— van Emde Boas 1990:4
Somente na área relacionada com a análise de algoritmos esse papel é assumido pelo modelo de RAM.
Formiga de Langton, uma representação simples da máquina de Turing em duas dimensões
Tese de Church-Turing, que diz que máquinas de Turing podem executar qualquer computação que pode ser executada
brainfuck, é uma linguagem Turing completa, desenhada para desafiar e confundir os programadores
Vermes de Paterson - família de autômatos celulares criados para modelar o comportamento e os padrões de alimentação de determinados vermes pré-históricos
Referências
↑ abSIPSER, MICHAEL (1997). Introdução a Teoria da Computação. EUA: PWS Puclishing Company
↑Google. «Doodles». www.google.com. Consultado em 23 de junho de 2012