# 

# High Performance Dual PWM Microstepping Controller

| Туре        | Package           | Temperature Range |
|-------------|-------------------|-------------------|
| IXMS150 PSI | 24-Pin Skinny DIP | -40°C to +85°C    |

The IXMS150 is a high performance monolithic 2-channel PWM controller. Implemented in CMOS, the low power IXMS150 precisely controls the current in each of two separate power H-bridge drivers using unique sampling and signal processing techniques. Each channel contains an error amplifier, PWM, feedback amplifier, and protection circuitry. Protection features include over/excess current shutdown, min/max duty cycle clamp, under voltage lockout, dead time insertion, and a shutdown input for over-temp or other external fault circuitry. Other features include a common oscillator. feedforward circuit for motor supply compensation, and an onchip negative bias generator.

The IXMS150 has been optimized for microstep control of two phase step motors. Due to its high level of accu-

#### Block diagram of IXMS 150

racy, the IXMS150 will allow a designer to implement a control system with a resolution in excess of 250 microsteps per step, or 50,000 steps per revolution with a 200 step per revolution step motor. The IXMS150 greatly improves positioning accuracy and virtually eliminates low speed velocity ripple and resonance effects at a fraction of the cost of a board level microstepping system.

Other applications which the IXMS150 is designed for include control of two single-phase (DC) motors or control of synchronous reluctance motors. The IXMS150 is ideal for robotics, printers, plotters, and x-y tables and can facilitate the construction of very sophisticated positioning control systems while significantly reducing component cost, board space, design time and systems cost.



| Symbol           | Definition                   | Max. Ra                  | tings |
|------------------|------------------------------|--------------------------|-------|
| V <sub>DD</sub>  | Supply voltage               | -0.315                   | V     |
| 66               | Operating range              | 10.813.2                 | V     |
|                  | Common-mode-range            | -1515                    | V     |
|                  | Differential Input voltage * | ±30                      | V     |
| V <sub>IN</sub>  | Input voltage *              | -1515                    | V     |
| V <sub>o</sub>   | Output voltage               | -0.3V <sub>DD</sub> +0.3 | V     |
| P <sub>D</sub>   | Maximum power dissipation    | 500                      | mW    |
| Т,               | Ambient temperature range    | -4085                    | °C    |
| T <sub>stg</sub> | Storage temperature range    | -55125                   | °C    |

Input voltage may not exceed either supply rail by more than 0.3 V at any time. IXYS reserves the right to change limits, test conditions and dimensions.

© 1998 IXYS All rights reserved

#### Features

- Two complete, synchronous PWMs
- Command input range ±2.0 V full scale
- ±0.625 V full scale current feedback signal
- 1% gain matching between channels without external trim
- 1.6% gain linearity
- Feedforward to compensate for motor supply variations
- Only one sense resistor per H-bridge needed
- Onboard two level current limiting
- Undervoltage lockout assures proper behavior on power up and power down
- Enable input for external over temperature or fault circuit input
- Duty cycles limited for AC coupled gate drive
- Wide range of built in dead time.
- On board negative power supply generator
- Single +12 V supply operation
- 24-pin DIP package

#### Applications

- Full, half quarter, or microstepping 2-phase step motor position controller
- Dual DC servo motor torque controller
- Solenoid actuator force controller
- General 2-channel currentcommanded PWM control

# 

| Symbol                      | Definition/Condition<br>( $V_{DD}$ = 12 V, T <sub>A</sub> = 25°C U |                                       |              | Characteristic Values<br>unless otherwise specified)<br>min.   typ.   max. |        |      |  |
|-----------------------------|--------------------------------------------------------------------|---------------------------------------|--------------|----------------------------------------------------------------------------|--------|------|--|
| Oscillator                  |                                                                    |                                       |              |                                                                            |        |      |  |
| f <sub>osc</sub>            | Frequency C <sub>。</sub>                                           |                                       | 10           |                                                                            | 400    | kHz  |  |
| V <sub>A(p-p)</sub>         | Amplitude FF\                                                      | ND = OPEN                             |              | 7                                                                          |        | V    |  |
| Ζ <sub>ουτ</sub>            | Output Impedance ± I <sub>c</sub>                                  | <sub>ουτ</sub> = 400 μΑ               |              | 2.5                                                                        |        | mΩ   |  |
|                             | Resistance Range R                                                 |                                       | 15           |                                                                            | 100    | kΩ   |  |
|                             | Capacitance Range C                                                |                                       | 100          |                                                                            | 2000   | pF   |  |
| Feed Forwa                  | rd                                                                 |                                       |              |                                                                            |        |      |  |
| V <sub>FFWD</sub>           |                                                                    | ND = Open                             |              | 3.5                                                                        |        | V    |  |
| FFWD                        | Voltage                                                            | ine open                              |              | 0.0                                                                        |        | v    |  |
| 7                           | Impedance to AGND                                                  |                                       | 25           | 45                                                                         |        | kΩ   |  |
|                             |                                                                    |                                       | 20           | 10                                                                         |        |      |  |
| Analog Inpu                 |                                                                    | 50                                    |              |                                                                            |        |      |  |
| V <sub>FS</sub>             | Input FullScale V <sub>INA</sub>                                   | DC                                    |              |                                                                            | ±2     | V    |  |
| _                           | V <sub>INB</sub>                                                   |                                       |              |                                                                            |        |      |  |
| Z <sub>IN1</sub>            | V <sub>IN</sub> to Comp <sub>2</sub>                               | DC                                    | 20           | 32                                                                         |        | kΩ   |  |
|                             | Impedance                                                          |                                       |              |                                                                            |        |      |  |
| Z <sub>IN2</sub>            | Comp <sub>1</sub> to Comp <sub>2</sub>                             | DC                                    | 12           | 20                                                                         |        | kΩ   |  |
|                             | Impedance                                                          |                                       |              |                                                                            |        |      |  |
| Sense Input                 | ts SENSE <sub>A</sub>                                              |                                       |              |                                                                            |        |      |  |
|                             | Full Scale Input SENSE                                             | DC                                    |              |                                                                            | ±0.625 | V    |  |
| SENSE                       | Input Impedance                                                    | DC                                    | 100          | 200                                                                        |        | kΩ   |  |
|                             |                                                                    | 20                                    | .00          | 200                                                                        |        |      |  |
| Protection (                |                                                                    |                                       | • •          | 0.0-                                                                       |        |      |  |
| V <sub>ov-1</sub>           | Over Current SENSE                                                 |                                       | 0.8          | 0.95                                                                       | 1.0    | V    |  |
|                             | Voltage                                                            |                                       | • -          |                                                                            |        |      |  |
| t<br>ov-1                   | Reset Pulse Width                                                  |                                       | 0.5          | 1                                                                          |        | μs   |  |
|                             |                                                                    |                                       | <b>•</b> · - |                                                                            |        |      |  |
| V <sub>EX-1</sub>           | Excess Current Voltage                                             |                                       | 3.45         | 3.6                                                                        | 3.75   | V    |  |
| t <sub>ex-1</sub>           | Reset Pulse Width                                                  |                                       |              | 300                                                                        |        | ns   |  |
| Under Volta                 | ge                                                                 |                                       |              |                                                                            |        |      |  |
| V <sub>uv</sub>             | Minimum V <sub>DD</sub> OUTDIS                                     |                                       | 7.5          | 8                                                                          | 8.5    | V    |  |
| I IH                        | Input High Current                                                 | V <sub>III</sub> = 11.5 V             |              | 100                                                                        |        | μA   |  |
|                             | Input Low Current                                                  | V <sub>  </sub> <sup>  </sup> = 0.5 V |              | 1.8                                                                        |        | mΑ   |  |
|                             | •                                                                  | IL.                                   |              |                                                                            |        |      |  |
| Outputs<br>V                |                                                                    | $1 - 10 m^{4}$                        | <u>م</u> و   | 11 2                                                                       |        | V    |  |
| V <sub>он</sub>             | Output High $V_{OUTA}, \overline{V_{OUTA}}$                        | I <sub>он</sub> = -10 mA              | 0.0          | 11.2                                                                       |        | v    |  |
|                             |                                                                    | 1 - 10 1                              |              |                                                                            |        |      |  |
| V <sub>ol</sub>             | Output Low $V_{OUTB}, \overline{V_{OUTB}}$                         | I <sub>oL</sub> = 10 mA               |              | 0.8                                                                        | 1.1    | V    |  |
|                             | Voltage                                                            | 0 400 -                               |              | 0-                                                                         | 50     |      |  |
| t,                          | Rise Time                                                          | $C_{L} = 100 \text{ pF}$              |              | 35                                                                         | 50     | ns   |  |
| t <sub>r</sub>              | Fall Time                                                          | $C_{L} = 100 \text{ pF}$              |              | 35                                                                         | 50     | ns   |  |
| t,<br>t,<br>T <sub>DT</sub> | Dead-Time                                                          | C = 180 pF                            | 200          | 300                                                                        | 450    | ns   |  |
| T <sub>MIN</sub>            | Minimum Pulse Width                                                | C <sub>p</sub> = 30 pF                | 0.6          | 0.8                                                                        | 1.5    | μs   |  |
| VBB Genera                  | ator                                                               |                                       |              |                                                                            |        |      |  |
| V <sub>BBmin</sub>          | Minimum V <sub>BB</sub>                                            | OUTDIS                                | -1.4         | -1.9                                                                       |        | V    |  |
| BBmin                       | Negative Bias                                                      | $= V_{DD}$                            |              |                                                                            |        | -    |  |
| V <sub>BB</sub>             | Negative Bias                                                      | $I_{out} = -3 \text{ mA}$             | -21          | -2.4                                                                       |        | V    |  |
| BB                          | Voltage                                                            | OUT OT                                | <u> </u>     | <b>-</b>                                                                   |        | v    |  |
| v                           | Load Regulation                                                    | f                                     |              | 60                                                                         |        | mV   |  |
| $V_{REG}$                   |                                                                    | f <sub>osc</sub><br>– 100 kHz         |              |                                                                            |        | IIIV |  |
| v                           |                                                                    | = 100 kHz                             |              | 11 0                                                                       |        | 11   |  |
| V <sub>он</sub>             | Output High Volt. C <sub>PUMP</sub>                                | I <sub>он</sub> = -10 mA              |              | 11.2                                                                       |        | V    |  |
| V <sub>oL</sub>             | Output Low Volt.                                                   | I <sub>oL</sub> = 32 mA               |              | 0.8                                                                        |        | V    |  |
| Supply                      |                                                                    |                                       |              |                                                                            |        |      |  |
| DD1                         | Idle Current V <sub>DD</sub>                                       | V <sub>IN</sub> = 0                   |              | 16                                                                         | 26     | mA   |  |
|                             | Operating Current                                                  | f <sub>osc</sub>                      |              | 15                                                                         | 45     | mA   |  |
| 002                         |                                                                    | = 100 kHz                             |              |                                                                            |        |      |  |
|                             | Bypass Voltage BYPASS                                              |                                       | 5.9          |                                                                            | 16.1   | V    |  |
| - BYPASS                    |                                                                    |                                       |              | 40                                                                         |        |      |  |
| Z                           | Impedance to AGND                                                  |                                       | 9            | 16                                                                         |        | kΩ   |  |

#### Dimensions in inch (1" = 25.4 mm) 24-Pin Skinny DIP





© 1998 IXYS All rights reserved



#### Pin Description IXMS 150

## **IXMS 150**

### Nomenclature of Dual PWM Microstepping Controller

#### ww.DataSheet4U.com

| Sym. Pin Description                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                            | IXMS 150 PS I | (Example)                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------------------------------------------------------------|
| AGND1Analog GroundCOMP2Analog Compensation4(see application notes for<br>recommendations).                                                                                                                                                                                                                                         | VBB 11 Negative Bias Generator<br>Output: For internal use by<br>the IXMS 150.                                                                                                                                                                                                                                                                             |               | – IXYS<br>– Dual PWM Controller<br>– Plackage Type<br>– Plastic Skinny DIP |
| 20         21         23         VIN       3         22       Analog Input: The analog input range is ± 2 V. A low output im pedance voltage source should drive these pins. The input is greater than 20 kΩ.         SENSE       6         19       Analog Sense: Each of the phases sense resistors are connected to these pins. | CPUMP 13<br>Charge Pump Capacitor:<br>Used by the internal<br>Negative Bias Generator.<br>OUTDIS 14<br>Digital ENABLE input and<br>STATUS output: Forcing this<br>pin low causes pins 9, 10,<br>15, and 16 to go low, disab-<br>ling the H-bridge. When uses<br>as an output, a low state on<br>this pin in dicates an over<br>current, excess current, or | Ι-            | Temperature Range<br>– Industrial                                          |
| FFWD7FFWD, for Motor High<br>Voltage Compensation: A<br>voltage on this pin sets the<br>oscillator amplitude. Input<br>range = 0.9-4 V (see<br>application notes for<br>recommendations).                                                                                                                                          | R <sub>o</sub> , C <sub>o</sub> 17 Oscillator Frequency and Dead-time set: Independent adjustment can be made to the oscillator frequency and dead-time (see applications notes).                                                                                                                                                                          |               |                                                                            |
| BY-<br>PASS8Filter Cap: A capacitor on<br>this pin provides filtering to<br>the internal bias network.VOUT9100utput Stage: To drive<br>buffered power MOSFET<br>H-Bridge.                                                                                                                                                          | VDD         24         Positive Supply Voltage           * Pin numbers in parantheses are associated with channel B.                                                                                                                                                                                                                                       |               |                                                                            |



## **Functional Description**

#### Introduction

The IXMS150 is designed with monolithic CMOS technology. The IC is primarily intended for use with twophase step motors in the microstepping mode but may also be used for control of two DC motors, audio amplifiers, or any application requiring two synchronized PWMs. The IXMS150 simultaneously controls the currents in each of two separate H-bridges. This device utilizes both analog and digital functions.

The IC has five fundamental sections: (1) oscillator and feedforward circuitry, (2) analog section for control of the motor currents, (3) a protection network to protect the H-bridges and the motor from abnormal conditions, (4) the digital PWM logic for the control signals, and (5) the power supply section which includes a negative bias generator.

#### Oscillator

The IXMS150 contains an internal oscillator which is controlled by adjusting the values of  $R_{\rm o}$  and  $C_{\rm o}$ . These two components determine the switching frequency, amount of dead time, and the minimum pulse width at output pins 9, 10, 15 and 16. The minimum and maximum values of  $R_{\rm o}$  and  $C_{\rm o}$  are given in the Electrical Characteristics.

The oscillator also sets the frequency of the charge pump circuit in the internal negative bias generator ( $V_{BB}$ ). At lower frequencies (<40 kHz) the value of CPUMP must be increased to assure proper operation.

#### **Feedforward Compansation**

In all fixed frequency PWM control systems open loop gain, motor current slew rate, and motor current ripple are proportional to the motor supply voltage. Gain variations due to supply voltage changes complicate the design of such systems and restrict their bandwidth to the minimum worst case condition. For this reason, an advanced adaptive compensation scheme is builtin using a feedforward technique. This feature has been designed such that open loop gain is inversely proportional to the voltage applied to the FFWD pin, normally a fraction of the motor supply. As a result, open loop gain can be

made independent of the high voltage supply and system bandwidth can be maximized.

#### Analog Section

The analog section of each channel of the IXMS150 consists of a signal processor and an error amplifier. The signal processor is required since the voltage developed across the sense resistor often contains transients associated with the switching characteristics of the power devices. These transients need to be properly filtered for the system to operate with the desired degree of precision. Because of this, the IXMS150 uses proprietary analog and digital signal processing techniques that sense the true average phase currents. Since this requires only one sense resistor per H-bridge it avoids mismatches in charge/discharge currents associated with two sense resistor per H-bridge topologies.

The instantaneous difference between the motor current and the control input is integrated via the E/A amp and fed to the PWM comparator to generate the appropriate signals for the H-bridges. External compensation of the input and sense signals is provided for via the comp1, comp2 and comp3 pins.

#### **Protection Circuitry**

The IC has a two-level Over/Excess Current protection circuit. Maximum current is represented as 0.625 V at the SENSE input. If the SENSE voltage exceeds 0.9 volts for more than one microsecond, the switching outputs (VOUT) and OUTDIS will be forced low. This represents a current that is 40 % beyond full scale. If the SENSE voltage exceeds 3.6 V, these outputs will be forced low immediately. This represents a current that is 500% beyond full scale. The time delay on the lower level of overcurrent avoids erroneous shutdowns as a result of noise spikes that are coupled from the motor's Hbridges. Note that the threshold voltages cited here assume a supply of +12 V.

#### **Undervoltage Lockout**

A third protection mechanism is the Under-Voltage Lockout. It assures proper behavior on power-up and power-down and avoids high power dissipation in the H-bridge due to insufficient gate voltage. It uses a zener for reference and has a trip point set at 8 V. It will also check to make sure there is sufficient negative bias to insure proper operation. This is typically -1.6 V. OUTDIS will be held low by the UV Lockout circuit until  $V_{\text{BB}}$  and  $V_{\text{DD}}$  reach these values.

#### **Output Disable Feature**

To enable external over-temperature protection, the output disable pin ( $\overline{OUTDIS}$ ) is available on the IXMS150. When pulled low this disables the output by forcing all output pins low. The same output disable input pin is also used as a status output. When it is pulled low by the internal circuitry it indicates an error condition such as undervoltage ( $V_{DD}$ ), insufficient negative bias voltage ( $V_{BB}$ ) or over/excess current. This can be used as a status indicator in smart systems.

#### **PWM Section**

The PWM comparator generates two complementary signals based on the output of the error amplifier. Dead-time is then added which is adjusted by the selection of the external oscillator capacitor. There is also a minimum duty cycle clamp circuit that allows the use of an AC coupled H-bridge.

#### **Supply Section**

The main power supply (V<sub>DD</sub>) is applied to pin 24. This is typically +12 V. Internal bias circuitry presents a V<sub>DD</sub>/2 reference voltage at pin 8, BYPASS. A 0.1  $\mu$ F capacitor should be connected from pin 8 to analog ground for noise immunity.

#### **Negative Bias Generator**

The IXMS150 samples both positive and negative voltages at the motor sense feedback resistor. In addition, since errors in the input current around zero are a major contributor to microstep positioning error, the input control range is bipolar and specified as ±2 V full scale. For these reasons it is desirable to have both positive and negative power supplies. In order to enable single 12 V supply operation, a negative voltage generator and regulator are built into the IC. This is a charge pump circuit whose frequency is that of the onboard oscillator. It utilizes an external pair of capacitors and diodes to generate a negative bias equal to  $-V_{DD}/5$  or approximately -2.4 V for  $V_{DD} = 12$  V.

### Application Information

#### Introduction

The advantages of step motors are well known. They may be operated in an open loop fashion, the accuracy of which is mostly dependent on the mechanical accuracy of the motor. They move in quantized increments (steps) which lends them easily to digitally controlled motion systems. In addition, their drive signals are square wave in nature and are therefore easily generated with relatively high efficiency due to their ON/OFF characteristics.

But step motors are not free of problems. Their large pulse drive waveforms create mechanical forces which excite and aggravate the mechanical resonances in the system. These are load dependent and difficult to control since step motors have very little damping of their own. At resonance a step motor system is likely to lose synchronization and therefore skip or gain a step. Being an open loop system, this would imply loss of position information and would be unacceptable. A common method of solving this problem is to avoid the band of resonance frequencies altogether, but this might put severe limitations on system performance. Steppers have 200 steps per revolution or 1.8 degrees per step. The highest resolution commercially available steppers have 400 steps per revolution or 0.9 degrees per step.

#### **Microstepping Mode**

One way to circumvent the problems associated with step motors while still retaining their open loop advantages is to use them in the microstepping mode. In this mode each of the steps is subdivided into smaller steps or "microsteps". Applying currents to both phases of the motor creates a torque phaser which is proportional to the vector sum of both currents. When the phasor completes one "turn" (360 electrical degrees), the motor moves exactly four full steps or one torque cycle. Similarly, when that phasor moves 22.5 electrical degrees the motor will move (22.5/90) • 100 = 25 % of a full step. Thus the position of the motor is determined by the angle of the torque phasor. When used with an appropriate motor a positioning accuracy of 2 % of a full step can be achieved, equaling 0.036 degrees for a 200

full steps per revolution motor. In this manner the motor can be positioned to any arbitrary angle. A common way to control the angle of the torque phasor is by applying to the motor's phases two periodic waveforms shifted by 90 electrical degrees.

Let the phase current equations be:

| $i_A = I_0 \cdot \cos \theta e$     | (1) |
|-------------------------------------|-----|
| $i_{B} = I_{O} \cdot \sin \theta e$ | (2) |

Note that  $\theta e$  is the electrical position.

The resulting torque generated by the corresponding phases would then be:

$$T_{A} = K_{0} \cdot i_{A} = K_{0} \cdot l_{0} \cdot \cos \theta e$$
(3)  
$$T_{B} = K_{0} \cdot i_{B} = K_{0} \cdot l_{0} \cdot \sin \theta e$$
(4)

where  $K_0$  is the torque constant of the motor. Substituting Eqs. (1), (2) into (3), (4) and doing vector summation the resulting total generated torque measured on the motor shaft is given by:

$$\mathsf{T}_{0} = \mathsf{K}_{0} \cdot \mathsf{I}_{0} \tag{5}$$

Note that in this case we have zero torque ripple.

Using this technique one can theoretically achieve infinite resolution with any step motor. Since the drive current waveforms are sinusoidal instead of square, the step to step oscillations are eliminated and the associated velocity ripple. This greatly improves performance at low rotational speeds and helps avoid resonance problems. In an actual application, the extent to which these things are true depends on how the two sinusoidal reference waveforms are generated.

Seemingly we have lost the quantized motion feature of a stepper when used in this mode. This can be regained by defining the term microsteps per step. Each full step is subdivided into microsteps by applying to the motor's phases those intermediate current levels for which their vector sum tracks the circle of Fig. 2 and divides the full step (90 electrical degrees) into the require number of microsteps. An example of the required phase currents for full step and four microstep per step operation are shown in Fig. 1 and 2 respectively.

#### Phase Current Matching Requirements

Assuming microstepping is being used for resolution improvement and not as a resonance avoidance technique, a step motor can be selected knowing the torque needed, its specified step



Fig. 1 Full Step Drive Waveforms

accuracy, and the required resolution or the number of microsteps per step. Next, one must determine the accuracy required of the phase currents to maintain the accuracy of the complete system. Equations (1) - (4) clearly indicate that errors in the absolute value or phase of the phase currents will impact positioning accuracy. Another observation is that by keeping the ratio of the phase currents  $i_A/i_B$ constant, errors in their value will result



Fig. 2 Four Microstep per Step Drive Waveforms



in torque value errors but no positioning errors. The question is, what is the upper bound on the current errors in order to keep the position error within some given angle  $\Delta \theta$ .

Referring to Fig. 3, assume the required currents  $i_A$ ,  $i_B$  are given by Equations (1), (2) respectively such that their vector sum points to position P. Let the phase currents vary by a small amount such that their vector sum lies within a circle centered at point P and having the radius i, as indicated in Fig. 3.



Fig. 3 Effect of Current Errors on Position

If follows that the worst case position error occurs for the cases where the vector sum is tangent to the circle such as point  $P_1$ , at which:

 $\tan\left(\Delta \theta\right) = \Delta i/I_{0} \tag{6}$ 

For instance, to keep position error to less than 1% of a full step, the electrical angular error would be:

 $\Delta \theta = 0.01 \cdot 90^\circ = 0.9^\circ \tag{7}$ 

This is assuming there are 90 electrical degrees for a full step. Therefore total current error must be:

$$i/I_0 = \tan(\Delta \theta) = 0.016 \text{ or } 1.6 \%)$$
 (8)

Thus the current error must be kept to less than 1.6 % of full scale or peak current at each phase for 1 % maximum position error. This upper bound on error includes all error sources such as zero offset errors and full scale matching errors. Another interesting observation is that in the vicinity of a full step (i.e.,  $\theta = 0$ ), the phase having the bigger impact on position error is the one carrying the smaller current through it. This has a strong impact on input waveform generation.

#### Input waveform generation

It has been shown that the two input signals,  $VIN_A$  and  $VIN_B$ , are sinusoidal and 90° out of phase. This may be accomplished by using two look-up



Fig. 4 Simple Reference Waveform Generator

tables stored in ROM and two DACs per Fig. 4. An up/down counter may be used to generate the appropriate address locations for the ROMs and the data outputs used to control the DACs. The user then need only supply up or down pulses to the counter to control the IXMS150 and hence the motor.

In higher performance systems a microprocessor may be used in place of the counter and the ROMs. The micro can perform the look-up function and calculate the appropriate system responses, velocity profiles, etc. necessary for total system operation. An example of this configuration is shown in Fig. 5.



Fig. 5 Microprocessor Based Referenced Waveform Generator

#### **Current Sensing Considerations**

Most commercially available monolithic PWM controllers monitor and control the peak of the phase current by comparing the voltage across the sense resistor with a ramp voltage. This approach assumes that the ripple current is fixed in amplitude. Results shown later clearly indicate the variation of the ripple current with frequency. But even in fixed frequency systems the ripple current is directly proportional to the motor supply voltage and to the back EMF voltage of the motor. Ripple current is not insignificant compared to the full scale current and therefore cannot be neglected in a precision system. In addition, there are transients associated with the turn on and turn off characteristics of the power devices in

the H-bridge that must be properly filtered if the system is to operate with the desired degree of precision.

This presents a significant engineering challenge that has been solved by IXYS's design team. Using proprietary analog and digital signal processing techniques, IXYS has developed a control system that measures the true average phase currents. Requiring only one sense resistor per H-bridge, this technique avoids errors due to mismatches in charge/discharge currents associated with using one sense resistor on each leg of the H-bridge. This improves system performance as well as minimizing component count. The sense resistor for each H-bridge should be selected based on the required peak motor current:

The voltage developed across this resistor is then applied to the corresponding sense input for each H-bridge.

#### **Negative bias Generator**

One of today's cost cutting trends is to minimize the number of power supplies, implying single supply operation for the control section. Yet the current feedback and reference inputs are bipolar signals. Level shifting has been used for the reference input in the past, but that can not be easily done for the feedback signal without impacting accuracy or efficiency. In practice one finds that in order to generate true zero voltage having low impedance drive there must be a negative power supply. Otherwise there will be a tradeoff sacrificing accuracy for simpler system design.

For these reasons the approach selected by IXYS was different. Taking advantage of our CMOS design, we opted to build into the chip a negative bias generator. This does put stringent demands on noise coupling but results in the most flexible system having the highest possible accuracy. The built in charge pump circuit requires two capacitors and two diodes to be added externally. The recommended component values for an oscillator frequency of 100 kHz are given below.

 $\begin{array}{l} \text{C1} = 0.047 \; \mu\text{F} \\ \text{C2} = 100 \; \mu\text{F} \\ \text{D1} = \text{D2} = 1\text{N4148} \\ \text{Note:} \; \; \text{V}_{\text{BB}} = \text{-}(\text{V}_{\text{DD}}/\text{5}) \end{array}$ 



Use the formula C2 = 100  $\mu$ F  $\cdot$  100 kHz/f<sub>osc</sub> for other frequencies.

With  $V_{DD}$  = 12 V and an oscillator frequency of 100 kHz, the bias generator should be able to source 3 mA at -2.4 V using these component values. This capability may be used to power other external circuitry as long as there is sufficient remaining negative bias to allow the IXMS150 to operate properly.

# Impact of PWM Frequency on System Operation

PWM switching frequency has a pronounced effect on ripple current through the motor windings, the resulting eddy current losses in the motor, and system efficiency. As expected, motor current ripple goes down as frequency increases and therefore losses resulting from ripple currents are also reduced. Switching frequency also impacts losses in the power stage. These losses are associated with the energy necessary to turn on and off the power MOSFEts and are proportional to the switching frequency. In addition, the switching frequency has a limiting effect on maximum current loop bandwidth and therefore system bandwidth and therefore system bandwidth and maximum motor velocity.

#### Oscillator

The oscillator block diagram is shown in Fig. 6.

The frequency is set by the values of  $\rm R_{o}$  and  $\rm C_{o}:$ 

$$f_{osc} = 1/R_o \cdot (C_o + C_p)) \tag{10}$$

Note:  $C_{p}$  is a 38 pF (typ.) internal parasitic capacitor.

#### Feedforward

The amplitude of the oscillator waveform and overall system gain are modulated by the voltage applied to the feedforward pin (FFWD). This is nominally 3.5 V which should be divided down from the motor high voltage supply. This will allow system bandwidth to be maximized by making overall system gain inversely proportional to the motor supply voltage. Refer to Fig. 7 for an example of how feedforward is connected to the motor supply. It is recommended that a filter capacitor be connected from FFWD to AGND to filter noise spikes from the motor supply. Its value should be chosen so that the time constant of the capacitor and the parallel combination of  $R_{ff1}$  and  $R_{ff2}$  is such that switching noise will be filtered but not variations in the motor supply such as 120 Hz ripple, etc.

#### **Minimum Pulse Width**

The minimum output pulse width can also be modified by adjusting the oscillator capacitor  $C_{\rm o}$ . The relationship is:

$$\begin{split} t_{\text{pw(min)}} &= \text{R}_{\text{mp}} \bullet (\text{C}_{\text{o}} + \text{C}_{\text{p}}) \quad (11) \\ \text{Note: } \text{R}_{\text{mp}} \text{ is a 3.6 k} \Omega \text{ (typ.) internal} \\ \text{resistor, and } \text{C}_{\text{p}} \text{ is a 38 pF (typ.) internal} \\ \text{parasitic capacitor.} \end{split}$$

#### **Dead Time**

Dead time is adjusted via the external oscillator capacitor  $C_{o}$ . There is an internal resistor in the dead time circuit as well. The relationship is:

$$t_{\rm DT} = R_{\rm DT} \cdot (C_{\rm o} + C_{\rm p}) \tag{12}$$

Note:  $R_{DT}$  is a 1.4 k $\Omega$  (typ.) internal resistor and  $C_p$  is a 38 pF (typ.) internal parasitic capacitor.



Fig. 7 Feedforward Connection Diagram

#### **Motor Slew Rate Limitations**

The maximum motor velocity in a microstepping application is determined by the maximum rate of change of the phase currents. Once this limit is reached the system is "slew rate limited," at which point the peak undistorted phase current times the frequency of the input command is a fixed value. The theoretical limit for the maximum di/dt of the phase currents is determined by the motor supply voltage and the inductance of the motor:

di/dt (max) = 
$$V_{HV}/L_m$$
 (13)

The limit does not take into account the back EMF of the motor, the bandwidth of the current loop driving the motor, or the minimum pulse width. The motor's back EMF will tend to reduce the voltage applied across the motor windings, effectively reducing the maximum slew rate. The bandwidth of the current loop must also be high enough so as not to degrade system performance.

#### Non-Circulating Operating Mode

The IXMS150 is designed to control an H-bridge in the non-circulating mode. The equivalent circuit for an H-bridge is shown in Fig. 8. In the non-circulating



Fig. 6a: Oscillator Block Diagram







mode, either SW1 and SW4 are on  $(V_m = V_{HV})$  or SW2 + SW3 are on  $(V_m = -V_{HV})$ . By appropriately controlling the duty cycle of SW1//4 vs. SW2/3, the average motor voltage can be controlled such that:

$$V_{m(avq)} = 2 \cdot V_{HV} (0.5-DUTY)$$

Note: DUTY is defined as the duty cycle of  $\rm V_{\rm outa}.$ 

The IXMS150 can now regulate the motor coil current by commanding the voltage level and polarity required.



Fig. 8 Simplified H-Bridge Diagram

#### The Power Stage: An AC Coupled H-Bridge

Fig. 9 shows the power driver selected for this application. Two of these are required to drive the two phase step motor. This circuit uses two N-channel and two P-channel power MOSFETs as opposed to an all N-channel architecture. The drawback of using P-channel transistors is that they are larger and therefore more expensive than similarly rated N-channel devices. But the advantages are much simplified drive and level shifting circuitry. This results in a lower component count and therefore higher reliability. It also lends itself easily to hybridization. Other advantages of this topology are: a) the high efficiency associated with level shifting by AC coupling since no power is dissipated in the capacitors, and b) the same circuit can be used for motor applications ranging from 12 V to several hundred volts, the only modification being appropriately rated power transistors and coupling capacitors.

A limitation of this circuit is that it cannot be used at duty cycle extremes. This would require one input to be continuously low while the other is continuously high. Eventually the coupling capacitors (C1, C2) would charge up to a voltage that would no longer fully enhance the MOSFETs, with the top two transistors (Q2, Q4) being destroyed due to excessive power dissipation. Therefore one has to limit the duty cycle excursions. The solution selected by IXYS limits the minimum output pulse-width to 0.5 ms, which translates to a duty cycle range of 5 % to 95 % when operating at 100 kHz, or wider at lower frequencies. There is a penalty of slightly limiting the maximum slew rate to (1-2 • Min Duty) of the unrestricted case, which translates to 90 % of the ration with a particular motor. The basic elements involved in the current loop are illustrated in Fig. 11a. Referring to Fig. 11b, the loop gain for this system (the product of the forward and feedback gain terms) can be expressed as:

$$G_{loop}(s) = G_{e/a}(s) \bullet K_{pwm} \bullet G_{m}(s) \bullet G_{i}(s)$$
(14)

where

 $G_{_{e/a}}(s)$  = error amplifier gain  $K_{_{pwm}}$  = cascade of pwm and output H-bridge gain



#### Fig. 9 AC Coupled H-Bridge Diagram

unrestricted maximum slew rate for 100 kHz operation.

#### Loop Compensation Information

When used with the appropriate power stage, each channel of the IXMS150 acts as a closed loop transconductance amplifier. As such, it must be properly compensated to guarantee stable ope $G_{m}(s)$  = cascade of motor winding impedance and H-bridge parasitic resistance

 $G_i(s)$  = current sense resistor and sampling amplifier gain

The value of each of these terms can be determined from the Laplace transform diagram in Fig. 11b:



Fig. 10a Simplified Microstepping System





Fig. 10b Input Offset Adjust Circuit





$$G_{e/a}(s) = (1 + sRC)/(sR_2C)$$
 (15)  
 $K = 2 \cdot V / V$  (16)

$$K_{pwm} = 2 \cdot V_{HV} / V_A$$
 (16)  
 $G_m(S) = 1/(sL_m + R_m + R_{sw} + R_s)$  (17)

 $G_i(s) = 2 \cdot R_s$ 

(ignoring sampling effects) (18) where:

R, C = external compensation components

- $R_2$  = internal input resistor, typically 20 kΩ
- $V_{HV}$  = motor high voltage power supply
- V<sub>A</sub> = oscillator amplitude, typically 7 V

- \_m = motor inductance
- $R_m$  = motor winding resistance
- R<sub>sw</sub> = power switch resistance
- R<sub>s</sub> = sense resistor

It is very important that the motor inductance value used in the analysis is not the value on the manufacturer's data sheet but rather the value observed in actual operation. The PWM action causes high frequency effects that can change the apparent small signal inductance significantly. These effects are dependent upon voltage as well as current and frequency. It is best to measure the observed current ripple at the motor supply voltage and switching frequency you expect to use and calculate the actual motor inductance using:

$$L_{m} = V_{HV} / ((2 \cdot F_{osc})(I_{max} - I_{min}))$$
(19)

It is also important to note that both  $R_m$ and  $R_{sw}$  are temperature dependent. The motor winding resistance can increase by as much as 30 % at high temperatures, and if FETs are used as power devices,  $R_{sw}$  can increase to 2.2 times its value at room temperature.

Substituting equations 15 through 18 into equation 14 gives the expanded loop gain equation (eq. 20):

$$G_{loop}(s) = \frac{(1+sRC) \cdot 2Vhv \cdot 1 \cdot 2Rs}{sR_2C \cdot V_A \cdot (sL_m+R_m+R_s+R_{sw})}$$

which can be written as (eq.21):

$$G_{loop}(s) = \frac{4 \cdot V_{HV} \cdot R_{s}}{V_{A}(R_{m} + R_{s} \cdot R_{sw})} \cdot \rightarrow \frac{(1+RC)}{(sR_{a} \cdot C) [1+sL_{a}/R_{a} + R_{s} + R_{sw}]}$$

Therefore the poles and zeros of the system are:

pole at DC, with a 0dB intercept of:

$$4V_{HV}R_{s}/[V_{A}R_{2}C(R_{m}+R_{s}+R_{sw})]$$

zero at 1/(R • C)

pole at  $(R_m + R_s + R_{sw}) / L_m$ 

A simple Bode analysis can be performed to provide the necessary information to guarantee the stability of the loop. A stable system will result when the gain crossover occurs at a point where the loop phase shift is less than -180 degrees. The gain crossover point is defined as the frequency where the magnitude of  $G_{loop}(s) = 1$  (0dB).

The Bode plot will show two figures of merit that give an indication of the behavior of the closed loop system, gain margin and phase margin. Gain margin is the amount of loop signal attenuation at the point where the loop phase has reached -180 degrees. It is a qualitative measure of how susceptible the loop is to noise outside its bandwidth. Phase margin is the amount of



Fig. 11a Loop Compensation Block Diagram

1-43





Fig. 11b Simplified laplace transform for stability analysis

phase shift left (i.e., 180 - (loop phase)) at the gain crossover. This number gives the most intuitive feeling for how the loop will respond to perturbations and variations in system parameters. Theoretically, a system with 1 degree of phase margin is stable. However, a step input to a system with small phase margin will cause an underdamped, ringly response or an oscillation that dies out after a long time.

In a step motor, this overshoot and ring in the current waveform is unacceptable. As the phase margin of a system is increased, the response to a step input slows down and the ringing is decreased. The response becomes more damped. In a practical system, the minimum acceptable phase margin is about 30 degrees. More than 90 degrees slows the system response with no significant improvement in stability. 60 degrees is usually considered optimal, if no other constraints exist.

In a PWM motor drive amplifier, there are several additional constraints that apply. Because the levels of voltage and current being switched are so high, synchronous noise appears everywhere and can degrade system performance. It is common to see apparent instabilities that are simply loop amplification of subharmonic switching transient noise. It is important to maintain at least 60 degrees of phase margin and to maintain as much gain margin as is practical. The PWM comparator delays, power stage gate drive delays, and the sampling technique used to generate the current feedback signal also account for significant phase delays when the switching frequency is high, or when the excitation approaches the switching frequency. For these reasons it is usually advisable to design for a calculated 60 to 90 degree phase margin because of the importance of the effects not accounted for in the linearized circuit model.



© 1998 IXYS All rights reserved