Teoría de la computación

La teoría de la computación ye un conxuntu de conocencies racionales, sistematizados y funcionales que se centren nel estudiu de l'astracción de los procesos qu'asoceden na realidá col fin de reproducilos con ayuda de sistemes formales, esto ye, al traviés de códigos de calteres y instrucciones lóxiques, reconocibles pol ser humanu, con capacidá de ser modeláu de procesos modelaes nes llimitaciones de dispositivos que procesen información y qu'efectúen cálculos como, por casu, l'ordenador. Pa ello, sofitar na teoría d'autómates, con cuenta d'asemeyar y estandarizar dichos procesos, según pa formalizar los problemes y da-yos solución.[ensin referencies]

Principales subramas editar

Teoría d'autómates editar

Esta teoría aprove modelos matemáticos que formalicen el conceutu de ordenador o algoritmu de manera abondo simplificada y xeneral por que puedan analizase les sos capacidaes y llimitaciones. Dalgunos d'estos modelos xueguen un papel central en delles aplicaciones de les ciencies de la computación, incluyendo procesamientu de testu, compiladores, diseñu de hardware y intelixencia artificial.

Esisten munchos otros tipos d'autómates como les máquines d'accesu aleatoriu, autómates celulares, máquines ábaco y les máquines d'estáu astractu; sicasí en tolos casos amosóse qu'estos modelos nun son más xenerales que la máquina de Turing, pos la máquina de Turing tien la capacidá d'asemeyar cada unu d'estos autómates. Esto da llugar a que se piense na máquina de Turing como'l modelu universal d'ordenador.

Teoría de la computabilidad editar

Esta teoría esplora les llendes de la posibilidá de solucionar problemes por aciu algoritmos. Gran parte de les ciencies computacionales tán dedicaes a resolver problemes de forma algorítmica, de manera que'l descubrimientu de problemes imposibles ye una gran sorpresa. La teoría de la computabilidad ye útil pa nun tratar de resolver algorítmicamente estos problemes, aforrando asina tiempu y esfuerciu.

Los problemes clasificar nesta teoría d'alcuerdu al so grau de imposibilidá:

  • Los computables son aquellos pa los cualos sí esiste un algoritmu que siempres los resuelve cuando hai una solución y amás ye capaz d'estremar los casos que nun la tienen. Tamién se-yos conoz como decidibles, resolubles o recursivos.
  • Los semicomputables son aquellos pa los cualos hai un algoritmu que ye capaz atopar una solución si ye qu'esiste, pero nengún algoritmu que determine cuando la solución nun esiste (y nesi casu l'algoritmu p'atopar la solución entraría a un bucle infinitu). L'exemplu clásicu por excelencia ye'l problema de la parada. A estos problemes tamién se-yos conoz como listables, recursivamente enumerables o reconocibles, porque si se enlistan tolos casos posibles del problema, ye posible reconocer a aquellos que sí tienen solución.
  • Los incomputables son aquellos pa los cualos nun hai nengún algoritmu que pueda resolver, nun importando que tengan o non solución. L'exemplu clásicu por excelencia ye'l problema de la implicación lóxica, que consiste en determinar cuándo una proposición lóxica ye un teorema; pa esti problema nun hai nengún algoritmu qu'en tolos casos pueda estremar si una proposición o la so negación ye un teorema.

Hai una versión más xeneral d'esta clasificación, onde los problemes incomputables subdivídense de la mesma en problemes más difíciles qu'otros. La ferramienta principal pa llograr estes clasificaciones ye'l conceutu de reducibilidad: Un problema   amenorgar al problema   si sol camientu de que sabe resolvese el problema   ye posible resolver al problema  ; esto se denota por  , y informalmente significa que'l problema   nun ye más malo de resolver que'l problema  . Por casu, sol camientu de qu'una persona sabe sumar, ye bien fácil enseña-y a multiplicar faciendo sumas repitíes, de manera que multiplicar amenorgar a sumar.

Teoría de la complexidá computacional editar

Entá cuando un problema sía computable, pue que nun sía posible resolvelo na práutica si ríquese muncha memoria o tiempu d'execución. La teoría de la complexidá computacional estudia les necesidaes de memoria, tiempu y otros recursos computacionales pa resolver problemes; d'esta manera ye posible esplicar por qué unos problemes son más difíciles de resolver qu'otros. Unu de los mayores llogros d'esta caña ye la clasificación de problemes, similar a la tabla periódica, d'alcuerdu a la so dificultá. Nesta clasificación los problemes dixebrar por clases de complexidá.

Esta teoría tien aplicación en casi toles árees de conocencia onde se deseye resolver un problema computacionalmente, porque los investigadores non solo deseyen utilizar un métodu pa resolver un problema, sinón utilizar el más rápidu. La teoría de la complexidá computacional tamién tien aplicaciones n'árees como la criptografía, onde s'espera que descifrar un códigu secretu sía un problema bien difícil nun siendo que se tenga la contraseña, y nesi casu el problema vuélvese fácil.

Otres subramas editar

  • Modelos de cómputu Estudia astracciones de faer un cómputu. Equí inclúyense los clásicos modelos de la teoría d'autómates amás d'otros modelos como funciones recursivas, cálculo lambda y inclusive llinguaxes de programación.
  • Teoría algorítmica de la información Centra la so atención na complexidá pa describir algorítmicamente una secuencia de datos (cadena); equí la complexidá ta midida pol llargor de la so descripción más pequeña.
  • Especificación y verificación formal Busca metodoloxíes pa garantizar qu'un problema tea correutamente modeláu y sistemes formales pa validar la correición de la solución algorítmica.
  • La Teoría del aprendizaxe computacional busca algoritmos que faigan que los ordenadores modifiquen los sos comportamientos de manera autónoma con base en datos empíricos, y concretamente n'exemplos y contraejemplos. A esti tipu d'aprendizaxe llámase-y aprendizaxe supervisáu. De forma análoga a la teoría de la complexidá computacional, nesta teoría les funciones clasificar pol so grau de dificultá de ser aprendíes.
  • Teoría de tipos Busca la clasificación d'enunciaos d'alcuerdu a los tipos de valores que calculen utilizando ferramientes de teoría de llinguaxes formales.

Historia editar

La teoría de la computación empieza puramente a principios del sieglu XX, poco primero que los ordenadores electrónicos fueren inventaes. Nesta dómina dellos matemáticos preguntaben si esistía un métodu universal pa resolver tolos problemes matemáticos. Pa ello teníen de desenvolver la noción precisa de métodu pa resolver problemes, esto ye, la definición formal de algoritmu.

Dalgunos d'estos modelos formales fueron propuestos por precursores como Alonzo Church (cálculo Lambda), Kurt Gödel (funciones recursivas) y Alan Turing (máquina de Turing). Amosóse qu'estos modelos son equivalentes nel sentíu de que pueden asemeyar los mesmos algoritmos, anque lo faigan de maneres distintes. Ente los modelos de cómputu más recién atópense los llinguaxes de programación, que tamién amosaron ser equivalentes a los modelos anteriores; esto ye una fuerte evidencia de la conxetura de Church-Turing, de que tou algoritmu habíu y por haber puede asemeyase nuna máquina de Turing, o equivalentemente, usando funciones recursivas. En 2007 Nachom Dershowitz y Yuri Gurevich publicaron una demostración d'esta conxetura basándose en cierta axiomatización d'algoritmos.[1]

Unu de les primeres resultancies d'esta teoría foi la esistencia de problemes imposibles de resolver algorítmicamente, siendo'l problema de la parada el más famosu d'ellos. Pa estos problemes nun esiste nin va esistir nengún algoritmu que pueda resolver, nun importando la cantidá de tiempu o memoria disponer nun ordenador. Coles mesmes, cola llegada de los ordenadores modernos constatóse que dellos problemes resolubles en teoría yeren imposibles na práutica, yá que diches soluciones precisaben cantidaes irrealistas de tiempu o memoria pa podese atopar.

Referencies editar

  1. Nachom Dershowitz & Yuri Gurevich (2008). «A natural axiomatization of computability and proof of Church's Thesis». Bulletin of Symbolic Logic 14 (3):  páxs. 299-350. ISSN 1079-8986. http://research.microsoft.com/en-us/um/people/gurevich/Opera/188.pdf. 

Bibliografía editar