técnicas digitais i circuitos digitais
Transcrição
técnicas digitais i circuitos digitais
Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais UNIVERSIDADE FEDERAL FLUMINENSE CENTRO TECNOLÓGICO - ESCOLA DE ENGENHARIA DEPARTAMENTO DE ENGENHARIA DE TELECOMUNICAÇÕES APOSTILA PARA DISCIPLINAS DE TÉCNICAS DIGITAIS I & CIRCUITOS DIGITAIS (CURSO DE ENGENHARIA DE TELECOMUNICAÇÕES DA UFF) (CURSO DE BACHARELADO EM INFORMÁTICA DA UFF) 2º PARTE (Versão 0) Profª Carmen Maria Costa de Carvalho Agosto,2002 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Parte 2 – Circuitos Combinacionais 1-Sistemas Digitais 1.1- Histórico - Circuito Integrado 1.2- Escala de Integração 1.3- Famílias lógicas - Principais características das famílias lógicas 1.4- Encapsulamento 2- Circuitos Combinacionais Básicos 2.1- Padrão de Circuitos Combinacionais 2.2- Somadores e Subtratores 2.2.1- Meio somador (Half-Adder) 2.2.2- Somador Inteiro (Full-Adder) 2.2.3- Somador Inteiro a partir de Meio somador 2.2.4- Somador de 4 bits 2.2.5- Complementador a 2 2.2.6- Subtrator de 4 bits em C2 2.2.7- Subtrator de 4 bits em C1 2.2.8- ULA – Unidade Lógica e Aritmética 2.3- Circuitos Conversores de Código 2.3.1- Apresentação de alguns códigos 2.3.2- Exemplo de Conversores de código 2.4- Codificadores / Decodificadores 2.4.1- Decodificadores 2.4.2- Codificadores 2.4.3- Conversor de Código a partir de Decodificador/Codificador 2.5- Multiplexadores / Demultiplexadores 2.5.1- Multiplexadores 2.5.1.1- Mux como Seletor de Canal 2.5.1.2- Mux como Gerador de Função 2.5.2- Demultiplexadores Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 1-Sistemas Digitais 1.1- Histórico - Circuito Integrado Em um Sistema Digital um componente eletrônico sozinho faz muito pouco. São necessários milhares, centenas de milhares, milhões, para compor as portas e as funções lógicas mais complexas desse sistema. Sendo assim, a velocidade do sistema como um todo, depende da velocidade de operação das portas. - Diferentemente dos sistemas analógicos, nos digitais, o valor real da corrente não é o que importa. Os dispositivos eletrônicos do sistema devem conduzir uma quantidade substancial de corrente ou muito pouca ou nenhuma corrente. Histórico: Dos componentes eletrônicos aos Sistemas Digitais • Até 1955 – os sistemas eram baseados em diodos semicondutores e válvulas a vácuo, apresentando as seguintes características: - diodos: relativamente pequenos (milímetros), dissipando relativamente pouca potência; - válvulas: grandes (vários centímetros), dissipando grandes potências (W). A maioria dos componentes compunha portas a base de diodos e resistores, mas também eram necessárias válvulas em grandes quantidades. - Conseqüência – sistemas digitais enormes, caros, consumindo muita potência. • Por volta de 1955 – foi inventado o transistor que veio substituir as válvulas. - Vantagem - muito menos potência (mW), dimensões da ordem de poucos centímetros. • Até 1965 – os semicondutores eram encapsulados individualmente. - Fabricados através da aplicação repetida de certos processos físicos e químicos à superfície de uma pastilha de silício extremamente puro. - Dispositivo na superfície do silício – da ordem de mícrons Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais - A maior parte da dimensão de um dispositivo encapsulado individualmente envolve e próprio encapsulamento e o suporte mecânico para as conexões elétricas. • Por volta de 1965 – iniciou-se uma série de progressos tecnológicos que levaram à fabricação do circuito integrado (CI). Em um CI, muitos transistores e diodos são fabricados, isto é, integrados, sobre a mesma pastilha de silício; na mesma estrutura são também integrados resistores e até mesmo as interligações para fabricar uma porta completa, muitas portas e até mesmo um sistema digital completo. • No início da década de 80 – os chips já atingem o ponto de se obter um circuito que coubesse na palma da mão, dissipando em torno de 1W e superando sistemas existentes há 30 anos que envolviam uma sala cheia de equipamento e consumiam milhares de watts. • Nos dias de hoje, os C.I.’s tornaram-se indispensáveis, pois com sua utilização os sistemas tiveram seus custos extremamente reduzidos e bem mais confiáveis. 1.2- Escala de Integração De acordo com a quantidade de portas ou componentes encapsulados em um mesmo chip os C.I.’s comercialmente disponíveis são classificados em: - SSI – small scale integration (baixa escala de integração) - MSI – medium scale integration (integração em média escala) - LSI – large scale integration (integração em larga escala) - VLSI – very large scale integration (integração em muita larga escala) - ULSI – ultra large scale integration (integração em ultra larga escala) A convenção adotada para a composição de cada uma dessas escalas é a seguinte: - SSI – até 12 portas ou até 99 componentes. - MSI – de 13 a 99 portas ou de 100 a 9999 componentes. - LSI – de 100 a 9999 portas ou de 10.000 a 99.999 componentes. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais - VLSI –de 10.000 a 99.999 portas ou de 100.000 a 999.999 componentes. - ULSI – acima de 100.000 portas 1.3- Famílias lógicas - Principais características das famílias lógicas Existe um número de famílias de C.I. que se distinguem umas das outras pelo tipo de dispositivo semicondutor que incorporam e pela maneira como os dispositivos semicondutores (e resistores, quando usados) são interligados para formar portas. Dentre as famílias, podemos citar: DTL (diode-transistor logic) RTL (resistor transistor logic) RCTL (resistor-capacitor transistor logic) HTL (high-thershold logic) TTL (transistor-transistor logic) ECL (emitter-compled logic) MOS logic (metal oxide semicondutor logic) C MOS (complementary MOS) Algumas das famílias acima citadas já estão obsoletas. As mais comumente encontradas são TTL, CMOS e ECL. OBS: A família encontrada no laboratório de Eletrônica do Departamento de Telecomunicações é a TTL. Principais características das famílias lógicas Uma família lógica é caracterizada por vários parâmetros, dos quais quatro se destacam: a) atraso de propagação e tempo de comutação b) dissipação de potência c) capacidade de saída Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais d) margens de ruído a) Atraso de propagação e tempo de comutação Atraso de propagação é o tempo requerido pela saída de uma porta para responder a uma mudança no nível lógico da entrada da porta (microssegundos e nanosegundos). Tempo de comutação é o tempo que uma porta leva para passar do estado 1 para o estado 0 ou vice-versa. b) Dissipação de potência Geralmente é possível melhorar a velocidade de operação (isto é, reduzir os tempos de a), sacrificando a potência. Como mais potência envolve mais correntes, as capacitâncias “parasitas” podem ser carregadas e descarregadas mais rapidamente. Estas capacitâncias parasitas não são introduzidas deliberadamente no circuito, mas são o resultado inevitável das dimensões e geometria do circuito. A disponibilidade de correntes maiores torna possível ligar e desligar as transistores mais rapidamente. Resta saber se o aumento de viabilidade compensa o sacrifício de potência. Produto velocidade X potência – produto do atraso de propagação pela dissipação de potência de uma porta. c) Capacidade de saída Fan-in – é o número total de entradas da porta lógica Fan-out – é o número que expressa a quantidade máxima de portas da mesma família que poderá ser conectada à saída de uma porta lógica. Uma fonte de um sinal digital aplicado à entrada de uma porta deve ser capaz de estabelecer naquela entrada uma ou outra tensão correspondente a um ou outro nível lógico. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Em qualquer um dos níveis a fonte deve satisfazer os requisitos de corrente da porta acionada. Como a saída de uma porta freqüentemente é usada como fonte para a entrada de outra porta é necessário conhecer o FAN-OUT desta porta. Portas lógicas apresentam uma impedância de saída. Ao conectar outras portas a esta, iremos diminuir cada vez mais a impedância de carga do bloco e, por conseguinte, drenaremos uma maior corrente do circuito, alterando assim mais características de limites de tensão de saída. d) Margem de ruído Níveis lógicos ≠ níveis de tensão Os níveis 1 e 0 não correspondem a 1V e 0V e sim a faixas de tensão específicas para cada família. O nível zero corresponde a uma faixa de tensão pequena, abaixo de um certo valor máximo. O nível um corresponde a uma faixa de tensão acima de um valor mínimo e abaixo de um valor máximo. Dentro deste conceito, os fabricantes especificam as seguintes tensões (de entrada e de saída): VOH – tensão de saída mínima que uma porta fornece quando na saída estiver em nível lógico 1. VOL – tensão de saída máxima que uma porta fornece quando na saída estiver um nível lógico 0. VIH – tensão mínima que pode ser aplicada à entrada de uma porta e reconhecida como nível 1. VIL – tensão máxima que pode ser aplicada à entrada de uma porta e reconhecida como nível 0. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 1.4 - Encapsulamento Os C.I. consistem fisicamente de uma pastilha (chip) sobre a qual os elementos lógicos reais são localizados, encapsulado num pacote com somente os pinos de conexão (leads) extendendo-se através da embalagem. Até uma determinada época, os C.I. eram encapsulados de um dos 2 modos abaixo: - flat pack - dual in lim package - DIP Flat pack – é o mais compacto e é destinado a ser permanentemente soldado no circuito impresso, geralmente de cerâmica. DIP – é mais resistente e pode ser encaixado em um soquete. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Hoje existem outras formas de encapsulamento. Este é um assunto para pesquisa dos alunos. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2- Circuitos Combinacionais Básicos 2.1- Padrão de Circuitos Combinacionais Qualquer circuito combinacional pode ser construído a partir dos seguintes passos: ⇒ identificação do problema (entradas e saídas) ⇒ construção da tabela verdade ⇒ obtenção da função (preferencialmente de forma minimizada) ⇒ representação por diagrama de portas Exemplo de padrão de circuitos combinacionais Ex: Construa um circuito capaz de produzir um nível alto na saída S, sempre que for aplicado à uma entrada uma combinação de bits – com 2 bits adjacentes iguais a zero (entrada de 4 bits). ⇒identificação do problema (entradas e saídas) A B C D Entradas S (saída) ⇒construção da tabela verdade 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 S 1 1 1 1 1 0 0 0 1 1 0 0 1 0 0 0 ⇒obtenção da função simplificada 00 01 11 10 00 01 11 10 1 1 1 1 1 1 1 1 S= AB+CD+BC Apenas com portas NOR: S = A B + C D + B C = A+B + C+D + B+C S = A+B + C+D + B+C Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais ⇒representação por diagrama de portas O diagrama de portas da função simplificada é obtido com 3 ANDs, 4 Inversores e 1 OR. Abaixo está desenhada a opção que monta o circuito usando apenas portas nor. 2.2- Somadores e Subtratores Os circuitos de somadores são bastante genéricos, podendo-se a partir deles obter a construção de subtratores e também multiplicadores. 2.2.1- Meio somador (Half-Adder) O primeiro circuito aritmético mais básico é o do meio somador (H.A.), pelo fato de poder realizar apenas a soma de dois bits. Neste caso, numa operação como a abaixo, o Meio Somador é o circuito que pode realizar apenas a soma de A0 com B0. C2 C1 C0 A = .......A3 A2 A1 A0 + B = .......B3 B2 B1 B0 C3 S3 S2 S1 S0 Partindo do padrão de circuitos combinacionais, os passos para a geração do Meio Somador são os seguintes: Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais ⇒identificação do problema A0 H.A. B0 ⇒ construção da tabela verdade S0 C0 (carry) ⇒obtenção da função S0 = A0B0 + A0B0 = A0 ⊕ B0 C0 = A0B0 ⇒representação por diagrama de portas ⇒Outra forma possível de representação por portas: A0 0 0 1 1 B0 0 1 0 1 S0 0 1 1 0 C0 0 0 0 1 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.2.2- Somador Inteiro (Full-Adder) Este circuito já é mais genérico, podendo realizar a soma de três bits quaisquer. C n-1 An Bn Cn Sn Seguindo todos os passos do padrão de circuitos combinacionais, tem-se: C n-1 Sn An F.A. Cn Bn An 0 0 0 0 1 1 1 1 B n C n-1 0 0 0 1 1 0 1 1 0 0 0 1 1 0 1 1 Sn 0 1 1 0 1 0 0 1 Cn 0 0 0 1 0 1 1 1 Geração de S n AnBn Cn-1 00 01 11 10 0 1 1 1 1 1 S n = A nB nC n-1 + A nB nC n-1 + A nB nC n-1 + A nB nC n-1 S n = A n (B nC n-1 + B nC n-1) + A n (B nC n-1 + B nC n-1) S n = A n (B n ⊕ C n-1) + A n (B n ⊕ C n-1) S n = A n ⊕ (B n ⊕ C n-1) S n = A n ⊕ B n ⊕ C n-1 OU EXCLUSIVO sempre gera a soma das variáveis Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais OBS: Toda vez que no Mapa de Karnaugh todas e somente as mesmas posições do Mapa, de nº ímpar de variáveis verdadeiras estiverem assinaladas tem-se uma EX-OR de todas as variáveis. Quando estiverem assinaladas todas as posições de nº par de variáveis verdadeiras tem-se uma EX-NOR de todas as variáveis. C C AB AB AB AB 1 1 1 1 ABC + ABC + ABC + ABC 1 3 1 0 2 2 2 AnBn Cn-1 00 01 11 10 0 1 1 1 1 1 C n = A nB n + A nC n-1 + B nC n-1 An Bn EX-OR ABC + ABC + ABC + ABC AB AB AB AB C 1 1 C 1 1 Geração de Cn: 1 Cn-1 Sn U1A U1B Cn EX-NOR Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.2.3- Somador Inteiro a partir de Meio somador Pelo circuito acima, verifica-se que ele é obtido através de 2 H.A. e mais algumas portas. Assim: An⊕Bn A nB n Entretanto, observando mais detalhadamente, percebe-se que para se ter estouro (carry), pelo menos duas variáveis precisam ser 1 e isto acontece quando An e Bn são 1 ou quando o carry de entrada e o resultado da soma de An e Bn também são 1. Logo: C n = (A n ⊕ B n) C n-1 + A nB n An 0 0 0 0 1 1 1 1 B n C n-1 A n ⊕ B n (A n ⊕ B n) C n-1 C n 0 0 0 0 0 0 1 0 0 0 1 0 1 0 0 1 1 1 1 1 0 0 1 0 0 0 1 1 1 1 1 0 0 0 1 1 1 0 0 1 E o circuito do F.A. pode ser construído da forma mais reduzida abaixo. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais An⊕Bn A nB n (A n ⊕ B n) C n-1 2.2.4- Somador de 4 bits Utilizando blocos somadores inteiros, um somador para 2 nos binários de 4 bits, corresponde a: C2 C1 C0 A3 A2 A1 A0 + B3 B2 B1 B0 C3 S3 S2 S1 S0 A3 B3 C3 F.A. A2 B2 C2 F.A. A1 B1 C1 S3 S2 Este somador de 4 bits é encontrado em F.A. A0 B0 C0 S1 A F.A. S0 B forma de CI, de número 7483. 7483 7483 S Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Se forem utilizados 2 CI´s 7483, pode-se obter um somador para 2 nos binários de 8 bits cada um. B7 B6 B5 B4 S8 A7 A6 A5 A4 B3 B2 B1 B0 7483 A3 A2 A1 A0 7483 S7 S6 S5 S4 S3 S2 S1 S0 2.2.5- Complementador a 2 De acordo com a análise feita na Parte 1 da Apostila, item 2.2, a subtração pode ser gerada a partir da soma do minuendo com o complemento do subtraendo. Para tal, já que o somador já está definido, resta gerar o circuito que realiza o complemento. Se a subtração for realizada com a técnica de complemento a 2, o circuito a ser gerado é o do Complementador a 2 que é um circuito combinacional e, como tal, pode ser construído da forma padrão abaixo: B3 B2 B1 B0 C3 Complementador a2 C2 C1 C0 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais B3 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 B2 0 0 0 0 1 1 1 1 0 0 0 0 1 1 1 1 B1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 B0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 C3 0 1 1 1 1 1 1 1 1 0 0 0 0 0 0 0 C2 0 1 1 1 1 0 0 0 0 1 1 1 1 0 0 0 C1 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 C0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 B3B2 00 B1B0 00 01 1 11 1 10 1 01 11 10 1 1 1 1 1 C3 = B3B2 + B3B0 + B3B1 + B3B2B1B0 C3 = B3 (B0 + B1 + B2) + B3 (B0 + B1 + B2) C3 = B3 ⊕ (B0 + B1 + B2) B3B2 B1B0 00 01 11 10 00 01 11 10 1 1 1 1 1 1 1 1 C2 = B2B1B0 + B2B0 + B2B1 C2 = B2 (B1 + B0) + B2 (B1 + B0) C2 = B2 ⊕ (B1 + B0) B3B2 B1B0 00 01 11 10 00 01 1 1 1 1 11 10 1 1 1 1 B3B2 B1B0 00 01 11 10 00 01 1 1 1 1 11 1 1 1 1 10 C1 = B1B0 + B1B0 C1 = B1 ⊕ B0 C0 = B0 Nem precisava ter feito, era só olhar para a tabela. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais C3 = B3 ⊕ (B0 + B1 + B2) C2 = B2 ⊕ (B0 + B1) C1 = B1 ⊕ B0 C0 = B0 B3 ⊕ (B0 + B1 + B2) B3 B2 C3 B0 + B1 + B2 B2 ⊕ (B0 + B1) B1 C2 B0 + B1 B1 ⊕ B0 B0 C1 C0 Outro modo possível de viabilizar o complemento a 2 é aplicando a regra prática de complemento a 2. B3 B2 B1 B0 C0 = B0 C3 C2 C1 C0 C1 = B1B0 + B1B0 Se B0 for 1, C1 = B1 e se B0 = 0 C1 = B1 C1 = B1 ⊕ B0 C2 = B2B1B0 + B2B0 + B2B1 Se B0 = B1 = 0 então C2 = B2 Se B0 = 1, C2 vai ser igual a B2 Se B1 = 1, C2 vai ser igual a B2 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais C3 = B3B2 + B3B0 + B3B1 + B3B2B1B0 Solução para o complemento de um número de n bits: C n = B n ⊕ (B n-1 + B n-2 + ... + B1 + B0) Uma terceira solução é utilizando o postulado matemático que diz: Cb = Cb-1 + 1 Logo: C2 = C1 + 1 C2 = inversor e soma com 1 2.2.6- Subtrator de 4 bits em C2 Considerando Minuendo ≥ Subtraendo Conforme já visto anteriormente, sempre vai ocorrer estouro quando for feita a soma do minuendo com o complemento a 2 do subtraendo, estouro este que poderá ser desprezado para representação do resultado da subtração. Ex: 5 – 3 = 5 + C23 = R M - S = M + C2S=R Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Circuito este que obviamente pode ser simplificado para: Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Considerando Minuendo < Subtraendo Neste caso, jamais vai haver estouro e o resultado da soma do minuendo com o complemento a 2 do subtraendo deve passar por novo complemento, se o objetivo for o de se obter a real magnitude da subtração. (OBS: Em uma operação de subtração realizada internamente no computador, o resultado é apresentado em SMC2, logo se o resultado é negativo, ele vai permanecer complementado a 2). * A figura abaixo tem um erro. Qual será ? Considerando o caso geral Observa-se que a diferença entre os circuitos acima, que tratam separadamente das subtrações para M > S e M ≤ S, está na necessidade de efetuar o segundo complemento a 2 ou não. Esta situação é identificada a partir do fato de ter ou não ocorrido estouro.Um circuito combinacional que atende a esta idéia de efetuar o complemento a 2 ou não a partir de um determinado comando é o circuito True / Complement, onde a saída corresponde à própria entrada ou ao complemento a 2 da mesma. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Aplicando a proposta do circuito True / Complement para o caso do subtrator genérico de 4 bits, chega-se ao seguinte circuito: Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Ampliando esta idéia, pode-se construir o circuito de um somador / subtrator genérico, para 4 bits, operando em C2, com uma variável de controle para selecionar qual a operação que se deseja realizar. Y = 5º bit da soma ou sinal da subtração Pequenas lógicas internas: C 0 0 1 1 C4 0 1 0 1 Cx 0 0 0 1 Y 0 1 1 0 Cx = C. C4 (Controle do segundo True / Complement) Y = C ⊕ C4 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.2.7- Subtrator de 4 bits em C1 Seguindo a mesma linha de raciocínio adotada para a construção das diversas etapas do subtrator em C2 e analisando a teoria de subtração com a técnica em C1, os diversos circuitos de subtrator de 4 bits em C1 e somador / subtrator em C1 são os abaixo apresentados. Subtrator binário para 2 números de 4 bits, operando em C1 e considerando M > S. (sempre vai ocorrer estouro, que deverá ser somado ao resultado) Subtrator acima, considerando M ≤ S * O Circuito abaixo tem um erro. Qual será ? Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Subtrator geral de 4 bits em C1 Somador / subtrator genérico em C1. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.2.8- ULA – Unidade Lógica e Aritmética A ULA é um circuito lógico inteiramente combinacional (isto é, consiste em portas sem realimentação e sem flip-flops) Ela torna disponível em um único chip a realização de diferentes operações lógicas e aritméticas, como soma, subtração, incremento, ou, e, ou-exclusivo, etc... A operação de uma ULA típica (de 4 bits) é a seguinte: A0, A1, A2, A3 e B0, B1, B2, B3 -> entradas Cn -> carry de entrada (indica vai-um no nível 0) M -> função lógica (1) ou aritmética (0) F0, F1, F2, F3 -> saídas Cn+4 -> carry de saída (indica se vai-um no nível 0) S0, S1, S2, S3 -> seleção de função Quando a unidade é utilizada para soma e a velocidade é importante, pode-se ligar na unidade (ULA) a VUA (vai-um antecipado), normalmente aplicada em computadores de grande porte. Esta adaptação com a VUA visa reduzir a séria limitação de velocidade que resulta no fato de o vai-um ter que se propagar, em seqüência, através de um somador após o outro. Para aumentar a velocidade dos somadores, aplica-se o princípio do vai-um antecipado. Neste método, antecipa-se quando e onde um vai-um seria gerado e circuitos adicionais são usados para gerar o vai-um mais diretamente do que através da propagação do vai-um vindo de estágios anteriores. 2.3- Circuitos Conversores de Código Freqüentemente, informação disponível em forma codificada deve ser traduzida para um código diferente. O circuito lógico que realiza esta tradução é chamado de conversor de código. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.3.1- Apresentação de alguns códigos De modo geral, os códigos podem ser classificados em: Ponderados -> Peso Ordenados ⇒ Códigos Ponderados: a) Binário Natural ou código 8421 B3 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 B2 0 0 0 0 1 1 1 1 0 0 0 0 1 1 1 1 B1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 B0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 é a contagem natural em binário 15 OBS: Existe a possibilidade de fazer a representação da um dígito decimal usando sempre 4 bits. Nesse caso, o código gerado é um caso específico do binário natural, já que com 4 bits não é possível representar os correspondentes decimais de 10 a 15, nem qualquer outro acima destes. Este código é chamado BCD ou NBCD. BCD – Decimal Codificado em Binário 1985 0001 1001 1000 0101 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais BCD em 8421 ou NBCD 8 0 0 0 0 0 0 0 0 1 1 0 0 0 1 0 4 0 0 0 0 1 1 1 1 0 0 0 2 0 0 1 1 0 0 1 1 0 0 0 1 0 1 0 1 0 1 0 1 0 1 0 0 Igual ao binário natural 9 10 b) Outros códigos ponderados: 7421, 2421, 5211, etc... - o código 8421 é o único que não apresenta multiplicidade de solução para um mesmo número. Ex: 4 0 0 0 0 0 1 0 1 0 3 0 0 0 1 0 0 1 0 1 2 0 0 1 0 1 0 0 0 1 1 0 1 0 0 1 0 1 1 0 3 4 5 ⇒ Códigos Ordenados: c) Códigos Gray - a principal característica é que de um nº a outro (anterior ou posterior) apenas varia um bit. No código Gray, os 2 primeiros correspondentes decimais a zero e um são representados normalmente. Os dois nos seguintes, são expressos do seguinte Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais modo: um “espelho” representado por uma linha tracejada é colocada debaixo dos primeiros 2 bits, gerando uma reflexão destes. Depois o dígito 0 é acrescentado acima do espelho e o dígito 1 é acrescentado abaixo do espelho e assim sucessivamente. Gray Natural 0 0 0 0 0 0 0 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 1 0 1 0 1 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 1 1 1 1 0 1 0 1 0 1 0 1 1 1 0 0 1 1 0 0 0 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 0 0 0 0 0 0 0 0 1 1 Gray BCD 0 0 0 0 0 1 0 1 1 1 1 1 1 0 1 0 1 0 1 0 0 1 1 0 0 1 1 0 0 1 Mapa de Karnaugh para Gray Natural O código Gray é o código utilizado para construção do Mapa de Karnaugh e é por este motivo que quando a numeração dos quadrículos no Mapa, é feita através do código binário, ela não segue uma seqüência correta. Já, se a numeração fosse realizada utilizando o código Gray, os quadrículos seriam numerados seqüencialmente, conforme pode ser observado abaixo: 00 01 11 10 00 0 1 2 3 01 7 6 5 4 11 8 9 10 11 10 15 14 13 12 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais d) Código excesso 3 – Ex-3 NBCD - é a transformação do nº decimal no binário correspondente, somando-se a este três unidades. N 0 0 0 0 0 0 0 0 1 1 B 0 0 0 0 1 1 1 1 0 0 C 0 0 1 1 0 0 1 1 0 0 D 0 1 0 1 0 1 0 1 0 1 0 1 2 3 4 5 6 7 8 9 Ex-3 NBCD 0 0 1 1 0 1 0 0 0 1 0 1 0 1 1 0 0 1 1 1 1 0 0 0 1 0 0 1 1 0 1 0 1 0 1 1 1 1 0 0 É interessante por 2 motivos: - Porque não aparece 0000 e 1111, que podem ser confundidos com linha aberta, ou curto-circuito. - é auto-complementar a 9. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.3.2- Exemplo de Conversores de código Ex: 1) Projete um conversor de NBCD -> Gray BCD B3 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 NBCD B2 B1 0 0 0 0 0 1 0 1 1 0 1 0 1 1 1 1 0 0 0 0 0 1 0 1 1 0 1 0 1 1 1 1 B0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 Gray BCD G3 G2 G1 G0 0 0 0 0 0 0 0 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 1 0 1 0 1 0 1 0 0 1 1 0 0 1 1 0 1 irrelevantes G3 = B3 G2 = B3 + B2 G1 = B2 ⊕ B1 G0 = B1 ⊕ B0 G3 00 01 11 10 00 X 1 01 X 1 11 X X 10 X X G2 00 01 11 10 00 1 X 1 01 1 X 1 11 1 X X 10 1 X X G1 00 01 11 10 00 1 X 01 1 X 11 1 X X 10 1 X X G0 00 01 11 10 00 X 01 1 1 X 1 11 X X 10 1 1 X X 2) Projetar um conversor de Gray BCD para NBCD Gray BCD G3 G2 G1 G0 0 0 0 0 0 0 0 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 1 0 1 0 1 0 1 0 0 1 1 0 0 1 1 0 1 B3 0 0 0 0 0 0 0 0 1 1 NBCD B2 B1 0 0 0 0 0 1 0 1 1 0 1 0 1 1 1 1 0 0 0 0 B3 = G3 B0 0 1 0 1 0 1 0 1 0 1 B2 = G3 ⊕ G2 ou B2 = G3 G2 -> sem usar o irrelevante B2 00 01 11 10 00 1 X 01 1 X 11 1 X X 10 1 X X Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais B1 00 01 11 10 00 1 X 01 1 X 11 1 X X 10 1 X X B1 = G2 G1 + G3 G2 G1 B1 = G3 G2 G1 + G3 G2 G1 = G3 (G2 ⊕ G1) Sem usar o irrelevante Os irrelevantes agora são a continuação da tabela GRAY B0 00 01 11 10 00 1 X 01 1 1 X 11 1 X X 10 1 X X B0 = G3 ⊕ G2 ⊕ G1 ⊕ G0 (todas as posições com nº ímpar de variáveis _______ ) 3) Projetar um conversor GRAY ⇔ NBCD selecionável. Arbitrar que C = 0 -> converte de GRAY para BCD C = 1 -> converte de BCD para GRAY C Y3 Y2 Y1 Y0 X3 X2 X1 X0 B3 = G3 ∴ X3 = Y3 B2 00 01 11 10 00 1 X 01 1 X 11 1 X X 10 1 X X G2 00 01 11 10 00 1 X 1 01 1 X 1 11 1 X X 10 1 X X B1 00 01 11 10 00 1 X 01 1 X 11 1 X X 10 1 X X B0 00 01 11 10 00 1 X 01 1 1 X 11 1 X X 10 1 X X G1 00 01 11 10 00 1 X 01 1 X 11 1 X X 10 1 X X G0 00 01 11 10 00 X 01 1 1 X 1 11 X X 10 1 1 X X Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais X2 = Y3Y2 + Y3Y2 X1 = Y3Y2Y1 + Y3Y2Y1 X2 = Y2 ⊕ Y3 X1 = Y3 (Y1 ⊕ Y2) B0 = G3 ⊕ G2 ⊕ G1 ⊕ G0 G0 = B1 ⊕ B0 X0 = (Y1 ⊕ Y0)C + (Y3 ⊕ Y2 ⊕ Y1 ⊕ Y0)C X0 = Y1 ⊕ Y0 ⊕ (Y3 ⊕ Y2)C X3 Y3 X2 Y2 Y1 X1 Y0 X0 C Outra solução mais simples para X0: C Y3 Y2 Y1 Y0 X0 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 4) Conversor BCD para 7 segmentos Utilização do Decoder/Driver – 9368 e do Display de 7 segmentos FND 500 FND 560 A Display de 7 segmentos: F E - G D B C Geralmente cada filamento é um LED. Só conduz quando polarizado diretamente Conversor BCD/7 segmentos Cada segmento do display O projeto do conversor BCD para 7 segmentos é objeto de exercício para o aluno. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.4- Codificadores / Decodificadores São circuitos que efetuam a passagem de um determinado código para outro assim como os conversores de código, porém eles possuem características específicas. 2.4.1- Decodificadores Os decodificadores constituem um tipo de conversor de código que apresentam a característica de que para cada entrada, somente uma saída é ativada. Isto significa que uma das saídas sempre será diferenciada das outras. (Ex.: uma saída estará em nível lógico 1 e as outras estarão em 0, ou vice-versa). O decodificador é composto apenas por portas AND, se cada saída for ativada através de nível lógico 1. Decodificador 1 alto de N (endereçados) Este circuito possui N saídas, das quais uma (a selecionada) sempre em 1 (nível lógico alto) e as demais em 0 (nível lógico baixo). Ex.: 1 alto de 2 C 0 1 X1 X0 0 1 1 0 1 =C 0 =C x x Ex.: 1 alto de 4 C1 C0 X3 X2 X1 X0 0 0 0 0 0 1 0 1 0 0 1 0 1 0 0 1 0 0 1 1 1 0 0 0 Para facilitar, o endereçamento é feito para a variável de número igual ao valor de controle. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Ex.: C1C0 à 10 (=2) — endereça a saída X2. 0 = c1.c 1 = c1.c0 2 = c1 .c0 3 = c1 . c0 x x x x 0 0 1 10 Decoder 7442 — trabalha de forma análoga porém inversa. Trata-se de um decodificador 1 baixo de 10, a saída é endereçada através de um zero. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.4.2- Codificadores Os codificadores executam a função inversa em relação aos decodificadores; isto é, operam com códigos de entrada que têm a característica de, em qualquer momento, apresentar uma entrada com nível lógico diferente de todas as demais. Muitas vezes as entradas de um codificador são as saídas de um decodificador. Ex.: (arbitrariamente) I0 I1 I2 A3 1 1 1 0 1 1 A2 1 1 0 A1 0 0 1 A0 1 1 1 Considerando que o código de entrada acima, só tem cada variável verdadeira em uma única situação e todas as demais combinações em que esta variável pudesse ser verdadeira são irrelevantes (já que não existem), as funções de saída poderão ser constituídas apenas por portas OU, como apresentado abaixo: A3c = I0c + I2C A2c = I0c + I1c A1c = I2c A0c = I0c + I1c + I2c 2.4.3- Conversor de Código a partir de Decodificador/Codificador Uma outra maneira de se gerar um conversor de código, sem seguir os passos de um circuito combinacional padrão, é fazendo uma associação de decodificador com codificador. Neste caso, em uma conversão de um código A para um outro código B, escolhe-se um código intermediário C, onde apenas uma variável seja diferenciada das demais, a cada instante, que fará o papel de decodificador, de A para C e de codificador de C para B. Se o código C escolhido tiver apenas uma variável verdadeira, a cada instante, o circuito será constituído de um conjunto de and’s (decodificador) associado a um conjunto de or’s (codificador). Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.5- Multiplexadores / Demultiplexadores 2.5.1- Multiplexadores Os multiplexadores são circuitos que podem ser aplicados de duas maneiras distintas: • Como seletores de canal • Como geradores de função 2.5.1.1- Mux como Seletor de Canal O multiplexador, como seletor de canal, é utilizado para selecionar dentre várias entradas uma para ser ligada à saída. Uma chave de n posições controlável que permite a passagem de somente uma entrada para a saída representa bem a função do multiplexador: (Ex.: seletor de canal de televisões antigas). I . . . I 8 SELEÇÃO Estrutura lógica de um MUX de 2 canais por 1 linha: 0 è X=A0 Ch 1 è X=A1 A1 A0 Ch X 0 0 0 0 0 0 1 0 0 1 0 1 0 1 1 0 1 0 0 0 1 0 1 1 1 1 0 1 1 1 1 1 A1 A0 00 Ch 0 1 X = 01 10 11 1 1 1 1 A0 .Ch + A1 . Ch Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Estrutura lógica de um MUX 4 canais por 1 linha. 4 entradas requerem 2 bits para selecionar Estrutura lógica de um MUX 4 canais por 2 linhas – MUX 4 x 2 (utilizado para um endereçamento de palavras com n bits — no caso a seguir, n=2 —, palavra esta situada em um único endereço). S1 S0 0 0 0 1 1 0 1 1 B0 B1 B2 B3 A0 A1 A2 A3 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Estrutura lógica de um MUX 16 canais por 1 linha (a partir de MUX’s 4x1) Canais 0a3 Servirão como entradas de seleção mais significativas (S3 S2) 678 Canais 4a7 Canais 8 a 11 Y= A0 à S3S2S1S0 = 0000 Y= X2 à S3S2S1S0 = 1000 (canal 8) Canais 12 a 15 Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais MUX 4x1 (74153 do laboratório) (efetivamente sua construção é de um MUX 4x2) • 1G e 2G • • terminais de controle — ENABLE (habilita). Ativas quando em baixa. Permite saída tri-state. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.5.1.2- Mux como Gerador de Função O Multiplexador pode ser usado não só para selecionar uma linha dentre um número de linhas, mas também para gerar uma função lógica arbitrária de “variáveis selecionáveis”. Ou seja, pode ser utilizado para montar qualquer circuito combinacional. Para isto, basta gerar a tabela verdade do circuito que se deseja. Voltando ao MUX original 4x1 G0 G1 G2 G3 Supondo que não existissem as linhas de entrada I0 – I3. neste caso as linhas de entrada de seleção das portas AND seriam exatamente as necessárias para gerar todos os mintermos das variáveis S1S0. A porta G0 gera m0 ( S 1.S 0 ), a porta G1 gera m1 ( S 1. S 0 ), etc. Pensando agora nas entradas I0,... , I3 como entradas habilitadoras. Se I0=0 a saída de G0 será 0 independente de S0 e S1, no entanto se I0=1, a saída G0 será igual a S 1.S 0 e assim sucessivamente. Assim, as quatro portas AND habilitadas pelas entradas correspondentes I0, ..., I3 geram os quatro mintermos das variáveis de seleção e a saída lógica é a soma lógica dos mintermos selecionados. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Ex: Gerar com um MUX 8x1, a função W = B.C. + A.B.C + A.B.C W = B.C.( A + A) + A.B.C + A.B.C W = AB.C. + ABC + A.B.C + A.B.C { { { { m7 m3 m2 m4 Com um MUX 8x1 (formado a partir de 4x1’s) W= Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais Pensando nas variáveis B e C como entradas de seleção e A como uma variável livre, é possível gerar a mesma função W a partir de um MUX 4 x 1. Centro Tecnológico Escola de Engenharia Departamento de Engenharia de Telecomunicações Técnicas Digitais I / Circuitos Digitais 2.5.2- Demultiplexadores O DEMUX proporciona o direcionamento de um dado de entrada para a entre n linhas de saída. Demux 1x4 Situação que serve como exemplo: 5 linhas telefônicas; de acordo com o endereço selecionado a origem vai se interligar com 1 dos 4 destinatários. A estrutura é similar a de um decodificador com a modificação que cada porta tem uma entrada adicional, que é a mesma para todas as portas. Dependendo do endereço requerido pelos bits de endereço S1S0, o dado de entrada será dirigido a um ou outro destino. Filosoficamente, o decodificador e o DEMUX são bem diferentes, já que o primeiro tem como objetivo principal distinguir uma saída das demais, enquanto que o último, objetiva direcionar o dado de entrada para uma das saídas, permitindo inclusive, que todas as saídas tenham o mesmo valor lógico.