Componentes Digitais
Aqui iremos alguns dos inúmeros componentes combinacionais (não precisam de clock) que são utilizados no desenvolvimento de circuitos digitais e que serão usados na disciplina.
portas lógicas
S <= A and B;
S <= A nand B; S <= not (A and B)
S <= A or B;
S <= A nor B; S <= not (A or B);
S <= A xor B;
S <= (not A);
S = A and B
S = not (A and B)
S = A or B
S = not (A or B)
S = A ^ B
S = not B
Multiplexado (mux)
fonte wikipedia: Schematic of a 2-to-1 Multiplexer. It can be equated to a controlled switch.
entity mux is port(
in0 : in std_logic;
in1 : in std_logic;
sel : in std_logic;
o : out std_logic);
end entity;
@block
def mux2Way(in0, in1, sel, o):
@always_comb
def comb():
if sel == 0:
o.next = in0
else:
o.next = in1
return comb
O mux como é chamado o Multiplexador é um componente que possui n
entradas e uma saída q
, um sinal chamado de seletor sel
seleciona qual entrada irá ser copiada para a saída.
As entradas n
e a saída q
podem ser binárias ou vetor de tamanho m
.
A seguir uma tabela verdade para um mux
de 2 entradas:
in 0 | in 1 | Sel | out |
---|---|---|---|
1 | X | 0 | 1 |
X | 0 | 1 | 0 |
0 | X | 0 | 0 |
X | 1 | 1 | 1 |
Note
A tabela verdade do mux de 2 entradas possuir 2^3 linhas (o seletor conta como entrada), totalizando 8 linhas. Porém para simplificar, utilizamos o X
que significa tanto faz (0
ou 1
), logo cada linha que possui X
seria expandida para duas linhas.
Tip
O tamanho do seletor deve ser um numero inteiro: \(log2(size(n))\).
| Quantidade de entras | Tamanho do seletor |
| ------------------- | ------------------ |
| 2 | 1 |
| 3 | 2 |
| 4 | 2 |
| 5 | 3 |
| 8 | 3 |
Demutiplexador (demux)
É similar com o mux só que possui uma entrada in
e n
saídas q
, o demux conecta a entrada a alguma das saídas, sendo controlado pelo seletor.
fonte wikipedia: Schematic of a 1-to-2 Demultiplexer. Like a multiplexer, it can be equated to a controlled switch.
entity demux is
port(
in0 : in std_logic;
sel : in std_logic;
out0 : out std_logic;
out1 : out std_logic
);
end entity;
@block
def deMux2Way(in0, sel, out0, out1):
@always_comb
def comb():
if sel == 0:
out0.next = a
out1.next = 0
else:
out0.next = 0
out1.next = a
return comb
A entrada in
e a saída q
podem ser binárias ou de vetorer de tamanho m
.
A seguir uma tabela verdade para um demux
de 2 saídas:
in | Sel | out 0 | out 1 |
---|---|---|---|
1 | 0 | 1 | 0 |
1 | 1 | 0 | 1 |
0 | 1 | 0 | 0 |
0 | 0 | 0 | 0 |
Enconders
Enconders são componentes que codificam uma entrada em uma saída de outro formato, algum exemplos são:
- BCD
- Gray code
- SevenSeg
- Priority Encoder
BCD
Binary-coded decimal
(BCD) é uma forma de codificação de números inteiros em binário na qual utiliza-se para cada dígito de um número inteiro, 4 bits em binário.
Decimal Number | BCD 8421 Code |
---|---|
0 | 0000 0000 |
01 | 0000 0001 |
02 | 0000 0010 |
03 | 0000 0011 |
04 | 0000 0100 |
05 | 0000 0101 |
06 | 0000 0110 |
07 | 0000 0111 |
08 | 0000 1000 |
09 | 0000 1001 |
10 (1+0) | 0001 0000 |
11 (1+1) | 0001 0001 |
12 (1+2) | 0001 0010 |
continua | em blocos de 4 |
|-----------|
| | out1[3..0]
x[n..0] | Binary |-----/-------->
----/------>| to | ....
| BCD | outm[3..0]
| |-----/-------->
|-----------|
entity binaryToBCD is
port(
x : in std_logic(4 downto 0);
out0 : out std_logic_vector(3 downto 0); -- Unidade
out1 : out std_logic_vector(3 downto 0) -- Dezena
);
end entity;
@block
def binaryToBCD(x, out0, out1):
@always_comb
def comb():
...
return comb
Tip
O maior valor que um bloco de 4 bits do BCD assume é o 1001
que é referente ao número inteiro 9.
O BCD é bastante utilizado para o controle de displays de 7 segmentos, como demonstrado na figura a seguir que usa o chip
Código Gray
O código gray é uma forma de codificar números binários, nessa codificação apenas um bit muda por vez.
Código decimal | Código Binário | Código Gray |
---|---|---|
0 | 0000 | 0000 |
1 | 0001 | 0001 |
2 | 0010 | 0011 |
3 | 0011 | 0010 |
4 | 0100 | 0110 |
5 | 0101 | 0111 |
6 | 0110 | 0101 |
7 | 0111 | 0100 |
8 | 1000 | 1100 |
9 | 1001 | 1101 |
10 | 1010 | 1111 |
11 | 1011 | 1110 |
12 | 1100 | 1010 |
13 | 1101 | 1011 |
14 | 1110 | 1001 |
15 | 1111 | 1000 |
Note
Esse sistema era muito utilizado antigamente quando relés eram utilizados no lugar de transistor, em um contador binário comum ocorre de muitos bits mudarem de uma única vez (0111 -> 1000) isso gerava um pico de corrente elétrica e muito ruído.
Tip
Utilizamos o código Gray para montar o Mapa de Karnaugh
Comparador
Comparadores são componentes que podem possuir diversos atributos, tais como comparar:
- se duas entradas são iguais
- se a entrada A é maior que entrada B
- se entrada A é igual a zero
- ...
A seguir um exemplo de um comparador que possui apenas uma entrada x[1..0]
e compara se essa entrada é igual a zero (x == 0
), ou maior que zero (x > 0
).
x (inteiro) | x binário | eq | gt |
---|---|---|---|
0 | 00 | 1 | 0 |
1 | 01 | 0 | 1 |
-1 | 11 | 0 | 0 |
-2 | 10 | 0 | 0 |
|-----------|
| | eq
x[1..0] | |---------->
----/------>| comparador|
| | gt
| |---------->
|-----------|
entity COMPARADOR is
port(
x : in std_logic_vector(1 downto 0);
eq : out std_logic;
gt : out std_logic
);
end entity;
@block
def binaryToBCD(x, eq, gt):
@always_comb
def comb():
gt = 1 if x > 0 else 0
eq = 1 if x == 0 else 0
return comb
Somadores
Os somadores são componentes que realizam a soma de dois números binários, eles podem ser construídos de diversas maneiras.
in0[1..0] |-----------|
----/------>| |
| | out[2..0]
| ADDER |-----/----->
in1[1..0] | |
----/------>| |
|-----------|
entity ADDER is
port(
in0 : in std_logic(1 downto 0);
in1 : in std_logic(1 downto 0);
o : out std_logic_vector(2 downto 0)
);
end entity;
@block
def adder(in1, in2, o):
@always_comb
def comb():
o = in1 + in2
return comb
Um somador de dois vetores de dois bits cada possui o seguinte comportamento:
in0 | in1 | out |
---|---|---|
00 | 00 | 000 |
00 | 01 | 001 |
01 | 01 | 010 |
10 | 01 | 011 |
10 | 11 | 101 |
11 | 11 | 110 |