Apostila
de
Teoria
para
Circuitos Digitais
(Versão A2015M12D03)
Universidade Federal Fluminense
Apostila
do
Departamento de Engenharia de Telecomunicações
da
Universidade Federal Fluminense
por
Alexandre Santos de la Vega
Dezembro, 2015.
.
621.3192
mudar!
D278
mudar!
2015
de la Vega, Alexandre Santos
Apostila de Teoria para Circuitos Digitais
/ Alexandre Santos de la Vega.
– Niterói:
UFF/TCE/TET, 2015.
237p. (atualizar...)
Apostila de Teoria – Graduação, Engenharia de
Telecomunicações, UFF/TCE/TET, 2015.
1. Circuitos Digitais. 2. Técnicas Digitais. 3. Telecomunicações. I. Tı́tulo.
Aos meus alunos.
Prefácio
O trabalho em questão cobre os tópicos abordados na disciplina Circuitos Digitais.
A apostila foi escrita com o intuito de servir como uma referência rápida para os alunos do
curso de graduação em Engenharia de Telecomunicações da Universidade Federal Fluminense
(UFF).
O material básico utilizado foram as minhas notas de aula que, por sua vez, originaram-se
em uma coletânea de livros sobre os assuntos abordados.
A motivação principal foi a de aumentar o dinamismo das aulas. Portanto, deve ficar bem
claro que esta apostila não pretende substituir os livros textos ou outros livros de referência.
Muito pelo contrário, ela deve ser utilizada apenas como ponto de partida para estudos mais
aprofundados, utilizando-se a literatura existente.
Espero conseguir manter o presente texto em constante atualização e ampliação.
Correções e sugestões são sempre benvindas.
Rio de Janeiro, 08 de setembro de 2010.
Alexandre Santos de la Vega
UFF/TCE/TET
v
vi
Agradecimentos
Aos alunos do Curso de Engenharia de Telecomunicações e aos professores do Departamento
de Engenharia de Telecomunicações (TET), da Universidade Federal Fluminense (UFF), que
colaboraram com crı́ticas e sugestões bastante úteis à finalização deste trabalho. Em particular,
à professora Carmen Maria Costa de Carvalho pela leitura meticulosa da versão original.
Aos funcionários do TET/UFF, Carmen Lúcia, Jussara, Arlei, Eduardo e Francisco, pelo
apoio constante.
Aos meus alunos, que, além de servirem de motivação principal, obrigam-me sempre a tentar
melhorar, em todos os sentidos.
Mais uma vez, e sempre, aos meus pais, por tudo.
Rio de Janeiro, 08 de setembro de 2010.
Alexandre Santos de la Vega
UFF/TCE/TET
vii
viii
Sumário
Prefácio
v
Agradecimentos
I
vii
Apresentação
1
1 Descrição do documento
1.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.2 Circuitos combinacionais . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
1.3 Circuitos sequenciais . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
3
3
3
4
II
5
Circuitos combinacionais
2 Conceitos básicos
7
3 Funções lógicas
3.1 Introdução . . . . . . . . . . . . . . . . . . . . . .
3.2 Exemplo introdutório (lógica clássica) . . . . . . .
3.3 Conceitos básicos . . . . . . . . . . . . . . . . . .
3.4 Formulação lógica clássica . . . . . . . . . . . . .
3.5 Operadores lógicos . . . . . . . . . . . . . . . . .
3.6 Relações de implicação . . . . . . . . . . . . . . .
3.7 Conjunto funcionalmente completo de operadores
3.8 Teoremas de De Morgan . . . . . . . . . . . . . .
3.9 Decomposição em funções canônicas . . . . . . . .
3.10 Blocos funcionais fundamentais . . . . . . . . . .
3.11 Manipulação algébrica de blocos . . . . . . . . . .
3.12 Uso de operador lógico como elemento de controle
3.13 Exercı́cios propostos . . . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
4 Álgebra de Boole
4.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.2 Postulados de Huntington . . . . . . . . . . . . . . . . . .
4.3 Dualidade . . . . . . . . . . . . . . . . . . . . . . . . . . .
4.4 Lemas e teoremas fundamentais . . . . . . . . . . . . . . .
4.5 Definição de uma estrutura algébrica particular . . . . . .
4.6 Exemplos de associação com a estrutura algébrica de Boole
4.7 Isomorfismo . . . . . . . . . . . . . . . . . . . . . . . . . .
ix
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
11
11
12
13
13
14
15
16
16
17
18
19
22
23
.
.
.
.
.
.
.
25
25
25
26
27
27
28
28
x
4.8
4.9
4.10
4.11
4.12
Simplificação algébrica de expressões lógicas . . . . . . . . . . . . . . . . . . . . 29
Exemplo de manipulação algébrica não sistemática: Postulados, Lemas e Teoremas 29
Exemplo de manipulação algébrica por isomorfismo: Diagrama de Venn . . . . . 32
Resumo das relações algébricas . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
Exercı́cios propostos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
5 Formas padrões para representação de expressões booleanas
5.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.2 Definições . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
5.3 Obtenção de formas SOP e POS padrões . . . . . . . . . . . . .
5.3.1 Complementação da lista de termos canônicos . . . . . .
5.3.2 Manipulação algébrica . . . . . . . . . . . . . . . . . . .
5.3.3 Utilização de tabela verdade . . . . . . . . . . . . . . . .
5.4 Conjuntos de formas padrões . . . . . . . . . . . . . . . . . . . .
5.4.1 Definição . . . . . . . . . . . . . . . . . . . . . . . . . .
5.4.2 Obtenção . . . . . . . . . . . . . . . . . . . . . . . . . .
5.4.3 Utilização . . . . . . . . . . . . . . . . . . . . . . . . . .
5.5 Exercı́cios propostos . . . . . . . . . . . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
37
37
38
39
39
40
42
44
44
44
44
46
6 Simplificação algébrica sistemática de expressões booleanas
6.1 Expressão mı́nima . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.2 Simplificação sistemática de expressões booleanas a partir de SOP e POS padrões
6.2.1 Operações básicas: aglutinação e replicação . . . . . . . . . . . . . . . .
6.2.2 Uso da aglutinação . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.2.3 Uso da replicação . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.3 Eliminação sistemática de literais . . . . . . . . . . . . . . . . . . . . . . . . . .
6.4 Processo sistemático de simplificação . . . . . . . . . . . . . . . . . . . . . . . .
6.5 Implicantes e implicados . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.5.1 Implicantes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.5.2 Implicados . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
6.5.3 Implicantes, implicados e o processo de simplificação . . . . . . . . . . .
6.6 Exercı́cios propostos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
47
47
48
48
48
49
49
52
52
52
53
53
54
7 Mapa de Karnaugh
7.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
7.2 Construção do mapa-K . . . . . . . . . . . . . . . . . . . . . . . .
7.2.1 Funções de 1 variável . . . . . . . . . . . . . . . . . . . . .
7.2.2 Funções de 2 variáveis . . . . . . . . . . . . . . . . . . . .
7.2.3 Funções de 3 variáveis . . . . . . . . . . . . . . . . . . . .
7.2.4 Funções de 4 variáveis . . . . . . . . . . . . . . . . . . . .
7.3 Preenchimento do mapa-K . . . . . . . . . . . . . . . . . . . . . .
7.4 Mapa-K como forma de expressão de função booleana . . . . . . .
7.5 Mapa-K na simplificação de expressões booleanas . . . . . . . . .
7.5.1 Adjacência lógica, aglutinação e replicação . . . . . . . . .
7.5.2 Seleção sistemática de termos (implicantes ou implicados)
7.5.3 Mapa-K de funções com múltiplos mı́nimos e mapa cı́clico
7.5.4 Indeterminações: don’t-care e can’t-happen . . . . . . . . .
7.6 Exercı́cios propostos . . . . . . . . . . . . . . . . . . . . . . . . .
55
55
56
56
57
58
59
60
60
62
62
63
63
64
66
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
xi
8 Sistemas de numeração
8.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.2 Sistema de numeração posicional convencional . . . . . . . .
8.2.1 Representação de números inteiros não negativos . .
8.2.2 Representação de números fracionários não negativos
8.2.3 Representação de números inteiros negativos . . . . .
8.2.4 Representação de números fracionários negativos . . .
8.2.5 Tabelas de operações básicas entre dı́gitos . . . . . .
8.2.6 Adição e subtração em complemento-a-2 . . . . . . .
8.2.7 Funções envolvidas na adição de dı́gitos binários . . .
8.2.8 Escalamento por potência inteira da base . . . . . . .
8.2.9 Conversão entre bases . . . . . . . . . . . . . . . . .
8.2.10 Bases mais comuns em circuitos digitais . . . . . . .
8.3 Quantização . . . . . . . . . . . . . . . . . . . . . . . . . . .
8.4 Exercı́cios propostos . . . . . . . . . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
9 Circuitos combinacionais básicos
9.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.2 Interpretações dos circuitos combinacionais . . . . . . . . . . . . . . .
9.2.1 Exemplos de interpretações . . . . . . . . . . . . . . . . . . .
9.3 Uso de portas lógicas como elementos de controle . . . . . . . . . . .
9.4 Uso de elementos de controle para mascaramento . . . . . . . . . . .
9.5 Gerador de funções lógicas . . . . . . . . . . . . . . . . . . . . . . . .
9.6 Conversor de códigos . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.7 Gerador e detector de paridade . . . . . . . . . . . . . . . . . . . . .
9.8 Multiplexador e demultiplexador . . . . . . . . . . . . . . . . . . . . .
9.9 Codificador e decodificador de endereço . . . . . . . . . . . . . . . . .
9.10 Codificador de prioridade . . . . . . . . . . . . . . . . . . . . . . . . .
9.11 Ordenador binário . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.12 Deslocadores (shifters) . . . . . . . . . . . . . . . . . . . . . . . . . .
9.13 Somadores em binário puro . . . . . . . . . . . . . . . . . . . . . . .
9.13.1 Half-adder (HA) . . . . . . . . . . . . . . . . . . . . . . . . .
9.13.2 Full-adder (FA) . . . . . . . . . . . . . . . . . . . . . . . . . .
9.13.3 Ripple-carry adder (RCA) ou carry propagate adder (CPA) . .
9.13.4 Carry lookahead adder (CLA) . . . . . . . . . . . . . . . . . .
9.14 Subtratores em binário puro . . . . . . . . . . . . . . . . . . . . . . .
9.14.1 Half-subtractor (HS) . . . . . . . . . . . . . . . . . . . . . . .
9.14.2 Full-subtractor (FS) . . . . . . . . . . . . . . . . . . . . . . .
9.14.3 Ripple-borrow subtractor (RBS) ouborrow propagate subtractor
9.15 Incrementador e decrementador em binário puro . . . . . . . . . . . .
9.16 Complementadores . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.16.1 Complementador-a-1 (bitwise implementation) . . . . . . . . .
9.16.2 Complementador-a-2 . . . . . . . . . . . . . . . . . . . . . . .
9.17 Multiplicadores em binário puro . . . . . . . . . . . . . . . . . . . . .
9.17.1 Multiplicador de 1 bit . . . . . . . . . . . . . . . . . . . . . .
9.17.2 Multiplicador de N bits . . . . . . . . . . . . . . . . . . . . . .
9.18 Comparadores . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9.18.1 Comparador numérico de um operando . . . . . . . . . . . . .
9.18.2 Comparador numérico de dois operandos . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
(BPS)
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
. . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
67
67
69
69
70
71
81
83
84
86
88
89
91
93
94
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
97
97
98
98
99
99
99
99
100
100
100
101
101
101
102
102
102
103
103
105
105
105
105
105
106
106
106
107
107
107
107
107
107
xii
III
Circuitos sequenciais
109
10 Circuitos seqüenciais: conceitos básicos
111
10.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
10.2 Estados e variáveis de estado . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
10.3 Tipos de variáveis e sua interações . . . . . . . . . . . . . . . . . . . . . . . . . . 112
10.4 Modelo genérico para circuitos seqüenciais . . . . . . . . . . . . . . . . . . . . . 113
10.5 Classificação de circuitos seqüenciais quanto à dependência do sinal de saı́da . . 114
10.6 Classificação de circuitos seqüenciais quanto ao tipo de controle da mudança de estado115
10.6.1 Circuitos seqüenciais clock-mode ou clocked . . . . . . . . . . . . . . . . 115
10.6.2 Circuitos seqüenciais pulsed . . . . . . . . . . . . . . . . . . . . . . . . . 116
10.6.3 Circuitos seqüenciais level-mode . . . . . . . . . . . . . . . . . . . . . . . 116
11 Elementos básicos de armazenamento
11.1 Introdução . . . . . . . . . . . . . . . . . . . . . .
11.2 Classificação quanto à funcionalidade . . . . . . .
11.3 Relacionamento entre os tipos básicos de flip-flops
11.4 Mapas de excitação dos flip-flops . . . . . . . . .
11.5 Tipos de comportamento das saı́das dos flip-flops
11.6 Excitação × comportamento . . . . . . . . . . . .
11.7 Funcionalidade × excitação × comportamento . .
11.8 Circuitos seqüenciais × tabelas dos flip-flops . . .
11.9 Estruturas estáticas simétricas . . . . . . . . . . .
11.10Exemplos de flip-flops . . . . . . . . . . . . . . .
11.10.1 Flip-flops do tipo unclocked . . . . . . . .
11.10.2 Flip-flops do tipo clocked . . . . . . . . . .
11.11Variações de funcionalidade . . . . . . . . . . . .
11.12Diferenças de nomenclatura . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
119
119
120
121
123
123
124
124
125
127
128
128
131
136
136
12 Circuitos seqüenciais clock-mode
137
12.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
12.2 Controle de circuitos do tipo clock-mode . . . . . . . . . . . . . . . . . . . . . . 138
12.2.1 Caracterı́sticas da estrutura clock-mode . . . . . . . . . . . . . . . . . . . 138
12.2.2 Controle de circuitos do tipo Moore . . . . . . . . . . . . . . . . . . . . . 138
12.2.3 Controle de circuitos do tipo Mealy . . . . . . . . . . . . . . . . . . . . . 139
12.3 Representação dos estados . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140
12.4 Estado inicial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140
12.5 Classificação quanto à capacidade de memorização . . . . . . . . . . . . . . . . . 140
12.6 Análise de circuitos seqüenciais . . . . . . . . . . . . . . . . . . . . . . . . . . . 142
12.6.1 Etapas de análise . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 142
12.6.2 Exemplos de análise . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 142
12.7 Projeto de circuitos seqüenciais . . . . . . . . . . . . . . . . . . . . . . . . . . . 143
12.7.1 Opções de projeto e suas caracterı́sticas . . . . . . . . . . . . . . . . . . . 143
12.7.2 Etapas de projeto de circuitos seqüenciais . . . . . . . . . . . . . . . . . 143
12.7.3 Exemplos de projeto de circuitos seqüenciais . . . . . . . . . . . . . . . . 144
12.8 Minimização de estados . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 146
12.8.1 Conceitos básicos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 146
12.8.2 Eliminação de estados redundantes por simples inspeção . . . . . . . . . 146
12.8.3 Método da partição em classes de estados indistinguı́veis (método de Huffman-Mealy) 148
xiii
12.8.4 Método da tabela de implicação de estados (método
12.9 Atribuição de estados . . . . . . . . . . . . . . . . . . . . .
12.9.1 Considerações iniciais . . . . . . . . . . . . . . . . .
12.9.2 Base teórica para as regras de atribuição de estados
12.9.3 Exemplo de regras simples (Armstrong-Humphrey)
12.9.4 Exemplo de regras mais refinadas . . . . . . . . . .
12.10Efeitos causados por estados extras . . . . . . . . . . . . .
12.10.1 Definição do problema . . . . . . . . . . . . . . . .
12.10.2 Possı́veis soluções . . . . . . . . . . . . . . . . . . .
13 Circuitos seqüenciais pulsed
13.1 Introdução . . . . . . . . . . . . . . . . . .
13.2 Restrições de operação . . . . . . . . . . .
13.3 Classificação quanto aos pulsos de entrada
13.4 Circuitos pulse-mode . . . . . . . . . . . .
13.4.1 Motivação . . . . . . . . . . . . . .
13.4.2 Mudanças nas representações . . .
13.4.3 Exemplos de projeto . . . . . . . .
13.5 Circuitos ripple-clock . . . . . . . . . . . .
13.5.1 Motivação . . . . . . . . . . . . . .
13.5.2 Operação . . . . . . . . . . . . . .
13.5.3 Desvantagens . . . . . . . . . . . .
13.5.4 Técnica de projeto . . . . . . . . .
13.5.5 Exemplo . . . . . . . . . . . . . . .
13.6 Circuitos controlled-clock . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
de Paul-Unger)
. . . . . . . . .
. . . . . . . . .
. . . . . . . . .
. . . . . . . . .
. . . . . . . . .
. . . . . . . . .
. . . . . . . . .
. . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
151
153
153
154
160
161
161
161
162
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
163
163
164
165
166
166
166
168
169
169
169
169
169
170
170
.
.
.
.
.
.
.
.
.
.
.
.
173
173
174
175
175
176
176
176
177
177
179
182
183
.
.
.
.
.
.
.
.
.
.
.
.
.
.
14 Circuitos seqüenciais level-mode
14.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
14.2 Problemas comuns em circuitos level-mode . . . . . . . . . . .
14.3 Exemplo de análise de circuito level-mode . . . . . . . . . . .
14.4 Exemplo de projeto de circuito level-mode . . . . . . . . . . .
14.5 Problemas causados pela realimentação contı́nua . . . . . . . .
14.5.1 Problemas causados pelo bloco de lógica combinacional
14.5.2 Problema natural dos circuitos level-mode . . . . . . .
14.6 Solução para as corridas: atribuição de estados . . . . . . . . .
14.6.1 Definição do problema . . . . . . . . . . . . . . . . . .
14.6.2 Possı́veis soluções . . . . . . . . . . . . . . . . . . . . .
14.7 Solução para os perigos . . . . . . . . . . . . . . . . . . . . . .
14.8 Valores das saı́das em estados instáveis . . . . . . . . . . . . .
IV
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
Apêndices
A Noções básicas sobre implementação de funções lógicas
A.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . .
A.2 Famı́lias lógicas . . . . . . . . . . . . . . . . . . . . . . . .
A.3 Elementos básicos . . . . . . . . . . . . . . . . . . . . . . .
A.4 Modelo de chaves . . . . . . . . . . . . . . . . . . . . . . .
A.4.1 Conceitos básicos . . . . . . . . . . . . . . . . . . .
185
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
187
187
187
188
189
189
xiv
A.4.2
A.4.3
A.4.4
A.4.5
A.4.6
A.4.7
Arranjos série e paralelo de chaves . . . . .
Modelo de chaves para a função NOT . . . .
Modelo de chaves para a função NAND . . .
Modelo de chaves para a função NOR . . . .
Modelo de chaves para arranjos AOI e OAI .
Modelo de chaves complementar genérico . .
B Tópicos sobre divisão de números inteiros
B.1 Algoritmo de divisão inteira . . . . . . . .
B.2 Quociente . . . . . . . . . . . . . . . . . .
B.3 Resto ou resı́duo . . . . . . . . . . . . . .
B.4 Congruência . . . . . . . . . . . . . . . . .
B.5 Relações úteis . . . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
190
192
193
195
197
200
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
203
203
203
203
203
204
C Minimização de tabela de estados
C.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
C.2 Tabelas de estados completamente especificadas . . . . . . . . . . . .
C.2.1 Relações de equivalência . . . . . . . . . . . . . . . . . . . . .
C.2.2 Estados e circuitos equivalentes . . . . . . . . . . . . . . . . .
C.2.3 Determinação de classes de estados indistinguı́veis . . . . . . .
C.2.4 Circuito de classes de equivalência . . . . . . . . . . . . . . . .
C.3 Tabelas de estados não completamente especificadas . . . . . . . . . .
C.3.1 Introdução . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
C.3.2 Noções básicas de compatibilidade . . . . . . . . . . . . . . .
C.3.3 Formalização dos conceitos de compatibilidade e de cobertura
C.3.4 Sistematização do processo de minimização . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
205
205
206
206
206
207
207
208
208
208
209
210
D Introdução à linguagem VHDL
D.1 Introdução . . . . . . . . . . .
D.2 Nı́veis de abstração . . . . . .
D.3 VHDL como linguagem . . . .
D.3.1 Palavras reservadas . .
D.3.2 Elementos sintáticos .
D.3.3 Bibliotecas e pacotes .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
211
211
212
212
212
212
215
Bibliografia
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
217
Lista de Tabelas
3.1
3.2
3.3
3.4
3.5
3.6
3.7
Tabela de funções de uma variável. . . . . . . . . . . . . . . . . . . . . . .
Tabela de operadores de 1 variável. . . . . . . . . . . . . . . . . . . . . . .
Tabela de funções de duas variáveis. . . . . . . . . . . . . . . . . . . . . . .
Tabela de operadores de duas variáveis. . . . . . . . . . . . . . . . . . . . .
Tabela de funções canônicas (mintermos e maxtermos) para duas variáveis.
Exemplo de decomposição em funções canônicas (mintermos e maxtermos).
Uso de operador lógico como elemento de controle. . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
. .
.
.
.
.
.
.
.
14
14
14
15
17
17
22
4.1
4.2
4.3
4.4
4.5
4.6
4.7
Tabela de mapeamento: Cálculo Proposicional × Álgebra de Boole. . . . .
Tabela de mapeamento: Teoria de Conjuntos × Álgebra de Boole. . . . . .
Resumo dos postulados de Huntington para a estrutura algébrica de Boole.
Resumo dos lemas para a estrutura algébrica de Boole. . . . . . . . . . . .
Resumo dos teoremas para a estrutura algébrica de Boole. . . . . . . . . .
Resumo da definição de uma estrutura algébrica de Boole particular. . . .
Resumo das relações de isomorfismo. . . . . . . . . . . . . . . . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
28
28
33
33
34
34
34
5.1
5.2
5.3
5.4
5.5
5.6
5.7
Definição de mintermos para três variáveis (A,B,C). . .
Definição de maxtermos para três variáveis (A,B,C). . .
Exemplo de função e associação de mintermos. . . . . .
Exemplo de função e definição de maxtermos. . . . . .
Exemplo da obtenção do grupo AND-OR para a função
Exemplo da mudança de grupo para a função XOR. . .
Exemplo da obtenção do grupo OR-AND para a função
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
39
39
42
43
45
45
45
6.1
Tabela verdade para funções de 3 variáveis. . . . . . . . . . . . . . . . . . . . . .
50
7.1
7.2
7.3
7.4
7.5
7.6
Tabela
Tabela
Tabela
Tabela
Tabela
Tabela
56
57
58
59
61
64
8.1
8.2
8.3
8.4
8.5
8.6
8.7
8.8
Tabela de sinal-e-magnitude, para número inteiros, b = 2 e N = 4. . . . . . . . . 76
Tabela de complemento-a-1, para número inteiros, b = 2 e N = 4. . . . . . . . . 78
Tabela de complemento-a-2, para número inteiros, b = 2 e N = 4. . . . . . . . . 80
Tabela de sinal-e-magnitude, para números puramente fracionários, b = 2 e N = 4. 81
Tabela de complemento-a-1, para números puramente fracionários, b = 2 e N = 4. 82
Tabela de complemento-a-2, para números puramente fracionários, b = 2 e N = 4. 82
Forma 1 para representar a detecção de overflow na adição em complemento-a-2. 85
Forma 2 para representar a detecção de overflow na adição em complemento-a-2. 85
verdade
verdade
verdade
verdade
verdade
verdade
. . . .
. . . .
. . . .
. . . .
XOR.
. . . .
XOR.
para funções de 1 variável. . . . . . . . .
para funções de 2 variáveis. . . . . . . . .
para funções de 3 variáveis. . . . . . . . .
para funções de 4 variáveis. . . . . . . . .
relativa à Equação (7.1). . . . . . . . . .
de função incompletamente especificada.
xv
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
xvi
10.1 Tipos de interações entre sinais dos tipos nı́vel e pulso. . . . . . . . . . . . . . . 112
11.1
11.2
11.3
11.4
11.5
11.6
Transformações envolvendo flip-flops dos tipos JK, D, T1 e T2 . . . . . . . . . . 122
Definição dos tipos de comportamento apresentados pela saı́da de um flip-flop. . 123
Tabela resumo de funcionalidade-excitação-comportamento para os flip-flops SR, JK, D e T2 .124
Tabela de mudanças de estado e de comportamento dos elementos de memória para um contador b
Operação das estruturas de armazenamento estáticas e simétricas controladas por meio de portas l
Diferentes nomenclaturas para flip-flops. . . . . . . . . . . . . . . . . . . . . . . 136
12.1 Número de atribuições de estados efetivamente diferentes. . . . . . . . . . . . . . 153
14.1
14.2
14.3
14.4
14.5
Atribuição
Atribuição
Atribuição
Atribuição
Atribuição
de
de
de
de
de
estados
estados
estados
estados
estados
universal, usando shared-row, para tabelas de 3 estados. . 180
universal, usando multiple-row, para tabelas de 4 estados. 181
universal, usando shared-row, para tabelas de 5 a 8 estados.181
universal, usando shared-row, para tabelas de 9 a 12 estados.181
padrão, usando shared-row, para tabelas de 5 estados. . . 181
A.1 Tipos básicos de associação entre valores de tensão e valores lógicos binários. . .
A.2 Comportamento elétrico do modelo de chaves NOT. . . . . . . . . . . . . . . . .
A.3 Comportamento lógico do modelo de chaves NOT. . . . . . . . . . . . . . . . . .
A.4 Comportamento elétrico do modelo de chaves NAND. . . . . . . . . . . . . . . .
A.5 Comportamento lógico do modelo de chaves NAND. . . . . . . . . . . . . . . . .
A.6 Comportamento elétrico do modelo de chaves NOR. . . . . . . . . . . . . . . . .
A.7 Comportamento lógico do modelo de chaves NOR. . . . . . . . . . . . . . . . . .
A.8 Comparação do comportamento dos blocos de chaves N e P no modelo de chaves
A.9 Comparação do comportamento dos blocos de chaves N e P no modelo de chaves
A.10 Comparação do comportamento dos blocos de chaves N e P no modelo de chaves
188
192
192
193
194
195
196
da função lógica
da função lógica
da função lógica
Lista de Figuras
3.1
3.2
3.3
3.4
Blocos funcionais fundamentais, associados aos operadores lógicos. . .
Manipulação algébrica de blocos: exemplo 1. . . . . . . . . . . . . . . .
Manipulação algébrica de blocos: exemplo 2. . . . . . . . . . . . . . . .
Uso de operador lógico como elemento de controle: simbologia genérica.
4.1
Mapeamento entre uma função genérica de duas variáveis e um Diagrama de Venn. 32
6.1
6.2
6.3
6.4
Eliminações
Eliminações
Eliminações
Eliminações
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
50
50
51
51
7.1
7.2
7.3
7.4
7.5
7.6
7.7
7.8
7.9
7.10
7.11
7.12
Exemplos de mapas de Karnaugh para funções de 1 variável. .
Exemplos de mapas de Karnaugh para funções de 2 variáveis.
Exemplos de mapas de Karnaugh para funções de 3 variáveis.
Exemplos de mapas de Karnaugh para funções de 4 variáveis.
Mapa de Karnaugh relativo à Equação (7.1). . . . . . . . . . .
Mapa de Karnaugh relativo à Equação (7.6). . . . . . . . . . .
Mapa de Karnaugh relativo à Equação (7.7). . . . . . . . . . .
Mapa de Karnaugh com múltiplas formas mı́nimas. . . . . . .
Mapa de Karnaugh com ciclo. . . . . . . . . . . . . . . . . . .
Mapa de Karnaugh da Tabela 7.6. . . . . . . . . . . . . . . . .
Mapa de Karnaugh dos mintermos da Tabela 7.6. . . . . . . .
Mapa de Karnaugh dos maxtermos da Tabela 7.6. . . . . . . .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
56
57
58
60
61
62
62
64
64
65
65
65
8.1
8.2
8.3
8.4
8.5
8.6
8.7
8.8
8.9
8.10
8.11
8.12
8.13
8.14
8.15
8.16
Representação de quantidades q < b, para b = 3. . . . . . . . . . . . . . . . . . . 69
Representação de quantidades q ≥ b, para b = 3, com ambigüidade. . . . . . . . 69
Representação de quantidades q ≥ b, para b = 3, com eliminação da ambigüidade através da ju
Uso repetido da técnica de justaposição de dı́gitos para representação de quantidades q ≥ b, pa
Mapeamento decimal-binário para números não negativos e N = 4, sem sinal. . . 73
Mapeamento decimal-binário para números não negativos e N = 4, com sinal. . 73
Mapeamento decimal-binário para números negativos e N = 4, com codificação Sinal-e-Magnit
Mapeamento decimal-binário para números negativos e N = 4, com codificação ComplementoMapeamento decimal-binário para números negativos e N = 4, com codificação ComplementoComparação dos mapeamentos decimal-binário para números negativos e N = 4. 75
Tabelas de operações entre dı́gitos para b = 2: (a) adição e (b) multiplicação. . . 83
Tabelas de operações entre dı́gitos para b = 3: (a) adição e (b) multiplicação. . . 83
Tabelas de operações entre dı́gitos para b = 4: (a) adição e (b) multiplicação. . . 83
Tabelas que definem a adição entre dois dı́gitos binários (A e B): (a) adição completa, (b) “va
Tabelas que definem a adição entre três dı́gitos binários (A, B e Ci): (a) adição completa, (b)
Tabelas que definem três funções úteis na implementação de somadores binários com algoritmo
de
de
de
de
1
2
1
2
literal em combinações de 2 mintermos. .
literais em combinações 4 de mintermos.
literal em combinações de 2 maxtermos. .
literais em combinações 4 de maxtermos.
xvii
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
18
20
21
22
xviii
10.1
10.2
10.3
10.4
10.5
10.6
Modelo genérico para circuitos seqüenciais. . . . . . . .
Exemplo de máquina de Mealy. . . . . . . . . . . . . .
Exemplo de máquina de Moore. . . . . . . . . . . . . .
Modelo genérico para circuitos seqüenciais clock-mode.
Modelo genérico para circuitos seqüenciais pulsed. . . .
Modelo genérico para circuitos seqüenciais level-mode. .
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
113
114
115
116
117
117
11.1 Tabelas de operação básica para os flip-flops SR, JK, D e T2 . . . . . . . . . . . . 121
11.2 Mapas de excitação para os flip-flops SR, JK, D e T2 . . . . . . . . . . . . . . . . 123
11.3 Tipos de comportamento e respectivas excitações para os flip-flops SR, JK, D e T2 .124
11.4 Mapas-K de transição para os elementos de memória de um contador binário, crescente, de três bit
11.5 Mapas-K de excitação para os flip-flops JK de um contador binário, crescente, de três bits.126
11.6 Estrutura de armazenamento estática e simétrica, não controlável. . . . . . . . . 127
11.7 Estruturas de armazenamento estáticas e simétricas, controláveis por chaves. . . 128
11.8 Uso de portas lógicas NOR na implementação de controle em uma estrutura de armazenamento est
11.9 Uso de portas lógicas NAND na implementação de controle em uma estrutura de armazenamento e
11.10Exemplo de implementação de flip-flop SR do tipo clocked elementar, usando portas lógicas NOR.1
11.11Exemplo de implementação de flip-flop SR do tipo clocked elementar, usando portas lógicas NAND
11.12Exemplo de implementação de flip-flop D do tipo clocked elementar, com base em um flip-flop SR.
11.13Técnica de pipelining: (a) Bloco funcional original e (b) Bloco com pipelining. . 133
11.14Exemplo de implementação de flip-flop D do tipo master-slave, com base em flip-flops SR.133
11.15Exemplo de implementação de flip-flop JK, a partir de flip-flop SR unclocked, com problema de osc
11.16Exemplo de implementação de flip-flop JK, a partir de flip-flop SR clocked, com problema de oscila
11.17Exemplo de implementação de flip-flop JK, a partir de flip-flop SR clocked, sem problema de oscila
11.18Exemplo 1 de implementação de flip-flop JK do tipo master-slave. . . . . . . . . 135
11.19Exemplo 2 de implementação de flip-flop JK do tipo master-slave. . . . . . . . . 135
12.1 Modelo genérico para circuitos seqüenciais clock-mode. . . . . . . . . . . . . . . 137
12.2 Modelo genérico para circuitos com memória finita. . . . . . . . . . . . . . . . . 141
12.3 Modelo genérico para circuitos com memória de entrada finita. . . . . . . . . . . 141
12.4 Modelo genérico para circuitos com memória de saı́da finita. . . . . . . . . . . . 142
12.5 Fluxos de projeto para circuitos seqüenciais clock-mode: (a) Fluxo genérico, (b) Caso particular de
12.6 Eliminação de estados redundantes através da inspeção da tabela de estados. . . 147
12.7 Exemplo de minimização positiva em um passo. . . . . . . . . . . . . . . . . . . 149
12.8 Exemplo de minimização negativa em um passo. . . . . . . . . . . . . . . . . . . 149
12.9 Exemplo de minimização positiva em mais de um passo. . . . . . . . . . . . . . 150
12.10Tabela de implicação genérica do método de Paul-Unger. . . . . . . . . . . . . . 152
12.11Célula genérica da tabela do método de Paul-Unger. . . . . . . . . . . . . . . . . 152
12.12Análise de minimização para as equações de excitação e de saı́da: mapa de Karnaugh simbólico.155
12.13Análise de minimização para as equações de excitação e de saı́da: tabela de atribuição de estados h
12.14Análise de minimização para as equações de excitação: casos de estados atuais com mesmo próxim
12.15Análise de minimização para as equações de excitação: casos de estado atual com próximos estados
12.16Análise de minimização para as equações de saı́da. . . . . . . . . . . . . . . . . . 159
12.17Ilustração das regras de Armstrong-Humphrey. . . . . . . . . . . . . . . . . . . . 160
13.1
13.2
13.3
13.4
13.5
Modelo genérico para circuitos seqüenciais pulsed. . . . . . . . . . . . . . . . . . 163
Equivalência de notações para mapa de Karnaugh utilizado na sı́ntese de variáveis pulsadas.167
Tabelas de estados para circuitos pulse-mode Mealy e Moore. . . . . . . . . . . . 167
Mapas de Karnaugh para sı́ntese de variáveis pulsadas, considerando-se duas entradas pulsadas: (a
Mapas de Karnaugh para sı́ntese de variáveis pulsadas, considerando-se três entradas pulsadas: (a)
xix
13.6 Exemplo 1 de controle de sinal de clock. . . . . . . . . . . . . . . . . . . . . . . 170
13.7 Exemplo 2 de controle de sinal de clock. . . . . . . . . . . . . . . . . . . . . . . 170
13.8 Modelo genérico para circuitos seqüenciais controlled-clock. . . . . . . . . . . . . 172
14.1 Modelo genérico para circuitos seqüenciais level-mode. . . . . . . . . . . . . . . . 173
14.2 Padrões de identificação de perigo essencial em tabelas de fluxo. . . . . . . . . . 177
14.3 Quadro resumo das mudanças de estado nos circuitos seqüenciais level-mode, operando em mo
A.1
A.2
A.3
A.4
A.5
A.6
A.7
A.8
A.9
Chaves simples ou Single-Pole Single-Throw (SPST). (a) Chave-N. (b) Chave-P. 189
Relação de complementariedade entre as chaves N e P. . . . . . . . . . . . . . . 190
Arranjo série de chaves simples. (a) Chave-N. (b) Chave-P. . . . . . . . . . . . 190
Arranjo paralelo de chaves simples. (a) Chave-N. (b) Chave-P. . . . . . . . . . 191
Modelo de chaves para uma implementação da função lógica NOT. . . . . . . . 192
Modelo de chaves para uma implementação da função lógica NAND. . . . . . . . 193
Modelo de chaves para uma implementação da função lógica NOR. . . . . . . . 195
Modelo de chaves para uma implementação do arranjo AOI f (A, B, C, D) = ¬( (A ∧ B) ∨ (
Modelo de chaves para uma implementação do arranjo OAI f (A, B, C, D) = ¬( (A ∨ B) ∧ (
D.1 Palavras reservadas de VHDL. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 213
D.2 Sı́mbolos especiais de VHDL. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 214
xx
Parte I
Apresentação
1
Capı́tulo 1
Descrição do documento
1.1
Introdução
• Este é um documento em constante atualização.
• Ele consta de tópicos desenvolvidos em sala de aula.
• Na preparação das aulas são utilizados os seguintes livros:
– Livros indicados pela ementa da disciplina: [IC08], [Tau82].
– Livros indicados pelo professor: [HP81], [Rhy73], [TWM07], [Uye02].
• Este documento aborda os seguintes assuntos:
– Circuitos combinacionais.
– Circuitos sequenciais.
1.2
Circuitos combinacionais
• Conceitos básicos: que busca contextualizar a disciplina no âmbito do curso de graduação.
• Funções lógicas: que define as bases para a representação de informações não numéricas
em circuitos digitais tradicionais.
• Álgebra de Boole: que apresenta um formalismo matemático para a estrutura algébrica
da lógica empregada em circuitos digitais tradicionais.
• Formas padrões para representação de expressões booleanas: que define formas de expressões booleanas adequadas ao processo de simplifição das mesmas.
• Simplificação algébrica de expressões booleanas: que ilustra um processo algébrico para
a simplificação de expressões booleanas.
• Mapa de Karnaugh: que apresenta uma ferramenta sistemática para a simplificação de
expressões booleanas.
• Sistemas de numeração: que define as bases para a representação de quantidades numéricas em circuitos digitais.
• Circuitos combinacionais básicos: que apresenta os blocos funcionais combinacionais básicos utilizados em sistemas digitais.
3
4
Capı́tulo 1. Descrição do documento
1.3
Circuitos sequenciais
• Conceitos básicos: busca contextualizar a disciplina no âmbito do curso de graduação e
apresentar os conceitos que serão necessários ao longo do texto.
• Elementos básicos de armazenamento: apresenta os elementos de armazenamento utilizados nos circuitos seqüenciais abordados neste texto.
• Circuitos seqüenciais do tipo clock-mode: define as caracterı́sticas dessa classe de circuitos
e aborda os procedimentos, as técnicas e as ferramentas de análise e de projeto para
circuitos da classe.
• Circuitos seqüenciais do tipo pulsed : define as caracterı́sticas dessa classe de circuitos
e aborda os procedimentos, as técnicas e as ferramentas de análise e de projeto para
circuitos da classe.
• Circuitos seqüenciais do tipo level-mode: define as caracterı́sticas dessa classe de circuitos
e aborda os procedimentos, as técnicas e as ferramentas de análise e de projeto para
circuitos da classe.
• Minimização de tabelas de estados: define o problema e apresenta técnicas de minimização
para tabelas de estados.
• Introdução à linguagem VHDL: trata de aspectos básicos da linguagem.
A.S.V.
Parte II
Circuitos combinacionais
5
Capı́tulo 2
Conceitos básicos
• Telecomunicações: definição e exemplos.
• Sistemas de Telecomunicações: definição, anatomia e exemplos.
• Relação: Circuito X Sistema.
• Sinais: definição.
• Sistemas: definição, anatomia (variáveis, elementos e topologia), análise × projeto.
• Classificação de sistemas:
– parâmetros concentrados × distribuı́dos.
– parâmetros constantes no tempo, fixo ou invariante no tempo ×
parâmetros variáveis no tempo, variável ou variante no tempo.
– linear × não linear.
– instantâneo ou sem memória × dinâmico ou com memória.
– contı́nuo × discreto (analógico/amostrado/quantizado/digital).
• Sistemas dinâmicos: estado e variáveis de estado.
• Medição e armazenamento: discretização.
• Discretização: amostragem × quantização.
• Tipos de discretização: uniforme × não uniforme.
• Tipos de aproximação na quantização: truncamento, arredondamento e truncamento em
magnitude.
• Anatomia de sistemas digitais:
– processamento digital dos sinais: digitais × analógicos.
– processamento digital dos sinais digitais: sinais de dados, sinais de temporização,
sinais de controle e alimentação.
– processamento digital dos sinais analógicos: conversores A/D e D/A, filtro limitador
de banda (anti-aliasing filter) e filtro de interpolação (smoothing filter).
• Hierarquia: em hardware e em software.
7
8
Capı́tulo 2. Conceitos básicos
• Codificação:
– Código: sintaxe (sı́mbolos) × semântica (significado).
– No caso geral: representação de idéias.
– No caso de transmissão digital: fonte (compressão) e canal (redução de taxa de erro).
• Elementos codificados:
– Informação (fatos, classificações) × Quantidade (números, contagem).
– Informação pode ser codificada em quantidade.
– Quantidade pode ser codificada como informação.
– Ambos podem ser representados e manipulados como um único elemento.
– Ambos são um único elemento.
– Ambos significam idéias codificadas.
• Representação de informação:
– Uma vez que a informação é multivalorada, pode-se utilizar, para representá-la,
um único dispositivo com múltiplos estados ou vários dispositivos com um número
reduzido de estados.
– O número total de estados, ou de condições às quais os dispositivos podem ser
ajustados, deve ser igual ou maior ao número de valores possı́veis que a informação
a ser representada pode assumir.
– Na tentativa de minimizar o número de dispositivos e o número de diferentes estados
em cada dispositivo, já foi demonstrado que o número de estados ótimo para cada
dispositivo é o número e = 2.718281828459 [Ric56].
– Embora a melhor aproximação seja um total de 3 estados por dispositivo, a disponibilidade de dispositivos eletro-eletrônicos que apresentam 2 estados de operação
(chaves, relés, diodos, transistores), aliada à facilidade e à confiabilidade (estabilidade e robustez) de implementação, têm levado à escolha da representação através
de mecanismos envolvendo 2 estados por dispositivo.
– Assim, para informações envolvendo N estados, são necessários M dispositivos de 2
estados, tal que 2M ≥ N.
• Representação de quantidade:
– Representação numérica (quantizada) de uma informação analógica ou discreta.
– Representação de informação analógica: amostragem e quantização.
– Representação de informação discreta: quantização.
– Fontes de erro:
∗
∗
∗
∗
∗
Acurácia da medida.
Resolução da medida (precisão).
Limites da representação da medida (máximo e mı́nimo).
Erros de conversão A/D.
Capacidade de armazenamento da amostra.
A.S.V.
9
– Quantidades são naturalmente multivaloradas e representadas por sı́mbolos.
– Novamente, dois extremos são possı́veis. Por um lado, pode-se usar um único sı́mbolo
variável, cujas variações representam todos os valores numéricos desejados. De outra
forma, pode-se optar por uma combinação de sı́mbolos de um conjunto, o qual é capaz
de representar apenas uma faixa de valores.
– Exemplos de representação numérica:
∗ Um sistema de numeração com 4 dı́gitos e resolução de 0.001 pode representar
números positivos de 0.000 até 9.999, num total de 10.000 valores diferentes.
∗ Para representar 100 valores diferentes, pode-se utilizar 100 sı́mbolos fixos diferentes ou X sı́mbolos variáveis, com Y valores cada.
• Um sistema de numeração significa, para a representação de quantidades numéricas, o
mesmo que sı́mbolos lógicos significam para a representação de informações não numéricas.
• Utilizando-se uma simbologia que atenda a ambas as representações, pode-se implementar sistemas que manipulem quantidades numéricas e informações não numéricas sem
distinção.
• Tais sistemas, e seus circuitos, são denominados sistemas e circuitos digitais.
TET / UFF
10
Capı́tulo 2. Conceitos básicos
A.S.V.
Capı́tulo 3
Funções lógicas
3.1
Introdução
• A manipulação de informações pode ser dividida em três partes básicas: a obtenção dos
dados, o processamento desses dados e a geração de novos dados.
• Toda ação envolve, de certa forma, tomadas de decisão.
• Compreender o raciocı́nio humano que rege as tomadas de decisão possibilita que o mecanismo seja implantado em sistemas artificiais.
• A lógica pode ser vista como um ramo de estudos da matemática que fornece elementos
para a tentativa de modelagem do raciocı́nio humano.
• A lógica formal fornece uma linguagem estruturada para a definição e a manipulação de
argumentos.
• Argumentos são conjuntos de enunciados, dos quais um deles é definido como conclusão
e os demais como premissas.
• Quanto à validade, os argumentos podem ser divididos em: dedutivos e indutivos.
• Em um argumento dedutivo, premissas verdadeiras conduzem a uma conclusão verdadeira.
• Nos argumentos indutivos, premissas verdadeiras não garantem uma conclusão verdadeira.
• A lógica dedutiva pode ser dividida em: clássica, complementar, e não-clássica.
• Atualmente, a lógica clássica é mais conhecida como Cálculo de Predicados de Primeira
Ordem.
• Exemplos de lógica complementar são: modal, deôntica e epistêmica.
• Alterando-se os princı́pios da lógica clássica, surgem as lógicas não-clássicas. Alguns
exemplos são: paracompletas, intuicionistas, não-aléticas, não-reflexivas, probabilı́sticas,
polivalentes, fuzzy.
11
12
Capı́tulo 3. Funções lógicas
3.2
Exemplo introdutório (lógica clássica)
• Motivações:
– Modelagem de um sistema automático de tomada de decisão.
– Verificação do uso de cinto de segurança em um automóvel.
• Objetivo: O sonorizador deverá emitir um sinal de alarme se, e somente se, a ignição for
acionada e a marcha for engatada, uma vez que os assentos frontais estejam ocupados e
os respectivos cintos de segurança não estejam engatados.
• Infraestrutura existente:
– Sensor de ignição.
– Sensor de engate de marcha.
– Sensor de presença em assentos dianteiros.
– Sensor de engate de cintos de segurança dianteiros.
– Atuador de sonorizador de alarme.
• Valores condicionais (mutuamente excludentes): F (False) e T (True).
• Declarações condicionais básicas (sentenças declarativas) e variáveis associadas:
– Alarme deve soar: A.
– Ignição está acionada: I.
– Marcha está engatada: M.
– Banco do motorista está ocupado: BM .
– Cinto do motorista está engatado: CM .
– Banco do carona está ocupado: BC .
– Cinto do carona está engatado: CC .
• Declarações derivadas
– Negação
∗ Função: NOT (¬).
∗ Exemplo: Banco não está ocupado (¬B).
– Composição (ou conexão ou combinação)
∗ Conjunção:
· Função: OR (∨).
· Exemplo: Banco do motorista OR banco do carona (BM ∨ BC ).
∗ Disjunção:
· Função: AND (∧).
· Exemplo: Ignição AND Marcha (I ∧ M).
∗ Equivalência:
· Função: XNOR (≡).
· Exemplo: Alarme XNOR “Modelo proposto” (A ≡ MP ).
• Proposta de modelo: A ≡ I ∧ {M ∧ [(BM ∧ ¬CM ) ∨ (BC ∧ ¬CC )]}.
A.S.V.
3.3. Conceitos básicos
3.3
13
Conceitos básicos
• Elementos utilizados em uma formulação funcional: valores fixos, variáveis e funções.
• Os valores fixos representam os estados definidos na formulação e são descritos por uma
simbologia adequada.
• As variáveis carregam informação. A codificação da informação depende do significado
que lhes é atribuı́do e dos estados que elas venham a assumir.
• As funções realizam um mapeamento entre variáveis. De uma forma geral, os estados
correntes de determinadas variáveis são utilizados para especificar um estado que será
atribuı́do a uma determinada variável.
• As funções são comumente descritas por: tabelas (pequena quantidade de pontos), gráficos
(grande quantidade de pontos) e equações (lei de formação explı́cita).
• Deve ser ressaltado que os valores fixos, as variáveis e as funções, podem ser associados a
qualquer tipo de informação, não necessariamente representando quantidades.
3.4
Formulação lógica clássica
• Nesse texto, será abordado apenas um tipo de lógica: binária, bivalente ou clássica.
• Os argumentos serão representados por proposições.
• Uma proposição é uma sentença afirmativa declarativa (ou uma afirmação declarativa
ou uma assertiva ou um statement), sobre a qual faz sentido se afirmar que a mesma é
verdadeira ou falsa.
• Variáveis e valores fixos na lógica binária:
– As variáveis representam assertivas (ou proposições ou argumentos).
– Só existem dois valores fixos que podem ser atribuı́dos a uma variável.
– Os dois valores devem ser, do ponto de vista lógico, mutuamente excludentes.
• Modelagem lógica de um problema real:
– A formulação de um problema real envolve diversas representações ou codificações.
– Problema real → um sistema formado por um conjunto de assertivas (statements),
associadas por meio de conectivos (operadores ou funções).
– Conectivo → elemento de conexão que é modelado por uma função lógica.
– Assertiva → afirmação declarativa (statement) sobre algum elemento do problema,
a qual é representada por uma variável de asserção do sistema.
– Variável de asserção → variável do sistema associada a uma assertiva, à qual será
atribuı́do um valor fixo lógico (truth value).
– Valor fixo lógico → representação do estado de uma variável de asserção por meio
de um sı́mbolo com significado lógico Por exemplo: F/T, F/V, 0/1, 0/5 ou +12/-12.
• Uma vez que os dois valores fixos possı́veis são mutamente excludentes, naturalmente surge
a idéia de negação (da associação de assertivas, do conectivo, da assertiva, da variável de
asserção, do valor ou do sı́mbolo).
TET / UFF
14
Capı́tulo 3. Funções lógicas
3.5
Operadores lógicos
• Um operador lógico pode ser definido por uma função de variáveis lógicas (truth function).
• Formalização matemática das funções lógicas: cálculo de funções lógicas ou cálculo sentencial ou cálculo proposicional ou tautologia.
• Representação eficiente de funções lógicas: tabela verdade (truth table).
• Valores lógicos utilizados: F e T .
• Funções de 1 variável:
– Cada uma das funções de uma variável é definida por sua Tabela Verdade na Tabela 3.1.
– Operações: os operadores Xi = fi (A) são definidos na Tabela 3.2.
A
F
T
X
X0
F
F
= f (A)
X1 X2
F
T
T
F
X3
T
T
Tabela 3.1: Tabela de funções de uma variável.
Xi
X0
X1
X2
X3
f (A)
Operação
Notação
(F )
(F )
(A)
(A)
NOT (A) ¬(A) ≡ ∼ (A) ≡ (A) ≡ (A)′ ≡ (A)∗ ≡ !(A)
(T )
(T )
Nomenclatura
Contradição
Identidade lógica
Negação lógica
Tautologia
Tabela 3.2: Tabela de operadores de 1 variável.
• Funções de 2 variáveis:
– Cada uma das funções de duas variáveis é definida por sua Tabela Verdade na Tabela 3.3.
– Operações: os operadores Xi = fi (A, B) são definidos na Tabela 3.4.
A
F
F
T
T
B
F
T
F
T
X0
F
F
F
F
X1
F
F
F
T
X2
F
F
T
F
X3
F
F
T
T
X4
F
T
F
F
X5
F
T
F
T
X = f (A, B)
X6 X7 X8
F
F
T
T
T
F
T
T
F
F
T
F
X9
T
F
F
T
X10
T
F
T
F
X11
T
F
T
T
X12
T
T
F
F
X13
T
T
F
T
X14
T
T
T
F
X15
T
T
T
T
Tabela 3.3: Tabela de funções de duas variáveis.
A.S.V.
15
3.6. Relações de implicação
f (A, B)
Xi
X0
X1
X2
X3
X4
X5
X6
X7
X8
X9
X10
X11
X12
X13
X14
X15
Operação
(F )
(A AND B)
NOT (A IMP LICA B)
(A)
NOT (B IMP LICA A)
(B)
(A XOR B)
(A OR B)
NOT (A OR B) ≡ (A NOR B)
NOT (A XOR B) ≡ (A XNOR B)
NOT (B)
(B IMP LICA A)
NOT (A)
(A IMP LICA B)
NOT (A AND B) ≡ (A NAND B)
(T )
Notação
(F )
(A ∧ B)
¬(A → B) ≡ ¬(A ⊃ B)
(A)
¬(A ← B) ≡ ¬(A ⊂ B)
(B)
(A ⊻ B)
(A ∨ B)
¬(A ∨ B) ≡ (A ↓ B)
¬(A ⊻ B) ≡ (A∧B) ≡ (A ↔ B) ≡ (A ≡ B)
¬(B)
(A ← B) ≡ (A ⊂ B)
¬(A)
(A → B) ≡ (A ⊃ B)
¬(A ∧ B) ≡ (A ↑ B)
(T )
Tabela 3.4: Tabela de operadores de duas variáveis.
• Com base nas operações identificadas nas Tabelas 3.1 e 3.3, podem ser definidos os operadores lógicos encontrados nas Tabelas 3.2 e 3.4.
– Operadores unários: identidade lógica e NOT (negação lógica).
– Operadores binários: AND (E lógico), OR (OU-inclusivo lógico), XOR (OU-eXclusivo),
NAND (NOT-AND), NOR (NOT-OR), XNOR (NOT-XOR ou bi-implicação ou
equivalência lógica) e IMPLICA (implicação lógica).
• Funções de N > 2 variáveis: definidas através da combinação das variáveis lógicas e das
operações identificadas nas funções de 1 e 2 variáveis.
3.6
Relações de implicação
• Podem-se definir três relações de implicação de uma assertiva precedente A para uma
assertiva conseqüente B:
– Condição necessária: “SOMENTE SE (A = T ) ENTÃO (B = T )”
ou “(B = T ) SOMENTE SE (A = T )”.
– Condição suficiente: “SE (A = T) ENTÃO (B = T)” ou “(B = T) SE (A = T)”.
– Condição necessária e suficiente: “SE E SOMENTE SE (A = T) ENTÃO (B = T)”
ou “(B = T) SE E SOMENTE SE (A = T)”.
• Portanto, pode-se estabelecer a seguinte modelagem:
– Condição necessária: (A ← B).
– Condição suficiente: (A → B).
– Condição necessária e suficiente: (A → B) ∧ (A ← B) ≡ (A ↔ B) ≡ (A ≡ B).
TET / UFF
16
Capı́tulo 3. Funções lógicas
3.7
Conjunto funcionalmente completo de operadores
• Deve-se notar, nas Tabelas 3.1 a 3.4, que metade da funções Xk pode ser obtida através
da aplicação do operador de negação lógica (NOT) sobre a outra metade.
• Além disso, deve-se notar que alguns operadores (conectivos) binários podem ser descritos
através da combinação de outros operadores.
• Questões que surgem naturalmente:
– É possı́vel descrever todos os demais operadores a partir de um determinado conjunto
(conjunto completo) ?
– Todos os operadores de um conjunto completo são absolutamente necessários (independentes)?
– Existe um conjunto mı́nimo de operadores que forme um conjunto completo (conjunto completo mı́nimo) ?
• Respostas:
– Tentativa 1: (AND) → Não!
– Tentativa 2: (OR) → Não!
– Tentativa 3: (AND + OR) → Não!
– Tentativa 4: (AND + OR + NOT) → OK! → Conjunto completo, mas não mı́nimo...
– Tentativa 5: (NOT + AND = NAND) → OK! → Conjunto completo e mı́nimo!
– Tentativa 6: (NOT + OR = NOR) → OK! → Conjunto completo e mı́nimo!
• Os operadores NOT, AND e OR são naturalmente utilizados nas expressões lógicas
elaboradas pelo ser humano.
• Os operadores NOT, NAND e NOR são facilmente implementados por dispositivos eletroeletrônicos.
• Assim sendo, é comum que se definam as expressões lógicas utilizando os operadores do
conjunto {NOT, AND, OR} e, em seguida, que elas sejam convertidas em expressões
equivalentes, empregando os operadores do conjunto {NOT, NAND, NOR}.
3.8
Teoremas de De Morgan
• Os teoremas de De Morgan descrevem uma relação direta entre os operadores NOT, AND
e OR.
• (A NAND B) ≡ NOT (A AND B) ≡ (NOT A) OR (NOT B)
ou
(A ↑ B) ≡ ¬(A ∧ B) ≡ (¬A) ∨ (¬B)
• (A NOR B) ≡ NOT (A OR B) ≡ (NOT A) AND (NOT B)
ou
(A ↓ B) ≡ ¬(A ∨ B) ≡ (¬A) ∧ (¬B)
A.S.V.
17
3.9. Decomposição em funções canônicas
3.9
Decomposição em funções canônicas
• Demonstra-se que uma função lógica genérica pode ser decomposta em funções canônicas,
dos tipos m e M.
• Em uma função canônica do tipo m, apenas um dos valores da sua Tabela Verdade é T,
enquanto todos os demais são F.
• Uma vez que, na decomposição de uma função genérica, ela será um termo com um
número mı́nimo de valores T, a função do tipo m é denominada de mintermo.
• Em uma função canônica do tipo M, apenas um dos valores da sua Tabela Verdade é F,
enquanto todos os demais são T.
• Uma vez que, na decomposição de uma função genérica, ela será um termo com um
número mı́nimo de valores F, a função do tipo M, é denominada de maxtermo.
• Para funções de duas variáveis, os mintermos mi são definidos por: m0 (A, B) = (¬A ∧ ¬B),
m1 (A, B) = (¬A ∧ B), m2 (A, B) = (A ∧ ¬B) e m3 (A, B) = (A ∧ B).
• Para funções de duas variáveis, os maxtermos Mi são definidos por: M0 (A, B) = (A ∨ B),
M1 (A, B) = (A ∨ ¬B), M2 (A, B) = (¬A ∨ B) e M3 (A, B) = (¬A ∨ ¬B).
• A Tabela 3.5 apresenta as funções canônicas (mintermos e maxtermos) para duas variáveis.
A
F
F
T
T
B
F
T
F
T
m0
T
F
F
F
m1
F
T
F
F
m2
F
F
T
F
m3
F
F
F
T
M0
F
T
T
T
M1
T
F
T
T
M2
T
T
F
T
M3
T
T
T
F
Tabela 3.5: Tabela de funções canônicas (mintermos e maxtermos) para duas variáveis.
• Para sintetizar os diversos valores T da Tabela Verdade de uma função genérica, utilizamse os mintermos correspondentes, combinados pelo operador lógico OR.
• Para sintetizar os diversos valores F da Tabela Verdade de uma função genérica, utilizamse os maxtermos correspondentes, combinados pelo operador lógico AND.
• A tı́tulo de exemplo, a Tabela 3.6 ilustra a decomposição da função X(A, B) = (A ⊻ B)
de duas formas: i) X(A, B) = (A ⊻ B) = m1 ∨ m2 = (¬A ∧ B) ∨ (A ∧ ¬B) e
ii) X(A, B) = (A ⊻ B) = M0 ∧ M3 = (A ∨ B) ∧ (¬A ∨ ¬B).
A
F
F
T
T
B
F
T
F
T
A⊻B
F
T
T
F
m1
F
T
F
F
m2
F
F
T
F
M0
F
T
T
T
M3
T
T
T
F
Tabela 3.6: Exemplo de decomposição em funções canônicas (mintermos e maxtermos).
TET / UFF
18
Capı́tulo 3. Funções lógicas
• Uma vez que, para uma determinada função alvo X(·), cada função mi (ou Mi ) utilizada
na sua decomposição é responsável por sintetizar apenas um dos valores T (ou F ) de X(·),
o total de termos m somado ao total de termos M, usados na decomposição de X(·),
é igual ao total de valores da sua Tabela Verdade.
• Deve-se notar ainda que ¬(mi ) = Mi .
• Portanto, as relações ¬m3 = M3 e ¬M0 = m0 representam, ao mesmo tempo, uma prova
para os Teoremas de De Morgan e uma outra forma de enunciá-los.
3.10
Blocos funcionais fundamentais
• Para cada operador lógico, pode-se definir um bloco funcional que realize a operação
correspondente.
• Posteriormente, pode-se propor um sistema fı́sico que implemente o bloco funcional
desejado.
• Blocos funcionais fundamentais, associados aos operadores lógicos, são ilustrados na
Figura 3.1.
Identidade
NOT
AND
NAND
OR
NOR
XOR
XNOR
Figura 3.1: Blocos funcionais fundamentais, associados aos operadores lógicos.
A.S.V.
3.11. Manipulação algébrica de blocos
3.11
19
Manipulação algébrica de blocos
• Os blocos funcionais são uma representação alternativa para os operadores lógicos.
• Desenhos esquemáticos envolvendo os blocos funcionais, denominados circuitos lógicos,
são uma representação alternativa para as equações envolvendo os operadores lógicos.
• Portanto, pode-se realizar uma manipulação diretamente sobre os blocos lógicos de um
circuito, a qual será idêntica àquela realizada sobre os operadores lógicos de uma equação.
• Dois exemplos de manipulação algébrica de equações são mostrados nas Equações (3.1) e (3.2).
• Dois exemplos de manipulação algébrica de blocos, referentes às manipulações das
Equações (3.1) e (3.2), são mostrados nas Figuras 3.2 e 3.3, respectivamente.
TET / UFF
X(A, B) =
=
=
=
=
=
A⊻B
(¬A ∧ B) ∨ (A ∧ ¬B)
¬ (¬ ((¬A ∧ B) ∨ (A ∧ ¬B)))
¬ ((¬A ∧ B) ↓ (A ∧ ¬B))
¬ ((¬ (¬A ∧ B)) ∧ (¬ (A ∧ ¬B)))
(¬A ↑ B) ↑ (A ↑ ¬B) .
(3.1)
X(A, B) =
=
=
=
=
=
A⊻B
(A ∨ B) ∧ (¬A ∨ ¬B)
¬ (¬ ((A ∨ B) ∧ (¬A ∨ ¬B)))
¬ ((A ∨ B) ↑ (¬A ∨ ¬B))
¬ ((¬ (A ∨ B)) ∨ (¬ (¬A ∨ ¬B)))
(A ↓ B) ↓ (¬A ↓ ¬B) .
(3.2)
20
Capı́tulo 3. Funções lógicas
Figura 3.2: Manipulação algébrica de blocos: exemplo 1.
A.S.V.
3.11. Manipulação algébrica de blocos
Figura 3.3: Manipulação algébrica de blocos: exemplo 2.
TET / UFF
21
22
Capı́tulo 3. Funções lógicas
3.12
Uso de operador lógico como elemento de controle
• No projeto de circuitos digitais, é comum que se necessite de alguns elementos básicos de
controle, os quais podem ser implementados através dos operadores lógicos.
• Considerando-se que as variáveis lógicas A e B, bem como a função do operador X(A, B),
sejam, respectivamente, mapeadas nas variáveis de entrada E, de controle CT RL e de
saı́da S(E, CT RL), e que elas assumam apenas os valores lógicos F e T , podem-se definir
as ações de controle apresentadas na Tabela 3.7.
• Uma simbologia genérica para tais operações pode ser visualizada na Figura 3.4.
Operador lógico: X(A, B)
AND
S
=
NAND
S
=
OR
S
=
NOR
S
=
XOR
S
=
XNOR
S
=
IMP LICA
S
=
S
=
S
=
S
=
NOT IMP LICA
Ação de controle: S(E, CT RL)
F , CT RL = F
(CT RL ∧ E) =
E
, CT RL = T
T , CT RL = F
(CT RL ↑ E) =
E , CT RL = T
E , CT RL = F
(CT RL ∨ E) =
T , CT RL = T
E , CT RL = F
(CT RL ↓ E) =
F , CT RL = T
E , CT RL = F
(CT RL ⊻ E) =
E , CT RL = T
E , CT RL = F
(CT RL ≡ E) =
E , CT RL = T
T , CT RL = F
(CT RL → E) =
E , CT RL = T
E , CT RL = F
(CT RL ← E) =
T , CT RL = T
F , CT RL = F
¬ (CT RL → E) =
E , CT RL = T
E , CT RL = F
¬ (CT RL ← E) =
F , CT RL = T
Tabela 3.7: Uso de operador lógico como elemento de controle.
A
B
Operador
X(A,B)
E
Controle
S(E,CTRL)
CTRL
Figura 3.4: Uso de operador lógico como elemento de controle: simbologia genérica.
A.S.V.
3.13. Exercı́cios propostos
3.13
23
Exercı́cios propostos
1. Discutir a propriedade de comutatividade dos operandos para todos os operadores
binários.
2. Considerando que todas as funções lógicas sejam descritas pela combinação dos operadores
unário e binários, provar que:
(a) Os conjuntos {AND}, {OR} e {AND, OR}, não são conjuntos completos.
(b) O conjunto {AND, OR, NOT } é um conjunto completo.
(c) O conjunto {AND, OR, NOT } não é um conjunto completo mı́nimo.
(d) O conjunto {AND, NOT } ≡ {NAND} é um conjunto completo mı́nimo.
(e) O conjunto {OR, NOT } ≡ {NOR} é um conjunto completo mı́nimo.
3. Escrever as funções de todos os conectivos binários utilizando apenas as seguintes funções
básicas:
(a) {AND, NOT }.
(b) {OR, NOT }.
(c) NAND.
(d) NOR.
4. Provar os Teoremas de De Morgan.
5. Decompor as funções de todos os conectivos binários como combinações das funções
básicas mi (mintermos), associadas pelo conectivo OR.
6. Decompor as funções de todos os conectivos binários como combinações das funções
básicas Mi (maxtermos), associadas pelo conectivo AND.
7. Dados os mintermos mi (A, B) e os maxtermos Mi (A, B):
(a) Descrever cada mintermo mi (A, B) em função dos demais mintermos mj (A, B), onde
i 6= j.
(b) Descrever cada mintermo mi (A, B) em função dos maxtermos Mj (A, B).
(c) Descrever cada maxtermo Mi (A, B) em função dos demais maxtermos Mj (A, B),
onde i 6= j.
(d) Descrever cada maxtermo Mi (A, B) em função dos mintermos mj (A, B).
8. Para os exercı́cios listados abaixo, considerar as equações lógicas apresentadas em seguida.
(a) Desenhar um Diagrama de Blocos Funcionais equivalente, para cada uma das
equações lógicas fornecidas.
(b) Decompor cada uma das equações lógicas fornecidas como combinação das funções
básicas mi (mintermos), associadas pelo conectivo OR.
(c) Decompor cada uma das equações lógicas fornecidas como combinação das funções
básicas Mi (maxtermos), associadas pelo conectivo AND.
TET / UFF
24
Capı́tulo 3. Funções lógicas
(d) Desenhar um Diagrama de Blocos Funcionais equivalente, para cada uma das
decomposições pedidas anteriormente.
Equações lógicas:
i.
ii.
iii.
iv.
v.
F (A, B) = (A ∨ B) ∧ (A ∨ ¬B) ∧ (¬A ∨ B).
F (A, B) = (¬A ∨ B) ∧ (A ∨ ¬B) ∧ (¬A ∨ ¬B).
F (A, B) = (A ∧ ¬B) ∨ (¬A ∧ B) ∨ (A ∧ B).
F (A, B) = (¬A ∧ ¬B) ∨ (¬A ∧ B) ∨ (A ∧ ¬B).
F (A, B, C, D) = (A ∨ B) ∧ (¬(C ∧ D)).
A.S.V.
Capı́tulo 4
Álgebra de Boole
4.1
Introdução
• A implementação de um sistema digital apresenta um custo.
• Sempre é desejado o menor custo possı́vel.
• Deve-se minimizar a implementação a fim de se reduzir o seu custo.
• O cálculo proposicional não apresenta ferramentas adequadas para encontrar a implementação mais econômica.
• É necessário definir uma representação lógica que forneça ferramentas para a minimização
das funções lógicas.
• Tais ferramentas podem ser encontradas na álgebra abstrata.
• A álgebra é o ramo da matemática que estuda as generalizações dos conceitos e das
operações da aritmética.
• Em álgebra abstrata definem-se estruturas abstratas que representam, de uma forma
global, diversas estruturas encontradas na prática.
• Uma estrutura algébrica adequada para a formulação, a manipulação e a minimização de
funções lógicas foi proposta por Boole, a qual será tratada neste capı́tulo.
4.2
Postulados de Huntington
• Na definição de estruturas algébricas abstratas, são apresentados axiomas que estabelecem:
– um conjunto de elementos;
– um determinado número de operações;
– alguns elementos particulares;
– algumas propriedades.
25
26
Capı́tulo 4. Álgebra de Boole
• Na associação de uma determinada estrutura abstrata com um determinado sistema
existente são definidos:
– os elementos dos conjuntos;
– o funcionamento das operações;
– os elementos particulares.
• Entre as diversas formas de abordar a estrutura proposta por Boole, uma das mais
utilizadas são os Postulados de Huntington, apresentados a seguir.
• Deve ser ressaltado que, nesses postulados, os sı́mbolos denotam componentes puramente
abstratos. Assim sendo, as operações abstratas “+” e “·” não significam as operações
aritméticas básicas de adição e multiplicação. Por sua vez, os sı́mbolos “0” e “1” não representam quantidades, uma vez que não é definido um tipo particular para os elementos.
• Postulados de Huntington
1. Existe um conjunto K de objetos ou elementos, sujeito a uma relação de equivalência,
denotada pelo sı́mbolo “=”, que satisfaz ao princı́pio da substituição.
2. É definida uma operação, denotada por “+”, tal que, dados a e b ∈ K, (a + b) ∈ K.
É definida uma operação, denotada por “·”, tal que, dados a e b ∈ K, (a · b) ∈ K.
3. Existe um elemento 0 ∈ K, tal que, para cada a ∈ K, (a + 0) = a.
Existe um elemento 1 ∈ K, tal que, para cada a ∈ K, (a · 1) = a.
4. As seguintes relações de comutatividade são válidas:
(a + b) = (b + a)
(a · b) = (b · a)
5. As seguintes relações de distributividade são válidas:
a + (b · c) = (a + b) · (a + c)
a · (b + c) = (a · b) + (a · c)
6. Para cada elemento a ∈ K existe um elemento a ∈ K, tal que
a+a=1
a·a=0
7. Deve haver, pelo menos, um total de dois elementos a e b ∈ K, tal que a 6= b.
4.3
Dualidade
• A dualidade é a caracterı́stica daquilo que é dual, o que significa ser composto por duas
unidades ou dois elementos.
• Pode-se observar que alguns postulados de Huntington são apresentados em pares.
• Em cada par, um postulado pode ser obtido através do outro, efetuando-se a troca das
operações “+” e “·”, bem como dos elementos 0 e 1.
• Cada teorema relacionado à estrutura algébrica de Boole possui um teorema dual.
• Ao usar a dualidade sobre a prova de um teorema, pode-se facilmente provar o seu dual.
A.S.V.
4.4. Lemas e teoremas fundamentais
4.4
27
Lemas e teoremas fundamentais
• Nessa seção, são apresentados lemas e teoremas para a estrutura algébrica de Boole.
• Lemas são resultados intermediários das provas dos teoremas.
• Teoremas são ferramentas para resolução de problemas.
• Os lemas e os teoremas, apresentados a seguir, podem ser demonstrados a partir dos
postulados definidos anteriormente.
• Lemas:
1.
2.
3.
4.
5.
6.
7.
8.
Os elementos 0 e 1 são únicos.
Para cada a ∈ K, (a + a) = a e (a · a) = a.
Para cada a ∈ K, (a + 1) = 1 e (a · 0) = 0.
Os elementos 0 e 1 são distintos e 1 = 0.
Para cada par a e b ∈ K, a + (a · b) = a e a · (a + b) = a,
O elemento a, definido no Postulado 6, é único, para cada a ∈ K.
Para cada a ∈ K, a = (a).
Para quaisquer três elementos a, b e c ∈ K, a · [(a + b) + c] = [(a + b) + c] · a = a.
• Teoremas:
1. Para quaisquer três elementos a, b e c ∈ K,
a + (b + c) = (a + b) + c
a · (b · c) = (a · b) · c
2. Para cada par a e b ∈ K,
a + (a · b) = (a + b)
a · (a + b) = (a · b)
3. Para cada par a e b ∈ K,
a+b=a·b
a·b=a+b
4. Para quaisquer três elementos a, b e c ∈ K, (a · b) + (a · c) + (b · c) = (a · b) + (a · c)
4.5
Definição de uma estrutura algébrica particular
• De acordo com o Postulado 7, o menor conjunto K possı́vel é aquele que possui dois
elementos.
• Por sua vez, uma estrutura algébrica que possa ser associada ao Cálculo Proposicional
também deve possuir um conjunto K com dois elementos.
• Portanto, com o objetivo de se modelar algebricamente o Cálculo Proposicional, pode-se
definir a seguinte estrutura algébrica:
–
–
–
–
K = {0, 1}
0=1e1=0
(1 · 1) = (1 + 1) = (1 + 0) = (0 + 1) = 1
(0 + 0) = (0 · 0) = (0 · 1) = (1 · 0) = 0
TET / UFF
28
Capı́tulo 4. Álgebra de Boole
4.6
Exemplos de associação com a estrutura algébrica de
Boole
• Cálculo proposicional: a associação entre o cálculo proposicional e a estrutura algébrica
de Boole é apresentada na Tabela 4.1.
• Teoria de conjuntos: a associação entre a teoria de conjuntos e a estrutura algébrica de
Boole é apresentada na Tabela 4.2.
• Das Tabelas 4.1 e 4.2, pode-se concluir que o Cálculo proposicional e Teoria de Conjuntos
compartilham a mesma estrutura algébrica de Boole.
Cálculo Proposicional
∧
∨
F
T
¬(S)
Álgebra de Boole
·
+
0
1
S
Tabela 4.1: Tabela de mapeamento: Cálculo Proposicional × Álgebra de Boole.
Teoria de Conjuntos
∩
∪
SZ
SU
C(S)
Álgebra de Boole
·
+
0
1
S
Tabela 4.2: Tabela de mapeamento: Teoria de Conjuntos × Álgebra de Boole.
4.7
Isomorfismo
• Sistemas que são modelados pela mesma estrutura algébrica são ditos sistemas isomórficos.
• Sistemas isomórficos podem ser mapeados uns nos outros, por intermédio da estrutura
compartilhada.
• As operações realizadas em cada sistema isomórfico são equivalentes e podem ser relacionadas entre si.
• As ferramentas existentes em um sistema isomófico podem ser usadas para resolver problemas nos sistemas equivalentes, através do mapeamento adequado.
A.S.V.
4.8. Simplificação algébrica de expressões lógicas
4.8
29
Simplificação algébrica de expressões lógicas
• As expressões lógicas, provenientes de problemas reais e que devem ser implementadas
com o menor custo possı́vel, podem ser simplificadas por meio das ferramentas da álgebra
abstrata (Postulados, Lemas e Teoremas).
• Inicialmente, deve-se mapear o sistema lógico (cálculo proposicional) em um sistema
algébrico (estrutura algébrica de Boole).
• Em seguida, pode-se realizar a manipulação algébrica das expressões lógicas mapeadas,
a fim de reduzı́-las a formas mais simples e, conseqüentemente, reduzir o custo de sua
implementação.
• As ferramentas algébricas utilizadas são os postulados, os lemas e os teoremas da estrutura
algébrica com a qual se esteja trabalhando.
• A manipulação algébrica não sistemática depende da habilidade do profissional e não
é diretamente automatizável, uma vez que não há uma definição inicial nem de qual
conjunto de ferramentas nem de qual item do conjunto deva ser utilizado, nem mesmo
em qual ordem.
• Portanto, faz-se necessário utilizar algum mecanismo mais adequado à atividade de simplificação das expressões.
• Um exemplo de manipulação algébrica não sistemática é apresentado a seguir.
4.9
Exemplo de manipulação algébrica não sistemática:
Postulados, Lemas e Teoremas
• Inicialmente, usando a Tabela 4.1, a expressão lógica (A ∨ B) ∧ (A ∨ ¬B) ∧ (¬A ∨ B) é
mapeada na expressão booleana (A + B) · (A + B) · (A + B).
• Em seguida, as Equações (4.1) a (4.3) ilustram possı́veis manipulações algébricas, não
sistemáticas, da expressão booleana, a fim de minimizá-la.
• É fácil perceber, por essas equações, que, dependendo das escolhas realizadas, há uma
grande diferença no esforço dispendido.
• Além disso, não há qualquer garantia de que a expressão final seja a expressão mı́nima,
ou de que a expressão mı́nima será alcançada.
TET / UFF
30
Capı́tulo 4. Álgebra de Boole
(A + B) · (A + B) · (A + B)
↓ P5
([(A + B) · (A)] + [(A + B) · (B)]) · (A + B)
↓ P5
([(A · A) + (B · A)] + [(A · B) + (B · B)]) · (A + B)
↓ L2/P 6
([A + (B · A)] + [(A · B) + 0]) · (A + B)
↓ P 4/P 3
([A + (A · B)] + [(A · B)]) · (A + B)
↓ L5
A + (A · B) · (A + B)
↓ P5
A · (A + B) + (A · B) · (A + B)
↓ P5
(A · A) + (A · B) + (A · B · A) + (A · B · B)
↓ P 6/P 4
0 + (A · B) + (A · A · B) + (A · B · B)
↓ P6
0 + (A · B) + (0 · B) + (A · 0)
↓ P 4/L3
0 + (A · B) + (B · 0) + 0
↓ L3
0 + (A · B) + 0 + 0
↓ P4
(A · B) + 0 + 0 + 0
↓ P 3/P 3/P 3
(A · B)
(4.1)
A.S.V.
4.9. Exemplo de manipulação algébrica não sistemática: Postulados, Lemas e Teoremas
31
(A + B) · (A + B) · (A + B)
↓ P5
A · (B + B) · (A + B)
↓ P6
(A · 1) · (A + B)
↓ P3
A · (A + B)
↓ P5
(A · A) + (A · B)
↓ P6
0 + (A · B)
↓ P4
(A · B) + 0
↓ P3
(A · B)
(4.2)
(A + B) · (A + B) · (A + B)
↓ L2
(A + B) · (A + B) · (A + B) · (A + B)
↓ P4
(A + B) · (A + B) · (A + B) · (A + B)
↓ P5
A · (B + B) · (A + A) · B)
↓ P6
A·1·1·B
↓ P 3/P 3
(A · B)
TET / UFF
(4.3)
32
Capı́tulo 4. Álgebra de Boole
4.10
Exemplo de manipulação algébrica por isomorfismo:
Diagrama de Venn
• Na tentativa de sistematizar o processo de simplificação de uma expressão lógica, pode-se
aproveitar o isomorfismo existente entre o Cálculo Proposicional e a Teoria de Conjuntos.
• Mapeando-se as operações e os elementos dos dois sistemas, o Diagrama de Venn pode
ser usado na simplificação de expressões lógicas que envolvam 2 ou 3 variáveis.
• Nesse sentido, a cada variável da expressão lógica é associado um conjunto e para cada
linha da Tabela Verdade da expressão lógica é associada uma região do Diagrama de Venn
construı́do com os conjuntos definidos.
• A Figura 4.1 mostra um exemplo de mapeamento entre uma função genérica de duas
variáveis e um Diagrama de Venn.
• Através da manipulação do Diagrama de Venn, pode-se tentar encontrar uma expressão
simplificada, equivalente à expressão original.
• Ainda assim, embora seja um processo sistemático, a etapa final da simplificação através
do Diagrama de Venn exige habilidade para encontrar a expressão mais simples.
• Além disso, para expressões que envolvam mais variáveis, o processo torna-se complexo e
confuso.
• Portanto, devem ser utilizadas ferramentas mais eficientes, as quais serão tratadas a seguir.
A B
X(A,B)
F F
F T
T F
T T
X0
X1
X2
U
X0
A
B
X2
X3
X1
X3
Figura 4.1: Mapeamento entre uma função genérica de duas variáveis e um Diagrama de Venn.
A.S.V.
33
4.11. Resumo das relações algébricas
4.11
Resumo das relações algébricas
As Tabelas 4.3 a 4.7 apresentam um resumo das relações algébricas abordadas neste capı́tulo:
os postulados, os lemas, os teoremas, a definição de uma estrutura algébrica de Boole particular
e os isomorfismos.
P3
P4
P5
P6
Postulados de Huntington
a+0 = a
a·1 = a
(a + b) = (b + a)
(a · b) = (b · a)
a + (b · c) = (a + b) · (a + c)
a · (b + c) = (a · b) + (a · c)
a+a = 1
a·a = 0
Tabela 4.3: Resumo dos postulados de Huntington para a estrutura algébrica de Boole.
Lemas
L2
L3
L4
L5
L7
L8
a+a = a
a·a = a
a+1 = 1
a·0 = 0
0 = 1
0 = 1
a + (a · b) = a
a · (a + b) = a
a = (a)
a · [(a + b) + c] = [(a + b) + c] · a = a
Tabela 4.4: Resumo dos lemas para a estrutura algébrica de Boole.
TET / UFF
34
Capı́tulo 4. Álgebra de Boole
T1
T2
T3
T4
Teoremas
a + (b + c) = (a + b) + c
a · (b · c) = (a · b) · c
a + (a · b) = (a + b)
a · (a + b) = (a · b)
(a + b) = a · b
(a · b) = a + b
(a · b) + (a · c) + (b · c) = (a · b) + (a · c)
(a + b) · (a + c) · (b + c) = (a + b) · (a + c)
Tabela 4.5: Resumo dos teoremas para a estrutura algébrica de Boole.
Estrutura algébrica de Boole Particular
{K
= {0, 1}
0 = 1
Complementos
0 = 1
1·1 = 1+1 = 1+0 = 0+1 = 1
Identidades
0+0 = 0·0 = 0·1 = 1·0 = 0
Elementos
Tabela 4.6: Resumo da definição de uma estrutura algébrica de Boole particular.
Isomorfismos
Teoria de Conjuntos Cálculo Proposicional Álgebra de Boole
∪
∨
+
∩
∧
·
SZ
F
0
SU
T
1
C(S)
¬(S)
S
Tabela 4.7: Resumo das relações de isomorfismo.
A.S.V.
35
4.12. Exercı́cios propostos
4.12
Exercı́cios propostos
1. Considerando o isomorfismo do Cálculo Proposicional com a Álgebra de Boole Binária:
(a) Provar que os postulados, os lemas e os teoremas, da Álgebra de Boole, se aplicam
para o Cálculo Proposicional.
(b) Para cada um dos operadores lógicos (unário e binários), escrever sua Tabela Verdade
usando a notação da Álgebra de Boole.
2. Para uma função genérica de duas variáveis, montar sua Tabela Verdade e identificar, em
um Diagrama de Venn correspondente, cada uma das possibilidades da tabela.
3. Para uma função genérica de três variáveis, montar sua Tabela Verdade e identificar, em
um Diagrama de Venn correspondente, cada uma das possibilidades da tabela.
4. Para os exercı́cios listados abaixo, considerar as equações lógicas apresentadas em seguida.
(a) Escrever as equações booleanas referentes às equações lógicas fornecidas.
(b) Montar a Tabela Verdade para cada uma das equações lógicas fornecidas, usando a
notação da Álgebra de Boole.
(c) Aplicando os postulados, os lemas e os teoremas, da Álgebra Abstrata de Boole, apresentar uma simplificação para as equações booleanas referentes às equações lógicas
fornecidas.
(d) Utilizando o Diagrama de Venn, apresentar uma simplificação para as equações booleanas referentes às equações lógicas fornecidas.
Equações lógicas:
i. F (A, B) = (A ∨ B) ∧ (A ∨ ¬B) ∧ (¬A ∨ B).
ii. F (A, B) = (¬A ∨ B) ∧ (A ∨ ¬B) ∧ (¬A ∨ ¬B).
iii. F (A, B) = (A ∧ ¬B) ∨ (¬A ∧ B) ∨ (A ∧ B).
iv. F (A, B) = (¬A ∧ ¬B) ∨ (¬A ∧ B) ∨ (A ∧ ¬B).
v. F (A, B, C, D) = (A ∨ B) ∧ (¬(C ∧ D)).
5. Provar as relações dos conjuntos duais abaixo, utilizando a Tabela Verdade com a notação
da Álgebra de Boole.
(a) A + 0 = A
A+A=1
A+A=A
A+1=1
(P3)
(P6)
(L2)
(L3)
(b) A · 1 = A
A·A = 0
A·A = A
A·0 =0
(P3)
(P6)
(L2)
(L3)
TET / UFF
36
Capı́tulo 4. Álgebra de Boole
6. Provar as relações abaixo, relativas ao conectivo XOR, utilizando a Tabela Verdade com
a notação da Álgebra de Boole.
(a) A ⊕ 0 = A
(b) A ⊕ 1 = A
(c) A ⊕ A = 0
(d) A ⊕ A = 1
(e) A ⊕ A = 0
(f) (A ⊕ A) ⊕ A = A
(g) (A ⊕ A) ⊕ A = A
(h) A ⊕ (A ⊕ A) = A
(i) A ⊕ (A ⊕ A) = A
(j) A ⊕ B = (A · B) + (A · B) = (A + B) · (A + B)
(k) A ⊕ B = (A · B) + (A · B) = (A + B) · (A + B)
(l) A ⊕ B = A ⊕ B = A ⊕ B
(m) (A ⊕ B) ⊕ C = A ⊕ (B ⊕ C)
(n) A · (B ⊕ C) = (A · B) ⊕ (A · C)
(o) f (C, D, E, F ) = (C · D) + (E · F ) = A ⊕ B , para C = A, D = B, E = A e F = B.
(p) f (C, D, E, F ) = (C · D) + (E · F ) = A ⊕ B , para C = A, D = B, E = A e F = B.
(q) f (C, D, E, F ) = (C + D) · (E + F ) = A ⊕ B , para C = A, D = B, E = A e F = B.
(r) f (C, D, E, F ) = (C + D) · (E + F ) = A ⊕ B , para C = A, D = B, E = A e F = B.
A.S.V.
Capı́tulo 5
Formas padrões para representação de
expressões booleanas
5.1
Introdução
• O projeto de sistemas digitais convencionais envolve a implementação de equações lógicas.
• Equações lógicas expressas por uma álgebra de Boole são denominadas equações booleanas.
• A minimização do custo de implementação de um projeto está associada à simplificação
de suas equações booleanas.
• Um processo eficiente de simplificação deve ser simples de se entender, fácil de se operar,
de rápida execução e completamente sistemático, a fim de permitir sua automatização.
• Os processos sistemáticos de simplificação que serão apresentados nos capı́tulos que se
seguem trabalham sobre uma função expressa em formas padrões.
• Assim, para que se possa usar tais ferramentas de projeto, expressões booleanas genéricas
devem ser inicialmente expandidas para tais formas.
• As formas padrões básicas são as decomposições da expressão booleana original em mintermos e maxtermos.
• Uma expansão em mintermos envolve realizar os mintermos necessários com operadores
AND e, em seguida, combiná-los com operadores OR. Por essa razão, uma decomposição
em mintermos é chamada de forma padrão AND-OR.
• Uma expansão em maxtermos envolve realizar os maxtermos necessários com operadores
OR. e, em seguida, combiná-los com operadores AND Por essa razão, uma decomposição
em maxtermos é chamada de forma padrão OR-AND.
• As demais formas padrões surgem como resultado de manipulações algébricas das formas
padrões básicas.
• Podem ser identificados dois conjuntos de formas padrões:
– Grupo AND-OR → AND-OR , NAND-NAND, OR-NAND, NOR-OR.
– Grupo OR-AND → AND-NOR, NAND-AND , OR-AND , NOR-NOR.
37
38
Capı́tulo 5. Formas padrões para representação de expressões booleanas
5.2
Definições
• Literal: variável booleana ou seu complemento.
• Termo (combinação de literais):
– Termo produto: combinação de literais através do operador AND.
– Termo soma: combinação de literais através do operador OR.
– Termo normal: termo produto ou termo soma onde nenhum literal aparece mais de
uma vez.
– Termo normal expandido: termo normal que contém todos os literais envolvidos na
expressão booleana.
• Observações:
– Uma vez que (A · A) = (A + A) = A, (A + A) = 1 e (A · A) = 0, conclui-se que
múltiplas ocorrências de um literal em um termo soma ou em um termo produto
acarretam: i) redundância ou ii) funções triviais.
– Portanto, pode-se dizer que, para fins de simplificação, a forma normal é a melhor
forma de representação.
– Além disso, como será abordado a seguir, a forma normal expandida é o ponto de
partida para o processo de simplificação adotado.
• Expansão (combinação de termos):
– Soma de produtos (SOP): combinação de termos produto através do operador OR.
– Produto de somas (POS): combinação de termos soma através do operador AND.
– Soma de produtos normal: SOP onde os termos produto são termos normais.
– Produto de somas normal: POS onde os termos soma são termos normais.
– Forma normal expandida: forma normal (SOP ou POS) onde cada termo é um termo
normal expandido.
• Expansão padrão:
– Em uma forma SOP normal expandida, os termos produto são chamados de:
produtos padrões, produtos canônicos ou mintermos.
– A forma SOP normal expandida recebe as seguintes denominações: SOP padrão,
SOP canônica, soma de mintermos, decomposição em mintermos ou forma
normal disjuntiva completa.
– Em uma forma POS normal expandida, os termos soma são chamados de:
somas padrões, somas canônicas ou maxtermos.
– A forma POS normal expandida recebe as seguintes denominações: POS padrão,
POS canônica, produto de maxtermos, decomposição em maxtermos ou forma
normal conjuntiva completa.
A.S.V.
39
5.3. Obtenção de formas SOP e POS padrões
• Exemplos da definição de mintermos e maxtermos, para três variáveis, são apresentados
na Tabela 5.1 e na Tabela 5.2, respectivamente.
Linha
0
1
2
3
4
5
6
7
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
C
0
1
0
1
0
1
0
1
P roduto
A · B · C
A · B · C
A · B · C
A · B · C
A · B · C
A · B · C
A·B ·C
(A · B · C)
Mintermo
m0
m1
m2
m3
m4
m5
m6
m7
Tabela 5.1: Definição de mintermos para três variáveis (A,B,C).
Linha
0
1
2
3
4
5
6
7
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
C
0
1
0
1
0
1
0
1
Soma
(A + B + C)
A + B + C
A + B + C
A + B + C
A + B + C
A + B + C
A + B + C
A+B+C
Maxtermo
M0 (ou M7 )
M1 (ou M6 )
M2 (ou M5 )
M3 (ou M4 )
M4 (ou M3 )
M5 (ou M2 )
M6 (ou M1 )
M7 (ou M0 )
Tabela 5.2: Definição de maxtermos para três variáveis (A,B,C).
5.3
Obtenção de formas SOP e POS padrões
Dada uma expressão booleana qualquer, pode-se obter uma forma padrão (SOP ou POS) por
meio dos seguintes procedimentos ou de suas combinações: complementação da lista de termos
canônicos, manipulação algébrica e utilização de tabela verdade. Cada um deles é abordado a
seguir.
5.3.1
Complementação da lista de termos canônicos
Dada uma função lógica, cada termo canônico (mintermo ou maxtermo) de uma forma padrão
que a represente é associado a uma linha da sua tabela verdade.
Uma vez que foi adotada uma numeração única para mintermos e maxtermos, associada
com o número da linha da tabela verdade, pode-se facilmente obter a lista do termos canônicos
de um dos dois tipos por complementação numérica
P da lista do outro tipo.
Por exemplo, dada a expressãoQF (A, B, C) = (1, 3, 5) para definir a SOP padrão, pode-se
obter a expressão F (A, B, C) =
(0, 2, 4, 6, 7) para definir a POS padrão, e vice-versa, por
simples complementação numérica.
TET / UFF
40
Capı́tulo 5. Formas padrões para representação de expressões booleanas
5.3.2
Manipulação algébrica
• Para se obter uma forma normal:
– Inicialmente, se houver negação de algum termo que não seja um literal, deve-se
aplicar o teorema de De Morgan.
– Quando houver negação apenas de literais, deve-se aplicar, repetidamente, as regras
de distributividade.
– Finalmente, deve-se eliminar literais e/ou termos redundantes ou triviais.
• Para se obter a forma normal expandida:
– Primeiro, deve-se inserir os literais faltosos nos termos normais. Isso é feito aplicandose os postulados, os lemas e os teoremas da álgebra de Boole sobre a forma normal.
– Em seguida, deve-se eliminar literais e/ou termos redundantes ou triviais.
• Um exemplo do procedimento para a obtenção de uma forma POS padrão é apresentado
na Equação (5.1), para F = f (A, B, C, D).
F = (A + B) · (C · D)
= (A + B) · (C + D)
= (A + B + 0) · (0 + C + D)
= [A + B + (C · C)] · [(B · B) + C + D]
= (A + B + C) · (A + B + C) · (B + C + D) · (B + C + D)
= (A + B + C + 0) · (A + B + C + 0) · (0 + B + C + D) · (0 + B + C + D)
= [A + B + C + (D · D)] · [A + B + C + (D · D)] ·
[(A · A) + B + C + D] · [(A · A) + B + C + D]
= (A + B + C + D) · (A + B + C + D) · (A + B + C + D) ·
(A + B + C + D) · (A + B + C + D) · (A + B + C + D) ·
(A + B + C + D)(A + B + C + D)
= (A + B + C + D) · (A + B + C + D) · (A + B + C + D) ·
(A + B + C + D) · (A + B + C + D) ·
(A + B + C + D)(A + B + C + D)
=
Y
M(0, 1, 2, 3, 11, 7, 15)
(5.1)
A.S.V.
5.3. Obtenção de formas SOP e POS padrões
41
• Um exemplo do procedimento para a obtenção de uma forma SOP padrão é apresentado
na Equação (5.2), para F = f (A, B, C, D).
F = (A + B) · (C · D)
= (A + B) · (C + D)
= [(A + B) · C] + [(A + B) · D]
= [(A · C) + (B · C)] + [(A · D) + (B · D)]
= (A · C) + (B · C) + (A · D) + (B · D)
= (A · 1 · C) + (1 · B · C) + (A · 1 · D) + (1 · B · D)
= [A · (B + B) · C] + [(A + A) · B · C] +
[A · (B + B) · D] + [(A + A) · B · D]
= (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C) +
(A · B · D) + (A · B · D) + (A · B · D) + (A · B · D)
= (A · B · C) + (A · B · C) + (A · B · C) +
(A · B · D) + (A · B · D) + (A · B · D)
= (A · B · C · 1) + (A · B · C · 1) + (A · B · C · 1) +
(A · B · 1 · D) + (A · B · 1 · D) + (A · B · 1 · D)
= [A · B · C · (D + D)] + [A · B · C · (D + D)] + [A · B · C · (D + D)] +
[A · B · (C + C) · D] + [A · B · (C + C) · D] + [A · B · (C + C) · D]
= (A · B · C · D) + (A · B · C · D) + (A · B · C · D) +
(A · B · C · D) + (A · B · C · D) + (A · B · C · D) +
(A · B · C · D) + (A · B · C · D) + (A · B · C · D) +
(A · B · C · D) + (A · B · C · D) + (A · B · C · D)
= (A · B · C · D) + (A · B · C · D) + (A · B · C · D) + (A · B · C · D) +
(A · B · C · D) + (A · B · C · D) + (A · B · C · D) + (A · B · C · D) +
(A · B · C · D)
=
TET / UFF
X
m(13, 12, 9, 8, 5, 4, 14, 10, 6)
(5.2)
42
Capı́tulo 5. Formas padrões para representação de expressões booleanas
5.3.3
Utilização de tabela verdade
A partir de uma tabela verdade, pode-se obter diretamente as formas padrões na forma de
decomposição em mintermos ou maxtermos. Ambas as formas são discutidas a seguir.
Decomposição em mintermos
• Dada uma expressão booleana, pode-se montar uma tabela verdade que a represente,
como demonstrado na Tabela 5.3, para uma função X = f (A, B, C).
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
C
0
1
0
1
0
1
0
1
X
0
1
0
0
1
0
1
0
Y1
0
1
0
0
0
0
0
0
Y2
0
0
0
0
1
0
0
0
Y3
0
0
0
0
0
0
1
0
Linha
0
1
2
3
4
5
6
7
Lógica
A · B · C
A · B · C
A · B · C
A · B · C
A · B · C
A · B · C
A·B·C
(A · B · C)
Mintermo
m0
m1
m2
m3
m4
m5
m6
m7
Tabela 5.3: Exemplo de função e associação de mintermos.
• Da Tabela 5.3, pode-se escrever que
Y1
Y2
Y3
=
=
=
f1 (A, B, C) =
f2 (A, B, C) =
f3 (A, B, C) =
A · B · C = m1
A · B · C = m4
= m6
A·B ·C
e que X = f (A, B, C) = (Y1 ) + (Y2 ) + (Y3).
• Pelas definições apresentadas, as funções auxiliares Yi são mintermos
e a função X pode
P
ser descrita pela forma SOP padrão X = m1 + m4 + m6 = m(1, 4, 6).
• Analisando-se as funções auxiliares Yi, pode-se observar que, para cada combinação das
variáveis, apenas um dos termos produto apresenta um valor lógico 1, enquanto todos os
outros assumem o valor lógico 0. Essa é a razão pela qual tais termos são denominados
produtos canônicos ou mintermos.
• Uma vez que toda expressão booleana é completamente representada por uma tabela
verdade e, a partir da tabela verdade, sempre é possı́vel se obter uma forma SOP padrão,
pode-se enunciar o teorema a seguir.
• Teorema: Qualquer expressão booleana de N variáveis, y = f (x1 , x2 , · · · , xN ), pode ser
expressa por uma forma SOP padrão.
A.S.V.
43
5.3. Obtenção de formas SOP e POS padrões
Decomposição em maxtermos
• Dada uma expressão booleana, pode-se montar uma tabela verdade que a represente,
como demonstrado na Tabela 5.4, para uma função X = f (A, B, C).
A
0
0
0
0
1
1
1
1
B
0
0
1
1
0
0
1
1
C
0
1
0
1
0
1
0
1
X
0
1
0
0
1
0
1
0
Z1
0
1
1
1
1
1
1
1
Z2
1
1
0
1
1
1
1
1
Z3
1
1
1
0
1
1
1
1
Z4
1
1
1
1
1
0
1
1
Z5
1
1
1
1
1
1
1
0
Linha
0
1
2
3
4
5
6
7
Lógica
(A + B + C)
A + B + C
A + B + C
A + B + C
A + B + C
A + B + C
A + B + C
A+B+C
Maxtermo
M0 (ou M7 )
M1 (ou M6 )
M2 (ou M5 )
M3 (ou M4 )
M4 (ou M3 )
M5 (ou M2 )
M6 (ou M1 )
M7 (ou M0 )
Tabela 5.4: Exemplo de função e definição de maxtermos.
• Da Tabela 5.4, pode-se escrever que
Z1
Z2
Z3
Z4
Z5
=
=
=
=
=
f1 (A, B, C)
f2 (A, B, C)
f3 (A, B, C)
f4 (A, B, C)
f5 (A, B, C)
= (A + B + C)
= A + B + C
= A + B + C
= A + B + C
= A+B+C
=
=
=
=
=
M0
M2
M3
M5
M7
e que X = f (A, B, C) = (Z1 ) · (Z2 ) · (Z3 ) · (Z4 ) · (Z5 ).
• Pelas definições apresentadas, as funções auxiliares Zi são maxtermos
Q e a função X pode
ser descrita pela forma POS padrão X = M0 · M2 · M3 · M5 · M7 = M(0, 2, 3, 5, 7).
• Analisando-se as funções auxiliares Zi , pode-se observar que, para cada combinação das
variáveis, apenas um dos termos soma apresenta um valor lógico 0, enquanto todos os
outros assumem o valor lógico 1. Essa é a razão pela qual tais termos são denominados
somas canônicas ou maxtermos.
• Uma vez que toda expressão booleana é completamente representada por uma tabela
verdade e, a partir da tabela verdade, sempre é possı́vel se obter uma forma POS padrão,
pode-se enunciar o teorema a seguir.
• Teorema: Qualquer expressão booleana de N variáveis, y = f (x1 , x2 , · · · , xN ), pode ser
expressa por uma forma POS padrão.
TET / UFF
44
Capı́tulo 5. Formas padrões para representação de expressões booleanas
5.4
5.4.1
Conjuntos de formas padrões
Definição
• Uma expressão booleana pode ser representada por um total de oito formas padrões.
• Uma soma de mintermos (SOP padrão) é identificada como uma forma AND-OR.
• Um produto de maxtermos (POS padrão) é identificado como uma forma OR-AND.
• A partir da forma AND-OR, pode-se obter o seguinte grupo de formas padrões: AND-OR,
NAND-NAND, OR-NAND, NOR-OR.
• A partir da forma OR-AND, pode-se obter o seguinte grupo de formas padrões: OR-AND,
NOR-NOR, AND-NOR, NAND-AND.
5.4.2
Obtenção
• Dentro de um mesmo grupo, as formas podem ser obtidas através da aplicação sucessiva
dos Teoremas de De Morgan.
• A mudança de grupo pode ser realizada aplicando-se a regra de distributividade entre as
formas AND-OR e OR-AND.
• As Tabelas (5.5) a (5.7), exemplificam, para a função XOR, a obtenção do grupo ANDOR, a mudança de grupo e a obtenção do grupo OR-AND, respectivamente.
• Partindo-se da tabela verdade, pode-se obter diretamente algumas formas:
– A soma de mintermos da função fornece a forma AND-OR.
– O produto de maxtermos da função, fornece a forma OR-AND.
– A soma de mintermos da função complementar, fornece a forma AND-NOR
(grupo OR-AND).
– O produto de maxtermos da função complementar, fornece a forma OR-NAND
(grupo AND-OR).
• Assim, uma outra técnica para mudança de grupo é montar a tabela verdade da função,
a partir de uma dada forma. De posse da tabela verdade, pode-se obter uma forma do
outro grupo.
5.4.3
Utilização
• O projeto e a análise de circuitos digitais convencionais são baseados na formação, na
manipulação e na implementação de funções lógicas booleanas. Por dois motivos básicos,
as formas AND-OR e OR-AND são as formas mais utilizadas na representação de tais
funções. Primeiro, ela são diretamente obtidas no processo de especificação do problema.
Segundo, elas são mais próximas da forma como se processa o pensamento (expressão
lógica) do ser humano.
• Por outro lado, as formas NAND-NAND e NOR-NOR são as formas básicas de operação
dos circuitos eletro-eletrônicos usados para implementar as funções lógicas booleanas.
A.S.V.
45
5.4. Conjuntos de formas padrões
• Portanto, transformações entre tais formas são freqüentemente realizadas.
• As formas padrões possuem dois grandes atrativos. Por um lado, e de uma forma geral,
elas apresentam o menor retardo de operação, uma vez que são compostas apenas por
dois planos de lógica. Além disso, elas são o ponto de partida para um processo de
simplificação sistemático e eficiente, conforme será abordado em seguida.
F (A, B) =
=
=
=
=
=
=
Expressão boolena
A ⊕ B
A·B + A·B
A·B + A·B
A·B · A·B
= (A ↑ B) ↑ (A ↑ B)
A+B · A+B
= A+B ↑ A+B
A + B + A + B =
A↓B + A↓B
A·B + A·B
Forma padrão
AND-OR
NAND-NAND
OR-NAND
NOR-OR
AND-OR
Tabela 5.5: Exemplo da obtenção do grupo AND-OR para a função XOR.
F (A, B) =
=
=
=
=
=
=
A ⊕ B
A
· B + A · B
A
·
B
+
A
·
A
·
B
+
B
(A + A) · (B + A) · A + B · B + B
[(1) · (B + A)] · A + B · (1)
(B + A) · A + B
A + B · (A + B)
Tabela 5.6: Exemplo da mudança de grupo para a função XOR.
F (A, B) =
=
=
=
=
=
=
Expressão booleana
A⊕ B
A + B · (A + B)
A + B · (A + B)
A + B + (A + B) = (A ↓ B) ↓ (A ↓ B)
(A · B) + A · B
= (A · B) ↓ A · B
= (A ↑ B) · A ↑ B
(A · B) · A · B
A + B · (A + B)
Forma padrão
OR-AND
NOR-NOR
AND-NOR
NAND-AND
OR-AND
Tabela 5.7: Exemplo da obtenção do grupo OR-AND para a função XOR.
TET / UFF
46
Capı́tulo 5. Formas padrões para representação de expressões booleanas
5.5
Exercı́cios propostos
1. Para os exercı́cios listados abaixo, considerar as equações booleanas apresentadas em
seguida.
(a) Algebricamente, obter a forma SOP normal da equação fornecida.
(b) Algebricamente, obter a forma SOP padrão da equação fornecida.
(c) Expressar a função por uma lista de mintermos.
(d) A partir da SOP padrão, obter as demais formas do seu grupo.
(e) Algebricamente, obter a forma POS normal da equação fornecida.
(f) Algebricamente, obter a forma POS padrão da equação fornecida.
(g) Expressar a função por uma lista de maxtermos.
(h) A partir da POS padrão, obter as demais formas do seu grupo.
(i) Expressar a função por uma tabela verdade, com notação booleana.
Equações boolenas:
i. F (A, B, C) = B · A · C + (A · C) + B + A + C · (A + C) .
nh
i h
io
.
ii. F (A, B, C) = (A + B) + C · A + B + C
A.S.V.
Capı́tulo 6
Simplificação algébrica sistemática de
expressões booleanas
6.1
Expressão mı́nima
Para que se possa propor um processo sistemático para a minimização de expressões, é necessário
que se defina, primeiramente, o que será aceito como expressão mı́nima.
Na busca da expressão mı́nima, serão considerados os seguintes requisitos: i) menor quantidade de circuito necessário à implementação, ii) menor tempo de resposta e iii) existência de
procedimentos sistemáticos de minimização para tais expressões.
No intuito de atender a todos esses requisitos simultaneamente, serão consideradas apenas
as expressões com dois planos de operações lógicas: SOP (AND-OR) e POS (OR-AND).
Uma expressão com dois planos de operações lógicas será considerada mı́nima se:
i) não existir outra expressão desse tipo com um número menor de termos e ii) não existir
outra expressão desse tipo com mesmo número de termos, porém com um número menor de
literais.
Deve ser ressaltado que, se for levado em consideração apenas a quantidade de circuito
necessário à implementação, a definição acima não garante que a expressão final será um mı́nimo
global. Em alguns casos, embora aceita com mı́nima, a expressão encontrada pode representar
um mı́nimo local.
P
Por exemplo, a função F (A, B, C, D) = m(5, 6, 9, 10, 13, 14) pode ser expressa por
e
F (A, B, C, D) = (A + B) · (C · D) + (C · D)
(6.1)
F (A, B, C, D) = (A · C · D) + (A · C · D) + (B · C · D) + (B · C · D) .
(6.2)
Na Equação (6.1), a função é representada por uma expressão booleana genérica. Na Equação (6.2), a expressão booleana encontra-se na forma SOP. Embora a expressão da Equação (6.1)
seja a menor entre as duas, ela apresenta, funcionalmente, um tempo de resposta maior, uma
vez que envolve três planos de operações lógicas. Além disso, não há um processo sistemático para sua obtenção. Portanto, a expressão da Equação (6.2) será considerada a expressão
mı́nima para o processo de minimização descrito a seguir.
Com base nessa definição de forma mı́nima (local), uma determinada função lógica pode ter
diversas expressões mı́nimas equivalentes.
Além disso, não se pode garantir que, para uma dada função, a expressão mı́nima seja da
forma SOP ou da forma POS. É necessário minimizar ambas as formas e escolher a menor delas.
47
48
6.2
Capı́tulo 6. Simplificação algébrica sistemática de expressões booleanas
Simplificação sistemática de expressões booleanas a
partir de SOP e POS padrões
As formas SOP (AND-OR) e POS (OR-AND) apresentam duas grandes vantagens: a facilidade
de descrição do problema durante a sua modelagem e a quantidade de planos de operações
lógicas utilizados na sua implementação. Porém, nem sempre tais formas estão em sua expressão
mais simples, pois, nestes casos, apresentam redundâncias.
A aplicação das operações de aglutinação e de replicação em funções lógicas expressas nas
formas padrões SOP e POS é a base para um processo sistemático de simplificação.
6.2.1
Operações básicas: aglutinação e replicação
No processo sistemático de simplificação algébrica de expressões booleanas, duas operações são
fundamentais: a aglutinação e a replicação, as quais são definidas nas Equações (6.3) e (6.4),
respectivamente. Da Álgebra de Boole, a aglutinação utiliza os Postulados 5, 6 e 3, enquanto
a replicação emprega o Lema 2.
(A · B) + (A · B) = A · (B + B) = A · 1 = A
Aglutinação
(6.3)
(A + B) · (A + B) = A + (B · B) = A + 0 = A
A = A + A + A + ...
Replicação
(6.4)
A = A · A · A · ...
6.2.2
Uso da aglutinação
A propriedade de distributividade mostra que, se dois termos diferem de apenas um literal
(A e A), eles podem ser fatorados. Surgem, desse modo, combinações do literal com seu
complemento. Tais combinações geram valores lógicos 0 ou 1, os quais podem ser eliminados
da expressão. Isto é exemplificado nas Equações (6.3) , (6.5) e (6.6).
F (A, B, C) =
=
=
=
=
=
=
=
F (A, B, C) =
=
=
=
=
=
=
X
m(4, 6)
m4 + m6
(A · B · C) + (A · B · C)
(A · C · B) + (A · C · B)
[(A · C) · B)] + [(A · C) · B)]
(A · C) · (B + B)
(A · C) · (1)
(A · C)
(6.5)
Y
(0, 4)
M0 · M4
(A + B + C) · (A + B + C)
[A + (B + C)] · [A + (B + C)]
(A · A) + (B + C)
(0) + (B + C)
(B + C)
(6.6)
A.S.V.
6.3. Eliminação sistemática de literais
6.2.3
49
Uso da replicação
A operação de replicação possibilita que um mesmo termo seja combinado com diversos outros, para que se possa obter simplificações através da aglutinação. Isto é exemplificado na
Equação (6.7).
F (A, B, C) =
=
=
=
=
=
=
=
=
6.3
X
m(0, 1, 2)
m0 + m1 + m2
(A · B · C) + (A · B · C) + (A · B · C)
m0 + m1 + m2 + m0
(A · B · C) + (A · B · C) + (A · B · C) + (A · B · C)
[(A · B · C) + (A · B · C)] + [(A · B · C) + (A · B · C)]
[(A · B) · (C + C)] + [(A · C) · (B + B)]
(A · B) + (A · C)
A · (B + C)
(6.7)
Eliminação sistemática de literais
• Aplicando-se as operações de aglutinação e de replicação às formas padrões SOP e POS,
vários literais podem ser eliminados.
• A quantidade de literais eliminados depende do número de termos combinados e da configuração de literais em cada termo.
• Eliminação de 1 literal: exceto 1 literal, o qual será eliminado, todos os demais literais
são idênticos em uma combinação de 2 termos normais.
• Eliminação de 2 literais: exceto 2 literais, os quais serão eliminados, todos os demais
literais são idênticos em uma combinação de 4 termos normais.
• Eliminação de 3 literais: exceto 3 literais, os quais serão eliminados, todos os demais
literais são idênticos em uma combinação de 8 termos normais.
• Eliminação de N literais: exceto N literais, os quais serão eliminados, todos os demais
literais são idênticos em uma combinação de 2N termos normais.
• A tı́tulo de exemplo, a Tabela 6.1 apresenta a tabela verdade para funções de 3 variáveis.
• Para tais funções, as Figuras 6.1 e 6.2 ilustram as possibilidades de eliminação de 1 e 2
literais em combinações de 2 e 4 mintermos, respectivamente.
• Por sua vez, as Figuras 6.3 e 6.4 ilustram as possibilidades de eliminação de 1 e 2 literais
em combinações de 2 e 4 maxtermos, respectivamente.
TET / UFF
50
Capı́tulo 6. Simplificação algébrica sistemática de expressões booleanas
Linha
0
1
2
3
4
5
6
7
A B
0 0
0 0
0 1
0 1
1 0
1 0
1 1
1 1
C
0
1
0
1
0
1
0
1
F (A, B, C)
F0
F1
F2
F3
F4
F5
F6
F7
Tabela 6.1: Tabela verdade para funções de 3 variáveis.
m0 + m1
m2 + m3
m4 + m5
m6 + m7
= (A · B · C) + (A · B · C) = (A · B)
= (A · B · C) + (A · B · C) = (A · B)
= (A · B · C) + (A · B · C) = (A · B)
= (A · B · C) + (A · B · C) = (A · B)
m0 + m2
m1 + m3
m4 + m6
m5 + m7
= (A · B · C) + (A · B · C) = (A · C)
= (A · B · C) + (A · B · C) = (A · C)
= (A · B · C) + (A · B · C) = (A · C)
= (A · B · C) + (A · B · C) = (A · C)
m0 + m4
m1 + m5
m2 + m6
m3 + m7
= (A · B · C) + (A · B · C) = (B · C)
= (A · B · C) + (A · B · C) = (B · C)
= (A · B · C) + (A · B · C) = (B · C)
= (A · B · C) + (A · B · C) = (B · C)
Figura 6.1: Eliminações de 1 literal em combinações de 2 mintermos.
m0 + m1 + m2 + m3 = (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C) = (A)
m4 + m5 + m6 + m7 = (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C) = (A)
m0 + m1 + m4 + m5 = (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C) = (B)
m2 + m3 + m6 + m7 = (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C) = (B)
m0 + m2 + m4 + m6 = (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C) = (C)
m1 + m3 + m5 + m7 = (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C) = (C)
Figura 6.2: Eliminações de 2 literais em combinações 4 de mintermos.
A.S.V.
6.3. Eliminação sistemática de literais
M0 · M1
M2 · M3
M4 · M5
M6 · M7
= (A + B + C) · (A + B + C) = (A + B)
= (A + B + C) · (A + B + C) = (A + B)
= (A + B + C) · (A + B + C) = (A + B)
= (A + B + C) · (A + B + C) = (A + B)
M0 · M2
M1 · M3
M4 · M6
M5 · M7
= (A + B + C) · (A + B + C) = (A + C)
= (A + B + C) · (A + B + C) = (A + C)
= (A + B + C) · (A + B + C) = (A + C)
= (A + B + C) · (A + B + C) = (A + C)
M0 · M4
M1 · M5
M2 · M6
M3 · M7
= (A + B + C) · (A + B + C) = (B + C)
= (A + B + C) · (A + B + C) = (B + C)
= (A + B + C) · (A + B + C) = (B + C)
= (A + B + C) · (A + B + C) = (B + C)
Figura 6.3: Eliminações de 1 literal em combinações de 2 maxtermos.
M0 · M1 · M2 · M3 = (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C) = (A)
M4 · M5 · M6 · M7 = (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C) = (A)
M0 · M1 · M4 · M5 = (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C) = (B)
M2 · M3 · M6 · M7 = (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C) = (B)
M0 · M2 · M4 · M6 = (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C) = (C)
M1 · M3 · M5 · M7 = (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C) = (C)
Figura 6.4: Eliminações de 2 literais em combinações 4 de maxtermos.
TET / UFF
51
52
6.4
Capı́tulo 6. Simplificação algébrica sistemática de expressões booleanas
Processo sistemático de simplificação
O ponto de partida do processo é expressar a função lógica nas formas SOP padrão e POS
padrão. Em seguida, a operação de aglutinação é aplicada sucessivamente. Sempre que possı́vel,
a operação de replicação deve ser empregada, para maximizar a simplificação das expressão.
Quando mais nenhuma aglutinação puder ser efetuada, a expressão restante será, naturalmente,
a expressão definida anteriormente como mı́nima.
No caso da existência de diversas formas mı́nimas equivalentes, deve-se aplicar algum critério
extra para a escolha final.
O processo em questão ainda apresenta um certo grau de subjetividade: a escolha dos termos
a serem replicados e a escolha dos termos a serem aglutinados.
A fim de tornar o processo de minimização ainda menos subjetivo, pode-se realizá-lo não
diretamente sobre as equações, mas, alternativamente, sobre uma forma pictórica de representação ou através de um procedimento computacional. Em ambos os casos, as operações básicas
são as mesmas, porém realizadas sobre outras formas de expressão. As alternativas comumente
empregadas são o Mapa de Karnaugh e o Algoritmo de Quine-McCluskey.
6.5
Implicantes e implicados
Quando uma função é expressa na forma SOP (AND-OR) ou POS (OR-AND), seus termos
recebem uma denominação adicional, de acordo com o valor lógico que eles geram na tabela
verdade da função: implicantes ou implicados. Tal denominação é descrita a seguir.
6.5.1
Implicantes
Quando uma função é expressa na forma SOP (AND-OR), cada termo produto é denominado
de implicante (implicant). O nome se deve ao fato de que, caso o termo produto (implicante)
assuma o valor lógico 1, isso implicará em um valor lógico 1 para a função.
No caso de uma SOP padrão, os implicantes são os próprios mintermos. Caso contrário,
eles são o resultado de simplificações provenientes de combinações de mintermos.
A Equação (6.8) apresenta um exemplo de implicantes. Na primeira expressão, ela apresenta
3 implicantes, que são os mintermos responsáveis pelas 3 combinações lógicas de literais que
fazem a função assumir o valor lógico 1. A segunda expressão apresenta 2 implicantes. O
primeiro deles, sendo uma combinação de 2 mintermos, representa 2 combinações lógicas de
literais capazes de produzir um valor lógico 1 para a função. O segundo deles, sendo um dos
mintermos, representa a terceira combinação lógica de literais capaz de produzir um valor lógico
1 para a função.
F (A, B, C) =
X
m(0, 1, 7)
= (A · B · C) + (A · B · C) + (A · B · C)
= (A · B) + (A · B · C)
(6.8)
A.S.V.
53
6.5. Implicantes e implicados
6.5.2
Implicados
Quando uma função é expressa na forma POS (OR-AND), cada termo soma é denominado de
implicado (implicate). O nome se deve ao fato de que, caso o termo soma (implicado) assuma
o valor lógico 0, isso implicará em um valor lógico 0 para a função.
No caso de um POS padrão, os implicados são os próprios maxtermos. Caso contrário, eles
são o resultado de simplificações provenientes de combinações de maxtermos.
A Equação (6.9) apresenta um exemplo de implicados. Na primeira expressão, ela apresenta
3 implicados, que são os maxtermos responsáveis pelas 3 combinações lógicas de literais que
fazem a função assumir o valor lógico 0. A segunda expressão apresenta 2 implicados. O
primeiro deles, sendo uma combinação de 2 maxtermos, representa 2 combinações lógicas de
literais capazes de produzir um valor lógico 0 para a função. O segundo deles, sendo um dos
maxtermos, representa a terceira combinação lógica de literais capaz de produzir um valor lógico
0 para a função.
F (A, B, C) =
Y
M(2, 3, 5)
= (A + B + C) · (A + B + C) · (A + B + C)
= (A + B) · (A + B + C)
6.5.3
(6.9)
Implicantes, implicados e o processo de simplificação
Pela definição apresentada, os termos normais expandidos das formas SOP padrão e POS padrão
são implicantes e implicados que geram, respectivamente, apenas um único valor lógico “1” e
“0” na tabela verdade da função por eles especificada.
A associação de 2n implicantes ou implicados quaisquer, com o intuito de eliminar n literais,
resulta em um único implicante ou implicado. acarretando a diminuição do número de tais
termos.
Além disso, cada novo implicante e implicado, gerado pela associação de 2n termos normais
expandidos, passa a ser responsável, respectivamente, pela geração de 2n valores lógicos “1” e
“0” na tabela verdade da função por eles especificada.
Assim sendo, o processo de simplificação definido acima pode ser pensado como a busca do
menor número possı́vel de implicantes e implicados, cada um deles apresentando o menor número possı́vel de literais e, conseqüentemente, cada um deles gerando, respectivamente, o maior
número possı́vel de valores lógicos “1” e “0” na tabela verdade da função por eles especificada.
TET / UFF
54
Capı́tulo 6. Simplificação algébrica sistemática de expressões booleanas
6.6
Exercı́cios propostos
1. Para os exercı́cios listados abaixo, considerar as equações booleanas apresentadas em
seguida.
(a) Algebricamente, obter a forma SOP padrão da equação fornecida.
(b) Algebricamente, obter a forma SOP mı́nima, a partir da SOP padrão.
(c) Algebricamente, obter a forma POS padrão da equação fornecida.
(d) Algebricamente, obter a forma POS mı́nima, a partir da POS padrão.
(e) Apresentar a expressão mı́nima para função.
Equações boolenas:
i. F (A, B, C) = B · A · C + (A · C) + B + A + C · (A + C) .
i h
nh
io
ii. F (A, B, C) = (A + B) + C · A + B + C
.
A.S.V.
Capı́tulo 7
Mapa de Karnaugh
7.1
Introdução
• O mapa de Karnaugh (mapa-K) é mais uma das possı́veis expressões de uma função
lógica, além de uma equação lógica genérica, uma equação booleana genérica, uma forma
do grupo SOP, uma forma do grupo POS, uma forma padrão do grupo SOP, uma forma
padrão do grupo POS, uma lista de mintermos, uma lista de maxtermos e uma tabela
verdade.
• Além de representar uma simples expressão para uma função lógica, o mapa-K pode ser
usado como ferramenta para a minimização da equação que a define.
• Ele pode ser interpretado como uma tabela verdade rearranjada ou como uma representação análoga ao Diagrama de Venn.
• Para cada linha da tabela verdade de uma função lógica booleana é associada uma posição
no mapa.
• Uma vez que cada linha da tabela verdade é associada a um mintermo ou a um maxtermo,
a cada um deles também é associada uma posição do mapa.
• A fim de que o mapa seja empregado no processo de simplificação de funções lógicas
booleanas, ele deve ser arranjado da seguinte forma:
– Deve existir uma localização única no mapa para cada combinação das variáveis das
quais a função lógica é dependente.
– As localizações devem ser arranjadas de tal forma que grupos de mintermos/maxtermos
possam ser facilmente combinados em formas reduzidas.
• Devido a uma limitação prática, são construı́dos mapas-K para funções lógicas de até 6
variáveis.
• Para funções lógicas com um número superior a 6 variáveis, pode-se utilizar um algoritmo
de minimização, tal como o algoritmo tabular de Quine-McCluskey.
55
56
7.2
7.2.1
Capı́tulo 7. Mapa de Karnaugh
Construção do mapa-K
Funções de 1 variável
Linha
0
1
A
0
1
F (A)
F0
F1
Tabela 7.1: Tabela verdade para funções de 1 variável.
A
F0
A
F1
A
F1
A
F0
A
←→
0
F0
1
F1
A
←→
1
F1
0
F0
Figura 7.1: Exemplos de mapas de Karnaugh para funções de 1 variável.
A.S.V.
57
7.2. Construção do mapa-K
7.2.2
Funções de 2 variáveis
Linha
0
1
2
3
A
0
0
1
1
B
0
1
0
1
F (A, B)
F0
F1
F2
F3
Tabela 7.2: Tabela verdade para funções de 2 variáveis.
A
B
F0
A
F2
F3
A
A
B
F0
F2
B
F1
F3
A
←→
B
0
0 F0
1 F1
1
F2
F3
B
←→
A
0
0 F0
1 F2
1
F1
F3
A
B
F1
B
F3
B
A
F0
B
B
A
F0
F1
B
F2
←→
AB
F0
AB
F1
AB
F3
AB
F2
←→
00
F0
AB
01 11
F1 F3
10
F2
00
F0
BA
01 11
F2 F3
10
F1
B
A
F2
A
F3
A
F1
←→
BA BA
F0
F2
BA
F3
BA
F1
←→
Figura 7.2: Exemplos de mapas de Karnaugh para funções de 2 variáveis.
TET / UFF
58
Capı́tulo 7. Mapa de Karnaugh
7.2.3
Funções de 3 variáveis
Linha
0
1
2
3
4
5
6
7
A B
0 0
0 0
0 1
0 1
1 0
1 0
1 1
1 1
C
0
1
0
1
0
1
0
1
F (A, B, C)
F0
F1
F2
F3
F4
F5
F6
F7
Tabela 7.3: Tabela verdade para funções de 3 variáveis.
A
C
C
B
F0
F1
C
C
A
F0
F1
A
B
F2
F3
B
F6
F7
A
F2
F3
A
F6
F7
B
B
F4
F5
↔
C
C
AB
F0
F1
AB
F2
F3
AB
F6
F7
AB
F4
F5
C
C
BA BA
F0
F2
F1
F3
BA
F6
F7
BA
F4
F5
↔
C
00
0 F0
1 F1
AB
01 11
F2 F6
F3 F7
10
F4
F5
C
00
0 F0
1 F1
BA
01 11
F4 F6
F5 F7
10
F2
F3
B
A
F4
F5
↔
↔
Figura 7.3: Exemplos de mapas de Karnaugh para funções de 3 variáveis.
A.S.V.
59
7.2. Construção do mapa-K
7.2.4
Funções de 4 variáveis
Linha
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
A
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
B
0
0
0
0
1
1
1
1
0
0
0
0
1
1
1
1
C
0
0
1
1
0
0
1
1
0
0
1
1
0
0
1
1
D
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
F (A, B, C, D)
F0
F1
F2
F3
F4
F5
F6
F7
F8
F9
F10
F11
F12
F13
F14
F15
Tabela 7.4: Tabela verdade para funções de 4 variáveis.
TET / UFF
60
Capı́tulo 7. Mapa de Karnaugh
A
C
C
D
D
D
D
B
F0
F1
F3
F2
A
B
F4
F5
F7
F6
B
F12
F13
F15
F14
B
F8
F9
F11
F10
←→
C
C
C
C
D
D
D
D
AB
F0
F1
F3
F2
AB
F4
F5
F7
F6
AB
F12
F13
F15
F14
AB
F8
F9
F11
F10
AB
11
F12
F13
F15
F14
10
F8
F9
F11
F10
l
CD
00
01
11
10
00
F0
F1
F3
F2
01
F4
F5
F7
F6
Figura 7.4: Exemplos de mapas de Karnaugh para funções de 4 variáveis.
7.3
Preenchimento do mapa-K
• Cada uma das localizações do mapa é associada a cada uma das combinações das variáveis
das quais a função é dependente.
• Isso equivale a dizer que cada uma das localizações do mapa é associada a uma linha da
tabela verdade da função.
• Logo, cada uma das localizações do mapa é preenchida com o respectivo valor lógico da
função (0 ou 1).
• Para montar e simplificar uma forma SOP, deve-se manter os valores lógicos 1 (mintermos)
no mapa e ignorar os valores lógicos 0 (maxtermos).
• Para montar e simplificar uma forma POS, deve-se manter os valores lógicos 0 (maxtermos) no mapa e ignorar os valores lógicos 1 (mintermos).
7.4
Mapa-K como forma de expressão de função booleana
Uma função de variáveis booleanas pode ser expressa por uma equação genérica, por uma forma
do grupo SOP, por uma forma do grupo POS, por uma forma padrão do grupo SOP, por uma
forma padrão do grupo POS por uma lista de mintermos, por uma lista de maxtermos e por
uma tabela verdade.
Além de ser usado como ferramenta de minimização, o mapa-K pode ser visto como mais
uma alternativa de representação para funções booleanas.
As transformações entre: i) uma equação genérica, ii) uma forma dos grupos SOP ou POS e
iii) uma forma padrão dos grupos SOP ou POS, envolvem manipulação algébrica das equações.
Por outro lado, as transformações realizadas entre uma lista de mintermos ou maxtermos,
uma tabela verdade, um mapa-K e as demais representações, envolvem catalogação direta.
Portanto, partindo-se de uma dada forma de representação, pode-se facilmente obter todas
as demais, independentemente do tipo de mapeamento utilizado.
A.S.V.
7.4. Mapa-K como forma de expressão de função booleana
61
Um exemplo de tais relacionamentos pode ser obtido a partir da função dada por
F (A, B, C) = A + (B + C) .
(7.1)
F (A, B, C) = (A) · (B + C)
(7.2)
F (A, B, C) = (A · B) + (A · C) .
(7.3)
Após alguma manipulação algébrica, a Equação (7.1) pode gerar a forma POS
e a forma SOP
Expandindo-se os termos das Equações (7.2) e (7.3), obtém-se, respectivamente, a forma
padrão POS
F (A, B, C) = (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C) · (A + B + C)
Y
=
M(0, 1, 2, 3, 4)
(7.4)
e a forma padrão SOP
F (A, B, C) = (A · B · C) + (A · B · C) + (A · B · C)
X
=
m(5, 6, 7) .
Por sua vez, a tabela verdade referente à Equação (7.1) é apresentada na Tabela 7.5.
Linha
0
1
2
3
4
5
6
7
A B
0 0
0 0
0 1
0 1
1 0
1 0
1 1
1 1
C
0
1
0
1
0
1
0
1
F (A, B, C)
0
0
0
0
0
1
1
1
Tabela 7.5: Tabela verdade relativa à Equação (7.1).
Finalmente, o mapa-K da função é mostrado na Figura 7.5.
C
0
1
AB
00 01 11 10
0 0 1 0
0 0 1 1
Figura 7.5: Mapa de Karnaugh relativo à Equação (7.1).
TET / UFF
(7.5)
62
7.5
7.5.1
Capı́tulo 7. Mapa de Karnaugh
Mapa-K na simplificação de expressões booleanas
Adjacência lógica, aglutinação e replicação
A simplificação algébrica de expressões booleanas baseia-se na utilização de duas operações: a
aglutinação e a replicação.
Se dois termos diferem de apenas um literal (A e A), a aplicação da aglutinação permite
simplificá-los em um único termo, sem o literal em questão. Tais termos são ditos logicamente
adjacentes. Isso pode ser exemplificado por
F (A, B, C) = (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C)
= (B · C) + (B · C) .
(7.6)
Por sua vez, a replicação permite que um mesmo termo seja utilizado em simplificações
envolvendo diversos outros termos. Um exemplo de replicação é dado por
F (A, B, C) = (A · B · C) + (A · B · C) + (A · B · C)
= (A · B · C) + (A · B · C) + (A · B · C) + (A · B · C)
= (A · C) + (B · C) .
(7.7)
Os mapas de Karnaugh são construı́dos de tal forma que as adjacências geométricas do
mapa são equivalentes às adjacências lógicas dos termos das equações. Portanto, a combinação
algébrica dos termos de uma equação é equivalente à combinação de termos adjacentes do mapa.
Assim sendo, a equação pode ser simplificada através da leitura direta da informação do mapa.
O mapa da Figura 7.6 exemplifica a Equação (7.6), onde são realizadas as combinações m0 + m4
e m3 + m7 .
C
0
1
AB
00 01 11 10
1 0 0 1
0 1 1 0
Figura 7.6: Mapa de Karnaugh relativo à Equação (7.6).
No mapa, a replicação é interpretada como a combinação de um termo com os demais geometricamente adjacentes. O mapa da Figura 7.7 exemplifica a Equação (7.7), onde o mintermo
m0 é replicado para as combinações m0 + m2 e m0 + m4 .
C
0
1
AB
00 01 11 10
1 1 0 1
0 0 0 0
Figura 7.7: Mapa de Karnaugh relativo à Equação (7.7).
A.S.V.
7.5. Mapa-K na simplificação de expressões booleanas
7.5.2
63
Seleção sistemática de termos (implicantes ou implicados)
Para as equações que possuem uma forma mı́nima única, duas definições são de grande auxı́lio
na escolha de termos (implicantes ou implicados) a serem agrupados para simplificação: termo
essencial e termo primo.
Quando um termo original é coberto por um único agrupamento possı́vel, o termo resultante
do agrupamento é denominado de termo essencial. Isso indica que ele deve ser incluı́do na
expressão mı́nima que expressa a função desejada.
Um termo que não tenha sido coberto por qualquer agrupamento anterior deve ser incluı́do
em um agrupamento máximo, o qual será denominado de termo primo.
Pode-se concluir que todo termo essencial deve ser primo (máximo), mas nem todo termo
primo (máximo) é essencial.
Assim, uma forma sistemática de escolha de termos é:
S1 - Identificar todas as possibilidades de agrupamento, através dos maiores grupos
possı́veis.
S2 - Marcar todos os termos originais cobertos por apenas 1 agrupamento. Tais
agrupamentos formam os termos essenciais.
S3 - Listar todos os termos essenciais.
S4 - Usar os maiores agrupamentos possı́veis (termos primos) para cobrir os termos
originais não cobertos pelos termos essenciais.
S5 - Listar apenas tais termos primos.
S6 - Montar a expressão mı́nima, a partir das duas listas.
Dada uma função, e suas formas SOP e POS, nada se pode garantir em relação a qual das
duas conduzirá à expressão mais simples. Assim, é necessário encontrar a forma mı́nima de
ambas e decidir qual delas é a mais simples.
7.5.3
Mapa-K de funções com múltiplos mı́nimos e mapa cı́clico
Algumas equações booleanas não possuem uma forma mı́nima única. Isso acontece porque, em
um conjunto de termos da expressão, cada um deles é coberto por mais de um agrupamento de
termos logicamente equivalentes. Assim sendo, não é possı́vel selecionar um conjunto único de
termos essenciais e/ou primos.
Em tais casos, o que se deve fazer é avaliar as possı́veis soluções e escolher a de menor custo.
Caso ainda existam opções logicamente equivalentes, todas de mesmo custo, deve-se adotar
algum critério extra de escolha.
A Figura 7.8 apresenta um mapa com múltiplas formas mı́nimas, envolvendo o termo m2 ,
que possui duas soluções de mesmo custo: i) (m0 + m4 ), (m3 + m7 ), (m0 + m2 ) e ii) (m0 +
m4 ), (m3 + m7 ), (m3 + m2 ).
Em alguns casos particulares, todos os termos de um subconjunto dos termos da função
são cobertos por mais de um agrupamento, todos de mesmo custo. Tal subconjunto de termos
forma um ciclo. Mapas de funções com tal caracterı́stica são denominados de mapas cı́clicos.
Nesses casos, deve-se adotar algum critério extra de escolha para quebrar o ciclo.
A Figura 7.9 apresenta um mapa com ciclo, que possui duas soluções de mesmo custo: i)
(m0 + m2 ), (m3 + m7 ), (m4 + m5 ) e ii) (m0 + m4 ), (m2 + m3 ), (m5 + m7 ).
TET / UFF
64
Capı́tulo 7. Mapa de Karnaugh
C
0
1
AB
00 01 11 10
1 1 0 1
0 1 1 0
Figura 7.8: Mapa de Karnaugh com múltiplas formas mı́nimas.
C
0
1
AB
00 01 11 10
1 1 0 1
0 1 1 1
Figura 7.9: Mapa de Karnaugh com ciclo.
7.5.4
Indeterminações: don’t-care e can’t-happen
Em alguns problemas, as funções booleanas podem não ser completamente especificadas. Nesses
casos, duas situações podem ocorrer. Na primeira delas, para uma dada combinação de valores
dos literais, o valor da função não é relevante (don’t-care). Por outro lado, pode acontecer que
uma determinada combinação de literais nunca ocorra (can’t-happen). Em ambas as situações,
pode-se especificar livremente qualquer um dos valores lógicos para a função. Na realidade,
atribui-se um valor lógico indeterminado X, caracterizando-se o aspecto indeterminado da sua
especificação.
Os valores indeterminados podem ser utilizados no processo de simplificação de formas
padrões contendo mintermos ou maxtermos.
A Tabela 7.6 exemplifica uma função incompletamente especificada, a qual também pode
ser expressa por
F (A, B, C) =
X
m(0, 3, 4) +
X
d(2, 7) =
Y
M(1, 5, 6) ·
Y
d(2, 7) .
(7.8)
As Figuras 7.10–7.12 ilustram os mapas de Karnaugh da função, de seus mintermos e de
seus maxtermos, respectivamente.
Linha
0
1
2
3
4
5
6
7
A B
0 0
0 0
0 1
0 1
1 0
1 0
1 1
1 1
C
0
1
0
1
0
1
0
1
F (A, B, C)
1
0
X
1
1
0
0
X
Tabela 7.6: Tabela verdade de função incompletamente especificada.
A.S.V.
7.5. Mapa-K na simplificação de expressões booleanas
C
0
1
65
AB
00 01 11 10
1 X 0 1
0 1 X 0
Figura 7.10: Mapa de Karnaugh da Tabela 7.6.
C
0
1
AB
00 01 11 10
1 X
1
1 X
Figura 7.11: Mapa de Karnaugh dos mintermos da Tabela 7.6.
C
0
1
AB
00 01 11 10
X 0
0
X 0
Figura 7.12: Mapa de Karnaugh dos maxtermos da Tabela 7.6.
Da configuração de mintermos apresentada no mapa da Figura 7.11, pode-se escrever que
F (A, B, C) =
X
m(0, 3, 4) +
X
d(2, 7)
= (m0 + m4 ) + (m3 + d2 ) = (B · C) + (A · B)
= (m0 + m4 ) + (m3 + d7 ) = (B · C) + (B · C) .
(7.9)
Da configuração de maxtermos apresentada no mapa da Figura 7.12, pode-se escrever que
F (A, B, C) =
Y
M(1, 5, 6) ·
Y
d(2, 7)
= (M1 · M5 ) · (M6 · d2 ) = (B + C) · (B + C)
= (M1 · M5 ) · (M6 · d7 ) = (B + C) · (A + B) .
(7.10)
As Equações 7.9 e 7.10 mostram que os valores lógicos indeterminados podem ser usados,
ou não, no processo de simplificação. Elas ilustram ainda o papel relevante dos valores indeterminados na simplificação de funções booleanas.
Deve ser ressaltado que, uma vez escolhidos como “0” ou como “1”, os valores indeterminados
“X”, bem como a função original, perdem a sua caracterı́stica de indeterminação na expressão
mı́nima. Assim sendo, a função minimizada final passa a ser completamente especificada.
TET / UFF
66
Capı́tulo 7. Mapa de Karnaugh
7.6
Exercı́cios propostos
1. Para os exercı́cios listados abaixo, considerar as equações booleanas apresentadas em
seguida.
(a) Obter a forma SOP padrão da equação fornecida.
(b) Obter a forma SOP mı́nima, utilizando o mapa de Karnaugh correspondente.
(c) Obter a forma POS padrão da equação fornecida.
(d) Obter a forma POS mı́nima, utilizando o mapa de Karnaugh correspondente.
(e) Apresentar a expressão mı́nima para função.
Equações boolenas:
i. F (A, B, C) = B · A · C + (A · C) + B + A + C · (A + C) .
nh
i h
io
.
ii. F (A, B, C) = (A + B) + C · A + B + C
2. Para os exercı́cios listados abaixo, considerar as equações booleanas apresentadas em
seguida.
(a) Obter a forma SOP mı́nima, utilizando o mapa de Karnaugh correspondente.
(b) Obter a forma POS mı́nima, utilizando o mapa de Karnaugh correspondente.
(c) Apresentar a expressão mı́nima para função.
Equações boolenas:
P
i. F (A, B, C) = m(0, 2, 3, 5, 7)
P
ii. F (A, B, C) = m(0, 1, 3, 4, 5)
P
iii. F (A, B, C) = m(0, 1, 2, 4, 6, 7)
P
iv. F (A, B, C, D) = m(4, 5, 11, 13, 15)
P
v. F (A, B, C, D) = m(0, 1, 5, 6, 7, 14)
P
vi. F (A, B, C, D) = m(0, 1, 2, 6, 7, 8, 9, 10, 14)
P
vii. F (A, B, C, D) = m(0, 1, 2, 5, 6, 7, 8, 9, 10, 14)
P
viii. F (A, B, C, D) = m(0, 1, 2, 6, 7, 8, 9, 10, 14, 15)
P
ix. F (A, B, C, D) = m(0, 1, 2, 5, 6, 7, 8, 9, 10, 14, 15)
P
x. F (A, B, C, D) = m(0, 1, 2, 5, 6, 7, 8, 9, 10, 13, 14, 15)
P
xi. F (A, B, C, D) = m(0, 2, 6, 7, 8, 9, 10, 12, 13)
P
xii. F (A, B, C, D) = m(0, 2, 6, 7, 8, 9, 10, 12, 13, 15)
P
xiii. F (A, B, C, D) = m(0, 1, 2, 3, 5, 7, 15)
P
xiv. F (A, B, C, D) = m(0, 1, 2, 3, 5, 7, 14, 15)
P
xv. F (A, B, C, D) = m(0, 1, 2, 3, 5, 7, 11, 15)
P
xvi. F (A, B, C, D) = m(0, 1, 2, 3, 5, 7, 13, 15)
P
xvii. F (A, B, C, D) = m(0, 2, 5, 6, 8, 10, 13)
P
xviii. F (A, B, C, D) = m(0, 2, 5, 7, 8, 10, 11, 13, 15)
P
xix. F (A, B, C, D) = m(1, 5, 6, 7, 11, 12, 13, 15)
P
xx. F (A, B, C, D) = m(2, 3, 4, 5, 6, 7, 10, 12, 13, 15)
P
xxi. F (A, B, C, D) = m(1, 2, 4, 6, 7, 9, 11, 12, 13, 14, 15)
A.S.V.
Capı́tulo 8
Sistemas de numeração
8.1
Introdução
• Sistema numérico (number system) × sistema de numeração (numeral system).
• Sistemas numéricos classificam o tipo da quantidade numérica: N, Z, Q, R, C, etc..
• Sistemas de numeração tratam da representação da quantidade numérica: grupos de
numerais (sı́mbolos) que representam quantidades.
• Máquinas digitais possuem capacidade de armazenamento finito. Um registro só pode
armazenar uma quantidade finita de elementos básicos de informação e a máquina só pode
armazenar uma quantidade finita de registros. Portanto, toda quantidade armazenada
será uma aproximação da quantidade original. O sistema de numeração utilizado pela
máquina tem influência direta na qualidade dessa aproximação.
• Da mesma forma, a eficiência de uma determinada implementação para as operações
aritméticas básicas (adição, subtração, multiplicação e divisão) também é influenciada
pelo sistema de numeração utilizado pela máquina. Deve ser ressaltado que a eficiência
é, geralmente, medida em relação ao tempo necessário para a realização da operação, à
quantidade de elementos constituintes utilizados, aos tipos de tais elementos e ao consumo
de energia.
• Assim, através da escolha adequada entre as diversas alternativas matemáticas para a
representação de quantidades, bem como da sua implementação (máquina e linguagem
de programação), procura-se reduzir o erro das aproximações e/ou tornar as operações
aritméticas mais eficientes.
• Sistemas comumente usados em máquinas digitais:
– Posicional.
– Resı́duos (ou resto).
– Racional.
– Logarı́tmico.
67
68
Capı́tulo 8. Sistemas de numeração
• Sistemas de numeração posicional
– Sistema vetorial posicional.
– É definido um conjunto básico de dı́gitos ou sı́mbolos S = {s1 , s2 , · · · , sM }.
– Os números x são representados por grupos de dı́gitos (vetores) pertencentes a S:
x = [dN , · · · , d2 , d1 ]S , onde di ∈ S.
– A posição de cada dı́gito no vetor tem significado.
– A cada posição i é associado um peso numérico wi , o qual é multiplicado pelo dı́gito
di correspondente: w = [wN , · · · , w2 , w1].
– Os dı́gitos di representam números inteiros, podendo ser positivos e/ou negativos.
– Os pesos podem ser os mais diversos possı́veis.
• Sistemas de numeração de resı́duos (ou restos)
– Sistema vetorial não posicional.
– É definido um vetor de elementos primos entre si dois a dois: m = [m1 , m2 , · · · , mN ].
– São calculados os resı́duos (restos) ri da divisão de um número inteiro x por cada
elemento mi .
– Os números x são representados por um vetor contendo os resı́duos: x = [r1 , r2 , · · · , rN ]m .
– Nas operações aritméticas, os resı́duos podem ser tratados independentemente, acelerando o processo de cálculo.
• Sistemas de numeração racional
– Representação de números através de frações.
– Numerador e denominador da fração são representados por números inteiros.
– As operações aritméticas são realizadas sem erro, mesmo em uma máquina com
precisão finita.
• Sistemas de numeração logarı́tmico
– Um número real µ > 1 é definido como base.
– É gerado um conjunto de números reais Lµ = {x | |x| = µi , i ∈ Z} U {0}.
– É objetivada uma melhoria de precisão na representação dos números, conseguida
através de arredondamento geométrico.
A.S.V.
69
8.2. Sistema de numeração posicional convencional
8.2
Sistema de numeração posicional convencional
Nos itens que se seguem, são abordados diversos aspectos do sistema de numeração posicional
convencional (SNPC):
• Representação de números com partes inteira e fracionária.
• Representação de números positivos, nulos e negativos.
• Tabelas de operações básicas entre dı́gitos.
• Escalamento por potência inteira da base.
• Conversão entre bases.
• Bases mais comuns em circuitos digitais.
8.2.1
Representação de números inteiros não negativos
Para representar quantidades numéricas inteiras, ordenadas e não negativas, o sistema de numeração posicional convencional utiliza um conjunto ordenado e não negativo de sı́mbolos simples
(dı́gitos) di ∈ S = {s1 , s2 , · · · , sM } = {0, 1, 2, · · · , (b − 1)}, juntamente com uma técnica de
poderação ou escala. O número de elementos de S, M = b, é denominado base ou radical
(radix) do sistema de numeração. Os pesos ou fatores de escala utilizados são potências inteiras
da base wi ∈ W = {w1 , w2 , w3 , · · ·} = {b0 , b1 , b2 , · · ·}.
Uma visão geométrica modular do processo de representação pode ser encontrada nas
Figuras 8.1 – 8.4, para b = 3. Para representar cada uma das quantidades q < b, é utilizado apenas um dos elementos de S, como na Figura 8.1. Para as quantidades q ≥ b, como não
existem outros sı́mbolos disponı́veis, repetem-se os elementos de S, em módulos de comprimento
b, como exemplificado na Figura 8.2. Porém, isso gera ambigüidade na representação, a qual
é resolvida através da combinação de sı́mbolos, como ilustrado na Figura 8.3. Agora, a cada
módulo de b sı́mbolos, no nı́vel básico de representação L = 0, são justapostos os elementos de
S, formando um novo nı́vel de representação L = 1. Essa técnica é aplicada, sucessivamente,
cada vez que o número de possibilidades de representação em um determinado nı́vel L se esgota
e uma nova ambigüidade é gerada pela repetição de sı́mbolos, como é apresentado na Figura 8.4.
Em cada nı́vel da representação existe um módulo formado pelos sı́mbolos de S. Devido à
lei de formação empregada, o comprimento do módulo em cada nı́vel é uma versão escalada dos
comprimentos dos módulos dos nı́veis inferiores. Os fatores de escala são as potências inteiras
da base W = {b0 , b1 , b2 , · · ·}. As mudanças de sı́mbolos, dentro de cada nı́vel, são reguladas
pelo fator de escala do nı́vel. Dessa forma, dentro de cada nı́vel L = 0, 1, 2, ..., (N − 1), ocorre
uma mudança de sı́mbolos a cada bL unidades da quantidade representada.
0 1
2
Figura 8.1: Representação de quantidades q < b, para b = 3.
0 1
2 0 1
2 0
1 2
Figura 8.2: Representação de quantidades q ≥ b, para b = 3, com ambigüidade.
TET / UFF
70
Capı́tulo 8. Sistemas de numeração
0 1
0
2 0 1
1
2 0
1 2
2
Figura 8.3: Representação de quantidades q ≥ b, para b = 3, com eliminação da ambigüidade
através da justaposição dos dı́gitos.
0
1 2 0
0
1 2
1
0
0 1 2
2
0 1
0
2 0 1
1
1
2 0
1 2 0
2
1 2
0
0 1 2
1
2
0 1
2
2
Figura 8.4: Uso repetido da técnica de justaposição de dı́gitos para representação de quantidades
q ≥ b, para b = 3, sem ambigüidade.
Algebricamente, a idéia geométrica modular de uma combinação de nı́veis pode ser expressa
por uma soma de nı́veis de valores, onde o valor numérico de cada nı́vel k é expresso por um
dı́gito dk ∈ S, ponderado por um fator wk ∈ W , conforme a Equação (8.1). A notação pode ser
simplificada através da justaposição dos dı́gitos, acompanhada da especificação da base, como
ilustrado na Equação (8.2). Nos casos onde se opera sempre com a mesma base, a sua indicação
pode ser omitida, como na Equação (8.3).
(qI )b = (dN −1 × bN −1 ) + · · · + (d2 × b2 ) + (d1 × b1 ) + (d0 × b0 ) =
N
−1
X
dk bk .
(8.1)
k=0
N
−1
X
(qI )b =
dk bk = [dN −1 · · · d2 d1 d0 ]b .
(8.2)
k=0
qI =
N
−1
X
dk bk = [dN −1 · · · d2 d1 d0 ] .
(8.3)
k=0
8.2.2
Representação de números fracionários não negativos
Para representar quantidades numéricas puramente fracionárias, ordenadas e não negativas,
o sistema de numeração posicional convencional utiliza o mesmo mecanismo empregado com
números inteiros. Nesse caso, os pesos wi , usados para ponderar os dı́gitos di , são potências
inteiras e negativas da base b.
Partindo-se das Equações (8.1) a (8.3), pode-se dizer que
−N
(qF )b = b
−1
−N +1
· (qI )b = (dN −1 × b ) + · · · + (d1 × b
−N
) + (d0 × b
)=
N
−1
X
dk b−N +k
(8.4)
k=0
ou, utilizando-se uma notação mais genérica, que
(qF )b = (d−1 × b−1 ) + (d−2 × b−2 ) + · · · + (d−N × b−N ) =
−1
X
dk bk = [d−1 d−2 · · · d−N ]b . (8.5)
k=−N
A.S.V.
8.2. Sistema de numeração posicional convencional
71
Na representação simplificada por um vetor de dı́gitos, para uso humano, emprega-se um
sı́mbolo extra para diferenciar as representações de números puramente inteiros, puramente
fracionários e com partes inteira e fracionária. Normalmente é utilizado um ponto ou uma
vı́rgula, como é ilustrado na Equação (8.6), para números puramente inteiros, na Equação (8.7),
para números puramente fracionários, e na Equação (8.8), para números com partes inteira e
fracionária.
(qI )b =
N
I −1
X
dk bk = [dNI −1 · · · d1 d0 · ]b = [dNI −1 · · · d1 d0 · 0]b .
(8.6)
dk bk = [ · d−1 d−2 · · · d−NF ]b = [0 · d−1 d−2 · · · d−NF ]b .
(8.7)
k=0
(qF )b =
−1
X
k=−NF
(q)b = (qI )b + (qF )b =
N
I −1
X
dk bk = [dNI −1 · · · d2 d1 d0 · d−1 d−2 · · · d−NF ]b .
(8.8)
k=−NF
Na representação utilizada nos circuitos digitais o sı́mbolo extra não é utilizado, uma vez
que o conhecimento de quantos dı́gitos são empregados para as partes inteira e fracionária
transformam-no em uma informação redundante e, portanto, dispensável.
Para o uso humano, a redundância é útil para facilitar a visualização das partes inteira e
fracionária, bem como para sua manipulação.
8.2.3
Representação de números inteiros negativos
• Na representação matemática para uso humano, uma forma de diferenciar números positivos e negativos é a adição dos sı́mbolos “+” e “−”, respectivamente. Tais sı́mbolos também
podem ser interpretados como operadores unários. Logo, a menos que seja necessário resolver alguma ambigüidade, o sı́mbolo “+”é dispensado, uma vez que não realiza qualquer
modificação sobre a quantidade original.
• Na representação utilizada nos circuitos digitais, é necessário empregar um dos próprios
sı́mbolos utilizados na codificação de quantidades para diferenciar quantidades positivas
e negativas, devido a não existência de outros sı́mbolos.
• Diversas formas de recodificação podem ser encontradas para os vetores de dı́gitos que
representam as quantidades numéricas. As mais comuns são discutidas a seguir.
• Representação numérica
– Sistema: SNPC com base b.
– Dı́gitos: di ∈ S = {0, 1, 2, · · · , (b − 1)}.
– Representação: vetor de N dı́gitos.
• Significado dos N dı́gitos
– O dı́gito mais significativo representa o sinal: dN −1 = sN −1 .
– Os restantes (N − 1) dı́gitos representam a quantidade numérica.
TET / UFF
72
Capı́tulo 8. Sistemas de numeração
• Números positivos
– Dı́gito mais significativo: dN −1 = sN −1 = 0.
– Representação: (qI+ )b = [sN −1 dN −2 · · · d2 d1 d0 ]b = [0 dN −2 · · · d2 d1 d0 ]b .
– Codificação: sinal-e-magnitude.
• Números negativos
– Dı́gito mais significativo: d′N −1 = s′N −1 = (b − 1).
– Representação: (qI− )b = [s′N −1 d′N −2 · · · d′2 d′1 d′0 ]b = [(b − 1) d′N −2 · · · d′2 d′1 d′0 ]b .
– Codificações:
∗ Sinal-e-magnitude.
∗ Sinal-e-complemento:
· Complemento à base (b).
· Complemento à base diminuı́da (b − 1).
• A seguir, são abordadas as codificações de números negativos para b = 2.
Visão geral das codificações
• Na representação de números inteiros não negativos, considerando-se b = 2, é utilizada a
justaposição de N dı́gitos para representar 2N valores consecutivos, na faixa [0; (2N − 1)].
Por exemplo, para N = 4, o valor V = (6)10 é representado por V = (0110)2 . Isso é
ilustrado na Figura 8.5, para N = 4.
• Para possibilitar a representação de números inteiros negativos, o dı́gito mais significativo
é utilizado para simbolizar os sinais “+” e “−”. Normalmente, são adotados “0” e “1”,
respectivamente.
• Portanto, uma metade dos 2N possı́veis padrões de dı́gitos é usada para representar os
números positivos e o zero, enquanto a outra metade pode ser usada para representar
números negativos.
• Para os valores não negativos, a associação entre números e padrões de dı́gitos é a mesma
utilizada anteriormente, adotando-se o dı́gito mais significativo com valor “0”, para representar o sinal “+”. Por exemplo, para N = 4, o valor V = (+6)10 é representado por
VSM = (0110)2. Isso é ilustrado na Figura 8.6, para N = 4.
• Por outro lado, para os valores negativos, três outros tipos de associação são comumente
empregados.
• Na codificação denominada de Sinal-e-Magnitude, a associação entre números negativos
e padrões de dı́gitos é a mesma utilizada anteriormente, adotando-se o dı́gito mais significativo com valor “1”, para representar o sinal “−”. Por exemplo, para N = 4, o valor
V = (−6)10 é representado por VSM = (1110)2. Isso é ilustrado na Figura 8.7, para
N = 4.
• Nas codificações denominadas de complementares, um valor negativo (V = −|V |) é representado por seu valor complementar (VC ) em relação a um determinado valor de referência
(VR ), de tal forma que VC = VR − |V |.
A.S.V.
73
8.2. Sistema de numeração posicional convencional
• Na codificação denominada de Complemento-a-1, o valor de referência é igual ao maior
valor representável (VR = bN −1 = 2N −1). Por exemplo, para N = 4, o valor V = (−6)10
é representado pelo valor complementar VC1 = VR − |V | = (15 − |6|)10 = (9)10 = (1001)2 .
Isso é ilustrado na Figura 8.8, para N = 4.
• Na codificação denominada de Complemento-a-2, o valor de referência é o valor seguinte ao
maior valor representável (VR = bN = 2N ). Por exemplo, para N = 4, o valor V = (−6)10
é representado pelo valor complementar VC1 = VR − |V | = (16 − |6|)10 = (10)10 = (1010)2 .
Isso é ilustrado na Figura 8.9, para N = 4.
• Para melhor comparação, todas as codificações são reunidas na Figura 8.10, para N = 4.
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Figura 8.5: Mapeamento decimal-binário para números não negativos e N = 4, sem sinal.
0
+1
+2
+3
+4
+5
+6
+7
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Figura 8.6: Mapeamento decimal-binário para números não negativos e N = 4, com sinal.
TET / UFF
74
Capı́tulo 8. Sistemas de numeração
0
+1
+2
+3
+4
+5
+6
+7
0
1
2
3
4
5
6
7
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Figura 8.7: Mapeamento decimal-binário para números negativos e N = 4, com codificação
Sinal-e-Magnitude.
0
+1
+2
+3
+4
+5
+6
+7
7
6
5
4
3
2
1
0
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Figura 8.8: Mapeamento decimal-binário para números negativos e N = 4, com codificação
Complemento-a-1.
0
+1
+2
+3
+4
+5
+6
+7
8
7
6
5
4
3
2
1
0
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Figura 8.9: Mapeamento decimal-binário para números negativos e N = 4, com codificação
Complemento-a-2.
A.S.V.
75
8.2. Sistema de numeração posicional convencional
0
+1
+2
+3
+4
+5
+6
8
7
6
5
4
3
2
1
7
6
5
4
3
2
1
0
0
1
2
3
4
5
6
7
0
+7
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111
0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Figura 8.10: Comparação dos mapeamentos decimal-binário para números negativos e N = 4.
TET / UFF
76
Capı́tulo 8. Sistemas de numeração
Sinal-e-magnitude
• Assim como na representação para uso humano, o dı́gito de sinal dN −1 = sN −1 = 0 ou
(b − 1) pode ser interpretado como um operador unário ou como um dı́gito sem peso
numérico, que indica apenas o valor do sinal.
• Os demais dı́gitos representam um valor numérico positivo.
• A representação possui dois padrões binários para o valor numérico nulo: +(0) e −(0).
• A Equação (8.9) apresenta uma interpretação numérica da representação, para b = 2.
• Um exemplo é apresentado na Tabela 8.1, para b = 2 e N = 4.
(qI )2 = [0/1 dN −2 · · · d2 d1 d0 ]2 = [sN −1 dN −2 · · · d2 d1 d0 ]2
= (−1)sN−1 × (dN −2 × 2N −2 ) + · · · + (d2 × 22 ) + (d1 × 21 ) + (d0 × 20 )
!
N
−2
X
d k 2k
= (−1)sN−1 ×
(8.9)
k=0
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Binário
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
0 0
0 0
0 1
0 1
1 0
1 0
1 1
1 1
1
0
1
0
1
0
1
0
0
1
0
1
0
1
0
1
Decimal Interpretação
7
(+1) · (7)
6
(+1) · (6)
5
(+1) · (5)
4
(+1) · (4)
3
(+1) · (3)
2
(+1) · (2)
1
(+1) · (1)
0
(+1) · (0)
0
(−1) · (0)
−1
(−1) · (1)
−2
(−1) · (2)
−3
(−1) · (3)
−4
(−1) · (4)
−5
(−1) · (5)
−6
(−1) · (6)
−7
(−1) · (7)
Tabela 8.1: Tabela de sinal-e-magnitude, para número inteiros, b = 2 e N = 4.
A.S.V.
77
8.2. Sistema de numeração posicional convencional
Complemento à base diminuı́da
• Para quantidades positivas, a codificação é sinal-e-magnitude, onde dN −1 = sN −1 = 0.
• Para quantidades negativas, a codificação é dN −1 = sN −1 = (b − 1) e os demais dı́gitos
são recodificados.
• A representação possui dois padrões binários para o valor numérico nulo: +(0) e −(0).
• Interpretação 1:
– Técnica: um valor positivo adequado é adicionado ao número negativo, de tal forma
que o resultado seja positivo e que o dı́gito de sinal passe de 0 para (b − 1).
– O número negativo é representado como o complemento do seu valor absoluto em
relação a um módulo cujo valor é a menor potência (inteira e positiva) da base que é
maior do que a representação do valor absoluto a ser representado, reduzida de uma
unidade.
– Para (qI− )b representada por um vetor de N dı́gitos: −|x| ↔ xC = bN − 1 − |x|.
– As Equações (8.10) e (8.11) apresentam uma interpretação numérica da representação, para b = 2.
!
N
−1
X
(qI− )2 = −|x| = −
(8.10)
dk 2k = − [dN −1 dN −2 · · · d1 d0 ]2 = − [0 dN −2 · · · d1 d0 ]2
k=0
xC1 =
2N − 1 − |x| =
2N − 1 −
N
−1
X
k=0
= [1 1 · · · 1 1]2 − [0 dN −2 · · · d1 d0 ]2 =
• Interpretação 2 (para b = 2):
d k 2k
!
1 d′N −2 · · · d′1 d′0
2
(8.11)
– O dı́gito de sinal tem peso negativo: wN −1 = [−(2N −1 − 1)].
– Os demais dı́gitos representam um valor numérico positivo que, somado ao valor
negativo do dı́gito de sinal, fornece o valor negativo desejado.
– As Equações (8.12) e (8.13) apresentam uma interpretação numérica da representação, para b = 2.
(qI+ )2 = [0 dN −2 · · · d2 d1 d0 ]2
= [sN −1 dN −2 · · · d2 d1 d0 ]2
= sN −1 · [−(2N −1 − 1)] + [(dN −2 × 2N −2 ) + · · · + (d2 × 22 ) + (d1 × 21 ) + (d0 × 20 )]
!
N
−2
X
(8.12)
= sN −1 · [−(2N −1 − 1)] +
d k 2k
k=0
(qI− )2 = [1 d′N −2 · · · d′2 d′1 d′0 ]2
= [s′N −1 d′N −2 · · · d′2 d′1 d′0 ]2
= s′N −1 · [−(2N −1 − 1)] + [(d′N −2 × 2N −2 ) + · · · + (d′2 × 22 ) + (d′1 × 21 ) + (d′0 × 20 )]
!
N
−2
X
(8.13)
= s′N −1 · [−(2N −1 − 1)] +
d′k 2k
k=0
TET / UFF
78
Capı́tulo 8. Sistemas de numeração
• Um exemplo é apresentado na Tabela 8.2, para b = 2 e N = 4.
• Para a base b = 2, pode-se definir o seguinte algoritmo para a conversão entre as representações de quantidades positivas e negativas, em complemento-a-1:
– Dada uma representação numérica, em complemento-a-1, para se obter sua representação complementar basta que se troque os numerais 0 por 1 e que se troque os
numerais 1 por 0.
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Binário
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
Decimal Interpretação 1 Interpretação 2
7
(0) + (7)
(0) + (7)
6
(0) + (6)
(0) + (6)
5
(0) + (5)
(0) + (5)
4
(0) + (4)
(0) + (4)
3
(0) + (3)
(0) + (3)
2
(0) + (2)
(0) + (2)
1
(0) + (1)
(0) + (1)
0
(0) + (0)
(0) + (0)
0
(15) − (0)
(−7) + (7)
−1
(15) − (1)
(−7) + (6)
−2
(15) − (2)
(−7) + (5)
−3
(15) − (3)
(−7) + (4)
−4
(15) − (4)
(−7) + (3)
−5
(15) − (5)
(−7) + (2)
−6
(15) − (6)
(−7) + (1)
−7
(15) − (7)
(−7) + (0)
Tabela 8.2: Tabela de complemento-a-1, para número inteiros, b = 2 e N = 4.
A.S.V.
79
8.2. Sistema de numeração posicional convencional
Complemento à base
• Para quantidades positivas, a codificação é sinal-e-magnitude, onde dN −1 = sN −1 = 0.
• Para quantidades negativas, a codificação é dN −1 = sN −1 = (b − 1) e os demais dı́gitos
são recodificados.
• A representação possui apenas um padrão binário para o valor numérico nulo: 0.
• Interpretação 1:
– Técnica: um valor positivo adequado é adicionado ao número negativo, de tal forma
que o resultado seja positivo e que o dı́gito de sinal passe de 0 para (b − 1).
– O número negativo é representado como o complemento do seu valor absoluto em
relação a um módulo cujo valor é a menor potência (inteira e positiva) da base que
é maior do que a representação do valor absoluto a ser representado.
– Para (qI− )b representada por um vetor de N dı́gitos: −|x| ↔ xC = bN − |x|.
– As Equações (8.14) e (8.15) apresentam uma interpretação numérica da representação, para b = 2.
!
N
−1
X
(qI− )2 = −|x| = −
(8.14)
dk 2k = − [dN −1 dN −2 · · · d1 d0 ]2 = − [0 dN −2 · · · d1 d0 ]2
k=0
xC2 = 2N − |x| = 2N −
N
−1
X
k=0
d k 2k
!
= [1 0 0 · · · 0 0]2 − [0 dN −2 · · · d1 d0 ]2 = 1 d′N −2 · · · d′1 d′0 2
(8.15)
• Interpretação 2 (para b = 2):
– O dı́gito de sinal tem peso negativo: wN −1 = (−2N −1 ).
– Os demais dı́gitos representam um valor numérico positivo que, somado ao valor
negativo do dı́gito de sinal, fornece o valor negativo desejado.
– As Equações (8.16) e (8.17) apresentam uma interpretação numérica da representação, para b = 2.
(qI+ )2 = [0 dN −2 · · · d2 d1 d0 ]2
= [sN −1 dN −2 · · · d2 d1 d0 ]2
= sN −1 · [−(2N −1 )] + [(dN −2 × 2N −2 ) + · · · + (d2 × 22 ) + (d1 × 21 ) + (d0 × 20 )]
!
N
−2
X
k
N −1
(8.16)
dk 2
= sN −1 · [−(2
)] +
k=0
(qI− )2 = [1 d′N −2 · · · d′2 d′1 d′0 ]2
= [s′N −1 d′N −2 · · · d′2 d′1 d′0 ]2
= s′N −1 · [−(2N −1 )] + [(d′N −2 × 2N −2 ) + · · · + (d′2 × 22 ) + (d′1 × 21 ) + (d′0 × 20 )]
!
N
−2
X
(8.17)
= s′N −1 · [−(2N −1 ] +
d′k 2k
k=0
TET / UFF
80
Capı́tulo 8. Sistemas de numeração
• Um exemplo é apresentado na Tabela 8.3, para b = 2 e N = 4.
• Para a base b = 2, podem-se definir os seguintes algoritmos para a conversão entre as
representações de quantidades positivas e negativas, em complemento-a-2:
– Algoritmo 1: Dada uma representação numérica, em complemento-a-2, para se obter
sua representação complementar basta: i) que se troque os numerais 0 por 1 e que se
troque os numerais 1 por 0 (complemento-a-1) e, em seguida, ii) que seja adicionado
o valor 1 ao dı́gito menos significativo (Least Significant Bit ou LSB).
– Algoritmo 2: Dada uma representação numérica, em complemento-a-2, para se obter
sua representação complementar deve-se realizar uma busca a partir do dı́gito menos
significativo (LSB). Durante a busca, os dı́gitos não serão modificados até que seja
encontrado o primeiro numeral 1, que também não será modificado. A partir deste
ponto, basta que se troque os numerais 0 por 1 e que se troque os numerais 1 por 0.
– Uma vez que trabalha com adição, o primeiro algoritmo é mais adequado para ambientes onde já se dispõe de um circuito somador.
– Por sua vez, dado que ele envolve um processo de varredura, o segundo algoritmo é
mais recomendado quando se deseja implementar um simples bloco funcional para
realizar a complementação.
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Binário
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
Decimal Interpretação 1 Interpretação 2
7
(0) + (7)
(0) + (7)
6
(0) + (6)
(0) + (6)
5
(0) + (5)
(0) + (5)
4
(0) + (4)
(0) + (4)
3
(0) + (3)
(0) + (3)
2
(0) + (2)
(0) + (2)
1
(0) + (1)
(0) + (1)
0
(0) + (0)
(0) + (0)
−1
(16) − (1)
(−8) + (7)
−2
(16) − (2)
(−8) + (6)
−3
(16) − (3)
(−8) + (5)
−4
(16) − (4)
(−8) + (4)
−5
(16) − (5)
(−8) + (3)
−6
(16) − (6)
(−8) + (2)
−7
(16) − (7)
(−8) + (1)
−8
(16) − (8)
(−8) + (0)
Tabela 8.3: Tabela de complemento-a-2, para número inteiros, b = 2 e N = 4.
A.S.V.
81
8.2. Sistema de numeração posicional convencional
8.2.4
Representação de números fracionários negativos
• O equacionamento utilizado para a representação de números inteiros negativos pode ser
aproveitado para números negativos puramente fracionários.
• Uma quantidade puramente fracionária xF pode ser obtida através da multiplicação de
uma quantidade inteira xI por um fator de escala F E adequado (xF = F E · xI ).
• Assim, para aproveitar o equacionamento anterior, basta utilizar um escalamento.
• Cabe ressaltar que, em circuitos digitais que manipulam números binários e que utilizam uma posição fixa para o separador das partes inteira e fracionária (aritmética de
ponto fixo), é comum que se interprete todas as grandezas como números puramente
fracionários 0 ≤ |xF | < 1, codificados em complemento-a-2. Nesse caso, o separador
encontra-se (virtualmente) entre o dı́gito de sinal (sN −1 ) e os demais N − 1 dı́gitos que
representam a quantidade numérica. Partindo-se das Equações (8.14) e (8.15), não é
difı́cil demonstrar a seguinte equivalência: −|xF | ↔ (xF )C2 = 2 − |xF |. Finalmente,
partindo-se das Equações
(8.16) e (8.17), não é difı́cil demonstrar a seguinte notação:
P
N −1
−k
(xF )C2 = −sN −1 +
.
k=1 d−k 2
• A tı́tulo de exemplo, as Tabelas 8.1 a 8.3, que representam números inteiros, são transformadas nas Tabelas 8.4 a 8.6, para números puramente fracionários, através do fator de
escala F E = 2−(N −1) = 2−3 = 8−1 .
• Comparando-se os conteúdos das Tabelas 8.1 a 8.6, destaca-se mais uma vez o fato de
que um mesmo padrão de dı́gitos pode ser interpretado de diversas formas diferentes,
dependendo do sistema de numeração, da forma de codificação e da posição do separador
fracionário utilizados.
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Binário
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
0 0
0 0
0 1
0 1
1 0
1 0
1 1
1 1
1
0
1
0
1
0
1
0
0
1
0
1
0
1
0
1
Decimal
0.875
0.750
0.625
0.500
0.375
0.250
0.125
0.000
0.000
−0.125
−0.250
−0.375
−0.500
−0.625
−0.750
−0.875
Interpretação
(+1) · (0.875)
(+1) · (0.750)
(+1) · (0.625)
(+1) · (0.500)
(+1) · (0.375)
(+1) · (0.250)
(+1) · (0.125)
(+1) · (0.000)
(−1) · (0.000)
(−1) · (0.125)
(−1) · (0.250)
(−1) · (0.375)
(−1) · (0.500)
(−1) · (0.625)
(−1) · (0.750)
(−1) · (0.875)
Tabela 8.4: Tabela de sinal-e-magnitude, para números puramente fracionários, b = 2 e N = 4.
TET / UFF
82
Capı́tulo 8. Sistemas de numeração
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Binário
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
Decimal
0.875
0.750
0.625
0.500
0.375
0.250
0.125
0.000
0.000
−0.125
−0.250
−0.375
−0.500
−0.625
−0.750
−0.875
Interpretação 1
(0.000) + (0.875)
(0.000) + (0.750)
(0.000) + (0.625)
(0.000) + (0.500)
(0.000) + (0.375)
(0.000) + (0.250)
(0.000) + (0.125)
(0.000) + (0.000)
(1.875) − (0.000)
(1.875) − (0.125)
(1.875) − (0.250)
(1.875) − (0.375)
(1.875) − (0.500)
(1.875) − (0.625)
(1.875) − (0.750)
(1.875) − (0.875)
Interpretação 2
(0.000) + (0.875)
(0.000) + (0.750)
(0.000) + (0.625)
(0.000) + (0.500)
(0.000) + (0.375)
(0.000) + (0.250)
(0.000) + (0.125)
(0.000) + (0.000)
(−0.875) + (0.875)
(−0.875) + (0.750)
(−0.875) + (0.625)
(−0.875) + (0.500)
(−0.875) + (0.375)
(−0.875) + (0.250)
(−0.875) + (0.125)
(−0.875) + (0.000)
Tabela 8.5: Tabela de complemento-a-1, para números puramente fracionários, b = 2 e N = 4.
0
0
0
0
0
0
0
0
1
1
1
1
1
1
1
1
Binário
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1 1
1 1
1 0
1 0
0 1
0 1
0 0
0 0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
Decimal Interpretação 1 Interpretação 2
0.875
(0) + (0.875)
(0) + (0.875)
0.750
(0) + (0.750)
(0) + (0.750)
0.625
(0) + (0.625)
(0) + (0.625)
0.500
(0) + (0.500)
(0) + (0.500)
0.375
(0) + (0.375)
(0) + (0.375)
0.250
(0) + (0.250)
(0) + (0.250)
0.125
(0) + (0.125)
(0) + (0.125)
0.000
(0) + (0.000)
(0) + (0.000)
−0.125
(2) − (0.125) (−1) + (0.875)
−0.250
(2) − (0.250) (−1) + (0.750)
−0.375
(2) − (0.375) (−1) + (0.625)
−0.500
(2) − (0.500) (−1) + (0.500)
−0.625
(2) − (0.625) (−1) + (0.375)
−0.750
(2) − (0.750) (−1) + (0.250)
−0.875
(2) − (0.875) (−1) + (0.125)
−1.000
(2) − (1.000) (−1) + (0.000)
Tabela 8.6: Tabela de complemento-a-2, para números puramente fracionários, b = 2 e N = 4.
A.S.V.
83
8.2. Sistema de numeração posicional convencional
8.2.5
Tabelas de operações básicas entre dı́gitos
• Para uma determinada base, as operações de adição e multiplicação entre dı́gitos podem
ser facilmente definidas por meio de tabelas.
• As Figuras 8.11 - 8.13 apresentam as tabelas para as bases b = 2, b = 3 e b = 4,
respectivamente.
• A partir de tais tabelas, definidas para dı́gitos, podem ser definidos algoritmos e implementações para uma operação envolvendo quantidades genéricas, expressas na base em
questão.
+
0
1
0 1
0 1
1 10
×
0
1
(a)
0 1
0 0
0 1
(b)
Figura 8.11: Tabelas de operações entre dı́gitos para b = 2: (a) adição e (b) multiplicação.
+
0
1
2
0 1 2
0 1 2
1 2 10
2 10 11
×
0
1
2
0
0
0
0
(a)
1 2
0 0
1 2
2 11
(b)
Figura 8.12: Tabelas de operações entre dı́gitos para b = 3: (a) adição e (b) multiplicação.
+
0
1
2
3
0
0
1
2
3
1 2 3
1 2 3
2 3 10
3 10 11
10 11 12
(a)
×
0
1
2
3
0
0
0
0
0
1 2
3
0 0
0
1 2
3
2 10 12
3 12 101
(b)
Figura 8.13: Tabelas de operações entre dı́gitos para b = 4: (a) adição e (b) multiplicação.
TET / UFF
84
Capı́tulo 8. Sistemas de numeração
8.2.6
Adição e subtração em complemento-a-2
A codificação em complemento-a-2 apresenta, entre outras, a grande vantagem de transformar
o processo de subtração em pura adição: x1 − x2 = x1 + (−x2 ) = x1 + (x2 )C2 . Assim, um único
bloco somador pode ser usado para realizar as operações de adição e subtração de números
codificados em complemento-a-2.
A adição de dois números puramente fracionários pode produzir um número com parte
inteira. Na representação de números puramente fracionários, com ponto fixo, não são utilizados dı́gitos para valores inteiros. Portanto, um resultado contendo parte inteira, positivo ou
negativo, é considerado uma situação de overflow.
Para que o resultado da adição em complemento-a-2 possa ser considerado correto, a ocorrência de overflow deve ser detectada e devidademente tratada.
Análise de overflow na adição em complemento-a-2
Considerando-se um bloco somador, operando com dados puramente fracionários, codificados
em complemento-a-2, o sinal de saı́da carry-out representa uma parte inteira de valor vI = 2.
• Caso 1: adição de números positivos.
0 ≤ x1 < 1, 0 ≤ x2 < 1 e xA = x1 + x2 .
Logo: 0 ≤ xA < 2.
Se 0 ≤ xA < 1: adição sem overflow.
Se 1 ≤ xA < 2: adição com overflow.
• Caso 2: subtração de números positivos.
0 ≤ x1 < 1, −1 < x2 < 0, (−|x2 |)C2 = 2 − |x2 | e
xA = (x1 + x2 ) = x1 − |x2 | = x1 + (x2 )C2 = 2 + (x1 − |x2 |).
Logo: −1 < xA < 1.
Portanto, nesse caso, não haverá ocorrência de overflow.
Se x1 ≥ |x2 |: resultado positivo, bastando ignorar o sinal de carry-out (xP = xA − 2).
Se x1 < |x2 |: resultado negativo já codificado (xN = xA ).
• Caso 3: adição de números negativos.
−1 < x2 < 0, −1 < x2 < 0, (−|x1 |)C2 = 2 − |x1 |, (−|x2 |)C2 = 2 − |x2 | e
(xC2 )A = x1 + x2 = (−|x1 |)C2 + (−|x2 |)C2 = (2 − |x1 |) + (2 − |x2 |) = 2 + [2 − (|x1 | + |x2 |)].
Logo: 0 < |x1 | + |x2 | < 2 → 2 < (xC2 )A < 4.
Se 2 < (xC2 )A ≤ 3: adição com overflow.
Se 3 < (xC2 )A < 4: adição sem overflow.
Se o resultado for sem overflow, o mesmo já estará codificado, bastando ignorar o sinal
de carry-out ((xA )C2 = (xC2 )A − 2).
Detecção e tratamento de overflow na adição em complemento-a-2
Pelos resultados da análise de overflow para adição em complemento-a-2, não é difı́cil encontrar
um mecanismo que indique sua ocorrência. A detecção de overflow pode ser feita através da
análise dos bits de sinal dos operandos (ds1 e ds2 ) e do resultado (dsA ), bem como do sinal de
carry-out (cO ) do bloco somador. As Tabelas 8.7 e 8.8 apresentam duas formas para representar
a detecção de overflow na adição em complemento-a-2, onde OF = 0 e OF = 1 indicam a
ausência e a presença de overflow, respectivamente. A diferença entre as duas formas é que,
na Tabela 8.7, são levados em consideração os casos que não podem acontecer (can’t happen),
o que pode levar a simplificações da função final. O tratamento de overflow mais comumente
empregado é a saturação do resultado no valor máximo representável (positivo ou negativo).
A.S.V.
85
8.2. Sistema de numeração posicional convencional
Caso
Adição de
positivos
ds1
0
ds2
0
dsA
0
1
Subtração
de positivos
0
1
0
1
1
0
0
1
Adição de
negativos
1
1
0
1
cO
0
1
0
1
0
1
0
1
0
1
0
1
0
1
0
1
OF
0
X
1
X
X
0
0
X
X
0
0
X
X
1
X
0
X = can´t happen
OF = 0 → sem overflow
OF = 1 → com overflow
Tabela 8.7: Forma 1 para representar a detecção de overflow na adição em complemento-a-2.
Caso
Adição de
positivos
Subtração
de positivos
Adição de
negativos
ds1
0
0
0
1
1
1
ds2
0
0
1
0
1
1
dsA
0
1
0
0
0
1
cO
X
X
X
X
X
X
OF
0
1
0
0
1
0
X = don´t care
OF = 0 → sem overflow
OF = 1 → com overflow
Tabela 8.8: Forma 2 para representar a detecção de overflow na adição em complemento-a-2.
TET / UFF
86
8.2.7
Capı́tulo 8. Sistemas de numeração
Funções envolvidas na adição de dı́gitos binários
A adição entre dı́gitos binários pode ser facilmente definida por meio de tabelas. A Figura 8.14
apresenta as tabelas que definem a adição entre dois dı́gitos binários (A e B). A Figura 8.14.(a)
define a operação completa, com todos os resultados descritos por dois dı́gitos. A Figura 8.14.(b)
define os dı́gitos da esquerda do resultado, que representam a parte excedente da adição,
denominada de “vai-um” (carry out - Co ). A Figura 8.14.(c) define os dı́gitos da direita, que
representam o resultado básico da adição, denominado de soma (S).
+
0
1
0 1
00 01
01 10
Co
0
1
(a)
0
0
0
1
0
1
(b)
S
0
1
0
0
1
1
1
0
(c)
Figura 8.14: Tabelas que definem a adição entre dois dı́gitos binários (A e B): (a) adição
completa, (b) “vai-um” (carry out - Co ) e (c) soma (S).
Apesar dos resultados das tabelas de Co e de S serem numéricos, os mesmos podem ser
interpretados como valores booleanos. Assim, supondo-se os dı́gitos binários A e B, pode-se
dizer que
Co = fC2 (A, B) = (A · B)
e que
S = fS2 (A, B) = A · B + A · B = (A ⊕ B) .
Na adição entre dois números com diversos dı́gitos binários, naturalmente acontece uma
propagação de excessos de soma, denominados de Co (carry out) para os blocos que os geram e
de Ci (carry in) para os blocos que os recebem. Logo, torna-se necessário definir a adição entre
três dı́gitos binários (A, B e Ci ), o que é feito nas tabelas da Figura 8.15.
+
0
1
00 01
00 01
01 10
11 10
10 01
11 10
(a)
Co
0
1
00
0
0
01 11 10
0 1 0
1 1 1
(b)
S
0
1
00
0
1
01 11 10
1 0 1
0 1 0
(c)
Figura 8.15: Tabelas que definem a adição entre três dı́gitos binários (A, B e Ci ): (a) adição
completa, (b) “vai-um” (carry out - Co ) e (c) soma (S).
Nesse caso, supondo-se os dı́gitos A e B na parte superior das tabelas e o dı́gito Ci à
esquerda, pode-se dizer que
S = fS3 (A, B, Ci ) = A · B · Ci + A · B · Ci + A · B · Ci + (A · B · Ci )
i
h
= (A ⊕ B) · Ci + (A ⊕ B) · Ci
= (A ⊕ B) ⊕ Ci
A.S.V.
87
8.2. Sistema de numeração posicional convencional
e que
Co = fC3 (A, B, Ci ) =
que pode ser simplificada como
A · B · Ci + (A · B · Ci ) + A · B · Ci + A · B · Ci ,
Co = fC3 (A, B, Ci)
= (A · B) + (A · Ci ) + (B · Ci )
e ainda como
Co = fC3 (A, B, Ci )
= (A · B) + [(A + B) · Ci ] ,
ou como
Co = fC3 (A, B, Ci)
= (A · B) + A · B + A · B · Ci
= (A · B) + [(A ⊕ B) · Ci ] .
Procurando-se otimizar algumas implementações, pode-se mostrar ainda que
Co = fC3 A, B, Ci
e que
S = fS3 A, B, Ci .
As funções definidas acima são suficientes para implementar um somador de dois números
com N dı́gitos binários através do algoritmo mais elementar. Porém, três funções mostram-se
bastante úteis na implementação de somadores com algoritmos mais complexos: Generate (G),
Propagate (P) e Kill (K). A Figura 8.16 apresenta as tabelas que definem as funções G, P e K,
supondo-se os dı́gitos A e B na parte superior das tabelas e o dı́gito Ci à esquerda. Para melhor
entender a sua aplicabilidade, é importante ressaltar a principal caracterı́stica das funções G,
P e K, que é não depender de Ci .
G
0
1
00
0
0
01 11 10
0 1 0
0 1 0
(a)
P
0
1
00 01 11
0 1 0
0 1 0
10
1
1
(b)
K
0
1
00
1
1
01 11 10
0 0 0
0 0 0
(c)
Figura 8.16: Tabelas que definem três funções úteis na implementação de somadores binários
com algoritmos complexos: (a) Generate (G), (b) Propagate (P) e (c) Kill (K).
A função Generate (G) assume o valor booleano “1” quando Co = 1 independentemente do
valor de Ci . Logo, deve-se ter A = B = 1, definindo-se
G = fG (A, B, Ci ) = (A · B) .
A função Propagate (P) assume o valor booleano“1”quando Co = 1 por propagação exclusiva
do valor Ci = 1. Logo, deve-se ter A = 0 e B = 1 ou A = 1 e B = 0, definindo-se
P = fP (A, B, Ci) = (A ⊕ B) .
TET / UFF
88
Capı́tulo 8. Sistemas de numeração
A função Kill (K) assume o valor booleano “1” quando é impossı́vel ter Co = 1 independentemente do valor de Ci . Logo, deve-se ter A = B = 0, definindo-se
K = fK (A, B, Ci) = (A · B) .
As funções S e Co podem ser escritas em função de G e P , de tal forma que
S = fS3 (A, B, Ci)
= (A ⊕ B) ⊕ Ci = (P ⊕ Ci )
e
Co = fC3 (A, B, Ci )
= (A · B) + [(A ⊕ B) · Ci ] = G + (P · Ci )
= (A · B) + [(A + B) · Ci ] = G + (P + · Ci ) ,
onde
P + = (A + B)
pode ser usada para diminuir o tempo de propagação envolvido na geração do sinal Co .
8.2.8
Escalamento por potência inteira da base
Um multiplicador é um circuito com relativa complexidade de implementação. Por isso, possui
relevantes medidas de custo (espaço ocupado, energia consumida e tempo de operação).
Por outro lado, o escalamento por potência inteira da base é uma operação simples, com
baixa complexidade de implementação. O escalamento pode ser de dois tipos, dependendo do
valor da potência inteira da base: multiplicação (valor positivo) ou divisão (valor negativo).
Na Equação (8.18), é apresentada uma quantidade genérica q, representada na base b. A
multiplicação de q pela base b é definida nas Equações (8.19) e (8.20). A divisão de q pela
base b é definida nas Equações (8.21) e (8.22). De acordo com as Equações (8.18) e (8.22), a
implementação do escalamento pode ser obtida através do simples deslocamento dos dı́gitos da
representação.
(q)b = (qI )b + (qF )b =
−N
XF
dk bk = [dNI · · · d2 d1 d0 · d−1 d−2 · · · d−NF ]b .
(8.18)
k=NI
(q′)b = (q)b × b
!
−N
−N
−N
−N
F +1
F +1
XF
XF
X
X
k
k+1
k
=
dk b × b =
dk b
=
dk−1 b =
d′k bk
k=NI
k=NI
k=NI +1
= [dNI · · · d2 d1 d0 d−1 · d−2 · · · d−NF ]b
= [d′NI +1 · · · d′3 d′2 d′1 d′0 · d′−1 d′−2 · · · d′−NF +1 ]b .
d′k = dk−1 .
k=NI +1
(8.19)
(8.20)
A.S.V.
89
8.2. Sistema de numeração posicional convencional
(q′)b = (q)b × b−1
!
−N
−N
−N
−N
F −1
F −1
XF
XF
X
X
−1
k
k−1
k
=
dk b × b =
dk b
=
dk+1b =
d′k bk
k=NI
k=NI
k=NI −1
k=NI −1
= [dNI · · · d2 d1 · d0 d−1 d−2 · · · d−NF ]b
= [d′NI −1 · · · d′3 d′2 d′1 d′0 · d′−1 d′−2 · · · d′−NF −1 ]b .
d′k = dk+1 .
8.2.9
(8.21)
(8.22)
Conversão entre bases
A seguir, são consideradas as conversões de números não negativos (inteiros e puramente fracionários).
Números não negativos e inteiros
A conversão da base s para a base t significa que, conhecendo-se os dı́gitos d′i da Equação (8.23),
deseja-se encontrar os dı́gitos di da Equação (8.24). Considerando-se todas as quantidades
expressas na base s, podem-se definir as relações expressas na Equação (8.25). Assim, para
que se encontrem os dı́gitos di , basta que se realizem divisões sucessivas do dividendo Ni pelo
divisor t, gerando-se o quociente Ni+1 e o resto di , e que, no final, os restos sejam posicionados
na ordem adequada. Uma vez que o número de dı́gitos di é finito, é garantido que o algoritmo
terá um número finito de passos.
(q)s = [d′J · · · d′1 d′0 ]s = (N0 )s .
(8.23)
(q)t = [dK · · · d1 d0 ]t .
(8.24)
dK × tK + · · · + d2 × t2 + d1 × t1 + d0 × t0
= dK × tK−1 + · · · + d2 × t1 + d1 × t0 × t + d0 × t0
= N1 × t + d0
N0 =
dK × tK−1 + · · · + d2 × t1 + d1 × t0
= dK × tK−2 + · · · + d2 × t0 × t + d1 × t0
= N2 × t + d1
N1 =
..
.
NK−1 = dK × t1 + dK−1 × t0
= (dK ) × t + dK−1 × t0
= NK × t + dK−1
NK = dK .
TET / UFF
(8.25)
90
Capı́tulo 8. Sistemas de numeração
Números não negativos e puramente fracionários
A conversão da base s para a base t significa que, conhecendo-se os dı́gitos d′i da Equação (8.26),
deseja-se encontrar os dı́gitos di da Equação (8.27). Considerando-se todas as quantidades
expressas na base s, podem-se definir as relações expressas na Equação (8.28). Assim, para
que se encontrem os dı́gitos di , basta que se realizem multiplicações sucessivas do multiplicando
puramente fracionário Ni pelo multiplicador t, gerando-se o resultado Ni−1 , que contém di como
parte inteira, e que, no final, os restos sejam posicionados na ordem adequada. Uma vez que
não se pode garantir que o número de dı́gitos di será finito, deve-se estabelecer um número
máximo de passos para garantir que o algoritmo terá um término.
(q)s = [d′−1 d′−2 · · · d′−J ]s = (N−1 )s .
(8.26)
(q)t = [d−1 d−2 · · · d−K ]t .
(8.27)
d−1 × t−1 + d−2 × t−2 + d−3 × t−3 + · · · + d−K × t−K × t
= d−1 × t0 + d−2 × t−1 + d−3 × t−2 + · · · + dK × t−K+1
= d−1 + N−2
N−1 × t =
d−2 × t−1 + d−3 × t−2 + · · · + d−K × t−K+1 × t
= d−2 × t0 + d−3 × t−1 + · · · + dK × t−K+2
= d−2 + N−3
N−2 × t =
..
.
N−K+1 × t = d−K+1 × t−1 + d−K × t−2 × t
= d−K+1 × t0 + d−K × t−1
= d−K+1 + N−K
N−K × t = d−K × t−1 × t
= d−K × t0
= d−K
(8.28)
A.S.V.
8.2. Sistema de numeração posicional convencional
8.2.10
91
Bases mais comuns em circuitos digitais
A notação em base b = 2 é a mais adequada para lidar com a implementação de circuitos digitais
baseados em sistemas binários. Porém, dada uma base de valor reduzido, a representação terá
um número elevado de dı́gitos. Para o uso humano, quanto maior é o número de dı́gitos,
mais trabalhoso é a sua interpretação e a sua manipulação. Assim, a fim de simplificar a
representação, duas bases são muito utilizadas: octal e hexadecimal. A base octal emprega
b = 8 e dı́gitos di ∈ S = {0, 1, 2, · · · , 7}. Por sua vez, a base hexadecimal emprega b = 16 e
dı́gitos di ∈ S = {0, 1, 2, · · · , 9, A, B, ..., F }. Supondo-se números não negativos e inteiros, as
Equações (8.29) – (8.31) ilustram as notações nas três bases.
(qI )2 = (dJ × 2J ) + · · · + (d2 × 22 ) + (d1 × 21 ) + (d0 × 20 ) .
(8.29)
(qI )8 = (d′K × 8K ) + · · · + (d′2 × 82 ) + (d′1 × 81 ) + (d′0 × 80 ) .
(8.30)
(qI )16 = (d′′L × 16L ) + · · · + (d′′2 × 162 ) + (d′′1 × 161 ) + (d′′0 × 160 ) .
(8.31)
As bases binária, octal e hexadecimal são comumente utilizadas em conjunto, devido à
facilidade de conversão entre as três bases. As Equações (8.32) – (8.36) ilustram a relação entre
as bases binária e octal.
(qI )2 = (dJ × 2J ) + (dJ−1 × 2J−1) + (dJ−2 × 2J−2 ) + · · · +
(d5 × 25 ) + (d4 × 24 ) + (d3 × 23 ) +
(d2 × 22 ) + (d1 × 21 ) + (d0 × 20 )
= (dJ × 22 ) + (dJ−1 × 21 ) + (dJ−2 × 20 ) × 2J−2 + · · · +
(d5 × 22 ) + (d4 × 21 ) + (d3 × 20 ) × 23 +
(d2 × 22 ) + (d1 × 21 ) + (d0 × 20 ) × 20
= (d′K × 8K ) + · · · + (d′1 × 81 ) + (d′0 × 80 )
= (qI )8 .
TET / UFF
(8.32)
J − 2 = 3K .
(8.33)
[d2 d1 d0 ]2 = [d′0 ]8 .
(8.34)
[d5 d4 d3 ]2 = [d′1 ]8 .
(8.35)
[dJ dJ−1 dJ−2 ]2 = [d′K ]8 .
(8.36)
92
Capı́tulo 8. Sistemas de numeração
As Equações (8.37) – (8.41) ilustram a relação entre as bases binária e hexadecimal.
(qI )2 = (dJ × 2J ) + (dJ−1 × 2J−1 ) + (dJ−2 × 2J−2 ) + (dJ−3 × 2J−3) + · · · +
(d7 × 27 ) + (d6 × 26 ) + (d5 × 25 ) + (d4 × 24 ) +
(d3 × 23 ) + (d2 × 22 ) + (d1 × 21 ) + (d0 × 20 )
= (dJ × 23 ) + (dJ−1 × 22 ) + (dJ−2 × 21 ) + (dJ−3 × 20 ) × 2J−3 + · · · +
(d7 × 23 ) + (d6 × 22 ) + (d5 × 21 ) + (d4 × 20 ) × 24 +
(d3 × 23 ) + (d2 × 22 ) + (d1 × 21 ) + (d0 × 20 ) × 20
= (d′′L × 16L) + · · · + (d′′1 × 161) + (d′′0 × 160 )
= (qI )16 .
(8.37)
J − 3 = 4L .
(8.38)
[d3 d2 d1 d0 ]2 = [d′′0 ]16 .
(8.39)
[d7 d6 d5 d4 ]2 = [d′′1 ]16 .
(8.40)
[dJ dJ−1 dJ−2 dJ−3]2 = [d′′L ]16 .
(8.41)
As Equações (8.42) – (8.46) ilustram a relação entre as bases octal e hexadecimal.
(qI )8 = (d′K × 8K ) + (d′K−1 × 8K−1) + · · · +
(d′3 × 83 ) + (d′2 × 82 ) +
(d′1 × 81 ) + (d′0 × 80 )
= (d′K × 81 ) + (d′K−1 × 80 ) × 8K−1 + · · · +
′
(d3 × 81 ) + (d′2 × 80 )+ × 82 +
′
(d1 × 81 ) + (d′0 × 80 ) × 80
= (d′′L × 16L ) + · · · + (d′′1 × 161 ) + (d′′0 × 160 )
= (qI )16 .
(8.42)
K − 1 = 2L .
(8.43)
[d′1 d′0 ]8 = [d′′0 ]16 .
(8.44)
[d′3 d′2 ]8 = [d′′1 ]16 .
(8.45)
[d′K d′K−1]2 = [d′′L ]16 .
(8.46)
Embora todas as equações tenham sido definidas para números não negativos e inteiros, não
é difı́cil mostrar que as relações se mantêm para números não negativos e fracionários.
A.S.V.
8.3. Quantização
8.3
93
Quantização
• Quantizar significa representar, através de uma aproximação, uma faixa contı́nua de valores originais por uma faixa de discreta de valores correspondentes.
• Todo sistema de medição possui um intervalo mı́nimo de medida (resolução da medida).
• Por outro lado, todo sistema de numeração possui um intervalo mı́nimo de representação
das quantidades numéricas (resolução da representação).
• Portanto, toda medida, bem como a sua respectiva representação, possuem um grau
intrı́nseco de aproximação.
• Dependendo do parâmetros considerados, a quantização pode assumir diversas clasificações.
• Quanto à regularidade da discretização efetuada, a quantização pode ser classificada como:
uniforme e não uniforme.
• Na quantização uniforme é utilizado um intervalo único de discretização.
• Na quantização não uniforme são empregados diversos intervalos de discretização diferentes.
• Quanto à aproximação adotada para o valor numérico, podem-se destacar três tipos de
quantização: truncamento, arredondamento e truncamento em magnitude.
• O truncamento assume o simples abandono dos dı́gitos menos significativos. Assim sendo,
não se pode garantir que o valor final seja mais próximo do valor original. Além disso,
dependendo do código utilizado para representar a quantidade numérica, o módulo do
valor original pode diminuir ou aumentar.
• No arredondamento, é realizada uma análise dos dı́gitos menos significativos, de forma
que o valor final seja mais próximo do valor original.
• Em alguns sistemas digitais, é desejado que o módulo dos valores quantizados nunca seja
aumentado. Dessa forma, realiza-se o denominado truncamento em magnitude. Para
alguns códigos, isso significa o simples truncamento do valor original. Para outros, devese efetuar uma análise do valor original, de forma a garantir que não ocorra um aumento
no seu módulo.
TET / UFF
94
Capı́tulo 8. Sistemas de numeração
8.4
Exercı́cios propostos
1. Considerando o SNPC, para cada uma das bases listadas abaixo, obter as respectivas
representações para as quantidades apresentadas em seguida.
(a) Base b = 2.
(b) Base b = 3.
(c) Base b = 16.
Quantidades numéricas:
i.
ii.
iii.
iv.
v.
vi.
vii.
viii.
q
q
q
q
q
q
q
q
= (17)10 .
= (24)10 .
= (32)10 .
= (48)10 .
= (80)10 .
= (144)10 .
= (272)10 .
= (528)10 .
2. Considerando o SNPC, com base b = 2, para cada uma das codificações listadas abaixo,
obter as respectivas representações para as quantidades apresentadas em seguida.
(a) Sinal-e-magnitude.
(b) Complemento-a-1.
(c) Complemento-a-2.
Quantidades numéricas:
i.
ii.
iii.
iv.
v.
vi.
vii.
viii.
q
q
q
q
q
q
q
q
= (−17)10 .
= (−24)10 .
= (−32)10 .
= (−48)10 .
= (−80)10 .
= (−144)10 .
= (−272)10 .
= (−528)10 .
3. Considerando o SNPC, com base b = 2, com codificação em complemento-a-2, analise o
resultado das seguintes operações:
(a) (00100) + (01001).
(b) (01100) + (01101).
(c) (00100) + (10111).
(d) (10100) + (01101).
(e) (11100) + (10111).
(f) (10100) + (10011).
A.S.V.
8.4. Exercı́cios propostos
95
4. Considerando o SNPC, com base b = 2, com codificação em complemento-a-2, com um
total 5 dı́gitos, para cada uma das quantizações listadas abaixo, obter as respectivas
representações para as quantidades apresentadas em seguida.
(a) Truncamento.
(b) Arredondento.
(c) Truncamento em magnitude.
Quantidades numéricas:
i.
ii.
iii.
iv.
v.
vi.
vii.
viii.
ix.
x.
xi.
xii.
xiii.
xiv.
xv.
xvi.
TET / UFF
(0010000).
(0010001).
(0010010).
(0010011).
(0010100).
(0010101).
(0010110).
(0010111).
(1110000).
(1101111).
(1101110).
(1101101).
(1101100).
(1101011).
(1101010).
(1101001).
96
Capı́tulo 8. Sistemas de numeração
A.S.V.
Capı́tulo 9
Circuitos combinacionais básicos
9.1
Introdução
• Esse capı́tulo trata do projeto de alguns exemplos de circuitos combinacionais simples,
básicos e tanto necessários quanto comuns a diversas aplicações.
• Técnicas de projetos
– Não existe uma técnica de projeto única que atenda a todos os tipos de problemas.
– Para problemas com baixa complexidade e poucas variáveis:
∗ Projeto formal: equacionamento lógico direto + minimização das equações +
implementação do circuito.
∗ Tentativa-e-erro (cut-and-try): sugestão de uma solução, sem a aplicação de
uma técnica formal, seguida de verificação da funcionalidade.
– Para problemas com alta complexidade e/ou muitas variáveis:
∗ Divisão do sistema original em subsistemas (divide-to-conquer ), a fim de diminuir a complexidade do sistema a ser projetado.
∗ Cada subsistema pode ser subdividido, acarretando um projeto hierárquico.
∗ Para cada subsistema:
· Projeto formal.
· Uso de blocos já projetados.
· Tipos de blocos: idênticos (projeto modular) ou diferentes.
• Arquitetura da solução
– Paralela.
– Serial.
97
98
Capı́tulo 9. Circuitos combinacionais básicos
9.2
Interpretações dos circuitos combinacionais
• Internamente, um circuito combinacional é apenas um conjunto de portas lógicas interligadas, sem realimentações, que realizam operações lógicas com nenhum significado extra.
• Externamente, baseado nas relações entre as variáveis de entrada e de saı́da, os circuitos combinacionais podem ser interpretados de diferentes formas, de acordo com suas
aplicações.
9.2.1
Exemplos de interpretações
• Gerador de funções lógicas
– Entrada: variáveis ou parâmetros de entrada para funções lógicas.
– Saı́da: resultados provenientes da avaliação das funções lógicas implementadas.
• Interpretador de comandos
– Padrões binários apresentados na entrada dos circuitos combinacionais podem ser
interpretados como palavras de comando ou instruções a serem interpretadas e executadas pelo circuito.
– O conjunto de padrões possı́veis de serem apresentados, interpretados e executados
pelo circuito, representa o denominado conjunto de instruções (instruction set) que
o circuito compreende.
– Por exemplo, um circuito combinacional que implemente a função lógica AND, com
duas entradas, pode ser interpretado como um circuito que compreende quatro comandos e produz uma saı́da que pode assumir quatro valores possı́veis.
– Entrada: palavra de comando ou instrução, podendo conter dados dentro do código
da instrução.
– Saı́da: sinais de controle que irão controlar a execução do comando e, possivelmente,
dados.
• Conversor de códigos
– Entrada: código original.
– Saı́da: novo código.
• Sistema digital instantâneo ou sem memória
– Entrada: sequência ou sinal de entrada.
– Saı́da: sequência ou sinal de saı́da.
• Controle de fluxo de dados
– Entrada: dados de entrada + sinais de controle de entrada.
– Saı́da: dados de saı́da + sinais de controle de saı́da.
A.S.V.
9.3. Uso de portas lógicas como elementos de controle
99
• Operador
– Entrada: Operandos.
– Saı́da: Resultados das operações realizadas pelo circuito sobre os operandos apresentados.
• Operador programável
– Entrada: Operandos + Sinais de controle da operação.
– Saı́da: Resultados das operações escolhidas para serem realizadas pelo circuito sobre
os operandos apresentados.
9.3
Uso de portas lógicas como elementos de controle
• Uma porta lógica com N entradas pode ser interpretada como um bloco funcional com 1
saı́da, 1 entrada e (N − 1) sinais de controle.
9.4
Uso de elementos de controle para mascaramento
• Por vezes, é necessário interromper o fluxo de um sinal, baseado em determinadas condições. Isso é denominado de mascaramento do sinal, onde a máscara do processo é formada
pelo conjunto de condições envolvidas.
• Um elemento de controle pode ser empregado para implementar o mascaramento, aplicandose o sinal na sua entrada e a máscara no seu controle.
9.5
Gerador de funções lógicas
• Um circuito combinacional com N entradas e M saı́das pode ser interpretado como M
funções lógicas de N variáveis.
• Cada uma das M funções pode ser definida independentemente das demais.
• As funções podem ser implementadas de forma independente uma das outras, facilitando
o projeto, os testes e a manutenção, ou compartilhando partes do circuito, a fim de reduzir
custos de implementação.
9.6
Conversor de códigos
• Um conversor de códigos é um circuito combinacional com N entradas e M saı́das, onde,
para cada padrão de valores de entrada definido, existe um padrão de valores de saı́da
correspondente.
TET / UFF
100
9.7
Capı́tulo 9. Circuitos combinacionais básicos
Gerador e detector de paridade
• Dado um operando de (N − 1) bits, o circuito gera um enésimo bits, de tal forma que o
total de valores “1” seja par ou ı́mpar, conforme definido.
• Dado um operando de N bits, o circuito indica se o número de valores “1” é par ou ı́mpar,
conforme definido.
9.8
Multiplexador e demultiplexador
• Um multiplexador é um circuito combinacional com N1 entradas e 1 saı́da, controlado por
N2 sinais de controle. De acordo com o padrão de valores aplicados nos sinais de controle,
uma das entradas é copiada para a saı́da.
• Um demultiplexador é um circuito combinacional com 1 entrada e N1 saı́das, controlado
por N2 sinais de controle. De acordo com o padrão de valores aplicados nos sinais de
controle, a entrada é copiada para uma das saı́das, enquanto as demais assumem um
valor lógico/booleano fixo.
• A fim de se utilizar toda a funcionalidade do circuito implementado, normalmente é
empregada a relação N1 = 2N2 .
9.9
Codificador e decodificador de endereço
• Um codificador/decodificador de endereço (address coder/decoder ) também é conhecido
como um codificador/decodificador de linha (line coder/decoder ).
• Um codificador de endereço é um circuito combinacional com N1 entradas e N2 saı́das.
Apenas uma das entradas assumirá um valor lógico/booleano, enquanto todas as demais
assumirão o valor lógico/booleano complementar. O padrão de valores gerado na saı́da
(interpretado como um endereço), será referente à entrada com valor lógico/booleano
diferente das demais entradas.
• Um decodificador de endereço é um circuito combinacional com N2 entradas e N1 saı́das.
De acordo com o padrão de valores aplicados na entrada (interpretado como um endereço),
uma das saı́das assumirá um valor lógico/booleano, enquanto todas as demais assumirão
o valor lógico/booleano complementar.
• A fim de se utilizar toda a funcionalidade do circuito implementado, normalmente é
empregada a relação N1 = 2N2 .
A.S.V.
9.10. Codificador de prioridade
9.10
101
Codificador de prioridade
• Um codificador de prioridades é um circuito combinacional com R entradas, numeradas
de E0 a ER−1 , onde cada uma delas é associada a uma requisição.
• Uma requisição é representada por um valor lógico/booleano.
• As requisições são independentes entre si, podendo ocorrer de 0 a R requisições simultâneas.
• As prioridades das requisições são organizadas na ordem crescente ou decrescente dos
números das entradas.
• Em uma primeira versão, o circuito apresenta R saı́das. Nesse caso, a saı́da Sk , para
0 ≤ k ≤ (R − 1), deve assumir um valor lógico/booleano somente quando houver uma
requisição na entrada Ek e ela for a de mais alta prioridade no momento, enquanto todas
as demais saı́das assumirão o valor lógico/booleano complementar.
• Em uma outra versão, o circuito apresenta N saı́das, onde R = 2N . Aqui, o padrão de
valores gerado na saı́da (interpretado como um endereço), será referente à entrada onde
ocorre a requisição de mais alta prioridade.
9.11
Ordenador binário
• O circuito possui N entradas e N saı́das.
• A saı́da apresenta todas as ocorrências de um valor lógico/booleano na entrada, seguidas
de todas as ocorrências do valor lógico/booleano complementar.
9.12
Deslocadores (shifters)
• O circuito possui N entradas e N saı́das.
• O padrão de saı́da é uma versão deslocada do padrão de entrada.
• O deslocamento pode ser de qualquer quantidade e para qualquer um dos dois sentidos.
• Três tipos de deslocamento são comumente implementados:
– Deslocamento lógico: as posições vazias são ocupadas pelo valor booleano “0”.
– Deslocamento aritmético: as posições vazias são ocupadas pelo valor booleano da
extremidade mais próxima.
– Deslocamento circular ou rotação: cada posição vazia é ocupada pelo valor removido.
• O termo barrel shifter é usado tanto para circuitos que implementam apenas a rotação
como também para aqueles que realizam os demais deslocamentos.
TET / UFF
102
9.13
Capı́tulo 9. Circuitos combinacionais básicos
Somadores em binário puro
• A seguir, são apresentados somadores de 2 operandos, codificados em binário puro.
9.13.1
Half-adder (HA)
• Um half-adder é um circuito combinacional com 2 entradas e 2 saı́das, todas de 1 bit, que
se comporta como um somador de 2 operandos, onde uma das saı́das é o resultado da
soma e a outra é o sinal de “vai-um” de saı́da (carry out).
• Equações básicas de um half-adder :
9.13.2
Co = (A · B) .
S = A · B + A · B = (A ⊕ B) .
Full-adder (FA)
• Um full-adder é um circuito combinacional com 3 entradas e 2 saı́das, todas de 1 bit,
que se comporta como um somador de 2 operandos, onde uma das entradas é sinal de
“vai-um” de entrada (carry in), enquanto uma das saı́das é o resultado da soma e a outra
é o sinal de “vai-um” de saı́da (carry out).
• Empregando-se diferentes elementos constituintes, diversas implementações podem ser
encontradas para um full-adder. Alguns exemplos são:
– SOP mı́nima:
Co = (A · B) + (A · Ci ) + (B · Ci ) .
S = A · B · Ci + A · B · Ci + A · B · Ci + (A · B · Ci ) = (A ⊕ B) ⊕ Ci .
– Bloco HA:
Co1 = (A · B) = G .
S1 = (A ⊕ B) = P .
Co2 = (S1 · Ci ) = (P · Ci ) .
S2 = (S1 ⊕ Ci ) = (P ⊕ Ci ) .
Co = Co1 + Co2 = G + (P · Ci ) .
S = S2 = (P ⊕ Ci ) .
– Bloco AOI (com diferentes composições):
Co = (A · B) + (A · Ci ) + (B · Ci ) = (A · B) + [(A + B) · Ci ] .
S = (A · B · Ci ) + (A + B + Ci ) · Co = [(A · B) · Ci ] + (A + B + Ci ) · Co .
– Multiplexador:
MUX1 = Ci · A + (Ci · A) .
MUX2 = B · MUX1 + (A · MUX1 ) .
MUX3 = MUX2 · MUX1 + (B · MUX1 ) .
Co = MUX2 .
Co = MUX2 .
S = MUX3 .
A.S.V.
103
9.13. Somadores em binário puro
9.13.3
Ripple-carry adder (RCA) ou carry propagate adder (CPA)
• Um ripple-carry adder ou um carry propagate adder é um circuito combinacional com
1 entrada de 1 bit, 2 entradas de N bits, 1 saı́da de N bits e 1 saı́da de 1 bit. que se
comporta como um somador de 2 operandos de N bits, que recebe um sinal de “vai-um”
de entrada (carry in) e gera um sinal de “vai-um” de saı́da (carry out), além do resultado
de N bits.
• Na sua forma original, o circuito é modular, sendo formado por uma seqüência de N blocos
do tipo full-adder, interligados pelos sinais “vai-um” de entrada (carry in) e “vai-um” de
saı́da (carry out) de cada par de blocos, o que justifica o seu nome.
• A facilidade de projeto é contrabalanceada pelo tempo de estabilização do resultado, que
é lento, uma vez que deve-se esperar pelo tempo total de N propagações do sinal de
“vai-um” (carry), acrescido do tempo de operação do último full-adder.
• Algumas implementações do bloco FA necessitam de um inversor tanto na saı́da Co quanto
na saı́da S. A remoção desses inversores produz um bloco F A que apresenta uma redução
de tempo na geração do carry. Utilizando-se esse FA modificado para implementar o
somador RCA, pode-se reduzir o tempo de caminho crı́tico do somador, que é o tempo
total de propagação de carry. Porém, para o correto funcionamento do somador RCA,
inversores extras devem ser anexados. Considerando-se que os operandos são formados
pelos N dı́gitos Op = [ dN −1 dN −2 · · · d1 d0 ], deve-se adicionar um inversor na saı́da
dos blocos F A com ı́ndice zero e par. Por sua vez, deve-se adicionar um inversor em cada
uma das entradas dos blocos F A com ı́ndice ı́mpar. Se N for ı́mpar, deve-se acrescentar
um inversor na saı́da carry out do somador RCA.
9.13.4
Carry lookahead adder (CLA)
• Um carry lookahead adder é um circuito combinacional com 1 entrada de 1 bit, 2 entradas
de N bits, 1 saı́da de N bits e 1 saı́da de 1 bit. que se comporta como um somador de
2 operandos de N bits, que recebe um sinal de “vai-um” de entrada (carry in) e gera um
sinal de “vai-um” de saı́da (carry out), além do resultado de N bits.
• Esse é um dos diversos somadores que busca uma melhoria de eficiência através da diminuição do tempo de caminho crı́tico, associado à propagação interna do carry.
• O circuito também é formado por uma seqüência de N blocos do tipo full-adder. Porém,
a caracterı́stica básica desse somador é que a geração do sinal Co em cada estágio é feita
localmente, ao invés de esperar a propagação de carry pelos estágios anteriores.
• Supondo-se que o sinal Ck é o carry de ligação entre os estágios k − 1 e k, as equações
originais do somador, para N = 4, são:
C0
C1
C2
C3
C4
TET / UFF
=
=
=
=
=
Cin
G0 + (P0 · C0 )
G1 + (P1 · C1 )
G2 + (P2 · C2 )
G3 + (P3 · C3 ) = Cout .
104
Capı́tulo 9. Circuitos combinacionais básicos
• Por sua vez, supondo-se que o sinal Sk é a saı́da do estágio k, as equações originais do
somador, para N = 4, são:
S0
S1
S2
S3
=
=
=
=
(P0 ⊕ C0 )
(P1 ⊕ C1 )
(P2 ⊕ C2 )
(P3 ⊕ C3 ) .
• Para obter a citada aceleração do tempo de caminho crı́tico, são definidas as funções
generate de grupo Gi:j e propagate de grupo Pi:j , definidas a seguir, de tal forma que os
sinais Ck são reescritos como
C1 = G0 + (P0 · C0 )
= G0:0 + (P0:0 · C0 )
C2 =
=
=
=
C3 =
=
=
=
C4 =
=
=
=
G1 + (P1 · C1 )
G1 + (P1 · (G0 + (P0 · C0 )))
(G1 + P1 · G0 ) + (P1 · P0 ) · C0
G1:0 + (P1:0 · C0 )
G2 + (P2 · C2 )
G2 + (P2 · (G1 + (P1 · (G0 + (P0 · C0 )))))
(G2 + P2 · G1 + P2 · P1 · G0 ) + (P2 · P1 · P0 ) · C0
G2:0 + (P2:0 · C0 )
G3 + (P3 · C3 )
G3 + (P3 · (G2 + (P2 · (G1 + (P1 · (G0 + (P0 · C0 )))))))
(G3 + P3 · G2 + P3 · P2 · G1 + P3 · P2 · P1 · G0 ) + (P3 · P2 · P1 · P0 ) · C0
G3:0 + (P3:0 · C0 ) ,
onde
Gk = (Ak · Bk )
e
Pk = (Ak ⊕ Bk ) ,
lembrando-se ainda que, para o cálculo dos sinais Ck , pode-se utilizar
Pk+ = (Ak + Bk ) .
A.S.V.
9.14. Subtratores em binário puro
9.14
105
Subtratores em binário puro
• A seguir, são apresentados subtratores de 2 operandos, codificados em binário puro.
9.14.1
Half-subtractor (HS)
• Um half-subtractor é um circuito combinacional com 2 entradas e 2 saı́das, todas de 1 bit,
que se comporta como um subtrator de 2 operandos, onde uma das saı́das é o resultado
da subtração e a outra é o sinal de “veio-um” de saı́da (borrow out).
9.14.2
Full-subtractor (FS)
• Um full-subtractor é um circuito combinacional com 3 entradas e 2 saı́das, todas de 1 bit,
que se comporta como um subtrator de 2 operandos, onde uma das entradas é sinal de
“veio-um” de entrada (borrow in), enquanto uma das saı́das é o resultado da subtração e
a outra é o sinal de “veio-um” de saı́da (borrow out).
9.14.3
Ripple-borrow subtractor (RBS) ou
borrow propagate subtractor (BPS)
• Um ripple-borrow subtractor ou um borrow propagate subtractor é um circuito combinacional com 1 entrada de 1 bit, 2 entradas de N bits, 1 saı́da de N bits e 1 saı́da de 1
bit. que se comporta como um subtrator de 2 operandos de N bits, que recebe um sinal
de “veio-um” de entrada (borrow in) e gera um sinal de “veio-um” de saı́da (borrow out),
além do resultado de N bits.
• Na sua forma original, o circuito é modular, sendo formado por uma seqüência de N
blocos do tipo full-subtractor, interligados pelos sinais “veio-um” de entrada (borrow in)
e “veio-um” de saı́da (borrow out) de cada par de blocos, o que justifica o seu nome.
• A facilidade de projeto é contrabalanceada pelo tempo de estabilização do resultado, que
é lento, uma vez que deve-se esperar pelo tempo total de N propagações do sinal de
“veio-um” (borrow ), acrescido do tempo de operação do último full-subtractor.
9.15
Incrementador e decrementador em binário puro
• Os circuitos incrementador e decrementador são versões simplificadas dos circuitos
somador e subtrator, respectivamente.
• Eles adicionam ou subtraem, respectivamente, uma unidade ao bit menos significativo
(LSB) do operando a ser incrementado ou decrementado.
• Assim sendo, pode-se adotar um projeto por uso de blocos pré-existentes.
TET / UFF
106
Capı́tulo 9. Circuitos combinacionais básicos
• Por exemplo:
– Um incrementador pode ser obtido de um ripple-carry adder baseado em full-adder,
aplicando-se Op2 = [ 0 0 · · · 0 0 ] = 0 e Cin = 1, além de realizar as conseqüentes
simplificações no circuito.
– Um decrementador pode ser obtido de um ripple-borrow subtractor baseado em fullsubtractor, aplicando-se Op2 = [ 0 0 · · · 0 0 ] = 0 e Bin = 1, além de realizar as
conseqüentes simplificações no circuito.
– Um decrementador pode ser obtido de um ripple-carry adder baseado em full-adder,
aplicando-se Op2 = [ 1 1 · · · 1 1 ] = −1 e Cin = 0, além de realizar as conseqüentes
simplificações no circuito.
9.16
Complementadores
• A seguir, são apresentados dois exemplos de conversores de códigos numéricos.
9.16.1
Complementador-a-1 (bitwise implementation)
• Um complementador-a-1 é um circuito combinacional com N entradas e N saı́das, que
realiza a conversão entre os códigos numéricos binário puro e complemento-a-1.
• Uma vez que, nessa conversão, as operações sobre os bits são independentes, um projeto
modular elementar pode ser adotado, utilizando-se a porta lógica XOR como bloco básico.
9.16.2
Complementador-a-2
• Um complementador-a-2 é um circuito combinacional com N entradas e N saı́das, que
realiza a conversão entre os códigos numéricos binário puro e complemento-a-2.
• Uma vez que, nessa conversão, as operações sobre os bits não são independentes, diferentes
técnicas podem ser adotadas, as quais são abordadas a seguir.
Complementador-a-1 + somador em binário puro
• Nesse caso, um complementador-a-2 é implementado usando um circuito complementadora-1 em conjunto com um circuito somador em binário puro. Por sua vez, o circuito
somador pode ser um somador de dois operandos ou apenas um incrementador.
Decrementador com saı́das invertidas
• Considerando-se um complementador-a-2 sem sinal de controle de complementação, podese adotar um decrementador com as saı́das invertidas. Isso é matematicamente comprovado por
(q)C2 = 2N − |q| = 2N − 1 + 1 − |q| = 2N − 1 − (|q| − 1) = (|q| − 1)C1 .
Complementador-a-2 puro (bit-scanning implementation)
• Nesse caso, um complementador-a-2 é implementado usando um projeto modular.
A.S.V.
9.17. Multiplicadores em binário puro
9.17
107
Multiplicadores em binário puro
• A seguir, é apresentada uma possı́vel implementação modular para um multiplicador de
2 operandos, em binário puro.
9.17.1
Multiplicador de 1 bit
• É facilmente demonstrável que um multiplicador de 2 operandos de 1 bit pode ser implementado por uma porta lógica AND.
9.17.2
Multiplicador de N bits
• Utilizando-se um projeto modular, pode-se mostrar que um multiplicador de 2 operandos
de N bits pode ser implementado usando apenas multiplicadores de 1 bit e full-adders.
9.18
Comparadores
• A seguir, são apresentados exemplos de circuitos combinacionais utilizados para comparação.
9.18.1
Comparador numérico de um operando
Comparador numérico de um operando (menor, igual, maior número de valores “0”
e “1”, no operando)
• Dado um operando, o circuito fornece 3 saı́das, que indicam se o número de valores “0” é
menor, igual ou maior que o número de valores “1”.
9.18.2
Comparador numérico de dois operandos
Comparador numérico de dois operandos (menor, igual, maior)
• Dados 2 operandos codificados em binário puro, o circuito fornece 3 saı́das, que indicam
se o operando Op1 é menor, igual ou maior que o operando Op2 .
Comparador numérico de dois operandos (menor, igual, maior número de valores
“0”, ou “1”, em cada operando)
• Dados 2 operandos, o circuito fornece 3 saı́das, que indicam se o número de valores “0”,
ou “1”, no operando Op1 é menor, igual ou maior que no operando Op2 .
TET / UFF
108
Capı́tulo 9. Circuitos combinacionais básicos
A.S.V.
Parte III
Circuitos sequenciais
109
Capı́tulo 10
Circuitos seqüenciais: conceitos básicos
10.1
Introdução
• Circuitos combinacionais × circuitos seqüenciais.
• Circuitos combinacionais são sistemas instantâneos ou sem memória.
• Circuitos seqüenciais são sistemas dinâmicos ou com memória.
• Por serem sistemas instantâneos, os circuitos combinacionais respondem sempre da mesma
forma, em qualquer momento, para os mesmos valores das variáveis de entrada.
• Por sua vez, por serem sistemas dinâmicos, dependendo da informação que se encontre
armazenada, os circuitos seqüenciais podem responder de formas diferentes, em diferentes
momentos, para os mesmos valores das variáveis de entrada.
• Circuitos seqüenciais também podem ser denominados de máquinas de estados ou de
autômatos.
10.2
Estados e variáveis de estado
• Uma vez que eles são capazes de armazenar energia, os sistemas dinâmicos podem apresentar diversas configurações energéticas diferentes, denominadas estados.
• Uma medida do estado de um sistema, em um instante de tempo t = tn , são os valores
assumidos por todas as variáveis do sistema, em t = tn .
• Interpretando-se o conjunto de todas as variáveis de um sistema como um espaço vetorial,
pode-se selecionar um conjunto mı́nimo de variáveis para formar uma base para esse
espaço. Uma vez que, a partir da base, podem ser obtidas todas as demais variáveis e,
portanto, pode-se caracterizar o estado do sistema, as variáveis da base são denominadas
variáveis de estado do sistema.
• Dessa forma, uma definição clássica para estado e variáveis de estado é: “O estado de
um sistema, em qualquer instante de tempo t = tn , é o menor conjunto de variáveis
(denominadas variáveis de estado), calculadas em t = tn , suficiente para determinar o
comportamento do sistema para qualquer instante de tempo t ≥ tn , quando a entrada do
sistema é conhecida para t ≥ tn ”.
111
112
10.3
Capı́tulo 10. Circuitos seqüenciais: conceitos básicos
Tipos de variáveis e sua interações
• Será considerado que todas as variáveis do circuito são booleanas.
• Assim sendo, os valores das variáveis podem ser interpretados como:
– Nı́vel: a informação é representada pelos nı́veis lógicos das variáveis boolenas (0 e
1). Cada nı́vel representa um evento.
– Borda: a informação é associada à seqüência de nı́veis 0 e 1 (borda positiva) ou à
seqüência de nı́veis 1 e 0 (borda negativa). Cada borda representa um evento.
– Transição: a informação é associada à troca de nı́veis 0 para 1 (transição positiva)
ou à troca de nı́veis 1 para 0 (transição negativa). Cada transição representa um
evento.
– Pulso: a informação é associada à seqüência de nı́veis 0 e 1 e 0 (pulso positivo) ou
à seqüência de nı́veis 1 e 0 e 1 (pulso negativo). A duração do valor intermediário
da seqüência é denominada de largura do pulso (pulsewidth) e deve ser pequena em
relação aos tempos envolvidos. Cada pulso representa um evento.
• Para alguns tipos de circuitos, as interações entre sinais dos tipos nı́vel e pulso são de
particular interesse. A Tabela 10.1 resume as possı́veis interações, considerando-se as
operações lógicas AND e OR. Os resultados indicam que, para tais operações, alguns tipos
de interações produzem resultados indeterminados. Portanto, no projeto de sistemas com
sinais pulsados, tais resultados devem ser levados em consideração.
A
Nı́vel
Nı́vel
Pulso Positivo
Nı́vel
Pulso Negativo
Pulso Positivo
B
Nı́vel
Pulso Positivo
Pulso Positivo
Pulso Negativo
Pulso Negativo
Pulso Negativo
A·B
Nı́vel
Pulso Positivo
Indeterminado
Indeterminado
Pulso Negativo
Indeterminado
A+B
Nı́vel
Indeterminado
Pulso Positivo
Pulso Negativo
Indeterminado
Indeterminado
Tabela 10.1: Tipos de interações entre sinais dos tipos nı́vel e pulso.
A.S.V.
113
10.4. Modelo genérico para circuitos seqüenciais
10.4
Modelo genérico para circuitos seqüenciais
• Na Figura 10.1 é apresentado um modelo genérico para circuitos seqüenciais, onde:
– xi ∈ x, i = 1, 2, · · · , L, são as variáveis de entrada ou variáveis de entrada principais.
– zi ∈ z, i = 1, 2, · · · , M, são as variáveis de saı́da ou variáveis de saı́da principais.
– Yi ∈ Y , i = 1, 2, · · · , P , são as variáveis de excitação ou variáveis de saı́da secundárias.
– yi ∈ y, i = 1, 2, · · · , R, são as variáveis de estado ou variáveis de entrada secundárias.
– tn é o instante atual, tn−1 é o instante anterior e tn+1 é o próximo instante.
– zin = fi (xn1 , · · · , xnL , y1n , · · · , yRn ), i = 1, 2, · · · , M.
– Yjn = fj (xn1 , · · · , xnL , y1n, · · · , yRn ), j = 1, 2, · · · , P .
– ykn+1 = fk (Y1n , · · · , YPn ), k = 1, 2, · · · , R.
• O conjunto das variáveis yi é denominado estado atual.
• Por sua vez, conjunto das variáveis xi e yi é dito estado atual total.
• O bloco denominado Função Combinacional é um circuito combinacional que, de
acordo com a viabilidade de custo, pode ser implementado através de portas lógicas individuais, memórias ROM (Read-Only Memory) ou circuitos PLA (Programmable Logic
Array).
• O bloco de memória denominado Geração e Armazenamento das Variáveis de Estado representa um dispositivo genérico de memória (flip-flop, banco de memória, atrasos
de propagação).
• A função do bloco de memória não é simplesmente armazenar Yin na forma de yin+1. Pelo
contrário, a sua função é mais complexa: a partir de alguns Yin deve ser gerado yjn+1, o
qual, então, será retido (armazenado).
x
L
z
M
~
Funçao
Combinacional
y
R
P
Y
~ e Armazenamento
Geraçao
´
das Variaveis
de Estado
Figura 10.1: Modelo genérico para circuitos seqüenciais.
TET / UFF
114
10.5
Capı́tulo 10. Circuitos seqüenciais: conceitos básicos
Classificação de circuitos seqüenciais quanto à dependência do sinal de saı́da
• Máquinas (circuitos) de Mealy e de Moore.
• Máquinas de Mealy: zin = fi (xn1 , · · · , xnL , y1n , · · · , yRn ), i = 1, 2, · · · , M.
• Máquinas de Moore: zin = fi (y1n , · · · , yRn ), i = 1, 2, · · · , M.
• As Figuras 10.2 e 10.3 apresentam, respectivamente, um exemplo de máquina de Mealy
e um exemplo de máquina de Moore.
• Geralmente, as máquinas de Mealy são implementadas por circuitos mais simples do que
as máquinas de Moore.
• Por outro lado, nas máquinas de Moore, em conseqüência de sua definição, os valores dos
sinais de saı́da permanecem constantes entre dois estados consecutivos. Portanto, tornase mais simples controlar a interação entre diversos blocos de circuitos desse tipo. Pela
mesma razão, é mais fácil acompanhar a evolução dos estados do circuito, o que simplifica
a depuração de erros.
x0
z0
x1
Y1
y1
y0
z1
Y0
~ e Armazenamento
Geraçao
´
das Variaveis
de Estado
Figura 10.2: Exemplo de máquina de Mealy.
A.S.V.
10.6. Classificação de circuitos seqüenciais quanto ao tipo de controle da mudança de estado115
x0
Y1
x1
z0
Y0
y1
y0
~ e Armazenamento
Geraçao
´
das Variaveis
de Estado
Figura 10.3: Exemplo de máquina de Moore.
10.6
Classificação de circuitos seqüenciais quanto ao tipo
de controle da mudança de estado
• Na literatura, são encontradas várias denominações diferentes para designar os diversos
tipos de circuitos seqüenciais existentes.
• A nomenclatura aqui utilizada será a seguinte:
– Clock-mode ou clocked.
– Pulsed.
– Level-mode.
10.6.1
Circuitos seqüenciais clock-mode ou clocked
• A Figura 10.4 ilustra um modelo genérico para circuitos seqüenciais clock-mode.
• Todas as variáveis carregam informação nos nı́veis.
• As variáveis de estado são modificadas apenas pela ação de um sinal pulsante, com função
de temporização ou de controle, comumente denominado de relógio (clock ).
• Apesar de ser um sinal pulsante, não é necessário que o clock seja periódico.
• O sinal de clock não carrega qualquer tipo de informação. Ele só determina quando haverá
mudança de estado.
• As variáveis de excitação, em conjunto com os elementos de armazenamento, determinam
qual será a mudança de estado.
• As variáveis de entrada devem estar estáveis quando da atuação do clock.
TET / UFF
116
Capı́tulo 10. Circuitos seqüenciais: conceitos básicos
• Um clock atuando em tn , com xn , z n , e Y n estáveis, provoca uma mudança de estado de
y n para y n+1 .
• O circuito deve estar estável entre dois pulsos de clock. Assim, o que limita a freqüência
máxima de operação do circuito é, basicamente, a soma do tempo de estabilização da
memória com o tempo de propagação máximo do circuito combinacional.
• De certa forma, um circuito seqüencial clock-mode pode ser interpretado como um caso
particular de circuitos seqüenciais pulsed.
x
L
z
M
~
Funçao
Combinacional
y
R
Y
P
~ e Armazenamento
Geraçao
´
das Variaveis
de Estado
Controle de mudança de estado
1
Figura 10.4: Modelo genérico para circuitos seqüenciais clock-mode.
10.6.2
Circuitos seqüenciais pulsed
• A Figura 10.5 apresenta um modelo genérico para circuitos seqüenciais pulsed.
• Não há um sinal pulsante de clock separado, sem informação.
• A mudança de estado ocorre pela atuação de um pulso em um sinal de entrada.
10.6.3
Circuitos seqüenciais level-mode
• Na Figura 10.6 pode ser visto um modelo genérico para circuitos seqüenciais level-mode.
• A realimentação das variáveis de excitação Yi , gerando as variáveis de estado yj , é realizada
de forma contı́nua, ao contrário das demais classes, onde a mesma é controlada.
• A mudança de estado ocorre pela atuação de nı́veis dos sinais de entrada.
• Caso particular: operação em modo fundamental, onde uma mudança de nı́vel só pode
ocorrer após a mudança de nı́vel anterior ter levado a máquina a um estado estável.
• Assim como nos demais classes: ykn+1 = fk (Y1n , · · · , YPn ), k = 1, 2, · · · , R.
• Mais especificamente, neste caso: P = R e yk (t + ∆tk ) = Yk (t), k = 1, 2, · · · , P .
A.S.V.
10.6. Classificação de circuitos seqüenciais quanto ao tipo de controle da mudança de estado117
x
L
z
M
~
Funçao
Combinacional
y
R
P
Y
~ e Armazenamento
Geraçao
´
das Variaveis
de Estado
Controle de mudança de estado
Figura 10.5: Modelo genérico para circuitos seqüenciais pulsed.
• Os atrasos ∆tk que implementam o bloco de memória não são blocos de retardo isolados. Eles representam a concentração de atrasos de propagação existentes no circuito
combinacional.
x
z
M
L
~
Funçao
Combinacional
y
P
P
Y
t1
tP
Figura 10.6: Modelo genérico para circuitos seqüenciais level-mode.
TET / UFF
118
Capı́tulo 10. Circuitos seqüenciais: conceitos básicos
A.S.V.
Capı́tulo 11
Elementos básicos de armazenamento
11.1
Introdução
• Se toda a informação presente em um circuito seqüencial for expressa por meio de valores
binários, os elementos básicos de armazenamento deverão ser dispositivos capazes de
armazenar variáveis booleanas.
• Assim, os requisitos básicos para tais dispositivos são:
– Capacidade de representar os valores lógicos “0” e “1”.
– Possibilidade de representar apenas os valores lógicos “0” e “1”.
– Capacidade de travar (latch) os valores lógicos “0” e “1” por tempo indeterminado.
– Capacidade de decidir sobre o valor lógico a ser armazenado, a partir de sinais de
acionamento.
• Os requisitos acima definem um dispositivo com dois estados, estáveis, cuja mudança de
estados é disparada (triggered ) por sinais de ativação especı́ficos.
• Tecnicamente, tal dispositivo é denominado de multivibrador biestável.
• Popularmente, embora não haja um consenso sobre a classificação dos dispositivos, são
empregadas as denominações latch e flip-flop.
• Um dispositivo multivibrador biestável pode ser implementado através de circuitos analógicos, utilizando-se transistores, resistores e capacitores.
• Por outro lado, é possı́vel obter uma implementação dita digital, utilizando-se apenas
portas lógicas como elementos primitivos.
• Do ponto de vista de integração do sistema (lógica combinacional + lógica seqüencial),
a implementação digital pode ser interpretada como a mais adequada para o projeto de
sistemas digitais, uma vez que utiliza portas lógicas como elementos primitivos.
• Deve ser ressaltado que, pela sua própria caracterização, os elementos básicos de armazenamento, implementados de forma digital, são circuitos seqüenciais elementares, do tipo
level-mode.
119
120
11.2
Capı́tulo 11. Elementos básicos de armazenamento
Classificação quanto à funcionalidade
• No tocante à funcionalidade, existem quatro tipos básicos de flip-flops: SR, JK, D e T.
• Dependendo do tipo de implementação do dispositivo e dos sinais de ativação existentes,
diversas variações desses quatro tipos básicos podem ser definidas e implementadas.
• Independentemente das possı́veis variações, a funcionalidade básica de cada um dos quatro
tipos citados pode ser representada pelas seguintes equações, onde X n representa o valor
da variável X no instante tn e X n+1 representa o valor da variável X no instante seguinte
tn+1 :
– Flip-flop SR:
Qn+1 = (S n ) + Rn · Qn
Indeterminado
, para (S n · Rn ) = 0
.
, para S n = Rn = 1
(11.1)
– Flip-flop JK:
– Flip-flop D:
Qn+1 = J n · Qn + K n · Qn .
(11.2)
Qn+1 = D n .
(11.3)
Qn+1 = Qn
(11.4)
Qn+1 = T n · Qn + T n · Qn .
(11.5)
– Flip-flop T1 :
– Flip-flop T2 :
• As operações básicas, associadas às Equações (11.1), (11.2), (11.3) e (11.5), podem ser
mais facilmente identificadas através de suas respectivas tabelas, apresentadas na Figura 11.1.
• As variáveis S, R, J, K, D e T representam os sinais de entrada, enquanto a variável Q
representa o sinal de saı́da dos respectivos flip-flops.
• Das equações apresentadas, e de suas respectivas tabelas, torna-se natural o significado
da nomenclatura dos sinais: Q (Quiescent), SR (Set-Reset), D (unit Delay) e T (Toggle).
• A nomenclatura JK surgiu historicamente, sem qualquer relação com a sua funcionalidade.
A.S.V.
11.3. Relacionamento entre os tipos básicos de flip-flops
Sn
0
0
1
1
Rn
0
1
0
1
Dn
0
1
Qn+1
Qn
0
1
proibido
Qn+1
0
1
121
Jn
0
0
1
1
Kn
0
1
0
1
Tn
0
1
Qn+1
Qn
0
1
Qn
Qn+1
Qn
Qn
Figura 11.1: Tabelas de operação básica para os flip-flops SR, JK, D e T2 .
11.3
Relacionamento entre os tipos básicos de flip-flops
• Observando-se as equações dos tipos básicos de flip-flops, e suas respectivas tabelas, podese notar um estreito relacionamento entre eles.
• Alguns desses relacionamentos podem ser estabelecidos sem o emprego de realimentação,
o que acontece nos casos de um flip-flop com mais funcionalidade para um flip-flop com
menos funcionalidade.
• Os casos contrários requerem que o flip-flop seja realimentado.
• Inicialmente, pode-se estabelecer as seguintes relações entre os flip-flops SR, JK, D e T:
– Para as combinações de entrada “00”, “01” e “10”, os flip-flops SR e JK possuem o
mesmo comportamento.
– O flip-flop JK amplia a operação do flip-flop SR, implementando uma funcionalidade
para a combinação de entrada “11”.
– O flip-flop JK, com as entradas J = K = 1 ou J = K = T , é equivalente ao flip-flop
T, de acordo com as Equações (11.4) e (11.5), respectivamente.
– Por sua vez, um flip-flop D pode ser implementado a partir de flip-flops SR ou JK,
se S = D e R = S ou se J = D e K = J, respectivamente.
– Um flip-flop T1 pode ser implementado a partir de um flip-flop T2 , fazendo-se T = 1.
– A partir de um flip-flop D
pode-se implementar um flip-flop T, adotando-se D = Q
ou D = T · Q + T · Q , conforme as Equações (11.4) e (11.5), respectivamente.
• A Tabela 11.1 apresenta um resumo de transformações envolvendo flip-flops dos tipos
SR, JK, D, e T, utilizando suas entradas e saı́das como variáveis de projeto. As opções
marcadas com (*) indicam a impossibilidade desse tipo de projeto, uma vez que o flip-flop
do tipo T1 não possui entrada de dados. Existe apenas um sinal de sincronismo (CT RL ou
CK) que controla a sua operação. Sendo assim, uma solução diferente deve ser proposta,
a qual atue sobre tal sinal de controle.
TET / UFF
122
Capı́tulo 11. Elementos básicos de armazenamento
Transformação
desejada
Tipo de arquitetura
Sem realimentação
Com realimentação
JK −→ SR
JK −→ D
JK −→ T1
JK −→ T2
Não aplicar: J = K = 1
J =D;K=J
J =K=1
J =K=T
—
—
—
—
SR −→ JK
D −→ JK
T1 −→ JK
T2 −→ JK
—
—
(*)
—
S = (J · Q) ; R = (K · Q)
D = (J · Q) + (K · Q)
(*)
T = (J · Q) + (K · Q)
SR −→ D
SR −→ T1
SR −→ T2
S=D ;R=S
—
—
—
S=Q;R=Q
S = (T · Q) ; R = (T · Q)
D −→ SR
T1 −→ SR
T2 −→ SR
—
(*)
—
D = (S) + (R · Q)
(*)
T = (S · Q) + (R · Q)
D −→ T1
D −→ T2
—
—
D=Q
D = (T · Q) + (T · Q)
T1 −→ D
T2 −→ D
(*)
—
(*)
T = (D · Q) + (D · Q)
T1 −→ T2
(*)
(*)
T2 −→ T1
T =1
—
Tabela 11.1: Transformações envolvendo flip-flops dos tipos JK, D, T1 e T2 .
A.S.V.
11.4. Mapas de excitação dos flip-flops
11.4
123
Mapas de excitação dos flip-flops
• Uma outra forma de descrever a operação de um flip-flop é através do tipo de excitação
que deve ser aplicado nas suas entradas a fim de provocar uma determinada variação na
sua saı́da. Tal forma de descrição é denominada mapa de excitação.
• A Figura 11.2 apresenta os mapas de excitação para os flip-flops SR, JK, D e T2 .
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Qn+1
0
1
0
1
X
X
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Sn
0
1
0
X
X
X
Rn
X
0
1
0
X
X
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Qn+1
0
1
0
1
X
X
Jn
0
1
X
X
X
X
Qn+1
0
1
0
1
X
X
Dn
0
1
0
1
X
X
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Qn+1
0
1
0
1
X
X
Tn
0
1
1
0
X
X
Kn
X
X
1
0
X
X
Figura 11.2: Mapas de excitação para os flip-flops SR, JK, D e T2 .
11.5
Tipos de comportamento das saı́das dos flip-flops
• Os tipos de comportamento que a saı́da de um flip-flop pode apresentar, de um instante
de tempo (tn ) para o instante de tempo seguinte (tn+1 ), são definidos na Tabela 11.2.
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Qn+1
0
1
0
1
X
X
Sı́mbolo
0
α
β
1
X
X
Tipo de Comportamento
Estático
Dinâmico
Dinâmico
Estático
Indeterminado
Indeterminado
Tabela 11.2: Definição dos tipos de comportamento apresentados pela saı́da de um flip-flop.
TET / UFF
124
11.6
Capı́tulo 11. Elementos básicos de armazenamento
Excitação × comportamento
• As tabelas da Figura 11.3 associam os tipos de comportamento da saı́da às respectivas
excitações que as entradas devem sofrer, para os flip-flops SR, JK, D e T2 .
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Qn+1
0
1
0
1
X
X
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Sn
0
1
0
X
X
X
Rn
X
0
1
0
X
X
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Qn+1
0
1
0
1
X
X
Variação
0
α
β
1
X
X
Jn
0
1
X
X
X
X
Variação
0
α
β
1
X
X
Dn
0
1
0
1
X
X
Qn
0
0
1
1
0
1
→
→
→
→
→
→
→
Qn+1
0
1
0
1
X
X
Variação
0
α
β
1
X
X
Tn
0
1
1
0
X
X
Variação
0
α
β
1
X
X
Qn+1
0
1
0
1
X
X
Kn
X
X
1
0
X
X
Figura 11.3: Tipos de comportamento e respectivas excitações para os flip-flops SR, JK, D e
T2 .
11.7
Funcionalidade × excitação × comportamento
• A Tabela 11.3 apresenta um resumo geral de funcionalidade-excitação-comportamento,
relacionando os valores de excitação a serem aplicados nas entradas, a partir de cada tipo
de comportamento da saı́da, para cada tipo de flip-flop.
Entrada
S
R
J
K
D
T
Entrada = “1” Entrada = “0” Entrada = “X”
α
0,β
1,X
β
1,α
0,X
α
0
1,β,X
β
1
0,α,X
1,α
0,β
X
α,β
0,1
X
Tabela 11.3: Tabela resumo de funcionalidade-excitação-comportamento para os flip-flops SR,
JK, D e T2 .
A.S.V.
11.8. Circuitos seqüenciais × tabelas dos flip-flops
11.8
125
Circuitos seqüenciais × tabelas dos flip-flops
• Uma vez que os flip-flops podem usados como elementos básicos de armazenamento nos
circuitos seqüenciais, as tabelas que os definem apresentam-se como ferramentas de análise
e sı́ntese para tais circuitos.
• As aplicações e os termos citados a seguir serão definidos nos próximos capı́tulos.
• No processo de análise de um circuito seqüencial, as tabelas de operação dos flip-flops são
utilizadas para montar a tabela de mudança de estados.
• No processo de sı́ntese, as tabelas de excitação e de comportamento são necessárias para
montar os mapas-K de excitação e de transição, respectivamente.
• Os mapas-K de excitação apresentam os valores que as variáveis de excitação do circuito
seqüencial, que são as variáveis de entrada dos elementos de memória, devem assumir, em
função das suas variáveis de estado e das variáveis de entrada. É utilizado um mapa-K
especı́fico para cada entrada de cada flip-flop.
• Os mapas-K de transição descrevem o comportamento dos elementos de memória do
circuito seqüencial, em função das suas variáveis de estado e das variáveis de entrada. É
necessário apenas um único mapa-K para todos os tipos de flip-flops, para cada elemento
de memória.
• Portanto, as funções lógicas que geram as variáveis de excitação, que são as variáveis de
entrada dos elementos de memória, podem ser obtidas: i) do mapa-K de excitação de cada
entrada, de cada flip-flop ou ii) do mapa-K de transição de cada elemento de memória,
em conjunto com a tabela resumo 11.3.
• Como exemplo, a Tabela 11.4 descreve as mudanças de estado e os tipos de comportamento
dos elementos de memória para um contador binário, crescente, de três bits. Por sua vez,
os mapas-K de transição dos elementos de memória e os mapas-K de escitação para flipflops JK são apresentados na Figuras 11.4 e 11.5, respectivamente. Deve-se notar que este
contador não possui variáveis de entrada. Das tabelas das Figuras 11.4 e 11.5, pode-se
obter
J2 = K2 = (Q1 · Q0 ) ,
(11.6)
J1 = K1 = Q0
(11.7)
J 0 = K0 = 1 .
(11.8)
e
TET / UFF
126
Capı́tulo 11. Elementos básicos de armazenamento
Qn2
0
0
0
0
1
1
1
1
Qn1
0
0
1
1
0
0
1
1
Qn+1
2
0
0
0
1
1
1
1
0
Qn0
0
1
0
1
0
1
0
1
Qn+1
1
0
1
1
0
0
1
1
0
Qn+1
0
1
0
1
0
1
0
1
0
Q2
0
0
0
α
1
1
1
β
Q1
0
α
1
β
0
α
1
β
Q0
α
β
α
β
α
β
α
β
Tabela 11.4: Tabela de mudanças de estado e de comportamento dos elementos de memória
para um contador binário, crescente, de três bits.
FF2
Q2
0
1
Q1 Q0
00 01 11 10
0 0 α 0
1 1 β 1
FF1
Q2
FF0
Q2
Q1 Q0
00 01 11
0 0 α β
1 0 α β
00
0 α
1 α
10
1
1
Q1 Q0
01 11 10
β β α
β β α
Figura 11.4: Mapas-K de transição para os elementos de memória de um contador binário,
crescente, de três bits.
J2
Q2
K2
0
1
Q1 Q0
00 01 11 10
0 0 1 0
X X X X
K1
0
1
Q1 Q0
00 01 11 10
0 1 X X
0 1 X X
K0
0
1
Q1 Q0
00 01 11 10
1 X X 1
1 X X 1
J1
Q2
J0
Q2
Q2
Q2
Q2
00
X
0
Q1 Q0
01 11 10
X X X
0 1 0
00
0 X
1 X
Q1 Q0
01 11 10
X 1 0
X 1 0
00
0 X
1 X
Q1 Q0
01 11 10
1 1 X
1 1 X
0
1
Figura 11.5: Mapas-K de excitação para os flip-flops JK de um contador binário, crescente, de
três bits.
A.S.V.
127
11.9. Estruturas estáticas simétricas
11.9
Estruturas estáticas simétricas
• Os elementos básicos de armazenamento (flip-flops) podem ser implementados de diversas
formas diferentes.
• Duas caracterı́sticas são de grande interesse para o projeto de circuitos seqüenciais: i) que
os flip-flops possuam saı́das complementares e ii) que a temporização das mudanças dos
valores de tais saı́das possua o maior sincronismo possı́vel.
• Tais caracterı́sticas podem ser obtidas através de estruturas simétricas.
• A Figura 11.6 apresenta uma estrutura simétrica de armazenamento, implementada por
dois inversores autorealimentados.
• A autorealimentação confere uma caracterı́stica de armazenamento estático à estrutura,
pois suas saı́das Q e Q estarão estáveis (quiescentes) enquanto os inversores estiverem
energizados.
• A estrutura da Figura 11.6 apresenta uma grande desvantagem: não é controlável.
• Algumas propostas para tornar o circuito da Figura 11.6 controlável são ilustradas na
Figura 11.7.
– No primeiro caso, Figura 11.7.a, utiliza-se um inversor com capacidade de corrente
alta (inversor forte), um inversor com capacidade de corrente baixa (inversor fraco)
e uma única chave responsável pela escrita do dado binário.
– No segundo caso, Figura 11.7.b, são utilizados dois inversores idênticos, enquanto
uma chave de duas posições controla a escrita e a manutenção do dado binário.
– No terceiro caso, Figura 11.7.c, são utilizados dois inversores idênticos e a chave de
duas posições é implementada através de duas chaves com controles independentes
para escrita e armazenamento.
– No último caso, Figura 11.7.d, são utilizados dois inversores idênticos e a chave de
duas posições é implementada através de duas chaves com acionamentos complementares para escrita e armazenamento.
Q
Q
Figura 11.6: Estrutura de armazenamento estática e simétrica, não controlável.
TET / UFF
128
Capı́tulo 11. Elementos básicos de armazenamento
W/H
Ctrl
Inversor forte
Q[n+1]
Q[n]
Q[n]
Q[n+1]
Q[n]
Q[n]
Inversor fraco
(a)
(b)
W/H
Cw
Q[n+1]
Q[n]
Q[n+1]
Q[n]
Ch
Q[n]
Q[n]
(c)
(d)
Figura 11.7: Estruturas de armazenamento estáticas e simétricas, controláveis por chaves.
11.10
Exemplos de flip-flops
• Uma vez que flip-flops são circuitos seqüenciais do tipo level-mode, os mesmos devem ser
projetados adequadamente, por meio das técnicas existentes para tais tipos de sistemas.
• Porém, ainda que não se conheça a forma como foram projetados, não é difı́cil analisar o
funcionamento de um determinado flip-flop.
• A seguir são apresentadas algumas implementações de flip-flops.
• Embora não haja um consenso na classificação dos flip-flops, os mesmos serão divididos
em: unclocked (sem sinal de controle de sincronismo) e clocked (com sinal de controle de
sincronismo).
11.10.1
Flip-flops do tipo unclocked
• Os flip-flops do tipo unclocked são também denominados de latches.
• O circuito de armazenamento estático da Figura 11.6 pode ser controlado usando apenas
portas lógicas. O primeiro passo nesse sentido é substituir os inversores por portas lógicas
NOR ou NAND. Em seguida, um terminal de entrada de cada porta deve ser desconectado,
a fim de ser utilizado como terminal de controle (S e R). O processo é ilustrado nas
Figuras 11.8 e 11.9.
A.S.V.
11.10. Exemplos de flip-flops
129
Q
Q
R
S
Q
Q
S
Q
Q
Q
Q
R
Figura 11.8: Uso de portas lógicas NOR na implementação de controle em uma estrutura de
armazenamento estática e simétrica.
Q
Q
Q
Q
S
Q
R
Q
R
Q
Q
S
Figura 11.9: Uso de portas lógicas NAND na implementação de controle em uma estrutura de
armazenamento estática e simétrica.
TET / UFF
130
Capı́tulo 11. Elementos básicos de armazenamento
• Deve ser notado que, enquanto S = R = 0, os valores de Q e Q são mantidos estáveis.
• Alterando-se os valores dos sinais de controle para S = 1 e R = 0, obtém-se:
– QN OR = 0 e, em seguida, QN OR = 1.
– QN AN D = 1 e, em seguida, QN AN D = 0.
• Retornando-se à condição S = R = 0, os valores de Q e Q são mantidos estáveis.
• Alterando-se os valores dos sinais de controle para S = 0 e R = 1, obtém-se:
– QN OR = 0 e, em seguida, QN OR = 1.
– QN AN D = 1 e, em seguida, QN AN D = 0.
• Se forem atribuı́dos os valores S = R = 1, o resultado é indeterminado e não complementar. No caso da implementação com NOR, QN OR = QN OR = 0. No caso da
implementação com NAND, QN AN D = QN AN D = 1. Por essa razão, tal configuração é
dita proibida.
• A Tabela 11.5 resume a análise acima, de onde pode-se observar que ambos os circuitos
implementam um flip-flop do tipo unclocked SR.
• Quanto aos demais tipos de flip-flop:
– Acrescentando-se uma porta lógica inversora aos circuitos, de forma que R = S, eles
podem implementar um flip-flop do tipo unclocked D. Porém, tal construção não
tem utilidade prática, uma vez que o circuito final passa a se comportar como um
mero propagador do sinal de entrada, sem controle de retenção.
– Devido a problemas de instabilidade, não é possı́vel implementar flip-flops dos tipos
unclocked JK e unclocked T.
• Finalmente, cabe observar que, embora o flip-flop do tipo unclocked SR possua várias
limitações, o mesmo é usado como núcleo básico para a implementação dos flip-flops do
tipo clocked, conforme será ilustrado a seguir.
Sn
0
0
1
1
Rn
0
1
0
1
Qn+1
Qn
0
1
proibido
Tabela 11.5: Operação das estruturas de armazenamento estáticas e simétricas controladas por
meio de portas lógicas NOR e NAND.
A.S.V.
11.10. Exemplos de flip-flops
11.10.2
131
Flip-flops do tipo clocked
• Dependendo da arquitetura utilizada, podem ser destacadas três classes de flip-flops do
tipo clocked : elementar, master-slave e edge-triggered.
Flip-flops do tipo clocked elementar
• Em relação aos flip-flops do tipo clocked elementar, pode-se dizer que um SR é um latch
com controle de sincronismo, conforme exemplificado nas Figuras 11.10 e 11.11. Por sua
vez, um flip-flop D pode ser implementado a partir de um SR, conforme ilustrado na
Figura 11.12.
.
(CK S)
.
(CK S)
S
Q
S
CK
S
Q
Q
R
Q
Q
CK
R
Q
R
.
(CK R)
(CK. R)
Figura 11.10: Exemplo de implementação de flip-flop SR do tipo clocked elementar, usando
portas lógicas NOR.
.
(CK S)
.
S
(CK S)
Q
S
CK
S
Q
Q
R
Q
Q
CK
R
Q
R
.
(CK R)
.
(CK R)
Figura 11.11: Exemplo de implementação de flip-flop SR do tipo clocked elementar, usando
portas lógicas NAND.
D
S
CK
Q
Q
CK
R
Q
Q
D
D
CK
CK
Q
Q
Q
Q
Figura 11.12: Exemplo de implementação de flip-flop D do tipo clocked elementar, com base
em um flip-flop SR.
TET / UFF
132
Capı́tulo 11. Elementos básicos de armazenamento
Flip-flops dos tipos clocked master-slave e clocked edge-triggered
• O tipo elementar pode ser usado como bloco básico de construção para outras estruturas
funcionais. Os tipos master-slave e edge-triggered são soluções propostas para problemas
que podem surgir em tais implementações.
• O tipo master-slave emprega o conceito de pipelining. A idéia por trás dessa técnica é que,
a cada unidade funcional de uma cadeia de processamento, sejam adicionados elementos
de memória de entrada (master ) e de saı́da (slave), com sinais de controle de carregamento
alternados. Dessa forma, todas as unidades da cadeia trabalham em paralelo, aumentando
o fluxo de processamento (throughput). A técnica é ilustrada na Figura 11.13. No caso
do flip-flop master-slave, a unidade funcional é apenas uma transmissão, conectando os
elementos de memória de entrada e de saı́da.
• Embora uma estrutura master-slave empregue o dobro do circuito necessário ao armazenamento, ela permite um maior controle de fluxo entre a entrada e a saı́da do flip-flop.
Uma vez que os sinais de entrada só provocam modificações na saı́da após uma alternância
de sinais de controle, tais flip-flops podem ser interpretados como sensı́veis a bordas (de
subida ou de descida) ou a pulsos (positivo ou negativo).
• O tipo edge-triggered é uma solução proposta para um problema de operação apresentado
pelo tipo master-slave. Nessa estrutura, além da célula básica de armazenamento, circuitos realimentados garantem que, logo após ocorra uma transição do sinal de controle, o
flip-flop fique insensı́vel a qualquer variação dos sinais de entrada, até que ocorra uma outra transição do mesmo tipo. Assim, desprezando-se o tempo necessário à insensibilização
da estrutura, pode-se dizer que a mesma é sensı́vel a transições (positiva ou negativa).
• Um exemplo de implementação para um flip-flop D do tipo clocked, com estrutura masterslave, pode ser encontrado na Figura 11.14, onde é empregado um flip-flop SR como célula
básica.
• Não é difı́cil mostrar que um flip-flop SR pode ser usado para implementar um flip-flop
JK, desde que S = (Q · J) e R = (Q · K). Implementações utilizando flip-flops SR
unclocked e clocked são mostradas nas Figuras 11.15 e 11.16, respectivamente. Uma
vez que a realimentação das saı́das (Q e Q) para as entradas (J e K) é realizada de
forma contı́nua, ambas apresentam o mesmo problema: oscilam quando J = K = 1.
Para solucionar esse problema, exemplos de implementação para um flip-flop JK do tipo
clocked, com estrutura master-slave, são apresentados nas Figuras 11.17 – 11.19.
• Devido a problemas de temporização, o flip-flop D da Figura 11.14 pode apresentar mau
funcionamento e até mesmo oscilações. Uma implementação mais robusta é alcançada
utilizando-se o flip-flop JK master-slave, com D = J e K = J.
• Por sua vez, um flip-flop T pode ser implementado com J = K = 1 ou J = K = T .
A.S.V.
11.10. Exemplos de flip-flops
Dado
133
F1
F2
Dado
FN
(a)
Dado
Mem
F1
Mem
Mem
FN
Dado
Mem
Ctrl
(b)
Figura 11.13: Técnica de pipelining: (a) Bloco funcional original e (b) Bloco com pipelining.
Q
D
SM
QM
SS
QS
CK S
CK M
QM
RM
QS
RS
Q
CK
CK
MASTER
D
SM
SLAVE
.
( CK M S M )
S
QM
.S
S)
QS
S
Q
R
Q
Q
CK S
R
CK
( CK S
Q
CK M
RM
SS
.
( CK M R M )
Q
QM
RS
( CK S
.R )
S
Q
QS
CK
Figura 11.14: Exemplo de implementação de flip-flop D do tipo master-slave, com base em
flip-flops SR.
TET / UFF
134
Capı́tulo 11. Elementos básicos de armazenamento
Q
Q
J
(Q
.J )
Q
K
J
S
Q
Q
K
R
Q
Q
Q
(Q
Q
. K)
Q
Figura 11.15: Exemplo de implementação de flip-flop JK, a partir de flip-flop SR unclocked,
com problema de oscilação.
Q
Q
. .J )
( CK Q
J
Q
J
S
Q
Q
R
Q
Q
CK
CK
K
. . K)
Q
K
( CK Q
Q
Q
Figura 11.16: Exemplo de implementação de flip-flop JK, a partir de flip-flop SR clocked, com
problema de oscilação.
Q
J
QS
QM
D
CK
CK
Q
Q
Q
Q
CK
QS
K
Q
QM
Figura 11.17: Exemplo de implementação de flip-flop JK, a partir de flip-flop SR clocked, sem
problema de oscilação, devido ao uso de estrutura master-slave.
A.S.V.
11.10. Exemplos de flip-flops
135
Q
J
Q
SM
QM
QS
CK S
CK M
K
SS
QM
RM
QS
RS
Q
Q
CK
CK
MASTER
Q
. .S
( CK M Q
SM
J
SLAVE
S
M)
QM
SS
.
( CK S S S )
Q
QS
S
Q
R
Q
Q
CK S
CK M
R
K
RM
Q
. .R
( CK M Q
Q
M)
QM
CK
RS
.
( CK S R S )
Q
QS
CK
Figura 11.18: Exemplo 1 de implementação de flip-flop JK do tipo master-slave.
Q
J
Q
SM
CK
K
QM
SS
QS
QM
RS
QS
CK M
RM
Q
Q
Figura 11.19: Exemplo 2 de implementação de flip-flop JK do tipo master-slave.
TET / UFF
136
Capı́tulo 11. Elementos básicos de armazenamento
11.11
Variações de funcionalidade
• De acordo com o circuito implementado, um flip-flop pode apresentar algumas variações
nas suas caracterı́sticas funcionais.
• Saı́das disponı́veis: simples (Q) ou dupla e complementar (Q e Q).
• Entradas para inicialização da saı́da: CLEAR (Q = 0) e PRESET (Q = 1).
• Tipo de ativação dos sinais de entrada: nı́vel baixo (nı́vel lógico “0”) ou nı́vel alto (nı́vel
lógico “1”).
• Tipo de ativação dos sinais de controle: nı́vel (baixo ou alto), borda (descida ou subida),
transição (subida ou descida) ou pulso (negativo ou positivo).
11.12
Diferenças de nomenclatura
• Diversas nomenclaturas diferentes podem ser encontradas na literatura técnica.
• Utilizando como referência os tipos aqui definidos, as nomenclaturas mais comumente
encontradas são apresentados na Tabela 11.6.
Nomenclatura
N1
Nomes
Flip-flop
N2
Latch
Flip-flop
N3
Latch
Latch master-slave
Flip-flop
Latch
Controlled/Clocked-latch
Positive/Negative-edge flip-flop
N4
N5
Tipos aqui definidos
Todos
(os tipos unclocked e clocked elementar
são considerados flip-flops elementares)
unclocked e clocked elementar
clocked master-slave e
clocked edge-triggered
unclocked e clocked elementar
clocked master-slave
clocked edge-triggered
unclocked
clocked elementar
clocked master-slave
Tabela 11.6: Diferentes nomenclaturas para flip-flops.
A.S.V.
Capı́tulo 12
Circuitos seqüenciais clock-mode
12.1
Introdução
• A Figura 12.1 ilustra um modelo genérico para circuitos seqüenciais clock-mode.
x
L
z
M
~
Funçao
Combinacional
y
R
Y
P
~ e Armazenamento
Geraçao
´
das Variaveis
de Estado
Controle de mudança de estado
1
Figura 12.1: Modelo genérico para circuitos seqüenciais clock-mode.
• As variáveis de estado são modificadas apenas pela ação de um sinal pulsante, com função
de temporização ou de controle, comumente denominado de relógio (clock ). Apesar de
ser um sinal pulsante, não é necessário que o clock seja periódico.
• O sinal de clock não carrega qualquer tipo de informação. Ele só determina quando haverá
mudança de estado.
• As variáveis de excitação, em conjunto com os elementos de armazenamento, determinam
qual será a mudança de estado.
• Um clock atuando em tn , com xn , z n , e Y n estáveis, provoca uma mudança de estado de
y n para y n+1 .
• O circuito deve estar estável entre dois pulsos de clock. Logo, cada circuito possuirá uma
freqüência máxima de operação. Tal freqüência será limitada por: i) acionamento dos
sinais de entrada, ii) tempos de retardo no bloco “Função Combinacional” e iii) tempos
de retardo no bloco “Geração e Armazenamento das Variáveis de Estado”.
137
138
Capı́tulo 12. Circuitos seqüenciais clock-mode
12.2
Controle de circuitos do tipo clock-mode
12.2.1
Caracterı́sticas da estrutura clock-mode
• z n = f1 (y n , xn ), para circuitos do tipo Mealy.
• z n = f2 (y n ), para circuitos do tipo Moore.
• Y n = f3 (y n , xn ).
• y n+1 = f4 (Y n ).
• Tempos de propagação:
– Estabilização da entrada x: ∆tx.
– Entrada x para saı́da z: ∆tzx.
– Entrada x para excitação Y : ∆tY x.
– Excitação Y para estado y: ∆tyY .
– Estado y para saı́da z: ∆tzy .
– Estado y para excitação Y : ∆tY y .
– Tempo máximo de propagação: ∆tmax = max{∆t} = max{∆t1 , ∆t2 , · · · , ∆tk }.
• Condições de correta operação:
– Para uma leitura correta dos sinais de saı́da z, os mesmos devem estar estáveis no
momento da leitura.
– Para uma operação previsı́vel do bloco Geração e Armazenamento das Variáveis de
Estado (G&A), as variáveis de excitação Y devem estar estáveis no momento do
acionamento do bloco.
12.2.2
Controle de circuitos do tipo Moore
• Será assumindo como ∆tx ≥ max{∆tx } o intervalo de tempo entre o acionamento do
bloco G&A e a estabilização dos sinais de entrada x.
• Assumindo que as variáveis de estado y estejam estáveis, as variáveis de excitação Y
estarão estáveis após um tempo ∆tY x ≥ max{∆tY x}, a partir da estabilização dos sinais
de entrada x.
• Assumindo que todos os sinais estejam estáveis, as variáveis de estado y estarão estáveis
após um tempo ∆tyY ≥ max{∆tyY }, a partir do acionamento do bloco G&A.
• As variáveis de saı́da z estarão estáveis após um tempo ∆tzy ≥ max{∆tzy }, a partir da
estabilização dos sinais de estado y.
• Assumindo que os sinais de entrada x estejam estáveis, as variáveis de excitação Y estarão
estáveis após um tempo ∆tY y ≥ max{∆tY y }, a partir da estabilização das variáveis de
estado y.
A.S.V.
12.2. Controle de circuitos do tipo clock-mode
139
• Uma vez que, nos circuitos do tipo Moore, a saı́da depende apenas das variáveis de estado,
só é possı́vel ler um valor de saı́da diferente a cada estado. Assim, ainda que a entrada varie
durante o perı́odo de tempo de um estado, haverá interesse apenas no seu valor estável
final, antes do próximo acionamento que causará uma mudança de estado. Portanto, é
necessário considerar apenas o tempo total de estabilização dos sinais de entrada x.
• Logo, para cumprir as condições de correta operação, o perı́odo de acionamento do bloco
G&A deve ser
TCT RL = TCK ≥ max{(∆tx + ∆tY x ), (∆tyY + ∆tY y ), (∆tyY + ∆tzy )} .
(12.1)
• É recomendável que se utilize
∆tyY < (∆tx + ∆tY x ) < max{(∆tyY + ∆tY y ), (∆tyY + ∆tzy )} .
12.2.3
(12.2)
Controle de circuitos do tipo Mealy
• Será assumindo como ∆tx ≥ max{∆tx } o intervalo de tempo entre o acionamento do
bloco G&A e a estabilização dos sinais de entrada x.
• Assumindo que as variáveis de estado y estejam estáveis, as variáveis de saı́da z estarão
estáveis após um tempo ∆tzx ≥ max{∆tzx }, a partir da estabilização dos sinais de
entrada x.
• Assumindo que as variáveis de estado y estejam estáveis, as variáveis de excitação Y
estarão estáveis após um tempo ∆tY x ≥ max{∆tY x}, a partir da estabilização dos sinais
de entrada x.
• Assumindo que todos os sinais estejam estáveis, as variáveis de estado y estarão estáveis
após um tempo ∆tyY ≥ max{∆tyY }, a partir do acionamento do bloco G&A.
• Assumindo que os sinais de entrada x estejam estáveis, as variáveis de saı́da z estarão
estáveis após um tempo ∆tzy ≥ max{∆tzy }, a partir da estabilização dos sinais de estado
y.
• Assumindo que os sinais de entrada x estejam estáveis, as variáveis de excitação Y estarão
estáveis após um tempo ∆tY y ≥ max{∆tY y }, a partir da estabilização das variáveis de
estado y.
• Logo, para cumprir as condições de correta operação, supondo uma única mudança nos
sinais de entrada a cada estado, o perı́odo de acionamento do bloco G&A deve ser
TCT RL = TCK ≥ max{(∆tx +∆tzx ), (∆tx +∆tY x ), (∆tyY +∆tzy ), (∆tyY +∆tY y )} . (12.3)
• Nesse caso, é recomendável que se utilize
∆tyY < (∆tx + ∆tY x ) < max{(∆tyY + ∆tzy ), (∆tyY + ∆tY y )}
(12.4)
(∆tx + ∆tzx ) < max{(∆tyY + ∆tzy ), (∆tyY + ∆tY y )} .
(12.5)
e
TET / UFF
140
12.3
Capı́tulo 12. Circuitos seqüenciais clock-mode
Representação dos estados
• Recursos comuns: texto, equações, tabelas, diagramas gráficos, diagramas temporais.
• Equações: equações de definição dos elementos de memória, equações de próximo estado.
• Tabelas: tabela de transição (de estados), tabela de atribuição de estados e tabela (de
transição) de estados.
• Diagramas gráficos: diagrama de fluxo (fluxograma) e diagrama de estados.
12.4
Estado inicial
• Os circuitos seqüenciais, dependendo de sua classe, devem ou podem apresentar um estado
explı́cito de inicialização (reset state).
• O estado inicial pode ser um estado extra ou apenas um dos estados já pertencentes à
operação normal do circuito.
• Associada ao estado de inicialização, deve haver uma seqüência de inicialização (reset
sequence ou synchronizing sequence).
• Normalmente, a seqüência de inicialização é fornecida por um único e particular sinal de
entrada, denominado sinal ou linha de inicialização (reset line).
• O sinal de inicialização pode atuar sobre os elementos de memória através das variáveis
de excitação ou através de entradas de controle especı́ficas para inicialização (CLEAR e
PRESET ), caso existam.
12.5
Classificação quanto à capacidade de memorização
• Circuito com memória não finita
– Apresenta um estado inicial ou de inicialização (reset state).
– Apresenta um estado final ou um ciclo de estados final.
– Possui uma seqüência de inicialização (reset sequence ou synchronizing sequence).
– Caso particular:
∗ Circuito de Moore onde o número de estados distintos é igual ao número de
valores distintos de saı́da, de forma que se possa estabelecer uma correspondência
biunı́voca entre valores de estados e de saı́das (zi = yi , i = 1, 2, · · · , K).
A.S.V.
141
12.5. Classificação quanto à capacidade de memorização
• Circuito com memória finita
– A Figura 12.2 apresenta um circuito com memória finita.
– Os blocos de retardo unitário D são conjuntos de flip-flops do tipo D.
– Os vetores xn−r , r = 0, 1, · · · , R, e z n−s , s = 0, 1, · · · , S, representam os sinais de
entrada xin−r , i = 1, 2, · · · , L, e de saı́da zjn−s , j = 1, 2, · · · , M, respectivamente.
– Neste tipo de circuito: z n = f (xn , xn−1 , · · · , xn−R , z n−1 , · · · , z n−S ).
– O valor P = max {R, S} é definido como comprimento ou profundidade da memória.
– Dependendo do projeto, pode haver um estado de inicialização explı́cito, com uma
seqüência de inicialização associada.
– Um circuito com memória finita pode ser empregado como passo inicial para uma
solução com memória não finita.
– As Figuras 12.3 e 12.4 destacam, respectivamente, dois casos particulares:
∗ Circuitos com memória de entrada finita: z n = f (xn , xn−1 , · · · , xn−R ).
∗ Circuitos com memória de saı́da finita: z n = g(z n−1 , · · · , z n−S ).
x
n
x
n−1
x
D
n−2
x
...
D
n−R
D
z
z
n
n
n−R
...
D
z
n−1
n−1
= f ( x , x , ..., x , z , ... ,z
D
n−S
z
n−2
n−S
n
)
D
z
n−1
Figura 12.2: Modelo genérico para circuitos com memória finita.
x
n
x
n−1
D
x
n−2
x
...
D
n−R
D
z
z
n
n
n−1
= f ( x , x , ..., x
n−R
n
)
Figura 12.3: Modelo genérico para circuitos com memória de entrada finita.
TET / UFF
142
Capı́tulo 12. Circuitos seqüenciais clock-mode
z
z
n
D
z
n−1
= f ( z , ... ,z
...
n−S
n−S
)
D
z
n−2
n
D
z
n−1
Figura 12.4: Modelo genérico para circuitos com memória de saı́da finita.
12.6
Análise de circuitos seqüenciais
• Dado um circuito digital seqüencial, existem algumas etapas genéricas para a análise do
seu comportamento.
• A seguir, tais etapas são abordadas e alguns exemplos são apresentados.
12.6.1
Etapas de análise
• Passos principais:
A1 - Circuito a ser analisado.
A2 - Equações das variáveis de saı́da, baseadas nas ligações do circuito.
A3 - Equações das variáveis de excitação, baseadas nas ligações do circuito.
A4 - Equações de próximo estado, baseadas na operação dos elementos de memória.
A5 - Tabela de transição de estados (transition table), contendo os valores das variáveis
de estado.
A6 - Tabela de atribuição de estados, associando nomes aos valores das variáveis de
estado.
A7 - Tabela de transição de estados (state table), contendo os nomes atribuı́dos aos
estados.
A8 - Diagrama de estados.
12.6.2
Exemplos de análise
• Circuito com memória finita.
• Caso particular de circuito de Moore onde o número de estados distintos é igual ao número
de valores distintos de saı́da, de forma que se possa estabelecer uma correspondência
biunı́voca entre valores de estados e de saı́das (zi = yi , i = 1, 2, · · · , K).
• Circuito com memória não finita genérico.
A.S.V.
12.7. Projeto de circuitos seqüenciais
12.7
143
Projeto de circuitos seqüenciais
• Uma vez que a sı́ntese é o processo reverso em relação à análise, as etapas de projeto
podem ser obtidas, a princı́pio, revertendo-se a ordem das etapas de análise.
• Porém, existe uma profunda diferença entre os dois processos. Na análise, há um único
circuito, uma única entrada e um único estado inicial. Portanto, uma saı́da única é obtida
no processo. Por outro lado, no processo de sı́ntese há uma entrada e uma saı́da, únicas,
e se procura por um circuito que realize o mapeamento entrada-saı́da. A solução nesse
caso raramente é única, pois, em cada passo do processo de sı́ntese, decisões podem ser
fazer necessárias, gerando uma árvore de opções.
• A seguir, são comentadas as caracterı́sticas de projeto para cada um dos tipos de circuito
clock-mode acima definidos, bem como são especificadas as etapas de projeto para tais
circuitos e são apresentados alguns exemplos.
12.7.1
Opções de projeto e suas caracterı́sticas
• Circuito com memória finita: ausência de lógica combinacional (ligação por meio de fios)
na geração das variáveis de excitação.
• Caso particular de circuito de Moore onde o número de estados distintos é igual ao número
de valores distintos de saı́da, de forma que se possa estabelecer uma correspondência
biunı́voca entre valores de estados e de saı́das (zi = yi , i = 1, 2, · · · , K): ausência de lógica
combinacional (ligação por meio de fios) na geração das variáveis de saı́da.
• Circuito com memória não finita genérico: possı́vel existência de lógica combinacional na
geração das variáveis de excitação e de saı́da, a qual pode ser minimizada.
• A Figura 12.5 apresenta os fluxos de projeto para cada uma das três opções.
12.7.2
Etapas de projeto de circuitos seqüenciais
• Os três tipos de projeto abordados possuem etapas que são particulares para cada caso.
Porém, pode-se definir um fluxo geral de projeto, que atenda a todos os três tipos. Assim,
dependendo do tipo de projeto, pode-se utilizar apenas as etapas necessárias a cada caso.
• Etapas gerais de projeto:
P1 - Problema a ser resolvido.
P2 - Descrição funcional do problema (textual).
P3 - Descrição diagramática, baseada na descrição textual:
– Diagrama de fluxo (fluxograma).
– Diagrama de estados.
P4 - Tabela de transição de estados (state table):
– Diretamente obtida da descrição funcional (circuito com memória finita).
– Baseada na descrição diagramática (circuito com memória não finita).
TET / UFF
144
Capı́tulo 12. Circuitos seqüenciais clock-mode
P5 - Tentativa de minimização, onde raramente é feita uma minimização global que
envolva o circuito combinacional e a memória ao mesmo tempo. Ao invés disso, o
mais comum é que se realize o processo em duas etapas:
P5.1 - Memória: Tabela de transição de estados reduzida (minimal-state table),
baseada em técnicas de minimização de estados.
P5.2 - Combinacional: dependente da classe do circuito a ser projetado. No caso
de circuito com memória finita e no caso particular de circuito de Moore, a minimização combinacional é uma caracterı́stica da estrutura. No caso de circuito
com memória não finita, tal minimização é realizada no passo P6.
P6 - Tabela de atribuição de estados, baseada em regras genéricas de atribuição.
P7 - Tabela de transição de estados (transition table):
– Diretamente da especificação do problema (circuito com memória finita).
– Diretamente da especificação das variáveis de saı́da (caso particular de circuito
de Moore com memória não finita).
– Baseada na atribuição de estados (circuito com memória não finita genérico).
P8 - Escolha dos elementos de memória.
P9 - Equações de entrada dos elementos de memória (variáveis de excitação), baseadas
na tabela de transição de estados (transition table) e nas tabelas de excitação dos
elementos de memória (excitation table/map ou transition list/table/map).
P10 - Circuito proposto.
P11 - Análise do circuito para verificação de comportamento dos estados não utilizados
e não especificados, caso existam.
12.7.3
Exemplos de projeto de circuitos seqüenciais
• Circuito com memória finita de entrada.
• Circuito com memória finita de saı́da.
• Circuito com memória finita de entrada e de saı́da.
• Caso particular de circuito de Moore onde o número de estados distintos é igual ao número
de valores distintos de saı́da, de forma que se possa estabelecer uma correspondência
biunı́voca entre valores de estados e de saı́das (zi = yi , i = 1, 2, · · · , K).
• Circuito com memória não finita genérico.
• Relacionamento dos três tipos de projeto.
A.S.V.
145
12.7. Projeto de circuitos seqüenciais
Especificação Textual
|
|
(MMF)
— — — — – <— — — — — — — — — — — —> – — — —
|
|
Diagrama de Estados
|
|
|
Tabela de Estados
<—
Tabela de Transições
<— – — — —
|
|
Minimização de Estados
|
|
|
Tabela de Estados
|
Mı́nima
|
|
(Saı́da <— Estado)
|
Atribuição de Estados
—> — — — — —
|
|
|
|
Tabela de Transições
Tabela de Transições
|
Mı́nima
Mı́nima
|
|
|
|
Sı́ntese das Variáveis
|
Sı́ntese das Variáveis
de Saı́da
|
de Saı́da
|
|
|
Escolha do Elemento
Escolha do Elemento
|
Básico de Armazenamento
Básico de Armazenamento
|
|
|
|
Sı́ntese das Variáveis
Sı́ntese das Variáveis
|
de Excitação
de Excitação
|
|
|
|
Circuito
Circuito
Circuito
(a)
(b)
(c)
Fluxo genérico
Caso particular de
Máquina de Moore
MMF
(minimização global)
(saı́da = fios)
(excitação = fios)
Figura 12.5: Fluxos de projeto para circuitos seqüenciais clock-mode: (a) Fluxo genérico,
(b) Caso particular de Máquina de Moore e (c) Máquina de Memória Finita (MMF).
TET / UFF
146
Capı́tulo 12. Circuitos seqüenciais clock-mode
12.8
Minimização de estados
12.8.1
Conceitos básicos
• A minimização do número de estados de um circuito seqüencial pode conduzir à redução
da quantidade de circuitos lógicos necessários para implementar os estados (bloco Geração
e Armazenamento) e as saı́das (bloco Função Combinacional).
• Dada uma tabela de transição de estados (state table), pode-se constatar que diferentes
estados podem realizar a mesma função. Do ponto de vista externo ao circuito, podese dizer que não é possı́vel distinguir entre tais estados, uma vez que eles apresentam o
mesmo resultado. Nesse caso, tal conjunto de estados pode ser representado por um único
estado. Conseqüentemente, a tabela de transição de estados (state table) é simplificada
e, possivelmente, o circuito lógico minimizado.
• Uma formalismo teórico é apresentado no Apêndice C.
12.8.2
Eliminação de estados redundantes por simples inspeção
• A simples inspeção da tabela de transição de estados (state table) pode revelar estados
redundantes, os quais podem ser imediatamente unificados em um estado equivalente.
• Em geral, esse método não conduz a um conjunto mı́nimo de estados, funcionando apenas
como um pré-processamento para os demais métodos de minimização.
• Condição de redundância: estados (q n ) que, para cada entrada simples (xn ), conduzem
aos mesmos próximos estados e às mesmas saı́das (q n+1 , z n ), representam um único estado
equivalente.
• Algoritmo de eliminação de estados redundantes por simples inspeção:
EI1 - Verificar a existência de redundância.
EI2 - Se não houver redundância, ir ao passo EI6.
EI3 - Se houver redundância, escolher um dos estados redundantes como estado equivalente, mantendo-o na tabela e eliminando todos os demais estados redundantes.
EI4 - Atualizar a tabela, trocando a designação dos estados eliminados por aquela do
estado escolhido como equivalente.
EI5 - Voltar ao passo EI1.
EI6 - Fim.
• A Figura 12.6 apresenta um exemplo de eliminação de estados redundantes por simples
inspeção.
A.S.V.
147
12.8. Minimização de estados
qn
q n+1 , z n
x = 0 xn = 1
C, 1
D, 0
E, 1
F, 0
D, 0
F, 1
C, 1
B, 0
D, 0
F, 1
E, 1
B, 0
qn
n
A
B
C
D
E
F
−→
A
B
C
D
F
↓
qn
A
C
D
q n+1 , z n
xn = 0 xn = 1
C, 1
D, 0
D, 0
D, 1
C, 1
A, 0
q n+1 , z n
x = 0 xn = 1
C, 1
D, 0
C, 1
F, 0
D, 0
F, 1
C, 1
B, 0
C, 1
B, 0
n
↓
qn
←−
A
B
C
D
q n+1 , z n
xn = 0 xn = 1
C, 1
D, 0
C, 1
D, 0
D, 0
D, 1
C, 1
B, 0
Figura 12.6: Eliminação de estados redundantes através da inspeção da tabela de estados.
TET / UFF
148
Capı́tulo 12. Circuitos seqüenciais clock-mode
12.8.3
Método da partição em classes de estados indistinguı́veis
(método de Huffman-Mealy)
• O processo é simples, mas não pode ser aplicado para os casos de tabelas de estados não
completamente especificadas.
• Ele é baseado no Teorema 1, discutido no Apêndice C e apresentado a seguir.
• Teorema 1: Suponha-se que os estados de um circuito seqüencial foram particionados
em classes disjuntas, onde p , q denota que os estados p e q pertencem à mesma classe.
A partição é composta por classes de equivalência de estados indistinguı́veis se e somente
se as duas condições seguintes forem satisfeitas por cada par de estados p e q da mesma
classe, para cada entrada simples xn :
1. λ(pn , xn ) = λ(q n , xn ).
2. δ(pn , xn ) , δ(q n , xn ).
• Conforme definido no Apêndice C, as funções λ(q n , xn ) = z n e δ(q n , xn ) = q n+1 , representam, respectivamente, a saı́da atual e o próximo estado.
• Basicamente, o método pode ser dividido em duas partes:
– Aplicação da condição (1) do Teorema 1.
– Aplicações sucessivas da condição (2) do Teorema 1.
• Algoritmo de minimização por partição em classes de estados indistinguı́veis:
HM0 - Tentar eliminar estados redundantes por simples inspeção da tabela de estados
original. Se houver alguma eliminação, a tabela de estados reduzida passa a representar a tabela de estados original para o restante do algoritmo. Este passo não é
necessário, mas diminui o espaço de busca do algoritmo.
HM1 - A partir da tabela de estados original, separar, em classes distintas (Czi ∈ Cz ),
os estados (ej ) que possuem os mesmos conjuntos de saı́das (zik ), para cada valor da
entrada (xk ).
HM2 - Se houver apenas um estado por classe, ir para o passo HM7.
HM3 - Se houver pelo menos uma classe atual com mais de um estado, descobrir as classes referentes aos próximos estados de cada estado atual, as quais serão denominadas
de próximas classes.
HM4 - Para cada classe com mais de um estado, verificar as próximas classes, para cada
valor da entrada (x).
HM5 - Se, dentro de uma mesma classe, houver estados com próximas classes diferentes
dos demais, separá-los em uma nova classe e retornar para o passo HM2.
HM6 - Se, dentro de cada classe, não houver estado com próximas classes diferentes dos
demais, ir para o passo HM7.
HM7 - Fim.
• As Figuras 12.7, 12.8 e 12.9 ilustram o processo para diferentes tabelas de estado.
A.S.V.
149
12.8. Minimização de estados
qn
A
B
C
D
E
F
q n+1 , z n
xn = 0 xn = 1
C, 1
D, 0
E, 1
F, 0
D, 0
F, 1
C, 1
B, 0
D, 0
F, 1
E, 1
B, 0
qn
⇐⇒
q n+1 , z n
xn = 0 xn = 1
q2 , 0
q2 , 1
q1 , 1
q2 , 0
q1
q2
↓
↑
Classe(n)
Estado(n)
Classe(n+1)
1
2
C
2
E
2 2
A
B
2 1 2
D
1 2
F
1 2 1
2
Figura 12.7: Exemplo de minimização positiva em um passo.
qn
q n+1 , z n
x = 0 xn = 1
B, 0
B, 1
F, 1
D, 1
E, 1
G, 1
A, 0
C, 0
D, 1
G, 0
F, 0
A, 0
C, 1
B, 0
n
A
B
C
D
E
F
G
↓↑
Classe(n)
Estado(n)
Classe(n+1)
0
D
F
1 3
0 1
1
A
3 3 0
2
E
3
G
2 3
B
3 0 0
C
2 2
Figura 12.8: Exemplo de minimização negativa em um passo.
TET / UFF
150
Capı́tulo 12. Circuitos seqüenciais clock-mode
qn
q n+1 , z n
x = 0 xn = 1
C, 0
D, 1
B, 0
E, 1
C, 0
E, 1
E, 1
H, 0
D, 1
F, 0
I, 0
C, 1
J, 0
B, 1
I, 0
A, 1
G, 1
E, 0
H, 1
D, 0
n
A
B
C
D
E
F
G
H
I
J
qn
q0
q1
q2
q3
⇐⇒
q n+1 , z n
xn = 0 xn = 1
q0 , 0
q2 , 1
q3 , 0
q1 , 1
q2 , 1
q1 , 0
q1 , 1
q2 , 0
↓
Classe(n)
Estado(n)
Classe(n+1)
0
A
0 1
B
C
0 1 0
1
F
1 1
G
0 1 0
H
1 0
D
E
1 0 1
I
0 0
J
1 0 1
↓
Classe(n)
Estado(n)
Classe(n+1)
A
0 2
0
B
0 2 0
C
F
2 3
1
G
0 3 0
2
H
3 0
D
2 1 2
3
E
I
1 1
J
2 1 2
Figura 12.9: Exemplo de minimização positiva em mais de um passo.
A.S.V.
12.8. Minimização de estados
12.8.4
151
Método da tabela de implicação de estados (método de PaulUnger)
• Processo mais complexo do que o apresentado pelo método da partição em classes.
• Porém, ele é mais genérico, podendo ser aplicado para os casos de tabelas de estados não
completamente especificadas.
• Definição 1: Um conjunto de estados P é implicado por um conjunto de estados R
se, para alguma entrada especı́fica xk , P é o conjunto de todos os próximos estados
pn+1
= δ(rjn , xnk ), para todos os estados atuais rj ∈ R.
i
• A partir do Teorema 1 e da Definição 1, pode-se dizer que os estados de um conjunto R
são equivalentes apenas se todos os estados de um conjunto P , implicado por R, também
são equivalentes.
• Para que os estados de um conjunto R sejam equivalentes, todos os pares (ri , rj ) ∈ R
devem ser equivalentes.
• Logo, para verificar a equivalência dos estados de um conjunto, basta testar a implicação
para cada par de estados do conjunto.
• Uma forma de realizar esse teste é montar uma árvore de implicação.
• A partir de um determinado par (ri , rj ) ∈ R, são determinados os estados implicados
para cada entrada. Partindo de cada novo conjunto implicado, a operação é repetida. Se
algum conjunto implicado da árvore de (ri , rj ) não for equivalente, o par inicial (ri , rj )
não pode ser equivalente.
• Tal processo de investigação, que caracteriza uma prova por absurdo ou contradição,
possui uma complexidade muito elevada.
• Uma forma mais eficiente de verificar a equivalência de estados é através de uma prova
por negação.
• Nesse caso, os estados são organizados em uma tabela de implicação, onde todas as combinações de pares de estados encontram-se representadas. Para cada par, são determinados
os estados implicados, para cada entrada. Em seguida, todos as implicações proibidas são
eliminadas da tabela. O processo de proibição é repetido até que nenhuma proibição seja
encontrada. Por fim, são listadas as classes de equivalência.
• As proibições iniciais são provenientes de pares de estados que apresentam saı́das diferentes
para as mesmas entradas.
• Uma tabela de implicação e uma de suas células são apresentadas, respectivamente, nas
Figuras 12.10 e 12.11.
TET / UFF
152
Capı́tulo 12. Circuitos seqüenciais clock-mode
e2
e3
e4
..
.
eN
e1
e2
· · · eN −1
e3
Figura 12.10: Tabela de implicação genérica do método de Paul-Unger.
δ(p, xnk )
↓
a
q
c
δ(q, xnk )
↓
−
b
←−
..
..
.
.
−
p
d
xn1
←− xnK
Figura 12.11: Célula genérica da tabela do método de Paul-Unger.
• Algoritmo de minimização por tabela de implicação de estados:
PU0 - Tentar eliminar estados redundantes por simples inspeção da tabela de estados
original. Se houver alguma eliminação, a tabela de estados reduzida passa a representar a tabela de estados original para o restante do algoritmo. Este passo não é
necessário, mas diminui o espaço de busca do algoritmo.
PU1 - A partir da tabela de estados original, separar, em classes distintas (Czi ∈ Cz ),
os estados (ej ) que possuem os mesmos conjuntos de saı́das (zik ), para cada valor da
entrada (xk ).
PU2 - Se houver apenas um estado por classe, ir para o passo PU8.
PU3 - Montar uma matriz triangular inferior, contendo ı́ndices horizontais hi ≡ ei ∈
{Cz − eN } e ı́ndices verticais vj ≡ ej ∈ {Cz − e1 }.
PU4 - Anular todas as posições da matriz, referentes às combinações hi × vj , onde
Cz (ei ) 6= Cz (ej ).
PU5 - Preencher todas as posições da matriz, referentes às combinações hni × vjn , onde
Cz (eni ) = Cz (enj ), com os pares (hn+1
— vjn+1 )k , se hn+1
6= vjn+1 , para cada valor da
i
i
entrada (xk ).
PU6 - Repetir, até que não haja mais anulações, para cada posição não anulada hni × vjn
da matriz:
PU61 - Verificar se os pares (hn+1
— vjn+1 )k foram anulados.
i
PU62 - Se, pelo menos um dos pares tiver sido anulado, anular a posição corrente
hni × vjn da matriz e notificar a ocorrência de anulação.
PU7 - Organizar em classes de equivalência os estados cujas combinações hni × vjn não
foram anuladas e em classes individuais os demais estados.
PU8 - Fim.
A.S.V.
12.9. Atribuição de estados
12.9
Atribuição de estados
12.9.1
Considerações iniciais
153
• No projeto de um circuito digital seqüencial, a atribuição de estados tem influência direta
na sı́ntese da lógica combinacional que gera as variáveis de excitação e as variáveis de
saı́da.
• A prática demonstra que atribuições de estados diferentes podem produzir lógicas combinacionais diferentes.
• Portanto, a fim de se obter o circuito combinacional de menor custo, deve-se procurar a
atribuição de estados que favoreça a sua sı́ntese.
• Uma vez que os estados são representados por um conjunto de V variáveis booleanas, duas
situações podem ocorrer. Na primeira, o número de estados (S) que se deseja representar
é igual ao número de estados representáveis, de forma que S = 2V . Caso contrário, o
número de estados a serem representados encontra-se na seguinte faixa: 2V −1 < S < 2V .
• Quando S = 2V , o problema de atribuição de estados se resume a estabelecer uma relação
de equivalência dos estados desejados com as configurações existentes para as variáveis
de estado.
• No caso de 2V −1 < S < 2V , além da equivalência, é necessário também escolher S
configurações a serem utilizadas dentre as 2V existentes.
• Para um número de estados na faixa 2V −1 < S ≤ 2V , pode-se demonstrar que o número
V!
.
total de atribuições (Atot ) pode ser calculado por Atot = (2V2−S)!
• Porém, muitas dessas atribuições são redundantes, pois representam apenas trocas e/ou
complementações lógicas das variáveis de estado.
• Assim, pode-se demonstrar que o número de atribuições efetivamente diferentes (Adif )
(2V −1)!
pode ser calculado por Adif = (2V −S)! V ! .
• A Tabela 12.1 ilustra algumas possibilidades.
Estados Variáveis de Estado Atribuições
(S)
(V )
(Adif )
2
1
1
3
2
3
4
2
3
5
3
140
6
3
420
7
3
840
8
3
840
9
4
10.810.800
Tabela 12.1: Número de atribuições de estados efetivamente diferentes.
• Assim sendo, para S = 3 ou 4, podem ser realizados 3 projetos, a partir das 3 atribuições
possı́veis, escolhendo-se o de menor custo.
TET / UFF
154
Capı́tulo 12. Circuitos seqüenciais clock-mode
• Para S ≥ 5, pode-se visualizar duas soluções:
– Aplicar um algoritmo que encontre a atribuição de menor custo.
– Aplicar regras que indiquem um conjunto reduzido de atribuições de menor custo,
projetar cada uma delas e realizar a escolha.
• Na literatura relativa ao assunto, podem ser encontradas várias propostas de técnicas a
serem aplicadas no processo de atribuição de estados.
• Infelizmente, nenhuma delas apresenta um algoritmo de busca da melhor atribuição.
• Na realidade, são apresentadas regras genéricas, cujo emprego conduz a um conjunto
reduzido de atribuições de menor custo.
• Portanto, enfatizando, a função das regras propostas é a de reduzir o número total de
atribuições para uma quantidade mı́nima de atribuições que mereçam ser analisadas.
• De posse de um conjunto reduzido de candidatas a uma atribuição de menor custo, o
projetista pode testar as alternativas e realizar a escolha.
• Vale ressaltar, ainda, que a aplicação das regras não garante que a melhor atribuição seja
encontrada.
• Dependendo da especificação do circuito seqüencial e do tipo de elemento de memória
utilizado, as regras podem apontar para uma solução que não é a de menor custo, porém
é bem próxima.
12.9.2
Base teórica para as regras de atribuição de estados
• A atribuição de estados de menor custo é aquela que sintetiza as variáveis de excitação e
as variáveis de saı́da através da menor quantidade de circuito combinacional.
• A redução da quantidade de circuito combinacional empregada é associada à simplificação
da equação lógica que o representa.
• Por sua vez, a minimização de uma equação lógica é conseguida através da combinação
de mintermos ou maxtermos que possuam adjacência lógica.
• Por adjacência lógica entende-se a situação onde dois mintermos (ou maxtermos) diferem
pelo valor de apenas um de seus bit.
• No mapa de Karnaugh simbólico da Figura 12.12, os conjuntos de variáveis {x1 , x0 } e
{y1 , y0} representam, respectivamente, as variáveis de entrada e as variáveis de estado.
• Utilizando-se o mapa na sı́ntese das variáveis de excitação (Y ) e das variáveis de saı́da
(z), destacam-se três situações distintas.
• Supondo-se que o mapa se refere à sı́ntese de variáveis de excitação, ocorrerem dois casos
que envolvem uma dinâmica de mudança de estados. O primeiro deles é relacionado com
a possibilidade de simplificação de valores em linha (vr ). Ele trata da mudança de dois
estados atuais para dois próximos estados, para um mesmo valor de entrada. O outro
caso é relacionado com a possibilidade de simplificação de valores em coluna (vc ). Ele
trata da mudança de um estado atual para dois próximos estados, para dois valores de
entrada diferentes.
A.S.V.
155
12.9. Atribuição de estados
• Por outro lado, se o mapa se refere à sı́ntese das variáveis de saı́da, ocorre a terceira
alternativa, estática. Nesse caso, os valores atuais (“0” ou “1”) da saı́da podem promover
simplificações em linha (vr ) e/ou em colunas (vc ).
• Com base na análise de cada situação, pode-se definir um conjunto de regras básicas que
indique uma atribuição de estados adequada.
• Ainda que tais regras não conduzam à maior simplificação possı́vel, elas ajudam a escolher
uma solução próxima da ótima.
x1 x0
00
01
11
10
y1 y0
00 01 11 10
vr vr
vc
vc
Figura 12.12: Análise de minimização para as equações de excitação e de saı́da: mapa de
Karnaugh simbólico.
Análise para a sı́ntese de variáveis de excitação
• Do mapa de Karnaugh da Figura 12.12, destacam-se duas situações dinâmicas distintas.
• Uma simplificação de linha (vr ) envolve a dinâmica de dois estados atuais para dois
próximos estados, considerando uma mesma entrada.
• Por sua vez, uma simplificação de coluna (vc ) envolve a dinâmica de um estado atual para
dois próximos estados, considerando duas entradas diferentes.
• Na simplificação de linha (vr ), podem ser identificados alguns subcasos, de acordo com os
próximos estados: i) todos iguais para as mesmas entradas, ii) todos iguais para entradas
diferentes, iii) alguns iguais para as mesmas entradas, iv) alguns iguais para entradas
diferentes, e v) todos diferentes. Tais subcasos não serão analisados, sendo deixados como
proposta de exercı́cio.
• A Figura 12.13 apresenta uma tabela de atribuição de estados hipotética. Nesse caso, os
estados logicamente adjacentes são: (a, b), (a, c), (b, d) e (c, d).
• As Figuras 12.14 e 12.15 ilustram a análise de minimização para as variáveis de excitação.
• A Figura 12.14 mostra que, se dois estados atuais possuem o mesmo próximo estado e não
são logicamente adjacentes, as suas excitações para os elementos de memória (Eij ) não
poderão ser combinadas. Caso contrário, elas se combinarão com certeza, minimizando a
expressão lógica, a menos de uma das variáveis de estado, para a qual não há garantia.
• Assim, desconsiderando-se os subcasos, a recomendação é: “Dois estados que possuam o
mesmo próximo estado devem ser logicamente adjacentes!”.
TET / UFF
156
Capı́tulo 12. Circuitos seqüenciais clock-mode
• A Figura 12.15 mostra que, se um estado atual possui dois próximos estados que não
possuem adjacência lógica, nada garante que as excitações dos elementos de memória
(Eij e Ekl ) serão as mesmas e, portanto, nada garante que elas serão agrupadas para
minimizar a expressão lógica. Caso contrário, a minimização é possı́vel com certeza, a
menos de uma das variáveis de estado, para a qual não há garantia.
• Nesse caso, a recomendação é: “Dois estados que sejam próximos estados de um mesmo
estado devem ser logicamente adjacentes!”.
• Uma vez que as duas recomendações envolvem, respectivamente, um impedimento e uma
possibilidade, a primeira delas delas deve ser prioritária em relação à segunda.
Estados Variáveis de Estado
q
y1 y0
a
00
b
01
d
11
c
10
Figura 12.13: Análise de minimização para as equações de excitação e de saı́da: tabela de
atribuição de estados hipotética.
A.S.V.
157
12.9. Atribuição de estados
qn
y1n y0n
···
b
c
···
···
01
10
···
y1n+1y0n+1
xn = 0 xn = 1
···
···
00
···
00
···
···
···
q n+1
xn = 0 xn = 1
···
···
a
···
a
···
···
···
Tabela de transição de estados
xn
y1n y0n
00 01 11 10
0
E00
E10
1
Dinâmica da variável de estado y1
xn
y1n y0n
00 01 11 10
0
E10
E00
1
Dinâmica da variável de estado y0
a) Caso sem simplificação.
qn
y1n y0n
···
b
d
···
···
01
11
···
y1n+1y0n+1
xn = 0 xn = 1
···
···
00
···
00
···
···
···
q n+1
n
x = 0 xn = 1
···
···
a
···
a
···
···
···
Tabela de transição de estados
n
x
y1n y0n
00 01 11
0
E00 E10
1
10
Dinâmica da variável de estado y1
n
x
y1n y0n
00 01 11
0
E10 E10
1
10
Dinâmica da variável de estado y0
b) Caso com simplificação.
Figura 12.14: Análise de minimização para as equações de excitação: casos de estados atuais
com mesmo próximo estado.
TET / UFF
158
Capı́tulo 12. Circuitos seqüenciais clock-mode
qn
y1n y0n
···
a
···
···
···
00
···
···
y1n+1y0n+1
xn = 0 xn = 1
···
···
01
10
···
···
···
···
q n+1
xn = 0 xn = 1
···
···
b
c
···
···
···
···
Tabela de transição de estados
n
x
0
1
00
E00
E01
y1n y0n
01 11
10
n
x
Dinâmica da variável de estado y1
00
0 E01
1 E00
y1n y0n
01 11 10
Dinâmica da variável de estado y0
a) Caso sem simplificação.
qn
y1n y0n
···
a
···
···
···
00
···
···
y1n+1y0n+1
xn = 0 xn = 1
···
···
01
11
···
···
···
···
q n+1
n
x = 0 xn = 1
···
···
b
d
···
···
···
···
Tabela de transição de estados
n
x
0
1
00
E00
E01
y1n y0n
01 11
10
n
x
Dinâmica da variável de estado y1
00
0 E01
1 E01
y1n y0n
01 11 10
Dinâmica da variável de estado y0
b) Caso com simplificação.
Figura 12.15: Análise de minimização para as equações de excitação: casos de estado atual com
próximos estados diferentes.
A.S.V.
159
12.9. Atribuição de estados
Análise para a sı́ntese de variáveis de saı́da
• Do mapa de Karnaugh da Figura 12.12, destaca-se uma situação estática, não envolvendo
mudanças de estado.
• Com base na atribuição de estados apresentada na Figura 12.13, a Figura 12.16 ilustra
a análise de minimização para as variáveis de saı́da. Se dois estados atuais possuem a
mesma saı́da, para a mesma entrada, e não são logicamente adjacentes, os valores de saı́da
não poderão ser combinados. Caso contrário, os valores de saı́da serão combinados com
certeza, minimizando a expressão lógica.
• Portanto, a recomendação é: “Dois estados atuais que possuam a mesma saı́da, para a
mesma entrada, devem ser logicamente adjacentes!”.
• Normalmente, o número de variáveis de saı́da é menor que o número de variáveis de
excitação. Assim sendo, tal recomendação terá a menor prioridade.
qn
···
b
c
···
y1n y0n
···
01
10
···
zin
n
x =0
···
1
1
···
n
x =1
···
0
0
···
xn
y1n y0n
00 01 11 10
0
1
1
1
0
0
zi
Tabela de transição de estados
Mapa-K da saı́da zi
a) Caso sem simplificação.
qn
···
b
d
···
y1n y0n
···
01
11
···
n
zin
x =0
···
1
1
···
n
x =1
···
0
0
···
Tabela de transição de estados
xn
y1n y0n
00 01 11 10
0
1 1
1
0 0
zi
Mapa-K da saı́da zi
b) Caso com simplificação.
Figura 12.16: Análise de minimização para as equações de saı́da.
TET / UFF
160
12.9.3
Capı́tulo 12. Circuitos seqüenciais clock-mode
Exemplo de regras simples (Armstrong-Humphrey)
• No projeto de circuitos seqüenciais que possuam um número pequeno de estados, podem
ser utilizadas duas regras básicas no processo de atribuição de estados [Arm62], [Hum58].
• Tais regras são originadas na tentativa de minimização da lógica responsável pela geração
das variáveis de excitação.
• A principal motivação para o emprego destas regras é que elas são de curta descrição, de
fácil compreensão, de simples aplicação e conduzem a bons resultados.
• Regras:
– Regra 1: Dois ou mais estados que possuam o mesmo próximo estado devem ser
logicamente adjacentes.
– Regra 2: Dois ou mais estados que sejam próximos estados de um mesmo estado
devem ser logicamente adjacentes.
• É importante ressaltar que as regras são listadas em ordem decrescente de prioridade.
• A Figura 12.17 ilustra as regras descritas acima.
Regras de Armstrong-Humphrey
qin+1
qin
ց
ր
qkn+1
ր
qkn
ց
qjn+1
qjn
Regra 1
Regra 2
“Os estados qi e qj devem ser logicamente adjacentes.”
Figura 12.17: Ilustração das regras de Armstrong-Humphrey.
A.S.V.
12.10. Efeitos causados por estados extras
12.9.4
161
Exemplo de regras mais refinadas
• Um conjunto de regras mais completo pode ser obtido: i) ao se detalhar a Regra 1,
anteriormente apresentada, e ii) ao se incorporar a tentativa de minimização da lógica
responsável pela geração das variáveis de saı́da.
• É importante ressaltar que as regras são listadas em ordem decrescente de prioridade.
• Regras:
– Regras 1:
∗ Regra 1a: Os estados que possuam todos os próximos estados iguais, coluna
a coluna, devem ser logicamente adjacentes. Se possı́vel, os próximos estados
também devem ser logicamente adjacentes, de acordo com a Regra 2.
∗ Regra 1b: Os estados que possuam todos os próximos estados iguais, mas
em colunas diferentes, devem ser logicamente adjacentes se os próximos estados
também puderem ser logicamente adjacentes.
∗ Regra 1c: Os estados que possuam alguns do próximos estados iguais devem ser
logicamente adjacentes. A prioridade de adjacência será maior para os estados
que apresentarem um maior número de próximos estados iguais.
– Regra 2: Os próximos estados provenientes de um mesmo estado atual devem ser
logicamente adjacentes.
– Regra 3: As atribuições devem ser feitas de forma a simplificar os mapas das
variáveis de saı́da. Assim sendo, os estados que possuam as mesmas saı́das, para as
mesmas entradas, devem ser logicamente adjacentes.
12.10
Efeitos causados por estados extras
12.10.1
Definição do problema
• No projeto de circuitos seqüenciais, é comum ocorrer a situação onde o número total de
estados que pode ser implementado pelo circuito é maior do que o número total de estados
que constam na sua especificação.
• Uma vez que, teoricamente, não haverá transições dos estados principais para os estados
extras, os valores de próximo estado e de saı́da para os estados extras podem ser assumidos
como não especificados (don’t care ou com valor lógico “X”).
• Tal decisão de projeto acarreta duas conseqüências imediatas. Por um lado, evita-se empregar uma quantidade extra de circuito lógico combinacional, responsável pelo correto
funcionamento a partir dos estados extras. Além disso, os valores lógicos “X” podem acarretar simplificações no projeto do circuito lógico principal, durante a sı́ntese das variáveis
de excitação.
• Na prática, porém, algum mal funcionamento do circuito pode colocá-lo em um dos
estados extras.
• Por essa razão, deve-se realizar uma análise do circuito projetado, de modo a verificar o
comportamento de tais estados.
TET / UFF
162
Capı́tulo 12. Circuitos seqüenciais clock-mode
• As seguintes situações podem ocorrer nos circuitos cujo projeto contém estados não especificados:
– No caso particular do uso de flip-flops do tipo SR, pode acontecer alguma indeterminação no circuito seqüencial devido a indeterminações nos flip-flops (S = R = 1).
– As saı́das do circuito podem apresentar valores não esperados e/ou não especificados.
– Podem surgir estados extras isolados (dead states) ou ciclos isolados de estados extras
(dead cycles), totalmente independentes dos estados relativos à operação normal do
circuito seqüencial projetado.
– Todos os estados extras podem formar seqüências de estados que convergem para os
estados relativos à operação normal do circuito seqüencial projetado. O diagrama de
estado de tais circuitos é chamado de arbusto (bush), sendo o conjunto dos estados
normais de operação denominado de tronco (trunk ) e as seqüências de estados extras
de ramos (branches). Nesses casos, o circuito seqüencial é dito auto-corretivo (selfcorrecting).
12.10.2
Possı́veis soluções
• As soluções para o retorno do circuito aos seus estados principais, a partir de algum estado
extra, podem envolver dois tipos de ações.
• Adotando-se uma correção ativa, pode-se empregar circuitos lógicos adicionais, com a
função de auxiliar na detecção dos estados extras e na atuação sobre o circuito.
• Em um tipo de correção passiva, pode-se projetar o circuito de tal forma que seu Diagrama
de Estados final seja um arbusto.
• Ações ativas (após o projeto):
– Detecção de erro: que exige um circuito adicional para identificação de um estado
extra.
– Sinalização de erro: que pode ser implementada através de um sinal extra de saı́da
(flag de erro) ou de um valor de saı́da não especificado.
– Interrupção do sinal de clock : que necessita de um circuito extra para mascaramento
do sinal de clock original.
– Correção ativa: que executa o retorno a um dos estados principais através de um
sinal de RESET.
• Ações passivas (durante o projeto):
– Verificar os mapas-K de excitação, para evitar que ocorram indeterminações (valores
S = R = 1) em flip-flops do tipo SR.
– Verificar os mapas-K de excitação, para evitar que ocorram dead states e/ou dead
cycles.
– Verificar os mapas-K de saı́da, para garantir consistência nos valores das mesmas.
• Deve ser ressaltado que, em projetos onde a operação correta é fundamental, ambos os
tipos de ações devem ser empregados.
A.S.V.
Capı́tulo 13
Circuitos seqüenciais pulsed
13.1
Introdução
• A Figura 13.1 apresenta um modelo genérico para circuitos seqüenciais pulsed.
x
L
z
M
~
Funçao
Combinacional
y
R
P
Y
~ e Armazenamento
Geraçao
´
das Variaveis
de Estado
Controle de mudança de estado
Figura 13.1: Modelo genérico para circuitos seqüenciais pulsed.
• O modelo destaca a ausência de um sinal especial de relógio ou clock, que atue diretamente
sobre o circuito de memória, destinado puramente ao sincronismo.
• Uma mudança de estado é provocada pela ocorrência de um pulso em um dos sinais de
entrada.
• Qualquer um dos sinais de entrada pode ser do tipo pulso.
• Os sinais de entrada xi podem ser tanto do tipo nı́vel quanto do tipo pulso. Porém, é
obrigatório que pelo menos um deles seja do tipo pulso.
• No caso de circuitos seqüenciais do tipo Mealy, por definição, as saı́das poderão ser do
tipo nı́vel e/ou do tipo pulso, uma vez que poderão ser provenientes das combinações dos
nı́veis das variáveis de estado com os nı́veis e os pulsos dos sinais de entrada. Porém, o
mais comum é que as saı́das sejam todas do tipo pulso.
163
164
Capı́tulo 13. Circuitos seqüenciais pulsed
• Para os circuitos seqüenciais do tipo Moore, as saı́das deverão ser do tipo nı́vel e deverão
permanecer estáveis durante o intervalo de tempo entre dois pulsos de entrada consecutivos.
• Os elementos de memória podem ser dos tipos unclocked ou clocked.
• Em relação às combinações de sinais dos tipos nı́vel e pulso, vale destacar os seguintes
aspectos:
– Uma vez que combinações lógicas AND e OR entre pulsos positivos e negativos
produzem resultados indeterminados, apenas um tipo de pulso (positivo ou negativo)
deve ser usado.
– Após a escolha do tipo de pulso a ser utilizado (positivo ou negativo), ainda deve ser
lembrado que algumas interações entre sinais dos tipos nı́vel e pulso geram resultados
indeterminados para as operações lógicas AND e OR.
– Portanto, considerando-se que os sinais xl , xp e xp representam, respectivamente,
sinais dos tipos nı́vel, pulso positivo e pulso negativo, as seguintes combinações
podem ser empregadas:
xl · xl = xl , xl + xl = xl , xl · xp = xp , xp + xp = xp
∗
ou
xl · xl = xl , xl + xl = xl , xl + xp = xp , xp · xp = xp .
13.2
Restrições de operação
• Os circuitos seqüenciais pulsed apresentam as seguintes restrições para o seu correto funcionamento:
– Deve ser garantido que os elementos de memória operem de tal forma que ocorra
apenas uma mudança de estado para cada pulso de entrada.
– Todos os pulsos de entrada devem apresentar uma duração (largura de pulso) suficiente para o correto acionamento dos elementos de memória.
– As bordas de disparo dos pulsos de entrada consecutivos, em um mesmo sinal de
entrada ou em sinais de entrada diferentes, devem ser espaçadas de um intervalo
maior que o tempo de mudança de estado dos elementos de memória.
∗ Como conseqüência desta restrição, é vetada a ocorrência de pulsos simultâneos
em sinais de entrada diferentes.
– As entradas do tipo nı́vel devem estar estáveis quando ocorrer um pulso em qualquer
das entradas do tipo pulso.
A.S.V.
13.3. Classificação quanto aos pulsos de entrada
13.3
165
Classificação quanto aos pulsos de entrada
• Três classes de circuitos seqüenciais do tipo pulsed podem ser destacadas: controlled-clock,
pulse-mode e ripple-clock.
• Circuitos do tipo controlled-clock são casos particulares, sujeitos a mais restrições. Ainda
assim, tal abordagem permite o projeto de sistemas digitais mais complexos do que aqueles
pertencentes à classe de circuitos clock-mode.
• Circuitos do tipo pulse-mode representam uma classe mais geral dentro dos circuitos do
tipo pulsed. Eles podem ser empregados nos casos onde as restrições de sincronismo dos
circuitos clock-mode e controlled-clock não possam ser cumpridas.
• Circuitos do tipo ripple-clock resultam de um tentativa de otimização que pode levar à
redução da quantidade de hardware em detrimento da freqüência máxima de operação.
• Circuitos do tipo controlled-clock :
– Os elementos de memória são do tipo clocked.
– Existe somente uma entrada pulsada, sendo esta periódica e denominada de clock.
– O sinal de clock não é aplicado diretamente nas entradas de controle dos elementos
de memória. Ele é combinado com os outros sinais de entrada e/ou com as variáveis
de estado para gerar fontes secundárias de sinais pulsados, sincronizados com o sinal
de clock.
• Circuitos do tipo pulse-mode:
– Os elementos de memória podem ser dos tipos unclocked ou clocked.
– Normalmente, existe mais de uma entrada pulsada.
– Podem ser destacados dois casos: i) coexistência de entradas dos tipos nı́vel e pulso
e ii) existência apenas de entradas do tipo pulso.
– Geralmente, os diversos sinais de entrada pulsantes são aperiódicos e temporalmente
descorrelacionados.
• Circuitos do tipo ripple-clock :
– Existe, pelo menos, uma entrada pulsada.
– Existe, pelo menos, um elemento de memória ativado pelos pulsos de entrada. Em
seguida, as saı́das desse elemento servem de sinal de ativação para outros elementos
de memória, e assim consecutivamente, até que todos os elementos de memória
tenham sido ativados.
– As entradas pulsadas podem ser periódicas ou não.
– O intervalo de tempo entre pulsos de entrada consecutivos deve levar em conta o
tempo de propagação de disparos sucessivos dos elementos de memória. Isso pode
ser controlado através do pior caso ou através de sinais de término de disparos.
– Geralmente, o circuito apresenta estados intermediários não estáveis (transitórios).
Se necessário for, as saı́das devem ser controladas pelos pulsos de entrada, a fim de
que apresentem apenas os resultados estáveis.
TET / UFF
166
Capı́tulo 13. Circuitos seqüenciais pulsed
13.4
Circuitos pulse-mode
13.4.1
Motivação
• Existem situações onde as restrições de sincronismo para os circuitos clock-mode e controlledclock não podem ser atendidas.
• Uma situação tı́pica é a interface entre subsistemas projetados independentemente uns
dos outros.
• Outra situação tı́pica é a interconexão de subsistemas implementados com famı́lias lógicas
diferentes, onde a diferença de taxa de operação é significativa.
• Por exemplo, um sinal de saı́da do tipo nı́vel em um subsistema com taxas elevadas de
chaveamento pode ser interpretado com um pulso de entrada em um subsistema mais
lento.
• Utilizando a técnica de projeto pulse-mode, o projetista ganha liberdade para designar
quais sinais serão interpretados como sendo do tipo nı́vel ou do tipo pulso.
13.4.2
Mudanças nas representações
• O diagrama de estados, a tabela de transição de estados (state table) e o mapa-K usados
na sı́ntese de circuitos pulse-mode apresentam algumas mudanças em relação àqueles que
são empregados em circuitos clock-mode.
• Tanto a sintaxe quanto a semântica de tais representações sofrem modificações.
• Diversas sintaxes, bem como seus significados, podem ser propostas.
• A sintaxe e a semântica utlizadas no presente texto são detalhadas a seguir.
• Assim como nos circuitos clock-mode, os valores xl = 0 e xl = 1, de uma entrada do tipo
nı́vel, e os valores zl = 0 e zl = 1, de uma saı́da do tipo nı́vel, representam os nı́veis lógicos
que tais sinais podem assumir.
• No diagrama de estados, a ausência ou a presença de um pulso (positivo ou negativo) em
um sinal de entrada pulsante xp é representada, respectivamente, pela ausência ou pela
presença da variável xp (pulso positivo) ou de sua negação lógica xp (pulso negativo).
• No diagrama de estados, a ausência ou a presença de um pulso (positivo ou negativo) em
um sinal de saı́da pulsante zp é representada, respectivamente, pelo valor lógico “0” ou
pela presença da variável zp (pulso positivo) ou de sua negação lógica z p (pulso negativo).
• Na tabela de estados, os valores zp = z p = 0 e zp = z p = 1, de saı́das pulsantes zp (pulso
positivo) e z p (pulso negativo), representam, respectivamente, a ausência e a presença de
um pulso em zp e z p .
• Entradas não especificadas nas transições do diagrama de estados, bem como as saı́das
nesses casos, são representadas na tabela de estados como don’t care (“X”).
• No diagrama de estados, a especificação conjunta de duas ou mais variáveis de entrada
do tipo pulso, (xp1 ,xp2 , · · ·), indica apenas que a ocorrência de um pulso em qualquer dos
sinais xpi acarretará uma mudança de estado. Afinal, deve ser lembrado que, devido às
restrições de operação, é proibida a ocorrência de pulsos simultâneos.
A.S.V.
13.4. Circuitos pulse-mode
167
• Como conseqüência das possibilidades de combinação entre sinais do tipo nı́vel e sinais
do tipo pulso, as variáveis de saı́da e as variáveis de excitação devem ser geradas por SOP
envolvendo pulsos positivos ou por POS envolvendo pulsos negativos.
• A sintaxe e a semântica do mapa-K, usado na sı́ntese das funções combinacionais, vão
depender do tipo de elemento de memória utilizado.
• Na sı́ntese das variáveis pulsadas (excitação ou saı́da), é comum que se utilize os valores
“0” e “1” para representar, respectivamente, a ausência ou a presença de pulsos. Esse
tipo de representação é mais adequado para um tratamento por computador. Para uso
humano, pode ser de grande auxı́lio utilizar um sinal indicativo de pulso (“Π”), conforme
ilustrado na Figura 13.2.
• Vale a pena ressaltar que, por vezes, o funcionamento desejado do circuito produz um
diagrama e uma tabela de estados não completamente especificados. Nesses casos, cabe
ao projetista decidir como proceder em relação aos itens não especificados durante a
realização do projeto.
• A Figura 13.3 apresenta exemplos de tabelas de estados para circuitos pulse-mode Mealy
e Moore. A tabela da Figura 13.3.a especifica que deverá ocorrer um pulso na saı́da zp
quando o circuito estiver no estado q = B e ocorrer um pulso na entrada xp2 ou quando o
circuito estiver no estado q = C e ocorrer um pulso na entrada xp1 . Por sua vez, a tabela
da Figura 13.3.b determina que a saı́da deverá assumir o nı́vel zl = 1 enquanto o circuito
estiver no estado q = D e não ocorrer um pulso em qualquer das entradas.
y1 y2
00
01
11
10
xp1 xp2
00
01
11
0 0/1/X —
0 0/1/X —
0 0/1/X —
0 0/1/X —
10
0/1/X
0/1/X
0/1/X
0/1/X
←→
y1 y2
00
01
11
10
00
0
0
0
0
xp1 xp2
01
11
0/Π/X —
0/Π/X —
0/Π/X —
0/Π/X —
10
0/Π/X
0/Π/X
0/Π/X
0/Π/X
Figura 13.2: Equivalência de notações para mapa de Karnaugh utilizado na sı́ntese de variáveis
pulsadas.
qn
A
B
C
D
q n+1 , zp
xp1
xp2
A, 0 B, 0
– , – C, 1
A, 1 D, 0
A, 0 A, 0
a) Circuito do tipo Mealy.
qn
A
B
C
D
q n+1
xp1 xp2
B
–
D
C
A
A
C
A
zln
0
0
0
1
b) Circuito do tipo Moore.
Figura 13.3: Tabelas de estados para circuitos pulse-mode Mealy e Moore.
TET / UFF
168
13.4.3
Capı́tulo 13. Circuitos seqüenciais pulsed
Exemplos de projeto
• Exemplo utilizando flip-flop JK, master-slave, ativado por pulso nas entradas J e K,
enquanto a entrada de controle de sincronismo C é mantida em nı́vel lógico “1”.
y1 y2
00
01
11
10
xp1 xp2
00 01 11
0 0/Π —
0 0/Π —
0 0/Π —
0 0/Π —
10
0/Π
0/Π
0/Π
0/Π
y1 y2
(a)
00
01
11
10
xp1
0/Π
0/Π
0/Π
0/Π
xp2
0/Π
0/Π
0/Π
0/Π
(b)
Figura 13.4: Mapas de Karnaugh para sı́ntese de variáveis pulsadas, considerando-se duas
entradas pulsadas: (a) Mapa completo e (b) Mapa simplificado.
y1 y2
00
01
11
10
000
0
0
0
0
001
0/Π
0/Π
0/Π
0/Π
011
—
—
—
—
xp1 xp2 xp3
010 100 101 111 110
0/Π 0/Π — — —
0/Π 0/Π — — —
0/Π 0/Π — — —
0/Π 0/Π — — —
(a)
y1 y2
00
01
11
10
xp1
0/Π
0/Π
0/Π
0/Π
xp2
0/Π
0/Π
0/Π
0/Π
xp3
0/Π
0/Π
0/Π
0/Π
(b)
Figura 13.5: Mapas de Karnaugh para sı́ntese de variáveis pulsadas, considerando-se três entradas pulsadas: (a) Mapa completo e (b) Mapa simplificado.
A.S.V.
13.5. Circuitos ripple-clock
13.5
Circuitos ripple-clock
13.5.1
Motivação
169
• A classe de circuitos ripple-clock surge como uma tentativa de otimização no acionamento
dos elementos de memória do circuito seqüencial.
• A mudança na forma de acionamento dos elementos de memória pode levar a uma simplificação da lógica combinacional do circuito seqüencial.
• Tal simplificação acarreta uma redução da quantidade de hardware do circuito combinacional.
13.5.2
Operação
• Nos circuitos do tipo clock-mode, os elementos de memória são acionados simultaneamente
pelo sinal de sincronismo (clock ).
• De forma semelhante, nos circuitos do tipo pulse-mode, os elementos de memória são potencialmente acionados em paralelo. A diferença, neste caso, é que, dependendo dos sinais
de entrada, alguns elementos de memória podem não ser acionados em uma determinada
mudança de estado. Ainda assim, a forma de acionamento é estruturalmente paralela.
• Nos circuitos ripple-clock, o acionamento é realizado por uma seqüência de eventos. Um
sinal de entrada provoca o acionamento de um ou mais elementos de memória. Por sua
vez, as modificações nas saı́das destes elementos acionam outros elementos de memória.
Este mecanismo se repete até que um último conjunto de elementos de memória seja
ativado, completando a mudança de estado do circuito seqüencial.
13.5.3
Desvantagens
• As desvantagens deste tipo de acionamento são: i) o aumento do tempo de estabilização
nas mudancas de estado, o que é equivalente à redução da freqüência máxima de operação
do circuito seqüencial e ii) o surgimento de estados e de conjunto de saı́das intermediários
(instáveis) durante uma mudança de estados estáveis.
• No cálculo do perı́odo mı́nimo para o sinal de acionamento inicial, deve-se levar em conta
o pior caso, que é quando ocorrem todos os nı́veis de acionamento intermediários.
13.5.4
Técnica de projeto
• Na sı́ntese da lógica combinacional para os circuitos clock-mode (ou pulse-mode), torna-se
necessário que os valores das variáveis de excitação que preenchem os mapas-K sejam
rigidamente controlados, pois os elementos de memória serão constantemente (ou potencialmente) acionados, independentemente do estado em que se encontre o circuito.
• No caso dos circuitos ripple-clock, os elementos de memória poderão ser acionados apenas
quando necessário. Portanto, para os estados onde não ocorrerá acionamento, os valores
da variáveis de excitação podem ser considerados don’t care (“X”), o que pode conduzir a
simplificações na lógica combinacional.
• O desafio, portanto, é obter um arranjo de acionamentos que reduza ao máximo a lógica
combinacional necessária.
TET / UFF
170
Capı́tulo 13. Circuitos seqüenciais pulsed
13.5.5
Exemplo
• O exemplo mais clássico é a obtenção do circuito ripple-clock para um contador binário, a
partir de um projeto de circuito clock-mode que utiliza um flip-flop JK sensı́vel a transição.
13.6
Circuitos controlled-clock
• Os elementos de memória são do tipo clocked.
• Assim como nos circuitos seqüenciais clock-mode, existe somente uma entrada pulsada,
sendo esta periódica e denominada de clock.
• Porém, o sinal de clock não é aplicado diretamente nas entradas de controle dos elementos
de memória.
• Como o próprio nome indica, o sinal de clock principal (master clock ) é combinado com
sinais de controle do tipo nı́vel (sinais de entrada e/ou variáveis de estado) para gerar
fontes secundárias de sinais pulsados, sincronizados com o sinal de clock.
• Tais sinais pulsados secundários são aplicados nas entradas de controle dos elementos de
memória ou ainda enviados para circuitos do tipo pulse-mode.
• As Figuras 13.6 e 13.7 apresentam exemplos de controle de sinal de clock.
Sinais de controle
´
(tipo nivel)
D
Q
D
Ctrl
Q
Ctrl
Pulsos de controle
Clock principal
Figura 13.6: Exemplo 1 de controle de sinal de clock.
´
Sinais de controle: tipo nivel
Pulsos 1
Sinal de controle 1
D
Q
D
Ctrl
Q
Ctrl
Clock principal
Pulsos de controle
Sinal de controle 2
Pulsos 2
Figura 13.7: Exemplo 2 de controle de sinal de clock.
A.S.V.
13.6. Circuitos controlled-clock
171
• Em uma grande variedade de aplicações de sistemas digitais, o conteúdo dos elementos
de memória ou não é modificado ou é condicionalmente carregado com o resultado da
aplicação de alguma função sobre um conjunto de dados.
• Portanto, para tais sistemas, o flip-flop do tipo D é o mais utilizado, pois realiza a função
de armazenamento com um custo menor do que o flip-flop do tipo JK.
• Sinais de controle de CLEAR e PRESET, independentes do sinal de ativação do flip-flop,
são comumente utilizados.
• Porém, a fim de evitar mudanças impróprias, provocadas pela aplicação de tais sinais ao
mesmo tempo em que o flip-flop é ativado, tais entradas de controle são normalmente
utilizadas apenas para a inicialização (reset) do circuito.
• Uma arquitetura do tipo controlled-clock comumente encontrada na prática é a denominada Lógica de Transferência entre Registradores (Register-Transfer Logic ou RTL).
• Nos circuitos que possuem tal arquitetura, os dados são condicionalmente armazenados
em registradores.
• De acordo com o processamento a ser realizado, os dados são transferidos entre registradores especı́ficos.
• Eventualmente, podem ser inseridos circuitos combinacionais no caminho de ligação entre
dois registradores, os quais serão responsáveis pela implementação de funções lógicas e/ou
aritméticas, necessárias ao processamento dos dados armazenados.
• As transferências são controladas por meio de sinais pulsantes secundários, sincronizados
com o sinal de clock principal.
• Normalmente, todos os sinais de um sistema são organizados em conjuntos de ligações,
denominados de barras ou barramentos: barra de dados (data bus), barra de controle
(control bus) e barra de alimentação (power bus).
• A transferência entre dois registradores é realizada por meio de uma barra de dados (data
bus).
• A Figura 13.8, apresentada em [HP81], ilustra um modelo genérico para circuitos seqüenciais controlled-clock.
• O modelo separa o sistema em duas partes: um bloco de processamento de dados e um
bloco de controle.
• O bloco de processamento de dados incorpora os registradores que armazenam os dados a serem processados e a lógica combinacional necessária à realização das funções de
processamento.
• O bloco de controle representa os circuitos seqüenciais responsáveis por gerar os sinais de
controle (nı́veis e pulsos) que realizam as transferências apropriadas, sincronizadas com o
sinal de clock principal.
• Normalmente, o número de linhas de entradas de controle e o número de linhas de sinais
de controle são pequenos em comparação tanto ao número de linhas de dados de entrada
e de saı́da quanto ao número de linhas de interconexão de dados, internas ao bloco de
processamento de dados.
TET / UFF
172
Capı́tulo 13. Circuitos seqüenciais pulsed
Dados
de
Entrada
.
.
.
Registradores de Dados
e
Logica
´
Combinacional
Clock
~
Informaçao
...
.
.
.
Dados
de
´
Saida
Sinais de
Controle
...
de desvio
Entradas
de
Controle
Circuitos Sequenciais
¨
.
.
.
de Controle
.
.
.
´
Saidas
de
Controle
Figura 13.8: Modelo genérico para circuitos seqüenciais controlled-clock.
A.S.V.
Capı́tulo 14
Circuitos seqüenciais level-mode
14.1
Introdução
• A Figura 14.1 apresenta um modelo genérico para circuitos seqüenciais level-mode.
x
z
M
L
~
Funçao
Combinacional
y
P
P
Y
t1
tP
Figura 14.1: Modelo genérico para circuitos seqüenciais level-mode.
• O modelo destaca a ausência de elementos de memória permanente.
• Ao invés disso, tal estrutura se utiliza de elementos de memória temporária, implementados através de atrasos.
• Por sua vez, os atrasos que implementam o bloco de memória não são blocos de retardo
isolados. Eles representam a concentração de atrasos de propagação existentes no circuito combinacional. Conseqüentemente, os valores de tais atrasos podem variar ao longo
do tempo, uma vez que eles serão dependentes dos diversos fluxos que os sinais podem
percorrer através do circuito combinacional.
• Assim como nos demais classes: ykn+1 = fk (Y1n , · · · , YPn ), k = 1, 2, · · · , R.
• Mais especificamente, neste caso: P = R e yk (t + ∆tk ) = Yk (t), k = 1, 2, · · · , P .
• Todos os sinais presentes no circuito são do tipo nı́vel.
• Uma mudança de estado é provocada por uma mudança de nı́vel nos sinais de entrada.
173
174
Capı́tulo 14. Circuitos seqüenciais level-mode
• Em resumo, a Figura 14.1 indica que um circuito seqüencial level-mode genérico é simplesmente um circuito combinacional realimentado, com entradas do tipo nı́vel.
• Porém, deve ser lembrado que, por definição, todo circuito seqüencial deve ser realimentado, mas a simples realimentação de um circuito combinacional não garante que ele passe
a se comportar como um circuito seqüencial.
• Em circuitos seqüenciais pulsados (pulsed e clock-mode), é natural que as saı́das dos
elementos de armazenamento sejam escolhidas como variáveis de estado, uma vez que
eles são também os elementos de sincronismo do sistema.
• Nos circuitos level-mode a realimentação é continuamente aplicada. Assim, qualquer
ponto dela pode ser identificado como uma variável de estado sem causar prejuı́zo à
análise ou ao projeto do circuito.
• Diz-se que um circuito opera em modo fundamental se, e somente se, não forem permitidas
mudanças nos valores de suas variáveis de entrada até que o circuito atinja um estado
estável.
• Deve-se observar que o modo fundamental é uma restrição quanto à forma como o circuito
é operado e não quanto ao tipo de projeto executado.
• O modo fundamental pode ser implementado permitindo-se que apenas uma das variáveis
de entrada seja modificada por vez e garantindo-se que modificações sucessivas em tais
variáveis só ocorram após a estabilização do circuito.
14.2
Problemas comuns em circuitos level-mode
• Nos circuitos seqüenciais controlados por pulsos (pulsed e clock-mode) a realimentação é
interrompida pelo bloco de memória e é ativada segundo um certo sincronismo.
• Por outro lado, nos circuitos seqüenciais level-mode a realimentação encontra-se ativa
durante todo o tempo.
• Conseqüentemente, podem ocorrer instabilidades e incertezas.
• Alguns problemas mais comuns são:
– As condições de entrada ou de saı́da de um circuito podem ser indeterminadas.
– A condição da saı́da de um circuito pode ser instável, a qual pode apresentar mudanças ainda que as entradas não sejam modificadas.
– A condição da saı́da de um circuito, mesmo que estável, pode não ser preditı́vel a
partir das condições da entrada.
• As soluções mais empregadas para tais problemas são:
– Evitar instabilidades crônicas (oscilações): se o circuito exibe oscilações para alguns valores de entrada e é estável para outros, então as condições que imprimem
oscilações devem ser evitadas.
– Evitar incertezas: se o circuito exibe comportamento indeterminado para alguns
valores de entrada e determinismo para outros, então as condições que provocam
indeterminismo devem ser evitadas.
A.S.V.
14.3. Exemplo de análise de circuito level-mode
175
– Operar em modo fundamental.
– Operar em modo pulsado (pulsed e clock-mode).
• Alguns pontos devem ser ressaltados:
– Circuitos que exibem oscilação sob certas condições não podem ser utilizados em aplicações de armazenamento ou processamento de dados. Porém, tal comportamento é
essencial quando a intenção é gerar sinais de sequenciamento ou temporização.
– Nem sempre é possı́vel garantir a operação em modo fundamental, uma vez que sinais
provenientes de diversas fontes diferentes podem variar aleatoriamente. Nesses casos,
uma solução é empregar circuitos sincronizadores extras para garantir a operação em
modo fundamental.
14.3
Exemplo de análise de circuito level-mode
• Análise de dois circuitos seqüenciais que implementam um flip-flop SR.
• Tabela de transição (de estados).
• Tabela de fluxo de estados (flow table).
• Tabela de fluxo de estados primitiva (primitive flow table).
14.4
Exemplo de projeto de circuito level-mode
• Diversas opções de projeto para circuitos seqüenciais que implementem um flip-flop SR.
• Definição de uma especificação para um flip-flop SR.
• Exemplo de diagrama de tempo.
• Tabela de fluxo de estados primitiva (primitive flow table).
• Tabela de fluxo de estados (flow table) minimizada ou reduzida.
• Tabela de atribuição de estados.
• Tabela de transição (de estados).
• Sı́ntese das variáveis de excitação e de saı́da.
• Circuito final.
TET / UFF
176
Capı́tulo 14. Circuitos seqüenciais level-mode
14.5
Problemas causados pela realimentação contı́nua
14.5.1
Problemas causados pelo bloco de lógica combinacional
• Existem dois efeitos comuns em circuitos combinacionais: corrida (race) e perigo (hazard ).
• No primeiro caso, após uma mudança nos sinais binários de entrada, espera-se alterar mais
de um dos sinais binários de saı́da. Devido a atrasos internos, os sinais de saı́da, partindo
de um valor inicial (estável), podem assumir configurações intermediárias (instáveis) antes
de atingir o seu valor final (estável).
• No segundo caso, após uma mudança nos sinais binários de entrada, duas situações podem
ocorrer. Na primeira delas, espera-se que o valor de um determinado sinal binário de saı́da
não seja modificado. Porém, devido a atrasos internos, ainda que o valores inicial e final
sejam o mesmo, surgem variações intermediárias. Isso é denominado perigo estático (static
hazard ). Na segunda situação, espera-se que o valor de um determinado sinal binário de
saı́da seja coplementado. Porém, devido a atrasos internos, ainda que o valor final seja o
complemento do valor inicial, surgem variações intermediárias. Isso é denominado perigo
dinâmico (dynamic hazard ).
• Para os circuitos combinacionais, embora a ocorrência de valores intermediários não previstos seja inoportuna, uma solução simples é aguardar a estabilização do resultado final.
• Em circuitos seqüenciais pulsados (pulsed e clock-mode), a ocorrência de configurações
intermediárias nas variáveis de excitação também não representa sério problema, uma vez
que a realimentação é interrompida pelo bloco que gera e armazena as variáveis de estado.
Novamente, uma solução simples é aguardar a estabilização do resultado final.
• Porém, nos circuitos seqüenciais level-mode, a realimentação acontece de forma contı́nua.
• Nesse caso, os valores intermediários não previstos, causados por corridas e/ou perigos
no bloco combinacional, geram estados intermediários não previstos, os quais podem
provocar mudanças de estado não desejadas, comprometendo o funcionamento do circuito
seqüencial.
14.5.2
Problema natural dos circuitos level-mode
• Devido à realimentação contı́nua, os circuitos level-mode apresentam um problema envolvendo duas ou mais variáveis de excitação/estado.
• Supondo operação em modo fundamental, após uma variação nos sinais de entrada, uma
variável de excitação Y1 pode sofrer modificação, ser realimentada e atuar sobre uma outra
variável de excitação Y2 , antes que a variação da entrada exerça influência sobre Y2 .
• Nesse caso, Y2 pode assumir um valor não esperado, comprometendo o funcionamento do
circuito seqüencial.
• Esse comportamento é denominado de perigo essencial (essential hazard ).
• Uma vez que o problema é associado ao tipo de estrutura e à sua especificação, ele pode
ser detectado diretamente na tabela de fluxo.
A.S.V.
177
14.6. Solução para as corridas: atribuição de estados
• Supondo um sinal de entrada binário, que sofra três variações consecutivas. Caso a
primeira e a terceira variações conduzam o circuito aos estados q1 e q3 , tal que q1 6= q3 ,
então existe perigo essencial na tabela de fluxo do circuito [Ung59].
• O comportamento em questão irá ocorrrer se quaisquer duas colunas adjacentes da tabela
de fluxo exibirem um dos dois padrões apresentados na Figura 14.2.
(1) 2
3 (2)
(3) (3)
(1) 2
4 (2)
(3)
(4) 3
(a)
(b)
Figura 14.2: Padrões de identificação de perigo essencial em tabelas de fluxo.
14.6
Solução para as corridas: atribuição de estados
14.6.1
Definição do problema
Objetivo da atribuição de estados
• Em circuitos seqüenciais pulsados (pulsed e clock-mode) a escolha da atribuição de estados
visa a minimização do bloco de lógica combinacional.
• Em circuitos seqüenciais level-mode, operando em modo fundamental, o problema de
estados intermediários, causados por corridas no bloco combinacional, pode ser resolvido
através de uma atribuição de estados adequada.
• Dependendo da tabela de fluxo em questão, para que se encontre uma atribuição de
estados adequada, pode ser necessário aumentar o número de estados do circuito.
Tipos de mudança de estado
• Duas situações podem ocorrer durante uma mudança de estado: i) alteração imediata de
estado ou ii) surgimento de estados intermediários (instáveis) não previstos.
• No primeiro caso, as variáveis de estado modificam-se de tal forma que o circuito passa
diretamente do estado inicial ao final, sem estados intermediários. Na prática, isso ocorre
porque apenas uma das variáveis de estado necessita trocar de valor.
• No segundo caso, duas situações podem ocorrer: ciclo (cycle) ou corrida (race).
• Um ciclo é definido por uma seqüência única de estados intermediários, instáveis, entre
dois estados estáveis (o inicial e o final).
• Os únicos problemas causados pelo ciclo são o prolongamento e a não uniformidade do
tempo de estabilização da mudança de estado.
TET / UFF
178
Capı́tulo 14. Circuitos seqüenciais level-mode
• A corrida caracteriza-se pela existência de diferentes ciclos para um mesmo estado inicial
estável. Nesse caso, não é possı́vel prever por qual ciclo o circuito irá fluir.
• Dois tipos de corrida podem ser definidos: não crı́tica (non-critical ) e crı́tica (critical ).
• Nas corridas não crı́ticas, o estado final estável é sempre o mesmo, independentemente
da seqüência de troca das variáveis de estado e, portanto, dos ciclos percorridos. Nesses
casos, os problemas são os mesmos dos ciclos.
• Nas corridas crı́ticas, os diferentes ciclos podem levar a diferentes estados finais estáveis.
Portanto, corridas crı́ticas representam comportamento não desejado.
• A Figura 14.3 apresenta um quadro resumo das mudanças de estado nos circuitos seqüenciais level-mode, operando em modo fundamental.
¨
level−mode
Circuito sequencial
(operando em modo fundamental)
Mudança imediata
de estado
Estados
´
Intermediarios
Ciclo
Corrida
~ critica
´
Nao
´
Critica
Figura 14.3: Quadro resumo das mudanças de estado nos circuitos seqüenciais level-mode,
operando em modo fundamental.
A.S.V.
14.6. Solução para as corridas: atribuição de estados
14.6.2
179
Possı́veis soluções
Origem do problema
• Em função do que foi exposto, pode-se concluir que: i) uma alteração imediata de estado
pode ser interpretada como um caso particular de ciclo e ii) as situações de corrida (ciclos
múltiplos) podem acarretar resultados indesejáveis (corrida crı́tica).
• Portanto, uma solução para o problema de funcionamento indesejado é adotar uma atribuição de estados que realize mudanças de estado apenas por ciclos.
• Para que uma mudança de estado seja executada em ciclo, cada par de estados, do inicial
ao final, deve possuir adjacência lógica.
• Dessa forma, para cada mudança de estado, apenas uma variável deverá trocar de valor,
evitando a ocorrência de corrida entre as variáveis.
Identificação do problema
• A análise dos tipos de mudanças de estado (ciclos e/ou corridas) que ocorrem em uma
dada tabela de fluxo de estados pode ser feita através de um hipercubo booleano.
• Inicialmente, um hipercubo é montado, contendo um número de nós suficiente para conter
a quantidade de estados estáveis da tabela de fluxo.
• Em seguida, percorrendo a tabela de fluxo, os estados são associados aos nós do hipercubo.
• A presença de ciclos e/ou corridas é verificada pelas transições presentes no hipercubo.
• Transições realizadas pelas arestas do hipercubo representam ciclos.
• Transições que ocorrem por diagonais significam corridas.
• A classificação das corridas deve ser realizada com o auxı́lio da tabela de fluxo.
• Supondo-se uma tabela de fluxo organizada de forma que as combinações de entrada
definam as colunas, uma transição para uma coluna que contenha apenas um estado
estável é associada a uma corrida não crı́tica. Por outro lado, se a coluna possuir dois ou
mais estados estáveis diferentes, a transição representa uma corrida crı́tica.
Estados reservas (spare states)
• A atribuição de estados deve ser feita de tal forma que sejam respeitadas todas as adjacências lógicas em todas as mudanças de estado.
• Dada uma determinada tabela e um determinado número de estados, pode-se não conseguir uma atribuição de estados adequada.
• Neste caso, devem-se empregar estados reservas (spare states).
• Para números de estados que não sejam potências de dois, podem-se usar os estados extras
como estados reservas.
• Porém, quando o número de estados é uma potência de dois ou não se consegue uma
atribuição adequada com os estados extras já existentes, deve-se gerar estados reservas
acrescentando-se novas variáveis de estado.
TET / UFF
180
Capı́tulo 14. Circuitos seqüenciais level-mode
Técnicas de atribuição
• Existem duas técnicas básicas para usar os estados reservas: atribuição por múltiplas
linhas (multiple-row assignment) e atribuição por linhas compartilhadas (shared-row assignment).
• Na técnica de atribuição por múltiplas linhas, aproveitando-se o fato de que o número de
estados é dobrado para cada nova variável de estado acrescentada, cada estado original
passa a ser representado por duas ou mais linhas na tabela de transição. Esta multiplicidade de representação para cada estado permite que se implemente adjacência lógica
para cada par de estados. Conseqüentemente, em qualquer tabela de fluxo, com qualquer
número de estados originais, todas as corridas podem ser transformadas em ciclos.
• A técnica de múltiplas linhas necessita que o número de linhas da tabela de transição seja
igual a, pelo menos, o dobro do número de estados. Assim, caso o número de estados
não seja uma potência de dois, é recomendável que se tente aplicar a técnica de linhas
compartilhadas.
• Na técnica de linhas compartilhadas, as combinações reservas de variáveis de estado
(linhas da tabela de transição) não são atribuı́das a estados individuais. Como o próprio nome já diz, cada linha é compartilhada por diferentes configurações de entrada
(colunas da tabela de transição), a fim de transformar corridas em ciclos.
Atribuições tabeladas
• Dois tipos de atribuições de estado podem ser empregadas: universal e padrão [Sau67].
• Atribuições universais são apresentadas em [Sau67], as quais se utilizam de 2 variáveis
para 3 estados, 3 variáveis para 4 estados, 4 variáveis para até 8 estados e 5 variáveis para
até 12 estados.
• Tais atribuições, ilustradas nas Tabelas 14.1 – 14.4, realizam quaisquer tabelas de fluxo,
com os referidos números de estados, sem corridas crı́ticas.
• Dado um determinado número de estados, as atribuições padrões procuram utilizar um
número menor de variáveis de estado para representá-los. Porém, elas não são capazes de
realizar todas as tabelas com tal número de estados.
• Um exemplo de atribuição padrão para tabelas com 5 estados é apresentado na Tabela 14.5.
y0
0
1
y1
0 1
+ +
+
Tabela 14.1: Atribuição de estados universal, usando shared-row, para tabelas de 3 estados.
A.S.V.
14.6. Solução para as corridas: atribuição de estados
y0
0
1
181
y2 y1
00 01 11 10
0 2 1 3
1 3 0 2
Tabela 14.2: Atribuição de estados universal, usando multiple-row, para tabelas de 4 estados.
y1 y0
00
01
11
10
y3 y2
00 01 11 10
+ +
+ +
+ +
+ +
Tabela 14.3: Atribuição de estados universal, usando shared-row, para tabelas de 5 a 8 estados.
y1 y0
y4 y3 y2
000 001 011 010 110 111 101 100
00 +
+
+
+
01
+
+
11 +
+
10
+
+
+
+
Tabela 14.4: Atribuição de estados universal, usando shared-row, para tabelas de 9 a 12 estados.
y0
0
1
y2 y1
00 01 11 10
+
+
+ + +
Tabela 14.5: Atribuição de estados padrão, usando shared-row, para tabelas de 5 estados.
TET / UFF
182
Capı́tulo 14. Circuitos seqüenciais level-mode
Conjunto de destinação (destination set)
• Conjunto de destinação (destination set) é um conceito que se pode utilizar na tentativa
de atender a uma determinada tabela de fluxo com uma atribuição que utilize apenas
estados reservas já existentes, sem acrescentar uma variável de estado extra.
• Dada uma tabela de fluxo, formam-se conjuntos de destinação para cada configuração das
variáveis de entrada (coluna da tabela).
• Para cada coluna, tais conjuntos são formados por um estado estável da coluna com um
estado (linha da tabela) que faça transição para o estado estável.
• A fim de que não haja corridas crı́ticas, os membros de cada conjunto de destinação
devem ser logicamente adjacentes ou devem ser alocados, em relação aos estados reservas,
de forma que as transições cı́clicas formadas para todos os conjuntos sejam atendidas sem
interferência mútua (cruzamento de ciclos).
Comparações
• Uma comparação entre as duas técnicas pode ser feita com base na complexidade e no
tempo de operação do circuito final.
• A técnica de linhas compartilhadas requer um número menor de variáveis de estado.
Portanto, o seu uso gera circuitos mais simples.
• A técnica de múltiplas linhas gera transições imediatas. Portanto, o seu emprego produz
circuitos com menor tempo de operação.
• Outras técnicas, que reduzem o tempo de operação do circuito, embora demandem maior
tempo de projeto e aumento da complexidade do circuito, podem ser encontradas em
[Ung69].
14.7
Solução para os perigos
• Dado o perigo estático para o valor binário “1”, ele ocorre porque o circuito desativa o
mintermo inicial antes de ativar o mintermo final. Dessa forma, acontece a transição
1|min inicial → 0 → 1|min f inal .
• Portanto, para solucionar o problema, basta acrescentar um mintermo redundante, que
permanecerá ativo durante a troca dos mintermos inicial e final. Assim, será realizada a
transição 1|min inicial → 1|min redundante → 1|min f inal .
• Adicionalmente, é apresentado em [McC65] o seguinte teorema:
“Um circuito combinacional implementado na forma padrão SOP de segunda ordem que
for livre de todos os perigos estáticos para o valor binário “1”, será livre de todos os perigos
estáticos e dinâmicos.”.
• Finalmente, uma forma comum de evitar o perigo essencial é acrescentar atrasos de propagação (inversores em número par) ao circuito.
A.S.V.
14.8. Valores das saı́das em estados instáveis
14.8
183
Valores das saı́das em estados instáveis
• Em mudanças de estados que se fazem por meio de ciclos, deve-se tomar cuidado com os
valores atribuı́dos para as saı́das durante os estados instáveis, a fim de se evitar a geração
de pulsos espúrios.
• Se, tanto no estado inicial quanto no estado final, o valor especificado para a saı́da for o
mesmo, ele deverá permanecer constante durante o ciclo.
• Se, do estado inicial para o estado final, os valores especificados para a saı́da forem
diferentes, deverá ocorrer apenas uma mudança durante o ciclo. Conseqüentemente, o
valor da saı́da só poderá ser especificado como don´t care (‘X’ ou ‘—’) para um dos
estados do ciclo.
TET / UFF
184
Capı́tulo 14. Circuitos seqüenciais level-mode
A.S.V.
Parte IV
Apêndices
185
Apêndice A
Noções básicas sobre implementação de
funções lógicas
A.1
Introdução
A implementação de funções lógicas é um assunto que possui grande extensão e é rico em
detalhes. Ainda que tal conteúdo não seja o objetivo do presente documento, é importante
que algumas noções básicas sejam abordadas. Este capı́tulo tem por objetivo apresentar, de
forma breve e superficial, alguns itens comumente encontrados em implementações tı́picas.
Inicialmente, as famı́lias lógicas são comentadas. Em seguida, são listados os elementos básicos
usados na implementação de circuitos lógicos em circuitos integrados. Finalmente, é discutido
um modelo de chaves para a implementação de funções da lógica binária, com processamento
de tensão.
A.2
Famı́lias lógicas
Na implementação dos circuitos digitais básicos, que, aqui, são os conectivos ou funções da lógica
clássica ou binária, podem ser utilizados diferentes dispositivos fı́sicos, associados a diversas
técnicas de composição e a diversos modos de operação.
Se determinados dispositivos fı́sicos são conectados de uma forma especı́fica, são operados
de um modo particular e apresentam parâmetros lógicos e fı́sicos que obedecem a padrões
estabelecidos, então diz-se que o circuito final pertence a uma Famı́lia Lógica.
Historicamente, várias famı́lias lógicas foram propostas, empregando-se dispositivos eletrônicos. Usando transistor bipolar e processamento de tensão, podem ser citadas: ResistorTransistor Logic (RTL), Diode-Transistor Logic (DTL), e Transisor-Transistor Logic (TTL).
Usando transistor de efeito de campo (FET) do tipo Metal-Oxide-Silicon (MOS), denominado
de MOSFET, e processamento de tensão, podem ser citadas: transistor do tipo N (NMOS),
transistor do tipo P (PMOS) e arranjo complementar de ambos os tipos de transistores (CMOS).
Usando transistor bipolar e processamento de corrente, podem ser citadas: Current Injection
Logic (IIL ou I2L) e Emitter-Coupled Logic (ECL).
O processamento de tensão é usado para soluções envolvendo baixas e médias taxas de
operação. Quando são necessárias altas taxas de operação, normalmente é empregada uma
solução com processamento de corrente.
No processamento de tensão, as famı́lias lógicas mais utilizadas comercialmente são a TTL
e a CMOS.
187
188
Apêndice A. Noções básicas sobre implementação de funções lógicas
Devido ao seu baixo consumo de energia e à sua baixa ocupação de espaço, os circuitos
CMOS são largamente utilizados em implementações de circuitos integrados de alta densidade.
A.3
Elementos básicos
Os elementos básicos usados na implementação de circuitos lógicos em circuitos integrados
são: fontes de alimentação (externas ao circuito integrado) e transistores (internos ao circuito
integrado).
As fontes de alimentação são elementos de transdução, que transformam grandezas de outros
sistemas fı́sicos em uma grandeza elétrica de tensão ou de corrente, de valor fixo. Elas podem
ser também elementos de transformação de grandezas elétricas de tensão ou de corrente de valor
variável em uma grandeza elétrica de tensão ou de corrente de valor fixo.
Os valores fixos fornecidos pelas fontes devem ser associados aos valores lógicos fixos a serem
implementados.
No caso da lógica binária, devem ser implementados os valores T (True) e F (False). No
processamento de tensão, para este caso, podem ser associados os seguintes valores: +|V | e 0,
0 e −|V | ou +|V | e −|V |. Os dois tipos básicos de associação entre valores de tensão e valores
lógicos binários são apresentados na Tabela A.1.
+|V |
0
Tensões
0 +|V |
−|V | −|V |
Associação 1
T
F
Associação 2
F
T
Tabela A.1: Tipos básicos de associação entre valores de tensão e valores lógicos binários.
Os transistores são dispositivos de três terminais. Um dos terminais é usado para realizar
um acionamento que produzirá um efeito sobre os outros dois terminais. Observam-se três
modos de operação, considerando-se o efeito causado nos dois terminais controlados: circuito
aberto, curto-circuito e fonte de corrente controlada (por tensão ou por corrente).
As implementações clássicas de funções lógicas binárias, tem, como modelo, o uso de dispositivos que possuem dois estados. Assim, em cada tipo de implementação, normalmente, são
utilizados apenas dois dos três modos de operação dos transistores.
A.S.V.
189
A.4. Modelo de chaves
A.4
A.4.1
Modelo de chaves
Conceitos básicos
Nas implementações que utilizam processamento de tensão, os transistores são usados, basicamente, como chaves de passagem, operando nos modos de circuito aberto e curto-circuito entre
os dois terminais controlados. A fontes de alimentação são utilizadas, ao mesmo tempo, como
sinal de acionamento e como resultado da avaliação da função lógica. Neste caso, os sinais
de entrada do circuito, que representam os parâmetros dos quais depende a função lógica, são
usados apenas para acionar transistores operando como chaves, cujo acionamento pode ainda
acionar outros transistores. Uma vez selecionado um determinado caminho formado por chaves
fechadas, uma das duas fontes de alimentação é conectada com a saı́da, o que irá representar o
valor da função lógica implementada para um dado conjunto de valores dos seus parâmetros.
Deve-se notar que os circuitos em si não implementam funções lógicas. Internamente, eles
apenas realizam operações elétricas. Porém, através de associações de significados pertinentes,
pode-se, externamente, interpretar o seu funcionamento como a avaliação de uma função lógica.
Pode-se montar um modelo de chaves para a implementação de funções da lógica binária,
com processamento de tensão, utilizando-se as chaves apresentadas na Figura A.1, denominadas
de chave-N e chave-P. O terminal A é o ponto de acionamento, o terminal R é o ponto de
referência e o terminal F é o ponto para onde irá fluir o valor da referência, quando a chave for
fechada. Enquanto a chave estiver aberta, o terminal F permanece indefinido.
F
A
F
A
R
(a)
R
(b)
Figura A.1: Chaves simples ou Single-Pole Single-Throw (SPST). (a) Chave-N. (b) Chave-P.
Será adotado o seguinte padrão de acionamento para as chaves N e P. Supondo-se que
VAR = VA − VR é a diferença de potencial entre os terminais A e R, a chave-N será fechada
quando VAR > 0 ou VA > VR e será aberta quando VAR ≤ 0 ou VA ≤ VR . De forma contrária, a
chave-P será fechada quando VAR < 0 ou VA < VR e será aberta quando VAR ≥ 0 ou VA ≥ VR .
Supondo-se a associação (VAR > 0) = T e (VAR ≤ 0) = F , pode-se dizer que, quando A = T ,
a chave-N será fechada e a chave-P será aberta. De forma contrária, quando A = F , a chave-N
será aberta e a chave-P será fechada.
A partir do padrão de acionamento definido, conclui-se que as chaves N e P são complementares em relação ao seu acionamento. Dito de outra forma, pode-se interpretar uma chave-P
acionada por uma variável A como uma chave-N acionada por uma variável ¬A Isso é ilustrado
na Figura A.2, onde a chave-P é interpretada como a associação de um bloco inversor lógico
(NOT) com uma chave-N. Por essa razão, a chave-P é representada como a chave-N acrescida
de um cı́rculo de negação.
TET / UFF
190
Apêndice A. Noções básicas sobre implementação de funções lógicas
Quanto ao terminal F, quando a chave está fechada, tem-se VF = VR . Por outro lado,
quando a chave está aberta, o valor de VF é indefinido e costuma-se dizer que o ponto F está
flutuando.
F
F
A
A
A
R
R
Figura A.2: Relação de complementariedade entre as chaves N e P.
A.4.2
Arranjos série e paralelo de chaves
A Figura A.3 mostra um arranjo série de chaves. Para as chaves-N, se VA1 > VR1 e VA2 > VR1 ,
então ambas as chaves estarão fechadas e VF2 = VR2 = VF1 = VR1 . Caso contrário, uma das
chaves estará aberta, ou ambas, e o valor de VF é indefinido. Para as chaves-P, se VA1 < VR1 e
VA2 < VR1 , então ambas as chaves estarão fechadas e VF2 = VR2 = VF1 = VR1 . Caso contrário,
uma das chaves estará aberta, ou ambas, e o valor de VF é indefinido. Esse tipo de arranjo é a
base para modelar uma implementação da função lógica AND.
F
F
2
A2
2
A2
F1 = R 2
A1
F1 = R 2
A1
R1
(a)
R1
(b)
Figura A.3: Arranjo série de chaves simples. (a) Chave-N. (b) Chave-P.
A Figura A.4 mostra um arranjo série de chaves. Para as chaves-N, se VA1 > VR1 ou
VA2 > VR2 , ou ambos, então uma das chaves estará fechada, ou ambas, e VF2 = VR2 = VF1 = VR1 .
Caso contrário, ambas as chaves estarão abertas, e o valor de VF é indefinido. Para as chaves-P,
se VA1 < VR1 ou VA2 < VR2 , ou ambos, então uma das chaves estará fechada, ou ambas, e
VF2 = VR2 = VF1 = VR1 . Caso contrário, ambas as chaves estarão abertas, e o valor de VF é
indefinido. Esse tipo de arranjo é a base para modelar uma implementação da função lógica
OR.
A.S.V.
191
A.4. Modelo de chaves
F = F
1
F = F
2
A1
1
A2
2
A1
A2
R1= R2
R1= R2
(a)
(b)
Figura A.4: Arranjo paralelo de chaves simples. (a) Chave-N. (b) Chave-P.
TET / UFF
192
A.4.3
Apêndice A. Noções básicas sobre implementação de funções lógicas
Modelo de chaves para a função NOT
Na Figura A.5 é apresentado um arranjo de chaves N e P, com fontes de alimentação. Baseado na
operação das chaves, pode-se comprovar o comportamento elétrico apresentado na Tabela A.2.
Estabelecendo-se a associação +|V | = T e −|V | = F , pode-se identificar o comportamento
lógico apresentado na Tabela A.3. Esse tipo de arranjo modela uma implementação da função
lógica NOT.
+ V
A
X
V
Figura A.5: Modelo de chaves para uma implementação da função lógica NOT.
VA
−|V |
+|V |
VX = f(VA )
+|V |
−|V |
Tabela A.2: Comportamento elétrico do modelo de chaves NOT.
A
F
T
X = f(A)
T
F
Tabela A.3: Comportamento lógico do modelo de chaves NOT.
A.S.V.
193
A.4. Modelo de chaves
A.4.4
Modelo de chaves para a função NAND
Na Figura A.6 é apresentado um arranjo de chaves N e P, com fontes de alimentação. Baseado na
operação das chaves, pode-se comprovar o comportamento elétrico apresentado na Tabela A.4.
Estabelecendo-se a associação +|V | = T e −|V | = F , pode-se identificar o comportamento
lógico apresentado na Tabela A.5. Esse tipo de arranjo modela uma implementação da função
lógica NAND.
+ V
A
B
X
V
Figura A.6: Modelo de chaves para uma implementação da função lógica NAND.
VA
−|V |
−|V |
+|V |
+|V |
VB
−|V |
+|V |
−|V |
+|V |
VX = f(VA , VB )
+|V |
+|V |
+|V |
−|V |
Tabela A.4: Comportamento elétrico do modelo de chaves NAND.
TET / UFF
194
Apêndice A. Noções básicas sobre implementação de funções lógicas
A B
F F
F T
T F
T T
X = f(A, B)
T
T
T
F
Tabela A.5: Comportamento lógico do modelo de chaves NAND.
A.S.V.
195
A.4. Modelo de chaves
A.4.5
Modelo de chaves para a função NOR
Na Figura A.7 é apresentado um arranjo de chaves N e P, com fontes de alimentação. Baseado na
operação das chaves, pode-se comprovar o comportamento elétrico apresentado na Tabela A.6.
Estabelecendo-se a associação +|V | = T e −|V | = F , pode-se identificar o comportamento
lógico apresentado na Tabela A.7. Esse tipo de arranjo modela uma implementação da função
lógica NAND.
+ V
X
A
B
V
Figura A.7: Modelo de chaves para uma implementação da função lógica NOR.
VA
−|V |
−|V |
+|V |
+|V |
VB
−|V |
+|V |
−|V |
+|V |
VX = f(VA , VB )
+|V |
−|V |
−|V |
−|V |
Tabela A.6: Comportamento elétrico do modelo de chaves NOR.
TET / UFF
196
Apêndice A. Noções básicas sobre implementação de funções lógicas
A B
F F
F T
T F
T T
X = f(A, B)
T
F
F
F
Tabela A.7: Comportamento lógico do modelo de chaves NOR.
A.S.V.
197
A.4. Modelo de chaves
A.4.6
Modelo de chaves para arranjos AOI e OAI
Além dos conectivos lógicos básicos (NOT, NAND e NOR), dois tipos de arranjos são largamente
utilizados na implementação de funções lógicas, os quais são denominados de AO (AND-OR)
e de OA (OR-AND). Como foi visto acima, o modelo de chaves complementares apresenta
uma inversão intrı́nseca. Assim, são naturalmente implementados os arranjos AOI (AND-ORINVERTER) e OAI (OR-AND-INVERTER), descritos a seguir.
Arranjos AOI
Os arranjos AOI (AND-OR-INVERTER) são funções lógicas onde as variáveis (e suas negações)
são inicialmente combinadas por conectivos AND. Em seguida, tais termos são combinados por
conectivos OR. Finalmente, toda a função sofre uma inversão através da operação NOT.
Exemplos de arranjos AOI são
f (A, B) = ¬( (A ∧ ¬B) ∨ (¬A ∧ B) ) ,
f (A, B, C) = ¬( (¬A ∧ ¬B ∧ C) ∨ (¬A ∧ B ∧ ¬C) ∨
(A ∧ ¬B ∧ ¬C) ∨ (A ∧ B ∧ C) ∨ ) ,
e
f (A, B, C, D) = ¬( (¬A ∧ B ∧ ¬C ∧ D) ∨ (¬A ∧ B ∧ C ∧ ¬D) ∨
(A ∧ ¬B ∧ C ∧ ¬D) ∨ (A ∧ ¬B ∧ C ∧ D) ) .
O arranjo AOI definido por f (A, B, C, D) = ¬( (A ∧ B) ∨ (C ∧ D) ) pode ser implementado
pelo modelo de chaves complementares mostrado na Figura A.8.
Arranjos OAI
Os arranjos OAI (OR-AND-INVERTER) são funções lógicas onde as variáveis (e suas negações)
são inicialmente combinadas por conectivos OR. Em seguida, tais termos são combinados por
conectivos AND. Finalmente, toda a função sofre uma inversão através da operação NOT.
Exemplos de arranjos OAI são
f (A, B) = ¬( (A ∨ ¬B) ∧ (¬A ∨ B) ) ,
f (A, B, C) = ¬( (¬A ∨ ¬B ∨ C) ∧ (¬A ∨ B ∨ ¬C) ∧
(A ∨ ¬B ∨ ¬C) ∧ (A ∨ B ∨ C) ∧ ) ,
e
f (A, B, C, D) = ¬( (¬A ∨ B ∨ ¬C ∨ D) ∧ (¬A ∨ B ∨ C ∨ ¬D) ∧
(A ∨ ¬B ∨ C ∨ ¬D) ∧ (A ∨ ¬B ∨ C ∨ D) ) .
O arranjo OAI definido por f (A, B, C, D) = ¬( (A ∨ B) ∧ (C ∨ D) ) pode ser implementado
pelo modelo de chaves complementares mostrado na Figura A.9.
TET / UFF
198
Apêndice A. Noções básicas sobre implementação de funções lógicas
+ V
A
B
C
D
X
A
D
B
C
V
Figura A.8: Modelo de chaves para uma implementação do arranjo AOI f (A, B, C, D) =
¬( (A ∧ B) ∨ (C ∧ D) ).
A.S.V.
199
A.4. Modelo de chaves
+ V
B
C
A
D
X
C
D
A
B
V
Figura A.9: Modelo de chaves para uma implementação do arranjo OAI f (A, B, C, D) =
¬( (A ∨ B) ∧ (C ∨ D) ).
TET / UFF
200
A.4.7
Apêndice A. Noções básicas sobre implementação de funções lógicas
Modelo de chaves complementar genérico
Do ponto de vista funcional, os conectivos lógicos anteriormente modelados (NOT, NAND e
NOR) são suficientes para gerar qualquer função lógica binária desejada. Mesmo assim, cabe
investigar tanto a possibilidade de sı́ntese de uma função genérica quanto a existência de uma
lei de formação para tal.
Observando-se os modelos apresentados para as funções NOT, NAND e NOR, percebe-se
que os mesmos compartilham certas caracterı́sticas.
Uma vez que as chaves N e P sofrem acionamento complementar, os blocos de chaves N e P
herdam o mesmo comportamento. Esse comportamento complementar garante a consistência
da operação, pois quando um bloco proporciona um caminho de condução ao longo de sua
estrutura e força um valor lógico na saı́da, o outro bloco gera uma obstrução e provoca uma
indeterminação. O comportamento complementar dos blocos de chaves N e P nos modelos
NOT, NAND e NOR, pode ser observado, respectivamente, nas Tabelas A.8, A.9 e A.10, onde
o valor lógico I significa uma indeterminação.
A
F
T
X(A)
I
F
A
F
T
(a)
X(A)
T
I
(b)
A
F
T
X(A)
T
F
(c)
Tabela A.8: Comparação do comportamento dos blocos de chaves N e P no modelo de chaves
da função lógica NOT. (a) Chave-N. (b) Chave-P. (c) Arranjo complementar.
A
F
F
T
T
B
F
T
F
T
X(A,B)
I
I
I
F
A
F
F
T
T
B
F
T
F
T
(a)
X(A,B)
T
T
T
I
A
F
F
T
T
B
F
T
F
T
(b)
X(A,B)
T
T
T
F
(c)
Tabela A.9: Comparação do comportamento dos blocos de chaves N e P no modelo de chaves
da função lógica NAND. (a) Chave-N. (b) Chave-P. (c) Arranjo complementar.
A
F
F
T
T
B
F
T
F
T
X(A,B)
I
F
F
F
(a)
A
F
F
T
T
B
F
T
F
T
X(A,B)
T
I
I
I
(b)
A
F
F
T
T
B
F
T
F
T
X(A,B)
T
F
F
F
(c)
Tabela A.10: Comparação do comportamento dos blocos de chaves N e P no modelo de chaves
da função lógica NOR. (a) Chave-N. (b) Chave-P. (c) Arranjo complementar.
A.S.V.
A.4. Modelo de chaves
201
Pode-se constatar que o bloco de chaves-N possui uma ligação direta com a função desejada
Porém, ele apresenta uma inversão intrı́nseca à estrutura. No caso da função NOT, quando a
variável de entrada vale T, o bloco conduz, realizando a passagem de um valor F para a saı́da.
No caso da função NAND, quando as variáveis de entrada valem ambas T, o bloco conduz,
realizando uma operação AND, mas passando um valor F para a saı́da. No caso da função
NOR, quando uma das variáveis de entrada vale T, ou ambas, o bloco conduz, realizando uma
operação OR, mas passando um valor F para a saı́da. Logo, pode-se dizer que, definindose a função desejada como ¬X(A, B, C, · · ·) o bloco de chaves-N realiza o seu complemento:
X(A, B, C, · · ·).
Por sua vez, o bloco de chaves-P deve colaborar na sı́ntese da função desejada de uma forma
funcionalmente complementar ao bloco de chaves-N, ao mesmo tempo que seu acionamento deve
ser provocado pelo complemento das variáveis de entrada que acionam o bloco de chaves-N.
Isso é equivalente à aplicação do Teorema de De Morgan ao complemento da funcionalidade do
bloco de chaves-N. Porém, nessa estrutura, a função do bloco de chaves-N já é o complemento
da função desejada. Logo, a sı́ntese do bloco de chaves-P é equivalente à aplicação do Teorema
de De Morgan sobre a função desejada. Além disso, o acionamento das chaves-P já é baseado no
complemento das variáveis que acionam o bloco de chaves-N. Portanto, após aplicar o Teorema
de De Morgan sobre a função desejada, deve-se desprezar a negação das variáveis de entrada na
equação final. Isso pode ser facilmente verificado nos modeles de chaves para as funções NOT,
NAND e NOR.
Resumindo, a regra geral para a sı́ntese de uma função lógica binária qualquer, usando
chaves complementares, através de um arranjo complementar, pode ser definida da seguinte
forma:
• Definir a função desejada como ¬X(A, B, C, · · ·).
• Sintetizar, através de um arranjo de chaves-N, a função X(A, B, C, · · ·).
• Aplicar o Teorema de De Morgan sobre ¬X(A, B, C, · · ·). Desconsiderar a negação das
variáveis de entrada. Sintetizar a equação final através de um arranjo de chaves-P.
TET / UFF
202
Apêndice A. Noções básicas sobre implementação de funções lógicas
A.S.V.
Apêndice B
Tópicos sobre divisão de números
inteiros
B.1
Algoritmo de divisão inteira
Teorema (Divisão com resto): Para cada inteiro c (dividendo) e cada inteiro positivo d
(divisor), existe um único par de inteiros Q (quociente) e r (resto), tal que c = d · Q + r, onde
0 ≤ r < d.
B.2
Quociente
O quociente pode ser descrito por
Q=
jck
d
,
onde ⌊(·)⌋ representa o maior inteiro menor que (·).
B.3
Resto ou resı́duo
O resto da divisão de c por d pode ser descrito por
r = Rd [c] = ((c)) = c
(mod d) ,
podendo ainda ser denominado de resı́duo de c, módulo d.
B.4
Congruência
Dois números inteiros c1 e c2 que, divididos por um terceiro inteiro positivo d, apresentam o
mesmo resto (ou resı́duo) r são ditos congruentes, módulo d, e são representados por
c1 ≡ c2
(mod d) ,
onde ≡ denota uma relação de equivalência.
203
204
B.5
Apêndice B. Tópicos sobre divisão de números inteiros
Relações úteis
Teorema: Para um mesmo número inteiro positivo d,
(i) Rd [a + b] = Rd [Rd [a] + Rd [b]]
(ii) Rd [a · b] = Rd [Rd [a] · Rd [b]]
onde + e · denotam, respectivamente, as operações de adição e multiplicação entre números
inteiros.
A.S.V.
Apêndice C
Minimização de tabela de estados
C.1
Introdução
• A minimização do número de estados de um circuito seqüencial pode conduzir à redução
da quantidade de circuitos lógicos necessários para implementar os estados (bloco Geração
e Armazenamento) e as saı́das (bloco Função Combinacional).
• Dada uma tabela de transição de estados (state table), pode-se constatar que diferentes
estados podem realizar a mesma função.
• Do ponto de vista externo ao circuito, pode-se dizer que não é possı́vel distinguir entre
tais estados, uma vez que eles apresentam o mesmo resultado.
• Nesse caso, tal conjunto de estados pode ser representado por um único estado.
• Conseqüentemente, a tabela de transição de estados (state table) é simplificada e, possivelmente, o circuito lógico minimizado.
• Na minimização do número de estados de uma máquina seqüencial, a idéia básica é
organizar os estados de uma máquina M1 em classes que possuam uma determinada
propriedade e, em seguida, definir uma máquina M2, de tal forma que cada estado em
M2 cumpra a função de uma das classes em M1.
• Podem-se destacar dois grupos de descrição de máquinas: i) descrição completamente
especificada e ii) descrição não completamente especificada.
• Nas máquinas seqüenciais com descrição completamente especificada, utiliza-se o critério
de equivalência entre máquinas.
• No caso das máquinas com descrição não completamente especificada, utilizam-se os critérios de compatibilidade e cobertura.
• Pode-se dizer que a equivalência é um caso particular de cobertura, que, por sua vez, é
um caso particular de compatibilidade.
• Nas máquinas seqüenciais com descrição completamente especificada, a solução é única
e, portanto, o processo é mais simples e direto. Nesses casos, utiliza-se o critério de
equivalência para garantir o cumprimento da mesma função por duas máquinas, M1 e
M2. Empregando-se as condições de exclusão definidas para equivalência, os estados de
uma máquina M1 são organizados em classes disjuntas de equivalência. Para cada classe
de M1 é definido um estado equivalente em M2.
205
206
Apêndice C. Minimização de tabela de estados
• Nas máquinas seqüenciais com descrição não completamente especificada, normalmente
deve-se avaliar diferentes soluções possı́veis, o que torna o processo mais complexo e menos
objetivo. Nesses casos, utiliza-se o critério de cobertura para garantir o cumprimento da
mesma função por duas máquinas, M1 e M2. Empregando-se as condições de exclusão
definidas para compatibilidade, os estados de uma máquina M1 são organizados em classes
conjuntas de compatibilidade máxima. Em seguida, deve-se determinar uma coleção de
cobertura (cover collection) mı́nima, que é uma coleção fechada (closed collection) mı́nima
que contém cada estado de M1 em, pelo menos, uma classe de compatibilidade. Para cada
classe de compatibilidade da coleção de cobertura de M1 é definido um estado de cobertura
em M2.
• O formalismo (Definições, Teoremas e Corolários) apresentado nesse capı́tulo foi retirado
integralmente de [HP81].
C.2
C.2.1
Tabelas de estados completamente especificadas
Relações de equivalência
• Quando um par ordenado de elementos (x, y) possui uma propriedade R que os relaciona,
pode-se dizer que “x é R-relacionado com y”, o que é simbolizado por xRy.
• A relação R é definida como o conjunto de todos os pares ordenados que possuem a
propriedade em questão.
• Pode-se assumir que R é uma relação definida sobre um conjunto de elementos, de tal
forma que x ou y possam representar qualquer elemento do conjunto.
• Classificação das relações:
– Reflexão: se xRx é válida para qualquer x, então R é reflexiva.
– Simetria: se yRx ↔ xRy, então R é simétrica.
– Transitividade: se (xRy e yRz) → xRz, então R é transitiva.
– Equivalência: se R é reflexiva, simétrica e transitiva, então R é uma relação de
equivalência.
C.2.2
Estados e circuitos equivalentes
• As tabelas de transição de estados (state tables) representam duas funções: a função de
próximo estado δ(·) e a função de saı́da λ(·).
• Pode-se definir a função de próximo estado por: δ(qin , xn ) = qjn+1 .
• Pode-se definir a função de saı́da por: λ(qin , xn ) = z n .
• Para uma seqüência de sinais de entrada dada por X = xn xn+1 · · · xn+R , tem-se:
n+(R+1)
δ(qin , xn xn+1 · · · xn+R ) = qj
e λ(qin , xn xn+1 · · · xn+R ) = z n z n+1 · · · z n+R .
• Em última análise, dado um estado inicial e uma seqüência de valores de entrada, a função
de um circuito seqüencial é produzir uma seqüência de valores de saı́da apropriada.
A.S.V.
C.2. Tabelas de estados completamente especificadas
207
• Dessa forma, podem-se estabelecer relações de equivalência entre estados e entre circuitos
seqüenciais.
• Definição 1: Sejam S e T dois circuitos seqüenciais completamente especificados, sujeitos a seqüências de entrada possı́veis e idênticas. Seja (xn xn+1 · · · xn+R ) uma seqüência de possı́veis valores de entrada, de comprimento arbitrário. Os estados p ∈ T e
q ∈ S são ditos indistinguı́veis (equivalentes), definido por p ≡ q, se e somente se
λT (pn , xn xn+1 · · · xn+R ) = λS (q n , xn xn+1 · · · xn+R ) para cada possı́vel seqüência de entrada.
• Definição 2: Os circuitos seqüenciais S e T são ditos equivalentes, definido por S ≡ T ,
se e somente se para cada estado p em T existe um estado q em S tal que p ≡ q, e,
inversamente, para cada estado q em S existe um estado p em T tal que q ≡ p.
C.2.3
Determinação de classes de estados indistinguı́veis
• Uma proposta para se obter a tabela de transição de estados (state table) mı́nima é
particioná-la no menor número possı́vel de classes de equivalência de estados indistinguı́veis.
• Em seguida, pode-se obter um circuito seqüencial equivalente, onde cada estado corresponda a uma classe do circuito original.
• Uma vez que nem toda partição é uma classe de equivalência, deve-se ter uma forma de
se definir corretamente as partições.
• Teorema 1: Suponha que os estados de um circuito seqüencial foram particionados em
classes disjuntas, onde p , q denota que os estados p e q pertencem à mesma classe. A
partição é composta por classes de equivalência de estados indistinguı́veis se e somente
se as duas condições seguintes forem satisfeitas por cada par de estados p e q da mesma
classe, para cada entrada simples xn :
1. λ(pn , xn ) = λ(q n , xn ).
2. δ(pn , xn ) , δ(q n , xn ).
C.2.4
Circuito de classes de equivalência
• Com a tabela de transição de estados (state table) particionada em classes de equivalência,
pode-se obter um circuito seqüencial equivalente ao original, com o número de estados
minimizado.
• Teorema 2: Suponha que seja formado um circuito seqüencial T , que corresponda a um
circuito completamente especificado S, de forma que para cada estado pj ∈ T corresponda
uma classe de equivalência Cj ∈ S. O circuito T assim construı́do, denominado circuito de
classes de equivalência, é equivalente a S. Além disso, nenhum outro circuito equivalente
a S possuirá um número menor de estados do que T e qualquer circuito equivalente a S
que possua o mesmo número de estados de T deve ser T .
TET / UFF
208
C.3
C.3.1
Apêndice C. Minimização de tabela de estados
Tabelas de estados não completamente especificadas
Introdução
• Na representação de um circuito digital, a falta de especificação de valores pode surgir
por diversos fatores.
• Em circuitos combinacionais, determinadas entradas e/ou saı́das dos blocos funcionais
podem não ocorrer (can’t happen) ou podem não importar (don’t care). Genericamente,
ambos os casos são empregados como don’t care, durante o processo de minimização dos
circuitos.
• Em circuitos seqüenciais, as indeterminações podem apresentar várias origens:
– Nas máquinas completamente especificadas que possuem um número de estados cujo
valor não é uma potência de dois, os estados extras da tabela de atribuição podem ser
assumidos como don’t cares. Nesses casos, é comum que eles recebam a denominação
de don’t cares acidentais (incidental don’t cares).
– Determinadas seqüências de entrada podem nunca acontecer, gerando indeterminações na tabela de estados (próximas entradas e saı́das), as quais podem ser especificadas como don’t cares.
– Em máquinas onde as saı́das são amostradas em intervalos de tempo maiores do que
aqueles das mudancas de estado, podem-se atribuir valores indeterminados às saı́das
intermediárias, as quais também podem ser assumidas como don’t cares.
• Em circuitos combinacionais, o valor don’t care (‘X’) pode ser substituı́do apenas por
valores booleanos (‘0’ ou ‘1’). Nesses casos, a substituição de valores é um processo
simples de ser executado e sempre auxilia na minimização das expressões.
• Em circuitos seqüenciais, situações diferentes podem ocorrer:
– Um valor don’t care (‘X’) de estado/saı́da pode ser substituı́do por N/M valores de
estados/saı́das.
– A substituição indiscriminada de valores de estados/saı́das pode: i) proporcionar a
minimização do número de estados, ii) conduzir a um número próximo do mı́nimo
ou iii) impedir a minimização.
• Assim, deve-se adotar um método sistemático na tentativa de minimização de estados de
máquinas não completamente especificadas.
C.3.2
Noções básicas de compatibilidade
• Dada uma tabela de estados, com próximos estados e/ou saı́das não completamente especificados, é possı́vel que se realize combinações de estados, reduzindo o número total
estados da tabela.
• Porém, não se pode falar, genericamente, de equivalência de estados em máquinas seqüenciais não completamente especificadas.
• A equivalência entre estados exige que tanto suas saı́das quanto seus próximos estados
sejam definidos para todos os valores das entradas.
A.S.V.
C.3. Tabelas de estados não completamente especificadas
209
• Tal exigência não é cumprida por máquinas não completamente especificadas.
• Estados não completamente especificados que podem ser combinados em um único estado
final são ditos compatı́veis entre si.
• Obviamente, estados que são idênticos em seus valores especificados podem ser transformados em estados equivalentes através da atribuição adequada de seus valores não
especificados.
• Conseqüentemente, tais estados são compatı́veis e podem ser combinados em um único
estado.
• Porém, tal condição é suficiente, mas não necessária.
• Estados não idênticos também podem ser combinados, em algumas condições.
• Em qualquer associação de estados, é aplicado o conceito segundo o qual estados que
possuem a mesma função dentro do circuito devem produzir os mesmos valores de saı́da,
para os mesmos valores de entrada.
• No caso das máquinas não completamente especificadas, a compatibilidade é associada
apenas aos valores especificados de entrada, de próximo estado e de saı́da.
C.3.3
Formalização dos conceitos de compatibilidade e de cobertura
• Definição 1: Seja uma seqüência de valores de entrada x = {xn xn+1 · · · xn+(K+1) }, aplicada a um circuito S, cuja descrição é não completamente especificada e que se encontra
em um estado inicial q n . A seqüência x é dita aplicável a q se todos os valores de próximo
estado forem especificados, exceto, possivelmente, aquele produzido pela última entrada
da seqüência.
• Definição 2: Dois estados, p e q, de um circuito S, são ditos compatı́veis se e somente se
λS δ(p, xn xn+1 · · · xn+K ), xn+(K+1) = λS δ(q, xn xn+1 · · · xn+K ), xn+(K+1) ,
sempre que ambas as saı́das forem especificadas, para cada seqüência x aplicável a ambos
os estados, onde x = {xn xn+1 · · · xn+(K+1) }.
• Teorema 1: Se dois estados, p e q, de um circuito S, são compatı́veis, então as seguintes
condições devem ser satisfeitas para toda entrada simples x:
1. λ(pn , xn ) = λ(q n , xn ), sempre que ambas forem especificadas.
2. δ(pn , xn ) e δ(q n , xn ) são compatı́veis, sempre que ambos forem especificados.
• Definição 3: Um conjunto de estados Si , de um circuito S, é denominado uma classe de
compatibilidade se cada par de estados em Si for compatı́vel.
• Definição 4: Uma classe de compatibilidade máxima é uma classe de compatibilidade
que deixará de sê-la, se um estado que não lhe for pertencente for a ela adicionado. Um
estado isolado, que não é compatı́vel com qualquer outro estado, é definido como uma
classe de compatibilidade máxima.
TET / UFF
210
Apêndice C. Minimização de tabela de estados
• Definição 5: Diz-se que um estado p, de uma tabela de estados T , cobre um estado q,
de uma tabela de estados S, o que é definido por p ≥ q, se, para qualquer seqüência de
entradas aplicável a q e aplicada a ambas as tabelas, inicialmente nos estados pn e q n ,
respectivamente, as duas seqüências de saı́das forem idênticas, sempre que a saı́da de S
for especificada.
• Definição 6: Diz-se que uma tabela de estados T cobre uma tabela de estados S se, para
estado q em S, existe um estado p em T que cobre q.
• Teorema 2: Se um estado p em T cobre ambos os estados qi e qj em S, então os estados
qi e qj devem ser compatı́veis.
• Corolário 2.1: Se um estado p em T cobre um conjunto de estados Si de S, então tais
estados devem formar uma classe de compatibilidade.
• Definição 7: Uma coleção de classes de compatibilidade é dita fechada se, para qualquer
classe {q1 , q2 , · · ·, qm } da coleção e para toda entrada simples x, todos os próximos estados
n
especificados, δ(q1n , xn ), δ(q2n , xn ), · · ·, δ(qm
, xn ), pertencem a uma única classe da coleção.
• Teorema 3: Suponha que, a partir dos n estados de um circuito seqüencial não completamente especificado S, seja formada uma coleção de m classes de compatibilidade,
de modo que cada um dos n estados seja membro de, pelo menos, uma das m classes.
O circuito S poderá ser coberto por um circuito T , que possua exatamente m estados,
(p1 , p2 , · · ·, pm ), de forma que cada classe de compatibilidade de S seja coberta por um
dos estados de T , se e somente se a coleção de m classes de compatibilidade de S for
fechada.
C.3.4
Sistematização do processo de minimização
• A Definição 1, a Definição 2, e o Teorema 1 apresentam as condições de exclusão que
podem ser usadas na organização dos estados em classes de compatibilidade.
• A Definição 3 e a Definição 4, fornecem as diretrizes para a geração das classes de
compatibilidade.
• A Definição 5, a Definição 6, o Teorema 2 e o Corolário 2.1 tratam da propriedade
de cobertura e de sua relação com a propriedade de compatibilidade.
• A Definição 7, e o Teorema 3 indicam as condições de cobertura entre máquinas.
A.S.V.
Apêndice D
Introdução à linguagem VHDL
D.1
Introdução
• Desde a implementção do primeiro dispositivo eletrônico em circuito integrado, os avanços
tecnológicos têm possibilitado um rápido aumento na quantidade de elementos que podem
ser combinados em um único circuito nesse tipo de implementção.
• Naturalmente, com a oferta de uma maior densidade de componentes, a complexidade
dos circuitos projetados cresce na mesma taxa.
• Porém, a capacidade de um ser humano em lidar com a idealização, o projeto e a manutenção de sistemas com um grande número de componentes é extremamente limitada.
• Dessa forma, torna-se necessário o uso de ferramentes adequadas a tal tipo de problema.
• Existem duas técnicas de projeto largamente utilizadas na abordagem de problemas de
elevada complexidade:
– Aumentar o nı́vel de abstração na descrição do sistema, de forma que o foco esteja
mais na função desempenhada e menos na implementação propriamente dita.
– Adotar uma visão hierárquica na elaboração do sistema, de forma que, em cada nı́vel
de representação, toda a complexidade dos nı́veis inferiores seja ocultada.
• Nesse sentido, na área de projeto de circuitos integrados, diversas Linguagens de Descrição
de Hardware (HDL) têm sido propostas, a fim de permitir uma descrição mais abstrata
dos componentes e possibilitando que estes sejam organizados de forma hierárquica.
• Uma das linguagens mais utilizadas no projeto de circuitos integrados digitais é a linguagem VHDL (Very-high-speed integrated-circuit Hardware Description Language), a qual é
apresentada a seguir, de forma introdutória.
211
212
D.2
Apêndice D. Introdução à linguagem VHDL
Nı́veis de abstração
• Fı́sico-matemático
• Componentes
• Células, blocos
• Lógico
• Comportamental
D.3
VHDL como linguagem
• Como qualquer linguagem escrita, VHDL utiliza um conjunto especı́fico de regras que
definem aspectos de sintaxe e de semântica.
• Embora seja uma linguagem especı́fica para a descrição de circuitos eletrônicos digitais,
VHDL ainda pode ser interpretada como uma linguagem de programação.
• Como tal, ela apresenta elementos comuns a diversas linguagens de programação modernas, alguns dos quais são discutidos a seguir.
D.3.1
Palavras reservadas
• Palavras reservadas (reserved words ou keywords) são identificadores que possuem um
significado especial dentro da linguagem.
• Assim, seu uso é restrito à sua definição original e, uma vez que não podem ser redefinidas,
elas não podem ser empregadas para nenhum outro propósito.
• A Figura D.1 apresenta as palavras reservadas de VHDL.
D.3.2
Elementos sintáticos
• Além das palavras reservadas e de identificadores definidos pelo usuário, podem-se utilizar
sı́mbolos especiais para escrever o código VHDL.
• Assim como as palavras reservadas, seu uso é restrito à sua definição original e, uma
vez que não podem ser redefinidos, eles não podem ser empregados para nenhum outro
propósito.
• A Figura D.2 apresenta os sı́mbolos especiais de VHDL.
A.S.V.
213
D.3. VHDL como linguagem
abs
açess
after
alias
all
and
architecture
array
assert
attribute
else
elseif
end
entity
exit
file
for
function
map
mod
begin
block
body
buffer
bus
generate
generic
group
guarded
nand
new
next
nor
not
null
case
component
configuration
constant
if
impure
in
inertial
inout
is
of
on
open
or
others
out
disconnect
downto
label
library
linkage
literal
loop
package
port
postponed
procedure
process
pure
range
record
register
reject
rem
report
return
rol
ror
select
severity
shared
signal
sla
sll
sra
srl
subtype
Figura D.1: Palavras reservadas de VHDL.
TET / UFF
then
to
transport
type
unaffected
units
until
use
variable
wait
when
while
with
xor
xnor
214
Apêndice D. Introdução à linguagem VHDL
Sı́mbolo
Significado
Sı́mbolo
Significado
+
−
/
=
<
>
&
|
;
#
(
)
.
Adição ou número positivo
Subtração ou número negativo
Divisão
Igualdade
Menor do que
Maior do que
Concatenador
Barra vertical
Terminador
Literal incluı́do
Parêntese da esquerda
Parêntese da direita
Notação de ponto
:
”
’
**
=>
=>
:=
/=
>=
<=
<=
<>
−−
Separação variável–tipo
Aspas duplas
Aspas simples ou marca de tick
Exponenciação
Seta indicando “então”
Seta indicando “recebe”
Atribuição de um valor a uma variável
Diferente de
Maior do que ou igual a
Menor do que ou igual a
Atribuição de um valor a um sinal
Caixa
Comentário
Figura D.2: Sı́mbolos especiais de VHDL.
A.S.V.
D.3. VHDL como linguagem
D.3.3
215
Bibliotecas e pacotes
• Em aplicativos de desenvolvimento, é comum que diversos elementos sejam previamente
definidos, tais como: identificadores, valores constantes, nomes de variáveis e de estruturas, inicialização de variáveis e de estruturas, macros, funções, objetos.
• O objetivo em se definir previamente tais elementos é facilitar o trabalho do projetista.
• Cada aplicativo possui seus próprios padrões para a organização dos elementos previamente definidos.
• Uma organização simples e bastante utilizada são os arquivos de configuração.
• Por outro lado, uma forma mais estruturada de organização é obtida através do agrupamento de informações em um pacote (package) e de pacotes em uma biblioteca (library).
• Nos circuitos digitais descritos em VHDL, são largamente utilizados a biblioteca padrão
ieee e os seus pacotes standard e IEEE 1164, ambos definidos pelo IEEE (Institute of
Electrical and Electronics Engineers).
TET / UFF
216
Apêndice D. Introdução à linguagem VHDL
A.S.V.
Referências Bibliográficas
[Arm62]
D. B. Armstrong. A Programmed Algorithm for Assigning Internal Codes to Sequential Machines. IRE Transactions on Electronic Computers, EC 11(4):466–472,
August 1962.
[HP81]
F. J. Hill and G. R. Peterson. Introduction to Switching Theory and Logical Design.
John Wiley, New York, NY, 3rd edition, 1981.
[Hum58]
W. S. Humphrey. Switching Circuits with Computer Applications. McGraw-Hill,
New York, NY, 1958.
[IC08]
I. V. Idoeta and F. G. Capuano. Elementos de Eletrônica Digital. Editora Érica,
40.a edição edition, 2008.
[McC65]
E. J. McCluskey. Introduction to the Theory of Switching Circuits. McGraw-Hill,
New York, NY, 1965.
[Rhy73]
V. T. Rhyne. Fundamentals of Digital Systems Design. Prentice-Hall, Englewood
Cliffs, NJ, 1973.
[Ric56]
R. K. Richards. Arithmetic Operations in Digital Computers. Van Nostrand Reinhold, New York, NY, 1956.
[Sau67]
G. A. Saucier. Encoding of Asynchronous Sequential Networks. IEEE Transactions
on Computers, EC 16(3), 1967.
[Tau82]
H. Taub. Digital Circuits and Microprocessors. McGraw-Hill, New York, NY, 1982.
Em português: McGraw-Hill, Rio de Janeiro, 1984.
[TWM07] R. J. Tocci, N. S. Widmer, and G. L. Moss. Sistemas Digitais: Princı́pios e Aplicações. Prentice Hall, Pearson Education, 10.a edição edition, 2007.
[Ung59]
S. H. Unger. Hazards and Delays in Asynchronous Sequential Switching Circuits.
IRE Transactions on Circuit Theory, CT-6(12), 1959.
[Ung69]
S. H. Unger. Asynchronous Sequential Switching Circuits. John Wiley, New York,
NY, 1969.
[Uye02]
J. P. Uyemura. Sistemas Digitais: Uma abordagem integrada. Thomson Pioneira,
São Paulo, SP, 2002.
217