

# Learn Git and GitHub without any code!

Using the Hello World guide, you'll start a branch, write comments, and open a pull request.

Read the guide



17.02.2021 15:27

| Dec.<br>equivalent | B[1:0] | A[1:0] | B is greater<br>than A | B equals<br>A | B is less<br>than A |
|--------------------|--------|--------|------------------------|---------------|---------------------|
| 4                  | 0 1    | 0 0    | 1                      | 0             | 0                   |
| 5                  | 0 1    | 0 1    | 0                      | 1             | 0                   |
| 6                  | 0 1    | 1 0    | 0                      | 0             | 1                   |
| 7                  | 0 1    | 11     | 0                      | 0             | 1                   |
| 8                  | 10     | 0 0    | 1                      | 0             | 0                   |
| 9                  | 1 0    | 0 1    | 1                      | 0             | 0                   |
| 10                 | 1 0    | 10     | 0                      | 1             | 0                   |
| 11                 | 10     | 11     | 0                      | 0             | 1                   |
| 12                 | 11     | 0 0    | 1                      | 0             | 0                   |
| 13                 | 11     | 0 1    | 1                      | 0             | 0                   |
| 14                 | 11     | 10     | 1                      | 0             | 0                   |
| 15                 | 11     | 1 1    | 0                      | 1             | 0                   |

## 2-bit Comparator



### **4-bit Comparator**

#### design.vhd

```
______
 library ieee;
 use ieee.std_logic_1164.all;
 ______
 -- Entity declaration for 4-bit binary comparator
 entity comparator_4bit is
    port(
               : in std_logic_vector(4 - 1 downto 0);
       a_i
                         : in std logic vector(4 - 1 downto 0);
       -- vektor dvou vodicu
       B_less_A_o : out std_logic;
                               -- B is less than A
      B_equals_A_o : out std_logic; -- B equals A
       );
 end entity comparator_4bit;
 -- Architecture body for 4-bit binary comparator
 ______
 architecture Behavioral of comparator_4bit is
 begin
    B_{ess}A_o \leftarrow (1' \text{ when } (b_i < a_i) \text{ else '0'};
    B_{equals} = (b_i = a_i) else (0);
    B_greater_A_o <= '1' when (b_i > a_i) else '0';
 end architecture Behavioral;
testbench.vhd
 library ieee;
 use ieee.std_logic_1164.all;
 ______
 -- Entity declaration for testbench
 -----
 entity tb_comparator_4bit is
    -- Entity of testbench is always empty
 end entity tb_comparator_4bit;
```

```
-- Architecture body for testbench
______
architecture testbench of tb_comparator_4bit is
   -- Local signals
   signal s_a : std_logic_vector(4 - 1 downto 0);
                : std_logic_vector(4 - 1 downto 0);
   signal s_b
   signal s_B_greater_A : std_logic;
   signal s_B_equals_A : std_logic;
   signal s_B_less_A : std_logic;
begin
   -- Connecting testbench signals with comparator_4bit entity (Unit Under Te
   uut_comparator_4bit : entity work.comparator_4bit
       port map(
           a_i
                      => s_a,
                      => s_b,
           bі
           B_greater_A_o => s_B_greater_A,
           B_equals_A_o => s_B_equals_A,
           B_less_A_o => s_B_less_A
       );
   -- Data generation process
   ______
   p_stimulus : process
   begin
       -- Report a note at the begining of stimulus process
       report "Stimulus process started" severity note;
       -- First test values
       s_b <= "0000"; s_a <= "0000"; wait for 100 ns;
       -- Expected output
       assert ((s_B_greater_A = '0') and (s_B_equals_A = '1') and (s_B_less_A
       -- If false, then report an error
       report "Test failed for input combination: 0000, 0000" severity error;
       s_b <= "0000"; s_a <= "0001"; wait for 100 ns;
       -- Expected output
       assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
       -- If false, then report an error
       report "Test failed for input combination: 0000, 0001" severity error;
       s_b <= "0000"; s_a <= "0010"; wait for 100 ns;
       -- Expected output
       assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
       -- If false, then report an error
       report "Test failed for input combination: 0000, 0010" severity error;
       s b <= "0000"; s a <= "0011"; wait for 100 ns;
       -- Expected output
```

```
assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
        -- If false, then report an error
        report "Test failed for input combination: 0000, 0011" severity error;
        s_b <= "0000"; s_a <= "0100"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
        -- If false, then report an error
        report "Test failed for input combination: 0000, 0100" severity error;
        s_b <= "0000"; s_a <= "0101"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
        -- If false, then report an error
        report "Test failed for input combination: 0000, 0101" severity error;
        s_b <= "0000"; s_a <= "0110"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
        -- If false, then report an error
        report "Test failed for input combination: 0000, 0110" severity error;
        s_b <= "0000"; s_a <= "0111"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
        -- If false, then report an error
        report "Test failed for input combination: 0000, 0111" severity error;
        s_b <= "0000"; s_a <= "1000"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '0') and (s_B_equals_A = '1') and (s_B_less_A
        -- If false, then report an error
        report "Test failed for input combination: 0000, 1000" severity error;
        s_b <= "0000"; s_a <= "1001"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '0') and (s_B_equals_A = '0') and (s_B_less_A
        -- If false, then report an error
        report "Test failed for input combination: 0000, 1001" severity error;
        -- WRITE OTHER TESTS HERE
        -- Report a note at the end of stimulus process
        report "Stimulus process finished" severity note;
        wait;
    end process p_stimulus;
end architecture testbench;
```

#### Console error:

```
[2021-02-17 08:53:38 EST] ghdl -i design.vhd testbench.vhd && ghdl -m tb_comparator_4bit && ghdl -r tb_comparator_4bit --vcd=dump.vcd && sed -i 's/^U/X/g; s/^-/X/g; s/^H/1/g; s/^L/0/g' dump.vcd analyze design.vhd analyze testbench.vhd elaborate tb_comparator_4bit testbench.vhd:51:9:@0ms:(report note): Stimulus process started testbench.vhd:105:9:@900ns:(assertion error): Test failed for input combination: 0000, 1000 testbench.vhd:119:9:@1us:(report note): Stimulus process finished Finding VCD file...
./dump.vcd
[2021-02-17 08:53:39 EST] Opening EPWave...
Done
```

### **EDA** playground link

6 z 6