ISSN: 1001-4055 Vol. 44 No. 4 (2023)

# Faults Identification in Digital Counter Using Naïve-Bayes' Algorithm

## Shruthi Modem<sup>1</sup>, Hamsa Girish<sup>2</sup>, Joseph Anthony Prathap<sup>3</sup>, Manaswini Ramakrishnappa<sup>4</sup>

UG Student<sup>1,2</sup>, Associate Professor<sup>3</sup>, Assistant Professor<sup>4</sup>, Presidency University, Bengaluru, India

Abstract:-This paper elaborates on the implementation of the Naïve Bayes Algorithm to identify the faults occurrence in the digital counter circuits. The digital counters are circuits utilized to count the values in increasing order, decreasing order, or both directions. The digital counters find applications in real time from simple wristwatches to the industrial conveyor belt that is automated based on timings. The fault happening in the digital counter circuit is to be identified using Fault detection methods such as modular redundancy methods and error detection methods. With the advent of Artificial Intelligence algorithms, the identification of faults and errors in circuits is attained rapid manner. Though there are several machine learning algorithms such as Decision trees, Random Forest, K-Nearest Neighbor, and Support Vector Machines, the naïve Bayes algorithm is an easy and efficient algorithm to identify the errors in the circuits. This work concentrates on the naïve Bayes algorithm by developing the HDL code to predict the faults in the counter circuits. The proposed HDL code is validated for parameters namely power, area, and timing using the EDA tools.

Keywords: Fault Analysis, Naïve Bayes Algorithm, Counters, Electronic Design Automation Tools

#### **I Introduction**

In digital system design, the counter circuit is a digital circuit that keeps track of the number of events occurring as per the count required. The counter circuit is the common component in any automated circuit used in real-time. The fault occurrence in digital circuits can degrade the overall performance of the system either temporarily or permanently. The need for fault analysis arises to identify, rectify, and eradicate such faults in real-time digital applications.

Several fault identification techniques can be used with the digital logic namely Triple Modular Redundancy, 5 Modular Redundancy, and N-modular Redundancy, and consume a high area in the design of these redundancy-based fault analyzing circuits. To overcome this, the faults in the digital circuits are identified using Artificial Intelligence algorithms namely the Decision tree method, Random forest method, K-nearest neighbor, and Support Vector Machines. Though many algorithms are available to analyze the faults, the Naïve Bayes algorithm is easy and simple to efficiently identify the faulty instances in the circuits.

The k-nearest neighbors (KNN) technique can be used to locate the problem, and the LSTM algorithm can be used to anticipate the preceding value of the power inverter input [1]. Artificial intelligence is used to forecast the power system characteristics to eliminate unexpected current flow, power outages, and leakage of amperes in industrial applications [2]. The machine learning-based technique can be used to assess line faults and changing impedance issues in inverter-generators linked to transmission lines [3]. In the micro-grid supplied generator based on inverter, the problematic phases are retrieved using the Pearson correlation coefficient-based approach [4]. In real-time power converters, the fault occurrence of a single-phase value can be accomplished using Classification & Regression Tree (CART) approach [5]. The teenager-kaiser energy operator algorithm, which has a low computational time and complexity, can be used to investigate DC faults [6].

The Naive Bayes algorithm is used to identify, classify, or predict the faults with the given dataset [7]. The real-time application-based Naïve Bayes algorithm is challenging to implement as it consists of probability functions [8]. The FPGA-based Naïve Bayes algorithm demands the compensatory approach to accurately derive the fault in the circuits. The HDL code for the probability function is not synthesizable in real time [9]. The need for an alternate approach may increase the size of the circuit under test.

This paper proposes the Naïve Bayes algorithm implementable using the FPGA device to identify the fault occurrence in the digital counter circuit. The synthesizable code for the proposed method is developed in HDL and the IC layout is presented for the proposed method using the VLSI EDA tools.

#### II. The Proposed Method: Naïve Bayes algorithm based Fault analysis for the counter circuit

The proposed Naïve Bayes algorithm-based fault analysis for digital counter circuits investigates the error occurrence in the counter circuit in digital design. The design for the fault analysis of the counter consists of two counter circuits of  $2^8$ -bit resolution. One of the counters is the counter circuit under test referred to as the "Valid Counter" and the other counter identifies the fault referred to as the "Fault Counter". The Valid counter is the counter used to generate the correct and errorless counting output and the fault counter is the circuit that produces the faulty output of the counter circuit. These two counters are generated simultaneously and the outputs of the counters are analysed for faults.

The counter outputs are fed into the Naïve Bayes algorithm block with the comparator as shown in Figure 1. This work uses the Naïve Bayes algorithm to predict the faults in the digital counter circuit. In general, Naïve Bayes algorithm is a supervised learning algorithm based on the Bayes theorem and used to solve classification problems. Naïve Bayes Classifier is a simple and effective Classification algorithm that builds fast machine learning models for quicker predictions. The Naïve Bayes algorithm is based on a probabilistic classifier that predicts based on the probability of an occurrence.



Fig. 1: Block Diagram for the proposed Fault Analyzer using Naïve Bayes method

In this work, the two 2<sup>8</sup>-bit counters are considered and the circuit counts from "0" to "255". The Valid counter displays the output of the count from 0 to 255 for clock triggering. Similarly, the Fault counter depicts the output with a random fault instance in the counter for the clock triggering. These two counters are accumulated together to manipulate the probability of the fault occurrence and

no-fault based on the formula given below

$$P\left(\frac{A}{B}\right) = \frac{P\left(\frac{B}{A}\right)P(A)}{P(B)}$$

The naïve Bayes algorithm calculates the probabilities of the two counters from the signal inputs of "counta" and "countb". These signals "counta" and "countb" are taken into account for the Naïve Bayes Block and the evaluated counts are expressed as "count1" and "count2". These count values are allotted with evaluated probabilities each of which is the function of the Naïve-Bayes parameters and converted to the digitalized

ISSN: 1001-4055 Vol. 44 No. 4 (2023)

probability equivalent. The digitalized probability equivalents of the counters are compared with the comparator circuit to give two possible outcomes of either with error or no error. The magnitude of error is evaluated using the relational comparison of the values.

To implement the proposed method in the hardware, the proposed fault analyzer is developed using the HDL code and evaluated using Xilinx. Initially, the proposed method is developed using HDL code for simulation verification by ModelSim Tool. After the simulation, the developed code is checked for synthesizabilityby making use of the Xilinx Tool. Further, the IC layout is accomplished by converting the HDL code of the proposed method using the cadence tool.

#### **III Results and Discussions**

The proposed naïve Bayes algorithm-based fault identification for the digital counter circuit is developed using the HDL code. The developed HDL code is designed using the behavioral model with the if-else block. The proposed method is developed in HDL code for simulation verification as presented in Figures 2 and 3. Figure 2 represents the counter output without errors and Figure 3 depicts the counter output with errors and indicates the occurrence of errors in the simulated output. The proposed method is real time validated by implementing in the Xilinx Tool. The RTL schematic for the proposed method using the Xilinx Tool is shown in Figure 4. Also, the area is evaluated using Xilinx Tool that uses 13% of LUTs and Occupied slices as presented in Table 1. Figure 5 gives the power report for the HDL code of the proposed methods using the Xilinx Tool. For the sake of developing the layout plan for the proposed method, the validated HDL is converted to the RTL schematic using the Genus Tool as shown in Figure 6. The IC layout can be obtained with the use of the INNOVUS cadence tool as depicted in Figure 7. The proposed method is analysed for power report using the Cadence Tool is given in Figure 8.



Fig. 2: Simulation output for the counter circuit without error using ModelSim Tool



 $Fig. \ 3: Simulation \ output \ for \ the \ proposed \ fault \ identifier \ using \ ModelSim \ Tool$ 



Fig. 4: RTL Schematic for the counter circuit fault identifier in Xilinx Tool

Table 1 Area Utilization chart for the counter circuit fault identifier in Xilinx Tool

| Device Utilization Summary                     |       |           |             |         |  |  |  |
|------------------------------------------------|-------|-----------|-------------|---------|--|--|--|
| Logic Utilization                              | Used  | Available | Utilization | Note(s) |  |  |  |
| Total Number Slice Registers                   | 526   | 9,312     | 5%          |         |  |  |  |
| Number used as Flip Flops                      | 13    |           |             |         |  |  |  |
| Number used as Latches                         | 513   |           |             |         |  |  |  |
| Number of 4 input LUTs                         | 1,231 | 9,312     | 13%         |         |  |  |  |
| Number of occupied Slices                      | 624   | 4,656     | 13%         |         |  |  |  |
| Number of Slices containing only related logic | 624   | 624       | 100%        |         |  |  |  |
| Number of Slices containing unrelated logic    | 0     | 624       | 0%          |         |  |  |  |
| Total Number of 4 input LUTs                   | 1,240 | 9,312     | 13%         |         |  |  |  |
| Number used as logic                           | 1,231 |           |             |         |  |  |  |
| Number used as a route-thru                    | 9     |           |             |         |  |  |  |
| Number of bonded <u>IOBs</u>                   | 9     | 232       | 3%          |         |  |  |  |
| IOB Latches                                    | 3     |           |             |         |  |  |  |
| Number of BUFGMUXs                             | 2     | 24        | 8%          |         |  |  |  |
| Average Fanout of Non-Clock Nets               | 4.55  |           |             |         |  |  |  |



Fig. 5:Power Output for the counter circuit fault identifier in Xilinx Tool



Fig.6: RTL schematic for the counter circuit fault identifier in Genus Cadence Tool

ISSN: 1001-4055 Vol. 44 No. 4 (2023)



Fig.7: IC layout plan for the counter circuit fault identifier inInnovus Cadence Tool

| Total Internal Power:<br>Total Switching Power:<br>Total Leakage Power:<br>Total Power: | 0.26148932<br>0.03658932<br>0.00840650<br>0.30648513 | 11.                    | 3188%<br>9384%<br>7429%  |                  |            |
|-----------------------------------------------------------------------------------------|------------------------------------------------------|------------------------|--------------------------|------------------|------------|
| Group                                                                                   | Internal<br>Power                                    | Switching<br>Power     | Leakage<br>Power         | Total<br>Power   | Percentage |
|                                                                                         | rower                                                | rower.                 | r one:                   |                  | (2)        |
| Sequential                                                                              | 0.1836                                               | 0.01259                | 0.003886                 | 0.2001           | 65.2       |
|                                                                                         |                                                      |                        |                          | n.               |            |
| Macro                                                                                   | 9                                                    |                        |                          | 0                |            |
| facro<br>IO                                                                             | 9                                                    | 8                      | 9                        | 0                | l cand     |
| facro<br>IO                                                                             | 9<br>9<br>9.97785                                    | 0<br>0.82399           | e.ee452                  | 0.1064           | 34.7       |
| facro<br>Combinational                                                                  | 9<br>9<br>9.97786<br>9                               | 0.82399<br>0           | 0.00452<br>0             | 0.1964<br>0      | 34.7       |
| Macro<br>(O<br>Combinational<br>Clock (Combinational)                                   | 9<br>9<br>9.97786<br>9                               | 0.02399<br>0<br>0      | 6.68452<br>6<br>6        | 0.1964<br>0<br>0 |            |
| Macro<br>IO<br>Combinational<br>Clock (Combinational)<br>Clock (Sequential)             | 9<br>9.97786<br>9<br>9                               | 0.02399<br>0<br>0<br>0 | 0.00452<br>0<br>0.008406 | 0.1064<br>0.3065 |            |

Fig. 8:Power Report for the counter circuit fault identifier in Cadence Tool

#### **IV Conclusion**

The proposed counter circuit fault identifier is successfully designed by the inculcation of the Naïve Bayes algorithm. The real application suitability is achieved using Xilinx EDA tool with the power of 0.081W and in the Cadence tool with the power of 0.3065W. The design of layout plan for the counter circuit fault identifier is achieved by the Innovus Cadence EDA Tool.

#### References

- [1] F. Fallah, A. Ramezani, and A. M. Sani, "Integrated fault diagnosis and control design for DER inverters using machine learning methods," in *IEEE Power and Energy Society General Meeting*, Jul. 2022, vol. 2022-July, pp. 1–5, doi: 10.1109/PESGM48719.2022.9916754.
- [2] K. V. Murthy and L. A. Kumar, "Analysis of artificial intelligence in industrial drives and development of fault deterrent novel machine learning prediction algorithm," *Automatika*, vol. 63, no. 2, pp. 349–364, Apr. 2022, doi: 10.1080/00051144.2022.2039988.
- [3] K. Al-Kharusi, A. E. Haffar, and M. Mesbah, "Fault detection and classification in transmission lines connected to inverter-based generators using machine learning," *Energies*, vol. 15, no. 15, Jul. 2022, doi: 10.3390/en15155475.
- [4] M. A. Jarrahi, H. Samet, and T. Ghanbari, "Protection framework for microgrids with inverter-based DGs: a superimposed component and waveform similarity-based fault detection and classification scheme," *IET Generation, Transmission and Distribution*, vol. 16, no. 11, pp. 2242–2264, Jun. 2022, doi: 10.1049/gtd2.12438.

### Tuijin Jishu/Journal of Propulsion Technology

ISSN: 1001-4055 Vol. 44 No. 4 (2023)

- [5] Y. Zhu and H. Peng, "Multiple random forests based intelligent location of single-phase grounding fault in power lines of DFIG-based wind farm," *Journal of Modern Power Systems and Clean Energy*, vol. 10, no. 5, pp. 1152–1163, 2022, doi: 10.35833/MPCE.2021.000590.
- [6] R. B. Damala, R. K. Patnaik, and A. R. Dash, "A simple decision tree-based disturbance monitoring system for VSC-based HVDC transmission link integrating a DFIG wind farm," *Protection and Control of Modern Power Systems*, vol. 7, no. 1, Dec. 2022, doi: 10.1186/s41601-022-00247-w.
- [7] Z. Xue, J. Wei and W. Guo, "A Real-Time Naive Bayes Classifier Accelerator on FPGA," in IEEE Access, vol. 8, pp. 40755-40766, 2020, doi: 10.1109/ACCESS.2020.2976879.
- [8] R. Sayed, H. Azmi, A. M. Nassar and H. Shawkey, "Design Automation and Implementation of Machine Learning Classifier Chips," in IEEE Access, vol. 8, pp. 192155-192164, 2020, doi: 10.1109/ACCESS.2020.3032658
- [9] Talib, M.A., Majzoub, S., Nasir, Q. et al. A systematic literature review on hardware implementation of artificial intelligence algorithms. J Supercomput 77, 1897–1938 (2021).