

**Grzegorz Góra PhDD1-Lab 20ggora@agh.edu.plhttp://home.agh.edu.pl/~ggora/**

**Department of Robotics and MechatronicsFaculty of Mechanical Engineering and RoboticsAGH University of Science and Technology**

*Actuating, Sensing and Control Mechatronic Systems* www.agh.edu.pl



- *1. Combinational and Sequential Logic Circuits*
- *2. Flip-flops*
- *3. Moore State Machine*
- *4. Mealye State Machine*
- *5. State Mechine Synthesis*
- *6. Example: Guarded railway crossing*







**COMBINATIONAL CIRCUITS**  $-$  is a type of logic circuit whose output depends only on the present value of its input signals. Combinational cicruits are eq. adders, substractors, multiplexers, comparators, transcoders, etc.

**SEQUENTIAL CIRCUITS** – is a type of logic circuit whose **output depends on the present value of its input signals and** on the sequence of past inputs (previous state of the circuit), eq. counters, state machines.

- *Sequential circuits contain elements that store the current state.*
- *Flip-flops are used to store the current state.*
- *In sequential circuits, the flip-flop serves as <sup>a</sup> 1-bit memory.*
- $\;\blacksquare\;$  The flip-flop state (stored value) in synchronous systems is updated on each rising (or falling) edge of *the clock.*



**InputFlip-flops** are systems that have two stable states in which information can be stored. The system can change state using signals applied to one or more control (data) inputs. Flip-flop is the basic memory element in sequential logic.







#### *Special flip-flop inputs*

EN (*enable*), G (*gate*), STB (*strobe*), LE (*lach enable*) – gating flip-flop input CE (*clock enable*) – clock signal blocking input PRE (*preset*), AS (*asynchronous set*) – asynchronous input setting the flip-flop CLR (*clear*), AR (*asynchronous reset*) – asynchronous flip-flop reset input

S (*set*), SET, SS (*synchronous set*) – synchronous input setting the flip-flop

R (*reset*), RES, SR (*synchronous reset*) – synchronous flip-flop reset input

OE (*output enable*) – input blocking the flip-flop output



#### *RS - Flip\_flop (asynchronous)*



**Forbidden state** –

in the forbidden state, both outputs are '0'





#### *RS - Flip\_flop (asynchronous)*





### *RS - Latch (asynchronous)*





#### **Truth table**





### *D-Latch (Data-Latch)*











#### *Master-Slave D Flip-flop*





*JK – Flip-flop*





*T – Flip-flop*





#### *Toggle mode*





All registers in digital systems have defined signal timing requirements that allow each register to correctly capture data at its inputs and produce output signals. To ensure correct operation, the input to <sup>a</sup> register must be stable for <sup>a</sup> minimum time before the clock edge and for <sup>a</sup> minimum time after the clock edge (these times are assigned as setup time  $t_{\rm SU}$  and hold time  $t_{\rm H}$ ). Then, the register output is available after a specified delay assigned as clock-to-output delay  $(t_{\text{co}})$ .





#### *Metastability*

If <sup>a</sup> data signal transition don't meet these requirements, the output signals can go to <sup>a</sup> metastable state. In <sup>a</sup> metastable state, the register output hovers at <sup>a</sup> value between the high and low states for some period of time. This means that the output transition to <sup>a</sup> defined high or low state is delayed beyond the specified clock-to-output delay ( $\mathsf{t}_{\mathsf{co}}$ ). For this reason, the phenomenon of metastability is very dangerous.

In synchronous systems, the input signals always meet the register<br>timing requirements. requirements, so<br>contrative represe rando represents in the result of the result of the represent results to the represent to t<br>contract response to the represent to the results of the results of the results of the results appear. metastability Metastability problems commonly appear when <sup>a</sup> signal is transferred in asynchronous clock domains (for example it is input signal from another device). In that case, the designer cannot guarantee that the<br>signal will meet timing signal will meet timing requirements, because the signal can arrive at any time relative tothe destination clock.





#### *Metastability*

When <sup>a</sup> signal is transferred between circuits in asynchronous clock domains, it is necessary to synchronize this signal to the new clock domain before it can be used. The first register in the newclock domain acts as <sup>a</sup> synchronization register.

To minimize the failures due to metastability in asynchronous signal transfers, circuit designers typically use <sup>a</sup> sequence of registers (a synchronization register chain or synchronizer) in the destination clock domain to resynchronize the signal to the new clock domain. These registers allow additional time for <sup>a</sup> potentially metastable signal to resolve to <sup>a</sup> known value before the signal is used in the rest of the design.





#### *Moore State Machine*



- The most frequently used form of description (behavior) of state machine is a diagram.
- The states of the machine are represented by circles.
- Transitions between states are represented by arrows.
- The transition conditions (combinations of inputs) are placed on the arrows.
- **In a Moore machine, the state of the outputs is clearly related to the state of the machine. The status of the outputs is placed inside the circles.**



#### *Moore State Machine*







**Generic Mealy model** 

- $\blacksquare$  The most frequently used form of description (behavior) of state machine is a diagram.
- $\textcolor{red}{\bullet}$  The states of the machine are represented by circles.
- **The Transitions between states are represented by arrows.**
- The transition conditions (combinations of inputs) are placed on the arrows.

 **In a Mealy machine, the state of the outputs is a function of the state of the machine and the inputs. The status of the outputs is placed on the arrows next to the status of the** 

**inputs.** 



#### *Automat Mealy'ego*





### *Synthesis of State Machines*

- **1. Drawing a diagram describing the state machine.**
- **2. Based on the diagram of the machine, draw a transition table and output table.**
- **3. Simplify the machine if possible.**
- **4. Encoding states.**
- **5. Selecting a flip-flop.**
- **6. Synthesis of combinational logic of transitions based on the transition table of the machine and the excitation table of the flip-flop.**
- **7. Synthesis of combinational logic of outputs based on the machine's output table.**
- **8. Drawing a complete diagram with gates and flip-flops.**



**TASK:** Design <sup>a</sup> control system for raising/lowering railway barriers, based on the signal from three train position sensors.





**TASK:** Design <sup>a</sup> control system for raising/lowering railway barriers, based on the signal from three train positionsensors.









*Example of State Machine synthesis - Guarded railway crossingTransition and output table*







*Example of State Machine synthesis - Guarded railway crossingRreduction of the number of states*





*Example of State Machine synthesis - Guarded railway crossingRreduction of the number of states*

## **B + C => BC**

#### $S_n$  **(Stan aktualny)X (wejścia)Sn+1 (Stan następny) <sup>b</sup> <sup>d</sup>A<sup>0</sup> <sup>0</sup> <sup>A</sup>BC <sup>0</sup> <sup>1</sup> BC<sup>1</sup> <sup>0</sup> - <sup>1</sup> <sup>1</sup> - BC<sup>0</sup> <sup>0</sup> BCBC <sup>0</sup> <sup>1</sup> BCDE <sup>1</sup> <sup>0</sup> DE <sup>1</sup> <sup>1</sup> - 00 DE DE<sup>0</sup> <sup>1</sup> <sup>F</sup> <sup>1</sup> <sup>0</sup> DE <sup>1</sup> <sup>1</sup> - F<sup>0</sup> <sup>0</sup> <sup>A</sup>** $\mathsf{F}$ **<sup>0</sup> <sup>1</sup> <sup>F</sup> <sup>1</sup> <sup>0</sup> - <sup>1</sup> <sup>1</sup> -**

# **D + E => DE**





*Example of State Machine synthesis - Guarded railway crossingState encoding*





*Example of State Machine synthesis - Guarded railway crossingTransition and output table*







*Example of State Machine synthesis - Guarded railway crossingTransition logic*





*D*1=*b*+*q*1 <sup>⋅</sup>*q*0+*q*1 $1 \cdot d$   $D_0 = b + q_1$  $1 \cdot d + d$  $a \cdot q_0$ 



*Example of State Machine synthesis - Guarded railway crossingOutput logic*



$$
Y_0 = b + \overline{q_1} \cdot q_0 + \overline{q_1} \cdot d
$$



### *Example of State Machine synthesis - Guarded railway crossingFull diagram*





#### *REFERENCE*

[1] dr hab. inż. Maciej Petko: Wykład – *Układy Sekwencyjne* z przedmiotu *Mechatronicze Systemy Wykonawcze, Sensoryczne i Sterujące*; KRiM AGH;

[2] dr inż. Konrad Gac: Wykład – *Układy Sekwencyjne* z przedmiotu *Mechatronicze Systemy Wykonawcze, Sensoryczne i Sterujące*; KRiM AGH;

[3] Barry Wilkinson: *Układy cyfrowe*; WKŁ

[4] Halina Kamionka-Mikuła, Henryk Małysiak, Bolesław Pochopień: Układy cyfrowe - teoria i przykłady; WPKJS;

[5] Wojciech Głocki: Układy cyfrowe; WSiP;

[6] Andrzej Skorupski: Podstawy techniki cyfrowej; WKŁ;

[7] prof. dr hab. in ̇z. Joanna Józefowska: *Kodowanie informacji - Reprezentacja liczb*; Poznań; rok akademicki 2010/2011;

[8] dr hab. inż. Mikołaj Morzy: *Wykład - kodowanie liczb*;

[9] Politechnika Łódzka: *Kodowanie liczb całkowitych w systemach komputerowych*; http://neo.dmcs.p.lodz.pl/ak/kodowanie\_liczb\_calkowitych.pdf