

## Process Termination

1. How is the process terminated?
2. What happens after termination?

The process is **terminated** in one of the following scenarios:

- ↳ executes all its instructions [return] } normal termination
- ↳ exits based on a given situation } abnormal termination
- ↳ killed by another privileged process }

## Normal Termination

<sys/wait.h> ↗ return = exit(0).

int exit (int status);

→ used to indicate whether the program executed successfully or if there were any errors

**Status:** a number (1 byte) (0 → 255) used by the process to tell its parent about its exit(status).

**N.B.**: each process running in the system has a PCB. when the process exits, it will stay on the system until his parent gets the info sent by the exit(status)

How the parent gets info about the death of the child?

↳ <sys/wait.h>  
int wait (int \*st\_ptr);  
pid = wait (&str\_ptr);

## Wait Statement:

the wait statement is a **blocking statement**, this means that the parent will **wait for the child to exit()**.

little demo:

parent

I<sub>1</sub>

I<sub>2</sub>

I<sub>3</sub>

I<sub>4</sub>

⋮

I<sub>n</sub>

pid = wait(&st)

child

I<sub>1</sub>

I<sub>2</sub>

⋮

I<sub>100</sub>

I<sub>101</sub>

⋮

I<sub>10n</sub>

exit(status)

↳ the wait function returns the pid of the exited child.

↳ the wait function is used for the first child that exits.

↳ if the parent has no children , wait returns -1

\* **while (wait (&str-pt) != -1);**

this means that the parent will wait for all the children to exit.

\* the parameter of the wait function is a pointer to int used for receiving the value sent by the child using the function exit(status).

\* **Wait (null);**  
ignores the return value sent by the child

**Note:** the returned status is put in the second byte of the integer  so the returned number is stored in ST as a different int, to solve this problem, we use:

ST = ST << 8 or ST = WEXITSTATUS(ST)

(these are used to shift 8 bits to the right).

**exit{}** : using exit and wait , parent and its child can make some **naïve communication**  
- some kind of **synchronization** \*

## Example:

array of integers (0 and 255)

```
int tab[10] = {12, 5, 3, 25, 16, 70, 112, 200, 240, 254};
```

\* determine the max of this vector

|                 |                |
|-----------------|----------------|
| parent<br>0 → 4 | child<br>5 → 9 |
|-----------------|----------------|

display the max on screen.

\* #include <unistd.h>

#include <stdlib.h>

#include <sys/wait.h>

```
int main(){
    int tab[10] = {12, 5, 3, 25, 16, 70, 112, 200, 240, 254}, j;
    if (pid = fork()) {
        int max = 0;
        for (int i = 0; i < 5; i++) {
            if (A[i] > max)
                max = A[i];
        }
        wait (&j); // j is max1.
        j = j << 8;
        if (max > j)
            printf ("%d", max);
        else
            printf ("%d", j);
    } else {
        int max1 = 0;
        for (int i = 5; i < 10; i++) {
            if (A[i] > max1)
                max1 = A[i];
        }
        exit (max1);
    }
}
```

`int sleep(int nsec)`

the process calling this function suspends its execution for nsec.

### Zombie Process:

- ↳ a child process that has completed its execution but still has an entry in the process table (process table entry contains process ID, exit status, etc).
- ↳ this occurs when the parent process hasn't yet collected the exit status of its child process. The operating system retains the zombie process entry in the process table until the 'wait' system call or similar mech.
- ↳ once the parent process collects the exit status of the child process to acknowledge their termination.

### Orphan Process:

- ↳ a child process whose parent process has terminated or been killed before the child process has completed its execution.
- ↳ orphan processes are typically adopted by the init process (process with pid=1). the init process becomes the new parent of the orphaned child process.
- ↳ Orphan processes continue their execution, and when they finish, they become zombie processes until the init process collects their exit status.

↳ Orphan processes are usually the result of a parent process creating a child process and then exiting unexpectedly before the child has completed its tasks.

Ex:

```
void main() {
    int pid;
    printf("I'm the main process with pid=%d\n",
           getpid());
    pid = fork();
    if (!pid) {
        printf("I'm the child process with pid=%d\n",
               getpid());
        exit(2);
    } else {
        sleep(100);
        wait(NULL);
    }
}
```

Output

child : pid=100  
parent: pid=90

## lecture3: Process Creation

How the process is created? Unix.



the main process in the unix is Init  $\rightarrow$  pid=1

- Initially when the system boots, a process (init) with pid=1 is started.
- In unix, the process are created by cloning! duplication  $\Rightarrow$  one process duplicated

je m'appelle j'lod

$P_1$  becomes parent.

$P_2$  child

- int fork();

```
#include <unistd.h>
int fork();
```



int fork()

|       |          |
|-------|----------|
| → -1  | failure  |
| → 0   | (child)  |
| → < 0 | (parent) |

pid of child.

```

Ex: void main() {
    int n, pid;
    n = 10;
    if (pid = fork())
        n = n + 5;
} printf("n=%d\n", n);

```

10  
15

15  
10



if (Pid = fork())  
 ↗ ① pid = fork();  
 ↗ ② if (pid) = if (pid != 0)

```

void main() {
    int a = 1; child.
    if (!fork()){
        a++;
        printf("%d\n", a);
    } else
        a++;
    printf("%d\n", a);
}

```

Output:  
 2 0 2  
 0 2 2  
 2 2 0

if (!fork())  
 ↗ pid = fork()  
 ↗ if (pid == 0)



```

Ex: void main(){
    if (fork())
        fork();
    else if (!fork())
        fork();
}

```

$\text{if } (\text{fork}()) \Rightarrow \text{Pid} = \text{fork}() = P_1$   
 $\text{if } (\text{Pid} < 0) \Rightarrow P_0.$



```

Ex: void main(){
    fork();
    fork();
    fork();
}

```



## Process Identification

- int getpid()  
returns the pid of the calling process.
  - int getppid()  
returns the pid of the parent of the calling process.

## Extra Exercises:

```
Ex: void main() {
    if (!fork())
        if (!fork())
            printf("I'm in\n");
    fork();
    printf ("I'm out\n");
}
```



- ```
- void main(){
    if (!fork())
        if (fork())
            printf ("I'm in\n");
    fork();
    printf ("I'm out\n");
}
```



## N.B: Break

```
- void main() {
    int i, j = 6;
    for( i=1; i<j; i++){
        if (!fork())
            break;
        else
            j=-i;
    }
    printf("i=%d, j=%d\n", i, j);
}
```

tree of process + output



Ex: void main()

```
int i=10, j=10;
for( i=0, i<2, i++) {
    if (fork()) · if parent break
        break;
    for(j=0, j<2, j++) {
        if (!fork()) · if child break
            break;
    }
    printf("%d,%d\n", i, j);
}
```



output: 0:0 10 4:22 8:20 12:21

1:12 5:20 9:21

2:10 6:21 10:22

3:11 7:22 11:20



# Lecture 2 - Process Management.

## Resource management

- ↳ process management
- ↳ memory management
- ↳ file system management
- ↳ I/O devices management
- ↳ security and protection

} OS responsible for managing these resources.

## I - What is a process?

- the process is a **program** in execution.
- ↳ **program**: set of instructions in machine language



## Example

**program**: steps of making a cake.

**process** : CPU is the baker, he uses the ingredients (data), and follows the recipe (instructions) to make the cake

## Actual Process Simplified

- When a program is run in a computer, its instructions are loaded into the RAM.
- The CPU fetches these instructions from memory, one at a time, decodes them, and then executes the instructions. (process)

Program → static  
Process → dynamic

## Multi programming mode (time-sharing model)

- execute several processes at the same time
- Only one CPU → shared resource



↳ it seems that 4 independent processes are happening in parallel (pseudo-parallelism)

- each process has a programming instruction, input, output, state, set of registers.
- a single processor (CPU) may be shared among several processes
- some scheduling algorithm is used to determine when to terminate a process and serve another one

## Each process has several attributes:

- 1- process id → pid (unique identifier)
- 2- state → to describe
- 3- priority
- 4- general purpose registers
  - ↳ PC (program counter)
  - ↳ IR for decode (instruction register)
  - ↳ accumulator
- 5- list of opened files
- 6- list of opened devices (I/O devices)
- 7- protection

## State of the process

- refers to the condition or status of a running program / process.
- each process can be in one of several states:
  - ↳ **running**: the process is currently being executed by the CPU
  - ↳ **ready**: the process was loaded into memory and is prepared to run but is waiting for its turn to execute on the CPU.
  - ↳ **blocked / waiting**: the process is in a state of waiting, often because it's waiting for some event, such as user input from an I/O device.
  - ↳ **terminated / exit**: the process has completed its execution and has been terminated. It may be waiting for the operating system to clean up resources (freeing memory, closing open files...) or for the parent process to collect exit status (determine outcome of the execution).



- 1 the process is created
- 2 the process gets to the CPU
  - the dispatcher elects the process to execute
- 3 the process makes I/O request so its blocked till the availability of the request
- 4 I/O request are now available
- 5 the process is not ended but its quantum time (slice of time) is expired or another process with higher priority arrives to ready queue
 

Context switching
- 6 the process is ended

**FIFO:** "First input, first out put" refers to a data processing principle in which the earliest data or request received is the first to be processed or served.

## Types of process

- ↳ CPU bound → it needs long time CPU (mathematical simulations)
- ↳ I/O bound → it needs long time I/O (reading files)

## Process Creation

PCB: Process Control Block, contains the attributes of each process (pid, state, priority,...)

in simpler terms: PCB is like a file that the computer uses to keep track of everything it's doing for each running program, such as what it's working on, where it's saved, and how much time it has used so far.

table of processes

| P <sub>i</sub> | PC | Pid | status | - | - | - | - |
|----------------|----|-----|--------|---|---|---|---|
| P <sub>1</sub> |    |     |        |   |   |   |   |
| P <sub>2</sub> |    |     |        |   |   |   |   |
| X →            |    |     |        |   |   |   |   |
| ⋮              |    |     |        |   |   |   |   |
| P <sub>n</sub> |    |     |        |   |   |   |   |

context  
PCB



FIFO (first  
input last  
output)

Dynamic

Variables  
(global)

instruction  
to execute

- When a process is created, it is assigned a process control block (PCB), which is stored in the table of processes located in the operating system's memory. The PCB contains essential info. about the process, including its process identifier (PID), status, priority, and pointers to the memory segments associated with this process, (Stack, Heap, Data, Code)

## How Process is Created

- 1- In UNIX, processes are created using a mechanism called "fork"
  - 2- A process (referred to as the "parent") can create a new process (the "child") by duplicating itself. This duplication includes copying the current state of the parent process such as its code, data, and file descriptors.
  - 3- When you start a UNIX-based system, the first process created has a process identifier (PID) of 1 and is known as "init". Init is responsible for initializing the system and starting other processes.
- The "fork" function is a system call provided by the "unistd.h" library in UNIX. When you call "fork()" in a program, it creates a new child process that is essentially a copy of the current (parent) process. The child process starts executing from the same point in the code as the parent process.

# Sequential Circuit

**Memory Elements:** Devices capable of storing information

**State of the Circuit at a Given Moment:**  
The Binary info stored at the el(s) at that moment

**(Combinational Circuit):** Outputs = Function(inputs)

**Sequential Circuit:**

Outputs = Function( inputs, circuit state)  
Next State = Function( present state, inputs)



Etat = state  
Sorties = output  
Suivant = next  
entrée = input

} common french terms.

When does the state of Seq. Circ. Change

- During the change of state of its inputs  
=> Asynchronous Sequential Circuit
- At discrete moments: Clock Signal.  
=> Synchronous / Clocked Sequential Circuit

Storage elements (memory) used in clocked sequential circuits are called Flip-Flops.

- A flip-flop is a binary storage device capable of storing a bit of information.
- In a stable state, the output of a flip-flop is 0 or 1.
- A sequential circuit can use multiple flip-flops to store as many bits as necessary.
- A change in the state of flip-flops is initiated only by a transition of the clock signal.

Example: the clock signal changes from 0 to 1.

the response time of the combinational circuit must be less than the period of the clock signal

An element of memory in a digital circuit can maintain a binary state indefinitely.

- Power supplied to the circuit
- Change of state according to an input signal

Differences between types of memory elements:

- Number of inputs
- How inputs affect the binary state

Latches: operate based on signal levels

FlipFlops: controlled by a clock transition



$$\begin{aligned} S = \text{Set} &= 1 \\ R = \text{Reset} &= 0 \end{aligned}$$

→ An active high SR latch is in stable (locked) condition when both inputs are low

$$Q(t+1) = \overline{R + \bar{Q}}$$

$$\overline{Q(t+1)} = \overline{(S + Q)}$$



latch initially reset



here in stable condition  
When both inputs are  
high

in  $\rightarrow$  we can't have both high  
in  $\circledast$  we can't have both low

$Q$  {  $Q \xrightarrow{\text{present}}$   
 $Q^+, Q^{++} \xrightarrow{\text{next}}$

$Q$   
 $Q(t+1)$

| S | R | $Q$ | $\bar{Q}$ |
|---|---|-----|-----------|
| 0 | 0 | q   | $\bar{q}$ |
| 0 | 1 | 0   | 1         |
| 1 | 0 | 1   | 0         |
| 1 | 1 | 0   | 0         |

No change (memory)  
Reset  
Set  
Invalid



- Quelle sera la sortie du Verrou  $\bar{S} - \bar{R}$  actif-BAS pour les entrées suivantes?



ISSUE: Issue with SR latches: parasitic signal on the inputs causing the latch to change

Solution: Latch with an enable (latched Latch)  
↳ EN must be high for the latch to respond to changes in S and R.



(a) Logic diagram



(b) Logic symbol

| En | S | R | Next state of Q       |
|----|---|---|-----------------------|
| 0  | X | X | No change             |
| 1  | 0 | 0 | No change             |
| 1  | 0 | 1 | $Q = 0$ ; reset state |
| 1  | 1 | 0 | $Q = 1$ ; set state   |
| 1  | 1 | 1 | Indeterminate         |



- Quelle est la forme d'onde de sortie Q si les entrées suivantes sont appliquées sur un verrou avec ENABLE étant initialement en état RESET



## Issue: Invalid Inputs | For bidden State

Solution: D Latch

- Single input D (for Data) + EN
- Our pur Q follows D + EN.
  - D = high, EN = high => Latch Set
  - D = low, EN = high => Latch Reset



(a) Logic diagram



(b) Logic symbol

No change => EN=0  
 Set => D=1  
 Reset => D=0

## Flip Flops

- A flip flop differs from a latches in the way it changes state.
- Clocked device, where only the clocked edge determines when a new bit is entered.
  - The active edge can be positive (rising) or negative (falling)



## D flip flop

the D input of the D flip flop is synchronous  
 ↳ the input is transmitted to the flip flop's output on the active edge (rising or falling) of the clock

### Truth Table (Rising Edge)

| D | CLK | Q | $\bar{Q}$ |
|---|-----|---|-----------|
| 0 | ↑   | 0 | 1         |
| 1 | ↑   | 1 | 0         |

Reset

Set

- Quelles sont les formes d'onde des sorties Q et  $\bar{Q}$  de la bascule pour les entrées D et CLK suivantes



## JK Flip Flop

- D flip flop most used in logic circuits
- requires fewer gates for its construction
- other flip flops: JK and T
- Three operations: set - reset - toggle.
- D flip flop allows two operations: set and reset.
- JK flip flop allows all three operations

\* The J and K inputs of the JK flip flop are synchronous.  
→ inputs are transmitted to the flip flop's output on the active edge (rising or falling) of the clock.

## Truth Table:

| J | K | clk | Q           | $\bar{Q}$   |
|---|---|-----|-------------|-------------|
| 0 | 0 | ↑   | $Q_0$       | $\bar{Q}_0$ |
| 0 | 1 | ↑   | 0           | 1           |
| 1 | 0 | ↑   | 1           | 0           |
| 1 | 1 | ↑   | $\bar{Q}_0$ | $Q_0$       |

No change (memory)  
Reset  
Set  
Toggle.



(a)  $J = 1, K = 0$  flip-flop SETS on positive clock edge. (If already SET, it remains SET.)



(b)  $J = 0, K = 1$  flip-flop RESETS on positive clock edge. (If already RESET, it remains RESET.)



(c)  $J = 1, K = 1$  flip-flop changes state (toggle).



(d)  $J = 0, K = 0$  flip-flop does not change. (If SET, it remains SET; if RESET, it remains RESET.)

- Quelle est la forme d'onde Q à la sortie de la bascule J-K pour les formes d'onde d'entrée suivantes? (Note: front actif descendant)



(falling edge active)

Design and Implement a JK flip flop using a D flip flop and logic gates

| J | K | Q | $Q^*$ | D |
|---|---|---|-------|---|
| 0 | 0 | 0 | 0     | 0 |
| 0 | 0 | 1 | 1     | 1 |
| 0 | 1 | 0 | 0     | 0 |
| 0 | 1 | 1 | 0     | 0 |
| 1 | 0 | 1 | 1     | 1 |
| 1 | 0 | 1 | 1     | 1 |
| 1 | 1 | 0 | 1     | 1 |
| 1 | 1 | 1 | 0     | 0 |

| JK | Q | 0 | 1 |
|----|---|---|---|
| 00 | 0 | 0 | 1 |
| 01 | 0 | 1 | 1 |
| 11 | 1 | 1 | 1 |
| 10 | 1 | 1 | 1 |



$$D = Q^* = \bar{J}Q + \bar{K}Q$$



(a) Circuit diagram

(b) Graphic symbol

$$D = J\bar{Q} + \bar{K}Q$$

### D flip flop in toggle mode

- D can operate in toggle mode by conn the output Q to D
- the flip flop only changes on the active edge  $\Rightarrow$  the output changes only with each clock pulse



## Flip Flop T

$T = 0 \Rightarrow$  unchanged state  
 $T = 1 \Rightarrow$  toggle.

| Q | T | Q <sub>ck</sub> | Q <sup>+</sup> |
|---|---|-----------------|----------------|
| 0 | 0 | ↑               | 0              |
| 0 | 1 | P               | 1              |
| 1 | 0 | ↑               | 1              |
| 1 | 1 | ↑               | 0              |

$$Q^+ = Q \oplus T$$



Design and implement a T flip flop using  
a) D flip flop  
b) JK flip flop.

a)  $D = Q^+ = Q \oplus T$



| T | Q | Q <sup>+</sup> | J | K | J K |
|---|---|----------------|---|---|-----|
| 0 | 0 | 0              | 0 | 0 | 0 X |
| 0 | 1 | 1              | 0 | 0 | X 0 |
| 1 | 0 | 1              | 1 | 0 | 1 X |
| 1 | 1 | 0              | 0 | 1 | X 1 |

| T | Q | Q <sup>+</sup> | J | K |
|---|---|----------------|---|---|
| 0 | 0 | 0              | 0 | 0 |
| 0 | 1 | 1              | 0 | 0 |
| 1 | 0 | 1              | 1 | 0 |
| 1 | 1 | 0              | 0 | 1 |

$$J = T \quad K = T$$



Characteristic Table relationship b/w current state and next state of the flip flop based on inputs

| JK: | J | K | Q* |
|-----|---|---|----|
| 0 0 | Q |   |    |
| 0 1 | 0 |   |    |
| 1 0 | 1 |   |    |
| 1 1 | Q |   |    |

| D: | D | Q* |
|----|---|----|
| 0  | 0 |    |
| 1  | 1 |    |

| T: | T  | Q* |
|----|----|----|
| 0  | Q  |    |
| 1  | Q̄ |    |

## Characteristic Equations:

flip flop D:  $Q(t+1) = D$

flip flop JK:  $Q(t+1) = J\bar{Q} + \bar{K}Q$

flip flop T:  $Q(t+1) = T \oplus Q = T\bar{Q} + \bar{T}Q$



$$D = J\bar{Q} + \bar{K}Q$$



Next State =  $f(\text{inputs, present state})$

## Synchronous Inputs

Synchronous inputs (D or J-K) are transferred to the active edge of the clock.

Most flip-flops have asynchronous inputs

- Affect the output independently of the clock.

- Normally called PRESET (PRE) and CLEAR (CLR)

- Usually Active-LOW

Connected to override the input effect synchronous D and the clock.

- PRESET and CLEAR are not practically low in same time

*preset = 0  $\Rightarrow Q_n = 1$*

*clear = 0  $\Rightarrow Q_n = 0$  because  $Q_n = 1$*

regardless of the values  
of clock and syn. inputs

| PR | CLR | $Q_n$                 |
|----|-----|-----------------------|
| 0  | 0   | INDEFINITE            |
| 0  | 1   | 1                     |
| 1  | 0   | 0                     |
| 1  | 1   | will perform normally |



## Flip Flop Usage

→ Parallel Storage of Data

⇒ A group of flip flops are connected to data lines parallel and clocked at the same time.

⇒ The Data is stored until the clock pulse next



# Analysis of Clocked Sequential Circuits

The analysis of a sequential circuit consists of:

- obtaining a state equation or transition equation
- obtaining a table state for the time sequence of inputs, outputs, and internal state.
- Draw a state diagram
- Draw a timing diagram



input(s):  $u$

flipflops: 2 D flipflops :  $D_A, D_B$

output(s):  $y$

$$Q(t+1) = D$$

$$A(t+1) = A u + B \bar{u}$$

$$B(t+1) = \bar{A} u$$

$$y(t) = (A+B)\bar{u}$$

} state equations

## State Table

| Present State | Input | Next State | Output |
|---------------|-------|------------|--------|
| A B           | $u$   | A B        | $y$    |
| 0 0           | 0     | 0 0        | 0      |
| 0 0           | 1     | 0 1        | 0      |
| 0 1           | 0     | 0 0        | 1      |
| 0 1           | 1     | 1 1        | 0      |
| 1 0           | 0     | 0 0        | 1      |
| 1 0           | 1     | 1 0        | 0      |
| 1 1           | 0     | 0 0        | 1      |
| 1 1           | 1     | 1 0        | 0      |

OR

| Present State | Next State |       | Output |       |
|---------------|------------|-------|--------|-------|
| A B           | $x=0$      | $x=1$ | $x=0$  | $x=1$ |
| 0 0           | 0 0        | 0 1   | 0      | 0     |
| 0 1           | 0 0        | 1 1   | 1      | 0     |
| 1 0           | 0 0        | 1 0   | 1      | 0     |
| 1 1           | 0 0        | 1 0   | 1      | 0     |

# State Diagram



Note:  $n$  flipflops  
 $\rightarrow 2^n$  states.



## Example (D flipflop)

- Analyser le circuit décrit par l'équation d'entrée

$$D_A = A \oplus x \oplus y$$

- Pas d'équation de sortie  $\Rightarrow$  la sortie est celle de la bascule  $\Rightarrow A$

No output equation  $\Rightarrow$  the output is that of the flip flop  $\Rightarrow A$ .

inputs:  $x, y$   
 flipflops: 1 D flipflop (A)  
 outputs:  $A$ .



State Equation:  $A(t+1) = A^+ = A^* = D_A = A \oplus x \oplus y$

### State Table:

| A | x | y | $A^+$ |
|---|---|---|-------|
| 0 | 0 | 0 | 0     |
| 0 | 0 | 1 | 1     |
| 0 | 1 | 0 | 1     |
| 0 | 1 | 1 | 0     |
| 1 | 0 | 0 | 1     |
| 1 | 0 | 1 | 0     |
| 1 | 1 | 0 | 0     |
| 1 | 1 | 1 | 1     |

### State Diagram:



# JK Flip Flop Analysis Diagram



Input(s):  $u$   
 FlipFlop(s): 2 JK ff. A, B  
 Output(s): no output

State Table:

| A | B | $u$ | $A^*$ | $B^*$ | $J_A$ | $K_A$ | $J_B$ | $K_B$ |
|---|---|-----|-------|-------|-------|-------|-------|-------|
| 0 | 0 | 0   | 0     | 1     | 0     | 0     | 1     | 0     |
| 0 | 0 | 1   | 0     | 0     | 0     | 0     | 0     | 1     |
| 0 | 1 | 0   | 1     | 1     | 1     | 1     | 1     | 0     |
| 0 | 1 | 1   | 1     | 0     | 1     | 0     | 0     | 1     |
| 1 | 0 | 0   | 1     | 1     | 0     | 0     | 1     | 1     |
| 1 | 0 | 1   | 1     | 0     | 0     | 0     | 0     | 0     |
| 1 | 1 | 0   | 0     | 0     | 1     | 1     | 1     | 1     |
| 1 | 1 | 1   | 1     | 1     | 1     | 0     | 0     | 0     |

I/O Equations

$$\begin{aligned}
 J_A &= B \\
 K_A &= B\bar{u} \\
 J_B &= \bar{u} \\
 K_B &= A \oplus u
 \end{aligned}$$



| $A^*$ : | $x$ | 0 | 1 |
|---------|-----|---|---|
| $AB$    |     | 0 | 1 |
| 00      | 00  | 0 | 0 |
| 01      | 11  | 1 | 1 |
| 11      | 01  | 0 | 1 |
| 10      | 11  | 1 | 1 |

| $B^*$ : | $u$ | 0 | 1 |
|---------|-----|---|---|
| $AB$    |     | 0 | 1 |
| 00      | 00  | 1 | 0 |
| 01      | 11  | 1 | 0 |
| 11      | 01  | 0 | 1 |
| 10      | 11  | 1 | 0 |

State Equations

$$A^* = \bar{A}B + Bu + A\bar{B}$$

$$B^* = \bar{A}\bar{u} + \bar{B}\bar{u} + ABu$$

# T Flip Flop Analysis Diagram



Input(s) :  $x$

Flip flop(s) : 2 T flip flops A, B

Output(s) :  $y$

Input Equation:

$$T_A = Bu$$

$$T_B = u$$

$$y = AB$$

| A | B | $\bar{u}$ | $A^*$ | $B^*$ | $T_A$ | $T_B$ | y |
|---|---|-----------|-------|-------|-------|-------|---|
| 0 | 0 | 0         | 0     | 0     | 0     | 0     | 0 |
| 0 | 0 | 1         | 0     | 1     | 0     | 1     | 0 |
| 0 | 1 | 0         | 0     | 1     | 0     | 0     | 0 |
| 0 | 1 | 1         | 1     | 0     | 1     | 1     | 0 |
| 1 | 0 | 0         | 1     | 0     | 0     | 0     | 0 |
| 1 | 0 | 1         | 1     | 1     | 0     | 1     | 0 |
| 1 | 1 | 0         | 1     | 1     | 0     | 0     | 1 |
| 1 | 1 | 1         | 0     | 0     | 1     | 1     | 1 |

| $A^*$ : | $A_B \setminus x$ | 0 | 1 |
|---------|-------------------|---|---|
| 00      | 00                | 0 | 0 |
| 01      | 01                | 0 | 1 |
| 10      | 11                | 1 | 1 |
| 11      | 10                | 1 | 0 |

| $B^*$ : | $A_B \setminus \bar{u}$ | 0 | 1 |
|---------|-------------------------|---|---|
| 00      | 00                      | 0 | 1 |
| 01      | 01                      | 1 | 0 |
| 11      | 11                      | 1 | 0 |
| 10      | 10                      | 0 | 1 |

State Equations:

$$A^* = \bar{A}Bx + A\bar{u} + A\bar{B}$$

$$B^* = B\bar{x} + \bar{B}x = B \oplus x$$



Mealy and Moore

Mealy Model: output is a function of both the present state and the input

Moore Model: output is a function of only the present state

In a Moore Model the outputs of the seq. circuit are synchronized with the clock, because they depend only on flip-flop outputs that are synchronized with the clock

The output of the Mealy Machine is the value that is present immediately before the active edge of the clock

Basically when the output is independent of the input (ex:  $y = \overline{Q_B} + Q_A$ ) it's Moore.

| Mealy        |   | Moore        |   |   |   |
|--------------|---|--------------|---|---|---|
| Etat Present | E | Etat Suivant | S |   |   |
| A            | B | x            | A | B | y |
| 0 0          | 0 | 0 0          | 0 | 0 | 0 |
| 0 0          | 1 | 0 1          | 0 | 0 | 0 |
| 0 1          | 0 | 0 0          | 1 | 0 | 1 |
| 0 1          | 1 | 1 1          | 0 | 1 | 0 |
| 1 0          | 0 | 0 0          | 1 | 0 | 1 |
| 1 0          | 1 | 1 0          | 0 | 1 | 0 |
| 1 1          | 0 | 0 0          | 1 | 1 | 1 |
| 1 1          | 1 | 1 0          | 0 | 1 | 0 |

| Mealy        |   | Moore        |   |   |   |
|--------------|---|--------------|---|---|---|
| Etat Present | E | Etat Suivant | S |   |   |
| A            | B | x            | A | B | y |
| 0 0          | 0 | 0 0          | 0 | 0 | 0 |
| 0 0          | 1 | 0 1          | 0 | 0 | 0 |
| 0 1          | 0 | 0 1          | 0 | 1 | 0 |
| 0 1          | 1 | 1 0          | 0 | 0 | 0 |
| 1 0          | 0 | 1 0          | 0 | 1 | 0 |
| 1 0          | 1 | 1 1          | 0 | 1 | 1 |
| 1 1          | 0 | 1 1          | 1 | 1 | 1 |
| 1 1          | 1 | 0 0          | 1 | 0 | 0 |



## Design of Timed Sequential Circuit

Example:

Detect 3 or more consecutive 1's



4 States  $\Rightarrow$  2 flipflops

| State          | A | B |
|----------------|---|---|
| S <sub>0</sub> | 0 | 0 |
| S <sub>1</sub> | 0 | 1 |
| S <sub>2</sub> | 1 | 0 |
| S <sub>3</sub> | 1 | 1 |



| Present State | Input | Next State | Output         |                |   |
|---------------|-------|------------|----------------|----------------|---|
| A             | B     | u          | A <sup>+</sup> | B <sup>+</sup> | y |
| 0             | 0     | 0          | 0              | 0              | 0 |
| 0             | 0     | 1          | 0              | 1              | 0 |
| 0             | 1     | 0          | 0              | 0              | 0 |
| 0             | 1     | 1          | 1              | 0              | 0 |
| 1             | 0     | 0          | 0              | 0              | 0 |
| 1             | 0     | 1          | 1              | 1              | 0 |
| 1             | 1     | 0          | 0              | 0              | 1 |
| 1             | 1     | 1          | 1              | 1              | 1 |

Flip Flop D: State equation = Input Equation

$$A^+ = D_A \quad B^+ = D_B \quad y = ?$$

| A <sup>u</sup> | B <sup>u</sup> | 0 | 1 |
|----------------|----------------|---|---|
| 00             | 0              | 0 | 0 |
| 01             | 0              | 1 |   |
| 11             | 0              | 1 |   |
| 10             | 0              | 1 |   |

| A <sup>u</sup> | B <sup>u</sup> | 0 | 1 |
|----------------|----------------|---|---|
| 00             | 0              | 1 | u |
| 01             | 0              | 0 |   |
| 11             | 0              | 1 |   |
| 10             | 0              | 1 |   |

$$\begin{aligned} A^+ &= B u + A u \\ &= u(A + B) \end{aligned}$$

$$\begin{aligned} B^+ &= A u + \bar{B} u \\ &= u(A + \bar{B}) \end{aligned}$$



# Excitation Table

| Etat<br>Présent | Etat<br>Suivant | Entrée<br>Bascule |
|-----------------|-----------------|-------------------|
| $Q(t)$          | $Q(t+1)$        | $D$               |
| 0               | 0               | 0                 |
| 0               | 1               | 1                 |
| 1               | 0               | 0                 |
| 1               | 1               | 1                 |

| Etat<br>Présent | Etat<br>Suivant | Entrée<br>Bascule |
|-----------------|-----------------|-------------------|
| $Q(t)$          | $Q(t+1)$        | $J$ $K$           |
| 0               | 0               | 0   x             |
| 0               | 1               | 1   x             |
| 1               | 0               | x   1             |
| 1               | 1               | x   0             |

- 0 0 (No change)
- 0 1 (Reset)
- 0 0 (Set)
- 1 1 (Toggle)
- 0 1 (Reset)
- 1 1 (Toggle)
- 0 0 (No change)
- 1 0 (Set)

| $Q(t)$ | $Q(t+1)$ | $T$ |
|--------|----------|-----|
| 0      | 0        | 0   |
| 0      | 1        | 1   |
| 1      | 0        | 1   |
| 1      | 1        | 0   |

JK Flip Flop: WAY 1

| Etat<br>Présent | Entrée | Etat<br>Suivant | Entrée Bascule          |
|-----------------|--------|-----------------|-------------------------|
| $A$ $B$         | $x$    | $A$ $B$         | $J_A$ $K_A$ $J_B$ $K_B$ |
| 0 0             | 0      | 0 0             | 0 x 0 x                 |
| 0 0             | 1      | 0 1             | 0 x 1 x                 |
| 0 1             | 0      | 0 0             | 0 x x 1                 |
| 0 1             | 1      | 1 0             | 1 x x 1                 |
| 1 0             | 0      | 0 0             | x 1 0 x                 |
| 1 0             | 1      | 1 1             | x 0 1 x                 |
| 1 1             | 0      | 0 0             | x 1 x 1                 |
| 1 1             | 1      | 1 1             | x 0 x 0                 |

| $J_A:$ $\bar{AB}$ | 0 | 1 |
|-------------------|---|---|
| 00                |   |   |
| 01                |   | 1 |
| 11                | x | x |
| 10                | x | x |

$$J_A = B\bar{a}$$

| $K_A:$ $\bar{AB}$ | 0 | 1 |
|-------------------|---|---|
| 00                | x | x |
| 01                | x | x |
| 11                | 1 |   |
| 10                | 1 |   |

$$K_A = \bar{a}u$$

| $J_B:$ $\bar{AB}$ | 0 | 1 |
|-------------------|---|---|
| 00                | 1 |   |
| 01                | x | x |
| 11                | x | x |
| 10                | 1 |   |

$$J_B = u$$

| $K_B:$ $\bar{AB}$ | 0 | 1 |
|-------------------|---|---|
| 00                | x | x |
| 01                | 1 | 1 |
| 11                | 1 |   |
| 10                | x | x |

$$K_B = \bar{u} + \bar{A}$$

$$Y = AB$$



WAY 2:

$$Q^+ = J\bar{Q} + \bar{K}Q$$

$$\begin{aligned} Q = 0 &\Rightarrow Q^+ = J \\ Q = 1 &\Rightarrow Q^+ = \bar{K} \end{aligned}$$

| Present State | Input | Next State | Output         |                |   |
|---------------|-------|------------|----------------|----------------|---|
| A             | B     | u          | A <sup>+</sup> | B <sup>+</sup> | y |
| 0             | 0     | 0          | 0              | 0              | 0 |
| 0             | 0     | 1          | 0              | 1              | 0 |
| 0             | 1     | 0          | 0              | 0              | 0 |
| 0             | 1     | 1          | 1              | 0              | 0 |
| 1             | 0     | 0          | 0              | 0              | 0 |
| 1             | 0     | 1          | 1              | 1              | 0 |
| 1             | 1     | 0          | 0              | 0              | 1 |
| 1             | 1     | 1          | 1              | 1              | 1 |

$$\begin{aligned} A^+ &= \bar{J}A\bar{A} + \bar{K}_{AA} \\ A=0 &\quad \bar{J}A = A^+ \\ A=1 &\quad \bar{K}_A = \bar{A}^+ \end{aligned}$$

$$\begin{aligned} B^+ &= \bar{J}B\bar{B} + \bar{K}_{BB} \\ B=0 &\quad \bar{J}B = B^+ \\ B=1 &\quad \bar{K}_B = \bar{B}^+ \end{aligned}$$

|     |    | A <sup>+</sup> |   |
|-----|----|----------------|---|
|     |    | A <sub>B</sub> | u |
|     |    | 0              | 1 |
| A=0 | 00 | 0              | 0 |
|     | 01 | 1              |   |
|     | 11 | / / / 1        |   |
|     | 10 | / / / 1        |   |

|     |    | A <sup>+</sup> |   |
|-----|----|----------------|---|
|     |    | A <sub>B</sub> | u |
|     |    | 0              | 1 |
| A=0 | 00 | 0              | 0 |
|     | 01 | / / / 1        |   |
|     | 11 | 1              |   |
|     | 10 | 1              |   |

$$J_A = \bar{A}Bx = Bx$$

$$K_B = \bar{A}x = \bar{x}$$

|     |    | B <sup>+</sup> |   |
|-----|----|----------------|---|
|     |    | B <sub>A</sub> | u |
|     |    | 0              | 1 |
| B=0 | 00 | 0              | 1 |
|     | 01 | / / / 1        |   |
|     | 11 | / / / 1        |   |
|     | 10 | 1              |   |

$$J_A = \bar{B}x = x$$

|     |    | B <sup>+</sup> |   |
|-----|----|----------------|---|
|     |    | B <sub>A</sub> | u |
|     |    | 0              | 1 |
| B=1 | 00 | 1 / / /        |   |
|     | 01 | 01             |   |
|     | 11 | 11             |   |
|     | 10 | 11             |   |

|     |    | B <sup>+</sup> |   |
|-----|----|----------------|---|
|     |    | B <sub>A</sub> | u |
|     |    | 0              | 1 |
| B=1 | 00 | 1 / / /        |   |
|     | 01 | 1              |   |
|     | 11 | 1              |   |
|     | 10 | 1              |   |

|     |    | B <sup>+</sup> |   |
|-----|----|----------------|---|
|     |    | B <sub>A</sub> | u |
|     |    | 0              | 1 |
| B=1 | 00 | 1 / / /        |   |
|     | 01 | 1              |   |
|     | 11 | 1              |   |
|     | 10 | 1              |   |

T Flip Flop:

| Etat Présent | Entrée | Etat Suivant | Entrée Bascule                    |
|--------------|--------|--------------|-----------------------------------|
| A            | B      | x            | A B T <sub>A</sub> T <sub>B</sub> |
| 0            | 0      | 0            | 0 0 0 0                           |
| 0            | 0      | 1            | 0 1 0 1                           |
| 0            | 1      | 0            | 0 0 0 1                           |
| 0            | 1      | 1            | 1 0 1 1                           |
| 1            | 0      | 0            | 0 0 1 0                           |
| 1            | 0      | 1            | 1 1 0 1                           |
| 1            | 1      | 0            | 0 0 1 1                           |
| 1            | 1      | 1            | 0 0 0 0                           |

|                |    | T <sub>A</sub> |   |
|----------------|----|----------------|---|
|                |    | T <sub>A</sub> | u |
|                |    | 0              | 1 |
| T <sub>A</sub> | 00 |                |   |
|                | 01 |                | 1 |
|                | 11 | 1              |   |
|                | 10 | 1              |   |

$$T_A = A\bar{x} + \bar{A}Bx$$

|                |    | T <sub>B</sub> |   |
|----------------|----|----------------|---|
|                |    | T <sub>B</sub> | u |
|                |    | 0              | 1 |
| T <sub>B</sub> | 00 |                | 1 |
|                | 01 | 1              |   |
|                | 11 | 1              |   |
|                | 10 | 1              |   |

$$\begin{aligned} T_B &= B\bar{x} + \bar{B}Ax + \bar{A}u \\ &= B \oplus x \times \bar{A}u \\ \text{or } & B \oplus u + \bar{A}B \end{aligned}$$

# Exercise



- Give the input and output equations of this circuit.
- Give the state table of this circuit.
- Draw the circuit state diagram.
- Deduce if this circuit is a Mealy or Moore system. Justify your answer.
- Re-implement the circuit using JK flip-flops

a) input(s):  $x$

flip flops: 2 D flip flops  $D_1, D_2$ .

output(s):  $y$ .

$$D_A = x$$

$$D_B = \bar{A}$$

$$y = \bar{A}_1 \cdot \bar{B}$$

}

$$D_1 = in$$

$$D_2 = \bar{Q}_1$$

$$Y = \bar{Q}_1 \bar{Q}_2$$

b)

| present state | inp | next state | out   |       |     |
|---------------|-----|------------|-------|-------|-----|
| A             | B   | $x$        | $A^+$ | $B^+$ | $Y$ |
| 0             | 0   | 0          | 0     | 1     | 1   |
| 0             | 0   | 1          | 1     | 1     | 1   |
| 0             | 1   | 0          | 0     | 1     | 0   |
| 0             | 1   | 1          | 1     | 1     | 0   |
| 1             | 0   | 0          | 0     | 0     | 0   |
| 1             | 0   | 1          | 1     | 0     | 0   |
| 1             | 1   | 0          | 0     | 0     | 0   |
| 1             | 1   | 1          | 0     | 0     | 0   |

c)



d) Moore since the output isn't influenced by the input, as in the output for each state doesn't change with the change of input.

$$e) A^+ = \bar{J}A + \bar{K}A$$

$$A=0 \quad A^+ = J$$

$$A=1 \quad A^+ = \bar{K}$$

$$B^+ = \bar{J}\bar{B} + \bar{K}B$$

$$B=0 \quad B^+ = J$$

$$B=1 \quad B^+ = \bar{K}$$

| $A^+$ | 0  | 1  |
|-------|----|----|
| AB    | 00 | 01 |
|       | 01 | 10 |
|       | 11 | 01 |
|       | 10 | 00 |

| $B^+$ | 0  | 1  |
|-------|----|----|
| AB    | 00 | 11 |
|       | 01 | 11 |
|       | 11 | 00 |
|       | 10 | 00 |

$$J_A = \bar{A}x = x$$

$$K_A = \bar{A}\bar{x} = \bar{A} + \bar{x} = \bar{x}$$

$$J_B = \bar{A}\bar{B} = \bar{A}$$

$$K_B = \bar{A}B = A + \bar{B} = A$$

$$Y = \bar{A}\bar{B}$$



Construct a JK flip-flop using a D flip-flop, a two-to-one-line multiplexer, and an inverter.

Show that the characteristic equation for the complement output of a JK flip-flop is

$$Q'(t+1) = J'Q' + KQ$$

A PN flip-flop has four operations: clear to 0, no change, complement, and set to 1, when inputs P and N are 00, 01, 10, and 11, respectively.

(a) Tabulate the characteristic table.      (b) Derive the characteristic equation.



$$\text{JK: } Q^+ = J\bar{Q} + \bar{K}Q$$

$$\text{D: } Q^+ = D$$

# Counters

## Asynchronous



divides freq.  
by 2.  
counts from 0-7



## Asynchronous Decade Counters

Count from 0-9, when it reaches 1010, the counter resets



## Synchronous



$Q_2 Q_1 Q_0$

0 0 0

0 0 1

0 1 0

0 1 1

1 0 0

1 0 1

1 1 0

1 1 1

$Q_2 = 1$   
when  
 $Q_1 Q_0 = 1$

Analyse: circuit  $\rightarrow$  Input Equation  $\rightarrow$  State Eq.  $\rightarrow$  State Table  $\rightarrow$  State Diagram  $\rightarrow$  function

Design: Problem  $\rightarrow$  State Diagram  $\rightarrow$  State Table  $\rightarrow$  State Eq.  $\rightarrow$  Scheme circ.

### 4 bits counter



### Synchronous BCD Counter

-  $Q_0$  toggles on each clock pulse  $\Rightarrow J_0 = K_0 = 1$

-  $Q_1$  toggles on next clock pulse each time  $Q_0 = 1 \wedge Q_1 = 0$   
 $\Rightarrow J_1 = K_1 = Q_0 \cdot \bar{Q}_3$

-  $Q_2$  toggles on next clock pulse

each time both  $Q_0 \wedge Q_1 = 1$   
 $\Rightarrow J_2 = K_2 = Q_0 \cdot Q_1$

$Q_3$  toggles for 2 conditions :

1)  $Q_0 = 1, Q_1 = 1, Q_2 = 1$ .

2)  $Q_0 = 1, Q_3 = 1$

$$\Rightarrow J_3 = K_3 = Q_0 \cdot Q_1 \cdot Q_2 + Q_0 \cdot Q_3$$



} counts up or down

## Exercise

Develop a 3-bit synchronous up/down counter for a sequence of UP/DOWN counter for a sequence of a 3-bit gray code in using JK flipflops. The counter must count UP when the UP/DOWN input is 1 and down if input is 0.

→ Binary

0 0 0

0 0 1

0 1 0

0 1 1

1 0 0

1 0 1

1 1 0

1 1 1

Gray

0 0 0

0 0 1

0 1 1

0 1 0

1 1 0

1 1 1

1 0 1

1 0 0

$Q_2 \ Q_1 \ Q_0$

0 0 0

0 0 1

0 1 1

0 1 0

1 1 0

1 1 1

1 0 1

1 0 0



| A | B | C | X | $A^{-1}$ | $B^*$ | $C^+$ |
|---|---|---|---|----------|-------|-------|
| 0 | 0 | 0 | 0 | 1        | 0 0   |       |
| 0 | 0 | 0 | 1 | 0        | 0 1   |       |
| 0 | 0 | 1 | 0 | 0        | 0 0   | 0     |
| 0 | 1 | 1 | 0 | 1        | 1 1   | 1     |
| 0 | 1 | 0 | 0 | 0        | 1 1   | 1     |
| 0 | 1 | 0 | 1 | 1        | 1 1   | 1     |
| 0 | 1 | 0 | 1 | 1        | 1 1   | 0     |
| 0 | 1 | 1 | 0 | 0        | 0 1   | 1     |
| 0 | 1 | 1 | 1 | 0        | 1 0   | 0     |
| 1 | 0 | 0 | 0 | 1        | 0 1   | 1     |
| 1 | 0 | 0 | 1 | 0        | 0 0   | 0     |
| 1 | 0 | 1 | 0 | 1        | 1 1   | 1     |
| 1 | 0 | 1 | 1 | 1        | 1 1   | 1     |
| 1 | 0 | 1 | 1 | 1        | 1 0   | 0     |
| 1 | 1 | 0 | 0 | 0        | 1 0   | 0     |
| 1 | 1 | 0 | 1 | 1        | 1 1   | 1     |
| 1 | 1 | 1 | 0 | 1        | 1 0   | 0     |
| 1 | 1 | 1 | 1 | 1        | 1 1   | 1     |

| $\cancel{AB}$ | 00 | 01 | 11                      | 10 |
|---------------|----|----|-------------------------|----|
| 00            | 1  |    | $\bar{B}\bar{C}\bar{x}$ |    |
| 01            |    | 1  | $+ \bar{B}\bar{C}x$     |    |
| 11            |    |    |                         |    |
| 10            |    |    |                         |    |

  

| $\cancel{AB}$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 00            | 1  |    |    |    |
| 01            |    | 1  |    |    |
| 11            | 0  | 1  | 1  | 1  |
| 10            | 1  | 0  | 1  | 1  |

| $\cancel{AB}$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 00            | 1  |    |    |    |
| 01            |    | 1  |    |    |
| 11            | 0  | 1  | 1  | 1  |
| 10            | 1  | 0  | 1  | 1  |

| $\cancel{AB}$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 00            | 1  |    |    |    |
| 01            |    | 1  |    |    |
| 11            | 1  | 1  | 0  | 1  |
| 10            |    |    |    |    |

| $\cancel{AB}$ | 00 | 01 | 11 | 10 |
|---------------|----|----|----|----|
| 00            | 1  | 1  | 0  |    |
| 01            |    | 0  | 1  |    |
| 11            | 0  | 1  | 0  |    |
| 10            | 1  | 1  | 0  |    |

$$B\bar{x} + \bar{B}x$$

$$Bx + \bar{B}\bar{x}$$

$$J_A = \bar{B}\bar{C}\bar{x} + \bar{B}\bar{C}x$$

$$J_B = \bar{A}C\bar{x} + AC\bar{x}$$

$$J_C = B\bar{x} + \bar{B}\bar{x} = B \oplus x$$

$$K_A = B\bar{C}\bar{x} + \bar{B}\bar{C}x$$

$$K_B = AC\bar{x} + \bar{A}C\bar{x}$$

$$K_C = Bx + \bar{B}\bar{x} = B \odot x$$

## Exercise

Develop the sequence of the following counter.



$$\begin{aligned}
 D_0 &= \overline{Q_1} \overline{Q_2}, & Q_2^* &= D_2 \\
 D_1 &= Q_0, & Q_1^* &= D_1 \\
 D_2 &= Q_1, & Q_0^* &= D_0
 \end{aligned}$$

| $Q_2$ | $Q_1$ | $Q_0$ | $Q_2^*$ | $Q_1^*$ | $Q_0^*$ |
|-------|-------|-------|---------|---------|---------|
| 0     | 0     | 0     | 0       | 0       | 1       |
| 0     | 0     | 1     | 0       | 1       | 1       |
| 0     | 1     | 1     | 1       | 1       | 1       |
| 1     | 1     | 1     | 1       | 1       | 0       |
| 1     | 1     | 0     | 1       | 0       | 0       |
| 1     | 0     | 0     | 0       | 0       | 1       |
| 0     | 1     | 0     | 1       | 0       | 1       |
| 1     | 0     | 1     | 0       | 1       | 1       |



Use JK flip-flops to design a 3-bit self-correcting counter with the repeated binary sequence: 0, 1, 2, 4, 5, 6. Show what happened if the counter is started in any of unused states.

| $A$ | $B$ | $C$ | $A^*$ | $B^*$ | $C^*$ |
|-----|-----|-----|-------|-------|-------|
| 0   | 0   | 0   | 0     | 0     | 1     |
| 0   | 0   | 1   | 0     | 1     | 0     |
| 0   | 1   | 0   | 1     | 0     | 0     |
| 0   | 1   | 1   | X1    | X0    | X0    |
| 1   | 0   | 0   | 1     | 0     | 1     |
| 1   | 0   | 1   | 1     | 1     | 0     |
| 1   | 1   | 0   | 0     | 0     | 0     |
| 1   | 1   | 1   | X0    | X0    | X0    |



$$\begin{aligned}
 J_B &= C \\
 K_B &= 1
 \end{aligned}$$



A sequential circuit has three flip-flops A, B, C; one input x; and one output, y. The state diagram is shown in next figure.

The circuit is to be designed by treating the unused states as *don't-care* conditions.

Analyze the circuit obtained from the design to determine the effect of the unused states.

- 1) Use D flip-flops in the design.
- 2) Use J-K flip-flops in the design.



| A | B | C | x | A* | B* | C* | y |
|---|---|---|---|----|----|----|---|
|---|---|---|---|----|----|----|---|

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
|----|----|----|----|----|

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
|----|----|----|----|----|

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
| 00 | 1  | 1  |    |    |
| 01 |    |    |    |    |
| 11 | X  | X  | X  | X  |
| 10 |    | X  | X  |    |

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
| 00 | 1  | 1  |    |    |
| 01 |    |    |    |    |
| 11 | X  | X  | X  | X  |
| 10 | 0  | 0  | X  | X  |

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
| 00 | 1  |    |    |    |
| 01 | 1  | 1  |    |    |
| 11 | X  | X  | X  | X  |
| 10 | 1  | 1  | X  | X  |

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
| 00 | 1  |    |    |    |
| 01 | 1  | 0  | 1  | 0  |
| 11 | X  | X  | X  | X  |
| 10 |    | X  | X  |    |

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
| 00 | 1  | 1  | 1  | 1  |
| 01 |    |    |    |    |
| 11 | X  | X  | X  | X  |
| 10 | 1  | X  | X  |    |

|    |    |    |    |    |
|----|----|----|----|----|
| AB | 00 | 01 | 11 | 10 |
| 00 | 1  | 1  | 1  | 1  |
| 01 | 0  | 0  | 1  | 1  |
| 11 | X  | X  | X  | X  |
| 10 | 1  | X  | X  |    |

$$J_A = \bar{B}x$$

$$K_A = 1$$

$$J_B = \bar{C}\bar{x} + A$$

$$K_B = \bar{C}x + C\bar{x} = C \oplus x$$

$$J_C = \bar{A}\bar{B}\bar{x} + Ax$$

$$K_C = Cx$$

$$y = \bar{A}x$$

Draw a table with missing States and add them to diagram

(15 pts)

**Exercise IV**

Draw the state diagram of a Moore-type sequential circuit with one input (I) and one output (S) that recognizes an input sequence of the form: 1 0 0 1 0 0 1 without overlapping.



The states of the diagram are labeled  $S_1, S_2, \dots$ . The inputs and outputs must be indicated on the diagram.



Design a logic circuit that controls the elevator door in a three-story building. The circuit has four inputs. M is a logic signal that indicates when the elevator is moving (M=1) or stopped (M=0). F<sub>1</sub>, F<sub>2</sub>, and F<sub>3</sub> are floor indicator signals that are normally LOW, and they go HIGH only when the elevator is positioned at the level of that particular floor. For example, when the elevator is lined up level with the second floor, F<sub>2</sub>=1 and F<sub>1</sub>=F<sub>3</sub>=0. The circuit output is

the OPEN signal, which is normally LOW and will go HIGH when the elevator door is to be opened. Find the simplified design and draw the diagram of the elevator circuit.

Note: Because the elevator cannot be lined up with more than one floor at a time, the cases when more than one floor inputs can be treated as don't care condition. When the elevator reaches at on floor and stops, the door opens.

| M | F <sub>1</sub> | F <sub>2</sub> | F <sub>3</sub> | Output |
|---|----------------|----------------|----------------|--------|
| 0 | 0              | 0              | 0              | 0      |
| 0 | 0              | 0              | 1              | 1      |
| 0 | 0              | 1              | 0              | 1      |
| 0 | 0              | 1              | 1              | x      |
| 0 | 1              | 0              | 0              | 1      |
| 0 | 1              | 0              | 1              | x      |
| 0 | 1              | 1              | 0              | x      |
| 0 | 1              | 1              | 1              | x      |
| 1 | 0              | 0              | 0              | 0      |
| 1 | 0              | 0              | 1              | 0      |
| 1 | 0              | 1              | 0              | 0      |
| 1 | 0              | 1              | 1              | x      |
| 1 | 1              | 0              | 0              | 0      |
| 1 | 1              | 0              | 1              | x      |
| 1 | 1              | 1              | 0              | x      |
| 1 | 1              | 1              | 1              | x      |

| M | F <sub>1</sub> | F <sub>2</sub> | F <sub>3</sub> | Output |
|---|----------------|----------------|----------------|--------|
|   |                |                |                | 00     |
|   |                |                |                | 01     |
|   |                |                |                | 11     |
|   |                |                |                | 10     |
|   |                |                |                |        |
|   |                |                |                |        |
|   |                |                |                |        |

Legend: 1 = Open, X = Don't Care

$$\begin{aligned}
 & \overline{M} F_1 + \overline{M} F_3 + \overline{M} F_2 \\
 &= \overline{M} (F_1 + F_2 + F_3)
 \end{aligned}$$

1 XXX 0



# Julia Abdallah

Computer Science Student at LU

Bekaa, Lebanon

+961 70672268

juliaAbdallah4@gmail.com

## Summary

I am a Computer Science student dedicated to my studies. Currently looking for a job that would allow me to further enhance my skills in Web Development, Software Engineering, Data Science, or any related fields.

## EDUCATION

### Computer Engineering | Lebanese University Faculty of Engineering

2020 – 2023

### Bachelor's in Computer Science | Lebanese University Faculty of Sciences

2023 – Present

## EXPERIENCE

### Private Math, Physics, and Chemistry Teacher

Feb 2019 – Oct 2019

### Coding Instructor | BrightChamps

Jan 2022 – Jan 2024

### Team Lead | BrightChamps

July 2022 – Jan 2024

### HR Manager | BrightChamps

June 2023 – August 2023

## SKILLS

- **Programming:** C, C++, Java, C#, HTML, CSS, JavaScript, Python
- **Software:** Office, AutoCAD, MATLAB
- **Languages:** English (fluent), French (fluent), Arabic (native)
- **Teamwork:** Project management, conflict resolution, leadership
- **Communication:** Public speaking, presentation, adaptability