Survey the stochastic computing and probabilistic transfer matrix (PTM) in logic circuits

Bahram Dehghan¹, Naser Parhizgar²

Department of Electrical Engineering, College of Engineering, Shiraz Branch, Islamic Azad University, Shiraz, Iran ¹,²

Abstract: Stochastic computing is a new alternative approach to conventional real arithmetic. Stochastic computation has been considered for different applications such as implementation of real-time motor controller and Error control coding and artificial neural networks. We have shown how to construct classic gates using probabilistic equations. In this paper, we focus on several logic circuits based on Probabilistic Transfer Matrix (PTM). In addition, this paper provides a survey of stochastic logic circuits with generating arbitrary probabilities. Also, we demonstrate PTMs is a methodology for representing probabilistic behaviour in logic circuits. In addition, our purpose has been to study the applicability of PTM in logic circuits. Results demonstrate that different kinds of logic circuits architecture can be verified with PTM methodology.

Keywords: Stochastic Computing, Probabilistic Transfer Matrix, Logic Circuits

I. INTRODUCTION

Stochastic computing (SC) was proposed in the 1960s as a low-cost alternative to conventional binary computing. It is unique in that it represents and processes information in the form of digitized probabilities[1]. Its key feature is the use of long random bit-streams called stochastic numbers (SNs) to represent the data being processed[2]. The idea of probabilistic computing with digital logic dates back to von Neumann [3] and Gaines [4]. Gaines introduced stochastic modules to perform simple arithmetic operations such as addition, multiplication, division and integration.

The growing interest in stochastic computing is attributed to the simplicity and error tolerance of the stochastic modules. Consider two independent random bit streams A and B as inputs to a two-input AND gate where, 

\[ \text{Prob}(A=1) = a, \text{Prob}(B=1) = b \quad (1) \]

The output random bit stream is then given by, 

\[ \text{Prob}(C=1) = \text{Prob}(A=1, B=1) = \text{Prob}(A=1) \cdot \text{Prob}(B=1) = ab \quad (2) \]

Stochastic multiplication is thus performed by one AND gate as shown in Fig.1[5]

\[
\begin{bmatrix}
0 & 1 & 0 & 1 & 1 & 0 \\
1 & 0 & 0 & 0 & 1 & 0 \\
0 & 0 & 0 & 0 & 1 & 0 \\
1 & 0 & 0 & 0 & 1 & 0 \\
0 & 0 & 0 & 0 & 1 & 0 \\
0 & 0 & 0 & 0 & 1 & 0
\end{bmatrix}
\begin{bmatrix}
a \\
b \\
1/6
\end{bmatrix}
= \begin{bmatrix}
c_1 \\
c_2 \\
c_3 \\
c_4 \\
c_5 \\
c_6
\end{bmatrix}
\]

Figure 1. Stochastic Multiplication, \( c_{1}=ab \)

Also, PTM is one of the probabilistic error modeling tools which performs simultaneous computation over all possible input combinations and calculates the exact probabilities of failures, it is based on matrix representation where column indices represent input values and row indices represent output values. For an example, PTM for a standard NOR gate is shown in (3) where \( p \) represents probability for incorrect output value[6].

\[
\text{PTM} = \begin{bmatrix}
p & 1-p & 1-p & 1-p & 1-p \\
1-p & p & p & p & p
\end{bmatrix} \quad (3)
\]

In this paper, we investigate this approach which directly models probability in digital circuits.

II. STOCHASTIC LOGIC CIRCUITS

Structured stochastic processes play a central role in the design of approximation algorithms for probabilistic inference and nonlinear optimization. Markov chain[7, 8] and sequential [9] Monte Carlo methods are classic examples. However, these widely used algorithms and approximate Bayesian inference in general - can seem unacceptably inefficient when simulated on current general-purpose computers.

A Boolean gate has input bit lines and output bit lines, and puts out a Boolean function of its inputs on each work cycle. Each gate is representable by a set of truth tables, one for each output bit; the abstraction and an AND gate example are shown in Figure 2a.

Figure 2b shows a combinational stochastic logic gate, which adds random bit lines. On each cycle, the gate puts a sample from P(OUT|IN) on its output lines, using the random bits[10]. Consider the JK flip-flop shown in Figure 3 with input sequences of \([a1, b1, c1, d1]\) and \([a2, b2, c2, d2]\) representing the probabilities of \(P_a, P_b, P_c, \) and \(P_d\) respectively. The output bit \(c_i\) is equal to ‘1’ with the probability of \(P_c\) and is equal to ‘0’ with the probability of \(1 - P_c\).

Figure 2. Combinational stochastic logic. (a) The combinational Boolean logic abstraction, and one example: the AND gate and its associated truth table. (b) The combinational stochastic logic abstraction[10].
A random output transition from '1' to '0' occurs with probability of \((1-P)\) and the reverse transition occurs with the probability of \(P\). Since the expected occurrence of random transition in both directions must be equal, we have

\[ \text{P} \times \text{P} = (1 - \text{P}) \times \text{P} \rightarrow \text{P} = \frac{\text{P}}{(\text{P} + \text{P})} \]  

(4)

\[ \begin{bmatrix} J & K \\ Q & c_i \\ \end{bmatrix} \]

\[ \begin{bmatrix} d_{ij} \\ b_j \\ \end{bmatrix} \]

\[ \text{P} := \text{P} \times (\text{P} + \text{P}) \]

Figure 3. Stochastic division[11]

TABLE I. EVALUATION OF JK-FPFLIP-FLOP

<table>
<thead>
<tr>
<th>J</th>
<th>K</th>
<th>Q</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Hold</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Reverse</td>
</tr>
</tbody>
</table>

Table I shows the evaluation of the mentioned circuit.

Any event, which is associated with some of the random experiments and is happen if the occurrence of any one of the elementary event is its outcome. Hence, in this gate with mentioned inputs probability of occurrence is 7/8.

\[ \begin{bmatrix} x & 01101111 \\ y & 00110110 \\ z & 01111111 \\ \end{bmatrix} \]

Figure 4. OR gate

\[ \begin{bmatrix} 1/8 & 2/8 & 3/8 & 2/8 \\ 1/8 & 7/8 & 1/8 & 0 \\ 0 & 1 & 0 & 1 \\ 1 & 0 & 1 & 0 \\ \end{bmatrix} \]

(6)

A relationship between input and output values for the operation of an integrated nano-based electronic circuit can be characterized by its truth table. Under certain circumstances, an incorrect output value can be generated by its input value. If we can identify how frequent this phenomenon is likely to occur, then we can demonstrate this occurrence using Probabilistic Transfer Matrix (PTM). PTM is represented in matrix form where column and row indicate input and output values respectively[15]. The number of different combinations of input and output vectors is limited by \(2^m\) and \(2^n\), respectively. Probabilistic Transfer Matrix (PTM) is defined as a matrix \(P\) where \(p_{ij}\) entry represents the probability of output vector value \(k\) given input vector value \(j\), i.e., \(p(k | j)\). Therefore, \(P\) has \(2^m\) rows and \(2^n\) columns and the complexity of a function PTM with \(m\) inputs and \(n\) outputs is of order \(O(2^{mn})\). Fig. 5 gives an example of PTM for the NOT gate and other logic functions with \(m = 2\) and \(n = 1\). From this figure, we see that \(p\) is obviously the probability of an error occurrence and so \(q = 1 - p\) is the correct value probability[16].

\[ T_{\text{NOT}} = \begin{bmatrix} 1 \\ 0 \end{bmatrix}, \quad P_{\text{NOT}} = \begin{bmatrix} q \\ p \end{bmatrix}, \quad T_{\text{AND}} = \begin{bmatrix} 1 \\ 1 \end{bmatrix}, \quad P_{\text{AND}} = \begin{bmatrix} q \\ p \end{bmatrix}, \quad T_{\text{XOR}} = \begin{bmatrix} 1 \\ 1 \end{bmatrix}, \quad P_{\text{XOR}} = \begin{bmatrix} q \\ p \end{bmatrix} \]

Figure 5. Truth table matrix (\(T\)) and probabilistic transfer matrix (\(P\)) for NOT, AND, and XOR logic gates.

TABLE II. PROBABILISTIC EQUATION

<table>
<thead>
<tr>
<th>Gate</th>
<th>Probabilistic equation</th>
</tr>
</thead>
<tbody>
<tr>
<td>NOT</td>
<td>1-x_i</td>
</tr>
<tr>
<td>AND</td>
<td>x_i x_j</td>
</tr>
<tr>
<td>NAND</td>
<td>1-x_i x_j</td>
</tr>
<tr>
<td>OR</td>
<td>(1-x_i)(1-x_j)</td>
</tr>
<tr>
<td>NOR</td>
<td>(1-x_i)(1-x_j)</td>
</tr>
<tr>
<td>XOR</td>
<td>x_i(1-x_j)+x_j(1-x_i)</td>
</tr>
</tbody>
</table>

Table II shows the probabilistic equation for several basic logic gates.

III. PROBABILISTIC TRANSFER MATRIX

Every logic circuit has a PTM representing its error-free function. This is a matrix of size \(2^m \times 2^n\) where \(m\) and \(n\) are the numbers of inputs and outputs of the circuit, respectively[2].

PTM of an OR gate implementing \(z = x \lor y\) is

\[ Z = \begin{bmatrix} x & 1 \\ 0 & 1 \\ \end{bmatrix} \]

\[ \begin{bmatrix} 1 & 0 \\ 0 & 1 \\ \end{bmatrix} \]

(5)

Multiplying an input PTM by a circuit PTM yields an output PTM, which for a single-output gate is a vector \([o_0, o_1]\) where \(o_0\) and \(o_1\) are the probabilities of 0 and 1, respectively, appearing at the output. For example, the SC operation performed by the OR circuit of Fig. 4 is described by the PTM calculation[2].

IV. PTM FOR OPERATIVE PART OF HALF-SUBTRACTOR

The purposes of PTM representation and label them \(i_{0n}, \ldots, i_{n_1}\), similarly, the \(m\) outputs are labeled \(o_{0n}, \ldots, o_{n_1}\). The circuit C can be represented by a \(2^m \times 2^n\) PTM M. The rows of M are indexed by an \(n\)-bit vector whose values range from 00...0 to 11...1. The row indices correspond to input vectors, i.e. 0/1 truth assignments of the circuit's input signals[17]. PTM can be utilized to any logic gates. In PTM computation, an assumption has been made that gate errors happen independently and gate’s PTM is already recognized. In this stage we implement the
PTM representation and the sample to see the evaluation tools. For example, architecture of half subtractor (HS) circuit is shown in Fig. 6.

The PTM for the complete half-subtractor design can be defined with matrix. We have two stage in recent example, S_0 and S_1 respectively.

Put be the addressing of columns in P_{S_0} from 0 to 15. As can be seen through this addressing, only the columns 2, 7, 8, 13 (in bold) are non-nulls and they correspond to the rows extracted from the P_{S_1} to form the total circuit probability transfer matrix P_{HS}.

Also, P_{G_1} and P_{G_2} are combined in parallel structure. We can achieve P_{S_1} = P_{XOR} ⊗ P_{AND} - PTM model that is applied to a parallel of XOR and AND gates must understand the differences at each stage. To determine the desired P_{S_0} we deal with first stage. Hence, recent matrix equation implies that:

\[
P_{S_0} = \begin{bmatrix} 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \end{bmatrix}
\]

The corresponding Matrix for operative part of half-subtractor is shown in the following:

\[
P_{S_1} = \begin{bmatrix} q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \\ q^2 & p^2 & q^2 & p^2 \\ q^2 & p^2 & q^2 & p^2 \\ p^2 & q & p & q & q^2 \\ p^2 & q & p & q & q^2 \\ p^2 & q & p & q & q^2 \\ p^2 & q & p & q & q^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \end{bmatrix}
\]

PTM for operative part of half-subtractor

In the following matrix, we can see that P_{HS} is a submatrix consisting of the useful rows in the matrix P_{S_1}.

\[
P_{HS} = \begin{bmatrix} q^2 & q & p & q & p^2 \\ p^2 & q & p & q & q^2 \\ p^2 & q & p & q & q^2 \\ q^2 & q & p & q & p^2 \\ q^2 & q & p & q & p^2 \end{bmatrix}
\]

PTM for the complete half-subtractor.

We can analyse the Probabilistic Transfer Matrix (PTM) methodology which is based on matrix representation of errors in logic circuits.

V. PTM FOR ONE BIT COMPARATOR (A ≤ B)

In digital system, comparison of two numbers is an arithmetic operation that defines if one number is greater than, equal to, or less than the other number. The comparator compares two numbers, A and B, and defines their relative magnitudes. The result of comparison is determined by three binary variables that indicate whether A>B, A=B, or A<B. The matrix representation of corresponding figure is shown.

The corresponding matrix for operative part of one bit comparator (A ≤ B) is shown in the following:

\[
P_{S_0} = \begin{bmatrix} 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \end{bmatrix}
\]

The corresponding matrix for operative part of one bit comparator (A ≤ B) is shown in the following:

\[
P_{S_1} = \begin{bmatrix} p & q & p^2 & q^2 \\ p & q & p^2 & q^2 \\ p & q & p^2 & q^2 \\ p & q & p^2 & q^2 \\ q & p & q & p^2 \\ q & p & q & p^2 \\ q & p & q & p^2 \\ q & p & q & p^2 \end{bmatrix}
\]
PTM for operative part of one bit comparator (A ≤ B)

A matrix operation can accomplish this easily.

\[ P_{CA}(A \leq B) = \begin{bmatrix} pq & p^2 & q^2 & pq \\ qp & q^2 & p^2 & pq \\ q^2 & pq & p^2 & pq \\ p^2 & pq & q^2 & pq \end{bmatrix} \]

PTM for the complete one bit comparator (A ≤ B)

VI. PTM FOR ONE BIT COMPARATOR (A ≥ B)

According to logic function achieved from truth table, logic diagram for one bit comparator (A ≥ B) is shown in Fig.8.

![Figure 8. One bit comparator (A ≥ B)](image)

The corresponding matrix for operative part of one bit comparator (A ≥ B) is shown in the following:

\[ P_{CA}(A \geq B) = \begin{bmatrix} pq & p^2 & q^2 & pq \\ pq & p^2 & q^2 & pq \\ p^2 & pq & q^2 & pq \\ q^2 & pq & p^2 & pq \end{bmatrix} \]

PTM for the complete one bit comparator (A ≥ B)

Considering that by putting q = 1 and p = 0 in the matrix, the output which is obtained based on the truth table that is true. For example, if the q and p parts of half-subtractor were equal to 1 and 0 respectively, then the following matrix can appear. The accuracy of the results is confirmed by the truth table.

\[ P_{HI} = \begin{bmatrix} 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1 \\ 0 & 0 & 1 & 0 \\ 1 & 0 & 0 & 0 \end{bmatrix} \]

PTM for the complete half-subtractor (q=1, p=0)

CONCLUSION

In stochastic computation, probabilities are represented as streams of random digital bits. The main objective of this work is to establish a comparison between three architectures in probabilistic transfer matrix (PTM). The PTM for NOT, AND, and XOR logic gates was depicted. Also, we illustrated the PTM concepts using a half-subtractor and one bit comparator with (A ≥ B, A ≤ B) characteristic using matrices. This paper focuses on the effect of PTM computation on digital circuits. The other circuits with over than two states can be constructed easily.

REFERENCES


