PROGRAMACION, ALGORITMOS Y ESTRUCTURAS DE DATOS Profesor Titular: Ing. Graciela TOCCACELI. email: toccaceli@ing.unlp.edu.ar Profesor Adjunto: Mag. Ing. Pablo A. GARCIA. pagarcia@ing.unlp.edu.ar 1 Objetivo de la materia: Estudiar Informática a través de uno de los lenguajes de programación más utilizados el lenguaje “C”. 2 INFORmación y autoMATICA La Informática trata de la adquisición, representación, tratamiento y transmisión de la información. Estas operaciones se realizan automáticamente utilizando máquinas llamadas computadoras. Ordenador Datos Resultado 3 HISTORIA DE LA INFORMÁTICA • El ábaco 500 años AC. • Siglo XVII Blaise Pascal . Crea la primera máquina de sumar y restar mecánica la Pascalina. Esta calculadora estaba basada en una serie de engranajes y ruedas dentadas. La base de las operaciones consistía en contar los dientes de un engranaje. 4 • En 1671, Gottfried Wilhelm Leibniz construye la Máquina Universal, la primera máquina capaz de sumar, restar, multiplicar y dividir. El mecanismo también era de engranajes. Las multiplicaciones se realizaban como sumas sucesivas y las divisiones como restas sucesivas. Estas no eran máquinas automáticas ya que requerían la Intervención humana durante el proceso. • Inicio XIX Joseph Marie Jacquard, inventa un telar mecánico cuyos diseños se reproducían gracias a una serie de tarjetas perforadas. Las tarjetas perforadas transmitían a la tejedora las instrucciones necesarias para su funcionamiento. • 1834-35 Charles Babbage utilizando tarjetas perforadas y ruedas mecánicas diseña la máquina analítica. La diseña con Memoria, Unidad de cálculo y Unidad de control basada en tarjetas perforadas. Era capaz de realizar cualquier cálculo y de almacenar programas. La tecnología de la época no permitió construirla. 5 • En 1890 Herman Hollerith, crea una máquina para realizar el censo de EEUU. Esta máquina utiliza un sistema electrónico para la lectura de las tarjetas perforadas y un sistema mecánico para calcular. En 1924 la compañía fundada por Hollerith cambia de nombre para denominarse "International Business Machines" (IBM). • Luego el avance tecnológico marcó distintas generaciones de computadoras: Se destacan -> 6 En 1943, J. Mauchly y J. Presper Eckert crean el primer equipo sin piezas mecánicas: el ENIAC (Calculador e integrador numérico electrónico). -utilizada por el Laboratorio de Investigación Balística del Ejército de los EEUU. -18.000 válvulas o tubos de vacío. -ocupaba 167 m2. -programación manual, mediante el seteo de interruptores o conectando cables -5000 instrucciones por segundo. – Sistema decimal - gran consumo energético (160 kW). • 7 • En 1944 Von Newmann propone que el programa debía almacenarse electrónicamente dentro de la computadora junto con los datos y el uso del sistema binario. • En 1946 J. Mauchly y J. Presper Eckert y John Von Neumann crean EDVAC (Equipo electrónico de variable discreta), que podía almacenar programas en la memoria (1.024 palabras en la memoria central y 20.000 palabras en la memoria magnética). - 6.000 tubos de vacío y 12.000 diodos. - Consumía 56 kilowatts de potencia. - Cubría 45,5 m² de superficie. - Pesaba 7.850 kg. - Binaria. • En 1953 IBM lanza el IBM 701: conocido como la "calculadora de Defensa" mientras era desarrollado, fue anunciado al público el 29 de abril de 1952 y era la primera computadora científica comercial de IBM. Durante los cuatro años de producción se vendieron 20 unidades La memoria contenía 72 tubos de vacio con una capacidad de 1024 bits, dando una memoria total de 2048 palabras de 36 bits cada una. Cada uno de los 72 tubos eran de 76 mm de diámetro. La memoria se podía ampliar a un máximo de 4096 palabras El tiempo de acceso de la memoria de 12 microsegundos. La memoria de tubos necesitaba "refrescarse" periódicamente. 8 El avance de la electrónica… 1947 1907 1957 1971 291 millones de transistores - Actual 9 Hitos de las diferentes generaciones: • Generación 1 (1940-1960) (válvula de vacío): Se sustituye la programación de 1s y 0s por un lenguaje simbólico. • Generación 2 (1960-1965) (transistor): Se introducen los lenguajes de alto nivel, se ampliaron las memorias auxiliares y se crearon los discos magnéticos de gran capacidad. Se diseñaron las impresoras y lectores ópticos • Generación 3 (1965-1975) (circuitos integrados): Aparecen los sistemas operativos para el control de la computadora. Aparecen lenguajes como Cobol y Fortran • Generación 4 (1975-1990) (microprocesadores) : Aparece el microprocesador. Nuevos lenguajes de programación :Logo, Pascal, Basic, C, C++. En 1976 Steve Wozniak y Steve Jobs fabrican en el garaje de su casa la primera microcomputadora Apple I del mundo y más tarde fundan la compañía Apple. En 1981 IBM lanza al mercado su primer IBM-PC. 10 • Generación 5 (1990 – hoy): supercomputadores que incorporan varios microprocesadores en la misma máquina. 384000 procesadores 11 ¿Que es un computador? Dispositivo capaz de aceptar unos datos de entrada, efectuar con ellos operaciones lógicas y aritméticas, y proporcionar la información resultante a través de un medio de salida; todo ello sin intervención de un operador humano y bajo el control de un programa de instrucciones previamente almacenado en el propio computador. 12 En el interior del ordenador la información se almacena y transfiere utilizando el sistema binario 1s y 0s. En las E y S se efectúan las transformaciones alfanumérico a binario y viceversa. Ordenador 321.15 E rojo 0110111000011 0110101001110 0000110100100 001110010 1001111000010 1001010001110 0111111001010 1001001001001 0111010010100 0000000010001 011111110010 1000101010010 1010011111000 2300,34 S Rosario 13 Los valores 0s y 1s pueden interpretar en el interior del ordenador dependiendo del dispositivo: -Un estado magnético (N/S) -Un nivel de tensión (5V/0V) -Un valor de corriente ( 20mA/0 mA) -Presencia o ausencia de Luz Bit (Binary Digit) es la mínima unidad de información que representará un 1 o un 0. 14 Estructura de un Ordenador tipo Von Newmann Unidades de Entrada: Teclado, lector de tarjeta, lápiz óptico, escáner, etc. Unidades de Salida: Monitor, impresora, plotter, etc. Unidades de E/S: Discos duros, sólidos, flash USB, cintas magnéticas, etc. 15 Memoria principal (MP): -El programa que se ejecuta debe almacenarse en la MP. -Gran velocidad de acceso (decenas de ns). -Formada por Circuitos integrados IC. -Volátil. -Estructurada en direcciones de un dado número de bits (palabra). -Para leer o escribir una palabra de información se debe dar la dirección de la posición en el IC. -Capacidad de GBytes. Dirección contenido 0000 0001 0002 ……….. ……….. ……….. ……….. ……….. FFFF 16 Memoria Auxiliar: -Presenta una capacidad de 100 a 1000 veces mayor que la MP. -Es 10000 a 100000 veces mas lenta que la MP (decenas de ms). -La información se almacena en forma permanente (Gbytes y TBytes. 17 UNIDAD ARITMETICO LOGICA (ALU): -formada por circuitos electrónicos que realizan operaciones aritméticas y lógicas -registros temporales le ayudan a operar -las señales de control especifican la acción: (Sumar, restar, dividir, multiplicar, etc.). -un registro de estado guarda información del resultado de la última operación ( cero, signo, acarreo, desborde, paridad.) Registro de estado Registros temporales R0 Z R1 S R2 C R3 V 18 UNIDAD DE CONTROL (UC) -Detecta las señales de estado provenientes de las distintas unidades. -Toma de la MP una de las instrucciones. -Decodifica la instrucción. -genera las señales necesarias para llevar a cabo la ejecución. -repite el proceso hasta finalizar el programa. -un clock sincroniza todas las operaciones. Clock Registro de instrucción Registro de estado Lógica de Control Señales de control Máquina de estados f = 1/T T Tiempo de ciclo Mhz, GHz 19 BUS (Conexión eléctrica entre las distintas unidades.) Tipos de Buses: -Serie -Paralelo de (8,16,32,64 o 128 líneas conductoras) Bus del Sistema informático: -Bus de Datos -Bus de Direcciones -Bus de Control CPU Memoria Entradas/ Salidas Bus de datos Bus de direcciones Bus de control 20 Aspecto de los buses del sistema: 21 MEDIDA DEL RENDIMIENTO O VELOCIDAD DEL PROCESADOR: MIPS: Millones de instrucciones máquina por segundo MIPS = NI /(te . 106) MFLOPS.: Millones de operaciones con números reales de 64 bits por segundo. MFLOPS = NOcf/(te. 106) NOcf: número de operaciones en coma flotante. te: tiempo de ejecución de programas especiales o benchmarks como Linpack o SPEC. 22 Clasificación de los ordenadores por el grado de paralelismo de su arquitectura: SISD Monoprocesadores -Una instrucción , un dato -Computadora Von Newman (ya analizada) SIMD Computadoras matriciales y vectoriales -Una instrucción , múltiples datos (No existen ninguna) MIMD Supercomputadoras -Múltiples instrucciones, Múltiples datos 23 MIMD MULTIPROCESADORES MULTICOMPUTADORES 24 Clasificación de los ordenadores según su uso: -Computadores de uso general. -Computadores embebidos (lavadoras, teléfonos inteligentes, controladoras de disco, teclado, impresora, etc.). 25 Clasificación de los computadores por su potencia de cálculo: Precio US$ Número procesado res Memoria Principal Memoria auxiliar Usuarios Supercomputador >5.000.000 miles TB EB Decenas a miles Servidor de gama alta (Mainframe) >500.000 cientos Cientos de GB TB Cientos a Miles Servidor de gama media 25.000 a 500.000 decenas Cientos de GB TB Decenas a cientos Servidor Básico <25.000 4, 16 Decenas de GB Cientos de GB decenas Computador personal 50010000 2,4 GB Cientos de GB personal 26 SUPERCOMPUTADORES: -Ejemplos: ASCI Whute, Earth Simulator, Tianhe 2. -Ejecutan Petaflops (billones de FLOPS). -Cientos o Miles de procesadores trabajando en paralelo. -Muy costosos. -Utilizados en aplicaciones de cálculo complejo (HPC High Perfomance Computing) : •Analisis de sismos o movimientos en la corteza terrestre •Predicción climática, etc. 27 El ciclo de máquina de cualquier instrucción consta de dos fases: Adquisición y ejecución EL (PC) ->(AR) Adquisición M(AR)->(DR) (DR)->(IR) (PC+1)->(PC) ALU Ejecución UC IR AR DR PC Memoria Entradas/ Salidas Bus de datos Bus de direcciones Bus de control 28 En la actualidad los procesadores incorporan: -Un procesador gráfico. -Un procesador de punto flotante -Un controlador de Memoria -Varios niveles de memoria caché -Varios cores. 29 Microcontrolador: (Presente en electrodomésticos, periféricos, teléfonos) Núcleo procesador Memoria EEPROM o Flash Puertos paralelos de E/S RAM Temporizadores Puertos series de E/S Conversor D/A Conversor A/D 30 Tipos de Memoria Memoria Interna: -Registros -caché (SRAM) -Memoria Principal (DRAM) -Memoria ROM Memoria auxiliar, externa o masiva: -Discos de estado sólido y flash USB -Dispositivos magnéticos -Dispositivos ópticos 31 JERARQUIA DE MEMORIA 1 ciclo Caché interna L1 1 ciclo Caché externa L2/L3 3 a 5 ciclos precio capacidad DRAM SSD velocidad Registros CPU 30 a 100 ciclos 10k a 20k ciclos Flash USB 300k a 3M ciclos HDD 10M a 100M ciclos Cinta magnética Mayor 100M ciclos 32 ¿ Porque se introducen las memorias chachés? -Porque la velocidad del procesador es del orden de los ns. Y la velocidad de la memoria principal es de 30 a 100 veces mas lenta que el procesador. En consecuencia el procesador se ve frenado cuando debe acceder a memoria. SOLUCION: Utilizar memoria caché mas rápidas con tecnología SRAM de 1 a 5 veces mas lenta que el procesador. 33 CORE i7 con 3 niveles de caché -Caché L1 : 32KB dentro del núcleo -Caché L2: 256KB por núcleo -Caché L3: 12 MB compartida 34 DISCO DE ESTADO SÓLIDO (SSD) Dispositivo de almacenamiento masivo basado en circuitos integrados, emulando un disco duro. Almacenan información en forma permanente. 35 GRABACIÓN Y LECTURA MAGNÉTICA Información leida Información a grabar Cabeza Lectora / Grabadora Material magnetizable substrato movimiento 36 Discos Duros (HDD) -La información se guarda por sectores (arcos de pistas). -El brazo con la cabeza lectora/grabadora tiene movimiento axial. 37 El HDD consiste en varios platos y un peine con varias cabezas lectoras/grabadoras que permiten acceder simultáneamente a un sector de un cilindro. 38 Primera Generación de CD -La información va troquelada en una superficie de aluminio -Si hay reflexión del haz laser se tiene un 0 sino un 1. 39 GENERACIONES DE DISCOS ÓPTICOS 40 Si conectamos todo mediante un solo bus, el del sistema……… CPU MEMORIA PUERTO IP PUERTO OP Bus del sistema Ventajas: Sencillo, barato. Desventaja: Toda la información se transmite por el mismo bus. Los dispositivos mas lentos frenan el funcionamiento del ordenador, por ejemplo mandar datos a una impresora. 41 SOLUCIONES A LA ESTRUCTURA DE UN ÚNICO BUS: -Memorias intermedias (buffer) -Buses específicos -Controladores de E/S -Controlador de Acceso Directo a Memoria DMA 42 BUFFER: Memoria intermedia que sirve para almacenar datos. El procesador carga el buffer con datos y se dedica a ejecutar otros procesos, mientras el periférico a su velocidad lee los datos del buffer. Un controlador o secuenciador controla las operaciones que se realizan en el interior del periférico. 43 BUSES ESPECIFICOS: Un bus especifico frontal, comunica procesador y memoria MEMORIA Bus frontal CPU PUERTO IP PUERTO OP Bus del sistema 44 Un Controlador de E/S es un procesador con memoria local, especializado en controlar operaciones de transferencia de datos entre periféricos conectados a él y el procesador MEMORIA P0 P1 P2 P3 P4 P5 CPU Controlador de E/S Canal 0 Controlador de E/S Canal 1 Bus del sistema 45 Un Controlador de Acceso Directo a Memoria (DMA) es un procesador que permite la transferencia de datos entre memoria y un periférico sin intervención del procesador. P0 P1 P2 Controlador de E/S P3 P4 P5 Controlador de E/S Canal 0 Canal 1 Bus de E/S MEMORIA CPU Bus frontal DMA PRINCIPAL CACHE Bus del sistema 46 UTILIZACIÓN DE BUSES Tipo Periféricos de bus AGP Adaptadores Gráficos PCI Discos duros, otros dispositivos, tarjeta gráfica, Tarjeta de red, controlador SCSI. ISA Lpt1 (impresora), COM1, COM2 (ratón , módem) disquetera, teclado. Teclado, mouse, cámara, escaner, impresora USB 47 ESQUEMA DE UN PC (1990-2000) 48 ESQUEMA DE UN PC ACTUAL Chipset: Conjunto de chips con la misma arquitectura del procesador que sirven de puente entre éste y la memoria y las E/S. PUENTE NORTE: Enlaza la CPU y la memoria. Controla el tráfico entre éste, la memoria y la tarjeya gráfica. Contiene el controlador de DMA: PUENTE SUR: comunica el procesador con el resto de los periféricos(IDE,USB ,PCI, ETC): 49 PINES DEL PROCESADOR INTEL CORE i7 50 SISTEMA INFORMÁTICO APLICACIONES DE USUARIO APLICACIONES DEL SISTEMA SISTEMA OPERATIVO HARDWARE 51 EL SISTEMA OPERATIVO Definición: Es el programa o grupo de programas que controlan el funcionamiento del hardware y nos ofrecen un modo sencillo de acceso al ordenador. El sistema operativo se compone de un núcleo o Kernel y un intérprete de comandos denominado Shell. El shell es un interfaz entre la CPU y el usuario. Cuando le pedimos algo al ordenador, el shell se encarga de traducirlo en llamadas o peticiones a los programas que componen el kernel o núcleo, y éste acciona el hardware. El kernel del sistema operativo tiene entre otros los siguientes componentes: o Cargador inicial (programa de arranque) o Planificador de trabajo de la CPU (Planifica procesos y tareas) o Administrador de periféricos o Comunicador entre procesos o Administrador de memoria o Administrador de archivos 52 Arranque del Ordenador Para que el ordenador pueda arrancar, los programas de arranque y otros de utilidades básicas se guardan en la ROM, que tiene especificado pedir un disco de sistema. Una vez se introduce este disco, el control lo asume el sistema operativo. El disco de sistema puede ser flexible A: o duro C: . 53 Cuando se enciende un ordenador Cuando se conecta el interruptor de un ordenador, ocurren una serie de operaciones que se pueden englobar en dos grupos: 1. Los test de comprobación: o Entrada de la alimentación eléctrica al ordenador desde la fuente de alimentación o Llamada del microprocesador a la ROM-BIOS o La BIOS le da las indicaciones de los test a realizar o Comprobación del bus de expansión (placas instaladas) o Verificación de la tarjeta de vídeo o Comprobación de la memoria caché o Comprobación de la memoria RAM o Comprobación del teclado o Comprobación de las unidades de disco 2. La carga del resto del sistema operativo: según el sistema operativo que se tenga. 54 USOS DE SISTEMAS OPERATIVOS DENTRO DE WINDOWS PARA MÓVILES 55 UNIX -SO estándar -Comercializado en los 90. -Se desarrollaron mas de 100 versiones en las dos primeras décadas. -Es la columna vertebral de Internet -Es un SO multiprogramación, multiusuario y multiprocesamiento -Muy utilizado en los supercomputadores actuales. -Presenta una versión para PC (Linux) 56 Bibliografía: 1. Programación en C, Metodología, estructura de datos y objetos de Luis Joyanes Aguilar. 2. Organización y Arquitectura de Computadores de Stalling. 3. Sistemas Operativos Modernos de Andrew S. Tanenbaum 4. Introducción a la Informática de A. P. Espinosa 57