Representación de Datos

Anuncio
Representación de
Datos
Una Introducción a los
Sistemas Numéricos
Tipos de Datos
Datos
Texto
Número
Imagen
Audio
Multimedia: Información que contiene números, texto, imágenes, audio y video.
Video
¿Como se manejan todos estos tipos de
Datos?




Los datos por lo general son una mezcla de
tipos.
Se utiliza una representación Uniforme de todos
los tipos de datos.
Los datos de entrada a una computadora se
transforman en la representación uniforme al ser
utilizados y almacenados por la PC.
A esta representación uniforme o formato
universal se le llama PATRÓN DE BITS.
¿Qué es un Bit?
Binary Digit = Digito Binario
Unidad mas pequeña de datos que puede almacenarse en
una computadora; puede ser ya sea 0 o 1 (cero o uno).
Un bit representa el estado de un dispositivo que puede
tomar uno de dos estados. Por ejemplo un interruptor
eléctrico.
Actualmente las computadoras utilizan varios dispositivos
binarios de dos estados para almacenar datos.
Un solo bit no puede resolver el problema
de la representación de datos, si cada
pieza de datos (caracter) pudiera
representarse por un 1 o un 0, entonces
solo se necesitaría un bit. Sin embargo se
hace necesario almacenar números mas
grandes, texto, gráficos y otros tipos de
datos.
 Es aquí donde se hacen necesarios los
PATRONES DE BITS.

Para representar diferentes tipos de datos se
utiliza un PATRON DE BITS, una secuencia o
como a veces se le llama, una cadena de bits.
Ejemplo:
1000101010111111
Esto significa que si se quiere almacenar un
patrón de bits formado por 16 bits, necesitan 16
interruptores electrónicos. Si quiere almacenar
1000 patrones de bits, cada uno de 16 bits,
necesita 16 000 bits y así sucesivamente.
¿Cómo identifica la memoria de la
computadora el tipo de datos?


No los identifica, la memoria solo almacena los
datos como PATRONES DE BITS. Es
responsabilidad de los dispositivos de
entrada/salida o de los programas interpretar un
patrón de bits como un numero, texto o algún
otro tipo de datos.
Los datos se codifican cuando entran a la
computadora y se decodifican cuando se
presentan al usuario.
¿Qué es un Byte?
Un patrón de bits con una longitud de 8 se
llama BYTE.
Este termino es también utilizado para medir
el tamaño de la memoria o de otros
dispositivos de almacenamiento.
Una pieza de texto en cualquier idioma es
una secuencia de símbolos usados para
representar una idea en ese idioma. (ej,
ABC…Z, 0,1,2,3…9)
 Se puede representar cada símbolo (de
lenguajes humanos) con un patrón de bits
(lenguaje de la maquina)

B
Y
T
E
1000010 1011001 1010100 1000101
b
y
t
e
0110010 1001001 1000100 0110101
¿Cuántos bits se necesitan en un patrón de bits
para representar un símbolo en un idioma?

Esto depende de cuantos símbolos haya
en la secuencia (idioma). La longitud del
patrón de bits que representa un símbolo
en un idioma depende del número de
símbolos usados en ese idioma. Mas
símbolos significan un patrón de bits mas
grande.
¿Cuántos bits se necesitan en un patrón de bits
para representar un símbolo en un idioma?

Aunque la longitud del patrón de bits
depende del numero de símbolos, la
relación no es lineal, es logarítmica. Si se
requieren dos símbolos, la longitud es un
bit (el log2 2 es 1). Si se necesitan cuatro
símbolos, la longitud es 2 bits (log2 4 es 2)
Numero de Símbolos
Longitud del Patrón de Bits
2
1
4
2
8
3
16
4
…
…
128
7
256
8
…
…
65 536
16
Un patrón de bits de dos bits puede tomar cuatro formas diferentes: 00, 01, 10 y 11
Cada una de las cuales representa un símbolo
Un patrón de tres bits puede tomar ocho formas diferentes:
000, 001, 010, 011, 100, 101, 110 y 111
Códigos
Se han diseñado diferentes secuencias de
patrones de bits para representar
símbolos de texto. A esta secuencia se le
conoce como Código y al proceso de
representar los símbolos se le llama
codificación
ASCII
Código Norteamericano de Estándares para Intercambio
de Información (American Standard Code for Information
Interchange).
Este código utiliza siete bits para cada símbolo. Esto
significa 128 (27) símbolos distintos que pueden
definirse mediante este código
ASCII extendido: Para hacer que el tamaño de cada patrón
sea de 1 byte (8 bits), a los patrones de bits ASCII se les
aumenta un cero mas a la izquierda. Cada patrón cabe
fácilmente en un byte de memoria
EBCDIC

Código Extendido de Intercambio decimal
codificado en binario desarrollado por IBM
al principio de la era de las computadoras.
Utiliza patrones de ocho bits, de manera
que puede representar hasta 256
símbolos. Solo es utilizado en
computadoras Mainframes de IBM.
Unicode

Ante la necesidad de un código de
mayores capacidades, una coalición de
fabricantes de hardware y software
desarrollo un código que utiliza 16 bits y
puede representar hasta 65 536 (216)
símbolos. Diferentes seccione del código
se asignan a los símbolos de distintos
idiomas en el mundo.
ISO

La Organización Internacional para la
Estandarización ha diseñado un código
que utiliza patrones de 32 bits . Este
código representa hasta 4 294 967 296
(232) símbolos, definitivamente lo
suficiente para representar cualquier
símbolo en el mundo actual.
Números
En una computadora, los números se
representan usando el sistema binario. En
este sistema un patrón de bits (una
secuencia de ceros y unos) representa un
numero.
Imágenes

Se representan en una computadora mediante
uno de dos métodos: Gráficos de mapas de
bits o gráficos de vectores
Imagen
Bitmap
Vector
Gráficos de Mapa de Bits
Una imagen se divide en una matriz de pixeles. A
cada pixel se le asigna un patrón de bits. El
tamaño y el valor del patrón depende de la
imagen, para una imagen formada solo por
puntos blancos y negros, un patrón de un bit es
suficiente para representar un pixel. Los
patrones se registran uno tras otra y se
almacenan en la computadora
Imagen
Representación de Pixeles
0 0 0 1 1 0 0 0
0 0 1 1 1 1 0 0
0 0 1 1 1 1 0 0
0 0 0 1 1 0 0 0
Representación Lineal
00011000
00111100
00111100
00011000
Para representar imágenes a color, cada
pixel coloraedo se descompone en tres
colores primarios: rojo, verde, azul (RGB).
Luego se mide la intensidad de cada color
y se le asigna un patrón de bits. En otras
palabras, cada pixel tiene tres patrones de
bits: uno para representar la intensidad del
color rojo, uno para la intensidad del color
verde y uno para la intensidad del color
azul .
Representación de pixeles de color
Rojo (con intensidad de 100%)
Verde (con intensidad de 100%)
Azul (con intensidad de 100%)
Blanco (con intensidad de 100%)
11111111
00000000
00000000
11111111
00000000
11111111
00000000
11111111
00000000
00000000
11111111
11111111
Representación de Gráficos de Vectores
Este método no guarda los patrones de bits.
La imagen se descompone en una
combinación de curvas y líneas. Cada
curva o línea se representa por medio de
una formula matemática. En este caso
cada vez que se dibuja la imagen, la
formula se vuelve a evaluar.
Audio
El audio por naturaleza es información análoga, es
continuo no discreto.
Muestreo
Cuantificación
00000100…00001111
Codificación
4 6 4
25
15
Video
Es una representación de imágenes
(llamadas cuadros o frames) en el tiempo.
Una película es una serie de cuadros
desplegados uno tras otro para crear la
ilusión de movimiento. Cada imagen o
cuadro cambia a una serie de patrones de
bits y se almacena. La combinación de las
imágenes representa el video.
Notación Hexadecimal
El patrón de bits se diseñó para representar
datos cuando estos se almacenan dentro
de una computadora. Sin embargo, para
la gente es difícil manipular los patrones
de bits. Escribir una series de números 0 y
1 es tedioso y propenso al error.
La Notacion hexadecimal se basa en 16.
Esto significa que hay 16 símbolos (dígitos
hexadecimales):
0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F
La importancia de la notación hexadecimal
se hace evidente cuando se convierte un
patrón de bits a esta notación.
Cada digito hexadecimal puede representar
cuatro bits y cuatro bits pueden
representarse mediante un digito
hexadecimal.
Dígito
Patrón de bits
Dígito
Patrón de bits
Hexadecimal
Hexadecimal
0
1
2
3
4
5
6
7
0000
0001
0010
0011
0100
0101
0110
0111
8
9
A
B
C
D
E
F
1000
1001
1010
1011
1100
1101
1110
1111
Notación Octal
Otra notación usada para agrupar patrones
de bits es la notación octal. Se basa en 8,
esto es, existen ocho símbolos (dígitos
octales): 0,1,2,3,4,5,6,7.
Cada dígito Octal representa tres bits y tres
bits pueden representarse mediante un
digito octal.
Dígito Octal
Patrón de
Bits
Dígito Octal
Patrón de
Bits
0
000
4
100
1
001
5
101
2
010
6
110
3
011
7
111
Sistemas Numéricos
Principios Básicos
Sistemas Numéricos
Un sistema numérico es un conjunto de números
que se relacionan para expresar la relación
existente entre la cantidad y la unidad. Debido a
que un número es un símbolo, podemos
encontrar diferentes representaciones para
expresar una cantidad.
Se clasifican en posicionales y no posicionales.
Sistemas Posicionales

Cada cifra de un valor numérico contribuye al
valor final dependiendo de su valor y de la
posición que ocupa. En estos sistema tenemos
tantos símbolos como la base del sistema. Los
números mayores que la base se representan
por medio de varias cifras. El valor final será la
suma de una serie de potencias de la base del
sistema:
N = An * Bn + An-1 * Bn-1 + … + A1 * B1 + A0 * B0
Donde Ai son las distintas cifras del valor numérico e “i” su posición.
Sistemas No Posicionales
Al contrario que en los sistemas posicionales, la
contribución de cada cifra no depende del lugar
que ocupa. Ejemplo, los números romanos.
El inconveniente que tienen estos sistemas es que
para escribir valores numéricos grandes son
necesarios muchos símbolos, y además resulta
difícil efectuar operaciones aritméticas con ellos,
cosa que no sucede con los posicionales.
Sistema Decimal
En el sistema de numeración decimal se utilizan
diez símbolos, del 0 al 9 para representar una
determinada cantidad. Los diez símbolos no se
limitan a representar solamente diez cantidades
diferentes, ya que se utilizan varios dígitos en
las posiciones adecuada dentro de un numero
para indicar la magnitud de la cantidad.
Base: 10
Símbolos: 0,1,2,3,4,5,6,7,8,9
Siguiendo la formula:
N = An * Bn + An-1 * Bn-1 + … + A1 * B1 + A0 * B0
n
10n
3
2
1
0
. . . 103
102
101
100
1
La posición de cada digito en una
numero decimal indica la magnitud de
la cantidad representada y se le puede
asignar un peso. Los pesos para los
números enteros son potencias de 10,
que aumentan de derecha a izquierda,
comenzando por 100 = 1.
10
100
1000
Para números fraccionarios, los pesos son
potencias negativas de diez que aumentan de
izquierda a derecha comenzando por 10-1
2
1
0
102
101
100
1
.
2
3
10-1 10-2 10-3
0.001
0.01
0.1
Punto decimal
Sistema Binario
El sistema de numeración binario es simplemente
otra forma de representar magnitudes. Es
menos complicado que el sistema decimal ya
que solo tiene dos dígitos. Es un sistema en
base dos. Los dos dígitos binarios son 0 y 1. La
posición de un 1 o un 0 en un numero binario
indica su peso dentro del numero, así como la
posición de un digito decimal determina el valor
de ese digito. Los pesos de un numero binario
están basados en las potencias de dos.
Base: 2
Símbolos: 0,1
El formato para números enteros y fraccionarios es similar
al de los números decimales.
n-1
2n-1
…
3
2
1
0
23
22
21
20
Números enteros
1
n = número de bits
2
4
8
2
1
22
21
0
20
1
.
2
3
2-1 2-2 2-3
Números Fraccionarios
1/8
1/4
Punto Binario
1/2
El sistema binario presenta el inconveniente de que
necesita muchas cifras para la representación de un
numero grande, y es muy engorroso para un humano.
Sin embargo, el sistema binario es el mas adecuado a las
maquinas electrónicas por varias razones:
1.
2.
3.
La mayor parte de las computadoras existentes
representan la información y la procesan mediante
elementos y circuitos electrónicos de dos estados
(relés, núcleos de ferrita, etc.):
Por la seguridad y la rapidez de respuesta de los
elementos físicos de dos estados diferenciados (ON /
OFF).
Las operaciones aritméticas son sencillas.
Sistema Hexadecimal
Este sistema da una forma mas compacta
para representar los números binarios.
Consta de 16 símbolos. Para indicar que
el número se expresa en hexadecimal se
suela colocar una H al final, 34AF16 34AFH
Base: 16
Símbolos: 0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F
Sistema Hexadecimal
Ejemplo de su uso en informática (de nominación de los colores para la
web)
Sistema Octal
Este sistema tiene una base de ocho
símbolos. La facilidad que existe en
convertir entre el sistema binario y el octal,
permite expresar los números binario en
un formato mas compacto, ya que cada
digito octal equivale a tres dígitos binarios.
Base 8:
Símbolos: 0,1,2,3,4,5,6,7
Sistemas Numéricos
Conversiones
Decimal a Binario
Se divide sucesivamente el numero decimal entre
2. Cada cociente resultando se divide entre 2
hasta que se obtiene un cociente cuya parte
entera es 0. Los restos generados en cada
división forman el numero binario. El primer
resto es el bit menos significativo (LSB) del
numero binario, y el ultimo resto es el bit mas
significativo (MSB).
Si el numero tiene parte fraccionaria. Esta parte
se convierte utilizando la multiplicación sucesiva
por dos, la cual consiste en multiplicar la parte
fraccionaria por 2 y después se multiplica cada
parte fraccional resultante del producto por 2,
hasta que el producto fraccionario sea 0 o hasta
que se alcance el numero deseado de
posiciones decimales. Los dígitos acarreados, o
acarreos generados por la multiplicación dan
lugar al numero binario. El primer acarreo que
se obtiene es el MSB y el ultimo el LSB.
Binario a Decimal
La forma mas sencilla para realizar esta
conversión es desarrollando la formula
que vimos para los sistemas posicionales
(suma de potencias de la base).
N = An * Bn + An-1 * Bn-1 + … + A1 * B1 + A0 * B0
Donde Ai son las distintas cifras del valor numérico e “i” su posición.
B=2
Decimal a Hexadecimal
Hexadecimal a Decimal
Hexadecimal a Binario
Binario a Hexadecimal
CONVERSION BINARIO-HEXADECIMAL
Basta con sustituir cada símbolo Binario por su equivalente en hexadecimal, según se indica en la tabla.
Decimal - Octal
Se realiza del mismo modo que de Decimal a Binario,
dividiendo la parte entera de forma sucesiva por la Base =
8 , y multiplicando la parte fraccionaria por la base
Decimal - Octal
Octal - Decimal
Se realiza del mismo modo que de Binario a Decimal, teniendo en cuenta que la
Base ahora es 8
Equivalencias en el Sistema Octal
Binario - Octal
Se realiza a la inversa, comenzando desde la coma decimal hacia la
izquierda para la parte entera, rellenando con 0´s a la izquierda si
fuera necesario; y desde la coma decimal hacia la derecha para la
parte fraccionaria, rellenando con 0´s a la derecha si fuera
necesario.
Octal - Binario
Para convertir un numero expresado en base 8 a
base 2, simplemente sustituimos cada una de
las cifras que lo forman por sus tres cifras
binarias equivalentes.
Binario (La Suma)
Sencillas reglas de la suma binaria de un bit.
1+1 = 0 y llevo 1
1+0 = 1
0+1 = 1
0+0 = 0
1+1+1 = 1 y llevo 1
Ejemplo de Suma Binaria
Ejemplo de Suma Binaria
Ejemplos de Sumas Binarias
Binario (La Resta)
Sencillas reglas de la resta binaria de un bit.
0-0=0
1-1=0
1-0=1
(1)0 - 1 = 1 con acarreo negativo (préstamo) de 1
Ejemplo de Resta Binaria
Ejemplos de Restas Binarias
19
-11
08
437
- 340
097
10011
- 1011
01000
110110101
- 101010100
001100001
63
- 46
17
111111
- 101110
010001
70
93
1000110
1011101
Binario (La Multiplicación)
La Multiplicación de Números Binarios se realiza
de la misma forma que con números decimales.
Se realizan los productos parciales,
desplazando cada producto parcial una posición
a la izquierda, y luego se suman dichos
productos. Es aun mas sencilla que con
números decimales, ya que en binario tan solo
tenemos dos dígitos: 0 y 1. Cuando
multiplicamos por 0 obtenemos 0, y cuando
multiplicamos por 1 obtenemos el mismo
numero.
La Multiplicación Binaria (Ejemplos)
Binario (La División)

Una división puede ser realizada a través
del método de substracciones sucesivas,
hasta obtener una diferencia igual a cero
(en el caso de una división exacta), o un
numero menor al divisor.
Binario (Ejemplos con División)
El cociente 10 se forma de la siguiente manera:
El 1 es resultado de la primera resta (110 -11) se resta una vez y mi cociente
se forma con 1
Al bajar el siguiente cero ya no hay posibilidad de volver a restar 11 así que
eso da por resultado el siguiente cero hacia la derecha.
Binario (Ejemplos con División)
Dividir 1110011 entre 101
Hexadecimal (La Suma)
Considerar la siguiente tabla para realizar la suma Hexadecimal
Hexadecimal (Ejemplo de Suma)
Hexadecimal (La Resta)
Decimal
Hexadecimal
0
0
1
1
2
2
3
3
4
4
5
5
6
6
7
7
8
8
9
9
10
A
11
B
12
C
13
D
14
E
15
F
Hexadecimal (La Multiplicación)
La Multiplicación Hexadecimal se realiza de la misma forma que la
multiplicación decimal, utilizando la siguiente tabla:
Hexadecimal (Ejemplo de Multiplicación)
En la tabla vemos que A*2 = 14, entonces escribimos
“4” y llevamos 1
2H *7H = 0EH, 0EH + 1 (que accarreo) = 0FH
escribo “F” y no llevo o accarreo nada.
2H * 6H = 0CH, se escribe “C” y no hay accarreo.
Continúa
Hexadecimal (Ejemplo de Multiplicación)
Continuación
Se continua multiplicando ahora por tres, para
obtener el siguiente producto parcial.
Una vez obtenidos los dos productos
parciales, se procede a realizar la suma.
Hexadecimal (Ejemplo de Multiplicación)
Hexadecimal (La División)
Hexadecimal (La División)
2 * A = 4 (y llevamos uno; F -4 = B
2 * 1 = 2 + 1 (de acarreo) = 3; 3 – 3 = 0
6 * A = C (llevamos tres); 4 – C = 8 (llevamos 4)
6 * 1 = 6 + 4 (de acarreo) = 10; B – A = 1
Hexadecimal (Ejemplo de División)
Octal (La suma)
Octal (La Resta)
Octal (La Multiplicación)
2*0=1
3*0=0
4*0=0
5*0=0
6*0=0
7*0=0
2*1=2
3*1=3
4*1=4
5*1=5
6*1=6
7*1=7
2*2=4
3*2=6
4 * 2 = 10
5 * 2 = 12
6 * 2 = 14
7 * 2 = 16
2*3=6
3 * 3 = 11
4 * 3 = 14
5 * 3 = 17
6 * 3 = 22
7 * 3 = 25
2 * 4 = 10
3 * 4 = 14
4 * 4 = 20
5 * 4 = 24
6 * 4 = 30
7 * 4 = 34
2 * 5 = 12
3 * 5 = 17
4 * 5 = 24
5 * 5 = 31
6 * 5 = 36
7 * 5 = 43
2 * 6 = 16
3 * 6 = 22
4 * 6 = 30
5 * 6 = 36
6 * 6 = 44
7 * 6 = 52
2 * 7 = 16
3 * 7 = 25
4 * 7 = 34
5 * 7 = 43
6 * 7 = 52
7 * 7 = 61
Octal (La Multiplicación)
Octal (La División)
3
756 33 010
3 67
3670
Se procede a buscar cuantas veces cabe
3301 en 756 (calculando que sea tres
tenemos…)
3 * 6 = 22; 31 – 22 = 7 (accarreo 3)
3 * 5 = 17(acarreo 3); 30 – 22 = 6
(accarreo 3)
3 * 7 = 25(acarreo 3); 33 – 30 = 3
Continuando la división tenemos ahora
que proceder a encontrar cuantas veces
cabe 3670 en 756 (calculando que sea 4)
Octal (La División)
34
756 33 010
3 67
3670
000
4 * 6 = 30; 30 – 30 = 0 (acarreo 3)
4 * 5 = 24 (acarreo 3); 27 – 27 = 0
(acarreo 2)
4 * 7 = 34 (acarreo 2); 36 – 36 = 0
Bibliografía Utilizada

Introducción a la ciencia de la Computación de la
manipulación de datos a la teoría de la computación.
Behrouz A. Forouzan
Ed. Thomson

Arquitectura del Computador
Prof. Sandro Costantini
http://medusa.unimet.edu.ve/sistemas/bpis03/clases.htm

Sistemas Numéricos y representación Interna
Prof. Roberto Willrich
http://www.inf.ufsc.br/~willrich/
Lecturas y Actividades Recomendadas

Lectura de Capítulos 2 y 3 de Introducción a la
ciencia de la Computación de Behrouz
Forouzan.(págs 14 – 49)

Resolución de ejercicios, preguntas de opción
múltiple y preguntas de repaso de los capítulo
arriba mencionados (págs 25 – 26 y págs 45 –
40)
Actividades de la Unidad
Conversiones TAREA1
 Operaciones Binarias TAREA 2
 Operaciones Hexadecimales TAREA3
 Operaciones Octales TAREA 4

Descargar