

Problem: Obtain the logic truth table directly from the logic diagram without going through the derivation of Boolean functions.

## Sequential Circuits (flip-flops)

→ Most interesting digital circuits also include storage elements (dipped in boxes full of pixie dust), which require that the system be described in terms of sequential circuits.



→ The most common type of sequential ckt. is the synchronous type.

★ Synchronous sequential circuits employ signals that affect the storage elements only at discrete instants of time.

- Synchronization is achieved by a timing device called a clock pulse generator that produces a periodic train of clock PULSES.

- The clock pulses are distributed throughout the system in such a way that storage elements are affected only with the arrival of SYNCHRONIZATION PULSES.

Clocked Clocked synchronous sequential circuits the type most frequently encountered in ~~paradise~~ practice

### Clocked (Syn) Sequential Circuits



- The storage elements employed in clocked sequential circuits are called flip-flops.
- A flip flop is a binary cell capable of storing ONE BIT of information. It has two outputs, one for the normal value and the other for complement value of bit stored in it.
- A flip flop maintains a binary state until directed by a clock pulse to switch states.
- The difference among various types of FLIP-FLOPs is in the number of inputs they possess. And in the manner in which the inputs affect the binary state.



- Half adder is like 2 i/p's and full adder be like more i/p's.

P. 28/01/10

Block diagram of a sequential circuit.



- Binary info. stored in Memory elements : STATE of the seq. ckt.
- Inputs, present state also determine the condition for changing the state in memory elements.
- The next state of memory element is also a function of external inputs & present state.
- Sequen. ckt. is specified by a time sequence of inputs, outputs and internal states.

Sequential ckt's → Synchronous  
→ Asynchronous

Asynchronous: Behaviour depends upon the order in which its input signals change and CAN BE AFFECTED at any time.

memory elements: Time-delay devices.

memory capability is due to the propagation time through the device.

- In gate type asynchronous systems.

→ Synchronous clocked sequential circuit.



CLOCKED SEQUENTIAL CIRCUITS.

- Synchronization is achieved by using a master timing device called MASTER-CLOCK GENERATOR, which generates a periodic train of CLOCK PULSES.

→ \* clock pulses are distributed throughout the system in such a way that memory elements are affected only with the arrival of synchronization pulse.

single bit storage  
devices.

## S-R Flip Flop (SET-RESET Flip Flop):



The flip-flop responds to a positive transition (from 0 to 1) of the i/p clock signal.

### OPERATION of S-R flip-flops:

→ If there is no signal at the clock i/p 'C', the o/p of the circuit cannot change irrespective of the values at input S, R.

→ Only when the clock signal changes from '0' to '1' can the o/p be affected according to the values in i/p S & R.

→ If  $S=1, R=0 \rightarrow Q=1$

Clock has to be (1) to trigger the flip flop  $S=0, R=1 \rightarrow Q=0$  → Reset condition

$S=0, R=0 \rightarrow Q$  doesn't change.

$S=1, R=1 \rightarrow Q$  Indeterministic / unpredictable.  
because  $Q=\bar{Q}$ , which is impossible

$Q(t)$  may go either '0' or '1', depending on internal timing delays that occur within the



$$Q_{n+1} = S + Q_n R$$

$Q_i(t)$ : Binary state of the  $i$ th output at a given time (called PRESENT STATE)

$Q_i(t+1)$ : Binary state of the  $Q$  cell

taking ~~on as a~~  
~~(any) variable~~ (' $00$ ' case), after the occurrence of a clock transition.

D-Flip Flop: An SR flip flop is converted to a D-flip flop by inserting an inverter b/w S and R, and assigning the symbol D to the single i/p.

effectively there'll be single i/p → D i/p is sampled during the occurrence of clock transition from 0 to 1.



|   |          |                          |
|---|----------|--------------------------|
| D | $Q(t+1)$ |                          |
| 0 | 0        | ... clear to '0' → reset |
| 1 | 1        | ... set to '1' bit       |

*we're assuming  
the clock is always on.* Characteristic eq<sup>h</sup>:  $\theta(t+1) = D$ .  
NO CHANGE condition doesn't

NO CHANGE condition doesn't exist.

"No-change" condition can be accomp

→ The difference among various types of FLIP FLOPs is in the no. of inputs they possess and the manner in which the inputs affect the final o/p.

→ "No change" condition can be accomplished either by disabling the clock signal or feeding the o/p back to the i/p so that clock pulses keep the



prints 1 as o/p,  
every occurrence of  
as substring

30/01/19

### JK FLIP FLOP

/Refinement of SR flip flop

In SR F.F : There is a drawback, an Indeterminate condition. It will be defined, in a JK F.F.

To fix the 1-1 case of SR → Inputs J and K behave like i/p's 'S' and 'R' to set and clear the Flip Flop respectively.

→ When inputs J and K are both equal to '1', a clock transition (from '0' to '1') switches the outputs of the Flip Flop to their complement state.



| J | K | Q(t+1)                                   |
|---|---|------------------------------------------|
| 0 | 0 | Q(t) - No change                         |
| 0 | 1 | 0 - -- clear to 0                        |
| 1 | 0 | 1 - -- set to 1                          |
| 1 | 1 | Q'(t) - -- complements of the pre. stat. |

→ As the IC technology improved, no. of gates that could be put into integrated circuit increased.

SSI → Small scale integration. → # of gates  $< 10$ .

MSI → medium " →  $\# \rightarrow 10 < \underline{5} < 200$  gates.  
systems generally used as decoders.

LSI →  $200 <$  to few thousand.

digital systems such as ~~programmable~~ processors, memory chips and programmable modules.

## DIGITAL LOGIC FAMILIES

TTL → transistor-transistor logic

ECL → emitter-coupled logic

MOS → metal-oxide semiconductor.

CMOS → complementary MOS.

## DECODERS:

Discrete quantities of  $2^n$ : Binary Codes.

Binary code of  $n$  bits: Represents  $2^n$  distinct element of coded informal.

→ A decoder is a COMBINATIONAL CIRCUIT that converts binary information from the 'n' coded input to a maximum of  $2^n$  unique outputs.



Decoders are specified as

| # I/P |                | $\frac{m}{n}$ O/P |                | $2^n$          |                | $n$ (desired)<br>(I/P) w.r.t. |                | $2^n$ (O/P)    |                | where $m \leq 2^n$ . |                |
|-------|----------------|-------------------|----------------|----------------|----------------|-------------------------------|----------------|----------------|----------------|----------------------|----------------|
| E     | A <sub>2</sub> | A <sub>1</sub>    | A <sub>0</sub> | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub>                | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub>       | D <sub>0</sub> |
| 0     | x              | x                 | x              | 0              | 0              | 0                             | 0              | 0              | 0              | 0                    | 1              |
| 1     | 0              | 0                 | 0              | 0              | 0              | 0                             | 0              | 0              | 0              | 1                    | 0              |
| 1     | 0              | 0                 | 1              | 0              | 0              | 0                             | 0              | 0              | 1              | 0                    | 0              |
| 1     | 0              | 1                 | 0              | 0              | 0              | 0                             | 1              | 0              | 1              | 0                    | 0              |
| 1     | 1              | 1                 | 1              | 1              | 0              | 0                             | 0              | 0              | 0              | 0                    | 0              |

(E) encoded  
it seems w.r.t.  
enable → 0 → decoder disabled, if p = 0  
→ 1 → enabled.

(D) correspond to octal digits.  
nice.

(A) → Binary.

MULTIPLEXERS : Combinational circuit.



It receives information from one of the  $2^n$  input data lines and directs it to a single output line.

The selection of particular input data line for the outputs is determined by a set of selection lines.

→ 4 to 1 Multiplexer

Multiplexer is  
like the IP of  
decoder

## 4-to-1 MULTIPLEXER

$n$  selection lines are usually taken for  $2^n$  inputs  
Function Table

The truth table would be having  $2^n$  entries, but we ain't gonna draw that. These are just all a few combinations.

| $S_1$ | $S_0$ | $Y$   |
|-------|-------|-------|
| 0     | 0     | $I_0$ |
| 0     | 1     | $I_1$ |
| 1     | 0     | $I_2$ |
| 1     | 1     | $I_3$ |



For something

~~like this~~

Here, we're just sending '0' to  $I_2$ , if

~~we sent them all to all 1's then it's perfect like complete.~~



$$Y = I_0 S_0' S_1' + I_1 S_1' S_0 + I_3 S_0' S_1 + I_3 S_1 S_0$$

DECODER → takes " "  
ENCODERS → opp. of that.

71

01/02/19

REGISTERS. → Connection of For ex. 'N' flip-flops.  
Each FF stores 1 bit of information.  
An N-bit register has a group of n-FF's. and  
is capable of storing any binary information  
of n-bits.

- In addition to FF's, a register may have COMBINATIONAL gates that perform certain data processing tasks.
- In its broadest definition, a register consists of a group of FF's and gates that effect their transition. The FF's hold the binary information and gates control when and how new information is transferred to the register.
- Various types of register are available commercially. The simplest register is the one that consists only of FFs, with no external gate.



DECODER → takes  $n$  inputs → converts it into  $2^n$  outputs  
ENCODERS → opp. of that.

01/02/19

REGISTERS. → Connection of  $N$  flip-flops. For ex.  $N$  flip-flops each FF stores 1 bit of information. An  $N$ -bit register has a group of  $n$ -FF's. and is capable of storing any binary information of  $n$ -bits.

- In addition to FF's, a register may have COMBINATIONAL gates that perform certain data processing tasks.
- In its broadest definition, a register consists of a group of FF's and gates that effect their transition. The FF's hold the binary information and gates control when and how new information is transferred to the register.
- Various types of register are available commercially. The simplest register is the one that consists only of FFs, with no external gates.



## Shift registers:

$1/\text{bit} \rightarrow 1 \text{ bit of info.}$

$n \text{ bits} \rightarrow n/\text{bit} \rightarrow \text{registers}$

→ A register capable of shifting its binary information in one or both directions is called a SHIFT REGISTER.

→ The logical configuration of a shift register consists of a chain of FF's in cascade with o/p of one FF connected to i/p of next FF.

→ Common Clock i/p is given to all of them.

LFSR → linear feedback shift register.

~~free conceiving~~

## Frequency reuse

Service provider → should make max utilization with the given set of channels.

Time axis → divide into slots — each user given a slot

when on phone → next frame you get another slot —

we keep getting disconnected every ms — we don't even notice

TDMA, FDMA → kya hai.

Q. Can a channel be used simultaneously by multiple users?

A. ~~multiple users~~ ~~multiple users~~ ~~multiple users~~

frequency division multiplexing

## Signature sequences

are generated by LFSR

specific to each user

Synchronous → clock predefined, i/p

asynchronous → clock not i/p

## Binary Counter:

A register that goes through a pre-determined sequence of states upon the application of ~~the~~

sequence of states upon the application of ~~the~~ input pulses (~~clock is step~~) is called COUNTER.

- The input pulses may be clock pulses or may originate from an external source. They may occur at uniform intervals of time or at random.
- Counters are found in almost all equipment containing digital logic. They are used for counting the # of occurrences of an EVENT and are useful for generating timing signals to control the sequence of operations in digital computers.
- Of the various sequences a counter may follow, the straight/uniform binary sequence is the simplest and most straightforward. A counter that follows the binary ~~new~~ number sequence is called a binary counter.
- An n-bit binary counter is a REGISTER of n-flip-flops and associated gates that follows a sequence of states according to the binary count of n-bits from '0' to ' $2^n - 1$ '

## MEMORY UNIT - most crucial element.

- A memory unit is a collection of storage cells, cache memories, very expensive; RAM and all registers are not so costly but.  
Wanna access the information?  
You need a reader & writer to control the signals together with associated circuits needed to transfer information in and out of storage.
- Memory stores binary information in groups of bits called WORDS. A word in memory is an event ENTITY of bits that move in and out of storage as a word UNIT.
- A memory word is a group of 1's and 0's and may represent a NUMBER, an INSTRUCTION CODE, ONE or more ALPHANUMERIC CHARACTERS, or any other BINARY CODED INFORMATION.
- A group of 8 bits is called a BYTE, most computer memories use words whose number of bits is a multiple of 8. Thus, a 16-bit word contains 2 bytes, and a 32-bit word is made up of 4 bytes.

$$\Sigma F = \sum (1, 2, 3, 5, 7)$$

using multiplexer.

| A | B | C | $m_0$ | 0 |
|---|---|---|-------|---|
| 0 | 0 | 0 | $m_0$ | 0 |
| 0 | 0 | 1 | $m_1$ | 1 |
| 0 | 1 | 0 | $m_2$ | 1 |
| 0 | 1 | 1 | $m_3$ | 1 |
| 1 | 0 | 0 | $m_4$ | 0 |
| 1 | 0 | 1 | $m_5$ | 0 |
| 1 | 1 | 0 | $m_6$ | 1 |
| 1 | 1 | 1 | $m_7$ | 1 |

$$f = m_1 + m_2 + m_3 + m_6 + m_7$$

Also

Program in each case A

$\begin{matrix} 0 & 0 & 0 \\ 0 & 0 & 1 \\ 0 & 1 & 0 \\ 0 & 1 & 1 \\ 1 & 0 & 0 \\ 1 & 0 & 1 \\ 1 & 1 & 0 \\ 1 & 1 & 1 \end{matrix}$

$\begin{matrix} 0 & 1 & -1 \\ 0 & 1 & -2 \\ 0 & 1 & -3 \\ 1 & 1 & -4 \\ 1 & 1 & -5 \\ 1 & 1 & -6 \\ 1 & 1 & -7 \end{matrix}$



4/2/19

Memory unit:

→ WORDS → Basic storage / retrieval unit in memory.

8 bits → 1 byte

Words → multiple of bytes.

→ CAPACITY OF MEMORY: Stated as the total # of bytes that can be stored.

→ Internal structure of a Memory unit:

Specified by the # of words it consists and the no. of bits in each word.

→ Special INPUT lines called ADDRESS lines to select a particular word.

- Each word in memory is assigned an identification number, called address, starting from '0' and continuing with  $1, 2, 3, \dots, 2^k - 1$ , where  $k$  is the # of address lines.
- The selection of SPECIFIC WORD inside the ~~mem~~ memory is done by applying the  $k$ -bit binary address to the address lines.
- A decoder inside the memory accepts this address and OPENS THE PATHS needed to select the bits of a specific word.
- Computer memories may range from 1024 words required requiring an address of 10 bits, to ~~1024~~  $2^{32}$  words requiring 32 address bits.

→ Types of Memories : 2 types

Random Access Memory  
(RAM)

Read Only Memory  
(ROM).

Semiconductor Memories

RAMs.

Sequence Access Memories  
(SAMs)

→ Memories constructed with SHIFT REGISTERS,  
CHARGE COUPLED DEVICES (CCDs) OR.

BUBBLE Memories --- SAMs.

2

$\boxed{\text{RAM}} = \begin{cases} \text{ROMs, Read Mostly memories (RMMs).} \\ \text{Read write memories (RWMs).} \end{cases}$

ROMs → Masked Programme ROMs.  
ROMs → User Programmed ROMs.



### RANDOM ACCESS MEMORY (RAM)

→ The amount of time taken to locate any word is same, irrespective of where it's physically present.

→ Communication between a memory and its environment is achieved through data input lines, data o/p lines, address selection lines and control lines.  
(Specify the direction of transfer)



2 operations that a RAM can perform: Write and Read.

Write signal:

- ① You apply the binary address of the desired word into the address lines.
- ② Apply the data bits that must be stored in memory into the data input lines.
- ③ Activate the WRITE i/p.

→ To transfer the stored word out of the address (READ)

- ① Apply the binary address of the desired word into the address line.
  - ② Activate the READ i/p.
- (\*) RAM → reads words that're permanently stored in the mem

$m \times n$  ROM

ROM as a block is  
a combinational  
ckt.



22/01/19

## Tutorial

### Binary codes

→ suitable for comp. applications & digital communication.

Attenuation  
Distortion  
Noise

} affect the analog signal, but they do not affect the digital signals that much.  
So, we prefer digital.

(DTH set top box something)



①  $754 + 138 \rightarrow \text{BCD mode}$

$$\begin{array}{r} 0111 0101 0100 \\ + 0001 0011 1000 \\ \hline 1000 1000 1100 \end{array}$$

8      8      12 → not acceptable

Whenever it exceeds 9,  
add binary 6 to it.

[0110]

1000 1001 0010

now if this was greater than 9, add 0110 to 100.

for the last one ignore carry.

$$\begin{array}{r} 1100 \\ 0110 \\ \hline 10010 \end{array}$$

Carry to next

BCD arithmetic is little complicated than ~~more~~  
binary arithmetic.

### Excess-3 code (XS3).

- unweighted code (no positional ~~bits~~ weights)

- obtained by adding binary 3 to the BCD code.  
 $\underbrace{(0011)}$

| <u>Decimal</u> | <u>BCD</u> | <u>Excess-3</u> |                                          |
|----------------|------------|-----------------|------------------------------------------|
| 0              | 0000       | 0011            | self complementing code.                 |
| 1              | 0001       | 0100            |                                          |
| 2              | 0010       | 0101            |                                          |
| 3              | 0011       | 0110            |                                          |
| 4              | 0100       | 1011            | not same for all.                        |
| 5              | 0101       | 1100            |                                          |
| 6              |            |                 | Hamming distance                         |
| 7              |            |                 | The corresponding no. of bit differences |
| 8              |            |                 |                                          |
| 9              |            |                 |                                          |

### Gray Code:

→ It is an unweighted case

→ Hamming distance always 1. (unit)

also called unit distance codes.

| <u>Decimal</u> | <u>BCD</u> | <u>Gray</u> |
|----------------|------------|-------------|
| 0              | 0000       | 0000        |
| 1              | 0001       | 0001        |
| 2              | 0011       | 0011        |
| 3              |            |             |
| 4              |            |             |
| 5              |            |             |
| 6              |            |             |
| 7              |            |             |
| 8              | 1000       | 1100        |
| 9              | 1001       | 1101        |

→ First bit written as it is  
and 1st, 2nd bit ka  
XOR gate is written at  
2nd position. 2, 3rd, 2  
3, 4 → 3. like that till  
the end.

⇒ Binary to Gray:



Gray to Binary:



~~Truth Table for Adder circuit.~~

| x | y | z |
|---|---|---|
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |
| 0 | 0 | 0 |

23/01/19

Subtractors:

$n \rightarrow$  minuend

$n-y=z$ .       $y \rightarrow$  subtrahend.

④ 2's complement of 'y' and add binary to 'x'!

④ If minuend is smaller than the subtrahend bit, a 1 is borrowed from the next significant position.

⇒ The fact that a 1 has been borrowed must be conveyed to the next higher pair of bits by means of a binary signal coming out of a given stage and going into the next higher stage. (input)

~~passion, zeal~~

Stack of the flip flop unchanged.

29/1/19

## TUTORIAL

RAM designed using registers  
for doing multiple tasks simultaneously.

One processor can't do it all,  
it gets hung.

→ So we have multicore processor

to execute multiple processes  
at the same time.

i<sub>5</sub> → 4 processors

↓  
each (2.57, 2.18)

tells the speed  
of different processes.



i<sub>7</sub>

→ 6 different processes

→ 64 bit registers

temp. storage of  
memory in the register  
in the processor

If it's in the register,  
then it won't be in the  
main memory.

→ All the I/Os are stored in the FLIP FLOPs.

$$\begin{array}{c} B_3 \oplus B_2 \oplus B_1 \oplus B_0 \\ \downarrow \quad \downarrow \quad \downarrow \quad \downarrow \\ G_3 \quad G_2 \quad G_1 \quad G_0 \end{array}$$



## Finite Automata (FA)



### Moore Machine

→ o/p is associated with the state



$$\lambda : Q \rightarrow \Delta$$



### Mealy Machine

o/p  $\lambda$  is associated with i/p



$q_0$  on  $a$ , is producing 1.



process



Input is  $a, b$   
prints 1 as O/P  
every occurrence of  $a$  as substring

30/01/12

### JK FLIP FLOP

/ Refinement of SR flip Flop

In SR FF : There is a drawback, an Indeterminate condition. It will be defined, in a JK F.F.

To fix the 1-1 case of SR  $\rightarrow$  Inputs J and K behave like i/p's 'S' and 'R' to set and clear the Flip Flop respectively.

When inputs J and K are both equal to '1', a clock transition (from '0' to '1') switches the outputs of the Flip Flop to their complement state.



| J | K | $Q(t+1)$                               |
|---|---|----------------------------------------|
| 0 | 0 | $Q(t)$ - No change                     |
| 0 | 1 | 0 - - - clear to 0                     |
| 1 | 0 | 1 - - - set to 1                       |
| 1 | 1 | $Q'(t)$ - complement of the pre. state |

→ As the IC technology improved, no. of gates that could be put into integrated circuit increased.

(SSI) → Small scale integration. → # of gates  $< 10$ .

MSI → medium " → # of gates  $10 < 5 < 200$  gates.  
systems generally used as decoders.

LSI → 200 < to few thousand.

digital systems such as ~~programmers~~.

processors, memory chips and programmable modules.

## DIGITAL LOGIC FAMILIES

TTL → transistor-transistor logic.

ECL → emitter-coupled logic

Mos → metal-oxide semiconductor.

CMOS → Complementary Mos.

## DECODERS:

Discrete Quantities of Info: Binary Codes.

Binary code of  $n$  bits: Represents  $2^n$  distinct elements of coded info.

→ A decoder is a COMBINATIONAL CIRCUIT that converts binary information from the  $n$  coded input to a maximum of  $2^n$  unique outputs.



Decoders are specified as  $n$  to  $m$  line decoders, where  $m \leq 2^n$ .

| E | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|---|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0 | x              | x              | x              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              |
| 1 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              |
| 1 | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              |
| 1 | 0              | 1              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              | 0              |
| : | :              | :              | :              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              |
| 1 | 1              | 1              | 1              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |

- (E) → encoded if seems off.
- (D) → correspond to octal digits nice.
- (E) enable → 0 → decoder disabled,  $Q/P = 0$  if irrespective of if.
- (E) 1 → enabled.

MUXPLEXERS : Combinational circuit.



It receives information from one the  $2^n$  input data lines and directs it to a single output.

The selection of particular input data line for the outputs is determined by a set of selection lines.

→ 4 to 1 Multiplexer

7a

Multiplexer is  
line the pp. of  
decoder

## 4-to-1 MULTIPLEXER

*n selection lines  
are usually taken for 2<sup>n</sup> inputs*

Function Table

The truth table would be having  $2^n$  entries, but we ain't gonna draw that. These are just all few combinations.

| (S <sub>1</sub> ) | S <sub>0</sub> ) | Y              |
|-------------------|------------------|----------------|
| 0                 | 0                | I <sub>0</sub> |
| 0                 | 1                | I <sub>1</sub> |
| 1                 | 0                | I <sub>2</sub> |
| 1                 | 1                | I <sub>3</sub> |

$$\rightarrow S_1 S_0 = 10.$$

for 10



For something

like

Here, we're just sending 10' to I<sub>2</sub>, if we sent them all to all I's then it's perfect like complete.



$$Y = I_0 S_0' S_1 + I_1 S_1' S_0 + I_2 S_0' S_1 + I_3 S_1' S_0$$

DECODER → takes  $n$  inputs → converts it into  $2^n$  o/p's.

ENCODERS → opp. of that.

01/02/19

REGISTERS. → Connection of for ex. 'N' flip-flops,  
Each FF stores 1 bit of information.

An N-bit register has a group of n-FF's. and  
is capable of storing any binary information  
of n-bits.

→ In addition to FF's, a register may have  
COMBINATIONAL gates that perform certain  
data processing tasks.

→ In its broadest definition, a register consists of  
a group of FF's and gates that effect their  
transition. The FF's hold the binary information  
and gates control when and how new information  
is transferred to the register.

→ Various types of register are available  
commercially. The simplest register is the one  
that consists only of FFs, with no external gate.



## Shift registers:

1 bit  $\rightarrow$  1 bit of info.

$n$  bits  $\rightarrow$  ~~1 bit~~  $\rightarrow$  registers

A register capable of shifting its binary information in one or both directions is called a SHIFT REGISTER.

The logical configuration of a shift register consists of a chain of FF's in cascade CASCADE with o/p of one FF connected to i/p of <sup>next</sup> other FF.

Common Clock i/p is given to all of them.

LFSR  $\rightarrow$  linear feedback shift register.

~~free concatenating~~

## Frequency reuse

Service provider  $\rightarrow$  should make max utilization with the given set of channels.

Time axis  $\rightarrow$  divide into slots — user given a slot  
when on phone  $\rightarrow$  next frame you get another slot —  
we keep getting disconnected every ms — we don't even notice

TDMA, FDMA kya hai.

Can a channel be used simultaneously by multiple users?

frequency division multiplexing

## Signature sequences

are generated by LFSR

specific to each slot and stop between them

## Binary Counter:

A register that goes through a pre-determined sequence of states upon the application of ~~the~~

input pulses (~~clock & comp~~)  $\xrightarrow{\text{can be}}$  is called COUNTER.

- The input pulses may be clock pulses or may originate from an external source. They may occur at uniform intervals of time or at random.
- Counters are found in almost all equipment containing digital logic. They are used for counting the # of occurrences of an EVENT and are useful for generating timing signals to control the sequence of operations in digital computers.
- Of the various sequences a counter may follow, the straight/uniform binary sequence is the simplest and most straightforward. A counter that follows the binary ~~no~~ number sequence is called a binary counter.
- An n-bit binary counter is a REGISTER of n flip-flops and associated gates that follows a sequence of states according to the binary count of n-bits from '0' to ' $2^n - 1$ '

## MEMORY UNIT - most crucial element.

- A memory unit is a collection of storage cells,  
cache memories } very ; RAM and all  
registers } expensive not so costly b/f.

Wanna access the information?

You need a reader & writer to control the signals.  
together with associated circuits needed to  
transfer information in and out of storage.

- Memory stores binary information in groups of bits

called WORDS. A word in memory is  
an entity of bits that move in and  
out of storage as a unit.

- A memory word is a group of 1's and 0's and  
may represent a NUMBER, an INSTRUCTION  
CODE, one or more ALPHANUMERIC CHARACTERS, or  
any other BINARY CODED INFORMATION.

- A group of 8 bits is called a BYTE, most  
computer memories use words whose number  
of bits is a multiple of 8. Thus, a 16-bit  
word contains 2 bytes, and a 32-bit word  
is made up of 4 bytes.

using multiplexer.

now for multiplexer,

| 8-1 |   |   | MUX                 |
|-----|---|---|---------------------|
| A   | B | X | OP                  |
| 0   | 0 | 0 | $m_0 \rightarrow 0$ |
| 0   | 0 | 1 | $m_1 \rightarrow 1$ |
| 0   | 1 | 0 | $m_2 \rightarrow 1$ |
| 0   | 1 | 1 | $m_3 \rightarrow 1$ |
| 1   | 0 | 0 | $m_4 \rightarrow 0$ |
| 1   | 0 | 1 | $m_5 \rightarrow 0$ |
| 1   | 1 | 0 | $m_6 \rightarrow 1$ |
| 1   | 1 | 1 | $m_7 \rightarrow 1$ |

$$f \rightarrow m_1 + m_2 + m_3 + m_6 + m_7$$



DATA

A program is stored in memory.

4/2/19

Memory unit:

Basic storage/retrieval unit in memory.

→ WORDS → Basic storage/retrieval unit in memory.

→ 8 bits → 1 byte

Words → multiple of bytes.

→ CAPACITY OF MEMORY: Stated as the total # of bytes that can be stored.

→ Internal structure of a Memory unit:

It consists and the specified by the # of words and the no. of bits in each word.

→ Special INPUT lines called ADDRESS lines to select a particular word.

→ Each word in memory is assigned an identification number, called address, starting from '0' and continuing with  $1, 2, 3, \dots, 2^k - 1$ , where  $k$  is the # of address lines.

→ The selection of SPECIFIC WORD inside the memory is done by applying the  $k$ -bit binary address to the address lines.

→ A decoder inside the memory accepts this address and OPENS THE PATHS needed to select the bits of a specific word.

→ Computer memories may range from 1024 words required requiring an address of 10 bits, to  $2^{32}$  words requiring 32 address bits.

→ Types of Memories are 2 types

- Random Access Memory (RAM)
- Read Only Memory (ROM).

Semiconductor Memories

- RAMs
- Sequence Access Memories (SAMs)

→ Memories constructed with SHIFT REGISTERS, CHARGE COUPLED DEVICES (CCDs) or BUBBLE Memories --- SAMs.

$\downarrow$   
 $\text{RAM} = \left\{ \begin{array}{l} \text{ROMs, Read Mostly memories (RMMs).} \\ \text{Read Write memories (RWMs).} \end{array} \right.$

$\text{ROMs} \rightarrow \left\{ \begin{array}{l} \text{Masked Programme ROMs.} \\ \text{User Programmed ROMs.} \end{array} \right.$



### RANDOM ACCESS MEMORY (RAM)

→ The amount of time taken to locate any word is same, irrespective of where it's physically present.

→ Communication between a memory and its environment achieved through data input lines, data o/p lines, address selection lines and control lines.  
 (specify the direction of transfer)



2 operations that a RAM can perform: Write and Read.

Write signal:

- ① You apply the binary address of the desired word into the address lines.
- ② Apply the data bits that must be stored in memory into the data input lines.
- ③ Activate the WRITE i/p.

→ To transfer the stored word out of the address (READ)

- ① Apply the binary address of the desired word into the address line.
- ② Activate the READ i/p.

RAM → reads words that're permanently stored in the mem

$m \times n$  ROM

ROM as a block is  
a combinational  
ckt.



Ques

10/2/19

→ How many half adders and full adders are needed for a 7-bit parallel binary adder?



$$\begin{array}{r} A_3 \mid A_2 \mid A_1 \mid A_0 \\ B_3 \mid B_2 \mid B_1 \mid B_0 \end{array}$$

Ex:

$$\begin{array}{r} 1011 \\ 1101 \\ \hline 11000 \end{array}$$

→ Here, 7-bit parallel binary adder

⇒ 6 F.A. and 1 H.A.



④ So this is an adder-subtractor circuit

When  $M=0$ , it acts as an adder  
and when  $M=1$ , it acts as a subtractor.

$R$ 's complement of  $A \Rightarrow R - A = B$ .

1's of OR  $\Rightarrow (1) \oplus (111)$

$$= 000.$$

$$2^5 \Rightarrow 111 - 111 = 111$$

So basically we

$(R+k)$  complement of  $A \Rightarrow (B+k)$

↓  
element wise addition

element wise  
addition

→ Decoder:

| E | B <sub>2</sub> | B <sub>1</sub> | B <sub>0</sub> | D <sub>7</sub> | P <sub>6</sub> | P <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | P <sub>1</sub> | D <sub>0</sub> |
|---|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| 0 | x              | x              | x              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 1 | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              | 0              |
| 1 | 0              | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              |
| 1 | 0              | 1              | 0              | 0              | 0              | 0              | 0              | 0              | 1              | 0              | 0              |
| 1 | 0              | 1              | 1              | 0              | 0              | 0              | 0              | 1              | 0              | 0              | 0              |
| 1 | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              | 1              |

$4 \times 16 \rightarrow$  not possible to design in real.

So, we use two  $3 \times 8$  lines.



Q: Re Design the F.A from  $3 \times 8$  decoder.



11/02/19

- ROM is constructed externally with decoders and a set of OR gates.
- ROM generates an I/p - O/p relationship specified by a truth table. It can implement any combinational circuit with 'K' inputs and ' $n$ ' O/p's.
- When employed (in cs) as a memory unit, the ROM is used for storing fixed programs that are not to be altered and for TABLE of constants that are not subjected to change.
- ROM is employed in the design of control units for digital computers. As such, they are used to store coded info. that represents the sequence of internal control variables needed for enabling various operations in computers.

→ A COMPUTER UNIT that utilizes a ROM to store binary control information is called a MICRO PROGRAMMED CONTROL UNIT.



Examples of flash memories:

① Storage Messages in a Mobile Phone.

## COMPUTER ARCHITECTURE & (CA)

## COMPUTER ORGANIZATION (CO)

CA: This attributes of a system visible to a program (for those attributes that have a direct impact on the logical execution of a program).

Examples → Instruction Set:

- Number of bits used to represent data types (Ex: NUMBERS, CHARACTERS, etc.)

- I/O mechanisms,

- Techniques for addressing memory

CO: Refers to the OPERATIONAL UNITS, and their interconnection that realize the architectural specifications. The organizations / attributes include - those hardware details transparent to the programmer, such as CONTROL signals  
 - Interfaces b/w computer & the peripherals  
 - Memory technology.



Model of Machine computation

### First Electronic Computer:

ENIAC (Electronic Number Integrator & Calculator)

- Clocked speed - 100 MHz
- Electronic accumulator → storage
- Additional units for additions / subtractions.
- MULT, DIVISION, SQUARE ROOT and strong function tables.
- MANUAL PROGRAMMING by setting switches and plugging wires.

→ That day I didn't write notes & everything came in exam

"IDK | 1 | 19"

FUCK YA!

Memory unit: 1000s of registers.

Processor unit: composed of various registers which store operands upon which operations are performed.

Control unit: Registers to keep track of various computer sequences.

### Register Transfer Language (RTL)

- Used to move contents from R<sub>1</sub> to R<sub>2</sub>.
- Von Neumann Arch → stores data & instructions in the same place.
- Harvard Arch → Program memory or Instruction memory Data memory is separate.

DIGITAL SIGNAL PROCESSORS are based on this architecture.

I/P - O/P PROCESSOR: contains electronic circuits for communicating & controlling the transfer of information b/w computer & outside world.



no. of functions

## DIGITAL LOGIC CIRCUITS

Binary logic → Binary variables  
 Operations that assume a logical meaning.

Electric signals ~ 2 states → 3 levels - 1  
 $0.5V - 0$ .

(XOR)

| x | y | O/P |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 1   |
| 1 | 0 | 1   |

$$z = x'y + y'x$$

X-NOR



$$z = xy + x'y'$$

| x | y | O/P |
|---|---|-----|
| 0 | 0 | 1   |
| 0 | 1 | 0   |
| 1 | 0 | 0   |
| 1 | 1 | 1   |

### \* Purpose of Boolean Algebra

- Analysis & Design of Digital circuits convenient
  - 1. express in algebraic form a truth table relationship b/w binary variables.
  - 2. Express algebraically the 1-0 relationship of logic diagrams.
  - 3. Find simpler circuit for the same function
- $F(x, y, z) = xy + x' + yz$  is always 1.

Boolean Expression: A boolean function specified by a truth table can be expressed algebraically in different ways.

## Basic identities

$$(1) x + 0 = x$$

$$(2) x + 1 = 1$$

$$(3) x \cdot 0 = 0$$

$$(4) x \cdot 1 = x.$$

$$(5) x + x = x.$$

$$(6) x \cdot x = x.$$

$$(7) x + x' = 1$$

$$(8) x \cdot x' = 0$$

$$(9) (x')' = x.$$

$$(10) (x + (y + z)) = ((x + y) + z)$$

$$(11) x \cdot (y + z) = x \cdot y + x \cdot z$$

$$(12) x \cdot (yz) = (xy) \cdot z$$

$$(13) (x+y)' = x' * y'$$

$$(14) (xy)' = x' + y'$$

$$(15) x + y = y + x$$

$$(16) x \cdot y = y \cdot x.$$

13/2/19

## Representing number in digital clock



To represent numbers, we have to have only a few lines lit up.

lift signs

full too

| decimal | BCD  | a | b | c | d | e | f | s |
|---------|------|---|---|---|---|---|---|---|
| 0       | 0000 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |
| 1       | 0001 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| 2       | 0010 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |
| 3       | 0011 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |
| 4       | 0100 | 0 | 1 | 1 | 0 | 0 | 1 | 1 |
| 5       | 0101 | 1 | 0 | 1 | 1 | 0 | 1 | 1 |
| 6       | 0110 | 1 | 0 | 1 | 1 | 1 | 1 | 1 |
| 7       | 0111 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| 8       | 1000 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| 9       | 1001 | 1 | 1 | 1 | 1 | 0 | 1 | 1 |

15/02/19

## Stored Program Machines:

- \* Introduction to binary system.
- \* Stored Program Concept where by program and data got stored in same memory.

Traditional machines: Harvard Mark I.

- \* Von Neumann architecture: "sequential" execution of stored program instructions.
- \* MIT's Whirlwind: First computer designed with real time applications & computer networking.

Features in first generation computers.

①

CPU → Execution unit.

Program control unit → set of registers

## Execution / Data Processing Unit

- Set of registers for storing data.
- An ALU for arithmetic & logic operations.
- execution of
- Additional registers for temporary storage of data.

(2). Main memory: Main storage control unit → MAR  
→ MDR.

Memory Address Register: (MAR)

- MAR is filled with some address (say 'x' denoted as  $M_x$ ) in a memory cycle.
- Data from addressed word is read into MDR for read operation and
- Data from MDR is written into the addressed word to write operation.

The no. of bits in an MAR implies memory capacity,  
(say 'n')  
whereas

$$= 2^n \text{ words.}$$

word size ~~is~~ → no. of bits of MDR

(3) Secondary Memory : Program & Data.

Cover your comp.

execute too! exactly → Nah! (Too Large brush)

Input Input to the system from some input device (or)

SECONDARY STORAGE, which is a low cost voluminous storage.

④ INPUT DEVICE: Card Reader: Read cards containing program and data.

→ Program or data is read into main storage (from I/P device or secondary storage) under the control of CPU input instruction.

⑤ OUTPUT DEVICES

O/P devices → Printer, Monitors  
Card Punch

O/P data from main storage goes to O/P device under the control of CPU output operation.

⑥ INSTRUCTION FORMATS:

- Consisted of subfield specifies specifying OPCODE and 1, 2, 3, or 4 OPERAND addresses.

- Organisation is shown in Fig 1.6.

Instruction format: op A<sub>1</sub> i.e. one address (Accumulator register is implied second operand)

Instructions are sequentially stored in MAIN STORAGE. CPU sequentially fetches each instruction & executes the operation.

## (7) CPU operation :



## (8) Information Representation :

Basic unit of information : transferred b/w main memory & CPU registers

(N-bit wide word) ie.  
Word size of main memory

18/2/19  
Program control unit decodes sub-fields of an instruction

## (9) Instruction Set and Micro-operations.

Instruction set is divided broadly into:



Computers.

## (10) Data Transfer

① Arithmetic.

② Logic

③ Program control

④ Input / output.

Bird's eye view of operation of computer:

Innovations in modern computers:



Programming a computational task.

Machine language : 0's and 1's.

ASSEMBLER      01001110

Assembly language ADD.

High level language

Add R<sub>1</sub>, R<sub>2</sub>.  
move R<sub>1</sub> → R<sub>2</sub>.

FORTRAN : 40, 70, COBOL, BASIC, ALGOL.

↓  
PASCAL

↓  
C

↓  
C++

↓  
JAVA

structured PL

↓  
IF, THEN, ELSE

CROSS ASSEMBLER

DMA, FDMA, TDMA

OPERATING SYSTEMS:

Systems software → kernel programming

→ UNIX application, software WINDOWS

open source: LINUX.

VIRTUALIZATION:

(software engineering)

Share the process / CPU time among multiple users.

TIME SHARING  $\longleftrightarrow$  Multi-tasking  
[SINGLE COMPUTER]

PARALLEL COMPUTATION: Multiple computers are available to execute jobs / programs / applications i.e., multiple CPUs can be effectively used to perform computational tasks.

20/2/19 PARALLEL COMPUTATION (In multicore machines)  
Dual core, quad core.

Intel:

Xeon - Phi

Processor - 72 cores.

Trivially parallelizable problems:

Serial algorithms.

Models of parallel computation:  
SIMD computer.

Single instruction, Multiple data.

Multiple instruction, MIMD.

Challenging problem  $\rightarrow$  design and analysis of parallel algorithm

## DISTRIBUTED COMPUTER

### Wireless Sensor Networks (WSNs)

- distributed and parallel computation.
- scheduling algorithms for multiple core and memory management.
- Application specific micro-processors.

### (B) Digital Signal Processors (DSP):

for signal processing applications. Models of computation in most DSPs : Harvard Architecture (Instructions and data , stored in different memory unit).

$$x(n+m) = a_1 x(n) + a_2 x(n+1) + \dots + a_m x(n+m-1).$$

### (II) Graph Processing Unit

~~for digital~~  
design for graphic (eg: video games) applications.

GPP GPUs : General purpose GPUs .

The company that came up with this - NVIDIA.

### III In memory computation

#### (IV) Field programmable gate arrays (FPGAs)

FPGAs → systolic arrays (it pumps elements)

## (2) Deep learning architectures:

Ex: Hardware accelerators.

CLUSTER → GRID → CLOUD

Edge computing

MIST

DEW

FOG

IPV4 → IPV6 → IoT

(32 bits)      (16 bytes,  
                  128 bits)

IoT + Edge computing = Edge AI  
(Data processing near the source)

Advantages of Edge Computing + Cloud Computing

Cloud computing

Disadvantages of Cloud Computing  
- High latency due to long distance between user and cloud server

- Data security issues due to multiple parties involved in data transmission

Edge computing

Advantages of Edge Computing  
- Low latency due to proximity of edge devices to users



25/02/19



REGISTER Transform: Information transfer : symbolic form.

$R_2 \leftarrow R_1$  } Destination register has a parallel  
destination      source load capability.

- We want transfer to occur only under a predetermined control condition. IF-THEN statement.

IF ( $P=1$ ) , THEN ( $R_2 \leftarrow R_1$ )  
 $P$  is a control signal generated in the control section.

- ① CONTROL FUNCTION: Convenient to separate the control variables from the register transfer operation by specifying a control function.

A control function is a Boolean variable that is equal to '1' or '0'.

Control function is included in the statement.

$$P: R_2 \rightarrow R_1.$$

- Every statement written in register transfer notation implies hardware for implementing it.



$$T: R_2 \leftarrow R_1, R_1 \leftarrow R_2$$

Block diagram that depicts transfer from  $R_1$  to  $R_2$ :



Basic symbols for Register Transfer

Letter: MAR, R2.

Parameter  
Paranthesis:  $R_2(0-f)$ ,  
 $R_2(L)$  -

Arrow:  $R_2 \leftarrow R_1$ .

Comma: Separates two micro-operations.

$R_2 \leftarrow R_1, R_1 \leftarrow R_2$ .

4.3

### BUS AND MEMORY TRANSFERS

Multiple Register Configuration: COMMON BUS.



For each bus line, we need a multiplexer and each mux has  $K$  inputs.

EXAMPLE: Common bus for 8 registers of 16 bits require  
16 multiplexers, one for each line of bus.

- Each multiplexer must have 8 data i/p lines and 3 selection lines to multiplex one significant bit in the 8 registers.

### Symbolic Notation



Alternative method : 3 state gates



### MEMORY TRANSFER:

READ: Transfer from Memory Word, M to the outside environment

WRITE: Transfer of new information to be stored into the memory is called WRITE operation.

Memory word  $\equiv M$ . Selected by the memory address during the transfer.

Tutorial

26/02/19

2-bit magnitude comparator  
(next page)

| $A_0$ | $A_1$ | $B_0$ | $B_1$ | $\oplus/\ominus$ | $X(A > B)$ | $Y(A = B)$ | $Z(A < B)$ |    |
|-------|-------|-------|-------|------------------|------------|------------|------------|----|
| 0     | 0     | 0     | 0     | 0                | 0          | 1          | 0          | 0  |
| 0     | 0     | 0     | 1     | 0                | 0          | 0          | 1          | 1  |
| 0     | 0     | 1     | 0     | 0                | 0          | 0          | 1          | 2  |
| 0     | 0     | 1     | 1     | 0                | 0          | 0          | 1          | 3  |
| 0     | 1     | 0     | 0     | 1                | 1          | 0          | 0          | 4  |
| 0     | 1     | 0     | 1     | 0                | 0          | 1          | 0          | 5  |
| 0     | 1     | 1     | 0     | 0                | 0          | 0          | 1          | 6  |
| 0     | 1     | 1     | 1     | 0                | 0          | 0          | 1          | 7  |
| 1     | 0     | 0     | 0     | 1                | 0          | 0          | 0          | 8  |
| 1     | 0     | 0     | 1     | 1                | 0          | 0          | 0          | 9  |
| 1     | 0     | 1     | 0     | 0                | 1          | 0          | 0          | 10 |
| 1     | 0     | 1     | 1     | 1                | 0          | 0          | 1          | 11 |
| 1     | 1     | 0     | 0     | 1                | 0          | 0          | 0          | 12 |
| 1     | 1     | 0     | 1     | 1                | 0          | 0          | 0          | 13 |
| 1     | 1     | 1     | 0     | 1                | 0          | 0          | 0          | 14 |
| 1     | 1     | 1     | 1     | 0                | 1          | 0          | 0          | 15 |

(\*)  $A > B$  is defined as  $A \oplus B + A \cdot B$

| $A_0A_1$ | $B_0B_1$ | 00 | 01 | 11 | 10 |
|----------|----------|----|----|----|----|
| 00       | 1        |    |    |    |    |
| 01       | 1        | 1  |    |    |    |
| 11       | 1        | 1  | 1  |    |    |
| 10       | 1        | 1  | 1  | 1  |    |

| $A_0A_1$ | $B_0B_1$ | 00 | 01 | 11 | 10 |
|----------|----------|----|----|----|----|
| 00       | 1        | 1  |    |    |    |
| 01       | 1        | 1  | 1  |    |    |
| 11       |          |    |    | 1  |    |
| 10       |          |    |    | 1  | 1  |

| $A_0A_1$ | $B_0B_1$ | 00 | 01 | 11 | 10 |
|----------|----------|----|----|----|----|
| 00       | 1        | 1  | 1  | 1  |    |
| 01       | 1        | 1  | 1  | 1  |    |
| 11       |          |    |    |    |    |
| 10       |          |    |    |    | 1  |

26/02/19

Currently computing paradigms for machine learning

Assembly language - fast but very tough to program.

#### 4.4 Types of Microprocessors

Definition: Elementary operation performed with data stored in registers.

The microoperations most often encountered in DIGITAL COMPUTERS are classified into 4 categories.

① Register Transfer Microoperations : Transfer binary information from one register to another.

② ARITHMETIC OPERATIONS : perform arithmetic operation on NUMERIC DATA stored in registers

③ LOGIC MICROOPERATIONS : Perform BIT manipulation operations on non numeric data stored in registers.

Note: Register transfer micro operation doesn't change the info. content when the binary info moves from the source register to the destination register.

The other 3 types of microoperations change the info. content during transfers.

### BASIC ARITHMETIC MICROOPERATIONS

Addition, Subtraction, increment, decrement, shift shifts → arithmetic shifts.

Example :  $R_3 \leftarrow R_1 + R_2$  : ADD Microoperation.

$R_3 \leftarrow R_1 - R_2$  : SUB Microoperation.

The arithmetic operations of multiply and divide are not listed in the table 4.3. These two operations are VALID ARITHMETIC OPERATIONS but are not included in the basic set of microoperations. The only place where these operations can be considered as microoperations is in a digital system, where they're implemented by means of a combinational ckt.

### Example hardware

- 4 bit binary adder based on.

- Increment/Decrement microoperations are implemented with a combinational circuit or with a binary up down counter.

#### 4.5 LOGIC MICRO OPERATIONS :

- They specify binary operations for strings of bits stored in registers. These operations consider each bit of the register separately and treat them as binary variables.

Example: Exclusive  $\rightarrow$  'OR' microoperation with the

contents of two registers  $R_1, R_2$ .

$$\text{with control signal } P: R_1 \leftarrow R_1 \oplus R_2.$$

1010 — content of  $R_1$

1100 — content of  $R_2$

0110 — content of  $R_1$  after  $P=1$ .

#### SPECIFIC SYMBOLS

Specific symbols will be adopted for the LOGIC MICRO OPERATIONS OR, AND and COMPLEMENT, to DISTINGUISH them from the corresponding symbols used to express Boolean functions.

V -- OR , A -- AND , B -- COMPLEMENT.

ie. Bar on top of symbol.  
- By using different symbols, it will be POSSIBLE to DIFFERENTIATE b/w a LOGIC MICRO OPERATION and ~~control~~ CONTROL (or Boolean) functions.

+ used for arithmetic plus or logic OR.

- Although the plus symbol has two meanings, it will be possible to distinguish b/w them by noting WHERE THE SYMBOL OCCURS.

- When the symbol '+' occurs in micro-operations, it will denote an arithmetic plus.

- When it occurs in a control (or boolean) function it will denote an OR operation.

- We will never use it to symbolize an OR microoperation.

$$P + Q : R_1 \leftarrow R_2 + R_3 ; R_4 \leftarrow R_5 \vee R_6.$$

'+' b/w 'P' and 'Q' is an OR operation b/w ~~two~~ two binary variables of a CONTROL FUNCTION.

+ b/w  $R_2, R_3 \dots$  Add microoperation.

- OR logic operation is represented by the symbol ' $\vee$ ' between  $R_5$  and  $R_6$ .

left shift  
↓  
double  
notaa

### SOME APPLICATIONS:

- Logic microoperations are very useful for manipulating individual bits or a portion of word stored in register.

- They can be used to change bit values, delete a group of bits or ~~not~~ insert new bit values into a register.



25/03/19

## Tutorial

### Register transfer & μ-ops

Simple digital system :- Combinational & Sequential Ckt. are used to create simple digital sys

- low level building blocks
- No. of registers
- No. of ops

## REGISTERS

- More the general purpose registers, faster the execution  
    ↓  
    Temporary storage.
- AC - Accumulator - processor register.  
    ↳ used to hold the first ~~last~~ value & o/p.  
        LDA, STA, ADD.
- PC - program counter - the next instruction's address is stored in the content of PC.  
    the content of PC is stored in stack.  
    main() {  
        add();  
        add();  
        shift();  
        shift();  
    }
- Instruction Register → holds the instruction to be executed.
- MAR (memory address register) - holds address (main memory address content)  
    then → DR (data R) & holds the content.
- no [address register]

## COMPUTER ORGANIZATION:

- Set of Registers
- Microoperations
- Control signals.

RTL

$$R_1 \leftarrow R_0$$

$$P: R_1 \leftarrow R_0$$

on reading the instruction P, if its 1,  
then  $R_0$  will move to  $R_1$

represented as



④ For a 4-bit Bus Transfer, we use a 4x1 multiplexer.



## Memory Transfer



$$R_3 \leftarrow R_1 + R_2 \rightarrow \text{addition}$$

$$R_3 \leftarrow R_1 - R_2 \rightarrow \text{subtraction}$$

$$R_2 \leftarrow R_1' \rightarrow 1\text{'s complement}$$

$$R_2 \leftarrow R_1' + 1 \rightarrow 2\text{'s complement}$$

$$R_3 \leftarrow R_1 + R_2' + 1 \rightarrow 2\text{'s complement subtraction}$$

$$R_1 \leftarrow R_1 + 1 \rightarrow \text{Increment}$$

$$R_1 \leftarrow R_1 - 1 \rightarrow \text{Decrement}.$$

ALU + control unit  $\rightarrow$  CPU.

06/03/19

- Major functional parts in a digital computer :

(i) CPU    (ii) Memory    (iii) I/P-O/P processor.

- Main digital hardware functional units of CPU :

(i) Control unit    (ii) ALU    (iii) Registers

- Functions of Control Unit : Initiates a sequence of micro-operations.

- The # of different types of microoperations that are available in a given system is finite.
- Complexity of the digital system is derived from the # of sequences of microoperations that are performed.

→ Two methods of implementing CONTROL UNIT:

- Hardwired control unit.
- Microprogrammed control units.

(2) Design of hardwired control unit involves the use of FIXED INSTRUCTIONS, FIXED LOGIC BLOCKS of arrays of ENCODERS, DECODERS.

→ Key characteristics of hardwired control logic are:-

- High speed of operation.
- Expensive
- Relatively complex.
- No flexibility of adding.

Example CPU's: with hardwired logic control:

Intel 8085, Motorola 6802, Zilog 80 and any.

RISC (Reduced Instruction Set Computers) CPU's.

Note: When the control signals are generated by hardware using conventional logic design techniques, the ~~con~~ CONTROL UNIT is said to be hardwired.

MICRO PROGRAMMING: is a second alternative for designing the ~~control~~ CONTROL UNIT of a digital computer.

- The principle of MCV is an ELEGANT and SYSTEMATIC method of controlling the MICROOPERATION sequences in a digital computer.

CPU's with MCV are Intel 8080, Motorola 68000 and any CISC computer (Complex Instruction Set Computer (CPUs)).

Details of MCV  $\rightarrow P : R_2 \leftarrow R_1$

- The control function that specifies a MICRO OPERATION is a binary variable. When it is in one binary state, the corresponding micro-operation is executed.
- A control variable in the opposite binary state doesn't change the state of the registers in the system. The active state of a control variable may be either '1' state or the '0' state depending on the application.

→ In a BUC organized system, the control ~~unit~~ signal that specify micro-operations are GROUPS OF BITS that select the paths in multiplexers, decoders and Arithmetic Logic units.

### The control:

→ The control unit Initiates a series of sequential steps of MICRO OPERATIONS. During any given time, certain operations are to be micro

→ The control variables at any point of time can be represented by a string of 1s and 0s called a CONTROL WORD. As such control words can be programmed to perform various operations on the components of the system.

→ A control unit whose BINARY CONTROL VARIABLES are stored in a memory is called a MPCU → Microprogrammed control unit.

→ Each word in CONTROL MEMORY contains within it a MICRO-OPERATION. The μ-instruction specifies one or INSTRUCTION.

more microoperations for the system.

→ A sequence of microinstructions constitutes a MICRO PROGRAM

→ Since all the microinstructions of the MICRO PROGRAM are not needed once

FULL YR

→ The design of complex digital systems at the gate and flip-flop level is tedious and time consuming process.

07/03/19

## Hardware Description Languages :

→ The design of complex digital systems at the gate and flip-flop level is tedious and time consuming process.

- Digital systems can be described at the register transfer level by means of Hardware Description Language (HDL)
- The HDL is a viable solution for designing & debugging a digital system at a higher level before ~~conversion~~ conversion to the gate & flip-flop level. To do the conversion, computer aided design (CAD) tools can be used (FPGA, PLA → programmable logic)

Note: This is similar to the converting a high level language program into machine language using compiler.

- Popular HDL's are VHDL or VHDL and verilog HDL.
- VHSIC → very high speed integrated circuit.

$$R_1 \rightarrow R_2 \rightarrow R_3$$

## BASIC COMPUTER ORGANIZATION & DESIGN

Organization of Computer: Defined by its internal registers, the TIMING and CONTROL STRUCTURE and the SET OF INSTRUCTIONS that it uses.

## DESIGN OF A DIGITAL COMPUTER (DC)

- The internal organization of a digital system is defined by the sequence of MICRO-OPTIONS. It performs on the data stored in registers.
- The general purpose DC is capable of executing various μ-OPTIONS and in addition can be instructed as to what specific sequence of operations it has to perform.
- The user of a computer can CONTROL the process by means of a PROGRAM.
- Program is a set of INSTRUCTIONS that specify operations, operands and the sequence by which processing has to occur.
- The data processing task may be altered by specifying a new program with a different instructions or specifying with the same instructions with different data.

## A COMPUTER INSTRUCTION:

- Binary code that specifies a sequence of  $\mu$ -operations.
- Instruction code, together with DATA are stored in memory.  
The computer reads each instruction from memory and ~~passes~~ places it on a CONTROL REGISTER.
- The control then ~~proceeds to~~ interprets the binary code of instruction and proceeds to executing it by issuing sequence of  $\mu$ -operations.
- Every computer has its own unique instruction set.

- It is usually divided into parts, each having its own particular interpretation.
- MOST BASIC PART of an instruction : operation part.  
The operation code is a group of bits that define such operations as ADD, SUBTRACT, MULTIPLY, SHIFT and COMPLEMENT.
- The number of bits required for the OPERATION CODE (op code) of an instruction depends on TOTAL NO OF OPERATIONS.