# DESIGN OF MODIFIED DUAL-CLCG ALGORITHM FOR PSEUDO RANDOM BIT GENERATOR G Sri Lakshmi<sup>1</sup>, K Thanmai<sup>2</sup>, P Varsha<sup>3</sup> <sup>1</sup>Department of ECE, Bhoj Reddy Engineering College for Women, Hyderabad, India <sup>2,3</sup>,UG scholar students Department of ECE, Bhoj Reddy Engineering College for Women, Hyderabad, India A pseudorandom bit generator (PRBG) is a crucial element in ensuring the security of data during its transmission and storage in different cryptographic applications. Out of the commonly used techniques for generating pseudorandom numbers, including linear feedback shift register (LFSR), linear congruential generator (LCG), connected LCG (CLCG), and dual-coupled LCG (dual-CLCG), the dual-CLCG approach is shown to be more safe. This approach utilizes inequality comparisons to generate pseudorandom bits at regular intervals. Therefore, a novel design of the dual- CLCG technique is created, which produces pseudo-random bits at a consistent clock rate. This work proposes a novel approach termed "modified dual-CLCG" for pseudo-random bit generation (PRBG) together with a very large-scale integration (VLSI) architecture. The purpose of this method is to address the aforementioned concerns. The innovative feature of the proposed PRBG approach is its ability to create pseudorandom bits at a consistent clock rate, with just one initial clock delay and little hardware complexity. ## Introduction Security and privacy over the internet is the most sensitive and primary objective to protect data in various ways. Pseudo-Random Bit Generators (PRBGs) play afundamental role in various fields such as cryptography, simulation, and secure communication systems. They are essential for generating sequences of bits that exhibit characteristics of randomness, making them suitable for cryptographic keys, statistical simulations, and more. The quality and efficiency of a PRBG are paramount for ensuring the security and reliability of systems that rely on random bit sequences. we present the design of a Modified Dual-CLCG (Combined Linear Congruential Generator). For IoT enabled hardware applications. The proposed PRBG method i.e. "modified dual-CLCG" and its VLSI architecture have the following advantages and novelcontributions over previous PRBG method. First, a single XOR logic is utilized at the output stage for generating pseudorandom bit at uniform clock rate which leads to lower the hardware cost. Secondly, it generates a maximum length of 2<sup>n</sup> pseudorandom bits with one initial clock latency. Third, the proposed modified dual-CLCG method passes all the fifteen benchmark tests of NIST standard and is proved to be polynomial-time unpre- dictable. The randomness tests are performed using NIST test tool sts-2.1.2. Further, the properties of the proposed PRBG method are investigated theoretically by using the probabilistic approach. It shows that the proposed modified dual-CLCG system has the similar security strength of dual-CLCG method and the probabilistic algorithm to obtain the initial seed requires the solution of n2<sup>4</sup>. The architecture of the existing dual-CLCG method and the proposed modified dual-CLCG method for different word size of n8 was implemented using Verilog HDL. This project is organized as follows: architectural mapping of the existing dual- CLCG method is performed and The proposed PRBG method along with its randomness properties are discussed. he efficient VLSI architecture of the proposed modified dual-CLCGmethod. Combined linear congruential generators, as the name implies, are a type of PRNG (pseudorandom number generator) that combine two or more LCGs (linear congruential generators). The combination of two or more LCGs into one random number generator can result in a marked increase in the period length of the generator which makes them better suited for simulating more complex systems. The combined linear congruential generator algorithm is defined as: $$Xi \equiv (\sum (-1)^{J-1} Y_{ij}) (mod(m1-1))$$ $$i=1$$ Where m1m1 is the modulus of the LCG, Yi, jYi, j is the iith input from the jjth LCG AXIXI is the iith random generated value. L'Ecuyer describes a combined linear generatorthat utilizes two LCGs in Efficient and Portable Combined Random Number Generators for 32-bit processors. Algorithm for a PRBG. The objective of this modification is to improve the efficiency and statistical properties of the generated random bit sequences. The Dual- CLCG algorithm combines the outputs of two Linear Congruential Generators (LCGs) with distinct seeds to produce random bits. Linear Congruential Generators are a common choice for generating pseudo-random sequences due to their simplicity and speed. However, their periodicity and statistical properties can be limited when used individually. The Dual-CLCG algorithm overcomes these limitations by leveraging the combined power of two LCGs while carefully selecting seed values and parameters. ## Modified Dual CLCG Modified algorithm of dual-coupled linear congruential generator (dual-CLCG) for pseudo-random bit generation is proposed to achieve the high randomness properties of generated bit sequence with minimum VLSI complexity. The proposed method relies based on randomly chosen inequality comparisons bits by the multiplexer circuit and its select lineis control by current seeds value to generates final random bits. Therefore, a new method forrandom bit generator i.e. modified dual-CLCG and its VLSI architecture are proposed in this work to mitigate the more secure random bit generator. The effect of modification on the design of a dual CLCG is observed to evaluate the some of the essential timing performance parameters such as initial clock latency, maximum possible frequency of bit generation and output –to-output latency. Also find the power dissipation and utilize chip area. The proposed architecture with 8, 16 and 32-bit length is design using Verilog-HDL and its synthesis is done based on 90-nm CMOS technology (GPDK) using Cadence Tool A block diagram of a Modified Dual CLCG (Complementary Linear Congruential Generator) structure typically consists of four linear congruential generators (LCGs) operating in parallel, with additional components for combining their outputs. Here's a breakdown of the components and their functions: LCG 1: This is the first linear congruential generator in the structure. It generates a sequence of pseudo-random numbers using a linear recurrence relation of the form. Combiner: This component combines the outputs of LCG 1 and LCG 2 to generate the final sequence of pseudorandom numbers. There are different methods for combining the outputs, such as adding, subtracting, XORing, or using other mathematical operations. The purpose of combining the outputs is to enhance the statistical properties of the generated random numbers. Output: This is the final output of the Modified Dual CLCG structure, consisting of a sequence of pseudorandom numbers with improved randomness properties compared to using a single linear congruential generator. The dual-CLCG algorithm for pseudorandom bit generator was proposed in. It is a dual coupling of four LCG block and it is given by following recurrence equations: $$x_{i+1} = [(2^{r_1} \times x_i) + x_i + b_1] \mod 2^n \tag{1}$$ $$y_{i+1} = [(2^{r2} \times y_i) + y_i + b_2] \mod 2^n \tag{2}$$ $$p_{i+1} = [(2^{r3} \times p_i) + p_i + b_3] \mod 2^n \tag{3}$$ $$q_{i+1} = [(2^{r4} \times q_i) + q_i + b_4] \mod 2^n \tag{4}$$ $$B_i = \begin{cases} 1 & \text{if } x_{i+1} > y_{i+1} \\ 0 & \text{if } x_{i+1} < y_{i+1} \end{cases}$$ (5) $$C_i = \begin{cases} 1 & \text{if } p_{i+1} > q_{i+1} \\ 0 & \text{if } p_{i+1} < q_{i+1} \end{cases}$$ (6) $$z_i = B_i \, ^{\wedge} C_i \tag{7}$$ Here b1, b2, b3, b4 are the constant parameter and x0, y0, p0 and q0 are the initial seeds value for above recurrence equations. Here shifting value r is the positive integer i.e. $1 < 2^r < 2^n$ . The final output of random bit sequence is given by variable zi. It is evaluated based on Equations (5) to (6) in each iteration. To enhance the randomness properties of the random sequence, we can modify the equation (7) and it is relies based on randomly chosen inequality comparisons bits by the multiplexer circuit and its select line is control by current seeds value [yi+1] to generates final random bit sequence i.e. given by equation(8). $$z_i = \begin{cases} B_i & \text{if } y_{i+1} = 0 \\ C_i & \text{if } y_{i+1} = 1 \end{cases}$$ (8) - 1) LCG 1 and LCG 2 operate independently in parallel, each generating its own sequenceof pseudorandom numbers. - 2) The parameters (multipliers, increments, and moduli) of LCG 1 and LCG 2 are carefully chosen to ensure they are statistically independent and have long periods. - 3) The outputs of LCG 1 and LCG 2 are combined using the combiner component. This combination can involve various mathematical operations that help reduce correlations between successive random numbers and improve the overall randomness of the sequence. - 4) The combined output from the combiner forms the final sequence of pseudo-random numbers, which can be used in various applications requiring random number generation. LCG 2: This is the second linear congruential generator in the structure. It also generates a sequence of pseudorandom numbers but uses different parameters compared to LCG 1. Overall, the Modified Dual CLCG structure enhances the quality of random numbergeneration by leveraging two complementary linear congruential generators and combiningtheir outputs to produce a sequence with improved statistical properties. Results and Analysis The RTL schematic is abbreviated as the register transfer level it denotes the blue print of the architecture and is used to verify the designed architecture to the ideal architecture that we are in need of development. The hdl language is used to convert the description or summery of the architecture to the working summery by use of the coding language i.e verilog ,VHDL. The RTL schematic even specifies the internal connection blocks for better analyzing. The figure 6.1 represented below shows the RTL schematic diagram of the designed architecture. Fig 8.1 RTL Schematic view of Modified Dual CLCG using CS3A Fig 8.2 RTL Schematic view of proposed Modified Dual CLCG using three operand Adder # **8.1** Technology schematic The technology schematic makes the representation of the architecture in the LUT format ,where the LUT is consider as the parameter of area that is used in VLSI to estimate the architecture design .the LUT is consider as an square unit the memory allocation of the code is represented in there LUT s in FPGA. Fig 8.3 View technology Schematic of modified Dual CLCG using CS3A Fig 8.4 View technology Schematic of proposed modified Dual CLCG using three operand adder # 8.2 Simulation The simulation is the process which is termed as the final verification in respect to its working whereas the schematic is the verification of the connections and blocks. The simulation window is launched as shifting from implementation to the simulation on the home screen of the tool, and the simulation window confines the output in the form of wave forms output. Here it has the flexibility of providing the different radix number systems. | Name | Value | 3 us | other | 2us | | | 415 | | Eus | | 8us | 1 | DE | | 1215 | | 1445 | | Eus | | |------------------|-------|------|-------|-----|---|-------|--------|--------|---------|--------|---------|---------|-------|-------|-------|-------|-------|-------|-------|------| | lig de | 1), | | | | | | ΠÜ | П | | | | | | | | П | | | | П | | a start | 1. | | | | | | | | | | | | | | | | | | | | | M 1031:0 | 2 | | | | | | | | | | | 1 | | | | | | | | | | W YORKS | 3 | | | | | | | | | | | ] | | | | | | | | | | ₩ p031:0 | 7 | | | | | | | | | | | 1 | | | | | | | | | | \$:150p 🔐 | 5 | | | | | | | | | | | 5 | | | | | | | | | | T <sub>e</sub> 2 | 0 | | | | | | | | | | | | 11 | | | | | | Ť. | | | kg out 3 fol | 0 | | 0 | 1 € | | 2838 | 184513 | 11993 | 77967 | 34274 | 37354 | 25438 | 21398 | 16502 | 41852 | 14579 | 27524 | 71107 | 32599 | Z52 | | 1 kg_002310 | 0 | | 1 | 15 | | 546 | 21337 | 704140 | 22236 | 76680 | 38298 | 18314 | 30869 | 15969 | 11567 | 38776 | 34087 | 82119 | 13295 | 5259 | | kg_outBadi | 0 | | -1 | 1 2 | | 424 | 7061 | 120060 | 2041048 | 34697 | 58986 | 14377 | 29663 | 31832 | 25760 | 84829 | 14511 | 31946 | 27735 | 4200 | | kg but4310 | 0 | | 0 | 9 | | 354 | 1829 | 9304 | 46079 | 230454 | 1157329 | 5761704 | 38808 | 14404 | 72021 | 36010 | 82550 | 41275 | 34576 | 1085 | | Te Cout1 | 0 | | | | | , it | | | | | | | fir . | | | | | | fi | | | Te Cout2 | 0 | | | | ı | ti ti | | - | | | | | i i | Ī | | | i . | | | | | ₩ a1[310] | 65 | | | | | | | | | | . 6 | 5 | | | | | | | | | | ₩ ±2510€ | 33 | | | | | | | | | | | ß | | | | | | | | | | ₩ 253105 | 17 | | | | | | | | | | | J | | | | | | | | | | ₩ a4B10[ | 5 | | | | | | | | | | | 5 | | | | | | | | | | M 15151 | 43 | | | | | | | | | | 74 | 8 | | | | | | | | | | W bestel | 19 | | | | | | | | | | 100 | 9 | | | | | | | | | | ₩ 6331:S | 23 | | | | | | | | | | | 3 | | | | | | | | | | ₩ 1431di | 59 | | | | | | | | | | | | | | | | | | | | Fig 8.5 simulated wave form of modified Dual CLCG using CS3A Fig 8.6 Simulated wave form of proposed modified Dual CLCG using three operand PPA # 8.3 Parameters Fig 8.7 family selected for synthesis Consider in VLSI the parameters treated are area, delay, frequency and power ,based on these parameters one can judge the one architecture to other. here the consideration of area and power consumptions are considered the parameters are obtained by using the tool XILINX 14.7 and the HDL is verilog language. When frequency is morefor any design it will increase the speed of design. | Parameter | Existed design | Proposed design | |----------------|----------------|-----------------| | Frequency(MHz) | 132.714 | 225.683 | Table 8.1 Parameter Comparison # **Existed Design Results** | Device Utilization Summary (estimated values) | | | | | | | | |-----------------------------------------------|------|-----------|-------------|--|--|--|--| | Logic Utilization | Used | Available | Utilization | | | | | | Number of Sice Registers | 121 | 93120 | 046 | | | | | | Number of Sice LIJTs | 501 | 46560 | 2% | | | | | | Number of fully used LUT-FF pairs | 121 | 501 | 24% | | | | | | Number of bonded IOBs | 131 | 240 | 54% | | | | | | Number of BUFG/BUFGCTRLs | 1 | 32 | 3% | | | | | Table 8.2 Existed design results Minimum period: 7.535ns (Maximum Frequency: 132.714MHz)Minimum input arrival time before clock: 7.610 ns Maximum output required time after clock: 2.666ns # Proposed Design Results | Device Utilization Summary (estimated values) | | | | | | | | |-----------------------------------------------|------|-----------|-------------|--|--|--|--| | Logic Utilization | Used | Available | Utilization | | | | | | Number of Slice Registers | 121 | 93120 | 0% | | | | | | Number of Sice LUTs | 685 | 46560 | 194 | | | | | | Number of fully used LUT-FF pairs | 121 | 685 | 17% | | | | | | Number of banded 108s | 131 | 240 | 54% | | | | | | Number of BUFG/BUFGCTRLs | 1 | 32 | 3% | | | | | Table 8.3 Proposed Design Results Minimum period: 4.431ns (Maximum Frequency: 225.683MHz)Minimum input arrival time before clock: 4.818ns Maximum output required time after clock: 2.660ns Other parameters ## **Existed Parameters** Minimum period: 4.43lns (Maximum Frequency: 225.683MHz) Minimum input arrival time before clock: 4.818ns Maximum output required time after clock: 2.660ns Maximum combinational path delay: No path found ## Proposed Results Minimum period: 7.535ns (Maximum Frequency: 132.714MHz) Minimum input arrival time before clock: 7.610ns Maximum output required time after clock: 2.666ns Maximum combinational path delay: No path found ## hapter 9 ## Conclusion - Modified Dual-CLCG using CS3A method involves dual coupling of four LCGs that makesit more secure than LCG based PRBGs. However, it is reported that this method has the drawback of generating pseudorandom bit at more delay. - Proposed architecture of the new modified dual- CLCG method is significantly reduced the parameter. The proposed architecture of the modified dual- CLCG using three operand PPA method is working with high frequency resultant it would be reduced the delay of the design. - Based on the performance analysis in terms of hardware complexity, randomness and security, it is observed that 32- bit hardware architecture of the proposed modified dual-CLCG method is optimum and can be useful in the speed of hardware security and IoT applications. ## References - [1] J. Zhou, Z. Cao, X. Dong, and A. V. Vasilakos, "Security and privacy for cloud-based IoT: Challenges," IEEE Commun. Mag., vol. 55, no. 1, pp. 26–33, Jan. 2017. - [2] Q. Zhang, L. T. Yang, and Z. Chen, "Privacy preserving deep computation model oncloud for big data feature learning," IEEE Trans. Comput., vol. 65, no. 5, pp. 1351–1362, May 2016. - [3] E. Fernandes, A. Rahmati, K. Eykholt, and A. Prakash, "Internet of Things security research: A rehash of old ideas or new intellectual challenges?" IEEE Secur. Privacy,vol. 15, no. 4, pp. 79-84, 2017. - [4] M. Frustaci, P. Pace, G. Aloi, and G. Fortino, "Evaluating critical security issues of the IoT world: Present and future challenges," IEEE Internet Things J., vol. 5, no. 4,pp. 2483–2495, Aug. 2018. - [5] E. Zenner, "Cryptanalysis of LFSR-based pseudorandom generators— A survey,"Univ.,MannheimMannheimGermany,2004.[Online].Available: http://orbit.dtu.dk/en/publications/cryptanalysis-of-lfsrbased-pseudorandom-generators—a-survey(59f7106b-1800-49df-8037- fbe9e0e98ced).html - [6] J. Stern, "Secret linear congruential generators are not cryptographically secure," inProc. 28th Annu. Symp. Found. Comput. Sci.,Oct. 1987, pp. 421–426. - [7] D. Xiang, M. Chen, and H. Fujiwara, "Using weighted scan enable signals to improve test effectiveness of scan-based BIST," IEEE Trans. Comput., vol. 56, no. 12, pp. 1619–1628, Dec. 2007. - [8] L. Blum, M. Blum, and M. Shub, "A simple unpredictable pseudo- random number generator," SIAM J. Comput., vol. 15, no. 2, pp. 364–383, 1986. - [9] W. Thomas Cusick, "Properties of the x2 mod N pseudorandom number generator," IEEE Trans. Inf. Theory, vol. 41, no. 4, pp. 1155–1159, Jul. 1995. - [10] C. Ding, "Blum-Blum-Shub generator," IEEE Electron. Lett., vol. 33, no. 8, p. 667, Apr. 1997. - [11] A. Sidorenko and B. Schoenmakers, "Concrete security of the Blum-Blum-Shub pseudorandom generator," in Cryptography and Coding (Lecture Notes in Computer Science), vol. 3796. Berlin, Germany: Springer, Nov. 2005, pp. 355–375. - [12] A. K. Panda and C. K. Ray, "FPGA prototype of low latency BBS PRNG," In Proc. IEEE Int. Symp. Nanoelectron. Inf. Syst. (INIS), Indore, India, Dec. 2015, pp. 118–123. - [13] P. P. Lopez and E. S. Millan, "Cryptographically secure pseudorandom bit generator for RFID tags," in Proc. Int. Conf. Internet Technol. Secured Trans., London, U.K., vol. 11, Nov.2010, pp. 1–6. - [14] R. S. Katti and R. G. Kavasseri, "Secure pseudo-random bit sequence generation using coupled linear congruential generators," in Proc. IEEE Int. Symp. Circuits Syst. (ISCAS), Seattle, WA, USA, May 2008, pp. 2929–2932. - [15] S. Raj Katti and S. Srinivasan, "Efficient hardware implementation of a new pseudo- random bit sequence generator," in Proc. IEEE Int. Symp. Circuits Syst. (ISCAS), Taipei, Taiwan, May 2009, pp. 1393–1396. - [16] R. S. Katti, R. G. Kavasseri, and V. Sai, "Pseudorandom bit generation using coupled congruential generators," IEEE Trans. Circuits Syst. II, Exp. Briefs, vol. 57, no. 3, pp. 203–207, Mar. 2010. - [17] Revised NIST Special Publication 800-22. (Apr. 2010). A Statistica Test Suite for the Validation of Random Number Generators and Pseudo Random Number Generators for Cryptographic Applications. [Online]. Available: http://csrc.nist.gov/publications/nistpubs/800-22-rev1.pdf [18] Random Integer Generator. Accessed: Feb. 20, 2018. [Online]. Available: https://www.random.org/integers [19] T. Addabbo, M. Alioto, A. Fort, A. Pasini, S. Rocchi, and V. Vignoli, "A class of maximum-period nonlinear congruential generators derived from the Rényi chaotic map," IEEE Trans. Circuits System. I, Ref. Papers, vol. 54, no. 4, pp. 816–828, Apr. 2007. [20] J. Massey, "Shift-register synthesis and BCH decoding," IEEE Trans. Inf. Theory, vol.IT-15, no. 1, pp. 122–127, Jan. 1969.