#### ☐ Ivo-Toceny-222683 / Digital-electronics-1





# 0. part - Link to GitHub repository

My GitHub 02-logic repository

README.md

# 1. part - Binary comparator truth table

| Dec.<br>equivalent | B[1:0] | A[1:0] | B is greater than | B equals<br>A | B is less than<br>A |
|--------------------|--------|--------|-------------------|---------------|---------------------|
| 0                  | 0 0    | 0 0    | 0                 | 1             | 0                   |
| 1                  | 0 0    | 0 1    | 0                 | 0             | 1                   |
| 2                  | 0 0    | 1 0    | 0                 | 0             | 1                   |
| 3                  | 0 0    | 11     | 0                 | 0             | 1                   |
| 4                  | 0 1    | 0 0    | 1                 | 0             | 0                   |
| 5                  | 0 1    | 0 1    | 0                 | 1             | 0                   |

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

# 2. part - 2-bit comparator





$$SoP = (B1*\overline{A1}) + (B1*B0*\overline{A0}) + (B0*\overline{A1}*\overline{A0})$$



### 3. part - 4-bit comparator

design.vhd

--- Entity declaration for 4-bit binary comparator

entity comparator\_4bit is

```
port(
                    : in std logic vector(4 - 1 downto 0);
       аi
       bі
                    : in std_logic_vector(4 - 1 downto 0);
       -- COMPLETE ENTITY DECLARATION
               B_greater_A_o : out std_logic;
               B_equals_A_o : out std_logic;
       B_less_A_o : out std_logic
                                    -- B is less than A
   );
end entity comparator_4bit;
-- Architecture body for 4-bit binary comparator
architecture Behavioral of comparator 4bit is
begin
   B less A o <= '1' when (b i < a i) 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

```
-- 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);
   signal s_b : std_logic_vector(4 - 1 downto 0);
   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 Test)
   uut_comparator_4bit : entity work.comparator_4bit
      port map(
```

```
a i
                     => s a,
        Ьi
                    => s 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 = '0'
    -- If false, then report an error
    report "Test failed for input combination: 0000, 0000" severity error;
    -- Second test values
           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 = '1'
    -- If false, then report an error
    report "Test failed for input combination: 0000, 0001" severity error;
    -- Third test values
    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 = '1'
    -- If false, then report an error
    report "Test failed for input combination: 0000, 0010" severity error;
    -- 4th test values
    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 = '1'
    -- If false, then report an error
    report "Test failed for input combination: 0000, 0011" severity error;
    -- 5th test values
    s b <= "0001"; s a <= "0000"; wait for 100 ns;
    -- Expected output
    assert ((s B greater A = '1') and (s B equals A = '0') and (s B less A = '0'
    -- If false, then report an error
    report "Test failed for input combination: 0001, 0000" severity error;
```

```
-- 6th test values
        s b <= "0001"; s a <= "0001"; wait for 100 ns;
        -- Expected output
        assert ((s B greater A = '0') and (s B equals A = '1') and (s B less A = '0'
        -- If false, then report an error
        report "Test failed for input combination: 0001, 0001" severity error;
        -- 7th test values
        s b <= "0001"; 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 = '1'
        -- If false, then report an error
        report "Test failed for input combination: 0001, 0010" severity error;
        -- 8th test values
        s b <= "0001"; 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 = '1'
        -- If false, then report an error
        report "Test failed for input combination: 0001, 0011" severity error;
        -- 9th test values
        s_b <= "0010"; s_a <= "0000"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '1') and (s_B_equals_A = '0') and (s_B_less_A = '0')
        -- If false, then report an error
        report "Test failed for input combination: 0010, 0000" severity error;
        -- 10th test values - INTENTIONAL ERROR
        s_b <= "0010"; s_a <= "0001"; wait for 100 ns;
        -- Expected output
        assert ((s_B_greater_A = '1') and (s_B_equals_A = '1') and (s_B_less_A = '0'
        -- If false, then report an error
        report "Test failed for input combination: 0010, 0001" severity error;
        -- Report a note at the end of stimulus process
        report "Stimulus process finished" severity note;
        wait:
    end process p_stimulus;
end architecture testbench;
```

#### Screenshot of Console with successful intentional error message



#### Screenshot of simulated waveforms from EDA



Note: To revert to EPWave opening in a new browser window, set that option on your user page.

#### Link to EDA playground of 4-bit comparator simulation

My EDA Playground sim