

# **Solar PV Inverter**

the thesis submitted by

**Yash Vardhan Omar, Satvik Patel**  
**(Enrollment no: 171020012018, 171020011038)**

in partial fulfillment of the requirements for the award of

**Bachelor of Technology**



**Department of Electrical Engineering  
Institute of Infrastructure Technology Research and  
Management, Ahmedabad, Gujarat-380026.**

June 2021

## **Self declaration**

We declare that this written submission represents our ideas in our own words, and where ideas or words of others have been included, we have adequately cited and referenced the original sources. We also declare that we have adhered to all principles of academic honesty and integrity and have not misrepresented or fabricated or falsified any idea/data/fact/source in my submission. We understand that any violation of the above will be a cause for disciplinary action by the Institute and can also evoke penal action from the sources that have thus not been properly cited, or from whom proper permission has not been taken.

Place:

Signature(s):

Date:

Yash Vardhan Omar, Satvik Patel

(171020012018, 171020011038)

## Approval sheet

The thesis entitled "**Solar PV Inverter**" submitted by **Yash Vardhan Omar, Satvik Patel** is the outcome of the work done during the academic period 2020-2021 under my supervision for the partial fulfilment of the requirements for the award of degree of **Bachelor of Technology**. The extent of similarity content found in this submission is acceptable for me.

Place: Ahmedabad

Name of the supervisor: Dr. Priyesh Chauhan

Date: June 2021

Signature:

The examination committee hereby approves that the thesis entitled "**Solar PV Inverter**" submitted by **Yash Vardhan Omar, Satvik Patel** can be considered for submission in the department of Electrical Engineering at Institute of Infrastructure Technology Research and Management, Ahmedabad.

**Name of the supervisor:** Dr. Priyesh Chauhan

**Affiliation:** Dept. of Electrical Engineering, IITRAM, Ahmedabad

**Signature with date:**

**Name of the examiner-1:** Dr. Manjunath K

**Affiliation:** Dept. of Electrical Engineering, IITRAM, Ahmedabad

**Signature with date:**

**Name of the examiner-2:** Dr. Kshitij Bhargava

**Affiliation:** Dept. of Electrical Engineering, IITRAM, Ahmedabad

**Signature with date:**

## **Acknowledgements**

We would like to thank our supervisor, Dr. Priyesh Chauhan, who provided us the opportunity to work on this project. Your insightful feedback pushed us to sharpen our thinking and brought our work to a higher level. This Project helped us to gain more knowledge in the field of solar inverter and micro-controller. We would also like to thank Tejas Sir for helping us in this project.

## **Dedication**

Dedicated to the almighty

## **Abstract**

Due to the increasing demand of renewable energy as a source of electricity, especially the solar energy, there arise a need to have a system that would work for both the on-grid and off-grid solar application , i.e., work as a hybrid system. The Project features a system that would control the flow of the power generated from PV module to the grid, household load and the battery system, depending on whether the grid is on-line or off-line, the battery needs charging or not. It has a MPPT and a PLL attached to it, which helps the system generate the maximum power possible and allows it to get connected with the grid. The SRF-PLL shown has been tested for a grid with variable frequency, phase and amplitude. It is also tested for a signal with harmonics that are usually found in the Indian transmission/distribution network. The efficiency of the MPPT and PLL approach is tested on off-line MATLAB Simulink and its implementation was tried on STM micro-controller.

# Contents

|                                                           |           |
|-----------------------------------------------------------|-----------|
| Declaration . . . . .                                     | ii        |
| Approval sheet . . . . .                                  | iii       |
| Acknowledgements . . . . .                                | iv        |
| Abstract . . . . .                                        | vi        |
| <b>1 Introduction</b>                                     | <b>1</b>  |
| 1.1 Increasing demand of solar energy . . . . .           | 2         |
| 1.2 Brief on Off and On Grid Solar PV programme . . . . . | 2         |
| 1.2.1 Off-grid Solar PV Programme . . . . .               | 2         |
| 1.2.2 On-grid Solar PV Programme . . . . .                | 3         |
| <b>2 Solar Energy</b>                                     | <b>4</b>  |
| 2.1 What is Solar energy ? . . . . .                      | 4         |
| 2.2 Working of Solar cell. . . . .                        | 4         |
| 2.3 Electrical Modelling of solar cell. . . . .           | 5         |
| 2.4 MATLAB Simulink model of Solar cell . . . . .         | 6         |
| <b>3 Inverter</b>                                         | <b>9</b>  |
| 3.1 Working of Inverter . . . . .                         | 9         |
| 3.2 Types of Solar PV Inverter . . . . .                  | 11        |
| 3.3 MPPT . . . . .                                        | 12        |
| 3.4 Methods to establish MPPT . . . . .                   | 13        |
| 3.5 MATLAB Simulink model of Inverter . . . . .           | 15        |
| <b>4 Controller Part of Inverter</b>                      | <b>17</b> |
| 4.1 STM32F407VG Discovery Board . . . . .                 | 17        |
| 4.2 Wajung Blockset . . . . .                             | 19        |
| 4.3 Proposed Plan . . . . .                               | 19        |
| 4.4 Proposed method . . . . .                             | 20        |
| 4.5 Methodology . . . . .                                 | 21        |
| 4.5.1 Working Strategy . . . . .                          | 22        |
| <b>5 Inverter-Grid Synchronisation</b>                    | <b>26</b> |
| 5.1 Phase Locked-Loop(PLL) . . . . .                      | 26        |

|                   |                                                                                                             |           |
|-------------------|-------------------------------------------------------------------------------------------------------------|-----------|
| 5.1.1             | Synchronous Reference Frame PLL (SRF-PLL) . . . . .                                                         | 28        |
| 5.1.2             | Generation of Alpha and Beta signals . . . . .                                                              | 31        |
| 5.2               | The MATLAB Simulink model and simulations for SRF-PLL . . . . .                                             | 32        |
| 5.2.1             | Simulation with a constant sinusoidal input signal (Input signal without disturbances) . . . . .            | 33        |
| 5.2.2             | Simulation with step variation of Frequency, Phase and Amplitude (Input signal with disturbances) . . . . . | 33        |
| 5.2.3             | Simulation with Harmonics in the input signal . . . . .                                                     | 37        |
| 5.3               | Code generation for STM32F4 discovery board . . . . .                                                       | 38        |
| <b>6</b>          | <b>Conclusion</b>                                                                                           | <b>42</b> |
| <b>Appendices</b> |                                                                                                             | <b>43</b> |
| <b>A</b>          | <b>Wajung Models</b>                                                                                        | <b>44</b> |
| <b>B</b>          | <b>STM codes</b>                                                                                            | <b>46</b> |
| B.1               | Code for controlling switching of on/off for path P1 and P2 . . . . .                                       | 46        |
| B.2               | Code for MPPT . . . . .                                                                                     | 48        |
| B.3               | Code for Glowing LED for an infinite period. . . . .                                                        | 50        |
| B.4               | Code for making LEDs blink automatically . . . . .                                                          | 51        |
| B.5               | Code for making all four LEDs glow one after the other . . . . .                                            | 52        |
| B.6               | Code for Making LED switch on/off by pressing switch. . . . .                                               | 54        |
| <b>C</b>          | <b>SRF-PLL Codes</b>                                                                                        | <b>57</b> |
| C.1               | MATLAB Function block code . . . . .                                                                        | 57        |
| C.1.1             | Step variation of freqeucy, phase and Amplitude . . . . .                                                   | 57        |
| C.2               | Model Files . . . . .                                                                                       | 57        |
| C.3               | Utility Files . . . . .                                                                                     | 65        |
| C.4               | Other Files . . . . .                                                                                       | 67        |
| <b>D</b>          | <b>SRF-PLL simulink block parameter and configurations</b>                                                  | <b>72</b> |

# List of Figures

|     |                                                                                     |    |
|-----|-------------------------------------------------------------------------------------|----|
| 2.1 | Schematic representation of Solar Cell (adapted from [1, 2]) . . . . .              | 5  |
| 2.2 | Simplified Circuit Model of a Solar Cell . . . . .                                  | 5  |
| 2.3 | I-V characterstics for different value of irradiation (adapted from [3]) . . . . .  | 6  |
| 2.4 | I-V characaterstics for different value of temperature (adapted from [3]) . . . . . | 6  |
| 2.5 | Simulink model of a solar cell . . . . .                                            | 7  |
| 2.6 | I-V characterstics for different value of Intensity . . . . .                       | 7  |
| 2.7 | I-V characterstics for different value of temperature. . . . .                      | 8  |
| 3.1 | Single phase Full-bridge inverter . . . . .                                         | 10 |
| 3.2 | Gate pulse for stitches in inverter . . . . .                                       | 10 |
| 3.3 | Full-bridge inverter output . . . . .                                               | 11 |
| 3.4 | P&O method algorithm . . . . .                                                      | 13 |
| 3.5 | Incremental Conductance method algorithm . . . . .                                  | 14 |
| 3.6 | Final model of Inverter . . . . .                                                   | 16 |
| 3.7 | Output of Inverter . . . . .                                                        | 16 |
| 4.1 | STM Discovery Board (adapted from [4]) . . . . .                                    | 18 |
| 4.2 | STM32F407VGT6 Micro-controller (adapted from [4]) . . . . .                         | 18 |
| 4.3 | Flow Diagram of our proposed plan for Hybrid Inverter System . . . . .              | 20 |
| 4.4 | Flow Diagram of our proposed method for Hybrid Inverter System . . . . .            | 21 |
| 4.5 | STM Discovery board with input and outputs. . . . .                                 | 21 |
| 4.6 | Simulink model for MPPT . . . . .                                                   | 23 |
| 4.7 | Model for path P4. . . . .                                                          | 23 |
| 4.8 | Algorithm for Controlling path P1 and P2 . . . . .                                  | 24 |
| 4.9 | Algorithm for MPPT. . . . .                                                         | 25 |
| 5.1 | PLL Block diagram . . . . .                                                         | 27 |
| 5.2 | SRF-PLL Block diagram . . . . .                                                     | 28 |
| 5.3 | Reference frames along with signal . . . . .                                        | 29 |
| 5.4 | Simulink model for generating Alpha Beta signals . . . . .                          | 31 |
| 5.5 | Alpha beta signals . . . . .                                                        | 32 |
| 5.6 | SRF-PLL MATLAB Simulink model . . . . .                                             | 33 |
| 5.7 | Constant Sinusoidal signal ( $220 \sin 2\pi 50$ ), ideal case output . . . . .      | 34 |
| 5.8 | Simulink model for Step variation of frequency . . . . .                            | 34 |

|      |                                                                          |    |
|------|--------------------------------------------------------------------------|----|
| 5.9  | Input for step variation of frequency . . . . .                          | 35 |
| 5.10 | Alpha beta signals generated for variation of frequency (50hz) . . . . . | 35 |
| 5.11 | Alpha beta signals generated for variation of frequency (51hz) . . . . . | 36 |
| 5.12 | output with Step variation of frequency . . . . .                        | 36 |
| 5.13 | Simulink model for Step variation of Phase . . . . .                     | 36 |
| 5.14 | Input for Step variation of Phase . . . . .                              | 37 |
| 5.15 | Alpha beta signals generated for variation of Phase . . . . .            | 37 |
| 5.16 | output with Step variation of Phase . . . . .                            | 38 |
| 5.17 | Simulink model for Step variation of amplitude . . . . .                 | 38 |
| 5.18 | Input for Step variation of Amplitude . . . . .                          | 39 |
| 5.19 | Alpha beta signals generated for variation of Amplitude . . . . .        | 39 |
| 5.20 | output with Step variation of Amplitude . . . . .                        | 40 |
| 5.21 | Simulink model for a signal with Harmonics . . . . .                     | 40 |
| 5.22 | Input signal: Harmonics injected signal . . . . .                        | 40 |
| 5.23 | Output for the signal with Harmonics . . . . .                           | 41 |
| A.1  | Model for turning on LED by giving input to pin PA5 . . . . .            | 44 |
| A.2  | Model for turning on/off led repeatedly. . . . .                         | 45 |
| A.3  | Model for switching on/off led by pressing switch. . . . .               | 45 |
| D.1  | $\alpha\beta$ 0 to DQ0 block . . . . .                                   | 72 |
| D.2  | low pass filter used in generation of alpha beta signals . . . . .       | 73 |
| D.3  | Integrator . . . . .                                                     | 73 |
| D.4  | fcn block (cos) . . . . .                                                | 74 |
| D.5  | PI controller . . . . .                                                  | 74 |
| D.6  | STM32CubeMX model configuration file . . . . .                           | 75 |
| D.7  | Code generation parameters . . . . .                                     | 75 |

# List of Tables

|     |                                                            |   |
|-----|------------------------------------------------------------|---|
| 1.1 | Number of units of off-grid solar pv applications. . . . . | 3 |
| 1.2 | Cumulative capacity of on-grid solar power. . . . .        | 3 |

# Chapter 1

## Introduction

The world's consumption of electrical energy is increasing at a rapid rate. This increase has an impact on both developing and developed countries, as well as causing environmental issues. We live in a time when new power generation solutions are desperately needed; sources that are cleaner and more sustainable than traditional energy power plants that use oil, gas, and uranium. Renewable energy sources such as wind, geothermal, and photovoltaic energy are largely used in the solutions [5]. Electric power has been generated using energy from renewable natural resources such as solar, wind, rainfall, tidal, geothermal heat, and so on. Renewable energy (RE) sources have the following major advantages over conventional fossil energy sources (coal, oil, and natural gas): (1) they are refilled from natural resources; thus, they are sustainable and will never run out; (2) They emit very little or no carbon dioxide when they generate. To summarize, Renewable energy (RE) appears to be the most ideal and effective solution for dealing with environmental issues [6].

Renewable Energy (RE) is seen as a critical and long-term solution to both transportation and power generating problems because the traditional energy is currently experiencing a depletion issue, and environmental contamination is on the rise. Rapid economic expansion necessitates the exploration, development of renewable energy sources. Solar energy has become a focused area as a type of new energy due to its in-exhaustible nature, safety, and cleanliness [7, 8]. Photovoltaic energy or the solar energy is one of the renewable energy sources that is also environmentally friendly. Despite the large distance between the sun and the earth (150,106 km), the terrestrial layer receives a significant amount of energy from the sun (180,106 GW), which is sufficient to meet the world's energy need [9]. Photovoltaic systems can be self-contained (water pumping, electric vehicles, public lighting, etc.) or grid-connected (power plants) [5].

Photo voltaic (PV) system can be used for obtaining the electricity by passing the DC supply from PV system through a inverter which would convert the incoming DC to AC which now can be utilised for fulfilling the electrical needs of world. Making maximum power point tracker (MPPT) is very much essential for this because the maximum power point (MPP) of a photo voltaic (PV) system fluctuates with changing climatic conditions

(such as irradiance and temperature), so tracking the MPP accurately is an essential concern in the design of efficient PV systems [10].

In this Project work on solar pv inverter is done along with some controlling part like maximum power point tracker (MPPT), controller for switching on/off the supply between the pv module, grid, household load and the battery system, controller for phase locked loop (PLL). It has been tried to implement the same on the STM32F4 discovery board. Process of implementing the above mentioned ideas on STM32F4 discovery board is done using the wajung blockset and STM coding.

## 1.1 Increasing demand of solar energy

In recent years, the solar power business in India has emerged as a rapidly growing sector. It promotes the government's objective of long-term prosperity while also establishing itself as an important contributor to meeting the country's energy demands and a key role in ensuring energy security. Millions of people in Indian communities have profited from solar energy-based decentralized and distributed applications that satisfy their cooking, energy demands in a friendly manner. Reduced drudgery among rural women and girls involved in long-distance fuel wood collecting and cooking in smoky kitchens are among the social and economic benefits [11].

Country's solar potential of about 748 GW assuming 3 percent of the waste land area to be covered by Solar PV modules is assessed by the national institute of solar energy. National solar mission (NSM) is one of major mission in making solar energy take a central place in India's national plan towards climate change .This mission was launched on 11th January, 2010. Objective of this mission is to establish India as an international leader in solar energy by making effective policies for diffusion of solar technology across the country as quickly as possible. It targets of installing 100 GW solar plants which are grid connected by the year 2022. It is in line with INDC target to fulfil 40 % amassed electric power from renewable energy resources and to decrease the emission intensity of its GDP by 33 to 35 percent from 2005 level by 2030 [11].

## 1.2 Brief on Off and On Grid Solar PV programme

### 1.2.1 Off-grid Solar PV Programme

It is one of the oldest programme of ministry aimed to provide solar energy in areas where grid power is not proper or on which one cannot depend fully. A target of acheiving 2000 MWp for off-grid solar pv applications was kept under the NSM scheme. Off-grid applications includes solar home lighting systems, solar pumps, solar study lamps, solar power plants etc [12]. The number of units of off-grid solar pv applications installed up till 2018-19 is shown in Table 1.1.

Table 1.1: Number of units of off-grid solar pv applications.

| <b>System</b>           | <b>No. of units/capacity installed</b> |
|-------------------------|----------------------------------------|
| Solar Lantern/ Lamp     | 5823800                                |
| Solar Home lighting     | 1715214                                |
| Solar street light      | 659218                                 |
| Solar Pump              | 237120                                 |
| Solar stand alone (KWp) | 212054.2                               |

### 1.2.2 On-grid Solar PV Programme

100 GW of grid connected solar power has been put as a target to achieve it by 2022. Government of India (GOI) has formulated many policies and launched many schemes to encourage the generation of solar power in India so that it achieves the target by 2022. Some of the schemes are solar park scheme, CPSU scheme, canal top scheme and many more. India has achieved 5th rank for solar power development in the world [13]. The cumulative capacity of on-grid solar power from year 2015-19 is shown in Table 1.2.

Table 1.2: Cumulative capacity of on-grid solar power.

| <b>Sr. No.</b> | <b>Year</b> | <b>Capacity added during F.Y (MW)</b> | <b>Cumulative capacity (MW)</b> |
|----------------|-------------|---------------------------------------|---------------------------------|
| 1              | 2015-16     | 3018.88                               | 6762.87                         |
| 2              | 2016-17     | 5525.98                               | 12288.85                        |
| 3              | 2017-18     | 9362.63                               | 21651.48                        |
| 4              | 2018-19     | 6529.20                               | 28180.68                        |

# **Chapter 2**

## **Solar Energy**

### **2.1 What is Solar energy ?**

Solar energy is the heat from the Sun that can be captured using a variety of technologies including solar heating, solar thermal energy, photovoltaics, solar architecture, artificial photosynthesis and molten salt power plants. It is an important source of renewable energy, and depending on how it captures and distributes solar energy or converts it to solar power, its technologies are classified as passive or active solar.

To harness the energy, active solar solutions include photovoltaic systems, solar water heating and concentrated solar power. Orienting a structure to the Sun, selecting materials with light dispersing qualities or favorable thermal mass and creating rooms that naturally circulate air are all examples of passive solar approaches [14].

### **2.2 Working of Solar cell.**

Alexandre-Edmond Becquerel was the first one to observe the photo-voltaic effect in 1839 [15]. The first modern solar cell was made in 1946 by Russel Ohl and was made of silicon [15, 16]. The photo-voltaic technology is based on principle of electron-hole pair creation in the cell. The cell is composed of two layers consisting of p-type and n-type material as shown in Figure 2.1.

The layer with excess of electrons and deficiency of holes is the n layer and the layer with excess of holes and deficiency of electrons is the p layer. Whenever the sun rays fall on the surface of solar cell, a current starts flowing from the p layer to the n layer due to movement of electrons and holes, thus powering the load. Between the p and n layer a depletion region also called P-N junction is formed due to combination of minority charge carriers (electrons in case of p layer and holes in case of n layer). The width of depletion region affects the current flow because a strong electric field will develop in the depletion region due to more combination of holes and electron which will oppose current flow.



Figure 2.1: Schematic representation of Solar Cell (adapted from [1, 2])

## 2.3 Electrical Modelling of solar cell.

Solar cell can be represented in the form of a electric circuit as shown in the Figure 2.2. The solar cells are semiconductor devices that resembles the characteristics of a diode. The value of  $I_o$  and  $V_o$  is approximately 1 to 3 amps and 0.5 volt respectively.

The output current and voltage of the solar cell gets affected due to the change in irradiance (intensity of light rays falling) and temperature. The I-V characteristics of the cell at various values of irradiance and temperature is shown in the Figure 2.3, 2.4 respectively. In Figure 2.3 current (I) has a considerable change as the value of irradiance (G) changes whereas in Figure 2.4 voltage has a considerable change due to change in temperature. As the irradiance decreases the current output from the solar cell also decreases and as the temperature decreases, output voltage of the solar cell increases. So in order to obtain maximum power from the solar cell, the operation of solar cell needs to be done at maximum power point (MPP) shown in Figure 2.3 and 2.4.



Figure 2.2: Simplified Circuit Model of a Solar Cell



Figure 2.3: I-V characteristics for different value of irradiation (adapted from [3])



Figure 2.4: I-V characteristics for different value of temperature (adapted from [3])

## 2.4 MATLAB Simulink model of Solar cell

The simulink model of solar cell is developed and shown in Figure 2.5. The I-V characteristics of the solar cell made in simulink is shown in Figure 2.6 and 2.7. Thus results of Figure 2.3, 2.4 were practically verified .



Figure 2.5: Simulink model of a solar cell



Figure 2.6: I-V characteristics for different value of Intensity



Figure 2.7: I-V characteristics for different value of temperature.

# Chapter 3

## Inverter

In the middle of 19<sup>th</sup> to 20<sup>th</sup> century , the direct current (dc) was converted to alternating current (ac) with the help of motor generator sets (MG sets) and rotary converters. Vacuum tubes as well as gas-filled tubes were used as switches in inverter circuits in the early 20th century [17]. An inverter can be defined as device which converts the DC to AC voltage. The inverter is a fixed piece of equipment. It has the ability to transform one type of electrical power into another. However, it is unable to create electricity. As a result, the inverter is a converter rather than a generator. Inverter plays a very crucial role in human's life. For example, a house has a number of equipment which works on 230V AC supply. When the electricity goes off, then the power supply can be provided using an Inverter and a battery system or an Inverter and PV module system or a mixture of both, i.e., it may be used as a stand-alone device for solar or backup power for house appliances.

### 3.1 Working of Inverter

The basic model of inverter consist of the dc voltage source as input, switches like IGBT, Thyristor, Mosfet etc., control circuit for controlling the gate pulse of the switches. The number of switches, such as IGBT, Thyristor, mosfet, depends on the type of inverter. The very basic model of inverter, the single phase full-bridge circuit is shown in Figure 3.1.

The diodes connected anti-parallel to the switches are called flyback diodes. There is no need to connect diode D1, D2, D3, D4, if the load is fully resistive since the output voltage and current are always in phase. However, for non-purely resistive loads, the load current ( $i_o$ ) will not be in phase with the load voltage ( $V_o$ ). When the main switch is switched off, the diode linked in anti-parallel with the switch will enable current to flow. When these diodes conduct, the energy is transmitted back to the DC source, which is why they are known as flyback diodes (D1, D2, D3, D4).

The successive triggering of switches set diagonally opposite is the operating concept of a single phase full bridge inverter, most commonly thyristor is used as a switching



Figure 3.1: Single phase Full-bridge inverter



Figure 3.2: Gate pulse for switches in inverter

device. This indicates that switches T3 and T4 will be triggered for half of the time period, while T1 and T2 will be triggered for the other half. In half of the time, just two switches are switched on.

Gate pulse waveform is seen in Figure 3.2. It is observed that switches S1 and S2 are activated at the same moment for a period of time  $T/2$ . As a result of S1 and S2 connecting the load to the source, the load voltage is equal to the source voltage with positive polarity. This is why the load voltage in the output voltage waveform is positive and equal to  $V_s$ .

S1 and S2 are switched off as soon as the gate signals ( $i_{g1}$  and  $i_{g2}$ ) are withdrawn.



Figure 3.3: Full-bridge inverter output

Consequently, S3 and S4 are switched on at the same time as gate signals ( $i_{g3}$  and  $i_{g4}$ ) are applied. The load is linked to the source while S3 and S4 are conducting. The load voltage is again  $V_s$ , but this time with opposite polarity. The output voltage is presented as negative in the voltage waveform because of this.

In conclusion, Switches S1 and S2 conduct for the duration  $0 < t \leq T/2$ , and the load voltage  $V_o = V_s$ . Switches S3 and S4 conduct for time  $T/2 < t \leq T$ , and load voltage  $V_o = -V_s$ .

## 3.2 Types of Solar PV Inverter

A solar inverter, also known as a PV inverter, is an electrical converter that converts a photovoltaic (PV) solar panel's variable direct current (DC) output into a alternating current (AC) with a particular frequency that can be fed into a electrical grid or used by a local user. Maximum power point tracking and anti-islanding prevention are two features that solar power converters have developed for use with photovoltaic arrays. The following are the several types of inverters:

1. **Off-Grid Inverters** : Off-grid inverters, which are sometimes also called stand-alone inverters, do not require that a solar panel be connected to them. Instead, they get DC power from batteries that are charged by solar panels or other sources including motor generators, hydro turbines, and wind turbines. Anti-islanding protection is not required as these inverters are separated from utility grids. Furthermore, they are unable to feed extra solar energy to the grid. In isolated places or when individuals prefer to live fully off the grid, off-grid inverters are useful [18].
2. **Grid Tied Inverters** : Grid-tied inverters are hooked to the utility grid and operate

by matching their frequency to that of the sine wave on the utility grid. For safety concerns, they are intended to shut down automatically in the case of a power outage. As a result, they are unable to provide electricity during a blackout. Central plant inverter systems, string inverter systems, multi-string inverter systems, and micro grid inverter (AC modules) systems are the four types of grid-integrated solar PV inverters available today [18].

3. **Battery-Hybrid Inverters** : These are a hybrid of the previous two inverters, allowing one to be mainly self-sufficient while still being able to connect to the grid in the event of low solar or heavy usage days. Inverters of this type often charge the coupled with a battery first, then export any extra power to the grid. Similarly, during nights/cloudy days, these inverters are adaptive enough to utilise the stored power for consumption first, then recharge the battery via the grid when a specific criterion has been reached. They must be equipped with anti-islanding protection due to grid-syncing. These are an excellent alternative for Indian consumers, but many utilities are reluctant to provide a net-metering connectivity to these hybrid inverters, and the legislation around them are opaque [18].
4. **String Inverters** : This is the most typical solar inverter for clients, such as Household and commercial users. These are directly linked to the grid and, in most cases, do not have a backup battery. They're high performance inverters with a 25-year design life and a 5-year guarantee, on average. The best inverters convert DC to AC at a rate of 97–99 percent. On the ground, the less advanced ones will only convert roughly 90-92 percent. Typically, the price and ease of maintenance differences are mirrored in the performance difference [18].
5. **Micro Inverter** : Microinverters are smaller than ordinary string inverters in terms of size and capacity. For residential applications, the latter is often between 1.5 and 5kW, while the former is often between 200 and 350W. These, unlike string inverters, do not require an array of panels to convert DC. These are mounted on the back of each panel and are in charge of converting the panel to which they are attached. These are a little more expensive, but they're excellent for regions with partial shadowing. These are also known as grid-connected or on-grid inverters [18].
6. **Central Inverter** : Inverters like this are frequently seen in MW-scale facilities. They're enormous, with their own quarters, exhaust, and so on. They are extremely efficient and contain a lot more grid-related functionality, such as balancing and fluctuation control. Unlike string inverters, they normally start at 400KW [18].

### 3.3 MPPT

A solar cell can operate over a wide range of voltage and current. A monocrystalline silicon solar cell at a temperature of 25°Celcius may produce 0.60 volts open circuit voltage ( $V_{oc}$ ).

On a full sunny day the cell temperature will probably be close to 45°Celcius even though the air temperature is 25°Celcius thus reducing the output of solar cell to 0.55 volts per cell. Maximum power is generally produced with 75-80 % of open circuit voltage ( $V_{oc}$ ) and approximately 90 % of the short circuit current [3]. The maximum power is obtained by tracking the maximum power point by the help of maximum power point tracker (MPPT). The MPPT, based on the output current and voltage of solar cell tracks the maximum power point.

### 3.4 Methods to establish MPPT

There are various methods to develop MPPT algorithms. Every method has its own advantage and its disadvantage. These methods are listed below as:

#### 1. Perturbation and observation (P&O) method:

The algorithm for this method is shown in Figure 3.4. This method compares the output power of the solar cell with the previous sample value. The advantage of P&O algorithm is its simple nature of algorithm. If the solar radiation does not deviate at a fast rate then the results provided by this method are appropriate [19].



Figure 3.4: P&O method algorithm

## 2. Incremental Conductance method

The algorithm for incremental conductance is shown in Figure 3.5. This method works if  $dP/dV$  is equal to zero because at maximum power point (MPP) the derivative of power is zero, if  $dP/dV$  is greater than zero it results in the left area of MPP curve and if  $dP/dV$  is less than zero it results in the right area of MPP curve.  $dP/dV$  can also be expressed as:

$$\frac{dP}{dV} = \frac{dIV}{dV} \cong I + V \frac{\Delta I}{\Delta V} \quad (3.1)$$

For MPP, putting  $\frac{dP}{dV} = 0$ , gives

$$I + V \frac{\Delta I}{\Delta V} = 0 \quad (3.2)$$

In extremely variable condition this algorithm works more accurately and it oscillates very less around MPP as compared to P&O method. The only disadvantage is the complexity of this algorithm.



Figure 3.5: Incremental Conductance method algorithm

## 3. Constant Voltage method

It is one of the simplest algorithm for making MPPT. This method cannot practically find MPP because in this method the operating point is fixed approximately equal to the MPP by setting solar's output voltage. Vref is then regulated to the voltage corresponding to maximum power point Vmpp. This method requires pre collection of data for a constant Vref [19].

#### 4. Fractional Open-Circuit Voltage (FOCV) method

In this method MPP is calculated using the equation given below:

Let voltage at maximum power point be  $V_{max}$  then,

$$V_{max} \approx M_{oc} * V_{oc} \quad (3.3)$$

where  $M_{oc}$  takes value in the range of 0.78-0.92 and its value can be obtained by a detailed analysis of irradiation and temperature values. In this method the load side is open circuited for a very small time and voltage  $V_{oc}$  is measured and then by using the above equation the  $V_{max}$  is calculated. This method is easy to implement but it can never attain MPP [19]

### 3.5 MATLAB Simulink model of Inverter

The simulink model of the inverter is shown in Figure 3.6 and the output of this inverter is shown in the Figure 3.7. MPPT is prepared using the P&O method which generates the gate pulse for the DC-DC boost converter. The DC-AC Converter works on the basis of pulse width modulation (PWM) technique.



Figure 3.6: Final model of Inverter



Figure 3.7: Output of Inverter

# Chapter 4

## Controller Part of Inverter

### 4.1 STM32F407VG Discovery Board

This discovery board is based on STM32F407VGT6 and has an inbuilt ST-Link/V2 debug tool interface, ST MEMS digital microphone, ST MEMS digital accelerometer, LEDs, push buttons, audio DAC with integrated class D speaker driver, USB OTG micro-AB connector. The discovery board is shown in the Figure 4.1. It is a low-cost device [4]. The development tool chain that supports the STM discovery board are

1. Altium, Tasking VX Toolset
2. Atollic True studio
3. IAR, EWARM
4. Keil, MDK-ARM

It has following features:

1. Two Push buttons.
  - B1 User: Connected to PA0 of microcontroller. It is blue in colour.
  - B2 Reset: It is connected to NRST and resets the microcontroller. It is black in colour.
2. Eight LEDs each for different purpose.
  - LD1 COM: It's default status is red. It turns green to show the communication is happening between PC and board.
  - LD2 PWR: It shows red colour which means that the board is getting power.
  - User LD3: It is an orange LED connected to pin PD13 of the microcontroller.
  - User LD4: It's a green LED conected to PD12 of microcontroller.
  - User LD5: It's a red LED connected to PD14 of microcontroller

- User LD6: It's a blue LED connected to PD15 of microcontroller.
- USB LD7: It's a green LED connected to PA9 of microcontroller which indicates the presence of VBUS on CN5.
- USB LD8: It's a red LED that is connected to PD5 of microcontroller that shows the overcurrent from VBUS of CN5.

3. It has 1MB of flash memory and 192 KB of RAM in a LQFP100 Package.

This discovery board is designed with the STM32F407VGT6 microcontroller in a 100-pin LQFP package. This microcontroller is a ARM Cortex-M4 32-bit unit with FPU having 210 DMIPS. The microcontroller is shown in Figure 4.2. The power supply is provided either by the PC which is connected to discovery board through a USB cable or by an external supply of 5V.



Figure 4.1: STM Discovery Board (adapted from [4])



Figure 4.2: STM32F407VGT6 Micro-controller (adapted from [4])

## 4.2 Waijung Blockset

It is a simulink blockset or a library in simulink which makes it easier for generating a C code from the simulink model for a number of microcontrollers. This library currently provides a path to support the generation of C codes for STM32F4 microcontrollers. It supports all the microcontrollers that belong to the family of STM32F4 [20].

## 4.3 Proposed Plan

As this project aimed towards making a hybrid model of inverter system that would behave as an On-grid and Off-grid system depending on the availability of the electricity supply from the grid, there was a need to have a control strategy that would regulate the working of hybrid system. Therefore a flow strategy of the controller part is thought and is shown in Figure 4.1.

In the Figure 4.1 we can see that PV module gets the sun rays from the sun and it converts the solar energy into electrical energy. This DC form of energy from PV module is fed to DC-DC Boost converter which further goes to DC-AC converter to get AC form of electric energy. The output of DC-AC converter has three paths to flow as shown in figure 4.1, the paths are:

- 1) Path (P1) : From DC-AC converter to Grid.
- 2) Path (P2) : From DC-AC converter to household load.
- 3) Path (P3) : From DC-AC converter to battery system via AC-DC converter.

The path P4 takes output of PV module and based on it controls the output of DC-DC converter so that the hybrid model works at maximum power point (MPP).

Motive was to regulate the working of hybrid system by controlling the closing and opening of these path (P1, P2, P3) based on whether the grid supply is there or not. The plan states that if grid supply is on then the path P1 will be closed i.e.. the power from DC-AC converter will go directly to the grid while path P2, P3 will be Open. On the other hand if grid supply is Off then the path P1 will be open and path P2 will be closed i.e.. the power from DC-AC converter will be fed to household load. The path P3 will get closed depending on the state of charge of battery i.e.. if battery is uncharged or low charged then the path P3 will get closed. The path P4 will always remain closed to ensure system works at MPP.



Figure 4.3: Flow Diagram of our proposed plan for Hybrid Inverter System

## 4.4 Proposed method

STM32F407VG discovery board is used here for implementing these control strategies. Help of wajung blockset [20] and STM coding using Atollic true studio for STM32 [21] is taken for the same. Flow diagram for the proposed method is shown in Figure 4.4

The inputs to the micro controller are from the grid via voltage sensing circuit, voltage and current of pv module through sensing circuit. The STM board is shown in Figure 4.5 with the inputs and outputs.



Figure 4.4: Flow Diagram of our proposed method for Hybrid Inverter System



Figure 4.5: STM Discovery board with input and outputs.

## 4.5 Methodology

To begin this project, study of STM32F4 discovery board was done in detail. After getting sufficient background knowledge of STM32F4 discovery board, study on wajung blookset was done in detail and its few pre-built models provided by wajung library were

tested on discovery board. The models are shown in Appendix A. This Testing was done after the proper connection was established between the STM32 discovery board and the computer. This connection was done by downloading few softwares like ST-Link [22], ST-Link\_USB\_V2\_1\_Driver, keil MDK-ARM version for proper running of discovery board. Various models were made using wajung blookset for the controller part for the proposed hybrid system but there were some errors in it and because of which the plan of controlling the path P1, P2, P3 was not satisfied fully.

For path P4, controller (MPPT) was built in MATLAB simulink as shown in Figure 4.6. It was not made using wajung blookset. After all these attempts new approach was used which was to build codes for STM micro controller and which was done using atollic true studio for STM32. Few basic codes were made in order to understand the STM coding, which are shown in Appendix B. Algorithm for MPPT is shown in Figure 4.9 and the exact code can be seen in Appendix B. Algorithm for controlling the path P1 and P2 is shown in Figure 4.8 and the exact code can be seen in Appendix B. PLL was also prepared which will be discussed later in this report in detail.

For path P3 mentioned in Figure 4.3, a small simulink model for the same has been thought of which is shown in Figure 4.7.

#### 4.5.1 Working Strategy

All the codes would be uploaded in the STM discovery board. Relay are the switches that gets closed or open depending on the signal received by it through the signal pin. If the input to the signal pin is high then the relay will get closed and if the input to the signal pin is low then the relay will get open. The code for controlling the opening and closing of path P1 and P2 will take voltage of grid as input labelled as “V of Grid” as shown in Figure 4.5. Based on code if the voltage of grid is some positive quantity then the microcontroller will send a high pulse and pass it through variable labelled as “On/off command R1” and will make the relay switch 1 closed, and if the voltage of grid is zero then the discovery board will generate a high pulse and pass it through variable labelled as “On/off command R2” and will make the relay switch 2 closed.

For the path P4 mentioned in Figure 4.3, code is prepared for MPPT mentioned in Figure 4.9. This code will take voltage and current of PV module as input labelled as “V of PV” and “I of PV” as shown in Figure 4.5. Based on the algorithm it will generate duty cycle for the DC-DC converter and pass it through variable “Gate Pulse” to the respective converter. The sensing circuit for PV module can be made using an op-amp and few resistors. The voltage is amplified by an op-Amp before being sent to the controller’s ADC. Several preset resistors are employed to modify the voltages to 3.3 V before feeding them to the controller [10].

The simulink model shown in the Figure 4.7 represents the basic idea as to how the relay switch 3 be turned on/off. This model consist of a simple AC-DC converter which converts AC to DC using the fixed gate pulse. The ac voltage source supplies the power

to the resistive load and the battery depending on whether the circuit breaker is closed or open. There are two circuit breaker in this model which get closed and open depending on the command given to them via “LoadOn” and “ChargingOn” variable. LoadOn and ChargingOn gets the value (1 or 0) based on the algorithm written in the matlab function block. This matlab function block takes the state of charge (SOC) of battery as the input. If the SOC is less than 100 it closes the ChargingOn breaker and opens the LoadOn breaker, but if the SOC is 100 then it closes the LoadOn breaker and opens the ChargingOn breaker.



Figure 4.6: Simulink model for MPPT



Figure 4.7: Model for path P4.



Figure 4.8: Algorithm for Controlling path P1 and P2



Figure 4.9: Algorithm for MPPT.

# Chapter 5

## Inverter-Grid Synchronisation

Even though renewable energy sources and distributed generation have been employed for more than two decades, there are still certain aspects that need to be improved in order to improve energy distribution and quality in the utility grid to levels needed by various standards and, most importantly, to meet the needs of customers. One of the primary issues in this regard is synchronising the current at the output of the inverter with the voltage of the utility grid [23].

A grid-connected solar power generating facility must be constantly alert to avoid grid disruptions and must be able to isolate when the system fails. If it does not isolate, the generated solar power will feed the grid, causing the solar plant to become overloaded and could cause injuries to the components inside the converters and other elements. It is indeed crucial to note that once the grid is disconnected, the solar power will continue to provide power even if work on the power system network is ongoing. Even though the grid is isolated, the customer must be receiving power since local loads require continuity, which isolation mode assists with. As a result, the utility will be separated, and the customer will not have an impact on the supply's continuity.

The accuracy with which the ac grid voltage parameters are assessed has a significant impact on the overall performance of grid-connected devices. To estimate the grid voltage characteristics, such as voltage amplitude, frequency, and phase angle, a precise synchronisation method is required, as these values are required for accurate synchronisation with the grid and delivery of generated electricity [23].

### 5.1 Phase Locked-Loop(PLL)

PLL is widely used in signal processing, including radio and telecommunications, computers, and electrical motor control. The approaches can be used across a wide range of frequencies, from a few hertz to orders of gigahertz.

The output voltage from the inverter must have the same frequency for each of the three phases in order to connect a power plant to the grid. If the phase angle of the grid voltage is tracked, this can be accomplished. This is a real-time procedure that is always



Figure 5.1: PLL Block diagram

running in order to keep the inverter output synchronised with the grid.

Standard synchronisation methodologies of the inverter current and the grid voltage involve widespread algorithms based on the phase-locked loops (PLL). Because utility voltage is rarely a pure sine wave, the PLL system must be able to manage distortions and irregularities satisfactorily. Unbalance in the three-phase system, presence of harmonics, variation in frequency, variation in amplitude, and phase leaps are all possible distortions in the grid voltage. These non-ideal situations arise for a variety of reasons. When a load or generator connects or disconnects from the grid, phase jumps and unbalances can occur. Grid voltages may experience harmonics as a result of transformers or devices having non-linear properties [24].

A PLL tracks one signal by another, and as a result of this tracking, the output signal is phase and frequency synced with the input reference signal. Because of their efficiency and resilience, various PLL approaches have been proposed and are utilised in single-phase, three-phase, and aviation electrical systems [25], whenever you need to keep track of currents and voltages. In general, Phase Lock Loop is the control loop or the control system which maintains the same phase between the input or the reference signal and the output signal.

For a long time, the tracing technique has been utilised, investigated, and developed. Different methods to implement the PLL in three-phase and single-phase applications can be found in the following three literature. Reference [26] [27] [28] offers an overview of the phased-locked loops' historical development, general information on their function, and a more extensive study of the three major blocks that make up the overall PLL, these major blocks are shown in figure 5.1. The basic structure of the most widely accepted synchronisation solution for a time-varying signal can be described by the block diagram shown in Fig. 5.1, which summarises the structure of nearly every PLL algorithm currently available in any literature, where the phase angle difference between the input and output signal is measured by phase detection (PD) and passed through the loop filter (LF). The voltage-controlled oscillator (VCO) is driven by the LF output signal to generate the output signal, which could follow the input signal.

### 5.1.1 Synchronous Reference Frame PLL (SRF-PLL)

A number of PLLs have recently been created for three-phase grid-connected power converters, the most common of which is the synchronous reference frame PLL (SRF-PLL) [29]. The synchronous-reference frame PLL's fundamental idea is to transform the input signals into dq-frame using the well-known Park and Clark transformations. Reference [29] proposes a concept for such a PLL. The Synchronous Rotating Reference Frame PLL (SRF-PLL) is the PLL system that performs best under distorted and non-ideal grid settings [30]. An adaptive synchronous reference frame PLL is proposed in [31] in the scenario of grid-inverter operation in a polluted utility grid to improve energy quality. The block diagram of SF-PLL is shown in figure 5.2, where the immediate phase angle is detected by synchronising the PLL rotating reference frame to the utility voltage vector.



Figure 5.2: SRF-PLL Block diagram

SRF-PLL with a high bandwidth can give a rapid and consistent detection of the phase and amplitude of the utility voltage vector under ideal utility conditions without any harmonic distortions or unbalance. If the utility voltage is distorted with high-order harmonics, the SRF-PLL can still operate if its bandwidth is decreased at the expense of PLL reaction time to reject and cancel the effect of these harmonics on the output [27]. The three-phase SRF-PLL does not require three input signals to operate, as shown by the representation of the SRF-PLL in the stationary frame. It can work if it is given a phase-a signal and its orthogonal equivalent, which is a  $90^\circ$  phase shifted version of that signal [32]. SRF-PLL provides average information rather than individual-phase frequency, amplitude, and phase measurements.

#### Synchronous rotating reference frame

In the SRF, the phase angle is tracked by synchronising the voltage space vector along the q or d axis [30]. The voltage space vector is synchronised with the q-axis in this example (figure 5.3).

This transformation synchronises the rotation of the two stationary axes with a reference frequency. The phase input  $\omega t$  is used to pass the reference frequency. There are



Figure 5.3: Reference frames along with signal

two modes for rotating frame alignment:

1. 0 - The axis is aligned with the rotating frame. The outputs of this mode are  $d = 0$  and  $q = -1$  when the signals come from a balanced three-phase signal with unitary positive-sequence magnitude.
2.  $-pi/2$  - The rotating frame is  $90^\circ$  behind the axis. The outputs of this mode are  $d = 1$  and  $q = 0$  when the signals come from a balanced three-phase signal with unitary positive-sequence magnitude.

Alpha-beta to dq 0 alignment transformation matrix:

$$\begin{bmatrix} d \\ q \end{bmatrix} = \begin{bmatrix} \cos(\omega t) & \sin(\omega t) \\ -\sin(\omega t) & \cos(\omega t) \end{bmatrix} \begin{bmatrix} \alpha \\ \beta \end{bmatrix} \quad (5.1)$$

Alpha-beta to dq -pi/2 alignment transformation matrix:

$$\begin{bmatrix} d \\ q \end{bmatrix} = \begin{bmatrix} \sin(\omega t) & -\cos(\omega t) \\ \cos(\omega t) & \sin(\omega t) \end{bmatrix} \begin{bmatrix} \alpha \\ \beta \end{bmatrix} \quad (5.2)$$

In the current model the  $-\pi/2$  behind the phase A alignment has been used.

In figure 5.3, different reference frames are represented along with the type of signal. When the values are DC (i.e., constant), different feedback controllers, such as

proportional-integral (PI) and proportional-integral-derivative (PID), provide a pragmatic and reliable control solution. The Park transformation is used to convert two-axis orthogonal stationary reference frame quantities into rotating reference frame quantities. Below is given one simple example, which shows the same.

### Park transformation or $\alpha\beta$ to DQ transformation

Suppose the input signal is,  $V = V_g \sin \omega t$ . Beta signal is taken as input, i.e.,  $V_\beta = V$ . It's equivalent alpha signal is generated using a orthogonal signal generator. The alpha signal is  $90^\circ$  phase shifted signal of the beta signal.

$$V_\beta = V_g \sin \omega t \quad (5.3)$$

$$V_\alpha = V_g \sin(\omega t + \pi/2)$$

$$V_\alpha = V_g \cos \omega t \quad (5.4)$$

Using the transformation matrix shown in equation 5.2, rotating reference frame quantities can be determined.

$$\begin{bmatrix} V_d \\ V_q \end{bmatrix} = \begin{bmatrix} \sin(\omega t) & -\cos(\omega t) \\ \cos(\omega t) & \sin(\omega t) \end{bmatrix} \begin{bmatrix} V_\alpha \\ V_\beta \end{bmatrix} \quad (5.5)$$

from this,  $V_d$  and  $V_q$  can be determined for the reference frame.

$$\begin{bmatrix} V_d \\ V_q \end{bmatrix} = \begin{bmatrix} \sin(\omega t) & -\cos(\omega t) \\ \cos(\omega t) & \sin(\omega t) \end{bmatrix} \begin{bmatrix} V_g \cos \omega t \\ V_g \sin \omega t \end{bmatrix} \quad (5.6)$$

$$\begin{bmatrix} V_d \\ V_q \end{bmatrix} = \begin{bmatrix} V_g \cos(\omega t) \sin(\omega t) - V_g \sin(\omega t) \cos(\omega t) \\ V_g \cos(\omega t) \cos(\omega t) + V_g \sin(\omega t) \sin(\omega t) \end{bmatrix} \quad (5.7)$$

$$\begin{bmatrix} V_d \\ V_q \end{bmatrix} = \begin{bmatrix} V_g \cos(\omega t) \sin(\omega t) - V_g \sin(\omega t) \cos(\omega t) \\ V_g \cos^2(\omega t) + V_g \sin^2(\omega t) \end{bmatrix} \quad (5.8)$$

$$\begin{bmatrix} V_d \\ V_q \end{bmatrix} = \begin{bmatrix} 0 \\ V_g(\cos^2(\omega t) + \sin^2(\omega t)) \end{bmatrix} \quad (5.9)$$

$$\begin{bmatrix} V_d \\ V_q \end{bmatrix} = \begin{bmatrix} 0 \\ V_g \end{bmatrix} \quad (5.10)$$

It is seen in the equation 5.10, that  $V_d = 0$  and  $V_q = V_g$ , which are constant values.

### 5.1.2 Generation of Alpha and Beta signals

As seen in figure 5.4, the alpha and beta (Input) signals are generated using two low pass filters. Using one low pass filter will give us an equivalent signal with a  $45^\circ$  phase shift. With two low pass filters using successively, a signal equivalent to input signal with  $90^\circ$  phase shift can be generated. The mathematics behind this, is shown below.



Figure 5.4: Simulink model for generating Alpha Beta signals

### Mathematical logic

The transfer function of a first order low-pass filter is given as,

$$TF = \frac{\omega_c}{s + \omega_c} \quad (5.11)$$

Where,  $\omega_c$  is the corner frequency of the low-pass filter. Substituting,  $s = j\omega$  in equation no (5.5),

$$TF = \frac{\omega_c}{j\omega + \omega_c} \quad (5.12)$$

From equation (5.6), The magnitude and phase of low-pass filter can be given as,

$$TF = \frac{\omega_c}{\sqrt{\omega^2 + \omega_c^2}} \quad \angle -\tan^{-1} \frac{\omega}{\omega_c} \quad (5.13)$$

At cutoff frequency, i.e.,  $\omega = \omega_c$

$$TF = \frac{\omega}{\sqrt{\omega^2 + \omega^2}} \quad \angle -\tan^{-1} \frac{\omega}{\omega} \quad (5.14)$$

$$TF = \frac{\omega}{\sqrt{\omega^2(2)}} \quad \angle -\tan^{-1} 1 \quad (5.15)$$

$$TF = \frac{\omega}{\omega\sqrt{2}} \quad \angle -\frac{\pi}{4} \quad (5.16)$$

$$TF = \frac{1}{\sqrt{2}} \quad \angle -45^\circ \quad (5.17)$$

When one more low-pass filter is used successively, the final magnitude and phase will become,

$$TF = \frac{1}{\sqrt{2}} * \frac{1}{\sqrt{2}} \quad \angle -45^\circ + (-45^\circ) \quad (5.18)$$

$$TF = \frac{1}{2} \quad \angle -90^\circ \quad (5.19)$$

As seen here, the magnitude of final signal is becoming half of what it was before. To compensate for this, gain of 2 has been used at the end as shown in figure 5.4. The output at the end of the gain is the equivalent of the input signal with  $90^\circ$  phase shift. Upon running the simulation, the generated alpha and beta signals are shown in figure 5.5.



Figure 5.5: Alpha beta signals

## 5.2 The MATLAB Simulink model and simulations for SRF-PLL

The three phase SRF-PLL model can be used to make single phase SRF-PLL, not in a straightforward manner but it provides a useful structure for single-phase PLLs as long

as the 90-degree-shifted orthogonal component of the single-phase input signal is created [32]. The model is Shown in fig 5.6. The solver configurations and all of the important block parameters to run the simulation are shown in Appendix B.



Figure 5.6: SRF-PLL MATLAB Simulink model

### 5.2.1 Simulation with a constant sinusoidal input signal (Input signal without disturbances)

The ideal case is when the input signal to the SRF-PLL has no disturbances , i.e., it's frequency, amplitude and Phase remains same always, that too without any harmonics. The model shown in figure 5.6 is constructed for such a case in simulink. The input signal given is  $220 \sin 2\pi 50$ , which is also the beta signal for the model. The simulation is run for 0.1 seconds, with variable type step solver (Ode 45, Dormand-prince) with min step being  $10^{-8}$  and maximum step being  $10^{-7}$ . The output signal is shown in figure 5.7. For an ideal signal, the PLL is giving the desired output. As seen in the error signal, in figure 5.7, it takes approximately  $2.1mS$  for the system to become steady.

### 5.2.2 Simulation with step variation of Frequency, Phase and Amplitude (Input signal with disturbances)

A PLL should be able to synchronise the grid's voltage and the inverter's current using a reference signal, even if there are disturbances in the grid. To realise such a case where there are frequency, phase and amplitude disturbances, the Simulink model shown in figure 5.8 is used. the input signal is varied using a MATLAB function block of Simulink with a simple code, shown in appendix A, which will pass one signal for a period of time then pass the other signal for a the next time period.



Figure 5.7: Constant Sinusoidal signal ( $220 \sin 2\pi 50$ ), ideal case output

### Step variation of frequency

As shown in Fig 5.8, when the clock is 1, the Matlab function block will pass the signal with  $51\text{hz}$  frequency,  $220 \sin 2\pi 51$ , for first half of the simulation time period, and then it will pass the signal with  $50\text{hz}$  frequency,  $220 \sin 2\pi 50$ . The input signal can be seen in figure 5.9. The alpha beta signals that are generated is shown in figures 5.10 and figure 5.11. The reference signal generated along with the error signal is shown in figure 5.12. The output at the end is what is desired, i.e, the PLL is tracking the input signal when the frequency varies.



Figure 5.8: Simulink model for Step variation of frequency

### Step variation of Phase

The same Matlab function block is used again with different input signals. The simulink model can be seen in figure. 5.13. Both having the same frequency and amplitude but with different phase. There's  $10^\circ$  of phase difference between these two input signals. The



Figure 5.9: Input for step variation of frequency



Figure 5.10: Alpha beta signals generated for variation of frequency (50hz)

input signal can be seen in figure 5.14. The generated alpha beta signals are shown in figure 5.15. The output reference signal along with error signal is shown in figure 5.16. It is seen in figure 5.16 that PLL is able to track the input signal as the output signal has same phase as the input signal phase.

### Step variation of Amplitude

Different input signals are used with the same Matlab Function block. The simulink model can be seen in figure. 5.17. Both having the same frequency and Phase but with different Amplitude. One signal has 230 amplitude and the other one has 220. The difference in amplitude can be seen by a horizontal line stretched using measurement feature of Scope block shown in figure 5.18. The input signal can be seen in figure 5.18. The generated alpha beta signals are shown in figure 5.19. The output reference signal along with error



Figure 5.11: Alpha beta signals generated for variation of frequency (51hz)



Figure 5.12: output with Step variation of frequency



Figure 5.13: Simulink model for Step variation of Phase



Figure 5.14: Input for Step variation of Phase



Figure 5.15: Alpha beta signals generated for variation of Phase

signal is shown in figure 5.20., in which it is seen that amplitude variation in input signal has no effect on the reference signal generated.

### 5.2.3 Simulation with Harmonics in the input signal

The model is tested for the input signal with general harmonics found in the transmission/distribution network. The current amount of harmonic pollution in the Indian power system is investigated in this research [33]. Also investigated is the harmonic content of some of the most widely utilised loads and residential regions. In addition, a survey is given in order to determine the harmonic level existing in the distribution system. It has been noted that the voltages on transmission/distribution systems have substantially less distortion, according to the analysis on the distribution network. However, as we get closer to the load, the voltage distortion rises. At the customer's end, significant



Figure 5.16: output with Step variation of Phase



Figure 5.17: Simulink model for Step variation of amplitude

distortion is recorded, with a high percentage of 5<sup>th</sup> and 7<sup>th</sup> harmonic components. From this study, to observe the injection of harmonics on the system a signal with 5<sup>th</sup> and 7<sup>th</sup> harmonic components is given to the SRF-PLL. The Simulink model for this test is shown in figure 5.21. The input signal with harmonic components in it are shown in figure 5.22. It's result is shown in figure 5.53. As seen from the results, the SRF-PLL model shown in the project is not able to track the fundamental component of the input signal.

### 5.3 Code generation for STM32F4 discovery board

Codes compatible with STM32F4 discovery board micro-controller are generated using Embedded coder application of MATLAB. The configuration files used to select the pins of micro-controller are made using STMicroelectronics application named, STM32CubeMX. The target file used to generate the code is stm32.tlc, which is seen in the appendix B



Figure 5.18: Input for Step variation of Amplitude



Figure 5.19: Alpha beta signals generated for variation of Amplitude

where the block parameters and configurations are given. The generated code for model and it's header files along with other helpful header files are given in Appendix B.



Figure 5.20: output with Step variation of Amplitude



Figure 5.21: Simulink model for a signal with Harmonics



Figure 5.22: Input signal: Harmonics injected signal



Figure 5.23: Output for the signal with Harmonics

# **Chapter 6**

## **Conclusion**

The model of inverter system was prepared with MPPT and the control strategy was devised for the same. Its implementation on STM discovery board was tried. On changing irradiance and temperature values the MPPT corresponded to the change in condition and thus it tracked the new MPP.

The SRF-PLL model shown here is highly accurate and has response time of approximately  $4.5mS$ . The simulations revealed that for ideal signal, as seen in the figure 5.7, the error signal is being stable after  $0.02S$ . When there is a step variation in frequency, phase and amplitude the model has accurate results but a signal with harmonics it can not track.

# Appendices

# Appendix A

## Waijung Models

These are basic models created using waijung library for a proper understanding of its simulink blocks.



Figure A.1: Model for turning on LED by giving input to pin PA5



Figure A.2: Model for turning on/off led repeatedly.



Figure A.3: Model for switching on/off led by pressing switch.

# Appendix B

## STM codes

These following codes are written in Atollic true studio for STM32. These are demo codes written for proper understanding of its library functions.

### B.1 Code for controlling switching of on/off for path P1 and P2

```
#include "stm32f4xx.h"                                     /* Include STM Inbuilt Library
*/
#include "stm32f4_discovery.h"

GPIO_InitTypeDef GPIO_C1;                                     /* Initiaializing the function
*/
int main(void)                                              /* Starting The main function
*/
{
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);      /* Initializing
    the clock for portA and enabling it */
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);      /* Initializing
    the clock for portD and enabling it */
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOE, ENABLE);      /* Initializing
    the clock for portE and enabling it */

    GPIO_C1.GPIO_Pin = GPIO_Pin_5;                                /* Initializing the
    Pin PA5 */
    GPIO_C1.GPIO_OType = GPIO_OType_PP;                          /* Initializing the
    Pin to work in push pull mode */
```

```

GPIO_C1.GPIO_Mode = GPIO_Mode_IN;                                /* Initializing the
   Pin PA5 to work in Input Mode */
GPIO_C1.GPIO_PuPd = GPIO_PuPd_NOPULL;                            /* Initializing the
   Pin PA5 to work as No pull means no low or high */
GPIO_C1.GPIO_Speed = GPIO_Speed_50MHz;                            /* Initializing the
   speed of clock pulse */
GPIO_Init(GPIOA, &GPIO_C1);                                     /* Calling the function
   Init by passing two values*/



GPIO_C1.GPIO_Pin = GPIO_Pin_12;                                  /* Initializing the Pin
   PD12 */
GPIO_C1.GPIO_Pin = GPIO_Pin_13;                                  /* Initializing the Pin
   PD13 */
GPIO_C1.GPIO_OType = GPIO_OType_PP;                             /* Initializing the Pin
   PD12, PD13 to work in Push Pull Mode */
GPIO_C1.GPIO_Mode = GPIO_Mode_OUT;                               /* Initializing the Pin
   PD12, PD13 to work in output mode */
GPIO_C1.GPIO_PuPd = GPIO_PuPd_NOPULL;                            /* Initializing the Pin
   PD12, PD13 to work as no pull mode */
GPIO_C1.GPIO_Speed = GPIO_Speed_50MHz;                            /* Initializing the speed
   of clock pulse */
GPIO_Init(GPIOD, &GPIO_C1);                                     /* Calling the function
   Init by passing two values*/



GPIO_C1.GPIO_Pin = GPIO_Pin_11;                                  /* Initializing the Pin
   PE11 */
GPIO_C1.GPIO_Pin = GPIO_Pin_13;                                  /* Initializing the Pin
   PE13 */
GPIO_C1.GPIO_OType = GPIO_OType_PP;                             /* Initializing the Pin
   PE1, PE13 to work in push pull mode */
GPIO_C1.GPIO_Mode = GPIO_Mode_OUT;                               /* Initializing the Pin
   PE11, PE13 to work in output mode */
GPIO_C1.GPIO_PuPd = GPIO_PuPd_NOPULL;                            /* Initializing the
   Pin PE11, PE13 to work as no pull mode */
GPIO_C1.GPIO_Speed = GPIO_Speed_50MHz;                            /* Initializing the Speed
   of clock pulse */
GPIO_Init(GPIOE, &GPIO_C1);                                     /* Calling the function
   Init by passing two values*/



while (1)
{

```

```

if(GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_5) == Bit_SET)           /* Checking
   if Input is High or not */
{
    GPIO_WriteBit(GPIOD, GPIO_Pin_12, Bit_SET);                  /* Making pin
   PD12 set high */
    GPIO_WriteBit(GPIOE, GPIO_Pin_11, Bit_SET);                  /* Making pin
   PE11 set high */
}
else
{
    GPIO_WriteBit(GPIOD, GPIO_Pin_13, Bit_SET);                  /* Making Pin
   PD13 set high */
    GPIO_WriteBit(GPIOE, GPIO_Pin_11, Bit_RESET);                /* Making Pin
   PE11 set low */
    GPIO_WriteBit(GPIOE, GPIO_Pin_13, Bit_SET);                  /* Making Pin
   PE13 set high */
}
}
}

```

## B.2 Code for MPPT

```

#include "stm32f4xx.h"
#include "stm32f4_discovery.h"

GPIO_InitTypeDef  GPIO_RefGen;          /* Defining the function*/

int Vrefmax = 363;                    /* Assuming the Vref maximum value*/
int Vrefmin = 0;                     /* Assuming the Vref minimum value*/
int Vrefinit = 300;                  /* Assuming Vrefinit value as 300 coz
   at here MPP occurs*/
int deltaVref = 1;                   /* Taking a constant value*/

double Vold = 0;double Pold = 0;      /*declaring values and variables*/
double Vrefold = 300;double V;
double P;double I;
double dV;double dP;double Vref;

int main(void)                      /*Starting the main function*/
{

```

```

RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);      /*initializing the
clock pulses*/
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);

GPIO_RefGen.GPIO_Pin = GPIO_Pin_5;                         /*Initializing the pin
*/
GPIO_RefGen.GPIO_OType = GPIO_OType_PP;
GPIO_RefGen.GPIO_Mode = GPIO_Mode_IN;
GPIO_RefGen.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_RefGen.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOA, &GPIO_RefGen);

GPIO_RefGen.GPIO_Pin = GPIO_Pin_12;
GPIO_RefGen.GPIO_OType = GPIO_OType_PP;
GPIO_RefGen.GPIO_Mode = GPIO_Mode_IN;
GPIO_RefGen.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_RefGen.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOD, &GPIO_RefGen);

while (1)
{
    V = GPIO_ReadInputData(GPIOA);
    I = GPIO_ReadInputData(GPIOD);
    P = V*I;
    dV = V - Vold;
    dP = P - Pold;

    if (dP == 0)
    {
        Vref = Vrefold;
    }

    if (dP < 0)
    {
        if (dV < 0)
        {
            Vref = Vrefold + deltaVref;
        }
        else
        {

```

```

        Vref = Vrefold - deltaVref;
    }

}

if (dP > 0)
{
    if (dV < 0)
    {
        Vref = Vrefold - deltaVref;
    }
    else
    {
        Vref = Vrefold + deltaVref;
    }
}
if (Vref >= Vrefmax || Vref <= Vrefmin)
{
    Vref = Vrefold;
}
Vrefold = Vref;
Vold = V;
Pold = P;
}
}

```

### B.3 Code for Glowing LED for an infinite period.

```

#include "stm32f4xx.h"                      /*Inculde STM inbuilt library*/
#include "stm32f4_discovery.h"

GPIO_InitTypeDef GPIO_LED;                  /* Initializing the function */

int main(void)   /* Begining the main function */
{

RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);      /* Initializing
and starting the clock of Port D */

GPIO_LED.GPIO_Pin = GPIO_Pin_12;           /* Initializing the Pin 12 */

```

```

GPIO_LED.GPIO_Mode = GPIO_Mode_OUT;           /* Initializing the Pin 12 in
output mode */
GPIO_LED.GPIO_OType = GPIO_OType_PP;         /* Initializing the Pin 12 with
Push Pull mode */
GPIO_LED.GPIO_Speed = GPIO_Speed_50MHz;       /* Initializing the port D with the
clock speed */

GPIO_Init(GPIOD, &GPIO_LED);                /* Calling the function Init by
passing two values */

GPIO_WriteBit(GPIOD, GPIO_Pin_12, Bit_SET);   /* Making pin PD12 set high by
passing Bit_SET value */

while (1)      /* Starting While Loop for controller to work for infinite
Period */
{
}

}

```

## B.4 Code for making LEDs blink automatically

```

#include "stm32f4xx.h"                      /* Include STM inbuilt Library */
#include "stm32f4_discovery.h"

GPIO_InitTypeDef GPIO_LED;                  /* Initializing the function */

void Delay( __IO uint32_t nCount)    /* Function for bringing the delay */
{
    while(nCount--)                    /* starting loop for delay */
    {

    }
}

int main(void)                          /* Beginning the main function */
{

RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE); /* Initializing the
clock for PortD and enabling it */

```

```

GPIO_LED.GPIO_Pin = GPIO_Pin_12;                                /* Initializing the
   Pin 12 pf port D*/
GPIO_LED.GPIO_Mode = GPIO_Mode_OUT;                            /* Initializing the
   Pin PD12 to work in output Mode */
GPIO_LED.GPIO_OType = GPIO_OType_PP;                           /* Initializing the
   Pin PD12 to work Push Pull Mode */
GPIO_LED.GPIO_Speed = GPIO_Speed_50MHz;                         /* Initializing the
   speed */
GPIO_Init(GPIOD, &GPIO_LED);                                  /* Calling the
   function Init By passing two values */

while (1)                                                 /* Stating while loop*/
{
    GPIO_WriteBit(GPIOD, GPIO_Pin_12, Bit_SET);      /* Making Pin PD12 output
   as high*/
    Delay(168000);                                 /* Providing a delay */
    GPIO_WriteBit(GPIOD, GPIO_Pin_12, Bit_RESET);    /* Making Pin PD12 output
   as low */
    Delay(168000);                                 /* Providing delay */
}
}

```

## B.5 Code for making all four LEDs glow one after the other

```

#include "stm32f4xx.h"                                         /* Include STM Inbuilt Library*/
#include "stm32f4_discovery.h"

GPIO_InitTypeDef GPIO_Led;                                     /* Initializing the function */

void Delay( __IO uint32_t nCount)                            /* Function for providing delay
   */
{
    while(nCount--)                                         /* This while loop gives delay */
    {
    }
}

int main(void)                                              /* Beginning the main function */

```

```

{
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);           /* Initializing
    the Clock for port D and enabling it */
    GPIO_Led.GPIO_Pin = GPIO_Pin_0;                                /* Initializing
    the Pin PD0 */
    GPIO_Led.GPIO_Pin = GPIO_Pin_1;                                /* Initializing
    the Pin PD1 */
    GPIO_Led.GPIO_Pin = GPIO_Pin_2;                                /* Initializing
    the Pin PD2 */
    GPIO_Led.GPIO_Pin = GPIO_Pin_3;                                /* Initializing
    the Pin PD3 */
    GPIO_Led.GPIO_Mode = GPIO_Mode_OUT;                            /* Initializing
    the Pin PD0, PD1, PD2, PD3 to work in output Mode */
    GPIO_Led.GPIO_OType = GPIO_OType_PP;                           /* Initializing
    the Pin PD0, PD1, PD2, PD3 to work in Push Pull Mode */
    GPIO_Led.GPIO_Speed = GPIO_Speed_50MHz;                         /* Initializing the
    speed of clock pulse */

    GPIO_Init(GPIOD, &GPIO_Led);                                 /* Calling the function Init by
    passing two values */

while (1)                                              /* Starting While Loop */
{
    GPIO_WriteBit(GPIOD, GPIO_Pin_0, Bit_SET);      /* Making Pin PD0 to output
    as high*/
    Delay(168000);                                /* Providing The delay */
    GPIO_WriteBit(GPIOD, GPIO_Pin_1, Bit_SET);      /*** Making Pin PD1 to ouput
    high and PD0 to output as low */
    GPIO_WriteBit(GPIOD, GPIO_Pin_0, Bit_RESET);
    Delay(168000);                                /* Providing a delay */
    GPIO_WriteBit(GPIOD, GPIO_Pin_2, Bit_SET);      /*** Making Pin PD2 to ouput
    high and PD1 to output as low */
    GPIO_WriteBit(GPIOD, GPIO_Pin_1, Bit_RESET);
    Delay(168000);                                /* Providing a delay */
    GPIO_WriteBit(GPIOD, GPIO_Pin_3, Bit_SET);      /*** Making Pin PD3 to
    ouput high and PD2 to output as low */
    GPIO_WriteBit(GPIOD, GPIO_Pin_2, Bit_RESET);
    Delay(168000);                                /* Providing a delay */
    GPIO_WriteBit(GPIOD, GPIO_Pin_3, Bit_RESET);     /*** Making Pin PD3 to
    to ouput low */
}

```

```
    }
}
```

## B.6 Code for Making LED switch on/off by pressing switch.

```
#include "stm32f4xx.h"                                /* Include STM Inbuilt Library
*/
#include "stm32f4_discovery.h"

GPIO_InitTypeDef GPIO_Led;                            /* Initiaializing the function */

int p = 0;                                         /* initializing the variable p */

void Delay( __IO uint32_t nCount)      /* Function to provide delay */
{
    while(nCount--)                           /* loop to bring delay */
    {

    }
}

int main(void)                                     /* Starting The main function */
{
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOD, ENABLE);      /* Initializing
        the clock for portD and enabling it */
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);      /* Initializing
        the clock for portD and enabling it */

    GPIO_Led.GPIO_Pin = GPIO_Pin_0;                      /* Initializing the Pin PD0
    */
    GPIO_Led.GPIO_Pin = GPIO_Pin_1;                      /* Initializing the Pin PD1
    */
    GPIO_Led.GPIO_Pin = GPIO_Pin_2;                      /* Initializing the Pin PD2
    */
    GPIO_Led.GPIO_Pin = GPIO_Pin_3;                      /* Initializing the Pin PD3
    */
    GPIO_Led.GPIO_Mode = GPIO_Mode_OUT;                 /* Initializing the Pin PD0,
        PD1, PD2, PD3 to work in output mode */
```

```

GPIO_Led.GPIO_OType = GPIO_OType_PP;           /* Initializing the Pin PDO,
PD1, PD2, PD3 to work in Push Pull Mode */
GPIO_Led.GPIO_Speed = GPIO_Speed_50MHz;         /* Initializing speed of clock
pulse */
GPIO_Led.GPIO_PuPd = GPIO_PuPd_NOPULL;          /* Initailaizing the pin to
work as No pull mode */
GPIO_Init(GPIOD, &GPIO_Led);                  /* calling the function Init
by passing two values */

GPIO_Led.GPIO_Pin = GPIO_Pin_1;                 /* Initializing the Pin PA1
*/
GPIO_Led.GPIO_Mode = GPIO_Mode_IN;              /* Initializing the Pin PA1
to work as Input mode */
GPIO_Led.GPIO_OType = GPIO_OType_PP;            /* Initiaializing pin to work
as Push pull mode */
GPIO_Led.GPIO_PuPd = GPIO_PuPd_DOWN;            /* Pin set low */
GPIO_Led.GPIO_Speed = GPIO_Speed_50MHz;          /* Initiaializing the speed of
clock pulse */
GPIO_Init(GPIOA, &GPIO_Led);                  /* Calling the function Init by
passing two values */

while (1)
{
    if (GPIO_ReadInputDataBit(GPIOA, GPIO_Pin_1) == Bit_SET) /* Checking if
Input is High or not */
    {
        if(p == 0)                                         /* Checking
value of p */
        {
            p = 1;                                         /* Changing
value of p if condition is true */
        }
        else
        {
            p = 0;                                         /* p remains same
if condition true */
        }
        Delay(168000);                                    /* Provide Delay
*/
    }
    if (p == 0)                                         /* Checking
condition by seeing value of p */
{

```

```

    GPIO_WriteBit(GPIOD, GPIO_Pin_0, Bit_SET);           /* Making pin PD0 to
set high */
    GPIO_WriteBit(GPIOD, GPIO_Pin_1, Bit_SET);           /* Making pin PD1 to
set high */
    GPIO_WriteBit(GPIOD, GPIO_Pin_2, Bit_RESET);         /* Making pin PD2 to
set low */
    GPIO_WriteBit(GPIOD, GPIO_Pin_3, Bit_RESET);         /* Making pin PD3 to
set low */
}
else
{
    GPIO_WriteBit(GPIOD, GPIO_Pin_0, Bit_RESET);         /* Making pin PD0 to
set low */
    GPIO_WriteBit(GPIOD, GPIO_Pin_1, Bit_RESET);         /* Making pin PD1 to
set low */
    GPIO_WriteBit(GPIOD, GPIO_Pin_2, Bit_SET);           /* Making pin PD2 to
set high */
    GPIO_WriteBit(GPIOD, GPIO_Pin_3, Bit_SET);           /* Making pin PD3 to
set high */
}
}

}

```

# Appendix C

## SRF-PLL Codes

Code generated using Embedded coder in MATLAB for PLL to be used in STM32F4 Discovery board.

### C.1 MATLAB Function block code

#### C.1.1 Step variation of frequency, phase and Amplitude

```
function y = fcn(CLK, Ip1,Ip2)
    if CLK == 0
        y = Ip1;
    else
        y = Ip2;
    end
end
```

Listing C.1: Step variation of frequency

### C.2 Model Files

#### 1) Model.c

```
/*
 * File: Model.c
 *
 * Code generated for Simulink model :Final_PLL_Single_Phase.
 *
 * Model version      : 1.8
```

```

* Simulink Coder version      : 9.3 (R2020a) 18-Nov-2019
* TLC version        : 9.3 (Jan 23 2020)
* C/C++ source code generated on : Fri May 28 20:30:58 2021
*
* Target selection: stm32.tlc
* Embedded hardware selection: STM32CortexM
* Code generation objectives:
*   1. Execution efficiency
*   2. RAM efficiency
* Validation result: Not run
*
*
*
*
*****
```

```

*****
```

```

*/
#include "Final_PLL_Single_Phase.h"

/* Private macros used by the generated code to access rtModel */
#ifndef rtmIsMajorTimeStep
#define rtmIsMajorTimeStep(rtm) (((rtm)->Timing.simTimeStep) ==
MAJOR_TIME_STEP)
#endif

#ifndef rtmIsMinorTimeStep
#define rtmIsMinorTimeStep(rtm) (((rtm)->Timing.simTimeStep) ==
MINOR_TIME_STEP)
#endif

#ifndef rtmSetTPtr
#define rtmSetTPtr(rtm, val) ((rtm)->Timing.t = (val))
#endif

/* Continuous states */
X rtX;

/* Block signals and states (default storage) */
DW rtDW;

/* Real-time model */

```

```

RT_MODEL rtM_;
RT_MODEL *const rtM = &rtM_;

/* private model entry point functions */
extern void Final_PLL_Single_Phase_derivatives(void);

/*
 * This function updates continuous states using the ODE3 fixed-step
 * solver algorithm
 */
static void rt_ertODEUpdateContinuousStates(RTW SolverInfo *si )
{
    /* Solver Matrices */
    static const real_T rt_ODE3_A[3] = {
        1.0/2.0, 3.0/4.0, 1.0
    };

    static const real_T rt_ODE3_B[3][3] = {
        { 1.0/2.0, 0.0, 0.0 },
        { 0.0, 3.0/4.0, 0.0 },
        { 2.0/9.0, 1.0/3.0, 4.0/9.0 }
    };

    time_T t = rtsiGetT(si);
    time_T tnew = rtsiGetSolverStopTime(si);
    time_T h = rtsiGetStepSize(si);
    real_T *x = rtsiGetContStates(si);
    ODE3_IntgData *id = (ODE3_IntgData *)rtsiGetSolverData(si);
    real_T *y = id->y;
    real_T *f0 = id->f[0];
    real_T *f1 = id->f[1];
    real_T *f2 = id->f[2];
    real_T hB[3];
    int_T i;
    int_T nXc = 4;
    rtsiSetSimTimeStep(si,MINOR_TIME_STEP);

    /* Save the state values at time t in y, we'll use x as ynew. */
    (void) memcpy(y, x,
                  (uint_T)nXc*sizeof(real_T));
}

```

```

/* Assumes that rtsiSetT and ModelOutputs are up-to-date */
/* f0 = f(t,y) */
rtsiSetdX(si, f0);
Final_PLL_Single_Phase_derivatives();

/* f(:,2) = feval(odefile, t + hA(1), y + f*hB(:,1), args(:)(*)) */
hB[0] = h * rt_ODE3_B[0][0];
for (i = 0; i < nXc; i++) {
    x[i] = y[i] + (f0[i]*hB[0]);
}

rtsiSetT(si, t + h*rt_ODE3_A[0]);
rtsiSetdX(si, f1);
Final_PLL_Single_Phase_step();
Final_PLL_Single_Phase_derivatives();

/* f(:,3) = feval(odefile, t + hA(2), y + f*hB(:,2), args(:)(*)) */
for (i = 0; i <= 1; i++) {
    hB[i] = h * rt_ODE3_B[1][i];
}

for (i = 0; i < nXc; i++) {
    x[i] = y[i] + (f0[i]*hB[0] + f1[i]*hB[1]);
}

rtsiSetT(si, t + h*rt_ODE3_A[1]);
rtsiSetdX(si, f2);
Final_PLL_Single_Phase_step();
Final_PLL_Single_Phase_derivatives();

/* tnew = t + hA(3);
   ynew = y + f*hB(:,3); */
for (i = 0; i <= 2; i++) {
    hB[i] = h * rt_ODE3_B[2][i];
}

for (i = 0; i < nXc; i++) {
    x[i] = y[i] + (f0[i]*hB[0] + f1[i]*hB[1] + f2[i]*hB[2]);
}

rtsiSetT(si, tnew);
rtsiSetSimTimeStep(si,MAJOR_TIME_STEP);
}

```

```

/* Model step function */

void Final_PLL_Single_Phase_step(void)
{
    real_T rtb_Integrator1;
    real_T rtb_Sum1_g;
    real_T rtb_Gain;
    if (rtmIsMajorTimeStep(rtM)) {
        /* set solver stop time */
        rtsiSetSolverStopTime(&rtM->solverInfo, ((rtM->Timing.clockTick0+1)*
            rtM->Timing.stepSize0));
    }                                /* end MajorTimeStep */

    /* Update absolute time of base rate at minor time step */
    if (rtmIsMinorTimeStep(rtM)) {
        rtM->Timing.t[0] = rtsiGetT(&rtM->solverInfo);
    }

    /* Integrator: '<Root>/Integrator1' */
    rtb_Integrator1 = rtX.Integrator1_CSTATE;

    /* Fcn: '<Root>/Fcn' incorporates:
     *   Integrator: '<Root>/Integrator1'
     */
    rtDW.Fcn = sin(rtX.Integrator1_CSTATE);

    /* Outputs for Enabled SubSystem: '<S1>/Subsystem - pi//2 delay' incorporates
     :
     *   EnablePort: '<S8>/Enable'
     */
    if (rtmIsMajorTimeStep(rtM)) {
        /* S-Function (GPIO_Write): '<Root>/GPIO_Write' */
        {
            if (rtDW.Fcn == 0)
                HAL_GPIO_WritePin(GPIOC, GPIO_PIN_0, GPIO_PIN_RESET);
            else
                HAL_GPIO_WritePin(GPIOC, GPIO_PIN_0, GPIO_PIN_SET);
        }

        /* S-Function (GPIO_Read): '<Root>/GPIO_Read' */
        {
            rtDW.GPIO_Read = (boolean_T)HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_2);
        }
    }
}

```

```

    rtDW.Subsystempi2delay_MODE = (rtmIsMajorTimeStep(rtM) ||
    rtDW.Subsystempi2delay_MODE);
}

/* End of Outputs for SubSystem: '<S1>/Subsystem - pi//2 delay' */

/* Sum: '<S10>/Sum1' incorporates:
 * Gain: '<S10>/D'
 * Integrator: '<S10>/Integrator'
 */
rtb_Sum1_g = 0.0 * rtDW.GPIO_Read + rtX.Integrator_CSTATE_d;

/* Gain: '<Root>/Gain' incorporates:
 * Gain: '<S11>/D'
 * Integrator: '<S11>/Integrator'
 * Sum: '<S11>/Sum1'
 */
rtb_Gain = (0.0 * rtb_Sum1_g + rtX.Integrator_CSTATE) * 2.0;

/* Outputs for Enabled SubSystem: '<S1>/Subsystem - pi//2 delay' incorporates
:

```

Listing C.2: Model.c

## 2) Model.h

```

/*
* File: Model.h
*
* Code generated for Simulink model :Final_PLL_Single_Phase.
*
* Model version      : 1.8
* Simulink Coder version   : 9.3 (R2020a) 18-Nov-2019
* TLC version       : 9.3 (Jan 23 2020)
* C/C++ source code generated on  : Fri May 28 20:30:58 2021
*
* Target selection: stm32.tlc
* Embedded hardware selection: STM32CortexM
* Code generation objectives:
*   1. Execution efficiency
*   2. RAM efficiency

```

```

* Validation result: Not run
*
*
*
*
*****
```

\*/

```

#ifndef RTW_HEADER_Final_PLL_Single_Phase_h_
#define RTW_HEADER_Final_PLL_Single_Phase_h_
#include <math.h>
#include <string.h>
#include "STM32_Config.h"
#include "Final_PLL_Single_Phase_External_Functions.h"
#ifndef Final_PLL_Single_Phase_COMMON_INCLUDES_
#define Final_PLL_Single_Phase_COMMON_INCLUDES_
#include "rtwtypes.h"
#include "rtw_continuous.h"
#include "rtw_solver.h"
#endif /* Final_PLL_Single_Phase_COMMON_INCLUDES_
*/
/* Model Code Variants */

/* Macros for accessing real-time model data structure */
#ifndef rtmGetContStateDisabled
#define rtmGetContStateDisabled(rtm) ((rtm)->contStateDisabled)
#endif

#ifndef rtmSetContStateDisabled
#define rtmSetContStateDisabled(rtm, val) ((rtm)->contStateDisabled = (val))
#endif

#ifndef rtmGetContStates
#define rtmGetContStates(rtm) ((rtm)->contStates)
#endif

#ifndef rtmSetContStates
#define rtmSetContStates(rtm, val) ((rtm)->contStates = (val))
#endif

#ifndef rtmGetContTimeOutputInconsistentWithStateAtMajorStepFlag

```

```
# define rtmGetContTimeOutputInconsistentWithStateAtMajorStepFlag(rtm) ((rtm)->
    CTOutputIncnstWithState)
#endif

#ifndef rtmSetContTimeOutputInconsistentWithStateAtMajorStepFlag
```

Listing C.3: Model.c

## C.3 Utility Files

### 1. rtwtypes.h

```
/*
 * File: rtwtypes.h
 *
 * Code generated for Simulink model :Final_PLL_Single_Phase.
 *
 * Model version      : 1.8
 * Simulink Coder version   : 9.3 (R2020a) 18-Nov-2019
 * TLC version       : 9.3 (Jan 23 2020)
 * C/C++ source code generated on : Fri May 28 20:30:58 2021
 *
 * Target selection: stm32.tlc
 * Embedded hardware selection: STM32CortexM
 * Code generation objectives:
 *   1. Execution efficiency
 *   2. RAM efficiency
 * Validation result: Not run
 *
 *
 *
 *
 ****
 */
#ifndef RTWTYPES_H
#define RTWTYPES_H

/* Logical type definitions */
#if (!defined(__cplusplus))
# ifndef false
#   define false          (0U)
# endif

# ifndef true
#   define true           (1U)
# endif
#endif
```

```

/*=====
 * Target hardware information
 *   Device type: MATLAB Host
 *   Number of bits:    char:    8     short:   16     int:   32
 *                     long:   32     long long:  64
 *                     native word size: 64
 *   Byte ordering: LittleEndian
 *   Signed integer division rounds to: Zero
 *   Shift right on a signed integer as arithmetic shift: on
=====*/
/*=====
 * Fixed width word size data types:
 *   int8_T, int16_T, int32_T      - signed 8, 16, or 32 bit integers
 *   uint8_T, uint16_T, uint32_T   - unsigned 8, 16, or 32 bit integers
 *   real32_T, real64_T          - 32 and 64 bit floating point numbers
=====*/
typedef signed char int8_T;
typedef unsigned char uint8_T;
typedef short int16_T;
typedef unsigned short uint16_T;
typedef int int32_T;
typedef unsigned int uint32_T;

```

Listing C.4: Model.c

## C.4 Other Files

### 1. External Functions.h

```
/*
 * File: Model_External_Functions.h
 *
 * Code generated for Simulink model :Final_PLL_Single_Phase.
 *
 * Model version      : 1.8
 * Simulink Coder version    : 9.3 (R2020a) 18-Nov-2019
 * TLC version       : 9.3 (Jan 23 2020)
 * C/C++ source code generated on : Fri May 28 20:30:58 2021
 *
 * Target selection: stm32.tlc
 * Embedded hardware selection: STM32CortexM
 * Code generation objectives:
 *   1. Execution efficiency
 *   2. RAM efficiency
 * Validation result: Not run
 *
 *
 *
 *
 ****
 */

#ifndef RTW_HEADER_Final_PLL_Single_Phase_External_Functions_h_
#define RTW_HEADER_Final_PLL_Single_Phase_External_Functions_h_

/* Generated by STM32_Config.*/
***** External Imported Functions *****
#endif          /* RTW_HEADER_Final_PLL_Single_Phase_External_Functions_h_
 */

/* File trailer for Real-Time Workshop generated code.
 *
 * [EOF] Final_PLL_Single_Phase_External_Functions.h
 */
```

Listing C.5: Model.c

## 2. Main.c

```
/*
 * File: main.c
 *
 * Code generated for Simulink model :Final_PLL_Single_Phase.
 *
 * Model version      : 1.8
 * Simulink Coder version    : 9.3 (R2020a) 18-Nov-2019
 * TLC version       : 9.3 (Jan 23 2020)
 * C/C++ source code generated on : Fri May 28 20:30:58 2021
 *
 * Target selection: stm32.tlc
 * Embedded hardware selection: STM32CortexM
 * Code generation objectives:
 *   1. Execution efficiency
 *   2. RAM efficiency
 * Validation result: Not run
 *
 *
 *
 *
 ****
 */

/* This section of code is going to be merged by the STM32CubeMX tool. */
/* USER CODE BEGIN 0 */
#include <stdio.h>
#include "Final_PLL_Single_Phase.h"
#include "rtwtypes.h"

/* Flags for taskOverrun */
static boolean_T OverrunFlags[1] = { false, };

/* Number of auto reload timer rotation computed */
static volatile uint32_t autoReloadTimerLoopVal_S = 1;

/* Remaining number of auto reload timer rotation to do */
volatile uint32_t remainAutoReloadTimerLoopVal_S = 1;

/* USER CODE END 0 */
```

```

/**
 * @brief  The application entry point.
 * @retval int
 */
int main (void)
{
    /* This section of code is going to be merged by the STM32CubeMX tool. */
    /* USER CODE BEGIN 1 */
    /* USER CODE END 1 */

    /* This section of code is going to be merged by the STM32CubeMX tool. */
    /* USER CODE BEGIN 2 */
    /* Use Systick arm timer and interrupt to tick step() functions of the
     * Simulink model. */
    /* Fundamental sample time is set to: '0.001' s */
    if (SysTick_Config((uint32_t)(SystemCoreClock/1000.0))) {
        autoReloadTimerLoopVal_S = 1;
        do {
            autoReloadTimerLoopVal_S++;
        } while ((uint32_t)(SystemCoreClock/1000.0)/autoReloadTimerLoopVal_S >
                 SysTick_LOAD_RELOAD_Msk);
}

```

Listing C.6: Model.c

### 3. STM32 config.h

```

/*
 * File: STM32_Config.h
 *
 * Code generated for Simulink model :Final_PLL_Single_Phase.
 *
 * Model version      : 1.8
 * Simulink Coder version   : 9.3 (R2020a) 18-Nov-2019
 * TLC version       : 9.3 (Jan 23 2020)
 * C/C++ source code generated on  : Fri May 28 20:30:58 2021
 *
 * Target selection: stm32.tlc
 * Embedded hardware selection: STM32CortexM
 * Code generation objectives:
 *   1. Execution efficiency
 *   2. RAM efficiency

```

```

* Validation result: Not run
*
*
*
*
*****
```

\*/

```

#ifndef RTW_HEADER_STM32_Config_h_
#define RTW_HEADER_STM32_Config_h_
#include "stm32f4xx.h"
#include "stm32f4xx_hal.h"

/* For Error_Handler() declaration. */
#include "main.h"
#include "rtwtypes.h"
#endif /* RTW_HEADER_STM32_Config_h_ */

/* File trailer for Real-Time Workshop generated code.
 *
 * [EOF] STM32_Config.h
 */
```

Listing C.7: Model.c

#### 4 stm32xxxx-it.c

```

/*
 * File: stm32xxxx_it.c
 *
 * Code generated for Simulink model :Final_PLL_Single_Phase.
 *
 * Model version      : 1.8
 * Simulink Coder version    : 9.3 (R2020a) 18-Nov-2019
 * TLC version       : 9.3 (Jan 23 2020)
 * C/C++ source code generated on : Fri May 28 20:30:58 2021
 *
 * Target selection: stm32.tlc
 * Embedded hardware selection: STM32CortexM
 * Code generation objectives:
 *   1. Execution efficiency
```

```

*      2. RAM efficiency
* Validation result: Not run
*
*
*
*
*****
```

\*/

```

/**  

 * @brief This function handles System tick timer.  

 */  

void SysTick_Handler(void)  

{  

    /* This section of code is going to be merged by the STM32CubeMX tool. */  

    /* USER CODE BEGIN SysTick_IRQn 0 */  

    {  

        extern volatile uint32_t remainAutoReloadTimerLoopVal_S;  

  

        /* Manage number of loop before interrupt has to be processed. */  

        if (remainAutoReloadTimerLoopVal_S) {  

            remainAutoReloadTimerLoopVal_S--;  

        }  

    }  

  

    /* USER CODE END SysTick_IRQn 0 */  

  

    /* USER CODE BEGIN SysTick_IRQn 1 */  

  

    /* USER CODE END SysTick_IRQn 1 */  

}  

  

/* File trailer for Real-Time Workshop generated code.  

*  

* [EOF] stm32xxxx_it.c  

*/

```

Listing C.8: Model.c

# Appendix D

## SRF-PLL simulink block parameter and configurations

Block parameters for SRF-PLL simulink model

Code generation configurations



Figure D.1:  $\alpha\beta 0$  to DQ0 block



Figure D.2: low pass filter used in generation of alpha beta signals



Figure D.3: Integrator



Figure D.4: fcn block (cos)



Figure D.5: PI controller



Figure D.6: STM32CubeMX model configuration file



Figure D.7: Code generation parameters

# Bibliography

- [1] H. Zhang, T. Van Gerven, J. Baeyens, J. Degrève, Photovoltaics: reviewing the european feed-in-tariffs and changing pv efficiencies and costs, *The Scientific World Journal* 2014 (2014).
- [2] R. Stevenson, Slimmer solar cells, *Ingenia* 53 (2014) 33–37.
- [3] M. Kamil, Grid-connected solar microinverter reference design using a dspic® digital signal controller, *Microchip Application Notes AN1338* (2010).
- [4] S. U. M. UM1472, Stm32f4discovery, stm32f4 high performance discovery board (2012).
- [5] R. Gammoudi, N. Rebei, O. Hasnaoui, Stm microcontroller implementation of mppt algorithms for stand-alone pv water pumping system, *International Journal of Engineering and Technical Research (IJETR)* (2015).
- [6] S. Motahhir, Contribution to the optimization of energy withdrawn from a pv panel using an embedded system, Ph.D. thesis, Université Sidi Mohamed Ben Abdellah (2018).
- [7] W. Dengsheng, W. Lidi, H. Chuncheng, L. Tong, Z. Chenglong, L. Chenyang, Research and design of pv mppt based on stm32, in: 2018 Chinese Control And Decision Conference (CCDC), IEEE, 2018, pp. 4971–4974.
- [8] Y. Cheddadi, F. Errahimi, N. Es-sbai, Design and verification of photovoltaic mppt algorithm as an automotive-based embedded software, *Solar Energy* 171 (2018) 414–425.
- [9] A. Durgadevi, S. Arulselvi, S. Natarajan, Study and implementation of maximum power point tracking (mppt) algorithm for photovoltaic systems, in: 2011 1st International Conference on Electrical Energy Systems, IEEE, 2011, pp. 240–245.
- [10] A. Tamkoria, N. Kumar, Design and analysis of microcontroller-based, maximum power point tracker for photovoltaic power systems, *IJSR* (2016).
- [11] Current status: Ministry of new and renewable energy, government of india (2021).  
URL <https://mnre.gov.in/solar/current-status/>

- [12] Solar off-grid (2021).  
URL <https://mnre.gov.in/solar/solar-offgrid>
- [13] Solar on-grid (2021).  
URL <https://mnre.gov.in/solar/solar-ongrid>
- [14] Solar energy (May 2021).  
URL [https://en.wikipedia.org/wiki/Solar\\_energy](https://en.wikipedia.org/wiki/Solar_energy)
- [15] R. N. Castellano, Solar panel processing, Archives contemporaines, 2010.
- [16] A. Yadav, P. Kumar, M. Rpsgoi, Enhancement in efficiency of pv cell through p&o algorithm, International Journal for Technological Research in Engineering 2 (2015) 2642–2644.
- [17] N. \*, Inverters: Working, different types, circuit working and its applications (May 2019).  
URL <https://www.elprocus.com/what-is-an-inverter-types-circuit-diagram-applications/>
- [18] Solar inverter - types of solar inverters in india (May 2018).  
URL <https://www.oorjan.com/blog/2018/04/09/types-solar-inverter-india/>
- [19] M. J. M. Al-Rubaye, V. Gino Morais Araujo, J. Kadhim Abed, A. Van den Bossche, Review different types of mppt techniques for photovoltaic systems, in: International Conference on Sustainable Energy and Environment Sensing (SEES 2018), 2018, p. 7.
- [20] aimagin (2017). [link].  
URL <https://waijung1.aimagin.com/>
- [21] Truestudio (2021).  
URL <https://www.st.com/en/development-tools/truestudio.html>
- [22] Stsw-link004 (2021).  
URL <https://www.st.com/en/development-tools/stsw-link004.html>
- [23] J. Rocabert, A. Luna, F. Blaabjerg, P. Rodriguez, Control of power converters in ac microgrids, IEEE transactions on power electronics 27 (11) (2012) 4734–4749.
- [24] J. Schlabach, D. Blume, T. Stephanblome, Voltage quality in electrical power systems, Vol. 241, IET, 2001.
- [25] F. Cupertino, E. Lavopa, P. Zanchetta, M. Sumner, L. Salvatore, Running dft-based pll algorithm for frequency, phase, and amplitude tracking in aircraft electrical systems, IEEE Transactions on industrial Electronics 58 (3) (2010) 1027–1035.
- [26] G.-C. Hsieh, J. C. Hung, Phase-locked loop techniques. a survey, IEEE Transactions on industrial electronics 43 (6) (1996) 609–615.

- [27] X.-Q. Guo, W.-Y. Wu, H.-R. Gu, Phase locked loop and synchronization methods for grid-interfaced converters: a review, *Przeglad Elektrotechniczny* 87 (4) (2011) 182–187.
- [28] R. J. Devi, S. S. Kadam, Phase locked loop for synchronization of inverter with electrical grid: a survey, *International Journal of Engineering Research & Technology (IJERT)* 4 (2) (2015) 352–358.
- [29] S. Golestan, M. Monfared, F. D. Freijedo, Design-oriented study of advanced synchronous reference frame phase-locked loops, *IEEE Transactions on Power Electronics* 28 (2) (2012) 765–778.
- [30] A. Ghoshal, V. John, A method to improve pll performance under abnormal grid conditions, *Proc. NPEC* 7 (2007) 17–19.
- [31] F. González-Espín, E. Figueres, G. Garcerá, An adaptive synchronous-reference-frame phase-locked loop for power quality improvement in a polluted utility grid, *IEEE Transactions on Industrial Electronics* 59 (6) (2011) 2718–2731.
- [32] S. M. Silva, B. M. Lopes, R. P. Campana, W. Bosventura, et al., Performance evaluation of pll algorithms for single-phase grid-connected systems, in: Conference Record of the 2004 IEEE Industry Applications Conference, 2004. 39th IAS Annual Meeting., Vol. 4, IEEE, 2004, pp. 2259–2263.
- [33] S. Jain, P. Agarwal, H. Gupta, A survey of harmonics: Indian scenario, in: Proceedings of the IEEE INDICON 2004. First India Annual Conference, 2004., IEEE, 2004, pp. 84–89.