Mathematical and Computational
Applications

## Article

# Logic Operators on Delta-Sigma Bit-Streams 

Axel Klein ${ }^{+(1)}$<br>Institut für Regelungstechnik, Technische Universität Braunschweig, 38106 Braunschweig, Germany; klein@ifr.ing.tu-bs.de; Tel.: +49-531-391-3834<br>† Current address: Hans-Sommer-Str. 66, 38106 Braunschweig, Germany

Received: 12 December 2017; Accepted: 15 January 2018; Published: 17 January 2018


#### Abstract

The fundamental logic operations NOT, OR, AND, and XOR processing bit-streams of $\Delta \Sigma$-modulators are discussed herein. The resulting bit-streams are evaluated on the basis of their mean values and their standard deviations. Mathematical expressions are presented for their mean values; i.e., the logic function XOR results in the negative multiplication of two bipolar bit-streams, and the logic function AND results in the multiplication of two unipolar bit-streams. As the results are valid for bit-streams with independent high-frequency components, the normed cross-product is utilized for evaluation of the independence of the high-frequency components. In order to achieve a high independence between the input bit-streams, representing the same value, the quantization noise is affected. Multiple strategies are examined and $\Delta \Sigma$-modulators with different designs are chosen as the best-suited solution. The operations are evaluated on a testbench.


Keywords: delta-sigma; signal processing; logic; nonlinear operations

## 1. Introduction

Operations in the delta sigma domain are a broad field of research. Previous publications have utilized complex networks and operations to achieve the desired mathematical operations. The first approaches were made in the 80's based on logic chips [1,2]. Further mathematical operations were introduced by the publications [3,4]. The described operations are linear or use long filters with more than 100 elements. As the bit-streams are usually binary signals, an investigation of the fundamental logic operations brings up mathematical operations without the need for filtering. The mathematical functions describing the averaged output of the fundamental logic operations NOT, OR, AND, and XOR will be presented in this publication. As these logic operations are dependent of the actual values of the input bit-streams, the high-frequency signal components are investigated. As the considerations are made for bit-streams with independent high-frequency components, the normed cross-product is utilized for evaluation of the independence of the high-frequency components. In order to achieve a high independence between the input bit-streams, if they represent the same value, the local distribution can be influenced by noise shaping. Several strategies are examined to increase the independence of the input bit-streams. The best rated strategy is examined on a testbench.

## 2. Delta-Sigma Modulators

Signal processing based on bit-streams requires an understanding of the operation of $\Delta \Sigma$-modulators. In a classical AD-conversion setup an $\Delta \Sigma$-analog-to-digital converter is comprised of two elements; i.e., the $\Delta \Sigma$-modulator and a low-pass filter with decimation, as shown in Figure 1. By omitting the low-pass filter and directly operating on the high-frequency ( $\geq 10 \mathrm{Mbit} / \mathrm{s}$ ) bit-stream [5-9], a larger small signal bandwidth is achieved, e.g., in control loops.

The $\Delta \Sigma$-modulator is composed of one or several integrators and a clocked comparator with feedback loops and gains. The order of the $\Delta \Sigma$-modulator is specified by the number of implemented integrators; for example, in Figure 1 a first-order $\Delta \Sigma$-modulator is shown. While
first-order $\Delta \Sigma$-modulators are always stable, for higher-order $\Delta \Sigma$-modulators the feedback coefficients to individual stages have to be designed carefully to stabilize the feedback loops [10]. Several design methods are known from the literature [11,12]. For the presented evaluation, second-order $\Delta \Sigma$-modulators are used.


Figure 1. First-order $\Delta \Sigma$-modulator with low-pass filter.

Considered as a closed control loop, the $\Delta \Sigma$-modulator integrates the control error between the input signal and the output signal. If this integral is greater than zero, it outputs a one, else a zero for the next clock cycle. In conjunction with the feedback loop, this simple control law ensures that the output bit-stream only consists of ones and zeros representing the input signal in average. As the bit-stream can only transport 1 bit information per clock cycle, quantization noise is introduced to the output bit-stream. Due to the internal structure, the $\Delta \Sigma$-modulator provides noise shaping. As shown in Figure 2, the quantization noise is mainly shifted to the high-frequency signal components. In a classical digital signal processing (DSP) implementation, these are suppressed by a digital low-pass filter. In $\Delta \Sigma$-signal processing (DSSP), this noise remains in the bit-streams and thereby influences the local distribution of ones and zeros.


Figure 2. Power of the noise transfer function (NTF) of a first-order $\Delta \Sigma$-modulator [10].

The $\Delta \Sigma$-modulators can be implemented in two ways. In a hardware $\Delta \Sigma$-modulator, the integrator is an analog circuit and the feedback is a one-bit digital-analog-converter, whereas in a software $\Delta \Sigma$-modulator the whole modulator is implemented digitally.

In general, there are two ways to map the logical values true and false, respectively 1 and 0 , to normalized signal values: signed and unsigned. In the signed case, the logical 1 is mapped to 1 and the logical 0 is mapped to -1 , whereas in the unsigned case the logical 0 is mapped to 0 .

## 3. Logic Operations

There are four fundamental logic operations, NOT, AND, OR, and XOR, which can be applied on one or two bit-streams [13]. The logic operation NOT has one input ( $x$ ), and the others require two inputs $\left(x_{1}, x_{2}\right)$. All fundamental logic operations have one output ( $y$ ). The truth tables are shown in Table 1-4.

Table 1. Truth table for NOT.

| $x$ | $y$ |
| :--- | :--- |
| 0 | 1 |
| 1 | 0 |

Table 2. AND.

| $x_{1}$ | $x_{2}$ | $y$ |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

Table 3. Truth table for OR.

| $x_{1}$ | $x_{2}$ | $y$ |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

Table 4. Truth table for XOR.

| $x_{1}$ | $x_{2}$ | $y$ |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

## 4. Statistical Analysis

Statistical analysis is applied in order to evaluate which mathematical functions are executed on the average value of bit-streams if fundamental logic operations are applied. The greatest difficulty for operations on $\Delta \Sigma$-bit-streams is that no meaningful instantaneous value can be attributed to $\Delta \Sigma$-bit-streams. As a substitute for the missing instantaneous value, many operations are designed on the average value over $N$ samples, as this represents the actual value. The probability of ones in these samples is $p_{1 \mid 2}$, where the index $1 \mid 2$ stands for either 1 or 2 . For logical analysis, the expected number of ones $\left(o_{1 \mid 2}=p_{1 \mid 2} \cdot N\right)$ is an integer value, resulting in an integer value of zeros $\left(z_{1 \mid 2}=\left(1-p_{1 \mid 2}\right) \cdot N\right)$. With rising sample size, the discretization step size of the probabilities decreases towards zero.

A statistical distribution of the positions of ones in the input bit-streams is assumed for the operations with two input bit-streams. This leads to the urn problem of type "drawing without replacement" for calculating the probability of ones in the output bit-stream [14].

### 4.1. NOT

The NOT operator inverts the bit-stream, leading to the probability $p_{y}=1-p_{1}$. This is equivalent to a multiplication with -1 for bipolar inputs, as stated in [15]. Due to the fact that this connection is already known from the literature, the logical function NOT is not investigated any further.

### 4.2. OR

For the operation OR, each one in the first input bit-stream $\left(x_{1}\right)$ and each one in the second input bit-stream $\left(x_{2}\right)$ at the position of a zero in $x_{1}$ will lead to a one in the output bit-stream (y). Thus, the probability of ones in the output bit-stream is at least the probability of ones in the first input bit-stream. This can be written as

$$
\begin{equation*}
p_{O R_{1}}=\frac{o_{1}}{N}=p_{1} . \tag{1}
\end{equation*}
$$

The distribution of ones in the output bit-stream is derived by the additional ones in the bit-stream, caused by $x_{2}$, which have to be described. As the output bit-stream already consists of the ones of the first bit-stream, only the zeros of the first bit-stream can be conditionally converted to ones.

The number of combinatorial possibilities for a zero in the first bit-stream is given by

$$
\begin{equation*}
p_{O R_{2}}=\frac{\left(N-z_{1}\right)!}{N!}=\frac{\left(p_{1} \cdot N\right)!}{N!} \tag{2}
\end{equation*}
$$

The possibilities to obtain $t$ ones from the second input bit-stream in the place of zeros from the first input bit-stream are

$$
\begin{equation*}
p_{O R_{3}}(t)=\frac{z_{1}!}{t!\cdot\left(z_{1}-t\right)!}=\frac{\left(\left(1-p_{1}\right) \cdot N\right)!}{t!\cdot\left(\left(1-p_{1}\right) \cdot N-t\right)!} \tag{3}
\end{equation*}
$$

This limits the possible amount of additional ones. The output bit-stream cannot have more ones than there are places in the output bit-stream and no more ones than the sum of ones in both input bit-streams. This leads to a maximum amount of additional ones in the output bit-stream, which can be expressed as

$$
\begin{equation*}
t_{O R, \max }=\min \left(z_{1}, o_{2}\right)=\min \left(1-p_{1}, p_{2}\right) \cdot N \tag{4}
\end{equation*}
$$

The probability of more ones in the output bit-stream is zero, as this event is not possible.
The probability for $t$ ones from the second input bit-stream being combined with zeros of the first input bit-stream is given by

$$
\begin{equation*}
p_{O R_{4}}(t)=\frac{o_{2}!}{\left(o_{2}-t\right)!}=\frac{\left(p_{2} \cdot N\right)!}{\left(p_{2} \cdot N-t\right)!} \tag{5}
\end{equation*}
$$

The remaining copied zeros of the first input bit-stream $\left(\left(1-p_{1}\right) \cdot N-t\right)$ also have to correspond to zeros in the second input bit-stream. The probability for this event can be expressed by

$$
\begin{equation*}
p_{O R_{5}}(t)=\frac{z_{2}!}{\left(z_{2}-z_{1}+t\right)!}=\frac{\left(\left(1-p_{2}\right) \cdot N\right)!}{\left(\left(p_{1}-p_{2}\right) \cdot N+t\right)!} \tag{6}
\end{equation*}
$$

If the second input bit-stream has more ones than the first input bit-stream, the output bit-stream has at least the amount of ones in the second input bit-stream. This forms the lower boundary for the amount of additional ones in the output bit-stream. This can be expressed as

$$
\begin{equation*}
t_{O R, \min }=\max \left(0, o_{2}-o_{1}\right)=\max \left(0, p_{2}-p_{1}\right) \cdot N \tag{7}
\end{equation*}
$$

The limitations (4) and (7) ensure that the factorial is only calculated from values $\in \mathbb{N}_{0}$. The product of (2), (3), (5), and (6) in the limits (4) and (7) describes the probability of $t$ additional ones
from the second input bit-stream in the output bit-stream if the input bit-streams are processed by the logic operation OR. This can be written as

$$
\begin{equation*}
p_{O R}(t)=\frac{\left(p_{1} \cdot N\right)!}{N!} \cdot \frac{\left(\left(1-p_{1}\right) \cdot N\right)!}{t!\cdot\left(\left(1-p_{1}\right) \cdot N-t\right)!} \cdot \frac{\left(p_{2} \cdot N\right)!}{\left(p_{2} \cdot N-t\right)!} \cdot \frac{\left(\left(1-p_{2}\right) \cdot N\right)!}{\left(\left(p_{1}-p_{2}\right) \cdot N+t\right)!} \tag{8}
\end{equation*}
$$

As a result, the probability of a one in the output bit-stream ( $p_{y, O R}$ ) is given by combining (1) and (8)

$$
\begin{equation*}
p_{y, O R}=\sum_{t=\max \left(0, o_{2}-o_{1}\right)}^{\min \left(z_{1}, o_{2}\right)}\left(\frac{t+o_{1}}{N}\right) \cdot p_{O R}(t)=\sum_{t=\max \left(0, p_{2}-p_{1}\right) \cdot N}^{\min \left(1-p_{1}, p_{2}\right) \cdot N} \frac{t}{N} \cdot p_{O R}(t)+p_{1} . \tag{9}
\end{equation*}
$$

With (9) the probability of a one in the output bit-stream can be calculated for combinations of $p_{1 \mid 2} \in\{0,1\}$. Figure 3 illustrates the results for the logic operation OR.


Figure 3. Expected probability of a one in the output bit-stream for the input bit-streams $x_{1}$ and $x_{2}$, with the probability of ones $p_{1 \mid 2}$, operated by OR.

### 4.3. AND

For the operation AND, each one in $x_{1}$ at the position of a one in $x_{2}$ leads to a one in $y$. Thus, the minimal number of ones in the output bit-stream results if the ones in $x_{1}$ are combined with zeros in $x_{2}$ and vice versa. The resulting ones-which cannot be combined with zeros-gives the minimal count of ones in the output bit-stream. These can be described by the ones, which are more than the length of the bit-stream

$$
\begin{equation*}
t_{A N D, \min }=\max \left(0, o_{1}+o_{2}-N\right)=\max \left(0, p_{1}+p_{2}-1\right) \cdot N \tag{10}
\end{equation*}
$$

The maximal number of ones in the output bit-stream is the minimum of ones in one of the input bit-streams, as a one can only result if two ones are combined. This can be expressed as

$$
\begin{equation*}
t_{A N D, \max }=\min \left(o_{1}, o_{2}\right)=\min \left(p_{1}, p_{2}\right) \cdot N \tag{11}
\end{equation*}
$$

For the description of the event, that two ones from both input bit-streams are in the same position, and the ones in the first bit-stream are taken into account. The number of combinatorial possibilities for a one in the first bit-stream is given by

$$
\begin{equation*}
p_{A N D_{1}}=\frac{\left(N-o_{1}\right)!}{N!}=\frac{\left(\left(1-p_{1}\right) \cdot N\right)!}{N!} . \tag{12}
\end{equation*}
$$

The possibilities of arranging $t$ ones from the second input bit-stream in the places of ones in the first input bit-stream are given by

$$
\begin{equation*}
p_{A N D_{2}}(t)=\frac{o_{1}!}{t!\cdot\left(o_{1}-t\right)!}=\frac{\left(p_{1} \cdot N\right)!}{t!\cdot\left(p_{1} \cdot N-t\right)!} \tag{13}
\end{equation*}
$$

The probability for $t$ ones from the second input bit-stream to be in the same place as ones of the first input bit-stream can be described as

$$
\begin{equation*}
p_{A N D_{3}}(t)=\frac{o_{2}!}{\left(o_{2}-t\right)!}=\frac{\left(p_{2} \cdot N\right)!}{\left(p_{2} \cdot N-t\right)!} \tag{14}
\end{equation*}
$$

In the position of the other ones in the first input bit-stream should be zeros in the second input bit-stream. The probability for this is expressed by

$$
\begin{equation*}
p_{A N D_{4}}(t)=\frac{z_{2}!}{\left(z_{2}-o_{1}+t\right)!}=\frac{\left(\left(1-p_{2}\right) \cdot N\right)!}{\left(\left(1-p_{1}-p_{2}\right) \cdot N+t\right)!} \tag{15}
\end{equation*}
$$

The product of (12)-(15) with the limits (10) and (11) describes the probability of $t$ ones in the output bit-stream, if the input bit-streams are processed by the logic operation AND

$$
\begin{equation*}
p_{A N D}(t)=\frac{\left(\left(1-p_{1}\right) \cdot N\right)!}{N!} \cdot \frac{\left(p_{1} \cdot N\right)!}{t!\cdot\left(\left(1-p_{1}\right) \cdot N-t\right)!} \cdot \frac{\left(p_{2} \cdot N\right)!}{\left(p_{2} \cdot N-t\right)!} \cdot \frac{\left(\left(1-p_{2}\right) \cdot N\right)!}{\left(\left(1-p_{1}-p_{2}\right) \cdot N+t\right)!} . \tag{16}
\end{equation*}
$$

The probability of a one in the output bit-stream ( $p_{y, A N D}$ ) follows from (16)

$$
\begin{equation*}
p_{y, A N D}=\sum_{t=\max \left(0, o_{1}+o_{2}-N\right)}^{\min \left(o_{1}, o_{2}\right)} \frac{t}{N} \cdot p_{A N D}(t)=\sum_{t=\max \left(0, p_{1}+p_{2}-1\right) \cdot N}^{\min \left(p_{1}, p_{2}\right) \cdot N} \frac{t}{N} \cdot p_{A N D}(t) \tag{17}
\end{equation*}
$$

With (17) the probability of a one in the output bit-stream can be calculated for combinations of $p_{1 \mid 2} \in\{0,1\}$. Figure 4 illustrates the results for the logic operation AND.


Figure 4. Expected probability of a one in the output bit-stream for the input bit-streams $x_{1}$ and $x_{2}$, with the probability of ones $p_{1 \mid 2}$, operated by AND.

### 4.4. XOR

For the operation XOR, a one in the output results if the inputs have opposite logical values in that position. As the logic operation XOR counts the differences in the bit-streams, only the probability
of a one in the second input bit-stream combined with a zero in the first input bit-stream has to be described in order to calculate the amount of ones in the output bit-stream.

Thus, the minimal occurrence of this event is the difference between the ones in the second input bit-stream to the first input bit-stream, which is given by

$$
\begin{equation*}
t_{X O R, \min }=\max \left(0, o_{2}-o_{1}\right)=\max \left(0, p_{2}-p_{1}\right) \cdot N \tag{18}
\end{equation*}
$$

The maximum number of ones of the second input bit-stream combined with zeros of the first input bit-stream is limited by the amount of ones in the second input bit-stream and by the amount of zeros in the first input bit-stream, resulting in

$$
\begin{equation*}
t_{X O R, \max }=\min \left(z_{1}, o_{2}\right)=\min \left(1-p_{1}, p_{2}\right) \cdot N \tag{19}
\end{equation*}
$$

The operation XOR requires special precautions, as it is not possible to change the parity of ones $\left(\operatorname{parity}\left(\left(p_{1}+p_{2}\right) \cdot N\right)=\operatorname{parity}\left(p_{y} \cdot N\right)\right)$, with parity $(x)$ defined in Definition 1. As the statistical model does not regard this matter and returns for those events the same probability as for the events with the right parity, the probabilities of the events with different parities have to be set to zero. This can be achieved by multiplication with

$$
\begin{equation*}
\left(1-\left|\operatorname{parity}(t)-\operatorname{parity}\left(\left(p_{1}+p_{2}\right) \cdot N\right)\right|\right) \tag{20}
\end{equation*}
$$

Definition 1. Let parity $(x)$ be a function of $\mathbb{N}_{0} \rightarrow \mathbb{N}_{0}$ : parity $(x)=x \bmod 2$.
First, the number of possibilities to place the zeros in the first input bit-stream is described, which can be expressed by

$$
\begin{equation*}
p_{\mathrm{XOR}_{1}}=\frac{\left(N-z_{1}\right)!}{N!}=\frac{\left(p_{1} \cdot N\right)!}{N!} \tag{21}
\end{equation*}
$$

The possibilities of arranging $t$ ones from the second input bit-stream in the places of zeros from the first input bit-stream can be described as

$$
\begin{equation*}
p_{\mathrm{XOR}_{2}}(t)=\frac{z_{1}!}{t!\cdot\left(z_{1}-t\right)!}=\frac{\left(\left(1-p_{1}\right) \cdot N\right)!}{t!\cdot\left(\left(1-p_{1}\right) \cdot N-t\right)!} . \tag{22}
\end{equation*}
$$

The probability of $t$ ones from the second input bit-stream falling on the places of zeros in the first input bit-stream is given by

$$
\begin{equation*}
p_{\mathrm{XOR}_{3}}(t)=\frac{o_{2}!}{\left(o_{2}-t\right)!}=\frac{\left(p_{2} \cdot N\right)!}{\left(p_{2} \cdot N-t\right)!} . \tag{23}
\end{equation*}
$$

The other zeros of the first input bit-stream $\left(\left(1-p_{1}\right) \cdot N-t\right)$ should also be zeros in the second input bit-stream. The probability for this event can be expressed by

$$
\begin{equation*}
p_{\mathrm{XOR}_{4}}(t)=\frac{z_{2}!}{\left(z_{2}-z_{1}+t\right)!}=\frac{\left(\left(1-p_{2}\right) \cdot N\right)!}{\left(\left(p_{1}-p_{2}\right) \cdot N+t\right)!} \tag{24}
\end{equation*}
$$

The product of (21)-(24) and the parity check (20) with the limits (18) and (19) leads to the probability for $t$ events of this kind, which can be expressed as

$$
\begin{array}{r}
p_{\mathrm{XOR}}(t)=\frac{\left(p_{1} \cdot N\right)!}{N!} \cdot \frac{\left(\left(1-p_{1}\right) \cdot N\right)!}{t!\cdot\left(\left(1-p_{1}\right) \cdot N-t\right)!} \cdot \frac{\left(p_{2} \cdot N\right)!}{\left(p_{2} \cdot N-t\right)!} \cdot \frac{\left(\left(1-p_{2}\right) \cdot N\right)!}{\left(\left(p_{1}-p_{2}\right) \cdot N+t\right)!}  \tag{25}\\
\cdot\left(1-\left|\operatorname{parity}(t)-\operatorname{parity}\left(\left(p_{1}+p_{2}\right) \cdot N\right)\right|\right)
\end{array}
$$

The probability of a one in the output bit-stream $\left(p_{y, X O R}\right)$ can be calculated. As the count of ones in the second input bit-stream combined with zeros from the first input bit-stream is known
as $t$, the output bit-stream must contain $t$ ones. The remaining zeros from the first input bit-stream are combined with zeros from the second bit-stream. These do not add ones to the output bit-stream. More ones in the output bit-stream can be added by the ones in the first input bit-stream if they match zeros in the second input bit-stream. This event will occur for all ones in the first input bit-stream $\left(o_{1}\right)$ minus the resulting ones in the second input bit-stream $\left(o_{2}-t\right)$, as $t$ ones from the second input bit-stream are already combined with zeros from the first input bit-stream. This can be described as

$$
\begin{equation*}
n_{\text {ones }, y}=t+o_{1}-o_{2}+t=2 \cdot t+\left(p_{1}-p_{2}\right) \cdot N \tag{26}
\end{equation*}
$$

The probability of ones in the output bit-stream can be derived from (25) and (26)

$$
\begin{equation*}
p_{y, X O R}=\sum_{t=\max \left(0, o_{2}-o_{1}\right)}^{\min \left(z_{1}, o_{2}\right)}\left(\frac{2 \cdot t+o_{1}-o_{2}}{N}\right) \cdot p_{X O R}(t)=\sum_{t=\max \left(0, p_{2}-p_{1}\right) \cdot N}^{\min \left(1-p_{1}, p_{2}\right) \cdot N} \frac{2 \cdot t}{N} \cdot p_{X O R}(t)+p_{1}-p_{2} . \tag{27}
\end{equation*}
$$

With (27), the probability of a one in the output bit-stream can be calculated for combinations of $p_{1 \mid 2} \in\{0,1\}$. Figure 5 illustrates the results for the logic operation XOR.


Figure 5. Expected probability of a one in the output bit-stream for the input bit-streams $x_{1}$ and $x_{2}$, with the probability of ones $p_{1 \mid 2}$, operated by XOR.

With the Equations (9), (17), and (27), a distribution of ones in the output of a logical operation for independent bit-streams can be derived. In the next section, mathematical functions for the expected probability of ones in the output bit-stream depending on the probability of ones in the input bit-streams are presented.

## 5. Mathematical Operations

In order to utilize the fundamental logic operations as mathematical operations for $\Delta \Sigma$-signal processing (DSSP), a mathematical function creating the same mapping of input values to output values must be fitted.

The statistical description developed in Section 4 leads to an expectation of ones in the output bit-streams of the logical operations OR, AND, and XOR for the input bit-streams with the probability $p_{1 \mid 2} \in\{0, \ldots, 1\}$. As stated in Section 4, the value represented in a bit-stream can be interpreted by averaging. The expected percentage of ones in $N$ sampled bits from a bit-stream contains the same information as the averaged value, as it represents the average probability. Thus, the expected percentage of ones in the bit-stream is directly linked to the represented value.

With the numerical interpretation of the input and output bit-streams, as presented in Section 2, mathematical functions can be fitted to the transformation of the logic operations.

## 5.1. $O R$

In Figure 3, the percentage of ones in the output bit-stream of the logical operation OR is shown for different probabilities of ones in the input signals $x_{1}$ and $x_{2}$. If $x_{1}$ or $x_{2}$ contain only zeros, the output value has a linear dependency on the probability of ones in the other input. This leads to the term $x_{1}+x_{2}$. To match the flat boarder at only ones for $x_{1}$ or $x_{2}$, the value represented by the output must be reduced by the value represented by the other input. One way to achieve this is to subtract $x_{1} \cdot x_{2}$, as the other input is only ones and is therefore mapped to one. Summed up, the unipolar mathematical function $x_{1}+x_{2}-x_{1} \cdot x_{2}$ concludes. This function forms the same image, e.g., Figure 6.


Figure 6. Results of the function $x_{1}+x_{2}-x_{1} \cdot x_{2}$.

### 5.2. AND

In Figure 4, the percentage of ones in the output bit-stream of the logical operation AND is shown for different probabilities of ones in the input signals $x_{1}$ and $x_{2}$. For any input consisting of only zeros, the output is only zeros. For an input consisting of only ones, the output has a linear dependency on the probability of ones of the other input. This leads to the unipolar mathematical function $x_{1} \cdot x_{2}$. The expected probability of ones compared to Figure 7 reveals that they form the same image.


Figure 7. Results of the function $x_{1} \cdot x_{2}$.

### 5.3. XOR

In Figure 5 the percentage of ones in the output bit-stream of the logical operation XOR is shown for different probabilities of ones in the input signals $x_{1}$ and $x_{2}$. In this case, a flat cross at $p_{y}=0.5$ is
revealed for $p_{1}$ or $p_{2}$ equal 0.5 . This behaviour matches the interpretation that $p=0.5$ equals zero and the bipolar function is $x_{1} \cdot x_{2}$. Furthermore, there is always a linear dependency on the probability of ones in one input if the other input is constant zeros or ones. The maxima occur when the bit-streams are different, and the minima occur if they are equal. This is expected for a multiplication, but the maxima and the minima are interchanged, thus leading to the bipolar function $-x_{1} \cdot x_{2}$. The figure of the bipolar function is similar to the image of the percentage of ones in the output bit-stream of the logical operation XOR (e.g., Figure 8).


Figure 8. Results of the function $-x_{1} \cdot x_{2}$.

Concerning the average values, the resulting functions can be written as

$$
\begin{gather*}
f_{\text {or }}\left(x_{1}, x_{2}\right)=x_{1}+x_{2}-x_{1} \cdot x_{2}: \forall x_{1}, x_{2} \in[0 \ldots 1]  \tag{28}\\
f_{\text {and }}\left(x_{1}, x_{2}\right)=x_{1} \cdot x_{2}: \forall x_{1}, x_{2} \in[0 \ldots 1]  \tag{29}\\
f_{x o r}\left(x_{1}, x_{2}\right)=-x_{1} \cdot x_{2}: \forall x_{1}, x_{2} \in[-1 \ldots 1] \tag{30}
\end{gather*}
$$

## 6. Prediction of the Standard Deviation

The intention is to utilize these functions in DSSP. Therefore, not only the average value has to be considered, but the standard deviation is also of interest, as it can be used as a measure for the image quality of the function. Thus, the standard deviation is discussed in this section.

The standard deviation must always be considered in the statistics for the mean value; in this case, it may also be used as a measure for the image quality of the derived mathematical function. According to the laws of logic, the standard deviation is calculated by [16]:

$$
\begin{equation*}
\sigma=\sqrt{\sum_{k=0}^{n}\left(p(k) \cdot k-p_{y}\right)^{2}} \tag{31}
\end{equation*}
$$

Based on (31), the distribution of the results from the logical operations can be calculated. For the logic operations OR and AND, the standard deviations are the same. This is shown in Figure 9.


Figure 9. Standard deviation for the event of a one in the output bit-stream for the input bit-streams $x_{1}$ and $x_{2}$, with the probability of ones $p_{1 \mid 2}$, operated by OR or by AND.

For the logic operation XOR, the standard deviation is doubled in comparison to the operations OR and AND. The standard deviation of the operation XOR is shown in Figure 10.


Figure 10. Standard deviation for the event of a one in the output bit-stream for the input bit-streams $x_{1}$ and $x_{2}$, with the probability of ones $p_{1 \mid 2}$, operated by XOR.

As can be seen, the shape of the standard deviation is the same for all three logic operations. There are no combinatorial possibilities at the edges of the displayed plane, because at least one bit-stream ( $x_{1}, x_{2}$ ) consists only of zeros or ones. Therefore, it can be reasoned that the result depends only on the probability of the other bit-streams. In the middle of the area (where both bit-streams consist of half ones and half zeros), there are-as expected-the most combinatorial possibilities. If, in extreme cases, the ones of one bit-stream coincide with the ones of the other bit-stream, the logical operations OR and AND result in output bit-streams corresponding to the input bit-streams. For the logical operation XOR, a bit-stream containing only zeros is the output bit-stream. In the other extreme case, if the ones of one bit-stream fall on the zeros of the other bit-stream, an output bit-stream of zeros results for the logical operation AND. For the logical operations OR and XOR, an output bit-stream consisting of ones results. For all other combinations of probabilities, at least one combination cannot be changed. Therefore, the largest standard deviations can be expected at this point. Due to the fact
that the output bit stream changes from zero to one with XOR and only from 0.5 to zero or one with OR and AND, the scaling is expected to be a factor of two of the standard deviations from OR and AND to XOR. This leads to the expectation that the image quality is very good at the definition limits of the input values in the number space and gets worse at the center.

In review, the influence of the logic operations OR, AND, and XOR on the mean value of two input bit-streams with independent high-frequency components to the output bit-stream and the standard deviation of these operations are discussed.

## 7. Quantization Noise

In this section, the independence of the quantization noise-which results in the high-frequency signal components-of two bit-streams will be discussed.

The mean value and the standard deviation have been discussed for statistical distributed bit-streams. This assumption is based on the linear model of the $\Delta \Sigma$-modulator (i.e., Figure 11) [17].


Figure 11. Linear model of the quantizer utilized in a $\Delta \Sigma$-modulator comprised of a gain $\left(k_{q}\right)$ and a white noise source $(e(n))$ [17].

As shown in previous publications [6,10,17-19], this assumption is quite common. In the case of non-linear DSSP, the assumption of a white noise source is bold, as the single bits at each clock cycle have an impact on the output bit-stream, whereas the white noise source assumption is more appropriate for a larger time scale. Therefore, the noise sources of the utilized $\Delta \Sigma$-modulators must be independent, or the discussed probabilities are invalid.

The high-frequency quantization noise is able to interchange the positions of ones and zeros locally in the bit-stream, but will not affect the overall ratio. Thus, the independence of the noise between two bit-streams representing the same signal can be approximated by the normed cross-product without shift (32) using the signed mapping of the bit-streams.

$$
\begin{equation*}
R_{x_{1}, x_{2}}=\frac{1}{n} \sum_{i=0}^{n} x_{1_{\{-1 ; 1\}}}(i) \cdot x_{2_{\{-1 ; 1\}}}(i) . \tag{32}
\end{equation*}
$$

The evaluation of the presented approaches for modifying the high-frequency signal components are examined with a sinusoidal excitation in simulation, as shown in Figure 12.


Figure 12. Testbench for evaluating the independence of the noise from $\Delta \Sigma$-modulators.
The intention is to measure the independence of the two signals; therefore, lower values of $R_{x_{1}, x_{2}}$ are preferable. Especially for two software $\Delta \Sigma$-modulators, which are created from logic cells in a field-programmable gate array (FPGA), driven by the same clock with the same parameter set and zero input value $R_{x_{1}, x_{2}}=1$. This behaviour is expected, as the main noise source is the quantization. Since the modulator is a non-linear operator, this behaviour can change with different input signals. However, it is not guaranteed that the input signals are different for all load points of the plant, or if
both signals are mapped to independent input ranges, the usable data range is significantly reduced and the result must be processed further. Another opportunity is to use different designs for the $\Delta \Sigma$-modulators [7] (e.g., [10,12]). With this combination, $R_{x_{1}, x_{2}}=0.278$. The last evaluated possibility to overcome this issue is utilizing different clock rates of the $\Delta \Sigma$-modulators ( $f_{s 1} \neq f_{s 2}$ ), which leads to different bit-streams. For a second-order $\Delta \Sigma$-modulator with minimal parameters [12] and $f_{s 1}=2 \cdot f_{s 2}$ follows $R_{x_{1}, x_{2}}=0.298$. This option has the drawback that the overall system clock has to be faster than necessary for the requested bandwidth.

For different modulator design combinations, it can be possible to reach a higher independence of the high-frequency noise signal components. Therefore, the proposed solution is to utilize differently designed $\Delta \Sigma$-modulators, since the investigated implementations have the lowest $R_{x_{1}, x_{2}}$ of all the proposed solutions.

## 8. Validation of the Results

The testbench in Figure 13 modulates the input signals with two different designed $\Delta \Sigma$-modulators. The resulting bit-streams are fed into a dual input logic operation (AND, OR, or XOR) and filtered with an $\operatorname{sinc}^{3}$ filter [10]. The resulting multibit value is compared against the sinc ${ }^{3}$ filtered multibit value of the corresponding multibit mathematical operation. For the unipolar functions AND and OR, unipolar signal sources and $\Delta \Sigma$-modulators are used, and the bipolar function XOR is driven by bipolar input signals with bipolar $\Delta \Sigma$-modulators.


Figure 13. Testbench for evaluating the logic functions.

The input sources are chosen as shown in Figure 13. The phase shift for the sinus source (Input ${ }_{1}$ ) and the delay followed by an overshoot by the ramp input ( Input $_{2}$ ) is due to the sinc ${ }^{3}$ filter.

The functional relation for OR and AND are proven in simulation (e.g., Figure 14). Nevertheless, the greatest deviations occur not in the region around 0.5 ms , where they are estimated from the considerations in Section 6. The resulting value for the logic operation OR deviates the most around 0.8 ms and the logic function AND in the mirrored region around 0.2 ms . This fact shows the necessity of evaluating the deviation for different $\Delta \Sigma$-modulator implementations on a testbench with the expected input signals.

The result in Figure 15 for the logic function XOR shows the expected behaviour. For input signals at the definition boarder (e.g., the beginning and the ending of the simulation), the represented value in the output bit-stream follows the expected signal. The deviations are most severe when both input signals represent a value in the middle of the definition range, which occurs in the range around 0.5 ms .

The simulation results show that the statistical considerations are valid. The resulting deviations are lower than expected from the calculated mean deviations. In order to use the logic operations as mathematical functions, the implementation of the $\Delta \Sigma$-modulators must be verified using the expected input signals.


Figure 14. Results from the testbench for the logic operations OR and AND and corresponding operations $f_{o r}=x_{1}+x_{2}-x_{1} \cdot x_{2}$ and $f_{\text {and }}=x_{1} \cdot x_{2}$.


Figure 15. Results from the testbench for the logic operation XOR and the float operation $f_{x o r}=-x_{1} \cdot x_{2}$.

## 9. Conclusions

In this publication, the results of the fundamental logic operations NOT, AND, OR, and XOR on bit-streams are investigated and interpreted statistically. The operation NOT represents a negation for a bipolar input signal. The operation AND results in the product for unipolar input signals. The operation OR results in the addition of the input signals minus the product for unipolar input signals. The operation XOR results in the negative product for bipolar input signals. All operations with multiple inputs have in common that the standard deviation reaches a minimum for input values at the border and a maximum for values in the center of the input range. As the results are based on the assumption of input bit-streams with independent high-frequency components, multiple optimisation strategies for decoupling the quantization noise are discussed and evaluated. The best-rated solution is to implement different designs for the $\Delta \Sigma$-modulators; for example, [10,12]. This combination has been simulated for all three dual input logic operations (AND, OR, XOR). The deviation between the filtered output bit-streams and the filtered functions show better results than expected from the standard deviation, and support the previous theses. In order to achieve the best independence of the high-frequency signal components, different designs must be evaluated with the expected input signals.

Conflicts of Interest: The author declares no conflict of interest.

## Abbreviations

The following abbreviations are used in this manuscript:

| DSP | digital signal processing |
| :--- | :--- |
| DSSP | $\Delta \Sigma$-Signal Processing |
| NOT | logic function not |
| OR | logic function or |
| AND | logic function and |
| XOR | logic function xor |
| FPGA | Field Programmable Gate Array |

## References

1. Lagoyannis, D.; Pekmestzi, K. Multipliers of delta-sigma sequences. Radio Electron. Eng. 1981, 51, 281-286.
2. Kouvaras, N. Operations on delta-modulated signals and their application in the realization of digital filters. Radio Electron. Eng. 1978, 48, 431-438.
3. Zrilic, D.G. Circuits and Systems Based on Delta Modulation: Linear, Nonlinear and Mixed Mode Processing; Springer: Berlin/Heidelberg, Germany, 2005.
4. Ng, C. Bit-Stream Signal Processing on FPGA. Ph.D. Thesis, University of Hong Kong, Hong Kong, China, 2008.
5. Homann, M. Hochdynamische Strom- und Spannungsregelung von Permanenterregten Synchronmaschinen auf Basis von Delta-Sigma Bitströmen. Ph.D. Thesis, TU Braunschweig, Braunschweig, Germany, 2016.
6. Homann, M.; Klein, A.; Kirchner, R.; Schumacher, W. Quasi-kontinuierliche Signalverarbeitung mit Delta Sigma Bitströmen in der Antriebstechnik-Ein Überblick. In Proceedings of the Fortschritte in der Antriebsund Automatisierungstechnik, Stuttgart, Germany, 27 April 2016; pp. 215-227.
7. Homann, M.; Klein, A.; Schumacher, W. Direct Delta Sigma Signal Processing for Control of Power Electronics. In Proceedings of the International Exhibition and Conference for Power Electronics, Intelligent Motion, Renewable Energy and Energy Management (PCIM), Nuremberg, Germany, 10-12 May 2016.
8. Homann, M.; Schumacher, W. High Bandwidth Phase Voltage and Phase Current Control Loop of a Permanent Magnet Synchronous Motor based on Delta Sigma Bitstreams. In Proceedings of the 18th European Conference on Power Electronics and Applications (EPE'16 ECCE Europe), Karlsruhe, Germany, 5-9 September 2016.
9. Kershaw, S.M.; Sandler, M.B. Digital signal processing on a sigma-delta bitstream. In Proceedings of the IEE Colloquium on Oversampling Techniques and Sigma-Delta Modulation, London, UK, 30 March 1994.
10. Schreier, R.; Temes, G.C. Understanding Delta-Sigma Data Converters; IEEE Press: Piscataway, NJ, USA, 2005.
11. Schreier, R. Delta Sigma Toolbox. Available online: http://www.mathworks.com/matlabcentral/ fileexchange/19-delta-sigma-toolbox (accessed on 21 June 2017).
12. Marques, A.; Peluso, V.; Steyaert, M.S.; Sansen, W.M. Optimal parameters for $\Delta \Sigma$ modulator topologies. IEEE Trans. Circuits Syst. II Analog Digit. Signal Process. 1998, 45, 1232-1241.
13. Wolfgang Rautenberg. Einführung in Die Mathematische Logik; Vieweg + Teubner: Wiesbaden, Germany, 2008.
14. Bernoulli, J.; Huygens, C. Wahrscheinlichkeitsrechnung (Ars Conjectandi); University of Michigan Library: Ann Arbor, MI, USA, 1899; Volume 2.
15. O'Leary, P.; Maloberti, F. Bit stream adder for oversampling coded data. Electron. Lett. 1990, 26, 1708-1709.
16. Rüschendorf, L. Mathematische Statistik; Springer-Lehrbuch Masterclass, Springer Spektrum: Berlin, Germany, 2014.
17. Ortmanns, M.; Gerfers, F. Continuous-Time Sigma-Delta AD Conversion: Fundamentals, Performance Limits and Robust Implementations; Springer Series in Advanced Microelectronics; Springer: Berlin, Germany, 2006; Volume 21.
18. Ardalan, S.H.; Paulos, J.J. An analysis of nonlinear behavior in delta-sigma modulators. IEEE Trans. Circuits Syst. 1987, 34, 593-603.
19. Reiss, J.D. Understanding Sigma-Delta Modulation: Solved and Unsolved Issues. J. Audio Eng. Soc. 2008, 56, 49-64.
© 2018 by the author. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (http://creativecommons.org/licenses/by/4.0/).
