Design of Low-Cost Stochastic Number Generator Using TSPC Logic in 45nm Technology

Pavan PH¹, Lalitha S²

¹Electronics and Communication Engineering, BMS College of Engineering, Bull Temple Road, Basavanagudi, Bengaluru, India
Email: pavanph123[at]email.com

²Electronics and Communication Engineering, BMS College of Engineering, Bull Temple Road, Basavanagudi, Bengaluru, India
Email: lalithas.ece[at]bmsce.ac.in

Abstract: An essential part of stochastic computing (SC) is the stochastic number generator (SNG). The SNG has an ability to change the binary numbers into stochastic bit streams. An SNG includes random number source (RNS) i.e., LFSR and a comparator. LFSR generates random bit sequences based on the tapings made in it. Using simulation outcomes, it describes how the weighted binary generator (WBG) which can be used to replace the comparator (CMP) component of SNG circuits to reduce SC correlation. The probability conversion circuit (PCC) is another name for WBG. The PCC converts the generated random numbers into a random bit stream, which has the desired chance of generating 1s. This project presents a comparative approach towards different logics in 45nm technology. Different logics are CMOS and TSPC. SNG is designed for every logic mentioned above. By comparing parameters like Area, Power consumption, Number of transistors used, working frequency, and concluding which logic based SNG is better.

Keywords: Linear feedback shift register, Stochastic number generator, weighted binary generator, Random number source

1. Introduction

An essential part of modern computing, the Stochastic Number Generator (SNG) manages the unpredictability in a wide range of applications. SNFs have proven to be remarkably sophisticated and adaptable in the face of contemporary issues. The problem of predictability and vulnerability has been addressed using advanced cryptography algorithms and methods. The generated sequences are protected from decryption efforts and pattern recognition by cryptographically secure SNFs, which contain challenging mathematical operations and strict entropy sources to fend off even the most cunning attacks.

The development of unique algorithms that optimize the trade-off between speed and statistical validity has addressed the problem of balancing randomness with computational efficiency. A new era of fully indeterministic sequences is also promised by the introduction of quantum-based random number generators, which will take use of the inherent unpredictable nature of quantum processes.

Fundamentally, modern SNFs have met the problem by using state-of-the-art cryptographic concepts, algorithmic breakthroughs, and quantum-inspired techniques. This development gives them the ability to overcome the complex difficulties given by modern computing environments, safeguarding data transmission, improving simulations, and strengthening their position as suppliers of real randomness in an increasingly interconnected digital world.

A contemporary method for using logic circuits to perform computations is stochastic computing (SC). Then executing computation on deterministic binary numbers, Stochastic computing circuits are built to process random bit streams. Bit streams are used to represent the input and output, and the values are encoded as the chances that the bit streams will include 1s. Compared to deterministic binary computing, Numerous benefits of stochastic computing include reduced hardware complexity, which may lead to fault-tolerant computing and cost-effective computing circuits.

A. Stochastic Number Generator (SNG)

A Stochastic Number Generator (SNG) is a fundamental computing tool that generates numbers in sequences with statistical characteristics similar to randomness. SNFs are essential for replicating randomness in different applications since computers create numbers deterministically, in contrast to actual random processes. These techniques are used by these generators, which are also used in simulations and cryptography, to create sequences that appear random. However, because SNFs are deterministic and repeating when the initial conditions are known, the phrase "pseudo-random" is frequently employed. Effective SNG design requires balancing variables like speed and statistical quality as well as resolving security issues.

![Figure 1: Stochastic number Generator](image)

B. Linear Feedback Shift Register

A Shift register’s input bits called in LFSR has a previous state that is linearly connected to it. The register's functioning is fated, and the streaming values generated is entirely defined by its current (or previous) state. A repeating cycle will occur due to the register's finite number of states. After 2n-1 cycles, the sequence repeats, and for a
given LFSR length, there may be more than one maximal tap sequence. Typically, this works with a clock pulse and an EXOR signal applied to each shift register's output. Typically, shift registers will be used as D flip flops.

![Linear Feedback Shift Register](image)

**Figure 2:** Linear Feedback Shift Register

The paper is organized as follows: Section II, depicts the literature reviews of Stochastic Number Generator. Section III describes the proposed Stochastic number generator using CMOS and TSPC logic. Section IV, the simulation results of proposed SNG. Section V concludes this paper.

2. **Literature Survey**

In this paper [1], the author has proposed a novel stochastic number generator architecture and proved that the resulting circuit can deliver independent stochastic numbers and improve the accuracy of the calculation results obtained using some recent conventional stochastic computing-based arithmetic circuits. This study is motivated by the increasingly important role of stochastic computing in various fields, such as the digital circuit design, where the stochastic number generators are responsible for a significant share of the hardware cost. Furthermore, the circuit constructed according to the proposed architecture delivers independent stochastic numbers and outperforms the circuits designed using conventional methods. In future studies, the author intends to evaluate the hardware cost of the proposed architecture [1].

A viable paradigm for achieving soft error-tolerant, low-complex digital circuits is stochastic computing (SC). SNG is a component of stochastic circuits that generates a stochastic number that corresponds to an input binary number. Traditional SNGs would take a long time to run since they use linear feedback shift registers (LFSRs) to create random numbers serially. This article suggests creating area-efficient SNGs. The suggested design generates stochastic bit streams with the least amount of area and power. SNGs using novel nanoscale components like memristors and spintronic devices have been proposed as a solution to this issue. However, due to unforeseen differences in their fabrication methods and noise in their control signals, these devices frequently have significant inaccuracies in their output probabilities. The author offers a fresh approach for utilizing such tools to create a very precise SNG. It is based on an RNS that, under ideal (nominal) circumstances, creates uniformly distributed random numbers. Additionally, when the RNS is prone to mistakes, it has a revolutionary error-canceling probability conversion circuit (ECPCC) that ensures extremely high accuracy in the output probability under realistic circumstances. Maximal correlated stochastic streams can also be produced by an ECPCC, which is a valuable feature for some applications [4].

Cryptographic key generation is an important part of the secured communication system where the key that is generated has a major role to play in the strength of the security of the data that is transferred. To enhance the necessary strength of the key, the random number generator has to be highly secure. This is enhanced using a True Random Number Generation. Diffused Bit Generator (DBG) is an entropy source which is used to produce a sequence of random bits. It is composed of a LFSR and a Cellular Automata for increasing the randomness emanating from the DBG. The proposed LFSR has been designed using TSPC based D flip-flops and the XOR gates consisting of 6 transistors, which has enabled it to fulfill the objective of low power. The circuit implementation has been done in Cadence Virtuoso in the CMOS 180 nm technology and simulated in Cadence Spectre. [3].

Low-area circuits are provided by stochastic unary computing. The required stochastic number generators (SNGs) in these circuits, however, can reduce their overall gain in area, especially if multiple SNGs are needed. By distributing the permuted output of a single linear feedback shift register (LFSR) among multiple SNGs, the author suggests creating area-efficient SNGs. The suggested design generates stochastic bit streams with the least amount of stochastic computing correlation (SCC) with no additional hardware overhead. When a 10-bit LFSR is shared between two SNGs, the authors' approach results in stochastic bit streams with 67% less average SCC than the circular
shifting method given in earlier work. The author suggests an algorithm to create a set of m permutations (n > m > 2) with a minimum pairwise SCC for an n-bit LFSR in order to generalize our method. When n rises, the search space for permutations with an exact minimum SCC expands quickly, and for n > 9, it becomes infeasible to run a search algorithm utilizing pairwise SCC values that have been precisely determined. To quickly locate a group of permutations with SCC values close to the minimal one, the author suggests a similarity function that may be incorporated into the suggested search process. For a number of applications, the author examined the strategy. The findings demonstrate that it delivers lower mean-squared error (MSE) with the same (or even smaller) area as past work [6].

3. Proposed Method

As it has been seen that how the Stochastic number generator works and what exactly it consists of. Stochastic number generator occupies more area in the stochastic computing circuits. By knowing all these, attempt has been to improve area consumption, a smaller number of transistor usage and the working frequency of the SNG. There are some of the logic in the VLSI design which are known for their unique characteristics. We decided to design SNG in 4 different logics such as CMOS and TSPC logic. Let us see the entire implementations of all the circuit.

Any SC circuit must have a stochastic number generator (SNG). To translate binary numbers into the corresponding random bit streams, a SC circuit employs SNGs. With probability of creating 1s equal to their corresponding binary integers, they produce random bit streams. SNGs are essential to a SC circuit's effectiveness.

There are many logics in VLSI designing Complementary Metal Oxide Semiconductor (CMOS) and True Single-Phase Clock (TSPC) to name a few. Here the question arises that which logic based SNG is better in all the parameters.

In response to the above question, the works in this paper are as follows: 1) The SNG is designed in different logic such as CMOS and TSPC. 2)Various parameters like Area, Power consumption, Number of transistors used, working frequency are compared and found that which logic SNG is better. The SNG’s implemented till date were designed using CMOS Logic and there is no information on implementations on TSPC and many other different logics in VLSI. Stochastic number generators continue to be among the costliest components of stochastic circuits. The problems of designing and deploying cost effective SNGs that ensure a desired, system-wide level of accuracy or precision is far from solved.

Till date there was an approach on improvising SNG by changing the circuit of PCC. In this work we have improved SNG in different parameters by designing it in different logics in 45nm technology. Not only PCC, each and every component has been designed in different logic to observe the mentioned constraints.

By comparing various parameters of SNG in different logics following were observed: Reduction in area, Reduction in no. of transistors required, Improvement in the working frequency and reduction in cost of the SNG in few logics. Thus, concluding which SNG is better according to the specifications.

The main objective of the proposed method is as follows:
- To design a low-cost stochastic number generator by sharing the single LFSR with two WBG circuits.
- To design all the components of the SNG in different logics like CMOS and TSPC and observe for perfect output.
- To observe the schematics, outputs and layouts of different SNGs.
- To build the compact layouts of all the components used in the project.
- To compare the different logic SNGs in parameters like Area consumed, Power consumed, No. of transistors and working frequency, thus concluding which SNG is better according to the given constraints and requirements.

A. CMOS logic

In VLSI there are different technologies. Most common used logic is Complementary Metal Oxide Semiconductor (CMOS). This is basically a class of integrated circuits, and is used in a range of applications with digital logic circuits, such as microprocessors, microcontrollers, static RAM, etc. It is also used in applications with analogue circuits, such as in data converters, image sensors, etc. There are quite a few advantages that the CMOS technology has to offer. One of the main advantages that CMOS technology, which makes it the most commonly-used technology for digital circuits today, is the fact that it enables chips that are small in size to have features like high operating speeds and efficient usage of energy.

Besides, they have very low static power supply drain most of the time. Besides, devices using CMOS technology also have a high degree of noise immunity. CMOS circuits use a combination of p-type and n-type metal–oxide–semiconductor field effect transistor (MOSFETs) to implement logic gates and other digital circuits.

B. TSPC Logic

Originally proposed as a high-speed topology, the TSPC structure also consumes less power and occupies less area than other methods. The high-speed dynamic True Single-Phase Clock (TSPC) logic design style offer fully pipelined logic circuits using only one clock signal, which makes clock distribution simple and compact. The TSPC-cell consists of one N-block and one P-block each driven by single clock signal.

In standard TSPC logic style the implementation of simple gates like AND, OR, XOR increases the transistor count since each logic cell implementation use both N-block together with P-block to remove transparency between the pipelined stages, while logic function is implemented only with N-block; therefore, it makes the P-block redundant, since it performs no logic function other than latching. Although logic merging is possible, in standard TSPC cell by implementing logic functions with both the N-block and P-block, but such a logic merging is inefficient, since in practical cases inputs to a gate may appear after different
cycle delays, which may not allow effective logic merging.

As we saw in the existing methodology, the block diagram of LFSR remains same for here too. But the main difference is that the circuit inside it is different. There are changes in basic components inner circuits.

**Proposed Weighted Binary generator (WBG):**

Weighted binary generator (WBG) is a PCC introduced by Gupta and Kumaresan. A WBG with the probability precision \( k = 8 \) is shown in Fig. The AND gates in the first level take unbiased random bits \( L_8 \ldots L_1 \) as inputs and produce the intermediate signals \( W_8 \ldots W_1 \).

\[
W_8 = L_8, W_7 = L_8' \& L_7, \quad W_6 = L_8' \& L_7' \& L_6, \quad W_5 = L_8' \& L_7' \& L_6 \& L_5, \quad W_4 = L_8' \& L_7' \& L_6 \& L_5' \& L_4, \quad W_3 = L_8' \& L_7' \& L_6 \& L_5' \& L_4' \& L_3, \quad W_2 = L_8' \& L_7' \& L_6 \& L_5' \& L_4' \& L_3' \& L_2, \quad W_1 = L_8' \& L_7' \& L_6' \& L_5' \& L_4' \& L_3' \& L_2' \& L_1 \ldots \ldots (1)
\]

Where & represents the logical AND. The AND gates in the second level take \( W_8, \ldots, W_0 \) and the target bits \( x_8, \ldots, x_0 \) as inputs and produce the intermediate signals. Finally, a tree of 7 two-input OR gates have been used. \( R_2 \ldots R_8 \) are the blocks of AND gates which we have made for references.

Given from equation (1), the probability of \( W_i \)'s are where \( i \) ranges from 8 to 1:

\[
P(W_8) = 1/2, \quad P(W_7) = 1/(2^2), \quad P(W_6) = 1/(2^3), \quad P(W_5) = 1/(2^4), \quad P(W_4) = 1/(2^5), \quad P(W_3) = 1/(2^6), \quad P(W_2) = 1/(2^7), \quad P(W_1) = 1/(2^8)
\]

The probability of out is given by:

\[
\text{P(out)} = P(W_8)x_8 + P(W_7)x_7 + P(W_6)x_6 + P(W_5)x_5 + P(W_4)x_4 + P(W_3)x_3 + P(W_2)x_2 + P(W_1)x_1
\]

\[
\text{P(out)} = (1/2)x_8 + (1/2^2)x_7 + (1/2^3)x_6 + (1/2^4)x_5 + (1/2^5)x_4 + (1/2^6)x_3 + (1/2^7)x_2 + (1/2^8)x_1
\]

\[
\text{P(out)} = X/(2^8), \quad \text{where} \quad X = (x_8 \ldots x_1)
\]

Thus, the WBG functions as PCC.

**Proposed stochastic number generator (SNG):**

Stochastic number generator (SNG) is an important component of a stochastic computing. It is the component which converts binary number into a stochastic bit stream. There are two main components in the stochastic number generator. SNG consists of a random number source (RNS) and a probability conversion circuit (PCC). RNS generates a random binary number distributed uniformly in the range \([0,2k-1]\) i.e., for every \([0,2k-1]\) bits the sequence repeats, where \( k \) is the bit width of the random binary number. The output of RNS can be taken as \( k \) unbiased bits having probability 0.5 for getting 1 and 0.5 for getting 0. We can consider linear feedback shift register as a random number source. In the above Fig we can observe that the random number source which provides random bit sequences has been shared between two PCC circuit just to make it of low cost as they saw in the paper.

**Figure 4:** SNG containing shared LFSR

The output of LFSR (RNS) is fed to the PCC circuit i.e., weighted binary generator. WBG is fed with another sort of inputs, those are called as target bits. \( x_8 \ldots x_1 \) are the target bits given to the 1st WBG circuit, \( y_8 \ldots y_1 \) are the target bits given to the 2nd WBG circuit. The 2 outputs are taken from 2 WBG circuit. They have to initialize the outputs of the linear feedback shift register; this process is called as a SEED.

When the clock pulse is applied to the LFSR, as we saw in the previous part, LFSR starts to generate random bit sequences. When these bits are fed to the WBG circuit, with the help of these random bits WBG encodes the target bits.

Then, can observe the output of SNG which has number of bits which are high is equal to decimal equivalent of target bits out of \( 2^k \) clock pulses. For example, if the target bits are 00000100. The decimal equivalent of the target bit is 4. In the output of an SNG, there will 4 bits which are high out of 256 bits.

**4. Simulation Results and Discussion**

The output of the SNG mainly depends upon the target bits given to the WBG circuit. The total number of ones in the output of SNG is the decimal equivalent of the target bits.
given to the WBG circuit. In this project we have shared a single SNG with two WBGs and hence we will get two outputs. We have designed an 8-bit SNG the total output bits are of 256 bits ($2^8$). The decimal equivalent of the target bits is the number of ones of the 256 bits.

The figures 5, 6 and 7 below shows the CMOS based 8-bit LFSR which consists of D Flip flops, WBG and SNG respectively. The design is done in Cadence Virtuoso Software using 45nm Technology.

The figures 9, 10 and 11 below are the TSPC based 8-bit LFSR, WBG and SNG respectively which consists of D Flip flops, AND gates, OR gates and XOR gates. The design is done in Cadence Virtuoso Software using 45nm Technology.
The figure 12 shows the output of the TSPC based SNG.

5. Comparison of Results

<table>
<thead>
<tr>
<th>Logics</th>
<th>CMOS</th>
<th>TSPC</th>
</tr>
</thead>
<tbody>
<tr>
<td>No. of Transistors</td>
<td>640</td>
<td>736</td>
</tr>
<tr>
<td>Area (in pm²)</td>
<td>38.85</td>
<td>35.95</td>
</tr>
<tr>
<td>Average power (in mW)</td>
<td>8.736</td>
<td>15.07</td>
</tr>
<tr>
<td>Working frequency (in GHz)</td>
<td>1.3</td>
<td>2</td>
</tr>
</tbody>
</table>

In the above table it can be observed that the values of different parameters in both logics. Here the SNG in CMOS logic uses less no. of transistors and the average power consumed is also low with respect to TSPC logic. SNG in TSPC logic consumes less area compared to CMOS. Therefore, it can be told that logics can be used according to the specifications and requirements.
6. Conclusion and Future Works

In this work, the schematic has been implemented SNG in different parameters by designing it in CMOS and TSPC logics in 45nm technology. Not only PCC, each and every component has been designed in corresponding logic to observe the mentioned constraints and to declare which logic based SNG is better. Improvements like reduction in area, reduction in number of transistors used, reduction in total power consumed and increase in working frequency is obtained in few logics.

According to observations, it can conclude that, if a SNG has to be designed with less no. transistors and less average power consumption CMOS based SNG can be used The TSPC based SNG can be used when less area constraints are to be satisfied and for high-speed applications.

The future scope in this field can be designing the SNG in many other different logics and observing which works in the better way. Furthermore, we can decompose the WBG into two parts, the set of AND gates at the first level that produces the intermediate signals and the remaining set of gates that produce the final output. This decomposition can be implemented in many other logics and corresponding outputs can be observed an experiment can be done by mixing the logics of few circuits for better outputs.

References


