

# Programable Logic Circuits

## Lab 01

Sølve Kjelseth

September 5, 2025

### 0. Introduction

This is the first report in this course, detailing the completion of the first lab exerciser, I hope to get some feedback on this. Note: The L<sup>A</sup>T<sub>E</sub>X code is open source, [github link](#).

### 0.0. Table of Contents

|                              |           |
|------------------------------|-----------|
| <b>1. Task number 1</b>      | <b>3</b>  |
| 1.0.Code .....               | 3         |
| 1.1.Simulation results ..... | 5         |
| <b>2. Task number 2</b>      | <b>6</b>  |
| 2.0.Code .....               | 6         |
| 2.1.Simulation results ..... | 8         |
| <b>3. Task number 3</b>      | <b>9</b>  |
| 3.0.Code .....               | 9         |
| 3.1.Simulation results ..... | 11        |
| <b>4. Task number 4</b>      | <b>12</b> |
| 4.0.Boolean expression ..... | 12        |
| 4.1.Code .....               | 12        |
| 4.2.RTL .....                | 13        |
| 4.3.Results .....            | 14        |
| <b>5. Task number 5</b>      | <b>15</b> |
| 5.0.Code .....               | 15        |
| 5.1.RTL .....                | 19        |
| 5.2.Results .....            | 21        |

## **0.1. List of Figures**

|     |                                                       |    |
|-----|-------------------------------------------------------|----|
| 1.0 | TLE as described in the task . . . . .                | 3  |
| 1.1 | TestBench for the TLE . . . . .                       | 4  |
| 1.2 | Simulation results . . . . .                          | 5  |
| 2.0 | TLE for a 4 bit 2 to 1 multiplexer . . . . .          | 6  |
| 2.1 | TestBench for the multiplexer . . . . .               | 7  |
| 2.2 | Simulation results . . . . .                          | 8  |
| 3.0 | TLE for a 2 bit 4 to 1 multiplexer . . . . .          | 9  |
| 3.1 | TestBench for the multiplexer . . . . .               | 10 |
| 3.2 | Simulation results . . . . .                          | 11 |
| 4.0 | TLE for a simple 7 segment decoder . . . . .          | 12 |
| 4.1 | RTL synthesizing of the circuit . . . . .             | 13 |
| 4.2 | Test results . . . . .                                | 14 |
| 5.0 | 2 bit 4-to-1 multiplexer . . . . .                    | 15 |
| 5.1 | 2 bit 7 segment decoder . . . . .                     | 16 |
| 5.2 | TLE for rotating display . . . . .                    | 18 |
| 5.3 | RTL synthesizing of the multiplexer circuit . . . . . | 19 |
| 5.4 | RTL synthesizing of the decoder circuit . . . . .     | 19 |
| 5.5 | RTL synthesizing of the TLE circuit . . . . .         | 20 |
| 5.6 | Test results for "dE1 " input . . . . .               | 21 |
| 5.7 | Test results for "E " input . . . . .                 | 22 |

## 1. Task number 1

This task was a introductory task, where the intent was to copy the provided VHDL instructions into a ModelSim project and make a test bench to simulate it. So that is what I did, there was chosen 8 different combinations for the simulations, I included both all 0 and all 1 for completeness and some other variants. I have one comment/question to the supplied instructions, it names it's architecture "behavioral" while I think I would have called this "structural" as it is describing the structural connection of the components.

### 1.0. Code

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P01 is
5     port(SW : in std_logic_vector(9 downto 0);
6          LEDR : out std_logic_vector(9 downto 0));
7 end L01P01;
8
9 architecture behaviour of L01P01 is
10 begin
11     LEDR <= SW;
12 end behaviour;
```

VHDL

Code 1.0: TLE as described in the task

VHDL

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P01TB is
5 end L01P01TB;
6
7 architecture behaviour of L01P01TB is
8
9     component L01P01
10         port(SW : in std_logic_vector(9 downto 0);
11              LEDR : out std_logic_vector(9 downto 0));
12     end component;
13
14     signal SW_s : std_logic_vector(9 downto 0);
15     signal LEDR_s : std_logic_vector(9 downto 0);
16
17 begin
18     vectors: process begin
19         SW_s <= "0000000000";
20         wait for 20 ns;
21         SW_s <= "0101010101";
22         wait for 20 ns;
23         SW_s <= "1111111111";
24         wait for 20 ns;
25         SW_s <= "1010101010";
26         wait for 20 ns;
27         SW_s <= "1111100000";
28         wait for 20 ns;
29         SW_s <= "0000011111";
30         wait for 20 ns;
31         SW_s <= "1100110011";
32         wait for 20 ns;
33         SW_s <= "0011001100";
34         wait;
35     end process;
36
37     U1: L01P01 port map (SW_s, LEDR_s);
38 end behaviour;
```

Code 1.1: TestBench for the TLE

## 1.1. Simulation results



(a) First four values



(b) Next three values

Figure 1.2: Simulation results

These are the simulation results. A keen eye might notice that the last value of the test-bench is not displayed. The issue is suspected to be that the wait command halts the simulation and the last chosen value will not be seen, for future simulations I will add an extra `wait for 20 ns;` at the end to ensure the last value also gets tested. Due to the low importance of this last simulation result, redoing it has been omitted.

## 2. Task number 2

This task was to write a simple 2-to-1 multiplexer. With two 4 bit inputs and a single selection bit and one 4 bit output. As the task supplied the statement that would add this functionality it relatively simple to program. Then I made a testbench code to test some inputs and see how it affected the outputs. In total 9 input combinations were tested. As LED nr 9 was used for a flag to see whether or not the selection input was on, the LEDs nr. 4-8 would not be in use and therefore they are assigned an unused signal such that they will not show up in the simulation.

### 2.0. Code

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P02 is
5     port(SW : in std_logic_vector(9 downto 0);
6          LEDR : out std_logic_vector(9 downto 0));
7 end L01P02;
8
9 architecture structural of L01P02 is
10 begin
11     LEDR(9) <= SW(9);
12     LEDR(8 downto 4) <= "00000";
13     LEDR(3) <= (not(SW(9)) and SW(3)) or (SW(9) and SW(7));
14     LEDR(2) <= (not(SW(9)) and SW(2)) or (SW(9) and SW(6));
15     LEDR(1) <= (not(SW(9)) and SW(1)) or (SW(9) and SW(5));
16     LEDR(0) <= (not(SW(9)) and SW(0)) or (SW(9) and SW(4));
17 end structural;
```

VHDL

Code 2.0: TLE for a 4 bit 2 to 1 multiplexer

VHDL

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P02TB is
5 end L01P02TB;
6
7 architecture behaviour of L01P02TB is
8
9     component L01P02
10         port(SW : in std_logic_vector(9 downto 0);
11              LEDR : out std_logic_vector(9 downto 0));
12     end component;
13
14     signal A      : std_logic_vector(3 downto 0);
15     signal B      : std_logic_vector(3 downto 0);
16     signal Sel    : std_logic;
17     signal flag   : std_logic;
18     signal na    : std_logic_vector(4 downto 0);
19     signal Y     : std_logic_vector(3 downto 0);
20
21 begin
22     vectors: process begin
23         A <= X"0"; B <= X"0"; Sel <= '0';
24         wait for 20 ns;
25         A <= X"F"; B <= X"4"; Sel <= '0';
26         wait for 20 ns;
27         A <= X"0"; B <= X"F"; Sel <= '0';
28         wait for 20 ns;
29         A <= X"F"; B <= X"0"; Sel <= '1';
30         wait for 20 ns;
31         A <= X"0"; B <= X"F"; Sel <= '1';
32         wait for 20 ns;
33         A <= X"A"; B <= X"7"; Sel <= '1';
34         wait for 20 ns;
35         A <= X"3"; B <= X"D"; Sel <= '0';
36         wait for 20 ns;
37         A <= X"7"; B <= X"9"; Sel <= '1';
38         wait for 20 ns;
39         A <= X"B"; B <= X"0"; Sel <= '1';
40         wait;
41     end process;
42
43     U1: L01P02 port map
44         (SW(9) => Sel,
45          SW(8) => '0',
46          SW(7 downto 4) => B,
47          SW(3 downto 0) => A,
48          LEDR(9) => flag,
49          LEDR(8 downto 4) => na,
50          LEDR(3 downto 0) => Y);
51 end behaviour;
```

Code 2.1: TestBench for the multiplexer

## 2.1. Simulation results



(a) First four values



(b) Next four values

Figure 2.2: Simulation results

Here you can see that the output is as expected. As long as Sel is set to 0 the flag is set to 0 and the output, Y is equal to input A. Then Sel is switched to 1 and that makes flag also go to 1 and output Y is now equal to input B instead. With the same reasoning as previous task the last line of test values are not shown, and screenshots will not be redone for this task either.

### 3. Task number 3

This task was similar to the previous but this time a 4-to-1 multiplexer. With four 2 bit inputs and a 2 bit selection and one 2 bit output. The logic statements from the previous task were used on two separate 2-to-1 multiplexers and results stored in a signal, where the final output was a 2-to-1 multiplexing of the signals. This then made up the 4-to-1 multiplexer. Then I made a testbench code to test some inputs and see how it affected the outputs. In total 8 input combinations were tested.

#### 3.0. Code

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P03 is
5     port(SW : in std_logic_vector(9 downto 0);
6          LEDR : out std_logic_vector(1 downto 0));
7 end L01P03;
8
9 architecture structural of L01P03 is
10    signal s : std_logic_vector(1 downto 0);
11    signal u : std_logic_vector(1 downto 0);
12    signal v : std_logic_vector(1 downto 0);
13    signal w : std_logic_vector(1 downto 0);
14    signal x : std_logic_vector(1 downto 0);
15    signal a : std_logic_vector(1 downto 0);
16    signal b : std_logic_vector(1 downto 0);
17    signal m : std_logic_vector(1 downto 0);
18
19 begin
20     s <= SW(9 downto 8);
21     u <= SW(7 downto 6);
22     v <= SW(5 downto 4);
23     w <= SW(3 downto 2);
24     x <= SW(1 downto 0);
25
26     a(0) <= (not s(0) and u(0)) or (s(0) and v(0));
27     a(1) <= (not s(0) and u(1)) or (s(0) and v(1));
28     b(0) <= (not s(0) and w(0)) or (s(0) and x(0));
29     b(1) <= (not s(0) and w(1)) or (s(0) and x(1));
30
31     m(0) <= (not s(1) and a(0)) or (s(1) and b(0));
32     m(1) <= (not s(1) and a(1)) or (s(1) and b(1));
33
34     LEDR <= m;
35 end structural;
```

VHDL

Code 3.0: TLE for a 2 bit 4 to 1 multiplexer

VHDL

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P03TB is
5 end L01P03TB;
6
7 architecture behaviour of L01P03TB is
8
9     component L01P03
10         port(SW : in std_logic_vector(9 downto 0);
11              LEDR : out std_logic_vector(1 downto 0));
12     end component;
13
14     signal Sel : std_logic_vector(1 downto 0);
15     signal U   : std_logic_vector(1 downto 0);
16     signal V   : std_logic_vector(1 downto 0);
17     signal W   : std_logic_vector(1 downto 0);
18     signal X   : std_logic_vector(1 downto 0);
19     signal LED : std_logic_vector(1 downto 0);
20
21 begin
22     vectors: process begin
23         U <= "00"; V <= "00"; W <= "00"; X <= "00";
24         Sel <= "00";
25         wait for 20 ns;
26         U <= "11"; V <= "10"; W <= "01"; X <= "00";
27         Sel <= "01";
28         wait for 20 ns;
29         Sel <= "10";
30         wait for 20 ns;
31         Sel <= "11";
32         wait for 20 ns;
33         U <= "11"; V <= "00"; W <= "11"; X <= "11";
34         Sel <= "01";
35         wait for 20 ns;
36         U <= "00"; V <= "11"; W <= "00"; X <= "00";
37         wait for 20 ns;
38         Sel <= "10";
39         wait for 20 ns;
40         U <= "11"; V <= "11"; W <= "11"; X <= "11";
41         Sel <= "11";
42         wait;
43     end process;
44
45     U1: L01P03 port map
46         (SW(9 downto 8) => Sel,
47          SW(7 downto 6) => U,
48          SW(5 downto 4) => V,
49          SW(3 downto 2) => W,
50          SW(1 downto 0) => X,
51          LEDR => LED);
52
53 end behaviour;
```

Code 3.1: TestBench for the multiplexer

### 3.1. Simulation results



(a) First four values



(b) Next three values

Figure 3.2: Simulation results

Here you can see that the output is as expected. When Sel is set to 00 the output, LED is equal to input U. When Sel is set to 01 the output is equal to input V. When Sel is set to 10 the output is equal to input W. When Sel is set to 11 the output is equal to input X. With the same reasoning as both previous tasks, the last line of test values are not shown, and screenshots will not be redone for this task either.

## 4. Task number 4

This task was to make a simple decoder for a 7 segment display. It would have a 2 bit input and a 7 bit output with the possibility to display "d", "E", "1" or off depending on the input. First I started with finding the boolean expression needed and then simply made a structural architecture based on the expressions for each output. Then it was tested on a FPGA board to show that it worked as expected.

### 4.0. Boolean expression

To find the boolean expressions I could have calculated it manual using boolean algebra but instead I opted for a truth table to expression solver to save time as there was no point in doing it manual. For segments 1-4 and 6 I saw there was a simple relation, just depending on one of the inputs and those were just used directly, for the few segments with a bit more advanced relation I used [https://tma.main.jp/logic/index\\_en.html](https://tma.main.jp/logic/index_en.html) to find the simplified boolean expression from the truth table.

### 4.1. Code

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P04 is
5     port(SW : in std_logic_vector(1 downto 0);
6          HEX0 : out std_logic_vector(6 downto 0));
7 end L01P04;
8
9 architecture structural of L01P04 is
10    signal c : std_logic_vector(1 downto 0);
11
12 begin
13     c <= SW;
14
15     HEX0(0) <= (not(c(0)) or c(1));
16     HEX0(1) <= c(0);
17     HEX0(2) <= c(0);
18     HEX0(3) <= c(1);
19     HEX0(4) <= c(1);
20     HEX0(5) <= (not(c(0)) or c(1));
21     HEX0(6) <= c(1);
22
23 end structural;
```

VHDL

Code 4.0: TLE for a simple 7 segment decoder

## 4.2. RTL



Figure 4.1: RTL synthesizing of the circuit

It is not clear from the RTL view what input is connected to which segments. Based on the numbering near the bottom, you can see that two instances of  $SW[0]$  are connected directly and three instances of  $SW[1]$ . Two segments are connected to each an or gate that is connected to  $SW[1]$  on one input and inverted  $SW[0]$ . This fits logically with what the code is doing, although there was no need to use two gates as the outputs are equal and could be connected together directly.

### 4.3. Results



Figure 4.2: Test results

Here you can see that the output is as expected. When the input is set to 00 the output is the letter "d". When the input is set to 01 the output is the letter "E". When the input is set to 10 the output is the number "1". When the input is set to 11 the output is off.

## 5. Task number 5

This is the final task for this lab and it was to combine the 2 bit 4-to-1 multiplexer with the 2 bit 7 segment display encoder. And rotated for 4 displays, such that the first display gets the first input, the second display gets the second input, third gets third and fourth gets fourth. Then when changing the selection input everything would rotate to the display next to it, and the last would wrap around to the first. I started with making the code for a 2 bit 4-to-1 multiplexer, very similar as in part 3. Then I made the code to a 2 bit decoder to a 7 segment display, very similar to part 4. Finally I made a TLE(Top Level Entity) code that imported the two previous codes. The TLE is constructed with four instances of the multiplexer to have one for each display, with the inputs rotated, such that if selection is 00 the output would be the first input on the left most display, the second input on the next display and so on. Four instances of the encoder was also added such that all 4 displays got their own encoder. As an extra feature, described in the task, all the switch inputs should light up each corresponding led to easier show on off position easier in pictures. After this the code was uploaded to a FPGA board and tested.

### 5.0. Code

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity MUX_2bit_4to1 is
5     port(S, U, V, W, X : in  std_logic_vector(1 downto 0);
6          M             : out std_logic_vector(1 downto 0));
7 end MUX_2bit_4to1;
8
9 architecture structural of MUX_2bit_4to1 is
10
11    signal A : std_logic_vector(1 downto 0);
12    signal B : std_logic_vector(1 downto 0);
13
14 begin
15     A(0) <= (not S(0) and U(0)) or (S(0) and V(0));
16     A(1) <= (not S(0) and U(1)) or (S(0) and V(1));
17     B(0) <= (not S(0) and W(0)) or (S(0) and X(0));
18     B(1) <= (not S(0) and W(1)) or (S(0) and X(1));
19
20     M(0) <= (not S(1) and A(0)) or (S(1) and B(0));
21     M(1) <= (not S(1) and A(1)) or (S(1) and B(1));
22
23 end structural;
```

VHDL

Code 5.0: 2 bit 4-to-1 multiplexer

VHDL

```
1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity DECODER_7seg is
5     port(C : in  std_logic_vector(1 downto 0);
6          D : out std_logic_vector(6 downto 0));
7 end DECODER_7seg;
8
9 architecture structural of DECODER_7seg is
10
11 begin
12     D(0) <= (not(C(0)) or C(1));
13     D(1) <= C(0);
14     D(2) <= C(0);
15     D(3) <= C(1);
16     D(4) <= C(1);
17     D(5) <= (not(C(0)) or C(1));
18     D(6) <= C(1);
19
20 end structural;
```

Code 5.1: 2 bit 7 segment decoder

```

1 library ieee;
2 use ieee.std_logic_1164.all;
3
4 entity L01P05 is
5     port(SW : in std_logic_vector(9 downto 0);
6          LEDR : out std_logic_vector(7 downto 0);
7          HEX0 : out std_logic_vector(6 downto 0);
8          HEX1 : out std_logic_vector(6 downto 0);
9          HEX2 : out std_logic_vector(6 downto 0);
10         HEX3 : out std_logic_vector(6 downto 0));
11 end L01P05;
12
13 architecture structural of L01P05 is
14
15     component MUX_2bit_4to1
16         port(S : in std_logic_vector(1 downto 0);
17               U : in std_logic_vector(1 downto 0);
18               V : in std_logic_vector(1 downto 0);
19               W : in std_logic_vector(1 downto 0);
20               X : in std_logic_vector(1 downto 0);
21               M : out std_logic_vector(1 downto 0));
22     end component;
23
24     component DECODER_7seg
25         port(C : in std_logic_vector(1 downto 0);
26               D : out std_logic_vector(6 downto 0));
27     end component;
28
29     signal A : std_logic_vector(7 downto 0);
30     signal Sel : std_logic_vector(1 downto 0);
31     signal IN0 : std_logic_vector(1 downto 0);
32     signal IN1 : std_logic_vector(1 downto 0);
33     signal IN2 : std_logic_vector(1 downto 0);
34     signal IN3 : std_logic_vector(1 downto 0);
35
36 begin
37     LEDR <= SW;
38
39     IN0 <= SW(1 downto 0);
40     IN1 <= SW(3 downto 2);
41     IN2 <= SW(5 downto 4);
42     IN3 <= SW(7 downto 6);
43     Sel <= SW(9 downto 8);
44
45     U0: MUX_2bit_4to1 port map
46         (S => Sel,
47          U => IN0,
48          V => IN1,
49          W => IN2,
50          X => IN3,
51          M => A(1 downto 0));
52
53     U1: MUX_2bit_4to1 port map
54         (S => Sel,
55          U => IN1,
56          V => IN2,
57          W => IN3,
58          X => IN0,
59          M => A(3 downto 2));
60

```

```

61      U2: MUX_2bit_4to1 port map
62          (S => Sel,
63           U => IN2,
64           V => IN3,
65           W => IN0,
66           X => IN1,
67           M => A(5 downto 4));
68
69      U3: MUX_2bit_4to1 port map
70          (S => Sel,
71           U => IN3,
72           V => IN0,
73           W => IN1,
74           X => IN2,
75           M => A(7 downto 6));
76
77      H0: DECODER_7seg port map
78          (C => A(1 downto 0),
79           D => HEX0);
80
81      H1: DECODER_7seg port map
82          (C => A(3 downto 2),
83           D => HEX1);
84
85      H2: DECODER_7seg port map
86          (C => A(5 downto 4),
87           D => HEX2);
88
89      H3: DECODER_7seg port map
90          (C => A(7 downto 6),
91           D => HEX3);
92
93  end structural;

```

Code 5.2: TLE for rotating display

## 5.1. RTL



Figure 5.3: RTL synthesizing of the multiplexer circuit

This is the RTL view of the first of the four instances of the multiplexer. If part 3 were synthesized it would look pretty close as it is the same logic used in both circus. Here you can see that the inputs are the U, V, W, X and the selector input S, all of which are 2 bit. and the output is the 2 bit M.



Figure 5.4: RTL synthesizing of the decoder circuit

This is the exact same function as the RTL in task 4 shows, as the codes are nearly identical.



Figure 5.5: RTL synthesizing of the TLE circuit

Here the setup of how each multiplexer is connected to each decoder that is connected to its own display is quite clear. You can also see on the input numbering that the numbers leading into each U, V, W and X on each multiplexer is rotating through the instances. Here you also see that the switches directly control the LEDs as well.

## 5.2. Results



Figure 5.6: Test results for "dE1" input

Here you can see that the only input changing is the selection and changing it makes the whole display rotate. The input for U is 00, which is for d, the input for V is 01 which is for E, the input for W is 10 which is for 1, and the input for X is 11 which is for off.



(a) E first at S = 00



(b) E second at S = 01



(c) E third at s = 10



(d) E last at s = 11

Figure 5.7: Test results for "E" input

As you can see here as with the previous example it is very easy to see how the rotation. At  $U = 01$  which makes E and V, W and X = 11 which makes the rest off, then only changing S between the photos clearly shows how the inputs are rotating along the multiplexer inputs.