BULETINUL INSTITUTULUI POLITEHNIC DIN IAȘI Publicat de Universitatea Tehnică "Gheorghe Asachi" din Iași Volumul 64 (68), Numărul 4, 2018 Secția ELECTROTEHNICĂ. ENERGETICĂ. ELECTRONICĂ

# DIGITAL PROCESSOR IMPLEMENTATION OF CHAOTIC GENERATOR

BY

## VICTOR GRIGORAŞ<sup>1,\*</sup> and CARMEN GRIGORAŞ<sup>2,3</sup>

<sup>1</sup>Technical University "Gheorghe Asachi" of Iaşi Faculty of Electronics, Telecommunications and Information Technology, <sup>2</sup> "Gr.T. Popa" University of Medicine and Pharmacy of Iaşi, Faculty of Biomedical Engineering, <sup>3</sup>Institute of Computer Science, Romanian Academy, Iaşi branch

Received: October 31, 2018 Accepted for publication: December 21, 2018

**Abstract.** Nonlinear systems with complex dynamical behaviour are well studied and electronic implementations are of great interest for measurement, communication and encryption applications. The present contribution aims at developing a digital implementation of a discrete-time chaotic generator, aiming applications in noise generation. The proposed generator is a nonlinear system designed based on an analog prototype submitted to a simple sampling process. The designed digital architecture is developed using a 32 bits ARM Cortex-M4 processor and its performance is studied from the dynamical and statistical points of view.

Keywords: nonlinear systems; chaotic dynamics; digital processor; signal sampling.

## 1. Introduction

Nonlinear systems perform different types of dynamical behaviors, starting from constant and periodic types up to complex quasi-periodic and

<sup>\*</sup>Corresponding author: *e-mail*: carmen.grigoras@umfiasi.ro

chaotic ones. Chaotic systems aim applications in noise generation (Grigoraş, 2011a), binary random number calculation (Yalcin, 2004; Yang, 2004), signal encryption for secure communication (Kocarev, 2001; Grigoraş, 2011b), signal generators based on discrete components (Teodorescu, 2011) and other applications requiring complex dynamics. Analogue implementations of the studied nonlinear systems is aiming simple alternatives, (Piper, 2010; Li, 2015), but is affected by parameter sensitivity of the chaotic circuits. Digital implementations are also studied, (Mandal, 2017; Giakoumis, 2018), because of their higher implementation precision and parameter control.

The present contribution presents the performance of a programmable digital implementation for a chaotic nonlinear system, aiming applications in measurement and communications as a noise generator. The proposed discrete-time system is designed starting from a hysteretic fourth order analogue prototype submitted to direct sampling. The dynamic and statistic properties of the resulting system are analyzed and its state equations used to develop a digital processor implementation.

The following section is devoted to the design of the discrete-time nonlinear system, starting from the state equations of a hysteretic analogue prototype. Implementation results are presented in the third section, showing the dynamic and statistical properties of the implemented system. The obtained results highlight the efficiency of digital programmable implementation of the chaos generator, suggesting possible applications in signal processing, communication and biomedical fields. The final section draws resulting conclusions.

### 2. Discrete Nonlinear System Design

The proposed discrete-time nonlinear system, used to develop the programmed implementation, is a fourth order hysteretic generator, designed on the basis of an analogue prototype, introduced in Grigoraş, (2017), described by the state equations:

$$\begin{cases} dx/dt = \omega_0 y - z, \\ dy/dt = -\omega_0 x + z, \\ dz/dt = -x - y - \omega_0 z + sat(v), \\ dv/dt = -G/\tau (-x) - v/\tau + Th \cdot G/\tau \cdot sat(v). \end{cases}$$
(1)

The nonlinear algebraic function sat(v), denotes the saturation characteristic of the amplifier used to implement the hysteretic element:

$$sat(v) = \begin{cases} -1 \text{ if } v < -1, \\ v \text{ if } |v| < 1, \\ 1 \text{ if } v > 1. \end{cases}$$
(2)

The Schmitt trigger, used as a basic hysteretic element, is characterized by the differential equation, included in (1):

$$\begin{cases} dv/dt = -\frac{v}{\tau} + Th \cdot \frac{G}{\tau} \cdot sat(v) - \frac{G}{\tau} \cdot u, \\ w = sat(v). \end{cases}$$
(3)

In eq. (3), u and w are the analogue input and output signals of the Schmitt trigger, G is the open loop gain and  $\tau$  the time constant of the operational amplifier in the implementation circuit and Th is the positive switching threshold scale factor of the Schmitt trigger. As presented in our previous contribution, equation (3) leads to a simple hysteretic behavior of the Schmitt trigger, the way depicted in Fig. 1, for a value of Th = 0.01.



Fig. 1 – Inverting type Schmitt trigger hysteretic characteristic.

The previous analysis, developed for the analogue hysteretic prototype, highlights the fact that the system (1) is characterized by two equilibrium points that are unstable for positive values of the  $\omega_0$  parameter. By symbolic calculation, the analogue system is demonstrated to be dissipative for all positive values of the coefficients  $\omega_0$  and  $\tau$ , while ergodicity and sensitivity properties, specific for chaotic systems, are justified by simulations, for large variation domains of the *Th* and  $\omega_0$  parameters.

The approach used in the following to obtain the discrete-time variant of the prototype system (1), is to replace analogue integrators with discrete-time accumulators, characterized by the equation:

$$w[k+1] = w[k] + T \cdot e[k]$$
(4)

where: w[k] denotes the state of the discrete-time accumulator and e[k] its discrete input signal. This approach leads to the approximation of the analogue time derivative with a discrete difference, as in:

$$\frac{\mathrm{d}x}{\mathrm{d}t} \approx \frac{1}{T} \Big[ x(t_{k+1}) - x(t_k) \Big]. \tag{5}$$

In equations (4) and (5), T denotes the discrete clock period of the resulting system, equal to the sampling time of the processed signals:

$$T = t_{k+1} - t_k, \ k \in \mathbb{Z}$$
 (6)

Applying the proposed method, the resulting nonlinear discrete-time system is described by the difference state equations:

$$x[k+1] = x[k] + T(\omega_0 \cdot y[k] - z[k]),$$
  

$$y[k+1] = y[k] - T(\omega_0 \cdot x[k] - z[k]),$$
  

$$z[k+1] = z[k] - T(x[k] + y[k] + \omega_0 \cdot z[k] - b \cdot sat(v[k])),$$
  

$$v[k+1] = v[k] - T(G/\tau \cdot x[k] + v[k]/\tau - Th \cdot G/\tau \cdot sat(v[k])).$$
(7)

Choosing a normalized clock period of maximum value T = 0.025, the time evolution of the state variables of the discrete system is non-periodic and unpredictable on large term, similar to the analogue system, as suggested in the results depicted in Fig. 2, where the three trajectories show the desired properties.



Fig. 2 – Time evolution of the state variables of the discrete system x[k] (dot), y[k] (circle) and z[k] (star).

For the system parameter  $\omega_0 = 2.21$ , the state portrait of the discretetime system follows a resembling profile to the analogue prototype, as shown in Fig. 3. Similar simulations, for different omega values, highlight the different attractors obtained in the analysis of the analogue system too.

#### **3. Implementation Results**

The proposed discrete nonlinear system has both dynamic and statistic properties that are attractive for noise or binary random number generation. Due to its discrete-time structure, the designed chaotic generator is open to the possibility of software controlled digital processor implementation.

For the digital implementation, we chose a processor of the ARM Cortex M4 type and an architecture using 32 bit values representation. This processor has sufficient computing power to perform the calculations imposed by the nonlinear algebraic functions comprised in the difference state equations of the nonlinear system to be implemented. The D/A converters, included in the microcontroller structure, have 12 bits conversion capability, reasonable for interfacing the tested digital system with the analogue world. Due to the high enough number representation in the chosen processor, the number of bits in the conversion structure leads to the dominating differences between floating point simulation results and the corresponding digital measurements.

The algorithm used in the program implementation is suggested by the system state equations and leads to the following pseudo code:

```
initialize (actual state vector);
while switch not pressed:
    compute state function (actual state vector);
    store result in (next state vector);
    transfer
    (next state vector) > (actual state vector);
```

The data structure needed for this simple algorithm is based upon two floating vectors with four components:

```
actual state vector;
next state vector;
```

Added to these vectors are the scalar system parameters:

T,  $\omega_0$ , Th, b, G,  $\tau$ ;

The processor used in the tested implementation is STMicroelectronics STM32F334R8T6 and the generated signals were acquired with a Tektronix TDS2002B oscilloscope, digital results being saved and graphically represented on computer. Examples of the acquired state variables from the implemented system are presented in Figs. 3 and 4, for two different values of the parameter  $\omega_0$ , namely 2.21 and 1.1.



Subtracting the values of the state variables of the simulated and implemented discrete type system, we obtain the error values depicted in Fig. 5, with of  $2 \times 10^{-4}$  maximum error values and relatively uniform fill of the value range.

Statistically analyzing the designed discrete system, we can show results similar to the ones obtained in the analog case. The histograms depicted in Fig. 6, for similar system parameter  $\omega_0 = 2.21$ , highlight statistics of the first order with a with two to three peaks, for the x[k], y[k] and z[k] state variables.

Errors in the simulated and implemented state variables histograms are also small, as suggested in the difference graph depicted in Fig. 7. The low order of magnitude maximum error, validate the efficiency of use for the digital implementation of the chaotic generator.





Fig. 5 – Difference between y[k] simulated and implemented state variables.



Fig. 6 – Hystograms for x[k] (up), y[k] (middle) and z[k] (down) implemented state variables.



Fig. 7 – Average errors in histograms for the first three state variables: x, y, z.

### 4. Conclusion

The present contribution concentrates on designing a discrete chaotic generator starting from an analogue prototype. The proposed nonlinear system is developed based on a previously designed analogue generator that is converted to a discrete version by direct sampling thus using discrete accumulators as a replacement of analogue integrators. The previously developed analogue generator is closely followed in performance by the discrete counterpart in both dynamic and statistic performance. The resulting discrete system is digitally implemented by programming a 32 bit ARM Cortex M4 architecture processor. The programed structure implements the calculations given by the discrete-time state equations describing the generator. The resulting structure performances are compared to the more precise 64 bit floating point computer simulations. The small value errors obtained confirm the efficiency of the proposed implementation.

#### REFERENCES

- Grigoraș V., Grigoraș C., *Chaotic Noise Generators with Periodic Nonlinearities*, 10th International Symposium on Signals, Circuits and Systems (ISSCS), 2011a, pp. 1-4.
- Yalcin M.E., Suykens J.A.K., Vandewalle J., *True Random Bit Generation From a Double Scroll Attractor*, IEEE Transactions on Circuits and Systems I: Regular Papers, 51, 7, Jul. 2004, pp. 1395-1404.
- Yang H.T., Huang R.J., Chang T.I., A Chaos-Based Fully Digital 120 MHz Pseudo Random Number Generator, Proceedings of the IEEE Asia-Pacific Conference on Circuits and Systems, Dec. 6-9, 2004, pp. 357-360.

- Kocarev L., Chaos and Cryptography: Block Encryption Ciphers Based on Chaotic Maps, IEEE Transactions on Circuits and Systems I, February 2001, pp. 163-169
- Grigoraș V., Grigoraș C., *Time Variant Chaos Encryption*, Chaos Theory: Modeling, Simulation and Applications, 2011b, World Scientific, pp. 175-182.
- Grigoraș V., Grigoraș C., *Chaos Based Spread Spectrum Clock Generator*, WSEAS Transactions on Circuits and Systems, **4**, 8, pp. 1104-1111, 2005.
- Teodorescu H.-N., Cojocaru V., Complex Signal Generators Based on Capacitors and on Piezoelectric Loads, Chaos Theory: Modeling, Simulation and Applications 2011, World Scientific Publishing Co., pp. 423-430
- Piper J.R., Sprott J.C., Simple Autonomous Chaotic Circuits, IEEE Transactions on Circuits and Systems II: Express Briefs, 57, September 2010, pp. 730-734, 2010, DOI:10.1109/TCSII.2010.2058493.
- Li C., Sprott J. C., Thio W., Zhu H., A Unique Signum Switch for Chaos and Hyperchaos, Proc. 7th International Conference on Physics and Control, PhysCon 2015, Istambul, Turkey.
- Mandal M.K., Das A.K., Chaos-Based Colour Image Encryption Using Microcontroller ATMEGA 32, Proceeding of NCCS 2017.
- Giakoumis A., Stouboulos I.N., Kyprianidis I., *Chaos Generator Device Based on a 32 Bit Microcontroller Embedded System*, 7th International Conference on Modern Circuits and Systems Technologies, MOCAST 2018
- Grigoraş C., Grigoraş V., Complex Dynamics in Hysteretic Nonlinear Oscillator Circuit, Proceedings of the Romanian Academy – Series A Mathematics, Physics, Technical Sciences, Information Science, 18, 4, Oct. Dec. 2017, pp. 370-377.

#### IMPLEMENTAREA CU PROCESOR NUMERIC A UNUI GENERATOR HAOTIC

#### (Rezumat)

Sistemele neliniare având comportari dynamice complexe sunt bine studiate, iar implementările electronice sunt de mare interes pentru aplicații în măsurări, comunicații și criptare. Prezentul articol vizează dezvoltarea unei implementări numerice pentru un generator haotic în timp discret, vizând aplicații la generarea zgomotului. Generatorul propus este un sistem neliniar, proiectat pe baza unui prototip analogic, supus unui process de eșantionare simplă. Arhitectura numarică proiectată este dezvoltată folosind un processor. ARM Cortex-M4 de 32 de biți și performanțele sale sunt studiate din punct de vedere dinamic și statistic.