Rashid Hussain Chandio<sup>1</sup>, Imtiaz Hussain Kalwar<sup>2</sup>, Tayab Din Memon<sup>2</sup>, Aftab Ahmed Mangrio<sup>1</sup>, Irfan Ali<sup>3</sup>

<sup>1</sup>Institute of Information and Communication Technologies, Mehran University of Engineering & Technology Jamshoro, <sup>2</sup>Department of Electronic Engineering, Mehran University of Engineering and Technology Jamshoro, Pakistan, <sup>3</sup>Department of Electrical Engineering, COMSATS Institute of Information Technology Lahore, Pakistan.

#### Abstract

This article describes the FPGA based implementation of Maximum Power Point Tracking (MPPT) using Perturbation and Observation (P & O) algorithms for solar cell. This work has been organized in two parts. The complete Maximum Power Point Tracking (MPPT) system model was developed in MATLAB/Simulink environment for functionality verification in the first part. It has been observed from the results which show that maximum power is extracted at the load from PV panel. The second part is to design of P & O algorithm from VHDL code. The designed P & O algorithm was synthesized in Xilinx ISE 14.2 software with small commercial FPGA devices i.e. KINTEX-7 and VIRTEX-5. That designed algorithm was simulated using vector waveform file in FPGA tools. Also, the synthesized results were compared on the basis of area-performance-power obtained through summary of both KINTEX-7 and VIRTEX-5 Xilinx FPGA devices. This work is highly beneficial in real time implementation of algorithm for effective performance.

**Key words:** PV Cell; Maximum Power Point Tracking (MPPT); DC-DC boost Converter; P & O tracking algorithm; FPGA Xilinx ISE tool

Corresponding author's email: sm.crashid@gmail.com

### INTRODUCTION

Renewable energy sources have got great importance to meet the high energy demands. The solar energy is one of the important from the non-renewable energy sources (Goma et al., 2014). DC electricity is generated from the solar energy as it falls on the devices called Photovoltaic (PV) cells. Nowadays, PV systems are considered as the most energy solutions because of the advantages like noiseless, recyclable, distributed throughout the earth and abundant. Unfortunately, these systems have some considerable drawbacks for instance their low conversion efficiency and high installation cost (Luppina et al., 2015). The main problem with the PV systems is the non-linearity. These have nonlinear current-voltage (IV) characteristics which vary with change in temperature and irradiance (W/m2). Thus, output power of the PV panel changes nonlinearly throughout the day (Choudhary et al., 2014). Therefore, it is very essential to operate the PV panel at its maximum possible power point (Sridhar et al., 2012). The technique or algorithm that is used to set the PV panel at its maximum point where it delivers maximum power under different environmental conditions is known as the maximum power point tracking (MPPT) (layachi et al., 2014) which is fully electronic. The complete MPPT system can be shown in Figure 1.



Figure 1: MPPT system Model

22



Figure 2: Maximum Power Point Tracking concept

There are many techniques have been discussed in the past literature like Incremental Conductance (IC), Perturb and Observe (P & O), Constant Voltage (Fang et al., 2007), Artificial Neural Network (ANN) (Ravi et al., 2008), Temperature Gradient (TG) (Piegari et al., 2015) and others. Different methods have been used for implementing MPPT algorithms to make MPPT controllers as DSP-based, microcontroller based. Advancement in present day technology paved the way for designers to implement the MPPT controller on programmable IC chips like Field Programmable Gate Array (FPGA).

FPGA has advantages that these are faster than microprocessor or microcontroller due to parallel processing (Y.F Chan et al., 2004). In addition, these have limitless flexible due to their reconfigurable property. These are fit to design the control algorithms however control algorithm designs using DSP's or microcontroller have slow response due to event sequencers or interrupts. Thus, FPGA's are very useful for realizing control designs. FPGAs are programmed through the Hardware Description Languages like VHDL (Very High Speed Integrated Circuit HDL) and Verilog. These have flexibility to be programmed while running process in microseconds. So, this very short period of the time cannot even be sensed by the system that the chip is reprogrammed.

In this paper, P & O algorithm has been developed in FPGA. This research methodology is divided into two parts. The first part includes the design of complete MPPT model in MATLAB/Simulink environment for functionality verification. After that, the second part includes the implementation of P & O algorithm using VHDL/system generator in FPGA and simulation of the design using vector waveform file in FPGA tools. It is also included to analyze the area-performance-power of the system.

#### System Design in Matlab/simulink

Project development of MPPT system in MATLAB involves the modelling of 50W PV panel from its mathematical equations and the mathematical equations are derived from the PV cell electrical equivalent circuit. Furthermore, DC-DC boost converter has been modelled from its schematic diagram with resistive load connected at the output. The tracking algorithm P & O is designed in Matlab function block. Finally, whole system has been tested for functionality verification. Besides, the VHDL code for the P & O algorithm has been synthesized in Xilinx ISE software for FPGA implementation.

#### **PV Cell Modeling**

There are different models of PV cell which are used like single diode, double diode, three diodes model. As a fact above, the one diode model requires only single diode for its construction, two diodes are required for the construction of two diode models and also the three diodes are the requirement of three diodes model. In this project, single diode cell is opted which is constructed from connecting the lighted generated current source in parallel with the single diode.



Figure 3: Single Diode Model of PV cell

To design the PV cell model in SIMULINK, the mathematical modelling and the parameters of the PV model are required. Mathematical modelling of the single diode PV cell is given as:

$$I = Np * Ipv - Np * Id * \left\{ e^{[(q/Ns * A * k * Tak) * (Vo + I * Rs)]} - 1 \right\}$$
(1)

*I* =Output Current of the PV module *Ipv*= *I*<sub>L</sub> = PV module light generated current *Id* = Diode saturation Current *Np*= No. of cells connected in parallel = 1 *Rs* = Series resistance of PV module = 0.45 ohm *Voc*= Open Circuit Voltage *Ns* = No. of cells connected in series =36 *Tak* = Operating temperature of PV module in Kelvin *q* = Electron charge =  $1.6 \times 10^{-19}C$ *A* = Ideality factor = 1.3

Table 1: PV Panel Parameters at 25° C and S= 1000W/m<sup>2</sup>

| Attribute                   | Value  |
|-----------------------------|--------|
| Open Circuit Voltage (Voc)  | 21.8 V |
| Short Circuit Current (Isc) | 3.11 A |
| Power at MPP (Pmp)          | 50 W   |

Above table shows the PV cell parameters and the Simulink model of 50W PV cell can be developed from the characteristics equation as (Figure 4-6).

#### **DC-DC** boost converter modeling

To track the maximum operating point of the PV cell for different temperature and solar irradiance which change throughout the whole day, specific circuits have been introduced in the literature.

The more common circuit used for maximum power point is DC-DC converters placed between source which is PV panel and the load. The DC-DC converter is controlled by the proposed tracking technique. In the past, researches have been done by many scholars mainly in two categories on MPPT. The first category is related to the topology optimization of DC-DC converter. In this, there is a focus on methods to get suitable DC-DC converter to track the maximum point of power (R.F Coelho et al., 2009). The second one is related to the tracking technique which is responsible to operate the DC-DC converter properly to track the maximum power point. Thus, it is need to develop an efficient maximum power point tracking system from the suitable

hardware and software. The hardware is the DC-DC converter whereas, the software refers to the tracking algorithm.

The DC-DC boost converter has been used in this research between the PV panel and the load in order to deliver maximum power at the load. Its construction involves the inductor, capacitor, diode and the active switch like MOSFET or IGBT. The converter with MOSFET has been used for this system. The basic schematic diagram of the DC-DC boost converter is shown on Figure 7-8.



Figure 4: Simulink Model of 50W PV model

PV cell Simulation and Verification



Figure 5: IV curve for 50W PV cell



Figure 6: PV curve for 50W PV cell



Figure 7: DC-DC boost converter

The above given schematic diagram can be used to develop the Simulink model of the converter in Matlab/Simulink environment. The proposed Simulink model in Matlab will be as:





#### Perturb and Observe (P & O) algorithm modeling

P & O is very often used method for the reason that it is easy in implementation and it involves Hill climbing nature therefore, is also called as Hill Climbing method. It requires less number of sensors (Pulkit Singh et al., 2015). In this technique PV cell operating voltage is to be perturbed (increased or decreased) to make the output power maximum. Further, when the voltage from the PV panel is increased and with that power is also increased it shows that point is going towards the MPP. In other case, if the power from PV panel decreases with increase in operating voltage the point must be perturbed in reverse direction (Nicola Femia et al., 2005). Here in this project, MATLAB function block is used to design the P & O algorithm based controller for Maximum Power Point Tracking. The inputs to the controller are current and voltage from the PV panel and output will be the PWM signal. The code can be created by following flow chart of the P & O algorithm.



Figure 9: Flow chart of P & O algorithm

27

### Complete MPPT system modelling and its working

The complete MPPT Model is developed as the DC-Dc boost converter is placed in between the PV panel and the load. PV panel outputs current and voltage are sensed by the current and voltage sensors and then current and voltage are fed into the P & O controller. The PWM signal will be the output of that controller and that generated PWM signal will be fed into the MOSFET of the DC-DC boost converter which sets the PV panel to deliver the maximum power at the load.

The complete MPPT model on MATLAB/SIMULINK has been developed as.



Figure 10. Complete Simulink Model of MPPT system

### **FPGA IMPLEMENTATION OF P & O ALGORITHM**

After the complete model has been modelled on the MATLAB/ Simulink. The P & O algorithm is to be generated in VHDL code. The VHDL code has been synthesized in FPGA and the FPGA will work as MPPT controller. Simply, the design of the algorithm on FPGA include:

- Implement the P & O algorithm using VHDL/system generator in FPGA.
- Simulate the design using vector waveform file in FPGA tools.
- Compute the area-performance and functionality of the design using various small commercial FPGA devices.

In this project, Xilinx ISE tool 14.2 has been selected to design the algorithm. VHDL code for the P & O algorithm has been generated and then it will be synthesized in Xilinx ISE 14.2 software for two Xilinx FPGA devices VIRTEX-5 and KINTEX-7. Both devices will be compared on the basis of performance, power and resource utilization.

## RESULTS

The results of this research has been divided into two parts to verify the developed project. The first results include the simulation results in MATLAB/Simulink environment for functionality verification and the second results are the FPGA results when VHDL code of the P & O algorithm has been synthesized in Xilinx ISE 14.2. Further VHDL code has been synthesized for two Xilinx FPGA devices KINTEX-7 and VIRTEX-5. Finally, the vector waveform for the design has been carried out and also the comparison has been made on the basis of area-performance and power for both FPGA Xilinx devices.

### **MATLAB Simulation results**

Complete model when simulated in MATLAB, the simulation results are as:







29



Figure 14. Collective Power (W), voltage (V) and current (A)

In figure 14 the upper curve shows the Power, middle curve shows the voltage and the current is shown by the bottom curve.

### **FPGA results**

After, the verification of the system, the algorithm P & O is designed for FPGA, for that, the VHDL code of the P & O algorithm is synthesized in Xilinx ISE software.

When the P & O algorithm is synthesized in Xilinx ISE tool, the results are as:

|               | X 🖲 🛯 🖉 👸 🛛                             | 10 38         | 0 0 /<br>0,800 ps | 8 178                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | / 👌 🗠 1   | 11/1        | ] <b>)</b> } <sup>I</sup> 1.002 |                           | elandi      |                   |        |
|---------------|-----------------------------------------|---------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------|---------------------------------|---------------------------|-------------|-------------------|--------|
| lane          | Value                                   | 025           | 00,000 ps         | 21,000 ps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 00,000 ps | H0,000 ps   | 50,000 ps                       | 66,000 ps                 | (70,000 ps  | 180,000 ps        | 90,000 |
| 🖣 (j. n(15))  | 0002010110100011                        | 0001000100100 | 0010101001000     | and the second se | 000000    | 00010101101 | 1100 (0001                      | 1101100 X00010            | 10110100.   | 10000311000001    |        |
| 💐 (Jn(054)    | 000311011011901                         | 0001010110111 | 001110101011      | 0000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 00001118  | 00110001101 | 100 (001                        | 110/10111_ <b>X</b> 00011 | 101100111.X | 00010101110001110 |        |
| 💊 ready_m     | 1                                       |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |             |                                 |                           |             | 5                 |        |
| a di          | 6                                       |               | uru               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | LU        | uu          | սս                              |                           | uu          |                   |        |
| 💐 शर्म (आदिश) | 000000000000000000000000000000000000000 |               | 0000000           | 00000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |             |                                 | ummu                      | 00000       |                   |        |
| eeady_out     | 0                                       |               |                   | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           |             |                                 |                           | -           |                   | _      |
| au            | ¢.                                      |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |             |                                 |                           | 17          |                   |        |
| tqa_qik 🕌     | 0                                       |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           | ·           | Y.                              |                           |             | 1 (               |        |
| av tet        | 0                                       |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           | -           |                                 | -                         |             |                   |        |
| didi_test     | 6                                       |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |             |                                 |                           |             |                   |        |
| 🖣 do_test     | 0                                       |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |             |                                 | -                         |             | 1                 |        |
| 🖣 nppt_dir    | 0.                                      |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |             |                                 |                           |             |                   |        |
| 🐧 dk period   | 5808 gs                                 |               |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           | 500         | 13                              |                           |             |                   |        |

Figure 15: Vector waveform for P & O algorithm verification





RTL is the Register Transfer Level view which describes the pre-optimized design of the synthesized file. It helps the designer to know the issues during the design.

| Resources           | Kintex-7 |       |          |    | Virtex-5  |             |  |  |
|---------------------|----------|-------|----------|----|-----------|-------------|--|--|
|                     | Used     | Avail | Utilizat | Us | Available | Utilization |  |  |
|                     |          | able  | ion (%)  | ed |           | (%)         |  |  |
| No. of Slice LUTs   | 284      | 222,6 | 1        | 21 | 28,800    | 1           |  |  |
|                     |          | 00    |          | 7  |           |             |  |  |
| No. slice registers | 183      | 445,2 | 1        | 19 | 28,800    | 1           |  |  |
|                     |          | 00    |          | 5  |           |             |  |  |
|                     |          |       |          |    |           |             |  |  |
| No. of              | 1        | 1440  | 1        | 1  | 48        | 2           |  |  |
| DSP48A1's/DSP48     |          |       |          |    |           |             |  |  |
| Es                  |          |       |          |    |           |             |  |  |
|                     |          |       |          |    |           |             |  |  |
| Number of Bonded    | 57       | 300   | 19       | 57 | 480       | 11          |  |  |
| IOBs                |          |       |          |    |           |             |  |  |
|                     |          |       |          |    |           |             |  |  |

Table 2: FPGA Resource Utilization

| Device             | Time Delay (ns) |
|--------------------|-----------------|
| KINTEX7-(XC7K335T) | 3.203           |
| VIRTEX5-(XCVLX50T) | 4.667           |

**Table 4:** Power consumption for both FPGA devices

| Power (W) | KINTEX7-(XC7K335T) | VIRTEX5-(XCVLX50T) |  |  |
|-----------|--------------------|--------------------|--|--|
| STATIC    | 0.138              | 0.448              |  |  |
| DYNAMIC   | 0.000              | 0.004              |  |  |
| TOTAL     | 0.138              | 0.452              |  |  |

### CONCLUSION

It is concluded from the designed MPPT model in MATLAB/SIMULINK environment that maximum power approximately 50W is delivered at the load. Further, VHDL code of P & O algorithms has be tested and synthesized in Xilinx ISE 14.2 software where vector waveform has been carried out. Also, the P & O algorithm has been synthesized for both Xilinx FPGA devices KINTEX7-XC7K355T and VIRTEX5-XC5VLX50T which are compared on the basis of area, performance and power for P & O algorithm. After analyzing both FPGA devices, the much better choice on the basis of Area-VIRTEX5- XC5VLX50T Performance- KINTEX7-XC7K355T

#### Power- KINTEX7-XC7K355T

Comparison results show that KINTEX7-XC7K355T is best choice for performance and consuming less power while the VIRTEX5- XC5VLX50T utilizes less resources like number of LUTs, IOB and registers. Future work of the system includes: This system can also be developed by using buck and boost converter operations in order to achieve the different voltage levels as per our desire. Modifications can be made to set the applications of the project where more PV cells or panels are present.

## REFERENCES

- Choudhary D, Saxena AR, (2014). DC-DC Buck Converter for MPPT of PV System. International Journal of Emerging Technology and Advanced Engineering. 4(7):813-821.
- Goma E, Orabi M, Hasaneen ES and Qahouq JA. (2014). Single-output-sensor on-chip integrated MPPT for PV solar system power management. Proceedings of IEEE Applied Power Electronics Conference and Exposition - APEC, Fort Worth, TX, pp. 655-661.
- Fang L, Pengwei X, Yong K, Shangxu D. (2007). A Variable Step Maximum Power Point Tracking Method Using Differential Equation Solution. Proceedings of 2nd IEEE Conference on Industrial Electronics and Applications, Harbin, 2007, pp. 2259-2263.
- Kamath HRS, Aithal RS, Sinha SAK, Danak AR. (2008). Modeling of Photovoltaic Array and Maximum Power Point Tracker Using ANN. Journal of Electrical Systems. 4(3):23.
- Piegari L, Rizzo R, Spina I, Tricoli P. (2015). Optimized Adaptive Perturb and Observe Maximum Power Point Tracking Control for Photovoltaic Generation. Proceedings of Energies Research Journal. pp.

3418-3436.

- Femia N, Petrone G, Spagnuolo G, Vitelli M. (2005). Optimization of Perturb and Observe Maximum Power Point Tracking Method. Proceedings of IEEE Transaction on Power Electronics. 20(4):963-973.
- Luppina P, Lugli P, Goodnick SM. (2015). Modeling of Silicon Heterojunction Solar Cells. Proceedings of IEEE 42nd Photovoltaic Specialist Conference (PVSC). New Orleans, LA, pp. 1-6.
- Singh P, Palwalia DK, Gupta A, Kumar P. (2015). Comparison of Photovoltaic Array Maximum Power Point Tracking Techniques. International Advanced Research Journal in Science, Engineering and Technology (IARJSET). 2(1):401-404.
- Coelho RF, Concer FM, Martins D. (2009). A Study of the Basic DC-DC converter. Proceedings of 10th IEEE Brazilian Power Electronics Conference. Bonito-Mato Grosso do Sul, Brazil. 2009, pp.673-678.
- Sridhar T, Anish KJ. (2012). Development of Solar MPPT System Using Boost Converter with Microcontroller. International Journal of Advanced Research in Electrical, Electronics and Instrumentation Engineering.1(4):334-340
- Chan YF, Moallem M, Wang W. (2004). Efficient implementation of PID control algorithm using FPGA technology. Proceedings of 43rd IEEE Conference on Decision and Control (CDC) (IEEE Cat. No.04CH37601), Nassau, Bahamas, Dec. 2004, pp. 4885-4890.
- Zaghba L, Borni A, Bouchakour A, Terki N. (2014). Buck-Boost Converter System Modeling and Incremental Inductance Algorithm for Photovoltaic System via MATLAB/Simulink. Proceedings of the 2nd International Seminar on New and Renewable Energies. 13 and 14 October 2014, Ghardaia – Algerie pp. 1-6.