Contenido principal

Induction Motor

Three-phase induction motor

  • Induction Motor block

Libraries:
Powertrain Blockset / Propulsion / Electric Motors and Inverters
Motor Control Blockset / Electrical Systems / Motors

Description

The Induction Motor block implements a three-phase induction motor. The block uses the three-phase input voltages to regulate the individual phase currents, allowing control of the motor torque or speed.

Note

The block parameters use per-phase values of a star-equivalent induction motor.

By default, the block sets the Simulation Type parameter to Continuous to use a continuous sample time during simulation. If you want to generate code for fixed-step double- and single-precision targets, considering setting the parameter to Discrete. Then specify a Sample Time, Ts parameter.

Three-Phase Sinusoidal Model Electrical System

The block implements equations that are expressed in a stationary rotor reference (dq) frame. The d-axis aligns with the a-axis. All quantities in the rotor reference frame are referred to the stator.

Three-phase induction motor currents and magnetic fields

The block uses these equations to calculate the electrical speed (ωem) and slip speed (ωslip).

ωem=Pωmωslip= ωsynωem

To calculate the dq rotor electrical speed with respect to the rotor A-axis (dA), the block uses the difference between the stator a-axis (da) speed and slip speed:

ωdA= ωda ωem

To simplify the equations for the flux, voltage, and current transformations, the block uses the rotor A-axis reference frame:

ωda=ωemωdA=0

CalculationEquation
Flux

ddt[λsdλsq]= [vsdvsq] Rs[isdisq] ωda[0110][λsdλsq]ddt[λrdλrq]= [vrdvrq] Rr[irdirq] ωdA[0110][λrdλrq]

[λsdλsqλrdλrq]= [Ls00LsLm00LmLm00LmLr00Lr][isdisqirdirq]

Current

[isdisqirdirq]= (1Lm2 LrLs)[Lr00LrLm00LmLm00LmLs00Ls][λsdλsqλrdλrq]

Inductance

Ls= Lls+LmLr= Llr+Lm

Electromagnetic torque

Te=PLm(isqird isdirq)

Power invariant dq transformation to ensure that the dq and three phase powers are equal

[vsdvsq]= 23 [cos(Θda)cos(Θda2π3)cos(Θda+2π3)sin(Θda)sin(Θda2π3)sin(Θda+2π3)][vavbvc]

[iaibic]= 23  [cos(Θda)sin(Θda)cos(Θda2π3)cos(Θda+2π3)sin(Θda2π3)sin(Θda+2π3)][isdisq]

The equations use these variables.

ωm

Angular velocity of the rotor (rad/s)

ωem

Electrical rotor speed (rad/s)

ωslip

Electrical rotor slip speed (rad/s)

ωsyn

Synchronous rotor speed (rad/s)

ωda

dq stator electrical speed with respect to the stator a-axis (rad/s)

ωdA

dq stator electrical speed with respect to the rotor A-axis (rad/s)

Θda

dq stator electrical angle with respect to the stator a-axis (rad)

ΘdA

dq stator electrical angle with respect to the rotor A-axis (rad)

Lq, Ld

q- and d-axis inductances (H)

Ls

Stator inductance (H)

Lr

Rotor inductance (H)

Lm

Magnetizing inductance (H)

Lls

Stator leakage inductance (H)

Llr

Rotor leakage inductance (H)

vsq, vsd

Stator q- and d-axis voltages (V)

isq, isd

Stator q- and d-axis currents (A)

λsq, λsd

Stator q- and d-axis flux (Wb)

irq, ird

Rotor q- and d-axis currents (A)

λrq, λrd

Rotor q- and d-axis flux (Wb)

va, vb, vc

Stator voltage phases a, b, c (V)

ia, ib, ic

Stator currents phases a, b, c (A)

Rs

Resistance of the stator windings (Ohm)

Rr

Resistance of the rotor windings (Ohm)

P

Number of pole pairs

Te

Electromagnetic torque (Nm)

Mechanical System

The motor angular velocity is given by:

ddtωm=1J(TeTfFωmTm)dθmdt=ωm

The equations use these variables.

J

Combined inertia of motor and load (kgm^2)

F

Combined viscous friction of motor and load (N·m/(rad/s))

θm

Motor mechanical angular position (rad)

Tm

Motor shaft torque (Nm)

Te

Electromagnetic torque (Nm)

Tf

Motor shaft static friction torque (Nm)

ωm

Angular mechanical velocity of the motor (rad/s)

Power Accounting

For the power accounting, the block implements these equations.

Bus Signal DescriptionVariableEquations

PwrInfo

PwrTrnsfrd — Power transferred between blocks

  • Positive signals indicate flow into block

  • Negative signals indicate flow out of block

PwrMtr

Mechanical power

Pmot

Pmot= ωmTe
PwrBus

Electrical power

Pbus

Pbus= vania+ vbnib+vcnic

PwrNotTrnsfrd — Power crossing the block boundary, but not transferred

  • Positive signals indicate an input

  • Negative signals indicate a loss

PwrElecLoss

Resistive power loss

Pelec

Pelec= (Rsisd2+Rsisq2+Rrird2+Rrirq2)
PwrMechLoss

Mechanical power loss

Pmech

When Port Configuration is set to Torque:

Pmech= (ωm2F+ |ωm|Tf)

When Port Configuration is set to Speed:

Pmech= 0 

PwrStored — Stored energy rate of change

  • Positive signals indicate an increase

  • Negative signals indicate a decrease

PwrMtrStored

Stored motor power

Pstr

Pstr= Pbus+ Pmot+ Pelec + Pmech

The equations use these variables.

Rs

Stator resistance (Ohm)

Rr

Rotor resistance (Ohm)

ia, ib, ic

Stator phase a, b, and c current (A)

isq, isd

Stator q- and d-axis currents (A)

van, vbn, vcn

Stator phase a, b, and c voltage (V)

ωm

Angular mechanical velocity of the rotor (rad/s)

F

Combined viscous damping of motor and load (N·m/(rad/s))

Te

Electromagnetic torque (Nm)

Tf

Combined friction torque of motor and load (Nm)

Ports

Input

expand all

Load torque on the motor shaft, Tm, in N·m.

Dependencies

To create this port, select Torque for the Port configuration parameter.

Angular velocity of the rotor, ωm, in rad/s.

Dependencies

To create this port, select Speed for the Port configuration parameter.

Stator terminal voltages, Va, Vb, and Vc, in V.

Output

expand all

The bus signal contains these block calculations.

Signal DescriptionVariableUnits

IaStator

Stator phase current A

ia

A

IbStator

Stator phase current B

ib

A

IcStator

Stator phase current C

ic

A

IdSync

Direct axis current

id

A

IqSync

Quadrature axis current

iq

A

VdSync

Direct axis voltage

vd

V

VqSync

Quadrature axis voltage

vq

V

MtrSpd

Angular mechanical velocity of the rotor

ωm

rad/s

MtrMechPos

Rotor mechanical angular position

θm

rad

MtrPos

Rotor electrical angular position

θe

rad

MtrTrq

Electromagnetic torque

Te

N·m

PwrInfo

PwrTrnsfrd

PwrMtr

Mechanical power

Pmot

W
PwrBus

Electrical power

Pbus

W

PwrNotTrnsfrd

PwrElecLoss

Resistive power loss

Pelec

W
PwrMechLoss

Mechanical power loss

Pmech

W

PwrStored

PwrMtrStored

Stored motor power

Pstr

W

Phase a, b, c current, ia, ib, and ic, in A.

Motor torque, Tmtr, in N·m.

Dependencies

To create this port, select Speed for the Port configuration parameter.

Angular speed of the motor, ωmtr, in rad/s.

Dependencies

To create this port, select Torque for the Port configuration parameter.

Parameters

expand all

Block Options

By default, the block uses a continuous sample time during simulation. If you want to generate code for single-precision targets, considering setting the parameter to Discrete.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: sim_type
Values: Continuous (default) | Discrete
Data Types: character vector

Dependencies

Setting Simulation Type to Discrete creates the Sample Time, Ts parameter.

Integration sample time for discrete simulation, in s.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: Ts
Values: 0.001 (default) | scalar
Data Types: double

Dependencies

Setting Simulation Type to Discrete creates the Sample Time, Ts parameter.

This table summarizes the port configurations.

Port ConfigurationCreates Input PortCreates Output Port

Torque

LdTrq

MtrSpd

Speed

Spd

MtrTrq

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: port_config
Values: Torque (default) | Speed
Data Types: character vector

Parameters

Motor pole pairs, P.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: P
Values: 2 (default) | scalar
Data Types: double

Stator resistance, RS, in ohms and leakage inductance, Lls, in H.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: Zs
Values: [1.77 0.0139] (default) | vector
Data Types: double

Rotor resistance, Rr, in ohms and leakage inductance, Llr, in H.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: Zr
Values: [1.34 0.0121] (default) | vector
Data Types: double

Magnetizing inductance, Lm, in H.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: Lm
Values: 0.3687 (default) | scalar
Data Types: double

Mechanical properties of the rotor:

  • Inertia, J, in kg·m^2

  • Viscous damping, F, in N·m/(rad/s)

  • Static friction, Tf, in N·m

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: mechanical
Values: [0.001 0 0] (default) | vector
Data Types: double

Dependencies

To enable this parameter, select Torque for the Port configuration.

Initial Values

Initial rotor angular position, θm0, in rad.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: theta_init
Values: 0 (default) | scalar
Data Types: double

Initial angular velocity of the rotor, ωm0, in rad/s.

Programmatic Use

To set the block parameter value programmatically, use the set_param function.

To get the block parameter value programmatically, use the get_param function.

Parameter: omega_init
Values: 0 (default) | scalar
Data Types: double

Dependencies

To enable this parameter, select Torque for the Port configuration.

References

[1] Mohan, Ned. Advanced Electric Drives: Analysis, Control and Modeling Using Simulink. Minneapolis, MN: MNPERE, 2001.

Extended Capabilities

expand all

C/C++ Code Generation
Generate C and C++ code using Simulink® Coder™.

Version History

Introduced in R2017a