

Title :- Design and Implementation of Sequence detector 1101 using the concept of Finite State Machines.

Objective :- designing a working model of a Finite State Machine Application 1101 sequence detector using required integrated circuits on breadboard and on Printed Circuit Board.

Literature Survey :- Sequence detectors are used in real-world applications such as in digital communication to recognise patterns, data compression and protocol implementation. They can also be used in emerging trends such as machine-learning, reconfigurable hardware implementation (eg, FPGA-based detectors) and application-specific optimizations. These detectors work on the principle of finite state machines.

→ Finite state machines.

They are computational models used to describe the behaviour of systems with a finite number of states. They are widely used in various applications, including digital circuit design, control systems and communication protocols.

Here's a breakdown of the key components and concepts of finite state machines:-

### Components of Finite State Machines



State Diagram

States :- A, B, C.

Transition :- The arrow marks show transition between states (a, b, c, d).

Input :- External stimuli which decides where transition happens ( $I_1, I_2, I_3, I_4$ )

Output :- Response of system in each transition ( $O_1, O_2, O_3, O$ )

7. States :- FSMs consist of a finite set of states, which represent different conditions or configurations of the system. Each state represents a distinct mode of operation or behaviour.

27. Transitions :- They define movement of the system from one state to another in response to input signals or events. They are triggered by input symbols or conditions and are associated with specific state changes.

37. Inputs :- They are external stimuli or signals that trigger state transitions in the FSM.

47. Outputs :- Outputs are generated by the FSM in response to input signals and current states. It represents the system's action corresponding to its current state and input.

57. Transition Function :- It defines the behaviour of FSM by specifying the next state for each possible combination of current state and input.

67. State Diagram :- It is a graphical representation of an FSM, depicting states as nodes and transitions as directed edges between states. It provides a visual representation of the system's behaviour and enable easy understanding and analysis.

DATE  
14/24

ST. NO.

finite state machines can be classified into 2 main types based on their output behaviour:-

1). Mealy Machine :- In this machine, the outputs are associated with individual states and remain constant throughout each state's duration. Output generation is solely dependent on the current state of the system.

2). Moore Machine :- In this machine, outputs are associated with transitions between states and are dependent on both the current state and input. Output generation occurs concurrently with state transitions, potentially resulting in more dynamic behaviour of the system as compared to Mealy machines.

→ Sequence detector. (An application of finite state Machines)  
It is a type of digital circuit that identifies specific patterns or sequences of symbols within a stream of input data. The core of it is implemented by finite state machine. The FSM consists of a finite number of states, each representing a different condition or configuration of the detection. Transitions are triggered by input symbols and thus determine the behaviour of the detection.



When the sequence detection recognizes the predefined pattern in an sequence within the input data stream, it generates an output signal. The output signal indicates the detection of the desired sequence and can be used to trigger further actions or operations in the system.

#### ⇒ Sequence detection 1101.

The sequence detection designed in this project takes a bit stream of data as its input and output becomes 1 only when the detection detects the input sequence 1101 in the the bit stream. Sequence detection are of two types:- overlapping and non-overlapping.

① Overlapping sequence detection :- In this type, the detection is capable of detecting multiple occurrences of the target sequence within the stream even if they overlap with each other.

Example :- To detect '1101' in

I/P :- 10110101101101001  
O/P :- 00000100001001001  
↑ ↑ ↑  
detected detected detected

2) Non overlapping sequence detection :- In this type, the detection only detects disjoint occurrences of the target sequence within the input data stream. It ignores any instances of the sequence that overlap with previously detected occurrences.

Example:- Let us take the same sequence & its stream data.

I/P :-    1 0 1 1 0 1 0 1 1 0 1 1 0 1 0 0 1  
O/P      0 0 0 0 0 1 0 0 0 0 1 0 0 0 0 0  
             ↑                                          ↑  
         detected                                    detected.

In our project, we have designed an overlapping sequence detector.

### Real life applications of sequence detectors:-

- In communication protocol to detect sync patterns and control characters within data packets
- Data compression
- Biomedical signal processing
- DNA sequencing
- Security and cryptography.

These are just a few examples of the wide-ranging applications of sequence detectors in various fields. Their ability to identify specific patterns within data streams makes them invaluable for tasks ranging from communication and data processing to control and automation.

## State diagram of 1101 overlapping sequence detector



$A \rightarrow B$ , when 1 is detected as 4th bit  
 $A \rightarrow A$ , when 0 is detected as 4th bit.  
 $B \rightarrow A$ , when 0 is detected as 1st bit.  
 $B \rightarrow C$ , when 1 is detected as 2nd bit.  
 $C \rightarrow C$ , when 1 is detected as 3rd bit.  
 $C \rightarrow D$ , when 0 is detected as 3rd bit.  
 $D \rightarrow A$ , when 0 is detected as 3rd bit.  
 $D \rightarrow B$ , when 1 is detected as 4th bit.  
 and it continues . . .

$\boxed{1101}$  detected

## Methology

1101 overlapping sequence detection.

| States required. | Meaning           |
|------------------|-------------------|
| A                | No word detected. |
| B                | 1 detected        |
| C                | 1 1 detected      |
| D                | 1 1 0 detected    |

Output = 1 if 4th bit is 1

State Table.

| Present State | Next State |     | Output |
|---------------|------------|-----|--------|
|               | X=0        | X=1 |        |
| A             | A          | B   | 0      |
| B             | A          | C   | 0      |
| C             | D          | C   | 0      |
| D             | A          | B   | 1      |

$X = \text{Input bit.}$

State Table in Binary:-

| Present State      | Q <sub>1</sub> | Q <sub>0</sub> | Present State      | Q <sub>1</sub> | Q <sub>0</sub> | Present State      | Q <sub>1</sub> | Q <sub>0</sub> | Output |
|--------------------|----------------|----------------|--------------------|----------------|----------------|--------------------|----------------|----------------|--------|
| A $\rightarrow 00$ | 0              | 0              | B $\rightarrow 01$ | 0              | 1              | C $\rightarrow 10$ | 0              | 0              | 0      |
| B $\rightarrow 01$ | 0              | 0              | C $\rightarrow 10$ | 0              | 1              | D $\rightarrow 11$ | 0              | 0              | 0      |
| C $\rightarrow 10$ | 0              | 1              | D $\rightarrow 11$ | 1              | 0              | A $\rightarrow 00$ | 1              | 0              | 1      |
| D $\rightarrow 11$ | 1              | 0              | A $\rightarrow 00$ | 1              | 0              | B $\rightarrow 01$ | 0              | 1              | 0      |
| A $\rightarrow 00$ | 1              | 0              | B $\rightarrow 01$ | 0              | 1              | C $\rightarrow 10$ | 0              | 0              | 0      |
| B $\rightarrow 01$ | 0              | 1              | D $\rightarrow 11$ | 1              | 0              | A $\rightarrow 00$ | 1              | 0              | 0      |
| C $\rightarrow 10$ | 0              | 0              | A $\rightarrow 00$ | 1              | 0              | B $\rightarrow 01$ | 0              | 1              | 0      |
| D $\rightarrow 11$ | 1              | 0              | B $\rightarrow 01$ | 0              | 1              | C $\rightarrow 10$ | 0              | 0              | 0      |
| A $\rightarrow 00$ | 1              | 0              | D $\rightarrow 11$ | 1              | 0              | A $\rightarrow 00$ | 1              | 0              | 1      |



Truth Table:-

| Input | Present State    | New State        | Output             | Input to D flip flop |
|-------|------------------|------------------|--------------------|----------------------|
| X     | $\overline{Q}_1$ | $\overline{Q}_0$ | $\overline{Q}_1^+$ | $\overline{Q}_0^+$   |
| 0     | 0                | 0                | 0                  | 0                    |
| 0     | 0                | 1                | 0                  | 0                    |
| 0     | 1                | 0                | 0                  | 0                    |
| 0     | 1                | 1                | 1                  | 0                    |
| 1     | 0                | 0                | 0                  | 0                    |
| 1     | 0                | 1                | 0                  | 0                    |
| 1     | 1                | 0                | 1                  | 0                    |
| 1     | 1                | 1                | 0                  | 1                    |
| 1.    | 1                | 1                | 0                  | 1                    |
| 1.    | 1                | 0                | 1                  | 0                    |
| 1.    | 1                | 1                | 0                  | 1                    |
| 1.    | 1                | 0                | 1                  | 0                    |
| 1.    | 1                | 1                | 0                  | 1                    |
| 1.    | 1                | 0                | 1                  | 0                    |
| 1.    | 1                | 1                | 0                  | 1                    |
| 1.    | 1                | 0                | 1                  | 0                    |
| 1.    | 1                | 1                | 0                  | 1                    |
| 1.    | 1                | 0                | 1                  | 0                    |
| 1.    | 1                | 1                | 0                  | 1                    |

D1 :-

$$Y = X \overline{Q}_1 \overline{Q}_0.$$

$$D1 = X \overline{Q}_1 \overline{Q}_0 + \overline{Q}_1 \overline{Q}_0.$$

D2 :-

$$X \quad \overline{Q}_1 \overline{Q}_0 \\ \overline{X} \quad \overline{Q}_1 \overline{Q}_0 \quad \overline{Q}_1 \overline{Q}_0 \quad \overline{Q}_1 \overline{Q}_0 \quad Q_1 \overline{Q}_0 \quad Q_1 \overline{Q}_0$$

|   |   |   |   |    |   |
|---|---|---|---|----|---|
| X | 0 | 1 | 3 | -1 | - |
| X | 0 | 1 | 3 | -1 | - |
| X | 0 | 1 | 3 | -1 | - |
| X | 0 | 1 | 3 | -1 | - |

$\overline{Q}_1 \overline{Q}_0$

$$D0 = X \overline{Q}_1 \overline{Q}_0 + X \overline{Q}_1 Q_0 + \overline{X} Q_1 \overline{Q}_0$$



## IC symbols and pin configuration

Name

Hex NOT gate.



Symbole.



0/P



Dual 2-input  
OR gate.



Dual 2-input  
AND gate.



Dual 3-input  
AND gate.



Dual  
D-flipflop.



Dual  
D-flipflop.

ComponentsResource Utilization

Components required:-

| Name                                 | IC number (if any) |
|--------------------------------------|--------------------|
| ① Dual D Flip Flop. IC.              | HC 74 ACT 74N.     |
| ② Triple 3-input AND gate IC<br>(x2) | SN 74 LS 11 N.     |
| ③ Quad 2-input OR gate IC.           | SN 74 HC 32 N.     |
| ④ Quad 2-input AND gate IC.          | SN 74 HC 08 N.     |
| ⑤ Hex NOT gate IC.                   | SN 74 HC 04 N.     |
| ⑥ Jumper wires (Male to Male)        | -                  |
| ⑦ Breadboard.                        | -                  |

List equipments.

| Name                               | Specifications.                                        | Range.                                     |
|------------------------------------|--------------------------------------------------------|--------------------------------------------|
| ① Power supply.                    | Scientific Multivolt<br>Power supply PS 13304          | 0 - 5 volt.<br>Working voltage :- 4.3V.    |
| ② Wave Generation.                 | 8-Wire variable wave<br>generator ST 2111<br>(Sweatex) | 0 to 8 volt.<br>Working logic :- 11011010. |
| ③ Digital Storage<br>Oscilloscope. | Oscilloscopes.                                         | 100MHz, 1G/S/s.                            |
| ④ External connecting wires        | -                                                      | -                                          |



↑ Sequence detector complete Setup ↓



## Implementation Steps

- Place the breadboard on a uniform plane region for smooth operation.
- Connect all the integrated circuits on the breadboard which are required as per the circuit diagram.
- Connect the lines across the ICs as shown in the circuit diagram by clearly following the pin configuration structure of respective ICs with the help of jumper wires.
- After connecting them, connect all the Vcc pin and ground pin of all the ICs to the two respective Vcc line and ground line on the breadboard.
- Give power supply to the two ICs by connecting it with the help of connections to the Vcc line on the breadboard and also to the power and clean pins on flip flop.
- Now connect the data generator to the breadboard connection at 'Input X' terminals on the ICs at required pins ~~by~~. Connect it with the 'data' socket on the generator.



OKEN Scanner

- Now connect the oscillator to the sequence generator, one channel to the input & another channel to the output with the help of connections so that we can observe the bit patterns of both parallelly and cross-check.
- Now switch on the power supply and maintain voltage around 4.3 V.
- Give the variable bit data with the help of the data generator & 1/0 switches and connect the clock terminal from it to the respective flip flop's clock pin. Apply a bit stream say '11011010' and select 'load' on the generator.
- Run the oscilloscope & capture the waveforms of both channel. You can observe that the output wave has value 1 whenever it detects the complete '110' from the input waveform.

 OKEN<sup>®</sup>  
OIP results as shown in line picture.

Input :- 1 1 0 1 1 0 1 0  
Output :- 0 0 0 1 0 0 1 0  
detected detected



Scanned with OKEN Scanner

### Critical Jitters

The most important thing which one should keep in mind is that we should never forget to connect the clear and nearest terminal of the flip flop IC to the power supply i.e. ground connecting them with binary '1' inputs. If both clear and preset input has binary '1' or '0' it implies that the flip flop will work on its normal stage without any hindrance. Keeping clear and preset as open circuit may result in the failure of the project. This is the only critical misuse encountered by us.

Software used for designing circuit for and PCB layout:-  
1 - Easy EDA.

# Circuit Layout on Simulation window



### Conclusion:-

Through meticulous design, testing and iteration, we've developed a neural system capable of accurately identifying and responding to target sequences. Moving forward, we can leverage the insights gained from this endeavor to tackle even more ambitious projects.