25/6/09

Diagramas de Flujo.

Introducción:
Los diagramas de flujo son una manera de representar visualmente el flujo de datos través de sistemas de tratamiento de información. Los diagramas de flujo describen que operaciones y en que secuencia se requieren para solucionar un problema dado.

Un diagrama de flujo u organigrama es una representación diagramática que ilustra la secuencia de las operaciones que se realizarán para conseguir la solución de un problema. Los diagramas de flujo se dibujan generalmente antes de comenzar a programar el código frente a la computadora. Los diagramas de flujo facilitan la comunicación entre los programadores y la gente del negocio. Estos diagramas de flujo desempeñan un papel vital en la programación de un problema y facilitan la comprensión de problemas compilados y sobre todo muy largos. Una vez que se dibuja el diagrama de flujo, llega a ser fácil escribir el problema en cualquier idioma de alto nivel. Vemos a menudo cómo los diagramas de fuljo nos dan ventaja al momento de explicar el programa a otros. Por lo tanto, está correcto decir que un diagrama de flujo es una necesidad para la documentación mejor de un programa complejo.

Reglas para dibujar u diagrama de flujo.

Los diagramas de flujo se dibujan generalmente usando algunos símbolos estándares; sin embargo, algunos símbolos especiales pueden ser desarrollados cuando sean requeridos. Algunos símbolos estándares, que se requieren con frecuencia para diagramar programas de computadora se muestran a continuación:



Observación: Para obtener la correcta elaboración de los símbolos, existen plantillas.
Las puedes conseguir en Papelerías.

Símbolos gráficos:Dentro de los símbolos fundamentales para la creación de diagramas de flujo, los símbolos gráficos son utilizados específicamente para operaciones aritméticas y relaciones condicionales. La siguiente es una lista de los símbolos mas comúnmente utilizados:



Reglas para la creación de Diagramas
1.Los Diagramas de flujo deben escribirse de arriba hacia abajo, y/o de izquierda a derecha.
2. Los símbolos se unen con líneas, las cuales tienen en la punta una flecha que indica la dirección que fluye la información procesos, se debe de utilizar líneas de flujo horizontal o verticales nunca diagonales.
3. Se debe de evitar el cruce de líneas, para lo cual se quisiera separar el flujo del diagrama desde un sitio distinto, se pudiera realizar utilizando los conectores se debe tener en cuenta que solo se van de utilizar conectores solo cuando sea estrictamente necesario.
4. No deben de quedar líneas de flujo sin conectar.
5. Todo escrito dentro de un símbolo debe de ser legible, preciso, evitando el uso de muchas palabras., a excepción del símbolo final.
6. Todos los símbolos pueden tener mas de una línea de entrada.
7. Solo los símbolos de decisión pueden y deben tener más de una línea de flujo de salida.



EJEMPLOS DE DIAGRAMAS DE FLUJO:
Diagrama de flujo que encuentra la suma de los primeros 50 números naturales.



Bueno, y ahora la descripción del Diagrama anterior:

Suma: es la variable a la que se le va agregando el valor de cada número natural. N, es el contador. Éste recorrerá los números hasta llegar a 50.


El primer bloque indica el inicio del Diagrama de Flujo.

El segundo, es un Símbolo de Procesos En éste bloque se asume que las variables suma y N han sido declaradas previamente las inicializa en 0 para comenzar el conteo y la suma de los valores (para la declaración existe el bloque Tarjeta Perforada).

El tercer, bloque es también un Símbolo de Procesos En este paso se incrementa en 1 la variable N (N = N + 1). Por que, en la primera pasada N valdrá 1, ya que estaba inicializada en 0.


El cuarto bloque es exactamente l mismo que el anteriorPero en éste, ya se le agrega el valor N a la variable que contendrá la suma (En el primer caso contendrá 1, ya que N=1).

El quinto bloque es un Símbolo de Toma de Decisiones y Ramificación. Lo que hay dentro del bloque es una pregunta que se le hace a los valores que actualmente influyen en el proceso ( Por decir algo, no se como decirlo, soy muy sope: D)

¿Es N = 50?, Obviamente la repuesta es No, ya que N todavía es 1 por lo que el flujo de nuestro programa se dirigirá hacía la parte en donde se observa la palabra NO: Tercer Bloque, éste le sumará 1 (N =N + 1) y vuelve a llegar a éste bloque, donde se preguntará ¿Es N = 50?... ¡No!, todavía es 2. Ha pues, regresa al Tercer Bloque y vuelve a hacer lo mismo. Y así asta llegar a 50, obteniendo así la suma de los primeros 50 primeros números naturales.


or último indicamos que el resultado será mostrado en la impresora (Este lo puedes cambiar por Display para mostrar datos).

Fin del programa (o diagrama).

22/6/09

Código ASCAII


Algoritmo

Es una lista bien definida, ordenada y finita de operaciones que permite hallar la solución a un problema. Dado un estado inicial y una entrada, atravez de pasos sucesivos y bien definidos se llega a un estado final, obteniendo una solución.

Objetivo:
"Transformar las entradas y salidas deseadas."

Caracteristicas:
  • Preciso: indica claramente el orden de ejecución de las acciones.
  • Definido: lo puedo ejecutar varias veces y obtener el mismo resultado.
  • Finito: tiene un fin.

Se divide en 3 partes:

  • Entrada: datos para ejecutar.
  • Proceso: se procesan los datos para obtener el resultado.
  • Salida: resultado.

Pasos para diseñar un algoritmo:

  1. Conocer el problema.
  2. Determinar los datos de entrada.
  3. Determinar la información necesaria que el algoritmo produsca.
  4. Determinar cuales procesos debe realizar conlos datos de entrada para los datos de salida correspodientes.

Medios de Comunicación de un Algoritmo:

  • Lenguaje Natural: el que utilizan los seres humanos como medio de comunicación.
  • Pseudocódigo: es la descripción de un algoritmo que se asemeja aun lenguaje de programación; pero con algunas convenciones de lenguaje natural. No esta regido por ningun estandar.
  • Diagrama de Flujos: son descripciones gráficas de algoritmos; usan símbolos conectados con flechas para indicar la frecuencia de instrucciones y estan regidos por la ISO (Organización Internacional de la Normalización.)
  • Lenguajes de Programación: nos permite crear lenguajes y sotfware.


Ejemplo de Código en PHP.

Class Caja
var $alto; var = variable
var $ancho;
var $largo; Atributos
var $contenido;
var $color;

Método -> fuction introdu ($cosa) {
$this -> contenido = $cosa;
}
Fuction muestra_contenido () {
echo $this -> contenido
}
}
Utilizar la Clave: objeto $ mi caja = new caja;

Lenguajes de Programación (Orientados a Objetos)

La Programación Orientada a Objetos (POO u OOP según sus siglas en inglés) es un paradigma de programación que usa objetos y sus interacciones para diseñar aplicaciones y programas de computadora. Está basado en varias técnicas. Su uso se popularizó a principios de la década de 1990. Actualmente son muchos los lenguajes de programación que soportan la orientación a objetos.

Los objetos son entidades que combinan estado, comportamiento e identidad:

  • El estado está compuesto de datos, será uno o varios atributos a los que se habrán asignado unos valores concretos (datos).
  • El comportamiento está definido por los procedimientos o métodos con que puede operar dicho objeto, es decir, qué operaciones se pueden realizar con él.
  • La identidad es una propiedad de un objeto que lo diferencia del resto, dicho con otras palabras, es su identificador (concepto análogo al de identificador de una variable o una constante).

Origen:
Los conceptos de la programación orientada a objetos tienen origen en Simula 67, un lenguaje diseñado para hacer simulaciones, creado por Ole-Johan Dahl y Kristen Nygaard del Centro de Cómputo Noruego en Oslo.
Más tarde en Smalltalk, que fue desarrollado en Simula en Xerox PARC (y cuya primera versión fue escrita sobre Basic) pero diseñado para ser un sistema completamente dinámico en el cual los objetos se podrían crear y modificar "en marcha" en lugar de tener un sistema basado en programas estáticos.
La programación orientada a objetos tomó posición como el estilo de programación dominante a mediados de los años ochenta, en gran parte debido a la influencia de C++, una extensión del lenguaje de programación C. Su dominación fue consolidada gracias al auge de las Interfaces gráficas de usuario, para las cuales la programación orientada a objetos está particularmente bien adaptada.
Las características de orientación a objetos fueron agregadas a muchos lenguajes existentes durante los 80, incluyendo Ada, BASIC, Lisp, Pascal, entre otros.
El Eiffel de Bertrand Meyer fue acertado lenguaje con orientación a objetos (el primer lenguaje que es completamente orientado a objetos) pero ahora ha sido esencialmente reemplazado por Java, en gran parte debido a la aparición de Internet, y a la implementación de la máquina virtual de Java en la mayoría de navegadores.

Conceptos fundamentales

  • Clase: definiciones de las propiedades y comportamiento de un tipo de objeto concreto. La instanciación es la lectura de estas definiciones y la creación de un objeto a partir de ellas.
  • Herencia: (por ejemplo, herencia de la clase D a la clase C) Es la facilidad mediante la cual la clase D hereda en ella cada uno de los atributos y operaciones de C, como si esos atributos y operaciones hubiesen sido definidos por la misma D. Por lo tanto, puede usar los mismos métodos y variables publicas declaradas en C.
  • Objeto: entidad provista de un conjunto de propiedades o atributos (datos) y de comportamiento o funcionalidad (métodos). Se corresponde con los objetos reales del mundo que nos rodea, o a objetos internos del sistema (del programa). Es una instancia a una clase.
  • Método: Algoritmo asociado a un objeto (o a una clase de objetos), cuya ejecución se desencadena tras la recepción de un "mensaje". Desde el punto de vista del comportamiento, es lo que el objeto puede hacer.
  • Evento: un suceso en el sistema (tal como una interacción del usuario con la máquina). El sistema maneja el evento enviando el mensaje adecuado al objeto pertinente. También se puede definir como evento, a la reacción que puede desencadenar un objeto, es decir la acción que genera.
  • Mensaje: una comunicación dirigida a un objeto, que le ordena que ejecute uno de sus métodos con ciertos parámetros asociados al evento que lo generó.
  • Propiedad o atributo: contenedor de un tipo de datos asociados a un objeto (o a una clase de objetos), que hace los datos visibles desde fuera del objeto y esto se define como sus características predeterminadas, y cuyo valor puede ser alterado por la ejecución de algún método.
  • Estado interno: es una variable que se declara privada, que puede ser únicamente accedida y alterada por un método del objeto, y que se utiliza para indicar distintas situaciones posibles para el objeto (o clase de objetos). No es visible al programador que maneja una instancia de la clase.
  • Componentes de un objeto: atributos, identidad, relaciones y métodos.
  • Representación de un objeto: un objeto se representa por medio de una tabla o entidad que esté compuesta por sus atributos y funciones correspondientes.

Características de la POO

  • Abstracción: Denota las características esenciales de un objeto, donde se capturan sus comportamientos. Cada objeto en el sistema sirve como modelo de un "agente" abstracto que puede realizar trabajo, informar y cambiar su estado, y "comunicarse" con otros objetos en el sistema sin revelar cómo se implementan estas características. Los procesos, las funciones o los métodos pueden también ser abstraídos y cuando lo están, una variedad de técnicas son requeridas para ampliar una abstracción.
  • Encapsulamiento: Significa reunir a todos los elementos que pueden considerarse pertenecientes a una misma entidad, al mismo nivel de abstracción. Esto permite aumentar la cohesión de los componentes del sistema. Algunos autores confunden este concepto con el principio de ocultación, principalmente porque se suelen emplear conjuntamente.
  • Principio de ocultación: Cada objeto está aislado del exterior, es un módulo natural, y cada tipo de objeto expone una interfaz a otros objetos que específica cómo pueden interactuar con los objetos de la clase. El aislamiento protege a las propiedades de un objeto contra su modificación por quien no tenga derecho a acceder a ellas, solamente los propios métodos internos del objeto pueden acceder a su estado. Esto asegura que otros objetos no pueden cambiar el estado interno de un objeto de maneras inesperadas, eliminando efectos secundarios e interacciones inesperadas.
  • Polimorfismo: comportamientos diferentes, asociados a objetos distintos, pueden compartir el mismo nombre, al llamarlos por ese nombre se utilizará el comportamiento correspondiente al objeto que se esté usando. O dicho de otro modo, las referencias y las colecciones de objetos pueden contener objetos de diferentes tipos, y la invocación de un comportamiento en una referencia producirá el comportamiento correcto para el tipo real del objeto referenciado. Cuando esto ocurre en "tiempo de ejecución", esta última característica se llama asignación tardía o asignación dinámica.
  • Herencia: las clases no están aisladas, sino que se relacionan entre sí, formando una jerarquía de clasificación. Los objetos heredan las propiedades y el comportamiento de todas las clases a las que pertenecen. La herencia organiza y facilita el polimorfismo y el encapsulamiento permitiendo a los objetos ser definidos y creados como tipos especializados de objetos preexistentes. Estos pueden compartir (y extender) su comportamiento sin tener que volver a implementarlo. Esto suele hacerse habitualmente agrupando los objetos en clases y estas en árboles o enrejados que reflejan un comportamiento común. Cuando un objeto hereda de más de una clase se dice que hay herencia múltiple.
  • Recolección de basura: la Recolección de basura o Garbage Collection es la técnica por la cual el ambiente de Objetos se encarga de destruir automáticamente, y por tanto desasignar de la memoria, los Objetos que hayan quedado sin ninguna referencia a ellos. Esto significa que el programador no debe preocuparse por la asignación o liberación de memoria, ya que el entorno la asignará al crear un nuevo Objeto y la liberará cuando nadie lo esté usando.

Resumen
Es un paradigma que utiliza objetos como elementos fundamentales en la construcción de la solución. Surge en los años 70. Un objeto es una abstracción de algún hecho o cosa del mundo real que tiene atributos que representan sus características o propiedades y métodos que representan su comportamiento o acciones que realizan. Todas las propiedades y métodos comunes a los objetos se encapsulan o se agrupan en clases. ¨Una clase es una plantilla o un prototipo para crear objetos, por eso se dice que los objetos son instancias de clases.

Lenguajes orientados a objetos

  • ActionScript
  • ActionScript 3
  • C++
  • C#
  • Object Pascal (Delphi)
  • Java
  • JavaScript
  • PHP (en su versión 5)
  • VB.NET

19/6/09

Lenguajes de Programación (Orientados a la Web)

Actualmente existen diferentes lenguajes de programación para desarrollar en la web, estos han ido surgiendo debido a las tendencias y necesidades de las plataformas. En el presente artículo pretende mostrar las ventajas y desventajas de los lenguajes más conocidos. Desde los inicios de Internet, fueron surgiendo diferentes demandas por los usuarios y se dieron soluciones mediante lenguajes estáticos. A medida que paso el tiempo, las tecnologías fueron desarrollándose y surgieron nuevos problemas a dar solución. Esto dio lugar a desarrollar lenguajes de programación para la web dinámicos, que permitieran interactuar con los usuarios y utilizaran sistemas de Bases de Datos. A continuación daremos una introducción a los diferentes lenguajes de programación para la web.


haXe: es un lenguaje de alto nivel que permite conocer un único lenguaje para desarrollar páginas web. Es una capa más de abstracción, estamos por tanto hablando de un meta-lenguaje que posibilita: Crear archivos Flash SWF, Generar archivos Javascript y por tanto aplicaciones AJAX, Generar Bytecode que se puede ejecutar en un servidor Apache mediante plugin o empaquetarlo como un ejecutable. La clave de haXe está en que aporta un lenguaje común basado en ECMAScript muy conocido y extendido, una librería básica, así como una API para cada una de las plataformas mencionadas; si bien es cierto que para usarlas hay que conocerlas ahora sólo es necesario saber un lenguaje. Además, también permite de manera sencilla interoperar entre estas plataformas usando las librerías de protocolo común que incorpora.






Lenguajes web de cliente:





Javascript : es un lenguaje de programación utilizado para crear pequeños programitas encargados de realizar acciones dentro del ámbito de una página web. Se trata de un lenguaje de programación del lado del cliente, porque es el navegador el que soporta la carga de procesamiento. Gracias a su compatibilidad con la mayoría de los navegadores modernos, es el lenguaje de programación del lado del cliente más utilizado.


DHTML : no es precisamente un lenguaje de programación. Más bien se trata de una nueva capacidad de la que disponen los navegadores modernos, por la cual se puede tener un mayor control sobre la página que antes. DHTML nos da más control sobre la página, gracias a que los navegadores modernos incluyen una nueva estructura para visualizar en páginas web denominada capa. Las capas se pueden ocultar, mostrar, desplazar, etc.



CSS : CSS, es una tecnología que nos permite crear páginas web de una manera más exacta. Gracias a las CSS somos mucho más dueños de los resultados finales de la página, pudiendo hacer muchas cosas que no se podía hacer utilizando solamente HTML, como incluir márgenes, tipos de letra, fondos, colores... CSS son las siglas de Cascading Style Sheets, en español Hojas de estilo en Cascada. En este reportaje vamos a ver algunos de los efectos que se pueden crear con las CSS sin necesidad de conocer la tecnología entera.




Lenguajes web de servidor:




CGI: Common Gateway Interface : Es el sistema más antiguo que existe para la programación de las páginas dinámicas de servidor. Actualmente se encuentra un poco desfasado por diversas razones entre las que destaca la dificultad con la que se desarrollan los programas y la pesada carga que supone para el servidor que los ejecuta. Los CGI se escriben habitualmente en el lenguaje Perl, sin embargo, otros lenguajes como C, C++ o Visual Basic pueden ser también empleados para construirlos. El funcionamiento básico de un programa CGI es parecido al apuntado para el conjunto de las páginas dinámicas del servidor, con algunas particularidades.



ASP: Active Server Pages : ASP (Active Server Pages) es la tecnología desarrollada por Microsoft para la creación de páginas dinámicas del servidor. ASP se escribe en la misma página web, utilizando el lenguaje Visual Basic Script o Jscript (Javascript de Microsoft). Un lenguaje del lado del servidor es aquel que se ejecuta en el servidor web, justo antes de que se envíe la página a través de Internet al cliente. Las páginas que se ejecutan en el servidor pueden realizar accesos a bases de datos, conexiones en red, y otras tareas para crear la página final que verá el cliente. El cliente solamente recibe una página con el código HTML resultante de la ejecución de la página ASP. Como la página resultante contiene únicamente código HTML, es compatible con todos los navegadores.



PHP: Hypertext Preprocesor es el acrónimo de Hipertext Preprocesor. Es un lenguaje de programación del lado del servidor gratuito e independiente de plataforma, rápido, con una gran librería de funciones y mucha documentación. Un lenguaje del lado del servidor es aquel que se ejecuta en el servidor web, justo antes de que se envíe la página a través de Internet al cliente. Las páginas que se ejecutan en el servidor pueden realizar accesos a bases de datos, conexiones en red, y otras tareas para crear la página final que verá el cliente. El cliente solamente recibe una página con el código HTML resultante de la ejecución de la PHP. Como la página resultante contiene únicamente código HTML, es compatible con todos los navegadores.


JSP: Java Server Pages es un acrónimo de Java Server Pages, que en castellano vendría a decir algo como Páginas de Servidor Java. Es, pues, una tecnología orientada a crear páginas web con programación en Java. Con JSP podemos crear aplicaciones web que se ejecuten en variados servidores web, de múltiples plataformas, ya que Java es en esencia un lenguaje multiplataforma. Las páginas JSP están compuestas de código HTML/XML mezclado con etiquetas especiales para programar scripts de servidor en sintaxis Java. Por tanto, las JSP podremos escribirlas con nuestro editor HTML/XML habitual.



HTML: Desde el surgimiento de internet se han publicado sitios web gracias al lenguaje HTML. Es un lenguaje estático para el desarrollo de sitios web (acrónimo en inglés de HyperText Markup Language, en español Lenguaje de Marcas Hipertextuales). Desarrollado por el World Wide Web Consortium (W3C). Los archivos pueden tener las extensiones (htm, html).

Sintaxis:
< html > (Inicio del documento HTML)
< head >
(Cabecera)


(Cuerpo)


Negrita

Definir párrafo
Apertura de la etiqueta
Cierre de la etiqueta


Ventajas:




  • Sencillo que permite describir hipertexto.

  • Texto presentado de forma estructurada y agradable.

  • No necesita de grandes conocimientos cuando se cuenta con un editor de páginas web o WYSIWYG.

  • Archivos pequeños.

  • Despliegue rápido.

  • Lenguaje de fácil aprendizaje.

  • Lo admiten todos los exploradores.


Desventajas:




  • Lenguaje estático.

  • La interpretación de cada navegador puede ser diferente.

  • Guarda muchas etiquetas que pueden convertirse en “basura” y dificultan la corrección.

  • El diseño es más lento.

  • Las etiquetas son muy limitadas.

DHT: Las Tablas de Hash Distribuido (Distributed Hash Tables, DHT) son una clase de sistemas distribuidos descentralizados que reparten la propiedad de un conjunto de claves (keys) entre los nodos que participan en una red, y son capaces de encaminar eficientemente mensajes al dueño de una clave determinada. Cada nodo es análogo a una celda de una tabla hash. Los DHT se diseñan normalmente para tratar un gran número de nodos y procesar entradas y salidas de nodos continuas. Esta infraestructura se puede utilizar para construir servicios más complejos, como sistemas de ficheros distribuidos, sistemas de compartición de archivos P2P, almacenamiento cooperativo en Web, multidifusión, anycast y servicios DNS.

Línea Cronológica:
HTML: Tim Berners 1986 (Creador de la Web); última versión html 4.0 en 1998.
CSS: Cascading Style Sheets 1994/1995; última versión CSS1 Mac de Internet Explorer 5 2000.
JAVA: Scrip Php Group 1995; última versión Java Scrip 5.2-9.2 en el 2009.
AJAX: Scripting Remoto 2005; hasta el momento.
DHTML: 2000; hasta el momento.
PHP: PHP Group 1995; última versión PHP 502.9-2 en el 2009.
CGI: en 1982 se creó con este lenguaje una imágen de un tren en 3D; última versión CGI 2009 con la película "Up".
ASP: Pre-.NET ASP/ Clásico 2002; última versión ASP/Clásico ASP 3.0.

Lenguajes de Programación (Programación Funcional)

Conjunto de operaciones primitivas cuyo significado está predeterminado en el sistema como por ejemplo la suma de los números enteros, la resta, el producto, etc. Conjunto de definiciones de función, establecidas por el programador, que eventualmente emplearán las funciones primitivas, por ejemplo la función factorial.

Utilidad: El objetivo es conseguir lenguajes expresivos y matemáticamente elegantes, en los que no sea necesario bajar al nivel de la máquina para describir el proceso llevado a cabo por el programa, y evitando el concepto de estado del cómputo. La secuencia de computaciones llevadas a cabo por el programa se regiría única y exclusivamente por la reescritura de definiciones más amplias a otras cada vez más concretas y definidas, usando lo que se denominan "definiciones dirigidas". Ejemplo:
Lisp:
*******************************************************************
; ---FACTORIAL----
;Definición matemática
; Factorial(x) = 1 si x=0 caso base
; x*factorial(x-1) si x>0 caso recursivo

;Función factorial hecha con recursividad no final
(defun factorial (n)
(if (= 0 n)
1 ; caso base
(* n (factorial (- n 1))))) ; caso recursivo

(factorial 4) ;esto nos devolvería 24=4*3*2*1

*******************************************************************


Ejemplos de Lenguajes de Programación a lo largo del Tiempo:

Lisp: 1958.
Scheme: 1970.
Miranda: 1985.
Haskell: 1990.
Scala: 2003.

Tipos de Lenguajes Funcionales

Puros: son fórmulas matemáticas. (Miranda)
Hibridos: tienen conceptos de lenguaje imperativo (Lisp, Scheme)

18/6/09

Lenguajes de Programación (Basado en Reglas [lógico])

La Programación Lógica: consiste en la aplicación del corpus de conocimiento sobre lógica para el diseño de leguajes de programación; no debe confundirse con la disciplina de la lógica computacional.La programación lógica comprende dos paradigmas de programación: la programación declarativa y la programación funcional.La programación declarativa gira entorno al concepto de predicado, o relación entre elementos. La programación funcional se basa en el concepto de función (que no es más que una que un evolución de los predicados), de corte más matemático

Fundamentos: la mayoría de los lenguajes de programación lógica se basan en la teoría lógica de primer orden, aunque también incorporan algunos comportamientos de orden superior. En este sentido, destacan los lenguajes funcionales, ya que se basan en el calculo lambda, que es la única teoría lógica de orden superior que es demostradamente computale (hasta el momento)
La programación permite formalizar hechos reales del mundo real, por ejemplo


las aves vuelan
los pingüinos no vuelan
"pichurri" es un ave
"sandokan" es un perro
"alegría"es un ave
y también reglas o restricciones:
una mascota vuela si es un ave y no es un pingüino
ante dicho "programa" es posible establecer hipótesis que no son más que preguntas o incógnitas, por ejemplo:
¿"pichurri" vuela?
¿ qué mascotan vuelan?...
Gracias a que la lógica de primer orden es compuable, el ordenador será capaz de verificar la hipótesis, es decir, responder a las incógnitas:
Es cierto que "pichurri"vuela
"pichurri" y "alegría" vuelan

Lenguajes Basados en Reglas: estos lenguajes han sido durante mucho tiempo posiblemente o más usados de todos, principalmente debido a su estrecha relación con los Sistemas Expertos utilizados en Inteligencia Artificial. Estos lenguajes son fáciles de enterder debido a su sencillez conceptual y su paralelismo con las estructuras de control más simples utilizadas en programación. Este tipo de lengujes han recibido también un fuerte impulso a partir de la web semántica. Este nuevo lenguaje incluye las siguientes características:

Reglas de producción: reglas de tipo IF- THEN habituales en los sistemas expertos.

Reglas de integridad: afirmaciones que se deben cumplir en cualquier estado del sistema

Reglas reactivas: reglas que realizan acciones cuando se cumple un evento o se dan unas determinadas circunstancias.

Reglas de derivación: reglas para definir conceptos derivados a partir de otros.

Reglas de Transformación: permiten crear reglas a travez de un llamador, una condición, y una transformación.

Podemos representar en RuleML la sentencia "Si a alguien le gusta la lectura, entonces Juan le gusta esa persona" de la siguente forma:

Prolog: el lenguaje de programación por excelencia es el Prolog, que cuenta con diversas variantes. Se creo como una respuesta a la crisis del software que ocurría durante los primeros años de la década de los 70 y producto del avance de la lógica moderna (de tipo funcional), nace PROLOG("PROgramación el LOgica").

Prolog es un lenguaje de programación que es usado para resolver problemas que envuelven objetos y las relaciones entre ellos. Su objetivo s la evolución de los lenguajes, como también el bajo "costo y facilidad" de programación que este puede ofrecer. El lenguaje está orientado para trabajar en aplicaciones de inteligencia artificial.

Otros ejemplos son:

  • ALF (Another logical framework)
  • Godel programming language
  • Mercury programming language

Lenguajes de Programación (Lenguaje Imperativo)

Son los lengujes que dan instrucciones a la computadora, es decir, órdenes.

Lenguaje Imperrativo: este lenguaje programa mediante una serie de comandos, agrupados en bloques y compuestos de órdenes condicionales que permiten al programa retornar a n bloque de comandos si se cumple la condición. Estos fueron lenguajes de programación de uso y aún hoy uchs lenguajes modernos usan este principio. No obstante, los lengujes imperativos estructurados carecen de flexibilidad debido a la secuencialidad de las instrucciones.

Algunos Lenguajes Imperativos:


  • ASP: Acive Server Pages.
  • Basic: (herramientas de enseñanza)
  • C: (implementación de Sistemas Operativos)
  • C#: C Sharp(orientado a objetos)
  • C++: (exterder lenguje de programación C)
  • Fortran: (Orientado al calculo) Variedad de versiones.
  • Pascal: (lenguaje de programación estructurado)
  • Java: (orientado a objetos)
  • Perl: (destresa en el procesado de texto)
  • PHP: (creación de páginas web dinamicas)
  • Lua: (lenguje de script con una semántica extendible)

Tipos de Lenguajes Imperativos

Lenguajes de Máquinas: consta de cadenas de números binarios y lo "entienden" directamente los procesadores.

Lenguajes Ensambladores: traducen antes los simbolos de código de operación especificados a sus equivalentes en lenguaje máquina.

Lenguajes de Alto Nivel: al desarollo de lenguajes de alto nivel que a menudo están orientados hacia una clase determinada de problemas de proceso.

Ejemplos de Lenguaje Imperativo

Procedimento factorial (entero "n")

entero resultado = 1;

mientras (n>0) {

resultado = resultado * "n"

n = n - 1;

}

devuelve resultado;

}

Ejemplo con números:

4 > 0 3 > 0

resultado = 1 * 4 resultado = 1 * 3

3 = 4 - 1 2 = 3 - 1

Conceptos de Programación


  • Alfabeto: conjunto de caracteres definidos para formar hileras.

  • Sintaxis: conjunto de reglas que determinan si una hilera es válida.

  • Semántica: conjunto de reglas que determinani la hilera tiene o no sentido.

  • Lenguaje: grupo de hileras que cumplen con reglasgrmaticales establecidas.

Tipos de lenguajes:



  • Bajo Nivel: es el lenguaje máquina. Ejemplo: 1011000001100001.

  • Nivel Medio(Ensamblador): en este lenguaje cada instrucción equivale a una instrucción en lenguaje máquina. Ejemplo: Mov al, 06lh.

  • Alto Nivel: lo comandos se introducen desde el teclado, un programa residente en la memoria o desde un Dispositivo de Almacenamiento (DD), son intersectados por un programa que los traduce a lenguaje máquina.

Traductor: es un programa que toma como entradaun programa fuente y lo convierte a un programa en código máquina.


Tipos de traductor:



  • Interprete: toma el programa fuente linea por linea y lo va ejecutando; si alguna linea tiene un error lo devuelve.

  • Compilador: genera aplicaciones que sean directamente utilizables en una computadora. El Compilador lee el programa fuente, compruebasu sintaxis y lo traduce a código máquina generando el archivo ejecutable final.

Programación: es escribir nuestras ideas sobre un lenguaje de programación, para que estas puedan ser entendidas por las computadoras, y así trabajar bajo las ordenes que se dan en las mismas con el fin de resolver problemas.


Lenguaje de Programación: son herramientas que nos permiten crear programas y sofware. Ejemplo: Delphi, Visual Basic, Java, Lisp, Prolog, etc.


La computadora funcionabajo control dee un programa el cual debe estar almacenado en una unidad de memoria (DD).

Diferentes tipo de Procesos de un Programa:

Tenemos 3 tipos:

  • Secuencial:son los que se realizan en secuencia, una acción sigue a la otra, un paso va tras otro.
  • Paralelo: se ejecutan simultáneamente.
  • Algoritmo.