Rappresentazione di numeri relativi (interi con segno)

Slides:



Advertisements
Presentazioni simili
I numeri interi relativi
Advertisements

Rappresentazioni numeriche
Aritmetica Binaria
Le frazioni Vogliamo ampliare l’insieme numerico N con un insieme numerico nel quale sia sempre possibile eseguire la divisione . Per fare ciò dobbiamo.
1 I numeri relativi DEFINIZIONE. Si dicono numeri relativi tutti i numeri interi, razionali e irrazionali dotati di segno (positivo o negativo). ESEMPI.
I numeri naturali ….. Definizione e caratteristiche
Rappresentazione di Numeri Reali
Rappresentazioni numeriche
Codifica dei Dati Idea: vogliamo rappresentare dati eterogenei utilizzando un linguaggio che l’elaboratore puo’ facilmente manipolare Essenzialmente vogliamo.
Sistemi di numerazione e codici
1 © 1999 Roberto Bisiani Rappresentazione delle informazioni n Occorre un codice n Legato alla tecnologia usata Robustezza Semplicita Economicita.
esponente del radicando
Esercitazioni su rappresentazione dei numeri e aritmetica
Larchitettura di Von Neumann CPU RAM Mem second I/O bus.
Informatica 3 Codifica binaria.
A.S.E.5.1 ARCHITETTURA DEI SISTEMI ELETTRONICI LEZIONE N° 5 Rappresentazione di numeri con segnoRappresentazione di numeri con segno –Modulo e segno (MS)
Introduzione alla Fisica
Corso di Informatica (Programmazione)
Corso di Informatica (Programmazione)
NUMERI RELATIVI.
Lezione del 30/11/2010 By Vaccaro Maria A.. Con base 2 e n cifre, abbiamo a disposizione 2 n configurazioni distinte. Per esempio con 8 bit (n=4) possiamo.
Esistono 10 tipi di persone al mondo: Quelli che conoscono il codice binario & Quelli che non lo conoscono.
Rappresentazione binaria dei numeri interi senza segno.
Rappresentazione dei numeri reali
Codifiche Interne Codifiche Interne
1 Sistemi Digitali. 2 Definizione Analog Waveform Time Voltage (V) 0 5 Digital Waveform Time Voltage (V)
I numeri relativi by iprof.
Codifica binaria Rappresentazione di numeri
Usare rappresentazioni di lunghezza fissa porta ad avere valori non rappresentabili: Overflow indica un errore nella rappresentazione del risultato in.
Conversione binario - ottale/esadecimale
Conversione binario - ottale/esadecimale
Rappresentazione di Numeri Reali
1 © 1999 Roberto Bisiani Rappresentazione delle informazioni n Occorre un codice n Legato alla tecnologia usata Robustezza Semplicita Economicita.
ALGEBRA.
Le operazioni aritmetiche con i numeri naturali e decimali
I numeri interi relativi
RAPPRESENTAZIONE DELL'INFORMAZIONE
CONVERSIONE NUMERI INTERI CON COMPLEMENTO A DUE. I computer di oggi effettuano ogni tipo di operazione numerica, ma le prime ALU degli anni 50 erano in.
Le operazioni con i numeri
Addizione e sottrazione
La rappresentazione delle informazioni in un computer [Terza parte]
NUMERI RELATIVI.
Process synchronization
Rappresentazione dell’Informazione
Rappresentazione dell’informazione nel calcolatore.

LA SOTTRAZIONE Beatrice Reina 1A.
ARCHITETTURA DEI SISTEMI ELETTRONICI
RETI LOGICHE Daniele Manzaroli
Rappresentazioni numeriche. Introduzione Un calcolatore elettronico dispone di uno spazio finito per memorizzare le cifre che esprimono un valore numerico.
Rappresentazione dell’informazione
Rappresentazioni a lunghezza fissa: problemi
1 © 1999 Roberto Bisiani Overflow n Overflow  traboccamento Si verifica se il risultato di un’operazione non puo’ essere rappresentato con il numero di.
Rappresentazione dell'informazione
La codifica dei numeri.
Conversione binario-ottale/esadecimale
Rappresentazione degli interi
Informatica Lezione 3 Psicologia dello sviluppo e dell'educazione (laurea magistrale) Anno accademico:
Istruzioni per l’uso…….
Le quattro operazioni.
Rappresentazione dei numeri
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Numeri in virgola Marco D. Santambrogio – Ver. aggiornata al 24 Agosto 2015.
I sistemi di numerazione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE Numeri con segno ed in virgola Marco D. Santambrogio – Ver. aggiornata al 20 Marzo.
Definizioni Rappresentazione Operazioni Espressioni Esercizi
Criteri di divisibilità
CODIFICA DATI/ISTRUZIONI Nel calcolatore tutta l’informazione e’ codificata in binario (sequenza di 0,1) Perche’ il calcolatore e’ formato da componenti.
I numeri relativi DEFINIZIONE. Si dicono numeri relativi tutti i numeri interi, razionali e irrazionali dotati di segno (positivo o negativo). ESEMPI Numeri.
Le frazioni A partire da N vogliamo costruire un nuovo insieme numerico nel quale sia sempre possibile eseguire la divisione. Per fare ciò dobbiamo introdurre.
Transcript della presentazione:

Rappresentazione di numeri relativi (interi con segno) E’ possibile estendere in modo naturale la rappresentazione dei numeri naturali ai numeri relativi. I numeri relativi sono numeri naturali preceduti da un segno: - positivi (segno +) - negativi (segno -) La parte che segue il segno è il valore assoluto Il segno può assumere 2 valori => Basta 1 bit per rappresentarlo. Il valore assoluto è un numero naturale. Quindi, se ho N bit per rappresentare un numero, 1 bit rappresenta il segno e gli altri N-1 il valore assoluto

Rappresentazione di numeri interi relativi (con N bit) Prima rappresentazione possibile (più naturale): Segno e Valore Assoluto Il primo bit indica il segno (0=positivo, 1=negativo), cui segue la rappresentazione (su N-1 bit) del valore assoluto del numero, cioè del numero naturale che si ottiene eliminando il segno. Es. (con 8 bit) 10000011 = - 3 NB Esistono 2 rappresentazioni per lo zero! 10000000 (-0) e 00000000 (+0)

Rappresentazione di numeri interi relativi (con N bit) Rappresentazione alternativa (più ‘furba’) : Complemento a due Un numero negativo -n è rappresentato attraverso il complemento a 2 del suo valore assoluto, cioè dal numero intero positivo 2N - n. Es. N=8 2N=256 (6)10 = (00000110)2 (-6)10 =(11111010)2 [Infatti: 256 - 6 = 250]

Osservazioni I numeri naturali e i corrispondenti numeri relativi positivi hanno la stessa rappresentazione e hanno come cifra più significativa 0 (35)10 = (00100011)2 in tutte le rappresentazioni Tutti i numeri negativi hanno 1 come cifra più significativa (come nella rappresentazione in segno e valore assoluto) (-35)10 = (10100011)2 rappr. segno + val. ass. (11011101)2 rappr. mediante compl. a 2 Lo zero ha un’unica rappresentazione E’ possibile estendere la proprietà dei numeri relativi per cui m – n = m + (-n)

Rappresentazione dello 0 modulo e segno rappresentazione ambigua +0 = 00000000 - 0 = 10000000 complemento a due rappresentazione univoca infatti il complemento a due di 00000000 è ancora 0 (primo vantaggio!) Quindi: in una rappresentazione a N bit con complemento a 2 posso rappresentare i numeri da - (2N-1) a + 2N-1-1 Es. con 8 bit rappresento i numeri da -128 -(27) a 127 (27-1)

Addizione Se si utilizza la notazione con complemento a 2, si può ragionare in termini “algebrici”: Es. 22 – 21 Rappresento -21 in complemento a 2 1 1 1 1 1 1 0 0 0 1 0 1 1 0 1 1 1 0 1 0 1 1 0 0 0 0 0 0 0 1 (1) bit di overflow La sottrazione equivale alla somma del minuendo con la negazione (rappresentazione complementata) del sottraendo. Secondo vantaggio della rappresentazione in complemento a 2: all’interno del calcolatore somme e sottrazioni sono eseguite utilizzando la stessa operazione (circuito).

Calcolo rapido del complemento a 2 Il complemento a 2 di un numero in una rappresentazione ad N bit si definisce come: C(n) = 2N - n Possiamo scrivere anche C(n) = (2N - n - 1) + 1 N.B. !! Dati n (ad es. 00100011) ed N (ad es. 8) la rappresentazione di 2N - n - 1 è uguale alla rappresentazione di n con le cifre invertite (11011100) Allora: il complemento di un numero si calcola invertendo tutti i suoi bit e sommando 1

E quindi……….. Per calcolare il complemento a 2 di un numero 1. si rappresenta il numero in binario 2. Si invertono tutte le cifre (1 ->0 e 0 ->1) 3. Si somma 1. 32 = 00100000 - 32 = 11011111 + 1 = 11100000 N.B. Il complemento del complemento di un numero è il numero stesso C (32) = 256 - 32 = 224; (uso 8 bit) C (C (32)) = 256 - (256 -32) = 32

Esempi di rappresentazioni Ad esempio, avendo a disposizione un byte, il numero naturale 35 ha la seguente rappresentazione binaria: 00100011 Il numero –35 in segno e valore assoluto: 10100011 Il numero –35 in complemento a due: rappr. di 35 00100011 scambio 0<->1 11011100 aggiungo 1 11011101

Rappresentazioni a lunghezza fissa: problemi Usare rappresentazioni di lunghezza fissa porta ad avere valori non rappresentabili (solo un certo numero di configurazioni è disponibile). Questo può provocare errori di due tipi: Overflow indica un errore nella rappresentazione di un certo numero (di solito il risultato di una operazione) dovuto al fatto che la quantità di cifre disponibili è minore rispetto a quelle necessarie a rappresentare il numero. Es. i due addendi di una somma possono essere rappresentabili ma il risultato della somma no. Es. (interi senza segno su 8 bit) 130 + 150 =280 Ma con 8 bit rappresento al max. il numero 255. Underflow indica che il risultato è troppo piccolo per essere rappresentato, cioè minore del più piccolo numero rappresentabile. Es. divisione fra interi quando il dividendo è minore del divisore. Il risultato in questo caso è 0. 25/50 = 0.5, ma io posso rappresentare solo 0, 1, …

Esempio 1 (overflow) Con 8 bit posso rappresentare: interi positivi da 0 a 255 interi con segno da -128 a +127 Supponiamo di essere nel primo caso e di avere 11111111 = (255)10 255 + 1 = ? 1111111 11111111+ 00000001 00000000 Ma ho solo 8 bit => il risultato dell’operazione è 0! 1 Bit di overflow 1

Esempio 2 (overflow) Con 8 bit posso rappresentare: interi positivi da 0 a 255 interi con segno da -128 a +127 Supponiamo di essere nel secondo caso e di avere 01111111 = (127)10 127 + 1 = ???? 1111111 01111111+ 00000001 --------- 0 10000000 Ma 10000000 è negativo! (-128) Ultimo riporto (carry) Bit di overflow

Esempio 3 (overflow) Con 8 bit posso rappresentare: interi positivi da 0 a 255 interi con segno da -128 a +127 Supponiamo di essere nel secondo caso e di avere 01111111 = (127)10 127 - 128 = ???? 01111111+ 10000000 --------- 0 11111111 Complemento 11111111 11111111 -> 00000000 00000000+1= 1 Quindi il risultato è -1 (corretto) Ultimo riporto (carry) Bit di overflow

Overflow Se sto rappresentando numeri naturali ho overflow se il bit di overflow è 1 Se sto rappresentando numeri relativi ho overflow se il bit di overflow è diverso dall’ultimo riporto (bit di carry)

Esercizi Verificare che (10000101)2 = (133)10 Data una rappresentazione intera a 8 bit senza segno, rappresentare e calcolare in binario le seguenti operazioni (decimali) : 12 + 78 240 + 17 (che risultato “apparente” ottengo con 8 bit ???) Data una rappresentazione a 8 bit con complemento a 2 determinare il minimo numero rappresentabile determinare il massimo numero rappresentabile rappresentare e calcolare: 125 - 33 125 + (-33) 37 - 125