# Enhancing Computer Processing Speed by Redesigning the Element of Its Main Memory

Samson Ogunlere, Chigozirim Ajaegbu, Olusola Maitanmi, Olawale Somefun <sup>1234</sup>Computer Science Department, Babcock University, Ilishan-Remo, Nigeria <sup>1</sup>ogunleres@babcock.edu.ng, <sup>2</sup>ajaegbuc@babcock.edu.ng, <sup>3</sup>maitanmis@babcock.edu.ng, <sup>4</sup>somefuno@babcock.edu.ng

*Abstract* - The performance of computers is mainly determined by their speed of operation which is governed by the Processor and Memory. In order to improve the speed of a computer, both the Processor and main Memory design must be improved. Hence, this research work is aimed at increasing the main memory speed of a computer by redesigning the components that make up the computer main memory. The design of basic memory devices, using the different Memory Elements developed from practical experimentation, analytical and numerical frameworks, was done. Analysis of each design was established using Propagation Route Framework in order to determine which of them gave higher computer speed. It was observed that the number of transitions required to complete a propagation route in the proposed SET/RESET memory element tagged SR<sub>ALT</sub> shows an operational maximum number of fourteen (14) transistors as against sixteen (16) transistors of the conventional SET/RESET memory element tagged SR<sub>CONV</sub>. Likewise, the SR<sub>ALT</sub> maximum data route delay passes through (3) gates as against SR<sub>CONV</sub> that has its maximum data route delay was drastically reduced, thereby increasing the speed of the computer processing when compared with the conventional (SR<sub>CONV</sub>), commercially available RAMs.

Keywords - SET/RESET Memory Element, SRALT, SRCONV, Propagation Route Framework, Quantum Computing.

#### I. INTRODUCTION

Computing technology, from desktop and laptop computers through cell-phones and embedded computing devices in everything from automobiles and consumer appliances to life saving medical equipment permeates nearly all aspects of modern life. Computer performance over the past fifty years has seen dramatic improvement due to technological advancements in semiconductor and silicon process. These advancements have enabled the number of transistors on a single chip to double every two years as suggested by Moore's Law [1]. Processor performance has also doubled every two years in the same time period as a corollary to Moore's Law due to a combination of larger transistor budget and the increased switching speed of transistors. However, comparable increase in the performance of computers may not be as a result of increase in processor performance for all types of applications. The reason is that computer performance is governed by the interaction between the memory and processor devices. Moreover, in contrast to the rapid improvements in processor performance, memory devices performance has seen only relatively modest improvements in the past fifty years [2,], [3] as depicted in Fig. 1. The source for this gap is directly related to the gap between transistor performance progresses versus on-chip interconnect delay.



Fig. 1. Processor versus Memory Gap, [2], [3]

Printed circuit board ('PCB') which is used to connect processor to memory also adds significantly to the 'gap,' [4] as illustrated in Fig. 2.



Fig. 2. Processor to Memory connection through PCB, [4]

For processors, this translates into performance, but for memory, it is not because processing power is optimized for computation while RAM is optimized for capacity. It is logical therefore to say that capacity affects performance, hence the result of the imbalance in performance between memory and processor in modern computers are increasingly inhibited by the performance of memory.

#### A. Growth in Processor Performance

After the release of the first microprocessor, Intel 4004 in 1971 [5], we have continually seen the launch of a new microprocessor every year, with each new one delivering significant performance improvements over previous ones unlike its memory counterpart. Some studies estimated this growth to have been exponential (in the order of about 52% per year) between 1986 and 2003 [6] as depicted in Fig. 3.



Fig. 3. Growth in processor performance over 40 years [6]

From Fig. 3, it can be seen that the early growth in processor performance averaged about 22% per year, or doubling performance every 3.5 years. Then an increase in growth to about 52% starting in 1986 or put in another way, doubling every 2 years was realized. This speed was also majorly made possible because of the emergence of the Reduced Instruction Set Computing (RISC) architecture. By 2003, the power limits were reached due to the end of Dennard scaling and the overall performance due to instruction-level parallelism significantly slowed down; hence up to 2011 we got performance growth doubling every 3.5 years.

Between 2011 and 2015, an annual improvement that was less than 12% or doubling every 8 years was achieved. This was in part due to the limits of parallelism of Amdahl's Law and the end of Moore's law. By 2015, with the impending end of Moore's Law, improvement has been reduced, just at 3.5% per year, or doubling every 20 years [6].

### B. What next after Moore's Law?

Though microprocessor has evolved all through the years with probably higher speed of operations than its memory counterpart; however, with the end of Dennard scaling, the impending complete demise of Moore's law and huge limits in parallelism due to Amdahl's law, there is the need to start seeing microprocessor and general computing in a new light. According to [6], there is a need for drastic change in computer architecture from general-purpose cores to Domain-Specific Architectures (DSAs). A computer of the future should consist of standard processors to run conventional large programs such as operating systems along with domain-specific processors that do only a narrow range of tasks extremely well [6]. This implies that computer engineers and architects need to rethink the way computers are built in order to leverage on fast processing and implementation of some Machine Learning Algorithms on huge dataset. Hence it is imperative that Architects and Engineers must be aware of the environment for which they must design a computer for.

For these reasons, it is highly imperative to re-analyze and re-design an efficient and high performance memory element for enhanced computer processing speed that can compete favorably with its processor counterpart while waiting for the proposed Quantum Computing Technology or other technologies that will take over from Moore's Law. One way for chip designers to overcome the slowing down of advances in general purpose chips is to make ever more specialized processors and memories. Graphics processing units (GPUs), Custom specialized processors for neural networks, computer vision for self-driving cars, voice recognition, and Internet of Things devices are just some few examples. These special designs can boast a range of improvements for greater levels of performance.

Thus, the optimization of existing hardware structures is necessary when the requirement of the memory element is for low-power, high-speed or low-noise applications. Even if Moore's Law was to end tomorrow, optimizing today's software would still provide years, if not decades, of growth, with little hardware improvements. Whether it is new configuration of machines, chips made out of entirely new materials, or new types of subatomic research that open up new ways of packing transistors on to chips, it is believed that the future of computing, with all the ingenuity it involves will continue to be reckoned with.

#### II. DESIGNING A FEASIBLE ALTERNATIVE OF S/R MEMORY ELEMENT

Alternative SR- memory element, to conventional one is proposed. The alternative SR- memory element is tagged  $SR_{ALT}$ -memory element and the conventional one tagged  $SR_{CONV}$  memory element as highlighted in Tables 1a and 1b.

| ra. SKALT Memory Element |                          |                                                                                                                                                                                                                                                                                          |    |                  |               |  |  |  |  |
|--------------------------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|------------------|---------------|--|--|--|--|
| S/N                      | S                        | R                                                                                                                                                                                                                                                                                        | Qn | Q <sub>n+1</sub> | REMARKS       |  |  |  |  |
| 0                        | 0                        | 0                                                                                                                                                                                                                                                                                        | 0  | 0                | Resting State |  |  |  |  |
|                          | 0                        | 0                                                                                                                                                                                                                                                                                        | 1  | 1                | Resting State |  |  |  |  |
| 1                        | 0                        | 1                                                                                                                                                                                                                                                                                        | 0  | 0                | Active Sate   |  |  |  |  |
|                          | 0                        | 1                                                                                                                                                                                                                                                                                        | 1  | 0                | Active State  |  |  |  |  |
| 2                        | 1                        | 0                                                                                                                                                                                                                                                                                        | 0  | х                | Forbidden     |  |  |  |  |
|                          | 1                        | 0                                                                                                                                                                                                                                                                                        | 1  | х                | Forbidden     |  |  |  |  |
| 3                        | 1                        | 1                                                                                                                                                                                                                                                                                        | 0  | 1                | Active Sate   |  |  |  |  |
|                          | 1                        | 1                                                                                                                                                                                                                                                                                        | 1  | 1                | Active State  |  |  |  |  |
| Transition               | 0 -<br>0 -<br>1 -<br>1 - | 1       1       1       Active state         0 $\rightarrow$ 0: S = 0,0 & R = 0,1 = [S = 0 & R = x]         0 $\rightarrow$ 1: S = 1 & R = 1 = [S = 1 & R = 1]         1 $\rightarrow$ 0: S = 0 & R = 1 = [S = 0 & R = 1]         1 $\rightarrow$ 1: S = 0,1 & R = 0,1 = [S = x & R = x] |    |                  |               |  |  |  |  |

TABLE 1a & 1b

Building Memory Element Using  $SR_{\text{ALT}}$  and  $SR_{\text{CONV}}$  NOR Gate Configurations respectively

| 1b. SR <sub>CONV</sub> Memory Element |   |    |                  |                 |  |  |  |
|---------------------------------------|---|----|------------------|-----------------|--|--|--|
| S                                     | R | Qn | Q <sub>n+1</sub> | TransitionState |  |  |  |
| 0                                     | 0 | 0  | 0                | Resting         |  |  |  |
| 0                                     | 0 | 1  | 1                | Resting         |  |  |  |
| 0                                     | 1 | 0  | 0                | Active          |  |  |  |
| 0                                     | 1 | 1  | 0                | Active          |  |  |  |
| 1                                     | 0 | 0  | 1                | Active          |  |  |  |
| 1                                     | 0 | 1  | 1                | Active          |  |  |  |
| 1                                     | 1 | 0  | D                | Forbidden       |  |  |  |
| 1                                     | 1 | 1  | D                | Forbidden       |  |  |  |

Note that,  $Q_n$  = Present Output and  $Q_{n+1}$  = Future Output or  $Q_n$  = Previous Output and  $Q_{n+1}$  = Present Output, D and X = don't care term (0, 1)

#### A. Developing SR<sub>ALT</sub> Memory Element Circuit Logic Diagram Using NOR Gate

The K-map of the  $SR_{ALT}$  memory element is shown in Table 2 based on Truth Table of Table 1a. The mathematical simplification of equations (1.1) and (1.2) using De-Morgan's Theorem and Boolean algebra rules in which real circuit design of the  $SR_{ALT}$  is developed as shown in Fig. 4.



TABLE 2

From the K-map of Table 2, equations 1.1 and 1.2 were derived concerning the  $SR_{ALT}$  memory element as the mathematical simplification using De-Morgan's Theorem and Boolean algebra rules for the  $SR_{ALT}$  memory element is shown in Table 3.

 TABLE 3

 Mathematical Simplification Using De-Morgan's Theorem

 $\bar{Q}_{n+1} = \bar{S}\bar{Q}_n + \bar{S}R......(1.1)$   $\bar{S}\bar{Q}_n = \bar{Q}_n + \bar{S}$   $\bar{S}\bar{R} = \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $Q_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{R} + \bar{S}$   $\bar{Q}_{n+1} = \bar{Q}_n + \bar{S} + \bar{Q}_n + \bar{R}$   $\bar{Q}_{n+1} = \bar{S} + \bar{Q}_n + \bar{R}$ 

The overall equations are as follows:

$$\overline{Q}_{n+1} = \overline{SR} + \overline{Q}_n \overline{S} \qquad (1.1)$$

$$Q_{n+1} = S + Q_n \overline{R} \qquad (1.2)$$

Combining equations 1.1a and 1.2a will produce the circuit diagram of Fig. 4.



Fig. 4. Logic Circuit of SRALT Using NOR gates configuration (Positive Logic Design)

#### B. Developing SR<sub>CONV</sub> Memory Element Circuit Logic Diagram Using NOR Gate

The Truth Table of Table 1b is converted into a K-Map in order to obtain the minimized logic equations of the SR<sub>CONV</sub> as shown in Table 4.

TABLE 4 K-Map for SR<sub>CONV</sub> Memory Element

| (SR-FF) Using NOR Gates                                                                                                      |    |    |    |         |  |
|------------------------------------------------------------------------------------------------------------------------------|----|----|----|---------|--|
| Qn                                                                                                                           | 00 | 01 | 11 | 10      |  |
| 0                                                                                                                            | 0  | 0  | d  | مل<br>ا |  |
| 1                                                                                                                            | T  | 0  | D  |         |  |
| $Q_{n+1} = S + \overline{R}Q_n \dots \dots (2.1)$<br>$\overline{Q}_{n+1} = R + \overline{S}\overline{Q}_n \dots \dots (2.2)$ |    |    |    |         |  |

Logic equations (2.1) and (2.2) are derived from the K-Map, and they can be used to construct the memory element using NOR gate configuration as given by the equations. The mathematical analysis of these equations using De-Morgan's theorem and Boolean algebra rules is as follows:

 $Q_{n+1} = S + \overline{R}Q_n \dots \dots (2.1)$   $\therefore \quad \overline{R}Q_n = \overline{R + \overline{Q}_n} \dots \dots (2.1a)$ Put equation (2.1a) into (2.1), we have  $Q_{n+1} = S + \overline{R + \overline{Q}_n} \dots \dots (2.1b)$ Complement equation (2.1b), we have  $\overline{Q}_{n+1} = \overline{S + \overline{R + \overline{Q}_n}} \dots \dots (2.1c)$ Also; Since,  $\overline{Q}_{n+1} = R + \overline{S}\overline{Q}_n$  in equation 2.2, Then,  $\overline{S}\overline{Q}_n = \overline{S + Q_n} \dots \dots (2.1d)$ Substituting equations (2.1d) into (2.1a), we have

 $\overline{\overline{SQ}_n} = \overline{S + Q_n} \dots \dots (2.1d)$ Substituting equations (2.1d) into (2.1a), we have  $\overline{Q}_{n+1} = R + \overline{S + Q_n} \dots \dots (2.1e)$ Complementing equation (2.1e), we have  $Q_{n+1} = \overline{R + \overline{S + Q_n}} \dots \dots (2.1f)$ 

Combining equations (2.1c) and (2.1f) results in the construction of SR<sub>CONV</sub> Logic Circuit Diagram, using only NOR gates (Positive Logic Design) configuration as shown in Fig. 5.



Fig. 5. Logic Circuit of SR<sub>CONV</sub> Using NOR gates configuration (Positive Logic Design)

# III. DATA PRESENTATION AND THE RESULTING DESIGN OF SR<sub>ALT</sub> AND SR<sub>CONV</sub> AT 50% ACTIVE STATES

Considering using the Set and Reset (SR) Memory Element, the Data Presentation and the Resulting Design can be derived from the Input Combination Table 5.

| S/N | Se | Ι | W | Qn | Qn+1 | SALT | RALT | Sconv | RCONV. |
|-----|----|---|---|----|------|------|------|-------|--------|
| 0   | 0  | 0 | 0 | 0  | 0    | 0    | х    | 0     | Х      |
| 1   | 0  | 0 | 0 | 1  | 1    | х    | Х    | Х     | 0      |
| 2   | 0  | 0 | 1 | 0  | 0    | 0    | х    | 0     | Х      |
| 3   | 0  | 0 | 1 | 1  | 1    | х    | Х    | Х     | 0      |
| 4   | 0  | 1 | 0 | 0  | 0    | 0    | Х    | 0     | Х      |
| 5   | 0  | 1 | 0 | 1  | 1    | х    | х    | Х     | 0      |

TABLE 5 Truth Table of Memory Elements on the  $SR_{\text{ALT}}$  and  $SR_{\text{CONV}}$ 

| 6     | 0   | 1      | 1     | 0   | 0 | 0 | х  | 0 | Х |
|-------|-----|--------|-------|-----|---|---|----|---|---|
| 7     | 0   | 1      | 1     | 1   | 1 | х | х  | Х | 0 |
| 8     | 1   | 0      | 0     | 0   | 0 | 0 | х  | 0 | Х |
| 9     | 1   | 0      | 0     | 1   | 1 | х | XX | Х | 0 |
| 10    | 1   | 0      | 1     | 0   | 0 | 0 | х  | 0 | Х |
| 11    | 1   | 0      | 1     | 1   | 0 | 0 | 1  | 0 | 1 |
| 12    | 1   | 1      | 0     | 0   | 0 | 0 | х  | 0 | Х |
| 13    | 1   | 1      | 0     | 1   | 1 | х | х  | Х | 0 |
| 14    | 1   | 1      | 1     | 0   | 1 | 1 | 1  | 1 | 0 |
| 15    | 1   | 1      | 1     | 1   | 1 | х | 0  | Х | Х |
| Input | Com | oinati | on Ta | ble |   |   |    |   |   |

The values of  $S_{ALT}$  and  $R_{ALT}$  are plotted into their respective K-Maps as shown in Table 6 from where the corresponding logic equations 3.1 and 3.2 are derived.

| $S_3 = S_e I W$    | <br>(3.1) |
|--------------------|-----------|
| $R_3 = S_e \ldots$ | <br>(3.2) |

|                               | TABLE 6<br>K-MAP FOR SR <sub>ALT</sub> MEMORY ELEMENT |                |                       |                 |                |           |       |                |                |                 |                 |
|-------------------------------|-------------------------------------------------------|----------------|-----------------------|-----------------|----------------|-----------|-------|----------------|----------------|-----------------|-----------------|
| $S_3 = S_e I W  \dots  (3.1)$ |                                                       |                |                       |                 |                | $R_3 = S$ | Ge (3 | 3.2)           |                |                 |                 |
| SeI                           |                                                       | 00             | 01                    | 11              | 10             | SeI       |       | 00             | 01             | П               | 10              |
| WQn                           | 00                                                    | 00             | 04                    | 012             | 08             | WQn       | 00    | x <sup>0</sup> | x <sup>4</sup> | x <sup>12</sup> | x <sup>8</sup>  |
|                               | 01                                                    | $\mathbf{x}^1$ | x <sup>5</sup>        | x <sup>13</sup> | x <sup>9</sup> |           | 01    | $\mathbf{x}^1$ | x <sup>5</sup> | x <sup>13</sup> | x <sup>9</sup>  |
|                               | 11                                                    | x <sup>3</sup> | <b>x</b> <sup>7</sup> | XD              | 011            |           | 11    | x <sup>3</sup> | x <sup>7</sup> | x <sup>15</sup> | 1 <sup>11</sup> |
|                               | 10                                                    | 0 <sup>2</sup> | 06                    | 1 <sup>14</sup> | 010            |           | 10    | x <sup>2</sup> | x <sup>6</sup> | 14              | x <sup>10</sup> |

The resulting circuit diagram is shown in Fig. 6.



Fig. 6. Basic Memory Element Using SR<sub>ALT</sub>

For the Conventional (SR<sub>CONV</sub>) designated S<sub>Conv</sub>, & R<sub>Conv</sub>; the values of S and R, are plotted into their respective K-Maps as shown in Table 7 from where the corresponding logic equations 4.1 and 4.2 are derived.

| $S = S_e I W$                 | (4.1) |
|-------------------------------|-------|
| $\mathbf{R} = S_e \bar{I} W.$ | (4.2) |

 TABLE 7

 K-Maps for Conventional SR- Memory Element at 50% active state

| K-Map for S        |    |                |                |                        |                               |     |    | K-Map          | for R          |                 |                 |
|--------------------|----|----------------|----------------|------------------------|-------------------------------|-----|----|----------------|----------------|-----------------|-----------------|
| $S = S_e IW$ (4.1) |    |                |                |                        | $\mathbf{R} = S_e \mathbf{I}$ | W   |    | (4.2)          |                |                 |                 |
|                    |    | Sel            | [              |                        |                               |     |    | Se             | I              |                 |                 |
| WQn                |    | 00             | 01             | 11                     | 10                            | WQn |    | 00             | 01             | 11              | 10              |
|                    | 00 | $0^{0}$        | 04             | 012                    | 08                            |     | 00 | $X^0$          | $X^4$          | X <sup>12</sup> | X <sup>8</sup>  |
|                    | 01 | $X^1$          | X <sup>5</sup> | <b>X</b> <sup>13</sup> | X9                            |     | 01 | $0^{1}$        | d <sup>5</sup> | 013             | 09              |
|                    | 11 | X <sup>3</sup> | X <sup>7</sup> | X <sup>15</sup>        | 011                           |     | 11 | 0 <sup>3</sup> | 07             | 015             | 111             |
|                    | 10 | 0 <sup>2</sup> | 06             | 1 <sup>14</sup>        | 010                           | 1   | 10 | $X^2$          | X <sup>6</sup> | 014             | X <sup>10</sup> |

When values of S and R, are plotted into their respective K-Maps as shown in Table 6, from where the corresponding logic equations ( $S = S_e$ . I. W and  $R = S_e$ .  $\overline{I}$ .W), are derived. The resulting circuit diagram for conventional SR memory element is developed as shown in Fig. 7.



Fig. 7. Basic Memory Element Using SR<sub>CONV</sub> at 50% utilization

#### A. Summary of Memory Elements Design

The summary of Basic Memory Elements of all the different Configurations is presented in Table 8.

|     | TABLE 8<br>Summary of the Different Memory Element Designs |                                                 |  |  |  |  |  |  |
|-----|------------------------------------------------------------|-------------------------------------------------|--|--|--|--|--|--|
| S/N | ТҮРЕ                                                       | STORAGE DEVICE                                  |  |  |  |  |  |  |
| 1.  | <b>Basic Memory Element made of SR</b> CONV will be active | This is the conventional memory element used to |  |  |  |  |  |  |
|     | only when SR = 00, 01 & 10 (50%)                           | build Storage Media                             |  |  |  |  |  |  |
| 2.  | Basic Memory Elements made of the SRALT will only          | This can be used to build Storage Media         |  |  |  |  |  |  |
|     | be active when SR = 00, 01 & 10 (50%)                      | This presents fewer network gate(s)             |  |  |  |  |  |  |

# IV. COMPARATIVE PERFORMANCE ANALYSIS OF THE TWO CONFIGURATIONS WITH RESPECT TO PROPAGATION TIME FRAMEWORK.

In digital logic design, analysis of Propagation Time is a measure of performance, which in this case speed performance of computer memory. The propagation time is determined by the number of transitions required to complete a propagation route in memory element configuration. This is used to examine the performance sensitivity of the various unit configurations in other to ascertain their comparative performances. To demonstrate the utility and flexibility of this framework, it is important to know the number of transistors per gate that make up a basic memory element. This is paramount in determining the performance or how fast a memory element is. The following should be noted in using Complementary Metal Oxide Semiconductor (CMOS).

- 1. Inverter gate has 2Transistors
- 2. AND gate has 6Transistors
- 3. OR gate has 6Transistors
- 4. NAND gate has 4Transistors, and
- 5. NOR gate has 4Transistors

#### A. Determination of Transition Routes for SR<sub>CONV</sub> Memory Element

Starting with SR conventional ( $SR_{CONV}$ ) memory elements, the propagation time for this is examined in Fig. 8 where 'T' represents Transistor(s) and 'G' represents Gate(s). Table 9 shows the number of transitions required to complete a propagation route in this configuration.



Fig. 8. Basic Memory Element using SRCONV 50%

| SIGNAL     | TRANSITION ROUTE                                                                                   | REMARKS                                   |
|------------|----------------------------------------------------------------------------------------------------|-------------------------------------------|
| Select, Se | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate 1 $\rightarrow$ 2-           | One 3-Input AND-gate 1 Ext has [6T]       |
|            | Input NOR-gate $4 \rightarrow Q$                                                                   | Two 2-Input NOR-gate 1 & 4 has [8T]       |
|            |                                                                                                    | Total No of Gates [Transistors] = 3 [14T] |
|            | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate 3 $\rightarrow \overline{Q}$ | One 3-Input AND-gate 1 Ext has [6T]       |
|            |                                                                                                    | One 2-Input NOR-gate 3 has [4T]           |
|            |                                                                                                    | Total No of Gates [Transistors] = 2 [10T] |
|            | 3-Input AND-gate 2 Ext $\rightarrow$ R $\rightarrow$ 2-Input NOR-gate 2 $\rightarrow$ 2-           | One 3-Input AND-gate 2 Ext has [6T]       |
|            | Input NOR-gate $3 \rightarrow \overline{Q}$                                                        | Two 2-Input NOR-gate 2 & 3 have [8T]      |
|            |                                                                                                    | Total No of Gates [Transistors] = 3 [14T] |
|            | 3-Input AND-gate 2 Ext $\rightarrow$ R $\rightarrow$ 2-Input NOR-gate 4 $\rightarrow$ <b>Q</b>     | One 3-Input AND-gate 2 Ext has [6T]       |
|            |                                                                                                    | One 2-Input NOR-gate 4 has [4T]           |
|            |                                                                                                    | Total No of Gates [Transistors] = 2 [10T] |
| Write      | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate 1 $\rightarrow$ 2-           | One 3-Input AND-gate 1 Ext has [6T]       |
| Command,   | Input NOR-gate $4 \rightarrow \boldsymbol{Q}$                                                      | Two 2-Input NOR-gate 1 & 4 have [8T]      |
| W          |                                                                                                    | Total No of Gates [Transistors] = 3 [14T] |
|            | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate 3 $\rightarrow \overline{Q}$ | One 3-Input AND-gate 1 Ext has [6T]       |
|            |                                                                                                    | One 2-Input NOR-gate 3 has [4T]           |
|            |                                                                                                    | Total No of Gates [Transistors] = 2 [10T] |
|            | 3-Input AND-gate 2 Ext $\rightarrow$ R $\rightarrow$ 2-Input NOR-gate 2 $\rightarrow$ 2-           | One 3-Input AND-gate 2 Ext has [6T]       |
|            | Input NOR-gate $3 \rightarrow \overline{Q}$                                                        | Two 2-Input NOR-gate 2 & 3 have [8T]      |
|            |                                                                                                    | Total No of Gates [Transistors] = 3 [14T] |
|            | 3-Input AND-gate 2 Ext $\rightarrow$ R $\rightarrow$ 2-Input NOR-gate 4 $\rightarrow$ <b>Q</b>     | One 3-Input AND-gate 2 Ext has [6T]       |
|            |                                                                                                    | One 2-Input NOR-gate 4 has [4T]           |
|            |                                                                                                    | Total No of Gates [Transistors] = 2 [10T] |
| Data to be | Inverter $\rightarrow$ 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate       | One Inverter has [2T]                     |
| written, I | $1 \rightarrow 2$ -Input NOR-gate $4 \rightarrow \boldsymbol{Q}$                                   | One 3-Input AND-gate 1 Ext has [6T]       |
|            |                                                                                                    | Two 2-Input NOR-gate 1 & 4 have [8T]      |
|            |                                                                                                    | Total No of Gates [Transistors] = 4 [16T] |
|            | Inverter $\rightarrow$ 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate       | One Inverter has [2T]                     |
|            | $3 \rightarrow \overline{Q}$                                                                       | One 3-Input AND-gate 1 Ext has [6T]       |
|            |                                                                                                    | One 2-Input NOR-gate 3 has [4T]           |
|            |                                                                                                    | Total No of Gates [Transistors] = 3 [12T] |
|            | Inverter $\rightarrow$ 3-Input AND-gate 2 Ext $\rightarrow$ R $\rightarrow$ 2-Input NOR-           | One Inverter has [2T]                     |
|            | gate 2 $\rightarrow$ 2-Input NOR-gate 3 $\rightarrow Q$                                            | One 3-Input AND-gate 1 Ext has [6T]       |
|            |                                                                                                    | Two 2-Input NOR-gate 2 & 3 have [8T]      |
|            |                                                                                                    | Total No of Gates [Transistors] = 4 [16T] |
|            | Inverter $\rightarrow$ 3-Input AND-gate 2 Ext $\rightarrow$ R $\rightarrow$ 2-Input NOR-           | One Inverter has [2T]                     |
|            | gate $4 \rightarrow \boldsymbol{Q}$                                                                | One 3-Input AND-gate 1 Ext has [6T]       |
|            |                                                                                                    | One 2-Input NOR-gate 4 has [4T]           |
|            |                                                                                                    | Total No of Gates [Transistors] = 3 [12T] |
| NOTE: The  | maximum delay is caused by the data route passing throug                                           | h four (4) gates with 16 transistors      |

 $TABLE \ 9$  Number of transitions required for the SR\_{CONV} Memory Element Configuration

In determining the transition route for  $SR_{CONV}$  memory element, the propagation time is determined by the number of gates the signals have to pass through from the inputs to its outputs. Having known the number of gates, the number of Transistors is determined as shown in Table 9 with 16 Transistors as maximum delay caused by data route passing through 4 gates.

# B. Determination of Transition Routes for SR<sub>ALT</sub> Memory Element

For the **SR**<sub>ALT</sub> memory element configuration, the propagation time route is analysed as shown in Fig. 9 Table 10 respectively.



Figure 9: Basic Memory Element using SR<sub>ALT</sub> Configuration

| SIGNAL              | TRANSITION ROUTE                                                      | REMARKS                                      |
|---------------------|-----------------------------------------------------------------------|----------------------------------------------|
| Select, Se          | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
|                     | $5 \rightarrow \overline{\overline{Q}}$                               | One 2-Input NOR-gate has [4T]                |
|                     |                                                                       | Total No of Gates [Transistors] = 2 [10T]    |
|                     | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
|                     | $1 \rightarrow 2$ -Input NOR-gate $3 \rightarrow \boldsymbol{Q}$      | Two 2-Input NOR-gates have [8T]              |
|                     |                                                                       | Total No of Gates [Transistors] = 3 [14T]    |
|                     | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
|                     | $2 \rightarrow 2$ -Input NOR-gate $3 \rightarrow \boldsymbol{Q}$      | Two 2-Input NOR-gates have [8T]              |
|                     |                                                                       | Total No of Gates [Transistors] = 3 [14T]    |
|                     | R→Inverter→2-Input NOR-gate 1 & $3 \rightarrow Q$                     | One Inverter has [2T]                        |
|                     |                                                                       | Two 2-Input NOR-gate has [8T]                |
|                     |                                                                       | Total No of Gates [Transistors] = 3 [10T]    |
|                     | $R \rightarrow 2$ -Input NOR-gate 4 & $5 \rightarrow \overline{Q}$    | Two 2-Input NOR-gate has [8T]                |
|                     |                                                                       | Total No of Gates [Transistors] = 2 [8T]     |
| Write               | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
| Command, W          | $5 \rightarrow \overline{Q}$                                          | One 2-Input NOR-gate has [4T]                |
|                     |                                                                       | Total No of Gates [Transistors] = 2 [10T]    |
|                     | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
|                     | $1 \rightarrow 2$ -Input NOR-gate $3 \rightarrow \boldsymbol{Q}$      | Two 2-Input NOR-gates have [8T]              |
|                     |                                                                       | Total No of Gates [Transistors] = 3 [14T]    |
|                     | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
|                     | $2 \rightarrow 2$ -Input NOR-gate $3 \rightarrow \boldsymbol{Q}$      | Two 2-Input NOR-gates have [8T]              |
|                     |                                                                       | Total No of Gates [Transistors] = 3 [14T]    |
| Data to be          | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
| written, I          | $5 \rightarrow \overline{Q}$                                          | One 2-Input NOR-gate has [4T]                |
|                     |                                                                       | Total No of Gates [Transistors] = 2 [10T]    |
|                     | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
|                     | $1 \rightarrow 2$ -Input NOR-gate $3 \rightarrow \boldsymbol{Q}$      | Two 2-Input NOR-gates have [8T]              |
|                     |                                                                       | Total No of Gates [Transistors] = 3 [14T]    |
|                     | 3-Input AND-gate 1 Ext $\rightarrow$ S $\rightarrow$ 2-Input NOR-gate | One 3-Input AND-gate has [6T]                |
|                     | $2 \rightarrow 2$ -Input NOR-gate $3 \rightarrow \boldsymbol{Q}$      | Two 2-Input NOR-gates have [8T]              |
|                     |                                                                       | Total No of Gates [Transistors] = 3 [14T]    |
| NOTE: RESET (R)     | Terminal is permanently connected to logic HIGH.                      | So, it does not contribute to any delay that |
| might be experience | ed by RAM built with this memory element. The ma                      | ximum delay is caused by the data route      |
| passing through (3) | gates with 14 Transistors.                                            |                                              |

TABLE 10 Number of Transitions Required for the  $\mathrm{SR}_{\mathrm{ALT}}$  Memory Element Configuration

# B. Summary of Comparative Performance Analysis of SR<sub>CONV</sub> and SR<sub>ALT</sub> Memory Element

Fig. 9, Table 10 produce a Basic Memory Element that can be used to configure RAMs of different capacities towards faster computer processing speed judging from the analysis. It should be noted that the maximum delay is caused by the data route passing through (3) gates with 14 Transistors using  $SR_{ALT}$  memory element configuration. Likewise, the maximum route delay using  $SR_{CONV}$  memory element configuration of Fig. 8, Table 9, is caused by data passing through (4) gates with 16 Transistors. Comparing the number of transitions required to complete a propagation route in both configurations; it could be seen that number of gate is reduced by one while at the same time, the number of transistor is reduced by two using the alternative (SR<sub>ALT</sub>) configuration.

Since the ultimate metric of memory system performance is related to how fast it can service critical requests from processors; the rationale used to justify the focus of this study is that by improving the Memory Element used for designing memory system, the average request service time can be reduced. This study shows remarkable speed improvement.

# V. CONCLUSION

This study has established that the developed design  $\mathbf{SR}_{ALT}$  memory element has a lot of added performance advantages over the conventional memory element in terms of speed (because fewer gates enhance speed; i.e., gate delay represents performance), portability (less transistors, smaller size design of devices) and reduction in cost (because it requires fewer transistors as against the conventional one). It is an established fact that in digital device design, numbers of transistors represent hardware cost.

#### ACKNOWLEDGEMENT

This work was supported by the School of Computing and Engineering Sciences faculty of Babcock University. The authors would like to convey deep appreciation to the Computer Science departmental research group for a thorough experimental evaluation carried out on the design models used in this work.

#### REFERENCES

- [1] Moore G. E. "Moore's law. Conference paper on Intel Corporation". Retrieved from en.wikipedia.org/wiki/Moore's\_law, 1965
- [2] [3]
- Hennessy, J. L. & David A. P. "Computer Architecture: A Quantitative Approach. 4th ed.", p. 289. Elsevier Inc. 2007 McCalpin, J. D. "Memory Bandwidth and System Balance in HPC Systems, Invited Talk, International Conference for High Performance Computing, Networking, Storage, and Analysis, 2016; Available from: http://sites.utexas.edu/jdm4372/2016/11/22/sc16.
- [4] Yeap, G. "Smart mobile SOCs driving the semiconductor industry"; Technology trend, challenges and opportunities. In Electron Devices Meeting (IEDM), 2013
- Federico, F. (n.d.). "The Silicon Gate Design of the 4004". Retrieved December 01, 2018, from Intel 4004. Available from: [5] http://www.intel4004.com/sgdm.htm
- Hennessy, J. L., & Patterson, D. A. "Computer Architecture: A Quantitative Approach (6th edition)". Cambridge, MA: Elsevier Inc., [6] 2019.