La pregunta para la que no mepuedo decidir
To iterate is human, to recurse divine.—L. Peter Deutsch
Ivan Meza
La tesis de Turing-Church(relajada)Toda computación real puede ser transformada a unamáquina de Turing
La tesis de Turing-ChurchToda computación efectiva puede llevarse a cabo por unamáquina de Turing
Método efectivo, M está compuesto por un número finito de instrucciones cuando llevado a cabo sin error siempre produce el resultado
deseado en un número finito de pasos puede llevarse a cabo por un humano sin la necesidad de una
computadora, pero con lápiz y papel no necesita de conocimiento externo o ingenuidad de parte del
humano que lo ejecuta
MM
M
M
EvidenciaToda función efectivamente calculable se ha comprobado ser unamáquina de TuringTodos los métodos para obtener nuevas funciones efectivamentecalculables tienen un equivalente en máquina de TuringTodos los intentos de formalizar la noción intuitiva de efectivamentecalculable han resultado en el mismo conjunto, recursivoenumerable
Otras formalizacionesCálculo lambdaGramática tipo 0Funciones parciales recursivasAlgoritmos PostForma canónica PostAlgoritmos de Markov
VariacionesTodas las funciones físicas computables son Turing-computableUna máquina probabilistica de Turing puede simular eficientementecualquier modelo razonable de computaciónMáquinas razonables pueden simularse las unas a las otras con unexceso polinomial en tiempo y un factor constante en espacioUna máquina de Turing cuántica puede simular eficientementecualquier modelo realista de computación
Problemas computables, REProblemas no computables, NRE, Ld
Lenguaje Gramática Máquina Ejemplo
No RE -- --
Tipo 0 ( )
Máquina de Turing,APDo, AC
/ ,
Tipo 1 ( )
Autómata lineal confronteras
Tipo 2 ( )
Autómata de pila
Tipo 3 ( )
Autómata finito
Ld
/LRE LRec
α → βLu Ln Lf̄
LDC
αV β → αγβww, anbncn
LLC
V → αw ,wr anbn
Lreg
V → aA|ϵw, a∗
Lenguajes decidibles
MT Verdadero
FalsoW
Suma¿Dado dos número en notación unaria, veri�car que sepuedan sumar?
Los sumamos
Muy fácil, O(n + m)
Verificación de suma¿Dado tres números en notación unaria, veri�car que elúltimo sea la suma de los dos primeros?
Los sumamos y comprobamos que sean el mismo valor
Muy fácil, O(n + m)
Multiplicación¿Dado dos número en notación unaria, veri�car que sepuedan multiplicar?
Los multiplicamos
Más o menos fácil, (naive)O(n ∗ m)
Verificación de multiplicación¿Dado tres número en notación unaria, veri�car que el últimosea producto de los dos primeros?
Los multiplicamos y comprobamos que sean el mismo valor
Más o menos fácil, (naive)O(n ∗ m)
Verificar número primos¿Dado un número en notación unaria, es primo?
Dividir número entre factores de hasta 2 n√
¡Más o meno algo de tiempo! O( )n√
Identificar factores¿Dado un número en notación unaria, identi�car si esdivisible entre dos factores primos?
Encontrar un par de primos menores a que produzcan elnúmero n
n
¡Más di�cil! O( )n∗ n)(√
log(n)2
Verificación factor¿Dado tres número en notación unaria, veri�car que el últimosea el producto de los dos primeros?
Los multiplicamos y comprobamos que sean el mismo valor
Más o menos fácil, (naive)O(n ∗ m)
Sacar un elemento de un arreglo Sacar un elemento de un ábol B Verificar que mi usuario esté en la base de datos
O(n)O(log(n))
O(n)
Nuestro talón de aquiles comienza con que el complementode decidibles son decidibles
Lenguajes no decidibles
Problema del paroExiste una máquina de Turing que pueda tomar cualquiermáquina y una entrada y pueda determinar si elprograma para.
Mh
M w
La respuesta es NO
T F F T F
F F F F F
T T T T T
F T F F F
T F T F F
M i0 i1 i2 i3 i4 …j0 …j1 …j2 …j3 …j4 …… … … … … … …
Cualquiera recursiva/decidibleM(i, j)
La función computable (nodecidible)
(i) = {Mg0loop
si M(i, i) = 0otherwise
Sabemos que es computable
Definición de halt
(M, w) = {Mh10
si M para con entrada wotherwise
Dos opciones¿Qué de�ne a ?M Mh
Si entonces , entonces M( , ) = 0Mg Mg ( ) = 0Mg Mg
( , ) = 1Mh Mg Mg
Si entonces loops, entonces M( , ) = 1Mg Mg ( )Mg Mg
( , ) = 0Mh Mg Mg
No hay una que que corresponda con para elprograma
M Mh
Mg
Uno de los primeros problemas descubiertos ser nodecidibles
Es común transformar problemas al problema de paro parademostrar que también son no decidibles
Teorema de RiceToda propiedad no trivial de los lenguajes RE es indecidible
Todo conjunto de lenguajes de RE es una propiedad y RE son propiedades triviales∅
El conjunto de que regresan verdadero para toda El conjunto de que no aceptan al lenguaje vacioEl conjunto de que corresponde a un lenguajes libres decontexto
M wMM
La app va a vigilarmeLa app va alentar mi celularLa app va a pasmarse
No recursivamente enumerables
Nuestro talón de aquiles continua con que hay problemaspara los cuales no hay una MT
y son Rec y no en RE
y no en RE
L L¯ ¯¯̄
L L¯ ¯¯̄
L ∈ RE ⋂ R¯ ¯¯̄
L¯ ¯¯̄
Los complementos de REh = {[M, w]|w ∈ L(M) y para}
= {[M, w]|w ∈ L(M)no para si M es una máquina de Turing oh¯¯̄
M no es una Máquina de Turing
El conjunto de que regresan falso para toda o no es unaMTEl conjunto de que aceptan al lenguaje vacio o no es una MTEl conjunto de que corresponde a los lenguajes no son libres decontexto o no es una MT
M w M
M MM
M
La app no va a vigilarmeLa app no va alentar mi celularLa app no va a pasmarse
Lenguaje Gramática Máquina Ejemplo
No RE -- --
Tipo 0 ( )
Máquina de Turing,APDo, AC
/ ,
Tipo 1 ( )
Autómata lineal confronteras
Tipo 2 ( )
Autómata de pila
Tipo 3 ( )
Autómata finito
, ,Ld Lh Lh̄
/LRE LRec
α → βLu Ln Lf̄
LDC
αV β → αγβww, anbncn
LLC
V → αw ,wr anbn
Lreg
V → aA|ϵw, a∗
[email protected] ivanvladimir.github.io ivanvladimir
La pregunta para la que no me puedo decidir by islicensed under a
. Creado a partir de la obra en
.
Ivan V. Meza RuizCreative Commons Reconocimiento 4.0Internacional License
http://turing.iimas.unam.mx/~ivanvladimir/slides/lfya/problems.html
Top Related