Algebre booleane e progetto logico dei calcolatori digitali/Algebre booleane

Da testwiki.
Vai alla navigazione Vai alla ricerca

Template:Algebre booleane e progetto logico dei calcolatori digitali

Definizioni assiomatiche

Si chiamera algebra di Boole o algebra Booleana il sistema:

B=<E,(+),() ,0,1,>

dove:

  1. E è un insieme non vuoto che contiene almeno due elementi, e cioè 1 e 0,
  2. (+) e () sono due operazioni binarie definite su E e tali che E sia chiuso rispetto ad esse.
  3. su E è definita una relazione di equivalenza, rappresentata dalla notazione = (e si legge uguale), e come tale soddisfacente,  x, y, zE alle seguenti relazioni:
    1. (x=y)(y=x) simmetria
    2. X=X riflessivata
    3. (x=y)(y=z)(x=z) transitivita

e tale che,  A, B, C, E, risultano soddisfatti i seguenti assiomi:

Assiomi Ai,j
associativita_
A1.1(A+B)+C=A+(B+C)A1.2(AB)C=A(BC)
commutativita_
A2.1A+B=B+AA2.2 AB=BA
distributivita_
A3.1A(B+C)=(AB)+(AC)A3.2 AB=BA
A4.1A+0=0+A  A4.2A1=1A=A

Nei precedenti due capitoli, abbiamo studiato l'algebra dei circuiti, l'algebra delle classi e l'algebra della logica; tutte e tre queste algebre rappresentano esempi di strutture algebriche Booleane. La definizione assiomatica dell'algebra di Boole riassume infatti le regole di calcolo incontrate nello studio delle algebre su menzionate. Per quanto riguarda l'applicazione dell'algebra astratta di Boole, vogliamo fare un breve cenno ad alcuni risultati dell'algebra dei circuiti (più avanti considereremo esempi di applicazione). Partendo dalla constatazione che operazioni quali connettere in serie, connettere in parallelo due o più interruttori elettrici e invertire un interruttore (chiuderlo se esso è aperto, aprirlo se esso è chiuso), soddisfano a tutti gli assiomi Ai,j(i=1,..,5); J=1, 2) si giunge alla conclusione che ogni risultato, ottenuto in sede astratta per le algebre di Boole, può essere tradotto in termini di interruttori, o più in generale, di circuiti.

Relazioni fondamentali in una algebra di Boole

Gli assiomi precedenti ci permettono di dimostrare diversi teoremi. Per semplificare le dimostrazioni si scriverà a destra di ogni identità o equazione, gli assiomi o i teoremi utilizzati.

Si hanno i seguenti teoremi:

T1_ A+A=Ainfatti:
 A+A=(A+A)1      (A4.2)
 =(A+A)(A+A¯)      (A5.1)
 =A+(AA¯)              (A3.2)
 =A+0                      (A5.2)
 =A                           (A4.1)

In maniera più generale si può dimostrare (per ricorrenza per esempio) che:

A+A+A.....+A=A
T2_ AA=Ainfatti:
 AA=(AA)+0      (A4.1)
 AA=(AA)+(AA¯)      (A5.2)
 =A(A+A¯)      (A3.1)
 =A1                      (A5.1)
 =A                           (A4.2)

In maniera analoga si potrà generalizzare il risultato nella maniera seguente:

AAA.....A=A

(T1) e (T2) costituiscono le proprietà di idem potenza; ossia che in un'algebra di Boole non vi sono ne multipli ne potenze.

T3_ A+1=1infatti:
 A+1=(A+1)1      (A4.2)
 =(A+1)(A+A¯)     (A5.1)
 =A+(1A¯)              (A3.2)
 =A+A¯                    (A4.2)
 =1                           (A5.1)
T4_A0=0_infatti:
 A0=(A0)+0        (A4.1)
 =(A0)+(AA¯)        (A5.2)
 =A(0+A¯)               (A3.1)
 =AA¯)                     (A4.1)
 =0                           (A5.2)
T5_A+(AB)=A_  (legge di assorbimento)infatti:
 A+(AB)=(A1)+(AB)          (A4.2)
 A(1+B)                                    (A3.1)
 A1                                             (T3)
 A                                                 (A4.2)
T6_A(A+B)=A_  (legge di assorbimento)infatti:
 A(A+B)=(AA)+(AB)           (3.1)
 A+(AB)                                     (T2)
 A                                                  (T5)
T7_A+(A¯B)=A+B_infatti:
 A+(A¯B)=(A+A¯)(A+B)          (A3.2)
 1(A+B)                                       (A5.1)
 A+B                                             (A4.2)
T8_A(A¯+B)=AB_infatti:
 A(A¯+B))=(AA¯)+(AB)           (A3.1)
 0+(AB)                                       (A5.2)
 AB                                              (A4.1)
T9_Il complemento A¯ di un elemento A e unico_
 barA1=A¯11            (A4.2)

Ragionando per assurdo, si supponga che l'elemento A possieda due componenti A¯1 e A¯2. In virtù dell'assioma (A5)si avranno le relazioni:

{A+A¯1=1AA¯1=0
{A+A¯2=1AA¯2=0

Si ha allora:

 A¯1=A¯11                  (A4.2)
=A¯1(A+A¯2)             (A5.1)
=A¯1A+A¯1A¯2      (A3.1)
=0+A¯1A¯2       (A5.2)
=AA¯2+A¯1A¯2       (A5.2)
=A¯2A+A¯2A¯1       (A2.2)
=A¯2(A+A¯1)       (A3.1)
=A¯21       (A5.1)
=A¯2       (A4.2)

Quindi A_1 e A_2 non possono che essere uguali.

Si chiama complementazione l'operazione che consiste nel far corrispondere l'elemento A¯ ad A.

T10_A¯¯=A     involuzione

Si consideri l'elemento A¯ e si cerchi il suo complemento che verrà scritto A¯¯.

Si avrà:

{A+A¯¯=1A¯A¯¯=0

d'altra parte:

{A+A¯=1AA¯=0

Si ha allora che A¯ e A¯¯ soddisfano alle stesse equazioni e poiché per il teorema T9, il complemento è unico, segue che A¯¯=A

T11_(¯A+B)=A¯B¯     primo teorema di de Morgan

Si cercherà il complemento diA¯B¯ e si dimostrerà che esso è A+B.

Si consideri la quantità (A+B)+(A¯B¯):

(A+B)+(A¯B¯)=[(A+B)+A¯][(A+B)+B¯]

=[A+(B+A¯)][A+(B+B¯)]
=[(A+A¯)+B][A+(B+B¯)]
=(1+B)(A+1)
=11

Analogamente si ha:

(A+B)(A¯B¯)=(A¯B¯)(A+B)

=(A¯B¯)A+(A¯B¯)B
=(A¯A)B¯+A¯(B¯B)
=0B¯+A¯0
=0

Dunque x=A+B e y=A¯B¯ verificano le due equazioni:

{x+y=1xy=0

per cui A+B è il complemento (unico) di A¯B¯: dunque

A+B=(A¯B¯)
(a+B)=(A¯B¯)=A¯B¯
(A+B)=A¯B¯
T12_(¯A+B)=A¯B¯     secondo teorema di de Morgan

Si consideri il secondo membro e se ne prenda il complemento:

(A¯+B¯)=A¯¯B¯¯        (T11)
=AB              (T10)

Si consideri ancora il complemento dei due membri:

(A¯+B¯)=AB
A¯+B¯=AB           (T10)

Espressioni duali - Principio di dualità

Si considerino le coppie degli assiomi Ai.j. Due assiomi di una qualunque di queste coppie si corrispondono nella maniera indicata nella tabella seguente (dove x rappresenta la variabile generica che figura negli assiomi).

Regole di dualizzazione
+   
   +
0   1
1   0
x   x
x   x

Con questo procedimento, da un assioma di una coppia, si deduce l'altro.

Per esempio, a partire da A1.1:

A+(B+C)=(A+B)+C

si può scrivere immediatamente A1.2

A(BC)=(AB)C

Si dice che i due assiomi di una tale coppia sono duali: oppure che le identità che li esprimono sono duali. In generale, si chiameranno espressioni duali due espressioni algebriche che si deducono l'una dall'altra meddiante le regole della tabella precedente.

Esempio di espressioni duali

A+(BC)     A(B+C)
AB¯+A¯B       (A+B¯)(A¯+B)

Il fatto che gli assiomi di un'algebra di Boole si raggruppino in coppie duali costituisce già una particolarità interessante. Ma più interessante è la considerazione che se ne trae sotto la forma detta del principio di dualità. Si consideeri un terorema valido su un'algebra di Boole; per dimostrarlo si deve applicare una successione di operazioni che, in ultima analisi, è una applicazione, in tappe successive, degli assiomi. Se ora si sostituisce ad ognuna di queste operazioni intermedie l'0perazione duale, si otterrà, ovviamente, il risultato duale; si potrà quindi fare a meno di dimostrare il duale di un teorema.
Il principio di dualità si può così enunciare:

A ogni teorema, vero in un'algebra di Boole, corrisponde un teorema duale che è altrettanto vero.

Data una espressione E si indicherà con E l'espressione duale.

Esempi di algebra di Boole

Algebra a due elementi

Si consideri un insieme I a due elementi: siano 0 ed 1; definiamo su questo insieme {0,1} 3 operazioni, date dalla tavola 6.1.

L'insieme {0,1} fornito delle operazioni +,*,neg ha una struttura algebrica Booleana:

B=<0,1,+,*,neg,0,1>

Per giustificare tale asserzione, è sufficiente dimostrare che gli assiomi Ai.j sono soddisfatti.

Cominciamo col verificare gli assiomi A4.1 e A4.2.

In sede di definizione dell'algebra di Boole, si era detto che l'insieme E doveva essere composto da almeno due elementi, e che tali elementi devevano essere 0 e 1; per cui il nostro insieme I soddisfa a questa prima proprietà.

Passiamo a verificare ora la A4.1:

A4.1A+0=0+A=A

cioè, quale che sia l'elemento AE, associato con l'elemento 0E mediante l'operatore (+), il risultato di tale applicazione deve essere ancora A. E questo si verifica puntualmente nel nostro insieme I; verifichiamo l'assioma A4.1 prima con l'elemento 1I e quindi con l'elemento 0I:

A4.11+0=10+0=0

abbiamo cioè riottenuto gli elementi 1 e 0 sfruttando la definizione dell'0perazione (+) (vedi tabella 6.1a).

Analogo discorso si farà per l'assioma A4.2:

A4.2A1=1A=A

usufruendo della tabella 6.1b, che riguarda l'operatore () verifichiamo tale assioma per l'insieme I.

01=011=1

Per quanto riguarda l'assioma A5:

A5.1A+A¯=1A5.2AA¯=0

usufruendo della tabella 6.1, possiamo facilmente verificarlo ponendo A=1, A=0 e viceversa:

A5.1{1+1¯=10+0¯=1A5.2{11¯=000¯=0

Lasciamo come esercizioal lettore la verifica dei restanti assiomi.

Algebra delle classi

Un secondo esempio di algebra di Boole è quello costituito dall'insieme di tutti i sottoinsiemi di un dato insieme M quando per ∪, ∩ e −, si prendano rispettivasmente le ordinarie operazioni di riunione, intersezione e complementazione tra insiemi, e perle costanti 0 e 1 ris\ ettivamente l'insieme vuoto Φ e l'insieme delle parti IM:

BM=<IM,,,¯ ,ϕ,IM>

Per vedere che gli assiomi Ai.j sono verificati è sufficiente considerare le relazioni incontrate nel capitolo.

Giova rilevare che M non è necessariamente finito; se lo è, se contiene cioè n (>2) elementi, l'algebra di Boole BM ne contiene 2n.

Algebra delle proposizioni

Consideriamo un insieme L di proposizioni, fornito delle operazioni ,, tale che se P,QL, si abbia PL,PQL,PQL. In queste condizioni gli assiomi Ai,j prenderanno la forma delle relazioni (L1...L10): l'insieme L delle proposizioni, con le operazioni ,, è un'algebra di Boole:

BL=<L,,,,P,P>

L'algebra delle proposizioni ha l'implicazione reciproca (↔) come relazione di equivalenza.

Algebra dei vettori a n dimensioni

Si consideri l'insieme dei vettori binari a n dimensioni. Un vettore binario (matrice riga) X è un insieme ordinato di variabili (componenti) capaci di assumere uno dei valori:0 e 1:

X=(x1,x2,...,xi...,xn)=(xi)xi0,1(i=1...n)

Questo insieme comprende:

222...2n fattori=2nelementi

Si possono introdurre le operazioni seguenti:

1) Prodotto

Dati due vettori X e Y

X=(x1,x2....,xn)=(xi)
Y=(y1,y2....,yn)=(yi)

si chiama prodotto booleano di X e Y, denotato con XY, il vettore

XY=(x1y1,x2y2....xiyi....xnyn)=(xiyi)

2) Somma

Dati due vettori X e Y definiti come sopra, si chiama somma booleana di X e Y il vettore:

X+Y=(x<1+y1,....xi+yi,....xn+yn)=(xi+yi)

3) Complemento

Dato un vettore X=(x1,..,xi,...,xn) il complemento di X è il vettore:

X=(x1,....xi,....xn)=(xi)

Le operazioni +, ., -, sulle variabili x,y sono quelle definite nell'algebra a due elementi.

4) Vettore nullo

Per definizione esso è un vettore formato unicamente da zeri:

0=(0,0,...,0)(xi=0i=1,...n)

5) Vettore unità

È il vettore formato unicamente da 1:

1=(11,12,...1i,...1)xi=1i=(1....n)

In queste condizioni l'insieme dei vettori binari ad n dimensioni, fornito di queste tre operazioni, è un'algebra di Boole a 2n elementi, con 0 e 1 per elementi costanti:

B=<x,+,,,0,1>

Si può dimostrare l'asserto facendo vedere che gli assiomiA1.1 sono verificati per i vettori si troverà ogni volta che la dimostrazione si riporta alle componenti. Ora, per quest' ultime, gli assiomi sono verificati in quanto si tratta di un'algebra di Boole a due elementi.

Si verifichi per esempio l'assioma A1.1. Si ha:

(X+Y)+Z=X+(Y+Z)

ma ciò equivale a scrivere:

[(xi+yi)+zi=xi+(yi+zi)][i(i=1,2,3...,n)(xi+yi)zi=xi+(yi+zi)]

Per ogni i quest'ultima relazione è vera in quanto abbiamo visto che per le componenti gli assiomi sono verificati (algebra a due elementi).

Per l'equivalenza, discende che anche la proposizione vettoriale è vera.

L'assioma (A1.1) è dunque verificato.

In maniera analoga si dimostrano gli alti assiomi.

Variabili ed espressioni booleane

Variabile booleana: è una variabile i cui valori appartengono ad una algebra di boole. Le lettere che abbiamo usato nelle definizioni degli assiomi e dei teoremi fino ad ora, rappresentano tali variabili. Si dirà anche che l'algebra considerata costituisce il dominio della variabile.

Espressione booleana: si chiamerà espressione booleana, o forma booleana, ogni espressione algebrica formata, a partire dalle variabili e dalle costanti appartenenti ad un'algebra booleana, mediante un numero finito di applicazioni delle operazioni ( +,,¯ ).

Più precisamente si può dire:

  1. 0 e 1 sono espressioni
  2. ogni variabile x è una espressione
  3. se A è una espresssione, anche A¯ lo è
  4. se A e B sono espressioni, anche A+B e A*B lo sono
  5. un'espressione può essere ottenuta applicando le regole1, 2, 3 e 4 un numero finito di volte.

Valore di un'espressione booleana

Funzioni generate da una espressione.

Data una espressione booleana ad n variabili, e sia

G(x1,x2.....xn),

se si sostituiscono le variabili con degli elementi particolari di E, che è l'insieme sostegno, si ottiene come risultato dell'espressione un elemento di E.

Si chiama assegnazione (dei valori alle variabili) ogni combinazione (a1,a2...an) di valori particolari attribuiti alle variabili (x1.x2...xn). L'elemento ottenuto, calcolando la G in corrispondenza dell'assegnazione (a1,a2...an), è il valore dell'espressione a tale assegnazione.

Sia data ad esempio l'espressione:

G(A,B,C)=AB+AC+BC+A¯B¯C¯

il suo valore per la combinazione (1,0,1) (cioè A=1, B=0, C=1) sarà:

G(1,0,1)=10+11+01+010=1

Se si calcolano i valori dell'espressione in corrispondenza a tutte le possibili combinazioni dei valori delle variabili, si definisce una funzione fG(x1...xn) di En in E. Si dirà allora che l'espressione G genera la funzione in questione e, inversamente, che G è un'espressione o una rappresentanza di fG.

Consideriamo ad esempio la funzione Somma di due variabili che, ad ogni coppia di valori, associa la loro somma; l'espressione sarà:

S(A,B)=A+B

avremo:

S80,0)=0S(0,1)=1S(1,0)=1S(1,1)=1

in tal modo abbiamo definito la funzione somma; cioè la corrispondenza che, mediante S(A,B), viene generata tra E2 ed E.

Vi è inoltre da notare che un'espressione definisce un'unica funzione mentre, per una funzione data di En in E, esistono infinite (a causa, ad esempio, della legge di idempotenza) espressioni che la generano. Così nell'algebra

B=<|0,1|,+,,¯,0,1>

le espressioni

AB¯+A¯BAB¯+A¯B+A¯B(A+B¯)(A¯+B)

rappresentano la stessa funzione definita dalla tabella:

A B f(A,B)
0 0 0
0 1 1
1 0 1
1 1 0

Uguaglianza di 2 espressioni booleane

Si dice che 2 espressioni sono uguali (o equivalenti) se esse assumono gli stessi valori per ogni assegnazione di valori delle vasrabili, cioè se esse generano la stessa funzione.

L'uguaglianza di due espressioni G e G' sarà rappresentata dal segno =. Si può verificare che essa è una relazione di equivalenza nel senso usuale.

Forme canoniche. Teorema di Shannon

Come si è detto precedentemente, una funzione booleana può essere rappresentata da infinite espressioni algebriche; tra tutte queste però, ve ne sono due particolari che prendono il nome di forme canoniche: Per giungere alla definizione di tali forme, occorre enunciare il seguente teorema:

Teorema di Shannon per espressioni a una variabile

Ogni espressione booleana di una variabile si può sempre esprimere medfiante una espressione del tipo:

F(x)=F(1)*x+F(0)*x¯(σ)

dove con F(1) e F(0) s'intende la funzione calcolata per i valori 1 e 0 della variabile.

Verifichiamo la validità di tale teorema perle funzioni base:

a) Funzioni costanti: F(x)=A, in tal caso l'espressione è indipendente dal valore della variabile; si ha cioè:

F(x)=F(1)=F(0)=A

per cui applicando gli assiomi visti nel paragrafo 6.1 si può scrivere:

F(x)=A=A1=A(x+x¯)=Ax+ax¯=F(1)x+F(0)x¯.

b) La funzione assume il valore della variabile x: P(x)=x; avremo:

P(1)=1P(0)=0

per cui:

P(x)=x=x+0=x+0x¯=1x+0x¯=P(1)x+P(0)x¯

c) La funzione assume il valore della variabile complimentata: G(x)=x¯ avremo:

G(1)=0G(0)=1

per cui:

G(x)=x¯=0+x¯=0x+x¯=0x+1x¯=G(1)x+G(0)x¯

Tenendo presente che ogni espressione booleana non sarà altro che una combinazione delle tre espressioni a), b), c), si può dimostrare la validità del teorema di Shannon per ogni espressione di una funzione ad una variabile. Per ottenere ciò è sufficiente far vedere che: date due funzioni F(x) e G(x) verificanti la (σ), allora anche il loro prodotto, la loro somma, ed il complemento di una di esse la verificano.

d) Sia H(x)=F(x)*G(x) e quindi H(1)=F(1) G(1) e H(0)=F(0) G(0) applicando la (σ) su F(x) e G(x) otterremo:

H(x)=[F(1)x+G(1)x¯][G(0)x+G(0)x¯]

e) Sia K(x)=F(x)+G(x) quindi

K(1)=F(1)+G(1)eK(0)=F(0)+G(0)

applicando la (σ) su F(x) e G(x) otterremo:

K(x)=[F(1)x+F(0)x¯]+[G(1)x+G(0)x¯]=
[F(1)+G(1)]x+[F(0)+G(0)]x¯=K(1)x+K(0)x¯

f) Sia N(x)=F(x) e quindi

N(1)=F(1)eN(0)=F(0)

applicando la (σ) su F(x) e per il primo e secondo teorema di Morgan avremo:

N(x)=F(1)x+F(0)x¯=
F(1)xF(0)x¯=[F(1)+x¯][F(0)+x¯¯]=
F(1)F(0)+F(0)x¯+F(1)x+x¯x=
[F(1)F(0)]1+F(0)x¯+F(1)x=
[F(1)F(0)](x+x¯)+F(0)x¯+F(1)x=
F(1)F(0)x+F(1)F(0)x¯+F(0)x¯+F(1)x=
[F(1)F(0)+F(1)]x]+[F(1)F(0)+F(0)]x¯=
F(1)x+F(0)x¯=N(1)x+N(0)x¯

Abbiamo così dimostrato che le operazioni, in una espressione di una funzione booleana, conservano la proprietà di Shannon e ciò ci permette sempre di ridurre l'espressione ad una forma lineare ed omogenea nelle variabili x e x¯:

f(x)=Ax+Bx¯(dove A=F(1)eB=F(0))

nella quale compaiono solo due costanti F(1), F(0) facilmente determinabili data l'espressione della funzione.

Teorema di Shannon per espressioni a n variabili

È possibile enunciare il teorema di Shannon anche per espressioni ad n variabili: ma prima di fornire tale enunciato, esponiamo il procedimento con cui si giunge a tale generalizzazione del teorema.

si consideri una espressione a n variabili:

F(x1,x2,....,xn

e si supponga di fissare (cioè considerare costanti) n-1 variabili: l'espressione F è allora una espressione ad una variabile, che gode quindi della proprietà di Shannon e può, di conseguenza, essere espressa nella forma:

F(x1,x2,...,xn)=F(1,x2,x3,...,xn)x1+F(0,x2,x3,...,xn)x1¯

I termini F(1,x2,...,xn)eF(0,x2,...,xn sono, non considerando più x2,...,xn costanti, delle espressioni ad n-1 variabili, nelle quuali noi possiamo di nuovo fissare momentaneamenten n-2 variabili, per esempio le ultime n-2, ed applicare ancora alla variabile x_2 il teorema di Shannon. Da cui:

F(x1,x2,...,xn)=[F(1,1,x3,...,xn)x2+F(1,0,x3,...,xn)x2¯]x1+
[F(0,1,x3,...,xn)x2+F(0,0,x3,...,xn)x2¯]x1¯=
F(1,1,x3,...,xn)x1x2+F(1,0,x3,...,xn)x1x2¯+
+F(0,1,x3,...,xn)x¯1x2+F(0,0,x3,...,xn)x¯1x2¯

Si può continuare ad applicare il teorema di Shannon fino all'esaurimento delle variabili; infine si otterrà la seguente espressione:

F(x1,x2,...,xn)=e=0,0,..,0e=1,1,..,1F(e1,e2,...,en)e1e1e2e2...enen

con la convenzione:

xiei={xi,quandoei=1x¯,quandoei=0

ed e=(e1,e2,...,een) vettore binarioad n dimensioni.

Per scrivere in maniera più compatta, si può pensare di considerare "e" come la rappresentazione binaria di un numero.

Da ciò la notazione abbreviata:

(σ)F(x1,x2,...,xn)=e=0e=2n1F(e)x1e1x2e2...xnen

e ora possiamo enunciare il teorema di Shannon per espressioni a n variabili:

ogni funzione booleana di n variabili, si può sempre esprimere mediante una espressione del tipo (σ).

La forma algebrica del secondo membro di (σ) porta il nome di forma canonica disgiunta, volendo indicare con questa terminologia, cher essa è una somma di prodotti.

In essa compaiono i 2n possibili coefficienti F(e) ed altrettanti monomi della forma:

(α)e1e1x2e2...eiei...xnen

Una espressione booleana a n variabili è quindi conosciuta quando si hanno i 2n coefficienti di F(e).

Un prodotto della forma (α) si chiama prodotto fondamentale.

Espressioni duali

Applicando il principio di dualità si deducono le formule seguenti:

F(x)=[F(1)+x¯][F(0)+x] (teorema di Shannon duale)

da cui:

F(x1,x2,...,xi,...,xn)=e=0,0,..,0e=1,1,..,1[F(e1¯,..,en¯)+x1e1+x2e2+..+xnen]

che prende il nome di forma congiuntiva.

Essa è un prodotto di somme. Le somme della forma:

x1e1+x2e2+...+xiei+...+xnen

sono chiamate somme somme fondamentali.

In maniera più compatta si scriverà:

F(x1,x2,...,xi,...,xn)=e=0e=2n1[F(2n1e)+x1e1+x2e2+..+xnen]

dove 2n1e = complemento ad 1 di e.

Metodo pratico del calcolo di un complemento

Consideriamo l'espressione E(x1,x2,...xn). Per calcolare il complemento non è necessario applicare passo passo i teoremi di De Morgan: è sufficiente sostituire l'espressione E(x1,x2,...xn) con l'espressione E(x1,x2,...xn), ottenuta con le regole seguenti:

Si noterà che questa tabella è differente, nelle ultime righe, da quella che definisce la regola di dualizzazione:

Esempio

F(A,B,C)=AB¯+C¯D¯+A¯B¯+AB+BC

Per definizione si ha:

F(A,B,C)=AB¯+C¯D¯+A¯B¯+AB+BC

Per semplificare tale espressione si può applicare il teorema di De Morgan oppure la regola sopra enunciata; applichiamo entrambe, e confrontiamo l'uguaglianza dei risultati.

Primo metodo

F=AB¯+C¯D¯+A¯BAB+BC=
(AB¯+C¯D¯+A¯B)(ABBC)=
(AB¯+C¯D¯+A¯B)(A¯+B¯)(B¯+C¯)

Secondo metodo

(AB¯+C¯D¯+A¯B)(A¯+B¯)(B¯+C¯)

come si vede questo secondo metodo è molto più rapido.

Riduzione ad un livello di complementazione in una espressione

Data una espressione che comporta più livelli di complementazione sovrapposti, come ad esempio:

F=A¯+B+C+D+E

è sempre possibile ricondurre una tale espressione ad una forma dove le complementazioni appaiono, al massimo, ad un livello.

Che ciò sia sempre possibile è una conseguenza dell'esistenza delle forme canoniche.

Comunque, applicando ripetutamente i teoremi di De Morgan, si può verificare tale affermazione senza dover ricorrere4 alle forme canoniche.

Per l'espressione precedente si avrà:

F=(A¯+B)(C+D)+E=(AB¯)(C+D)E¯}

cioè si è ottenuta una espressione dove gli elementi sono complimentati al massimo una volta.

Tale espressione si potrà sviluppare in somma di prodotti:

F=AB¯CE¯+AB¯DE¯

Relazione tra espressione duale e complemento

Data una espressione di una funzione F(x1,x2,...,xn) le tavole delle regole di dualizzazione e di complementazione permettono di dedurre due espressioni associate alla funzione data:

F(x1,x2,...xn)(duale)
F¯(x1,x2,...,xn)(complemento)

La relazione che lega queste due funzioni è

F(x1,x2,...,xn)=)F¯(x¯1,x¯2,...,x¯n)(β)

i procedimenti per costruire le espressioni F,sim F,\bar F possono essere riassunte nella tabella a fianco.

F è costituita da un numero finito di operazioni +, *, -, a partire dalle variabili e dalle costanti 0 ed 1; e si vede che applicando passo passo la corrispondenza della tabella, la relazione (β) è verificata. Template:Avanzamento