Academia.eduAcademia.edu

Aposcd

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