联系方式

您当前位置:首页 >> Matlab编程Matlab编程

日期:2024-12-12 09:28

School of Engineering 1 of 13

Control of an Electric Drive in Simulink

Introduction

Simulink is a dynamic simulation environment of Matlab, in which complex

physical systems can be modelled through differential equations and their

behaviour can be analysed. An electric drive can also be modelled in Simulink

through the equations governing its operation. However, as the electric drive

consists of different subsystems, such as an electric motor, a power electronic

converter, a mechanical load, each of these subsystems can be modelled

separately before combining them into a single model to emulate the behaviour

of a complete electric drive.

Fig. 1 shows the basic structure of an electric drive. The type of the motor

determines the configuration of the power converter, the number of sensors,

and the control algorithm. For example, if the motor is a dc machine, then the

power converter would be a half-bridge (two-quadrant drive) or a full H-bridge

(four-quadrant drive), there will be one current sensor and one dc-link voltage

sensor. The position/speed of the rotor is acquired through a shaft-mounted

position sensor.

Fig. 1 A typical electric drive

Using the blocks and tools offered by Simulink, the physical behaviour of the

blocks shown in Fig. 1 can be emulated. The scheme of Fig. 1 in terms of Simulink

blocks is shown in Fig. 2. The highlighted areas represent different subsystems

of Fig. 1. The area labelled ‘Display’ shows a scope on which different quantities

can be plotted as a function of time to visualize the time evolution of different

variables. The subsystems are briefly described below.

Motor Load Power

Converter

Control

algorithm

User set

points

Sensors

Conversion

to digital

domainControl of an Electric Drive in Simulink

School of Engineering 2 of 13

Fig. 2 Simulink block diagram of a dc motor drive

The motor

In Fig. 2, a dc motor is shown as the actuator, but it can also be any other

electrical machine, such as a three-phase permanent magnet synchronous

motor. The details of the ‘Motor’ subsystem are shown in Fig. 3. As observed,

they are the electrical and mechanical state equations of a separately excited

constant flux dc motor. The applied armature voltage is the electrical actuation

signal and the torque produced by the machine acts as the mechanical actuation

signal. The load torque is shown as a separate input, which can be either a

constant, a step function or any other load torque profile depending on the

application being analysed. The outputs of the dc motor block are the armature

current and the rotor mechanical position. The user can choose to have the

mechanical speed as another output.

The parameters of the dc motor can be set/changed by double clicking on the

block and just inputting the new values in the dialog box. Fig. 4 shows the dialog Control of an Electric Drive in Simulink

School of Engineering 3 of 13

box for the dc motor parameters. Since all the parameters shown in Fig. 4 are in

their standard SI units, the inputs (voltage and load torque) and the outputs of

(current and angle) of the motor block should also be interpreted in their

standard SI units.

Fig. 3 Simulink block implementation of the state equations of a constant flux dc motor

Fig. 4 Parameter dialog box for a constant flux dc motor Control of an Electric Drive in Simulink

School of Engineering 4 of 13

The power converter

For a dc motor drive, the power electronic converter can consist of a half-bridge

or a full H-bridge depending on whether the motor is required to rotate in one

direction only (half-bridge) or in both directions (full-bridge). To preserve

generality of the implemented drive system, a full H-bridge is simulated to give

maximum flexibility to the user. The power converter block also includes a pulse

width modulation (PWM) scheme that converts the duty cycles for the two legs

of the H-bridge (da and db) into pulses of varying widths. The dc-link voltage is

defined as a constant input decided by the user. The modulator block’s

parameter dialog box is shown in Fig. 5, which requires the user to input the

switching frequency in Hz. The details of the modulator block are shown in Fig. 6.

Fig. 5 Parameter dialog box for the modulator

Fig. 6 H-bridge modulation scheme Control of an Electric Drive in Simulink

School of Engineering 5 of 13

Sensors and ADCs

In electric drives, voltage, current and position sensors are used to measure the

dc-link voltage, the load currents and the shaft position respectively. Since these

quantities are in the analog domain while the control, in modern electric drives,

is in digital domain, an analog to digital conversion is necessary. Analog to digital

converters (ADCs) do this conversion and provide the controller with

measurements at a fixed sampling frequency (decided by the drive designer).

The sensors measuring the voltage and current also introduce noise on the

measurements, which is normally a zero-mean, constant variance white noise.

In addition to the white noise on the analog signal, the noise due to the

quantization effect of the ADCs impacts the measurement in the digital domain

further. All these effects are simulated inside the ‘Sensing subsystem’ of Fig. 2

as detailed in Fig. 7.

For the shaft position measurement, incremental or absolute position sensors

are normally used in electric drives. The resolution of the position signal

available to the controller depends on the number of pulses per revolution of

the incremental encoder or the bit resolution of the absolute encoder. The fixed

resolution of the position sensors introduces a quantization noise on the

position signal. This quantization noise is emulated in the simulation for an

incremental encoder.

Fig. 7 Sensor subsystem structure Control of an Electric Drive in Simulink

School of Engineering 6 of 13

It can be noticed from Fig. 7 that there is only one input current ia but two other

currents ib and ic are included to allow the user to simulate a three-phase

system. For a three-phase machine, the currents ib and ic must also be added as

inputs to the block rather than constants as shown in Fig. 7.

Fig. 8 shows the parameter dialog box for the sensing subsystem. The range of

the current and voltage measurement must be set such that this range is not

exceeded at any time. The resolution of the ADCs is usually 12-bit in commercial

electric drives but can also be 14 to 16-bit in case of high-end drives. The pulseper-revolution

(ppr) value for incremental encoders starts from as low as 12ppr

for very low-cost encoders and can be in excess of 10,000ppr for devices used

for precision applications.

Fig. 8 Sensor subsystem parameters

Control algorithm

The control algorithm for the electric drives is normally executed on a digital

signal processor (DSP) at a fixed control execution frequency, usually at the

switching frequency of the power converter. The control routines are normally

written in a high-level language such as C. The block labelled ‘Control’ in Fig. 2

emulates the behaviour of a DSP that samples the input data at a fixed frequency

and outputs the duty cycles for the power converter after one execution cycle.

The details of the block are shown in Fig. 9. Control of an Electric Drive in Simulink

School of Engineering 7 of 13

This block consists of a Matlab s-function. S-functions (system-functions)

provide a powerful mechanism for extending the capabilities of the Simulink

environment. An S-function is a computer language description of a Simulink

block written in MATLAB, C, C++, or Fortran. The block labelled ‘simple_control’

is like any other Simulink block but its behaviour can be fully controlled by the

user by modifying the program that describes it.

Fig. 9 Details of the block labelled ‘Control’ in Fig. 2

In electric drives, the control algorithm is executed on a DSP that can be

programmed in C, BASIC and assembly languages with C being the most

commonly used language. The s-function feature of Simulink is therefore used

to program the functionality of the block ‘simple_control’ in C.

The program describing an s-function block must follow a certain structure and

must contain some pre-defined functions and definitions. To program the

s-function block properly, it is recommended to start with an example code such

as ‘sfuntmpl_doc.c’ or ‘sfuntmpl_basic.c’ available from Matlab and modify

according to the requirements of the application. The available templates are

for a level 2 s-function.

The number of inputs, outputs and parameters of the s-function block are

defined inside the C program and they must match the inputs and outputs in Control of an Electric Drive in Simulink

School of Engineering 8 of 13

Simulink. The parameters passed by Simulink to the s-function are listed in the

dialog box of the s-function as shown in Fig. 10. In Fig. 10, the only parameter

that Simulink passes to the s-function is Ts, the sampling time. Inside the C

program describing the s-function, this parameter Ts is used to define the

execution sample time of the s-function block i.e. the block is executed every Ts

seconds.

Since the execution time of the s-function must match the switching period of

the power converter and the sampling frequency of the current, voltage and

position measurements, the parameter Ts is defined as a global constant for the

simulation. To change this parameter, go to: File->Model Properties->Model

Properties, click on the tab Callbacks and then click InitFcn.

Fig. 10 Parameter dialog box for the s-function shown in Fig. 9

Some screenshots from the C code for the s-function ‘simple_control’ are shown

below with a brief explanation of the functions, variables and parameters.

S_FUNCTION_NAME: this constant defines the name of the s-function and it

must correspond to the name of the file (without the extension .c) which is also

used as the s-function name in the block (see Fig. 10). Control of an Electric Drive in Simulink

School of Engineering 9 of 13

The header files, such as aux_funcs.h and Constants.h are user-defined .h files

that contain definitions of functions and constants used in the code. The two

header files are included as an example, others can be defined and included as

necessary.

Fig. 11 Code lines defining the type of the s-function, inputs, outputs and parameters

U(element): this function macro gets a pointer to the vector of inputs from

Simulink and allows to get the inputs to local variables.

NUM_INPUTS, NUM_OUTPUTS, NUM_PARAMS: these must correspond to the

inputs, outputs and parameters of the s-function block in Simulink. If these

constants do not match the s-function block’s conditions, Matlab will generate

an error and will not compile the code for execution.

The parameters passed by Simulink to the function can be accessed as elements

of the parameter array starting from 0. For example, the first parameters will be

read in as: (mxGetPr(ssGetSFcnParam(S,0))[0]). The second parameter can be

read in as: (mxGetPr(ssGetSFcnParam(S,0))[1]).

The global variables should be defined outside of any functions so that they’re

accessible to all the functions. In Fig. 11, TS, TS_INV and thm_prev are global

variables. Variables that must hold their values between executions can be

declared as global, although it is not strictly necessary.

In Fig. 12, the sizes of the inputs, outputs, sample times, and other arrays are

defined. It is important to set the number of sample times to 1 through the Control of an Electric Drive in Simulink

School of Engineering 10 of 13

function ssSetNumSampleTimes(S, 1); as the s-function is intended to be a

single-execution-rate block in our application of an electric drive. The sample

time of the s-function is then set by calling ssSetSampleTime(S, 0, Ts); as shown

in Fig. 13. The figure also shows the initialization conditions that the user can

set, for example, assigning initial values to the global variables.

Fig. 12 Definition of the s-function code array sizes

Fig. 13 s-function sample time and initialization conditions Control of an Electric Drive in Simulink

School of Engineering 11 of 13

The outputs for the model are calculated through the function mdlOutputs

shown in Fig. 14. First, the inputs from the Simulink environment are read into

the local variables and arrays. The calculations necessary for the control of an

electric drive are performed on these local variables before passing the outputs

to Simulink. This is the function where almost all of the code related to the

drive’s control should reside.

Fig. 14 Some code lines for mdlOutputs function

To complete the process of building a Simulink block from a C program, the code

must be compiled into a Matlab executable file. The command used for this is

mex (that stands for Matlab executable). This command must be called in the

Matlab command window by ensuring that the folder in which the code files are

located is selected as the ‘current folder’ in Matlab (see Fig. 15). All the .c and .h

files that contain the functions used inside the main file ‘simple_control.c’

should be within the current folder and all .c source files must be included as Control of an Electric Drive in Simulink

School of Engineering 12 of 13

input arguments of the mex command as shown in Fig. 15, where aux_funcs.c is

the second .c source file that must be compiled along with simple_control.c.

Every time anything is changed in the code (e.g. changing a parameter in a .h file

or adding/deleting a line in any .c file of the project), the mex command should

be repeated before expecting a change in the behaviour of the s-function block.

This process is similar to compiling and building the project files in a DSP code.

Fig. 15 Instructions for compiling the C code into a mex file

A C compiler will be needed to compile the code into a mex file. There are

several compilers available from Mathworks, any of these can be used for

compiling the code.

Once successfully mexed, the current folder will have a mexw file with the name

of the s-function e.g. simple_control.mexw64. This file will be accessed by

Simulink during simulation as the contents of the S-function block shown in

Fig. 9. Control of an Electric Drive in Simulink

School of Engineering 13 of 13

The task

Your task is to understand the model and the basic project you are provided.

Simulate it with different conditions to enhance your understanding and be

familiar to the model and the C code. Then, starting from the basic project as

described above, develop the model and C code for the following objectives:

1) Armature current control of the dc motor

2) DC motor’s speed control

3) Apply different load torque profiles to test your speed control

4) DC motor’s position control (optional)

5) A model to simulate a three-phase PMSM drive (advanced)

6) Simulate vector control of a three-phase PMSM (advanced)


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:821613408 微信:horysk8 电子信箱:[email protected]
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:horysk8