Evolución del Computador Antecedentes históricos Máquinas mecánicas: las computadoras de Charles Babbage Máquinas electromecánicas: el computador de Konrad Zuse Generaciones tecnológicas Primera generación: válvulas Segunda generación: transistores Tercera generación: circuitos integrados Cuarta generación: microprocesadores ¿Quinta generación?: el microprocesador como elemento básico
Antecedentes históricos Primer reto: operaciones básicas
El ábaco: primer instrumento para calcular.
Tablilla dividida en varias columnas. Cada una con un conjunto de cuentas engarzadas en una varilla.
Su origen se remonta a los siglos III o IV a. de C.
Sigue en uso
Máquina aritmética Desarrollada por Blas Pascal (1642, a los 18 años) Constaba de un conjunto de ruedas dentadas, cada una de ellas numerada del 0 al 9. Al pasar una rueda del 9 al 0 avanzaba un diente de rueda a la siguiente.
Máquina Mecánica. Charles Babbage (1791-1871) Uno de los padres del computador actual Adelantado para la tecnología de la época Consta de una memoria, una unidad aritmética, sistema de engranajes para transferir datos entre memoria y la unidad aritmética y un dispositivo para introducir y sacar datos de la máquina Empleaba tarjetas perforadas para Programarse Antecedentes históricos
Máquina Electromecánicas Herman Hollerith (1860-1929). Censo de los Estados Unidos Tarjetas perforadas Crea la empresa (TMC) que da lugar a IBM Konrad Zuse Construye (1941) el primer calculador universal programable (Z3). Trabaja en binario. Computador MARK-I Howard Aiken Evolución: Mark-II máquina de relés Mark-III y Mark-IV máquinas de tubos de vacío con programa almacenado. Antecedentes históricos
1ª Generación: válvulas de vacío Velocidad de proceso en ms. Disipación calorífica muy elevada Gran tamaño y poca capacidad Lenguaje máquina Monoprogramación Sin sistema operativo
1ª Generación: válvulas de vacío Colossus: grupo de científicos ingleses con Alan Turin (1943). Ayudó a descifrar el código enigma de los alemanes. ENIAC Electronic Numerical Integrator and Calculator. Eckert y Mauchly (1941) 1er computador electrónico de propósito general. Programa cableado Cálculo de tablas de fuego de artillería Operativo durante la II Guerra Mundial. Conocido en 1946
1ª Generación: válvulas de vacío ENIAC Características:
30 Tm 18.000 tubos de vacío 100 Kw 100 Khz Operaciones: suma, resta, multiplicación y división (suma: 200µs) 20 registros de 10 dígitos (2 pies/registro) Entrada/Salida de datos: Tarjetas perforadas
1ª Generación: válvulas de vacío EDVAC (Electronic Discrete Variable Automatic Computer) Eckert-Mauchly-von Neumann Bases de la Arquitectura von Neumann Programa almacenado Tubos de vacío Aritmética binaria 5 unidades: Entrada, Memoria, UAL, Control, Salida UNIVAC I – Remington-Rand Co. (Eckert-Mauchly Computer Co.) 1er computador comercial con éxito. 1951 48 sistemas, 250.000 $
2ª Generación: transistores (1948) Menor tamaño, menor disipación de calor, mayor fiabilidad
Primeros lenguajes de alto nivel: FORTRAN COBOL ALGOL
Sistema Operativo
Extensión de los computadores comerciales
2ª Generación: transistores Innovadores, con poca repercusión comercial: UNIVAC LARC IBM STRETCH (o 7030) Burroughs D-825 ATLAS Comerciales: CDC 1604 y 3600 IBM 1410 PDP 1 de DEC Serie 1100 de Univac
3ª Generación: circuitos integrados Menor tamaño, más baratos, menor consumo de energía
Primera familia de computadores, compatibles a nivel de arquitectura: IBM360
Supercomputadores: 6600 de Control Data (Cray).
Minicomputadores: PDP-8 y PDP-11
Sistemas Operativos: Multiprogramación, tiempo compartido
Lenguajes: alto nivel estructurado (Dijkstra, 1968)
4ª Generación: microprocesadores VLSI Microprocesadores y memorias de semiconductor.
1971: 1er microprocesador, INTEL 4004 (4 bits)
8 bits: Intel 8080-85, Motorola 6800 y Zilog Z-80
16 bits: Intel 8086-88, Motorola 68000 y Z-8000
32 bits: Intel 80386, Motorola 68030
Computadores personales y estaciones de trabajo
Válvula, transistor, circuito integrado, microprocesador
4ª Generación: microprocesadores VLSI Otras aplicaciones: electrodomésticos, equipos de música y vídeo, etc.
Arquitectura RISC (MIPS R2000, SPARC)
Supercomputadores: computadores paralelos
Lenguajes de programación: C y Ada
Sistemas Operativos. Estandarización: UNIX
Interfaces gráficas
Generalización de las redes de computadores
¿5ª Generación?: microprocesadores El microprocesador como elemento básico
La computación masivamente paralela
La comunicación y las conexiones entre computadores como algo generalizado.
Internet. Correo electrónico. World Wide Web….
Los ordenadores actuales Integrados con millones de transistores
Velocidades > GHz
UAL y UC Microprocesador o CPU
Memoria Principal (capacidad > Giga)
Unidad de E/S en chipsets
Diversidad y compatibilidad de periféricos (USB)
Interconectividad de sistemas
ARQUITECTURA DEL COMPUTADOR Cualquier computadora es parte de un sistema, Un sistema de computo consta de cuatro partes: HARDWARE, conocido como la computadora SOFTWARE, conocido como los programas DATOS, los cuales son convertidos por el sistema en información, los datos computarizados son digitales (dígitos o números). Un archivo es un conjunto de datos que se le ha dado un nombre: trabajo.doc, foto.jpg, musica.mp3, programa.c, datos.txt PERSONAS, conocidos como los usuarios
ARQUITECTURA DEL COMPUTADOR HARDWARE, tiene muchas partes, pero cada pieza cae en una de las siguientes: Procesador (CPU : Central Processing Unit ) Memoria Dispositivos de entrada y salida Dispositivos de almacenamiento
ARQUITECTURA DEL COMPUTADOR HARDWARE, Arquitectura de von Neumann : Soporta el concepto del programa almacenado, un concepto teórico muy importante que fue establecido por el matemático John von Neumann el 30 de junio de 1945, tanto el programa como sus datos son almacenados en la memoria del computador. Estos elementos están interconectados a través de un conjunto de líneas que llevan instrucciones (control bus), datos (data bus) y que permiten dar los valores de direcciones de memoria y dispositivos (memory bus).
ARQUITECTURA DEL COMPUTADOR HARDWARE, Arquitectura de von Neumann : Soporta el concepto del programa almacenado, un concepto teórico muy importante que fue establecido por el matemático John von Neumann el 30 de junio de 1945, tanto el programa como sus datos son almacenados en la memoria del computador. Estos elementos están interconectados a través de un conjunto de líneas que llevan instrucciones (control bus), datos (data bus) y que permiten dar los valores de direcciones de memoria y dispositivos (memory bus).
ARQUITECTURA DEL COMPUTADOR PROCESADOR (CPU) es el cerebro de la computadora, organiza y lleva a cabo las instrucciones del usuario o del software Pueden ser uno o mas microprocesadores conectados a una tarjeta de circuitos , todos sobre una tarjeta denominada Madre, que los conecta entre si.
ARQUITECTURA DEL COMPUTADOR PROCESADOR (CPU) Consiste de tres unidades principales: Unidad Aritmética/Lógica (ALU): La ALU es donde se realizan todas las operaciones que involucran un procesamiento matemático (particularmente aritmético) o lógico (operaciones booleanas). Registros: Los registros permiten el almacenammiento de datos para estas operaciones y sus resultados. Unidad de Control (CU): En la CU es donde se ejecutan todo el resto de las operaciones (decisión, control, movimiento de datos).
Una CPU con todos estos elementos implementada en un solo chip recibe el nombre de microprocesador.
Cada 18 meses se duplica el poder de computo de los micro procesadores basados en la tecnología del silicio
ARQUITECTURA DEL COMPUTADOR PROCESADOR (CPU) Velocidad de procesamiento Poder de computo
Ley de Moore: Honor a Gordon Moore, fundador de Intel. El poder de computo se duplica cada 18 meses
Esto es debido a que cada 18 meses, el avance en la tecnología de silicio ha permitido colocar mas transistores en chips mas pequeños, hoy día se cuentan por millones, versus, a principios de los 70s de solo miles.
http://www.intel.com
ARQUITECTURA DEL COMPUTADOR PROCESADOR (CPU) Velocidad de procesamiento Poder de computo
Ley de Moore: Honor a Gordon Moore, fundador de Intel. El número de transistores de un chip se duplica cada dos años.
Si el Hierro fue la materia prima del siglo XIX, .. el Silicio es la del siglo XX .
Pero la Ley de Moore también significa costes en descenso. A medida que los ingredientes de las plataformas y los componentes basados en el silicio obtienen más rendimiento, resulta exponencialmente más barato fabricarlos y, por consiguiente, son más abundantes, más potentes y están más integrados en nuestra vida cotidiana.
Los microprocesadores de hoy día equipan todo tipo de artículos, desde juguetes hasta semáforos. Una tarjeta de cumpleaños musical que cuesta unos cuantos bolívares hoy día tiene más capacidad de proceso que los grandes ordenadores más rápidos de hace décadas.
ARQUITECTURA DEL COMPUTADOR PROCESADOR (CPU) Velocidad de procesamiento Poder de computo
Ley de Moore: Honor a Gordon Moore, fundador de Intel. El número de transistores de un chip se duplica cada dos años.
Esto ha dado como resultado ganancias en el desempeño e incremento en la velocidad. Pero no solo esto determina la velocidad de un chip, sino otros factores como el Reloj, los buses de datos la memoria caché y el coprocesador matemático.
La velocidad de un procesador se mide en Megahertz, los megahertz indican la velocidad del reloj interno que posee todo microprocesador.
Un Pentium 4 tiene una velocidad de 3.0 GHz (GHz = 1000 MHz )
ARQUITECTURA DEL COMPUTADOR
DATOS: son convertidos por el sistema en información, los datos computarizados son digitales (dígitos o números).
Los datos se representan utilizando únicamente los símbolos 0 y 1
0 y 1 son llamados BITS ( BInary digiTS )
Un conjunto de 8 bits se denomina byte (octeto, de ocho)
Con 8 bits, pueden representarse 2 a la 8, combinaciones: podemos crear 256 combinaciones diferentes de octetos con 0 y 1
El código ASCII (American Standard Code for Information Interchange):
representación de caracteres y símbolos de forma electrónica, en combinaciones de 8 bits. Incluye códigos para las letras del alfabeto (minúsculas y mayúsculas), los dígitos decimales, 32 caracteres especiales y caracteres de control.
ARQUITECTURA DEL COMPUTADOR DATOS: los datos computarizados son digitales (dígitos o números).
Usar estándares requiere disciplina y a veces restringe la creatividad. Sin embargo, es muy útil para la comunicación entre usuarios. Internet requiere aún más enfoque en estándares, porque se trata en muchos casos de usuarios de idiomas diferentes. Las personas que tuvieron la visión de internet, trataron de establecer un plataforma de comunicación global. Usar estándares es una forma de cumplir este objetivo Ejemplo: Código ASCII carácter o símbolo que representa byte 64 @ 00100000 65 A 00100001
Recuerden, en el sistema numérico decimal:
123 base 10 = 1x 10^2 + 2 x 10^1 + 3 x 10^0 = 100 + 20 + 3
De igual manera en el sistema numérico binario:
100000 base 2 = 1 x 2^6 + 0 x 2^5 + 0 x 2^4 + 0 x 2 ^3 + 0 + 0 + 0 = 64
ARQUITECTURA DEL COMPUTADOR MEMORIA, Los programas se cargan y se corren desde la memoria.
Los datos usados por el programa también se cargan en memoria para un acceso rápido. La unidad de medición para describir la memoria es el byte ( 8 bits ) Es decir la capacidad de almacenar datos se mide en el numero de bytes que puede almacenar
Kilobyte (KB) = 2 ^ 10 bytes = 1024 bytes, aprox 1000 bytes Megabyte (MB)= 2 ^ 20 bytes = 1048576 bytes, aprox 1000 KB Gigabyte (GB)= 2 ^ 30 bytes = 1073741824 bytes, aprox 1000 MB
Hay dos tipos de memoria: RAM ( Random Access Memory) Se usa para cargar programas y datos mientras están en uso, pues permite un acceso mas rápido entre ella y el CPU. Son chips volátiles, al apagar el computador se borran los datos ROM ( Read Only Memory ) Se usa para mantener información de manera permanente, esto se realiza en fabrica, y no son volátiles, por ejemplo, datos de arranque del computador.
ARQUITECTURA DEL COMPUTADOR DISPOSITIVOS DE ENTRADA Y SALIDA.
Los dispositivos de entrada aceptan los datos del usuario:
Teclado, ratón, escaners, cámaras digitales, micrófonos, etc
Los dispositivos de salida devuelven los datos procesados por el usuario:
Pantalla o monitor, la impresora, cornetas
Los dispositivos de entrada/salida:
Permiten la comunicación en las dos vías: módems, conectividad en redes, etc.
ARQUITECTURA DEL COMPUTADOR ALMACENAMIENTO.
El propósito del almacenamiento, es guardar de manera permanente nuestros datos o programas.
Diferencias entre almacenamiento y memoria: 1 Hay mas lugar en el almacenamiento que en la memoria 2 Los contenidos son conservados en el almacenamiento cuando la computadora se apaga 3 El almacenamiento es mucho mas barato que la memoria
El dispositivo que contiene un disco se llama unidad de disco Ejemplos: Disco duro : disco construido dentro del computador no removible, con gran capacidad Unidad de diskettes: permite leer/grabar datos en discos flexibles de diferentes formatos. Unidad de CD RW: permite leer/grabar datos en unidades de CD Unidades de diferentes formatos de discos ópticos, microdrive, flashcard, etc.
ARQUITECTURA DEL COMPUTADOR SOFTWARE: Permite a la computadora realizar una tarea determinada
Programa: conjunto especifico de instrucciones electrónicas que dirigen a una computadora a realizar una tarea especifica.
SOFTWARE DEL SISTEMA: Sistema Operativo: Le dice a la computadora como interactuar con el usuario y como usar los dispositivos
SOFTWARE DE APLICACIÓN: Otros programas que ayudan a la gente a realizar tareas especificas, desde procesamiento de palabras (Word), hasta para interactuar en la WEB !!
ARQUITECTURA DEL COMPUTADOR SISTEMA OPERATIVO S.O.
Conjunto de programas que se encargar de realizar la administración de todos los recursos que posee un computador Permiten que el desarrollo de nuevos programas o aplicaciones se independice del tipo de Hardware, Portabilidad
COMANDO: Significa mandato, orden
El usuario interactúa con el S.O a través de Comandos !! Pueden ser: Líneas de Comando: como en UNIX, DOS, LINUX Entorno TEXTO-GRAFICO: como en MS-WINDOWS, OPENWINDOWS, AMBIENTES GRAFICOS DE LINUX DE LA COMUNIDAD DE OPEN SOURCE
Tareas del S.O. ORGANIZA Y ADMINISTRA LOS MEDIOS DE ALMACENAMIENTO DIRECTORIOS: Entidades logicas para organizar jerarquicamente la ubicación de la informacion. Se usan comandos para crear Directorios ARCHIVOS: Entidades logicas que contiene informacion diversa, creada por la aplicación o el usuario. Como archivos de texto, imágenes, musica, video. Con comandos del S.O las guardamos en Directorios
ARQUITECTURA DEL COMPUTADOR SOFTWARE DE APLICACION:
Aplicaciones: es un conjunto de programas que llevan a cabo tareas especificas tales como: Manejo de base de datos, Procesadores de texto, Diseño grafico, control de procesos, sistemas de finanzas, planillas de calculo, etc.
Sistemas de desarrollo: Son conjuntos de programas, que implementan una tecnología de desarrollo, para generar nuevas aplicaciones.
– Implementados usando Lenguajes de programación
LENGUAJES DE PROGRAMACION
Nivel de abstracción – Lenguajes de 1er nivel (bajo nivel): código de maquina – Lenguajes de 2do nivel (bajo nivel): Uso de Ensamblador – Lenguajes de 3er nivel (alto nivel): Uso de traductores tipo interpretadores o compiladores. ( Lenguajes Pascal, Fortran, C, Basic, C++, Prolog, Lisp, Cobol, PL1, Ada, Java, HTML, XML, etc)
Lenguajes de 1er Nivel Lenguaje de máquina, binario Ejecuta acciones directas en el CPU Instrucciones del tipo 1001001100101 Como recordar esto? Prácticamente nadie trabaja hoy a este nivel, excepto los diseñadores de "chips" procesadores.
Lenguajes de Programación
Lenguajes de 2do Nivel lenguaje más comprensible: por el hombre consiste por lo tanto en establecer la equivalencia de bloques binarios con signos de nuestro lenguaje habitual Comandos del tipo ADC (ADd with Carry) Se llama ENSAMBLADOR, el prog que traduce los comandos al lenguaje de máquina Progreso en la redacción de comandos Muy atado al tipo de CPU de la máquina
Lenguajes de Programación
Lenguajes de 3er Nivel Lenguajes de "alto nivel", es decir más cercanos al modo de expresar del hombre que de la operación de la máquina. El programador manipula entidades lógicas abstractas, sin los detalles de su implementación a nivel de maquina Más fáciles de manejar y más independientes de las características técnicas de los procesadores Redactar un programa, sin tener que preocuparse por el código binario o de ensamble
Lenguajes de Programación
Lenguajes de 3er Nivel Necesita un programa traductor, que transforma los bloques del lenguaje en bloques binarios El avance en el desarrollo de "compiladores" e "intérpretes" (los dos tipos de programas traductores) ha sido por lo tanto fundamental en el desarrollo de los lenguajes de alto nivel Ventajas: facilidad de aprendizaje, lectura/escritura, corrección, transformación y conversión de un lenguaje a otro.
Lenguajes de Programación
FORTRAN ( FORmula TRANslation) 1953, Job Backus, un empleado de IBM propuso el desarrollo de un nuevo lenguaje de programación, el Fortran. Por aquella época, todos los programadores escribían en ensamblador Fue el primer lenguaje de alto nivel: fue desarrollado por IBM y su primera versión se lanzo en 1957. Se caracteriza por su potencia en los cálculos matemáticos pero está limitado en lo relativo al tratamiento de datos no numéricos
Lenguajes de Programación
ALGOL ( ALGOrithmic Lenguage) Primer lenguaje creado por un comité internacional (GAMM y ACM). En 1960 se reunieron representantes de varios países europeos y de Estados Unidos para crear un lenguaje destinado a "describir procesos" mediante instrucciones de control (iteraciones y alternaciones) de nivel más elevado que las existentes en las versiones existentes de su predecesor, el FORTRAN.
Lenguajes de Programación
Lenguajes de Programación
Lenguajes de Programación
C ( después de B )
Creado en 1972 por Dennis Ritchie, que junto con Ken Thompson habían diseñado anteriormente el sistema operativo UNIX, y su intención al desarrollar el lenguaje C fue conseguir un lenguaje idóneo para la programación de sistemas que fuese independiente de la máquina para utilizarlo en la implementación del sistema operativo UNIX .
Se creó para superar las limitaciones del lenguaje B, utilizado por Ken Thompson para producir la versión original de UNIX en 1970.
Lenguaje de Programación C
El C es un lenguaje moderno de propósito general que combina las características de un lenguaje de alto nivel (programación estructurada, tipos y registros de datos, recursividad, etc.) con una serie de características más propias de lenguajes de mas bajo nivel
Su definición apareció en 1978 en el libro "The C programming Language" Brian W. Kernighan y Dennis M. Ritchie (Ed. Prentice-Hall)
Lenguaje de Programación C
En 1983 se establece un comité para resolver las discrepancias de varias versiones de C, el cual empezó a trabajar en un estándar ANSI C, la cual fue completada en 1988. Este estándar incluye una enorme biblioteca de funciones para entrada/salida, tratamiento de textos, funciones matemáticas, etc
Documentada en: 1988. "The C Programming Language-Reference Manual Dennis M. Ritchie (Lab.Bell)
ANSI ( American National Standard Institute)
Lenguaje de Programación C
Lenguaje de Programación C CARACTERISTICAS
Programación estructurada Economía de las expresiones Abundancia de operadores y tipos de datos Codificación en alto nivel y bajo nivel. No esta orientado a ningún área en especial Producción de código objeto altamente optimizado