## FSM SYSTEM DESIGN

LAB REPORT 2 FOR ECE327
DIGITAL SYSTEMS DESIGN

SUBMITTED BY
JULIAN COY

## Undergraduate of Electrical & Computer Engineering Clemson University

MARCH 12, 2014

### **Abstract**

Finite state machines (FSMs) are the basic building blocks of complex computing. They allow for logical implementation of algorithms, which is critical to the engineering of computing systems. In this lab, a finite state machine is constructed to flag "stop codons" in a sample of DNA code. The implementation of this finite machine is done though VHDL using behavioral modeling techniques. Testbench results are provided later in this report to show a working simulation of the FSM when connected to other logical components. The other logical components built for this lab are a Parallel-to-Serial Output (PISO) register and a counter register. The inputs to the FSM design will be threefold. There will be one array of 18 switches which are used to simulate the DNA input. There will also be a "reset" button and a "load" button. The reset button will asynchronously reset the counter block, while the load button will be used to push new data into the PISO register. This design showcases the power of finite state machine logic. It is critical for engineers to grasp the power of logical computation and to see the scalability of such power. By combining simple FSM logical blocks, one can create a vast and complicated algorithm with ease.

#### **INTRODUCTION**

The purpose of this lab is to sequence DNA bases consisting of T, A, C, and G and look for stop codons. Stop codons are series of three bases that trigger the end of a DNA sequence. The stop codons we look for in this lab are TAA, TGA, and TAG. In order to differentiate the bases, we use a binary representation for the bases (Figure 1.1). The bases are then fed into the FSM, the number of stop codons are counted, and then the count is displayed on the Altera board.

| Nitrogen base | Binary code |
|---------------|-------------|
| A             | 00          |
| T             | 01          |
| С             | 10          |
| G             | 11          |

Figure 1.1: DNA Base Representation

Lab two consists of three major logical components (the FSM logic, the counter logic, and the PISO logic) and one mior component (the LED logic). The counter and PISO components are standalone and can be simulated through ModelSim for testing or used for implementation with other systems with minimal modifications. The FSM logic is designed to model state transitions of the incoming DNA data from the PISO. And the minor LED logic simply displays a number of LEDs correspondent to the output of the counter logic.

#### 1.1 FSM SYSTEM DESIGN

#### 1.1.1 PISO LOGIC DESIGN

The PISO design for this lab was built specifically to handle 18 bits of input data at a time. This was a design choice made for the layout of the Altera board, as it only allowed for 18 bits of modifiable input at a time. The PISO logic parses the 18 bits of data by 2 bit intervals. It then outputs the first two bits of data on the rising edge of the clock. This output is connected to the FSM input. The PISO then shifts the data left by two bits and adds a "01" to the right end. The "01" code was chosen for the shift packing to make sure that when the data is fully read, no extra stop codons are accidentally detected. Since the code for the T base is "01" and no stop codons end with T or consist of all T's, this eliminates that possibility.

#### 1.1.2 TESTING OF THE PISO

The counter is modeled behaviorally and simply counts the number of stop flags from the FSM it encounters. The maximum count use for this project is three, but can be modified to much larger ranges with only three lines of code. The counter outputs its value on an integer signal that is sent to the LED logic.

#### 1.1.3 COUNTER LOGIC DESIGN

The counter is modeled behaviorally and simply counts the number of stop flags from the FSM it encounters. The maximum count used for this project is three, but can be modified to much larger ranges with only a few lines of code. The counter outputs its value on an integer signal that is sent to the LED logic.

#### 1.1.4 TESTING OF THE COUNTER

The counter was tested by sending stop flags to the input and periodically sending a reset signal. The counter performed without issue even when using large integer values. The maximum count size tested was 255, but since the maximum number of stop codones possible from the board were three, the counter integer limit was set to 3.



Figure 1.2: Simulation Results [1]

#### 1.1.5 TESTING OF THE 2-TO-1 MULTIPLEXER

Testing of the multiplexer was done with a testbench through ModelSim. Inside the test bench the input signals were initialized and set to different values. Next, the channels were cycled through using the select signal. Once cycled, the signal that was selected was changed and the change was verified through the Wave view in ModelSim. Finally, the signal that was not selected was changed and monitored to make sure the output did not change.

Once the testbench was completed, the code was compiled inside of Quartus II and flashed onto the Cyclone IV FPGA. Once the code was loaded onto the FPGA the switches and LEDS were used to verify the operation of the code. For this multiplexer design, the switches 15 to 8 were used for the Y channel and switched 7 to 0 were used for X. Switch 16 was used as the select signal and the red LEDs were connected to the output channel. By toggling through the earlier mentioned states, the program was verified in hardware.

#### 1.2 5-TO-1 MULTIPLEXER

#### 1.2.1 DESIGNING THE 5-TO-1 MULTIPLEXER

The second system was a 5-to-1 multiplexer design. This design is very similar to the previous system. The addition of three more channels will require a more complex decoding algorithm. This can complicate the design greatly; however, smart implementation techniques can limit the overhead of the computation. As shown in Figure a simple case block was sufficient to perform the select signal decoding for the 3 bit select line. This method is inefficient with larger select lines as they exponentially increase the number of required cases per select channel bit.

#### 1.2.2 Testing the 5-to-1 Multiplexer

The testing of the 5-to-1 multiplexer was almost exactly the same as the test for the 2-to-1. Figure shows the timing diagram of the signals. The diagram shows the transition from the output signal (TESTM) as the select signal (TESTS) is modified. The first 5 changes for TESTS show the value of the output matching the selected input. The second to last change shows that non-selected input does not affect the output. The final change to TESTW when it is selected shows that the output changes immediately with the selected signal.

#### 1.3 SEVEN SEGMENT DECODER

#### 1.3.1 DESIGNING THE SEVEN SEGMENT DECODER

The basic truth table and signal layout for the seven segment decoder (SSD) are shown in Figure (ref here). The SSD is supposed to take a 3-bit input and display a letter corresponding to the values in the truth table. This means that a maximum of 2<sup>3</sup> Each segment in the decoder is set by a bit. So the input channel must be 7 bits wide to accommodate the SSD.

#### 1.3.2 TESTING THE SEVEN SEGMENT DECODER

Testing of the SSD is more efficient on the Cyclone IV due to the nature of the visual display. For a human eye the waveform simulation was unfortunately hard to follow. Although the waveform allowed for proper logical adjustments, it was unknown that the SSD required a low bit to activate a segment and all of the letters were inverted. Figure shows the timing waveform.

#### 1.4 5-SEVEN SEGMENT DISPLAY

#### 1.4.1 DESIGNING THE 5-SEVEN SEGMENT DISPLAY

The final system of Lab 1 is a 5-count SSD that can display a word. The word must be able to be shifted by a 3-bit select channel and each letter must be modifiable by another 3-bit select channel. Each of the previous subsystems is included for the final design. There are 5 5-to-1 multiplexers which are connected to SSDs.

Figure shows the truth table for the select line input. This table is assuming that the SSD letter codes are not changing when the select line does. Each SSD also has a 3-bit select line that will tell the multiplexer what values to send to the decoder. The diagram for the signals is shown in Figure .

#### 1.4.2 TESTING THE 5-SEVEN SEGMENT DISPLAY

As the complexity of a system grows, so does the complexity of its verification. The final system in lab 1 required multiple tests between components and tests of the components themselves to verify functionality. For the test, the SSD were initialized to display "TIGER". Then the letters were permuted through the TESTSW signal. Once that was verified, the letters were randomized and then permuted randomly through the SSDs. In the code the "default" value for the SSD was set to display the number "8" for easy debugging.

The code for the testbench can be seen in Appendix B. The waveform simulation can be found in Appendix C.

#### 1.5 CONCLUSIONS

This lab is a testament to the modularity, reliability, and scope of FPGA programming with VHDL. Simple components or systems can be designed and connected to form incredibly complex systems that can perform a wide range of actions. Originally, the subsystems in the lab seemed unconnected to one another. However, by the end of the lab it was clear that the systems were building upon each other. This lab also

clearly demonstrated the value of simulations in attempting to analyze complex FPGA systems.

#### WORKS CITED

[1] J. Lewis, "Vhdl quick reference." Internet: http://www.synthworks.com/downloads/vhdl\_quickref.pdf, 2008.

# APPENDIX A: 5-SEVEN SEGMENT DECODER

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY work;
USE work.all;
ENTITY LAB1d IS
 PORT (
                  : IN STD_LOGIC_VECTOR(17 DOWNTO 0);
   HEXO, HEX1, HEX2, HEX3, HEX4: OUT STD_LOGIC_VECTOR(6 DOWNTO 0)
 );
END ENTITY LAB1d;
ARCHITECTURE LAB1d_arch OF LAB1d IS
 COMPONENT seven_seg_parse
   PORT (
     DATA : IN STD_LOGIC_VECTOR(2 DOWNTO 0);
     OUTPUT : OUT STD_LOGIC_VECTOR(6 DOWNTO 0)
   );
 END COMPONENT seven_seg_parse;
 SIGNAL SO,S1,S2,S3,S4 : STD_LOGIC_VECTOR(6 DOWNTO 0);
BEGIN
   behav: PROCESS (S0,S1,S2,S3,S4)
```

#### BEGIN

```
CASE SW(17 DOWNTO 15) IS
 WHEN "000" =>
    HEXO <= SO;</pre>
    HEX1 <= S1;</pre>
    HEX2 <= S2;
    HEX3 <= S3;
    HEX4 <= S4;
  WHEN "001" =>
    HEXO <= S1;</pre>
    HEX1 <= S2;
    HEX2 <= S3;</pre>
    HEX3 <= S4;
    HEX4 <= S0;
  WHEN "010" =>
    HEXO <= S2;</pre>
    HEX1 <= S3;</pre>
    HEX2 <= S4;
    HEX3 <= S0;
    HEX4 <= S1;</pre>
 WHEN "011" =>
    HEX0 <= S3;</pre>
    HEX1 <= S4;
    HEX2 <= S0;</pre>
    HEX3 <= S1;</pre>
    HEX4 <= S2;
  WHEN "100" =>
    HEXO <= S4;</pre>
    HEX1 <= S0;
    HEX2 <= S1;</pre>
    HEX3 <= S2;
    HEX4 <= S3;</pre>
  WHEN others =>
    HEXO <= SO;</pre>
    HEX1 <= S1;</pre>
```

HEX2 <= S2;</pre>

```
HEX3 <= S3;
         HEX4 <= S4;
     END CASE;
   END PROCESS behav;
   seven_seg_0 : seven_seg_parse PORT MAP(SW(2 DOWNTO 0),S0);
   seven_seg_1 : seven_seg_parse PORT MAP(SW(5 DOWNTO 3),S1);
   seven_seg_2 : seven_seg_parse PORT MAP(SW(8 DOWNTO 6),S2);
   seven_seg_3 : seven_seg_parse PORT MAP(SW(11 DOWNTO 9),S3);
   seven_seg_4 : seven_seg_parse PORT MAP(SW(14 DOWNTO 12),S4);
END ARCHITECTURE LAB1d_arch;
______
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY work;
USE work.all;
ENTITY seven_seg_parse IS
 PORT (
   DATA : IN STD_LOGIC_VECTOR(2 DOWNTO 0);
   OUTPUT : OUT STD_LOGIC_VECTOR(6 DOWNTO 0)
 );
END ENTITY seven_seg_parse;
ARCHITECTURE basic OF seven_seg_parse IS
BEGIN
 behav : PROCESS (DATA)
 BEGIN
   CASE DATA IS
     WHEN "000" => OUTPUT <= "0000111";
     WHEN "001" => OUTPUT <= "1111001";
     WHEN "010" => OUTPUT <= "0010000";
```

```
WHEN "011" => OUTPUT <= "0000110";
     WHEN "100" => OUTPUT <= "1001100";
     WHEN others => OUTPUT <= "0000000";
   END CASE;
 END PROCESS behav;
END ARCHITECTURE basic;
LIBRARY ieee;
USE ieee.std_logic_1164.all;
LIBRARY work;
USE work.all;
ENTITY mux21 IS
 PORT (
   SEL,X,Y : IN STD_LOGIC;
   M : OUT STD_LOGIC);
END ENTITY mux21;
ARCHITECTURE basic OF mux21 IS
BEGIN
 mux21_behavior : PROCESS (SEL,X,Y)
 BEGIN
     if (SEL = '0') then M <= X; else M <= Y; END if;
 END PROCESS mux21_behavior;
END ARCHITECTURE basic;
```

## APPENDIX B: TEST BENCH (PART 4)

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
ENTITY TB1d IS
END TB1d;
ARCHITECTURE TB1d_arch OF TB1d IS
 -- test signals going into and out of the mux
 SIGNAL TESTS01 : STD_LOGIC_VECTOR(6 DOWNTO 0);
 SIGNAL TESTS02 : STD_LOGIC_VECTOR(6 DOWNTO 0);
 SIGNAL TESTS03 : STD_LOGIC_VECTOR(6 DOWNTO 0);
 SIGNAL TESTS04 : STD_LOGIC_VECTOR(6 DOWNTO 0);
 SIGNAL TESTS05 : STD_LOGIC_VECTOR(6 DOWNTO 0);
 SIGNAL TESTSW : STD_LOGIC_VECTOR(17 DOWNTO 0);
 COMPONENT LAB1d
   PORT (
     SW : IN STD_LOGIC_VECTOR(17 DOWNTO 0);
     HEXO : OUT STD_LOGIC_VECTOR(6 DOWNTO 0);
     HEX1 : OUT STD_LOGIC_VECTOR(6 DOWNTO 0);
     HEX2 : OUT STD_LOGIC_VECTOR(6 DOWNTO 0);
     HEX3 : OUT STD_LOGIC_VECTOR(6 DOWNTO 0);
     HEX4 : OUT STD_LOGIC_VECTOR(6 DOWNTO 0)
   );
 END COMPONENT;
 -- map the signals
 BEGIN
```

```
multimux : LAB1d
PORT MAP (
 SW => TESTSW,
 HEXO => TESTS01,
 HEX1 => TESTS02,
 HEX2 => TESTS03,
 HEX3 => TESTS04,
 HEX4 => TESTS05
);
-- start the test
test : PROCESS
BEGIN
-- set the initial word to be TIGER and initial position
TESTSW(14 DOWNTO 0) <= "100011010001000";
TESTSW(17 DOWNTO 15) <= "000"; WAIT FOR 4 ns;
-- cycle around message
TESTSW(17 DOWNTO 15) <= "001"; WAIT FOR 2 ns;
TESTSW(17 DOWNTO 15) <= "010"; WAIT FOR 2 ns;
TESTSW(17 DOWNTO 15) <= "011"; WAIT FOR 2 ns;
TESTSW(17 DOWNTO 15) <= "100"; WAIT FOR 2 ns;
-- change message
TESTSW(17 DOWNTO 15) <= "000";
TESTSW(14 DOWNTO 0) <= "100001010011000"; WAIT FOR 4 ns;
-- cycle randomly message
TESTSW(17 DOWNTO 15) <= "011"; WAIT FOR 2 ns;
TESTSW(17 DOWNTO 15) <= "010"; WAIT FOR 2 ns;
TESTSW(17 DOWNTO 15) <= "001"; WAIT FOR 2 ns;
TESTSW(17 DOWNTO 15) <= "100"; WAIT FOR 2 ns;
```

```
WAIT;
END PROCESS test;
END TB1d_arch;
```

## APPENDIX C: WAVEFORM (PART 4)