Stepper motor math model

Summary

A stepper motor is a special kind of brushless DC motor. It can execute precise movements without the need of a closed loop control system or a sensor. In this page a mathematical model of such a motor is derived and the model's parameters are examined and tuned so that the model's performance mimics the actual performance of the motor.

Motor used

This model focuses on a NEMA 17 stepper motor but the process followed is similar for modelling other stepper motors as well. The exact motor used is described by the code name 42HD4027-01 under the NEMA standard. The last section in this page - Motor design - includes mechanical drawings, photos and the datasheet of this stepper motor.

OGstepper.jpg

Model block diagram

Inputs

This stepper motor has two separate phases. Therefore, the main inputs for the model are the two voltage differentials applied to each of the two phases. Other secondary inputs are the moment of inertia of the load attached to the motor and any external torques applied to the load and/or motor shaft. Also some inputs in the form of initial conditions are the initial angular position and speed of the rotor and the initial currents in each phase.

The friction in the motor is neglected in this model but it can easily be implemented as an external source of torque.

Outputs

After solving the differential equations of the model, the kinematic response of the rotor can be extracted as well as the electric response of the phases. On the kinematic side, the outputs are the angular position, speed, acceleration, jerk(or rate of change of acceleration) and torque. The electric response includes phase current and voltage induced by the spinning magnetic rotor.

modelBlockDiagram.jpg

The above diagram shows the main idea of this model:

  1. Voltage is applied to the phases
  2. That generates current in the phases
  3. Phases run with current generate torque on the motor's shaft
  4. Torque on the shaft rotates it, changing its speed and position
  5. The speed and position of the motor's shaft affect both the torque applied by the phases and the current in the phases

Physics

These are the basic physics laws used to describe the behavior of the motor:

Apart from the above well known and broadly applicable theorems, there are a few equations that specifically describe the behavior of this stepper motor:

Shaping the equations

In order to derive the model of this system, every equation that describes its nature must be related to each other. Initially, the total torque exerted on the rotor can be expressed as:

(8)Tsum=TA+TB+TdT+Text

Tsum is the total torque on the rotor,
TA is the torque exerted by phase A on the rotor,
TB is the torque exerted by phase B on the rotor and
Text is the sum of external torques on the rotor.

torqueSum.jpg

After substituting the known equations for Tsum, TA, TB and TdT, we get:

(9)(IROTOR+ILOAD)ω˙=KTIAsin(pθ)KTIBcos(pθ)TdTmaxsin(4pθ)+Text

The two expressions for the torques TA and TB have a phase difference of π/2. This behavior is due to the way the motor is constructed - it is due to the geometric characteristics of the stator and rotor and the way they interact.

Kirchhoff's 2nd law can be applied for each of the two phases of the motor:

Phase A

(10)VA=RIA+LIA˙eA

Phase B

(11)VB=RIB+LIB˙eB

IA and IB are the currents in phases A and B respectively,
VA and VB are the applied voltages,
R and L are the phase resistance and phase inductance and
eA and eB are the voltages induced in each phase by the spinning rotor.

phaseVoltageDiagram.jpg

According to Faraday's law ( 3 ) the induced voltage is equal to the rate of change of magnetic flux linkage. Therefore, substituting eA and eB for the rate of change of magnetic flux linkage between one phase and the rotor we get:

Phase A

(12)VA=RIA+LIA˙pΨMsin(pθ)dθdt

Phase B

(13)VB=RIB+LIB˙pΨMcos(pθ)dθdt

The two expressions for the induced voltages eA and eB have a phase difference of π/2. This again happens due to the geometric characteristics of the stator and rotor and the way they interact.

At this point, equations 9, 12, 13 and the initial conditions for speed and position of the rotor and initial currents in phases A and B are enough to solve this system and calculate the response of the motor.

Equation parameters

The parameters in equation 9 are:

  1. IROTOR - moment of inertia of the rotor
  2. ILOAD - moment of inertia of the load (although this could also be considered an input)
  3. KT - constant relating phase current to maximum phase torque
  4. p - number of teeth on the rotor
  5. TdTmax - maximum detent torque

The parameters in equations 12 and 13 are:

  1. R - phase resistance
  2. L - phase inductance
  3. ΨM - maximum magnetic flux linkage between a phase and the rotor

Changing the values of these parameters will affect the behavior of the model. In order to tune these parameters so that the model mimics the behavior of the motor, their values must be derived from the motor's characteristics. This is possible by either making measurements on the motor or by consulting the motor's datasheet. Unfortunately, not all information needed is always available in the datasheet, so some measurements are often required.

Tuning the parameters

The parameters can be tuned by either consulting the motor's datasheet or taking measurements on the motor.

  1. IROTOR - moment of inertia of the rotor
    It is usually given in the motor's datasheet but can also be calculated from the rotor's geometry. IrotorDatasheet.jpg
  2. ILOAD - moment of inertia of the load
    Can be arbitrarily chosen or should be calculated for a specific load based on the load characteristics.
  3. KT - constant relating phase current to maximum phase torque
    Revisiting equation 4, it is evident that a phase current value and its corresponding maximum phase torque are enough to calculate KT. Unfortunately, the motor's datasheet provides the maximum phase current and the corresponding maximum holding torque of the combination of two phases. To derive the holding torque of one phase, the two phase holding torque must be divided by 2. Therefore, KT can be calculated by:

    (14)KT=ThmaxPhaseImaxPhase=Thmax2Phase2ImaxPhase

    Where:
    ImaxPhase is the nominal current of a phase,
    ThmaxPhase is the maximum holding toque of one phase and
    Thmax2Phase is the maximum holding torque of two phases. KTDatasheet.jpg Manufacturers probably prefer to display the two phase holding torque in the datasheet because it has a bigger value.
  4. p - number of teeth on the rotor
    The rotor has as many teeth as a quarter of the steps the motor can execute in a full circle (360°). stepAngleDatasheet.jpg Consequently, for a step angle of 1.8°:

    (15)p=360°1.8°4=50

    Alternatively, the teeth of the rotor can be counted by eye. The left side only should be counted. rotorTeethCount.jpg
  5. TdTmax - maximum detent torque
    This value is rarely if ever given in the datasheet. The maximum torque the motor exerts when both phases are inactive (0 current) is the maximum detent torque. It can be measured with a precision scale by placing the motor on a jig as shown in the next image: dTJig.jpg Alternatively, it can be estimated to be about 2% of the motor's two phase holding torque (this percentage gets smaller for bigger motors).
  6. R - phase resistance
    The motor's phase resistance is given in the datasheet and can be easily measured using a multimeter. resistanceDatasheet.jpg resistanceMulti.jpg
  7. L - phase inductance
    The motor's phase inductance is also given in the datasheet and can be easily measured using an LCR meter. inductanceDatasheet.jpg inductanceLCR.jpg
  8. ΨM - maximum magnetic flux linkage between a phase and the rotor
    This value will most probably not be in the datasheet and cannot be estimated based on other information in it. There are several ways to calculate it but they require some tools. The main concept is measuring the signal produced in a phase when the rotor is rotated and then deriving the maximum flux linkage based on that signal.
    • Oscilloscope methods
      The probes of the oscilloscope are tied to a phase of the motor. The motor's shaft is rotated at a constant speed with a help of an external motor (e.g. a hand drill). The induced voltage is measured - it has the shape of a sine wave. osciSetup.jpg inducedWave.jpg This induced sine wave is described by equation 7 and when it takes its maximum value the equation gives:

      (16)dΨAdtmax=eAmax=pΨMdθdtΨM=eAmaxpω

      Therefore, the maximum flux linkage between the rotor and a phase can be calculated by the angular speed of the rotor(ω) and the corresponding maximum induced voltage in a phase(eAmax). The maximum induced voltage can be extracted from the graph of the induced voltage. The speed of the rotor is directly related to and can be estimated by the period of the signal(Te): (17)ω=0.1257Te There is also a way to directly calculate the maximum magnetic flux linkage using the induced signal. It is actually equal to the area between each of the sine wave's curve and the time axis. Some modern oscilloscopes might be able to integrate the curve and get a quick result. In the next image each of the areas(E) are equal to the maximum magnetic flux linkage. inducedWaveE.jpg
    • Multimeter and tachometer
      An estimation of the magnetic flux linkage can be made using these simpler tools. In this case the multimeter is used to measure the RMS value of the induced sine wave and the tachometer is used to measure the speed of the rotation. MultiTacho.jpg Afterwards, the maximum induced voltage can be calculated by multiplying the RMS value by 2 and then equation 16 can be used to calculate the maximum magnetic flux linkage.

Solving the model

After having created an accurate model, it must be solved. The best way to tackle this is using a firmware such as Simulink of Matlab or Xcos of Scilab. The following image shows an implementation of the above model in Simulink:

simulinkModel.jpg

Motor design

Assembled motor:

OGstepper.jpg

Disassembled motor:

stepperDisassembled.jpg

Exploded view:

explodedView.jpg

Parts:

  1. Cover B part1.jpg
  2. Wave washer part2.jpg
  3. Bearing part3.jpg
  4. Spacer B part4.jpg
  5. Axel part5.jpg
  6. Rotor assembly part6.jpg
  7. Spacer A part7.jpg
  8. Bearing part8.jpg
  9. Insulation A part9.jpg
  10. Stator punched sheet metal part10.jpg
  11. JST connector part11.jpg
  12. Insulation B part12.jpg
  13. THT board part13.jpg
  14. Cap A part14.jpg
  15. Phillips screw part15.jpg

Section view:

sectionView.jpg

Datasheet:

nema17datasheetSMALL.jpg

Sources

This page is a summary of part of the thesis "Stepper motors and simulation of their operation" available as a PDF here.