AN1017

AN1017
Sinusoidal Control of PMSM Motors with dsPIC30F DSC
Author:
Jorge Zambada
Microchip Technology Inc.
INTRODUCTION
This application note describes a method of driving a
sensored Permanent Magnet Synchronous Motor
(PMSM) with sinusoidal currents controlled by a
dsPIC30F Digital Signal Controller (DSC). The motor
control firmware uses the dsPIC30F peripherals while
the mathematical computations are performed by the
DSP engine. The firmware is written in ‘C’ language,
with some subroutines in assembly to take advantage
of the special DSP operations of the dsPIC30F.
APPLICATION FEATURES
• Sinusoidal current generation for controlling
PMSM motor phases using Space Vector
Modulation (SVM)
• Synchronization of sinusoidal voltages to PMSM
motor position
• Four-quadrant operation allowing forward,
reverse and braking operation
• Closed-loop speed regulation using digital
Proportional Integral Derivative (PID) control
• Phase advance operation for increased speed
range
• Fractional math operations performed by the DSP
engine of the dsPIC® DSC
MOTOR CONTROL WITH DIGITAL
SIGNAL CONTROLLERS
for motor control: Motor Control Pulse Width Modulation (MCPWM) and high-speed A/D Converter. The
DSP engine of the dsPIC30F2010 supports the
necessary fast mathematical operations.
The dsPIC30F2010 family member is a 28-pin 16-bit
DSC specifically designed for low-cost/high efficiency
motor control applications. The dsPIC30F2010
provides these key features:
• 30 MIPS processing performance
• Six independent or three complementary pairs of
dedicated Motor Control PWM outputs
• Six-input, 1 Msps ADC with simultaneous sampling capability from up to four inputs
• Multiple serial communications: UART, I2C™ and
SPI
• Small package (6 mm x 6 mm QFN) for
embedded control applications
• DSP engine for fast response in control loops
HARDWARE REQUIRED
You will need the following hardware to implement the
described motor control application:
• PICDEM™ MCLV Development Board (Figure 1)
• Hurst DMB0224C10002 BLDC Motor
• 24 VDC Power Supply
You can purchase these items from Microchip as a
complete kit or as individual components. Check the
Development Tools section of the Microchip web site
for ordering information.
FIGURE 1:
PICDEM™ MCLV
DEVELOPMENT BOARD
The dsPIC30F Motor Control family is specifically
designed to control the most popular types of motors,
including AC Induction Motors (ACIM), Brushed DC
Motors (BDC), Brushless DC Motors (BLDC) and Permanent Magnet Synchronous Motors (PMSM), to list a
few. Several application notes have been published for
ACIM operation (AN984, AN908 and GS004) and
Brushless DC Motor Control operation (AN901, AN957
and AN992) based on the dsPIC30F motor control family. These application notes are available on the the
Microchip web site (www.microchip.com).
This application note demonstrates how the
dsPIC30F2010 is used to control a sensored PMSM
motor with sinusoidal voltages. The design takes
advantage of dsPIC30F peripherals specifically suited
© 2005 Microchip Technology Inc.
DS01017A-page 1
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
It is strongly recommended that you read the
“PICDEM™ MCLV Development Board User’s Guide”
(DS51554) to fully understand the hardware topology
being used in this application note. This User’s Guide
can be downloaded from the Microchip web site.
On the low side, the voltage limit is 10V. On the high
side, the voltage limit is 48V. It is important to note that
the heat sink on the IGBTs have very limited heat dissipation, so high power requirements may not be easily
met with the PICDEM™ MCLV development board.
Figure 2 is a simplified system block diagram for a
Sinusoidal PMSM motor control application. This
diagram will help you develop your own hardware.
To use the PICDEM™ MCLV development board for this
application, use the jumper settings shown in Table 1 and
the motor connections shown in Table 2 and Table 3.
FIGURE 2:
TABLE 1:
SYSTEM BLOCK DIAGRAM
dsPIC30F2010
PWM3H
PWM3L
Phase A
PWM2H
3-Phase
Phase B
Inverter
Phase C
PWM2L
3-Phase
PMSM
Motor
PWM1H
PWM1L
IBUS
AN1
R14
AN2
RC14
Reference
Speed
S2
R26
+5V
RB4/IC7
RB5/IC8
Hall A R21
Position for Sinusoidal
Control (dsPIC® DSC
Sensored)
Jumpers
J7, J8, J11
Open
J12, J13, J14
Open
J15, J16, J17, J10
Open
J19
Short
TABLE 2:
Start/Stop
RB3/CN5
PICDEM™ MCLV
DEVELOPMENT BOARD
JUMPER SETTINGS
CONNECTIONS FOR MOTOR
WINDINGS*
R24 R23 R20
Hall B R22
Hall C R25
Connector J9
Position for Sinusoidal
Control (dsPIC® DSC
Sensored)
M3
Phase A (White)
M2
Phase B (Black)
Salient aspects of this topology are:
M1
Phase C (Red)
• Potentiometer R14 selects the desired speed
(Reference Speed)
• Rotor position is detected using Hall effect
sensors connected to pins RB3, RB4 and RB5
• Current feedback is provided through a simple
operational amplifier circuit
• Fault input is received through a comparator circuit connected with the current feedback circuit.
The current is sensed using a 0.1 ohm resistor
(R26)
G
You can easily adjust the values of the resistors to
accommodate the current capabilities of the motor
being used for your application. The motor drive circuit,
on the other hand, is designed to drive a 24V PMSM
motor. You can change the hardware to meet the drive
requirement of a specific motor.
Note:
Refer to the “PICDEM™ MCLV Development Board User’s Guide” (DS51554) for
details on how to change the hardware for
use with motors greater or less than 24V.
DS01017A-page 2
Ground (Green) if available
TABLE 3:
MOTOR CONNECTIONS FOR
HALL SENSORS*
Connector J9
+5V
Position for Sinusoidal
Control (dsPIC® DSC
Sensored)
Red
GND
Black
HA
White
HB
Brown
HC
Green
*
The colors referenced in Tables 2 and 3 for
the motor windings and hall sensors,
respectively, pertain to the Hurst 24V motor
available from Microchip. The ground wire
is sometimes not available on some
motors.
After your code is developed and you have downloaded it to the dsPIC30F, you will need to press switch
S2 to start and stop the motor. The potentiomer marked
REF (R14) sets the required speed and direction of
rotation of the motor. The motor does not need to stop
to change direction of rotation.
© 2005 Microchip Technology Inc.
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
PROGRAMMING THE dsPIC30F2010
WITH THE dsPICDEM™ MCLV
DEVELOPMENT BOARD
For a good introduction to BLDC motors and their basic
operating principles, see also AN885 “Brushless DC
(BLDC) Motor Fundamentals” (DS00885) .
The dsPICDEM MCLV development board allows you
to program the dsPIC30F2010 in-circuit. To program
the part, you must set DIP switch S4 to the PRGM position. When programming is complete, you must set the
DIP switch to the DEBUG position to execute the code.
If the IDC2 is connected to the PICDEM™ MCLV development board as a debugger, the connector at J6
should be attached. If you use MPLAB® ICD 2 as a
debugger, the RJ11 cable should be connected to the
board (J6). If you use MPLAB ICD 2 as a programmer
only, the RJ11 cable should be connected for programming the part and unplugged for normal program execution.
FIGURE 3:
The following configuration allows the application to
work on a PICDEM™ MCLV development board:
Oscillator Source:
Primary Oscillator
Primary Oscillator Mode:
XT w/PLL 16x
Comm Channel Select:
EMUC2 and EMUD2
Other settings can be enabled or disabled as needed,
or modified in the application.
BACKGROUND
Many consumer and industrial applications use the
BLDC motor because of its compact size, controllability
and high efficiency. Increasingly, it is used in automotive applications as part of a strategy to eliminate belts
and hydraulic systems, to increase functionality and to
improve fuel economy. In high-performance applications, such as machine tools and low noise fan
applications, the production of smooth torque is crucial.
The main disadvantage of BLDC motors, when low
torque ripple and quieter operation are required, is the
non-sinusoidal distribution of the stator windings.
BLDC motors with non-sinusoidal winding distribution
generate trapezoidal back-EMF, as shown in Figure 3.
Trapezoidal Back-EMF BLDC motors are specifically
designed to be driven with square voltages synchronized with the motor’s angular position. This control
method is commonly called six-step commutation.
It is assumed that you are familiar with the six-step
commutation technique, so no further elaboration is
offered in this application note. However, for more
detailed information on how to operate a BLDC motor
with six-step commutation, you can refer to these
additional Microchip application notes:
0
TRAPESOIDAL BACK-EMF
60
120
180
240
300
0
60
Phase A
Phase B
Phase C
Trapezoidal distribution of the motor windings of a
BLDC motor leads to torque ripple during motor operation since the current generation is also trapezoidal.
This torque ripple produces a small speed oscillation,
which generates audible noise. On the other hand,
sinusoidal Back-EMF BLDC motors, also known as
Permanent Magnet Synchronous Motors (PMSM) produce sinusoidal currents, which reduce the torque ripple, thus minimizing the audible noise. Figure 4 shows
the sinusoidal back-EMF voltages generated by a
motor with sinusoidal winding distribution.
FIGURE 4:
0
SINUSOIDAL BACK-EMF
60
120
180
240
300
0
60
Phase A
Phase B
Phase C
This application note assumes a 3-Phase PMSM motor
with sinusoidal back-EMF and three Hall effect
sensors.
• AN857 “Brushless DC Motor Control Made Easy”
(DS00857)
• AN957 “Sensored BLDC Motor Control Using
dsPIC30F2010” (DS00957)
© 2005 Microchip Technology Inc.
DS01017A-page 3
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
SENSORED OPERATION OF BLDC
MOTORS
To allow correct commutation of the motor, the absolute
position within an electrical cycle must be measured.
Three Hall effect sensors provide rotor position information. These sensors are distributed along the stator
in such a way that they generate six different logic
states per electrical cycle. The ratio between the electrical cycles and mechanical revolutions depends on
the number of motor pole pairs. For instance, the motor
used in this application note has five pole pairs, so
every mechanical revolution requires five electrical
cycles. For conventional energization (six-step commutation), six equally spaced commutations are
required per electrical cycle. This is usually implemented using three Hall effect or optical switches with
a suitable disk on the rotor. Continuous position information is not required. Only detection of the required
commutation instances is required. Figure 5 shows the
three sensor outputs along with the corresponding
voltage driving each motor winding.
FIGURE 5:
SIX-STEP COMMUTATION
FOR TRAPEZOIDAL BLDC
MOTORS
0
60
120
180 240
300
0
You can see that the voltage does not vary for each particular sector until a new motor position or combination
of Hall effect sensor is detected. For the technique
described in this application note, the three Hall effect
sensors detect the rotor position, as in the six-step
technique. However, instead of generating square
waves, a continuous changing voltage is generated
with a sine-wave shape. Figure 6 shows the resulting
sinusoidal voltage generation. The relation is shown
between the phase voltages and the three Hall effect
sensors. The amplitude of the sinusoidal voltages
determines the speed for a specific mechanical load in
the motor.
FIGURE 6:
VOLTAGE GENERATION
FOR SINUSOIDAL BLDC
MOTORS
0
60
120
180 240
300
0
60
HALL A
HALL B
60
HALL C
HALL A
+V
HALL B
VOLTAGE A
Float
-V
+V
HALL C
VOLTAGE B
Float
-V
+V
+V
VOLTAGE A
Float
-V
VOLTAGE C
Float
-V
+V
VOLTAGE B
Float
-V
+V
VOLTAGE C
Float
-V
DS01017A-page 4
© 2005 Microchip Technology Inc.
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
IMPLEMENTATION OF SINUSOIDAL
VOLTAGE CONTROL
control loop only controls Amplitude. The value of
Phase from the Phase Advance block is derived from
Hall effect sensor information to maintain the sinusoidal
voltage alignment to the rotor.
Figure 7 is a block diagram representation of the application software. When the motor is running, Measured
Speed is subtracted from Reference Speed (desired
speed) and the resulting error is processed by the PID
controller to generate the amplitude of the sine wave.
The Reference Speed is set by an external potentiometer, while the measured speed is derived from a Hall
effect sensor.
Using the software block diagram as a point of reference, the following sections of this application note
describe the software functionality in detail. The
description starts with the Main State machine, which
interacts with all the other software blocks using global
variables. Then the description focuses on speed measurements (Reference Speed and Measured Speed),
leading to an explanation of the software implementation of the PID controller. This discussion includes
some background information on PID control.
Once Amplitude is known, two additional parameters
are needed for sine generation. One parameter is the
Period of the sine wave, which is taken from one of the
Hall effect sensors. The other parameter is the Phase,
which is calculated using Phase Advance, depending
on speed range requirements and the rotor position
from the Hall effect sensors.
Next, calculation of the parameters for generating
three-phase sine waves is discussed, starting with the
rotor sector and phase advance calculations. And
finally, sinusoidal voltage generation using space vector modulation, with Amplitude, Phase and Period as
parameters, concludes the discussion.
The Amplitude variable sets the amount of motor
current and the resulting torque. An increase in torque
corresponds to an increase in speed. The speed
FIGURE 7:
SOFTWARE BLOCK DIAGRAM
dsPIC® DSC Software
Duty
Cycles
Reference
Speed
Error
+-
PID
Amplitude Sine-Wave
Generation
Phase
3-Phase
Voltages
MCPWM
10-Bit ADC
+5v
Period
3-Phase
Inverter
BLDC
Fault
Measured
Speed
Phase
Advance
Maximum
Phase Advance
Rotor
Sector
Rotor
Direction
Speed
Sector
Calculation
Calculation
Start/
Stop
Angular
Position
Main State
Machine
© 2005 Microchip Technology Inc.
Input Capture
GPIO
Period
Hall
Sensors
Low-Pass
Passive
Filters
DS01017A-page 5
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
MAIN STATE MACHINE
The state diagram shown in Figure 8 illustrates how
each interrupt (shown with heavy, dark lines) interacts
with the motor control software. At Power-on Reset, the
software initializes all the software variables and
enables all the peripherals to be used by the application. After the variables and peripherals are initialized,
the software enters the Motor Stopped state and
remains there until a Start command is executed from
the external push button (S2 pressed).
When S2 is pressed, the RunMotor() subroutine is
called, and the first process within this subroutine
(ChargeBootstraps()) is executed. The inverter
circuit uses N-channel MOSFETs for the upper and
lower devices. The bootstrap circuit generates a
floating voltage source for the gate drive of the upper
devices. The bootstrap supply voltage can be 15V
greater than the inverter voltage rail to ensure that the
upper devices turn on. The ChargeBootstraps()
subroutine is needed to charge the bootstrap capacitors each time the motor is energized for the first time
before running the motor. The ChargeBootstraps()
TABLE 4:
subroutine turns on the lower transistors for 10 ms, to
ensure voltage on these capacitors, and then transfers
control of the outputs to the PWM module.
Next, the variables used for controlling the motor are
initialized. Then the PID coefficients, error accumulation and controller output variables used in the PID
Speed Controller are initialized. In the RunMotor()
subroutine, the timer counters are also initialized to
zero, and the variables to capture the Hall effect sensor
period are also initialized. At the end of the subroutine,
the interrupt flags are cleared and the interrupts are
enabled.
Once the variables have been initialized in the
RunMotor() subroutine, all other activities within the
state machine are performed by Interrupt Service Routines (ISRs). Table 4 summarizes the Interrupt Service
Routines, indicates when they are called and provides
a brief description of the operations executed in each
particular ISR.
If S2 is pressed while the motor is running, the
StopMotor() subroutine disables all the interrupts
and stops the motor.
SUMMARY OF INTERRUPT SERVICE ROUTINES
Interrupt
When Called
Operations Performed
A/D
20 kHz
• Reads new Reference Speed value from AN2
PWM
20 kHz
• Generates sine wave using SVM
T1
1 kHz
•
•
•
•
CN5
Every Hall A transition
• Calculates rotor position
• Determines rotor mechanical direction
• Synchronizes sine-wave pointer to rotor position
IC7
Every Hall B transition
•
•
•
•
IC8
Every Hall C transition
• Calculates rotor position
• Determines rotor mechanical direction
• Synchronizes sine-wave pointer to rotor position
DS01017A-page 6
Measures Speed Calculation using IC7 data
Executes PID control
Calculates Phase Advance
Provides Motor Stalled protection
Calculates rotor position
Determines rotor mechanical direction
Captures Hall transition timing using IC
Synchronizes sine-wave pointer to rotor position
© 2005 Microchip Technology Inc.
MAIN STATE MACHINE DIAGRAM
es
se
d
Pr
I nt
er
ru
Enable
Peripherals
and
Interrupts
Calculate
Phase
Advance if
enabled
pt
1m
s)
Reset Phase
to agree with
motor
position
Motor
Running
rrup
Inte
I C7 B
Ha l l
d
not
tor
Mo 10 ms
for
Motor
Stalled
Protection
g
vin
mo
has
A Hall effect sensor interrupt
ms
been generated within 10
CN5 Interr
upt (Hall
A)
IC
8
se
es
Pr
2
S
In
t
er
ru
pt
(
Ha
l
lC
Calculate rotor
position from
Hall effect
sensors
Calculate rotor
direction from
Hall effect
sensor change
)
t
Disable
interrupts
and stop the
motor
pt
rru
Initialize
PID Controller
parameters
te
In
Motor
Stopped
A/
D
Execute PID
Speed
Controller
Calculate
actual speed
from IC
buffered
M
PW
Read
Reference
Speed from
AN2
Initialize
value for
running the
motor
Initialize
variables and
peripherals
Generate new
Sine point
using SVM
Increment
phase of
Sine Wave
Charge
Bootstrap
Capacitors
S2
0 ms
(ea
ch
for 10
terr
upt
g
movin
T1
In
Initialize
variables and
peripherals
not
Motor
Synchronize
sine-wave
phase with
rotor position
Calculate rotor
position from
Hall effect
sensors
Reset
DS01017A-page 7
Capture
IC Event
Calculate rotor
direction from
Hall effect
sensor change
Calculate rotor
position from
Hall effect
sensors
Calculate rotor
direction from
Hall effect
sensor change
Synchronize
sine-wave
phase with
rotor position
Synchronize
sine-wave
phase with
rotor position
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
© 2005 Microchip Technology Inc.
FIGURE 8:
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
SPEED CALCULATION
Measured Speed Calculation
The actual speed of the motor is calculated from one
Hall effect sensor (Hall B). The calculation uses an
Input Capture channel (IC7 input pin) to measure the
time between two consecutive transitions in Hall effect
sensor B. The timing diagram in Figure 9 shows the
capture events and the variables used to store two consecutive captures to measure the time between Hall
effect sensor B transitions. In the same figure, the
mechanical rotation angle is plotted for the five polepair motor used to see the relationship between Hall
effect sensor B signal and the actual mechanical
movement.
Reference Speed Calculation
The Reference Speed variable (see Figure 7) is read
by the A/D interrupt using the A/D converter (AN2 input
pin). The A/D converter is configured to generate interrupts at the PWM rate (20 kHz in this application).
Within the A/D ISR, the A/D conversion buffer is copied
into a variable (RefSpeed) in signed fractional format.
This variable represents the desired speed from -1.0 to
0.99997. Table 5 summarizes the minimum and maximum value of this variable and their interpretation for
the motor used in this application note.
TABLE 5:
EXAMPLES OF REFERENCE SPEED CALCULATIONS
RefSpeed Variable
Hex Value
Fractional Value
Desired Speed in RPM
Min Value
0x8000
-1.0
6000 RPM Reverse
Max Value
0x7FFF
0.99997
6000 RPM Forward
FIGURE 9:
TIME RELATIONSHIP BETWEEN HALL B AND MOTOR MECHANICAL POSITION
PastCapture = IC7BUF
ActualCapture = IC7BUF
Electrical Degrees
0
180
0
180
0
36
72
108
0
180
0
180
0
180
0
144
180
216
252
288
324
360
HALL B
Motor Position
(Rotor Angle)
Mechanical Degrees
DS01017A-page 8
© 2005 Microchip Technology Inc.
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
The variable used to store the time between transitions
is called Period and is calculated in the Timer 1 ISR.
This ISR is generated every 1 millisecond and
executes the speed controller. The formula used to
calculate the actual speed of the motor is:
Period = ActualCapture – PastCapture
where ActualCapture and PastCapture contain
timing information of two consecutive Hall effect sensor
B transitions as shown in Figure 9. Period is used for
calculating the step size of the pointer used to generate
the sine wave, since the generated sinusoidal voltages
need to be of the same frequency compared to the Hall
effect sensor information.
For Speed calculation, the following formula is used to
convert Hall effect sensor time between transitions
(Period) to the measured speed (MeasuredSpeed):
MINPERIOD
MeasuredSpeed = FractionalDivide ⎛⎝ -----------------------------------⎞⎠
Period
TABLE 6:
MINPERIOD is a constant value calculated to give a
fractional value of 0.99997, if a maximum speed of
6000 RPM is detected from the Hall effect sensor. The
MINPERIOD formula is:
MINPERIOD =
(Timer 1 Input Clock) x 60
(Max Speed in RPM) x (Motor Poles)
(20 MHz/64) x 60
=
6000 RPM x 10
= 312
Table 6 provides examples of speed calculation
(MeasuredSpeed) from the input capture values
stored in PastCapture and ActualCapture.
The sign is added to the MeasuredSpeed depending
on variable CurrentDirection, which is calculated
in the Hall effect sensor interrupts. CurrentDirection is calculated based on two consecutive combinations from the Hall effect sensors (or two consecutive
sectors). If the motor is moving forwards (CW), the
MeasuredSpeed is kept positive. If the motor is moving backward (CCW), MeasuredSpeed is converted to
a negative value.
EXAMPLES OF MEASURED SPEED CALCULATIONS
MeasuredSpeed
ActualCapture
0x0000
PastCapture
0xFEC7
Period
0x0139
Hexadecimal
Fractional
RPM
0x7F97
0.99679
5990.4
0x2000
0x1D8E
0x0272
0xFCB
0.49838
2995.2
0x4000
0xC5EE
0x7A12
0x0147
0.00998
60
© 2005 Microchip Technology Inc.
DS01017A-page 9
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
PID SPEED CONTROLLER
The PID speed controller is executed in the T1 interrupt
(Timer 1 ISR) every 1 millisecond. This subroutine is
called SpeedControl() and uses both Reference
Speed (RefSpeed) and the actual speed of the motor
(MeasuredSpeed) in signed fractional format. MeasuredSpeed is subtracted from RefSpeed to determine the speed error (Error), which determines if the
motor must speed up or slow down. To ensure smooth
operation of the motor, the error value is parsed into
proportional, integral and derivative components to
produce a composite output that is used to compensate
for the speed error.
The PID controller implementation takes advantage of
the MAC instruction of the dsPIC DSC for fast execution. The formula used to generate the controller output
(ControlOutput) depends on three error values
saved in the last three T1 interrupts (ControlDifference[0], ControlDifference[1] and ControlDifference[2]) and the PID coefficients
(PIDCoefficients[0],
PIDCoefficients[1]
and PIDCoefficients[2]). The formula is:
ControlOutput = ControlOutput
+ ControlDifference[0] x PIDCoefficients[0]
+ ControlDifference[1] x PIDCoefficients[1]
Table 7 provides a brief description of the PID control
variables
This implementation of the PID uses the MAC instruction along with the automatic saturation feature of the
dsPIC DSC when performing MAC operation. When
adjusting PID gains, the user is responsible for avoiding maximum values of the PID coefficients. These values represent fractional values and have to be within
the following values:
Kp + Ki + Kd
<
0.9999 (0x7FFF)
-Kp – 2*Kd
>
-1.0(0x8000)
Kd
<
0.9999(0x7FFF)
Figure 10 is a flow chart that shows how the
SpeedControl() function is implemented.
Required_Direction is taken from the sign of the
PID controller output (ControlOutput) and tells the
software to run the motor CW or CCW. The following
code sample shows how the required direction is
calculated in the software:
// ControlOutput determines the motor
// required direction
if (ControlOutput < 0)
Required_Direction = CCW;
else
Required_Direction = CW;
+ ControlDifference[2] x PIDCoefficients[2]
TABLE 7:
PID CONTROL VARIABLES
Variable
Description
ControlOutput
The output of the controller in 16-bit signed fractional format
ControlDifference[0]
Most recent calculated speed error (RefSpeed - MeasuredSpeed)
ControlDifference[1]
Speed error in the previous T1 ISR (1 ms old)
ControlDifference[2]
Speed error before ControlDifference[1] (2 ms old)
PIDCoefficients[0],
PIDCoefficients[1] and
PIDCoeffients[2}
Modified PID coefficients from regular PID form to filter-like PID implementation:
PIDCoefficients[0] = Kp + Ki = Kd
PIDCoefficients[1] = -Kp - 2Kd
PIDCoefficients[2] = Kd
DS01017A-page 10
© 2005 Microchip Technology Inc.
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
FIGURE 10:
SPEED CONTROL FLOW CHART
SpeedControl()
Initialize Pointers to Controller Variables
Calculate most recent Error and store at
ControlDifference[0]
Load Accumulator with last
ControlOutput
MAC (ControlDifference[0] x PIDCoefficients[0]
(ControlDifference[1] x PIDCoefficients[1]
(ControlDifference[2] x PIDCoefficients[2]
Save old Errors in ControlDifference[] array
Yes
New ControllerOutput<0>
Required Direction = CCW
No
Required Direction = CW
Save old Errors in ControlDifference[] array
End
© 2005 Microchip Technology Inc.
DS01017A-page 11
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
PID BACKGROUND
ADJUSTING PID GAINS
A complete discussion of Proportional Integral Derivative (PID) controllers is beyond the scope of this application note. However, some PID operation basics are
relevant.
The P gain of a PID controller sets the overall system
response. When first tuning a controller, the I and D
gains should be set to zero. The P gain can then be
increased until the system responds well to set-point
changes without excessive overshoot or oscillations.
Using lower values of P gain will ‘loosely’ control the
system, while higher values will give ‘tighter’ control. At
this point, the system will probably not converge to the
set-point.
A PID controller responds to an error signal in a closed
control loop and attempts to adjust the controlled quantity to achieve the desired system response. The controlled parameter can be any measurable system
quantity such as speed, torque or flux. The benefit of
the PID controller is that it can be adjusted empirically
by adjusting one or more gain values and observing the
change in system response.
A digital PID controller is executed at a periodic sampling interval. It is assumed that the controller is executed frequently enough so that the system can be
properly controlled. The error signal is formed by subtracting the desired setting of the parameter to be controlled from the actual measured value of that
parameter. The sign of the error indicates the direction
of change required by the control input.
The Proportional (P) term of the controller is formed by
multiplying the error signal by a P gain, causing the PID
controller to produce a control response that is a function of (i.e., proportional to) the error magnitude. As the
error signal becomes larger, the P term of the controller
becomes larger to provide more correction. The effect
of the P term tends to reduce the overall error as time
elapses. However, the P term has less effect as the
error approaches zero. In most systems, the error of
the controlled parameter gets very close to zero but
does not converge. The result is a small remaining
steady state error.
After a reasonable P gain is selected, the I gain can be
slowly increased to force the system error to zero. Only
a small amount of I gain is required in most systems.
Note that the effect of the I gain, if large enough, can
overcome the action of the P term, slow the overall control response and cause the system to oscillate around
the set-point. If oscillation occurs, reducing the I gain
and increasing the P gain usually solves the problem.
The D gain can speed up system response. However,
it must be used carefully because it can produce large
output swings, which potentially cause mechanical
damage on the motor.
The Integral (I) term of the controller is used to eliminate small steady state errors. The I term calculates a
continuous running total of the error signal. Therefore,
a small steady state error accumulates into a large
error value over time. This accumulated error signal is
multiplied by an I gain factor and becomes the I output
term of the PID controller.
The Differential (D) term of the PID controller is used to
enhance the speed of the controller and responds to
the rate of change of the error signal. The D term input
is calculated by subtracting the present error value
from a prior value. This delta error value is multiplied by
a D gain factor that becomes the D output term of the
PID controller. The D term of the controller produces
more control output the faster the system error is
changing.
DS01017A-page 12
© 2005 Microchip Technology Inc.
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
ROTOR SECTOR CALCULATION
The following code illustrates this process:
Again referring to the software block diagram in
Figure 2, the rotor sector value is needed for sinusoidal
voltage generation. Rotor sector is the absolute position of the rotor, in electrical degrees, in 60-degree
steps. That information is obtained by reading the digital value from the three Hall effect sensors. The Rotor
Sector Calculation software block uses the three Hall
effect sensor interrupts (CN5, IC8 and IC7 interrupts,
as shown in Figure 8). The sector is calculated using
the relationships shown in Table 8:
TABLE 8:
Hall C
RELATIONSHIP OF SECTOR
TO ANGULAR POSITION
Hall B
Hall A
Sector
0
0
0
Invalid
0
0
1
4
0
1
0
2
0
1
1
3
1
0
0
0
1
0
1
5
1
1
0
1
1
1
1
Invalid
For calculating the actual motor direction of rotation
(Current_Direction) the last two consecutive sectors in the Hall effect sensor interrupts are compared.
Table 9 summarizes the direction calculation based on
the last two sectors.
TABLE 9:
CURRENT DIRECTION
CALCULATION
LastSector
Sector
Current_Direction
0
1
CCW
1
2
CCW
2
3
CCW
3
4
CCW
4
5
CCW
5
0
CCW
0
5
CW
1
0
CW
2
1
CW
3
2
CW
4
3
CW
5
4
CW
The actual direction of motor rotation is used in the
Speed Calculation block. If the actual direction is CCW,
the speed is negative.
© 2005 Microchip Technology Inc.
// MeasuredSpeed sign adjustment based on
// current motor direction of rotation
if (Current_Direction == CCW)
MeasuredSpeed = -MeasuredSpeed;
The calculated Rotor Sector value is modified by the
measured speed and maximum phase advance to set
the phase angle of the sinusoidal voltage.
PHASE ADVANCE
Under normal conditions, motor speed is limited by the
voltage supplied to the motor windings by the inverter.
The voltage on the motor windings is usually
synchronized with the rotor position, as shown by the
relationship between Voltage A and Hall A in Figure 11.
This condition creates a rotating electrical field in the
stator that is 90 degrees ahead of the rotor magnetic
field, which produces the maximum torque per amp
from the motor.
FIGURE 11:
EFFECT OF PHASE
ADVANCE ON DRIVE
VOLTAGE
0
60
120
180
240
300
0
60
VOLTAGE A
HALL A
Θ
VOLTAGE A
With Phase
Advance
If the field generated in the stator is shifted by an angle
theta, the resulting magnetic field between the stator
and the rotor is increased. The addition of this phase
advance creates a negative field in the rotor, which
reduces the field produced by rotor permanent
magnets. Some important effects of this phase shift
include:
• Phase advance increases the speed range over
the nominal speed limit, since the resulting field
vector is increased.
• Phase advance weakens the rotor field since it
produces a negative field in the rotor. Field weakening reduces the overall torque output available
from the motor.
• Motor current consumption, motor operating
temperature and audible noise increase when
phase advance is used because the stator field is
working against the rotor field.
DS01017A-page 13
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
SINE-WAVE GENERATION USING
SPACE VECTOR MODULATION
For applications where an increase in the speed range
of the motor is required, phase advance is a recommended algorithm. This algorithm can be enabled by
defining PHASE_ADVANCE in the SinusoidalBLDC
v1.1.c file. This feature is disabled in the context of
this application note.
#define PHASE_ADVANCE
TABLE 10:
The final step in the sinusoidal control of a PMSM
motor is to generate pulse-width modulation signals for
the three-phase motor voltage signals. By using Space
Vector Modulation (SVM), the process of generating
the pulse width for each of the three phases reduces to
a few simple equations. Each of the three inverter outputs can be in one of two states: either connected to the
+ bus rail or the - bus rail. Thus the output can be in
eight possible states (23 = 8), as shown in Table 10.
// for extended
// speed ranges this
// should be defined
SPACE VECTOR MODULATION INVERTER STATES
C
B
A
Vab
Vbc
Vca
Vds
Vqs
Vector
0
0
0
0
0
0
0
0
U(000)
0
0
1
VDC
0
-VDC
2/3Vdc
0
U0
0
1
1
0
VDC
-VDC
VDC/3
VDC/3
U60
0
1
0
-VDC
VDC
0
-VDC/3
VDC/3
U120
1
1
0
-VDC
0
VDC
-2VDC/3
0
U180
1
0
0
0
-VDC
VDC
-VDC/3
-VDC/3
U240
1
0
1
VDC
-VDC
0
VDC/3
-VDC/3
U300
1
1
1
0
0
0
0
0
U(111)
DS01017A-page 14
© 2005 Microchip Technology Inc.
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
The two states where all three outputs are connected
to either the + bus or the - bus are considered null
states because there is no line-to-line voltage across
any of the phases. These are plotted at the origin of the
SVM Star. The remaining six states are represented as
vectors with 60 degree rotation between each state, as
shown in Figure 12.
FIGURE 12:
SPACE VECTOR
MODULATION
U120(010)
III
U180(110)
period. This configuration produces two pulses line-toline during each period. The effective switching frequency is doubled, reducing the ripple current while not
increasing the switching losses in the power devices.
FIGURE 14:
PWM FOR PERIOD T
000
100
110
111
111
T0/4
T1/2
T2/2
T0/4 T0/4
110
100
000
PWM1
U60(011)
II
U(111)
PWM2
I
PWM3
U(000)
U0(001)
T2/2 T1/2 T0/4
T
IV
VI
V
U240(100)
Figure 15 shows a complete electrical revolution with
duty cycles using SVM. the values represent duty
cycles between 0% and 100%.
U300(101)
Space Vector Modulation allows any resultant vector
be represented by the sum of the components of the
two adjacent vectors. In Figure 13, UOUT is the
desired resultant. It lies in the sector between U60 and
U0. If during a given PWM period T, U0 is output for T1/
T and U60 is output for T2/T, the average for the period
will be UOUT.
FIGURE 13:
AVERAGE SPACE VECTOR
MODULATION
U60(011)
T = T1 + T2 + T0 = PWM Period
UOUT =
UOUT
T1 * U0 + T2 * U60
T
T2/T * U60
T1/T * U0
U0(001)
FIGURE 15:
LINE-TO-GROUND
VOLTAGES USING SVM
100%
50%
0%
SVM
Sector
I
II
As shown in Figure 14, the PWM period T, the vector
T1 is output for T1/T and the vector T2 is output for T2/
T. During the remaining time the null vectors are output.
The dsPIC30F device is configured for center aligned
PWM, which forces symmetry about the center of the
© 2005 Microchip Technology Inc.
IV
V
VI
PWM1
PWM2
PWM3
The resulting line-to-line voltages are shown in
Figure 16. Sinusoidal voltages with full amplitude are
fed into the motor windings.
FIGURE 16:
The values for T1 and T2 are taken from a look up table
containing 172 fractional sinusoidal values for 0 to 60
electrical degrees. As a result, for each of the six segments one axis is exactly opposite that segment, and
the other two axes symmetrically bound the segment.
The values of the vector components along those two
bounding axis are equal to T1 and T2. For details of the
calculations, refer to the SVM.c file that accompanies
this application note.
III
LINE-TO-LINE VOLTAGES
USING SVM
+VDC
0V
-VDC
SVM
Sector
I
II
III
IV
V
VI
Va - Vb
Vb - Vc
Vc - Va
DS01017A-page 15
SINUSOIDAL CONTROL OF PMSM MOTORS WITH DSPIC30F DSC
CONCLUSION
The dsPIC30F2010 provides an ideal low-cost solution
for controlling a PMSM motor with sinusoidal voltages.
Motor control peripherals, such as the MCPWM, in
combination with processing power, makes possible
several algorithms such as Space Vector Modulation
for sine-wave generation, and PID loops for controlling
motor speed.
The dsPICDEM™ MCLV development board has the
necessary hardware to run this application while
maintaining low cost to the total system.
Software files are contained in the AN1017.zip file and
can be downloaded from the Microchip web site
www.microchip.com
REVISION HISTORY
Revision A (December 2005)
• Initial release of this document.
DS01017A-page 16
© 2005 Microchip Technology Inc.
Note the following details of the code protection feature on Microchip devices:
•
Microchip products meet the specification contained in their particular Microchip Data Sheet.
•
Microchip believes that its family of products is one of the most secure families of its kind on the market today, when used in the
intended manner and under normal conditions.
•
There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our
knowledge, require using the Microchip products in a manner outside the operating specifications contained in Microchip’s Data
Sheets. Most likely, the person doing so is engaged in theft of intellectual property.
•
Microchip is willing to work with the customer who is concerned about the integrity of their code.
•
Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not
mean that we are guaranteeing the product as “unbreakable.”
Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our
products. Attempts to break Microchip’s code protection feature may be a violation of the Digital Millennium Copyright Act. If such acts
allow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.
Information contained in this publication regarding device
applications and the like is provided only for your convenience
and may be superseded by updates. It is your responsibility to
ensure that your application meets with your specifications.
MICROCHIP MAKES NO REPRESENTATIONS OR WARRANTIES OF ANY KIND WHETHER EXPRESS OR IMPLIED,
WRITTEN OR ORAL, STATUTORY OR OTHERWISE,
RELATED TO THE INFORMATION, INCLUDING BUT NOT
LIMITED TO ITS CONDITION, QUALITY, PERFORMANCE,
MERCHANTABILITY OR FITNESS FOR PURPOSE.
Microchip disclaims all liability arising from this information and
its use. Use of Microchip’s products as critical components in
life support systems is not authorized except with express
written approval by Microchip. No licenses are conveyed,
implicitly or otherwise, under any Microchip intellectual property
rights.
Trademarks
The Microchip name and logo, the Microchip logo, Accuron,
dsPIC, KEELOQ, microID, MPLAB, PIC, PICmicro, PICSTART,
PRO MATE, PowerSmart, rfPIC, and SmartShunt are
registered trademarks of Microchip Technology Incorporated
in the U.S.A. and other countries.
AmpLab, FilterLab, Migratable Memory, MXDEV, MXLAB,
PICMASTER, SEEVAL, SmartSensor and The Embedded
Control Solutions Company are registered trademarks of
Microchip Technology Incorporated in the U.S.A.
Analog-for-the-Digital Age, Application Maestro, dsPICDEM,
dsPICDEM.net, dsPICworks, ECAN, ECONOMONITOR,
FanSense, FlexROM, fuzzyLAB, In-Circuit Serial
Programming, ICSP, ICEPIC, Linear Active Thermistor,
MPASM, MPLIB, MPLINK, MPSIM, PICkit, PICDEM,
PICDEM.net, PICLAB, PICtail, PowerCal, PowerInfo,
PowerMate, PowerTool, Real ICE, rfLAB, rfPICDEM, Select
Mode, Smart Serial, SmartTel, Total Endurance, UNI/O,
WiperLock and Zena are trademarks of Microchip Technology
Incorporated in the U.S.A. and other countries.
SQTP is a service mark of Microchip Technology Incorporated
in the U.S.A.
All other trademarks mentioned herein are property of their
respective companies.
© 2005, Microchip Technology Incorporated, Printed in the
U.S.A., All Rights Reserved.
Printed on recycled paper.
Microchip received ISO/TS-16949:2002 quality system certification for
its worldwide headquarters, design and wafer fabrication facilities in
Chandler and Tempe, Arizona and Mountain View, California in
October 2003. The Company’s quality system processes and
procedures are for its PICmicro® 8-bit MCUs, KEELOQ® code hopping
devices, Serial EEPROMs, microperipherals, nonvolatile memory and
analog products. In addition, Microchip’s quality system for the design
and manufacture of development systems is ISO 9001:2000 certified.
© 2005 Microchip Technology Inc.
Advance Information
DS00000A-page 17
WORLDWIDE SALES AND SERVICE
AMERICAS
ASIA/PACIFIC
ASIA/PACIFIC
EUROPE
Corporate Office
2355 West Chandler Blvd.
Chandler, AZ 85224-6199
Tel: 480-792-7200
Fax: 480-792-7277
Technical Support:
http://support.microchip.com
Web Address:
www.microchip.com
Australia - Sydney
Tel: 61-2-9868-6733
Fax: 61-2-9868-6755
India - Bangalore
Tel: 91-80-2229-0061
Fax: 91-80-2229-0062
China - Beijing
Tel: 86-10-8528-2100
Fax: 86-10-8528-2104
India - New Delhi
Tel: 91-11-5160-8631
Fax: 91-11-5160-8632
Austria - Wels
Tel: 43-7242-2244-399
Fax: 43-7242-2244-393
Denmark - Copenhagen
Tel: 45-4450-2828
Fax: 45-4485-2829
China - Chengdu
Tel: 86-28-8676-6200
Fax: 86-28-8676-6599
India - Pune
Tel: 91-20-2566-1512
Fax: 91-20-2566-1513
France - Paris
Tel: 33-1-69-53-63-20
Fax: 33-1-69-30-90-79
China - Fuzhou
Tel: 86-591-8750-3506
Fax: 86-591-8750-3521
Japan - Yokohama
Tel: 81-45-471- 6166
Fax: 81-45-471-6122
Germany - Munich
Tel: 49-89-627-144-0
Fax: 49-89-627-144-44
China - Hong Kong SAR
Tel: 852-2401-1200
Fax: 852-2401-3431
Korea - Gumi
Tel: 82-54-473-4301
Fax: 82-54-473-4302
China - Qingdao
Tel: 86-532-8502-7355
Fax: 86-532-8502-7205
Korea - Seoul
Tel: 82-2-554-7200
Fax: 82-2-558-5932 or
82-2-558-5934
Atlanta
Alpharetta, GA
Tel: 770-640-0034
Fax: 770-640-0307
Boston
Westborough, MA
Tel: 774-760-0087
Fax: 774-760-0088
Chicago
Itasca, IL
Tel: 630-285-0071
Fax: 630-285-0075
Dallas
Addison, TX
Tel: 972-818-7423
Fax: 972-818-2924
Detroit
Farmington Hills, MI
Tel: 248-538-2250
Fax: 248-538-2260
Kokomo
Kokomo, IN
Tel: 765-864-8360
Fax: 765-864-8387
Los Angeles
Mission Viejo, CA
Tel: 949-462-9523
Fax: 949-462-9608
San Jose
Mountain View, CA
Tel: 650-215-1444
Fax: 650-961-0286
China - Shanghai
Tel: 86-21-5407-5533
Fax: 86-21-5407-5066
China - Shenyang
Tel: 86-24-2334-2829
Fax: 86-24-2334-2393
China - Shenzhen
Tel: 86-755-8203-2660
Fax: 86-755-8203-1760
China - Shunde
Tel: 86-757-2839-5507
Fax: 86-757-2839-5571
China - Wuhan
Tel: 86-27-5980-5300
Fax: 86-27-5980-5118
China - Xian
Tel: 86-29-8833-7250
Fax: 86-29-8833-7256
Malaysia - Penang
Tel: 60-4-646-8870
Fax: 60-4-646-5086
Philippines - Manila
Tel: 63-2-634-9065
Fax: 63-2-634-9069
Italy - Milan
Tel: 39-0331-742611
Fax: 39-0331-466781
Netherlands - Drunen
Tel: 31-416-690399
Fax: 31-416-690340
Spain - Madrid
Tel: 34-91-708-08-90
Fax: 34-91-708-08-91
UK - Wokingham
Tel: 44-118-921-5869
Fax: 44-118-921-5820
Singapore
Tel: 65-6334-8870
Fax: 65-6334-8850
Taiwan - Hsin Chu
Tel: 886-3-572-9526
Fax: 886-3-572-6459
Taiwan - Kaohsiung
Tel: 886-7-536-4818
Fax: 886-7-536-4803
Taiwan - Taipei
Tel: 886-2-2500-6610
Fax: 886-2-2508-0102
Thailand - Bangkok
Tel: 66-2-694-1351
Fax: 66-2-694-1350
Toronto
Mississauga, Ontario,
Canada
Tel: 905-673-0699
Fax: 905-673-6509
*DS01017A*
10/31/05
DS01017A-page 18
© 2005 Microchip Technology Inc.