

#### **Features and Benefits**

- Designed for automotive, battery-powered applications
- Customer programmable quiescent duty cycle, sensitivity, and PWM carrier frequency, through VCC pin
- Simultaneous programming of duty cycle, sensitivity, and PWM carrier frequency, for system optimization
- Factory programmed sensitivity temperature coefficient and quiescent duty cycle drift
- Selectable unidirectional or bidirectional quiescent duty eycles
- Pulse width modulated (PWM) output provides increased noise immunity compared to analog output
- Temperature-stable quiescent duty cycle output and sensitivity

Continued on the next page...

### Package: 4-pin SIP (suffix KT)



### Description

The A1354 device is a high precision, programmable 2-wire Hall effect linear sensor IC with a pulse width modulated (PWM) output. The duty cycle (D) of the PWM output signal is proportional to the applied magnetic field. The A1354 device converts an analog signal from its internal Hall circuit to a digitally encoded PWM output signal. The coupled noise immunity of the digitally encoded PWM output is far superior to the noise immunity of an analog output signal.

The BiCMOS, monolithic circuit inside of the A1354 integrates a Hall element, precision temperature-compensating circuitry to reduce the intrinsic sensitivity and offset drift of the Hall element, a small-signal high-gain amplifier, proprietary dynamic offset cancellation circuits, and PWM conversion circuitry. The dynamic offset cancellation circuits reduce the residual offset voltage of the Hall element. Hall element offset is normally caused by device overmolding, temperature dependencies, and thermal stress. The high frequency offset cancellation (chopping) clock allows a greater sampling rate, which increases the accuracy of the output signal and results in faster signal processing capability.

The A1354 device is provided in a lead (Pb) free 4-pin single inline package (KT suffix), with 100% matte tin leadframe plating.

### **Functional Block Diagram**



### Features and Benefits (continued)

- Output duty cycle clamps provide short circuit diagnostic capabilities
- Optional 50% duty cycle calibration test mode at device power-up
- Wide ambient temperature range: -40°C to 125°C
- Resistant to mechanical stress
- Extremely thin package: 1 mm case thickness

#### **Selection Guide**

| Part Number  | Packing*                    |
|--------------|-----------------------------|
| A1354KKTTN-T | 4000 pieces per 13-in. reel |

<sup>\*</sup>Contact Allegro® for additional packing options



### **Absolute Maximum Ratings**

| Characteristic                | Symbol               | Notes   | Rating     | Unit |
|-------------------------------|----------------------|---------|------------|------|
| Forward Supply Voltage        | V <sub>CC</sub>      |         | 28         | V    |
| Reverse Supply Voltage        | V <sub>RCC</sub>     |         | -16        | V    |
| Forward Supply Current        | I <sub>CC</sub>      |         | 50         | mA   |
| Reverse Supply Current        | I <sub>RCC</sub>     |         | -50        | mA   |
| Operating Ambient Temperature | T <sub>A</sub>       | Range K | -40 to 125 | °C   |
| Maximum Junction Temperature  | T <sub>J</sub> (max) |         | 165        | °C   |
| Storage Temperature           | T <sub>stg</sub>     |         | -65 to 165 | °C   |

### **Pin-out Diagram**



#### **Terminal List**

| Number | Name | Function                                                      |
|--------|------|---------------------------------------------------------------|
| 1      | VCC  | Input power supply; use bypass capacitor to connect to ground |
| 2      | NC   | Not connected                                                 |
| 3      | NC   | Not connected                                                 |
| 4      | GND  | Ground                                                        |



## OPERATING CHARACTERISTICS (A) Valid with C<sub>BYPASS</sub> = 0.01 μF, over full operating temperature range, T<sub>A</sub>, and V<sub>CC</sub>, unless otherwise noted

| Characteristics                   | Symbol                 | Test Conditions                                                                                                      | Min. | Тур.  | Max. | Unit <sup>1</sup> |
|-----------------------------------|------------------------|----------------------------------------------------------------------------------------------------------------------|------|-------|------|-------------------|
| ELECTRICAL CHARACTERISTICS        | ·                      |                                                                                                                      |      |       |      |                   |
| Supply Voltage <sup>2</sup>       | V <sub>CC</sub>        |                                                                                                                      | 4.5  | 12    | 16   | V                 |
| Supply Current                    | I <sub>CC(LOW)</sub>   |                                                                                                                      | _    | 6     | 9    | mA                |
| Supply Current                    | I <sub>CC(HIGH)</sub>  |                                                                                                                      | 13   | _     | 19   | mA                |
| Supply Current Ratio <sup>3</sup> | I <sub>CC(rat)</sub>   |                                                                                                                      | 2    | _     | _    | _                 |
| Power-On Time <sup>4</sup>        |                        | $T_A = 25$ °C, $C_L$ (of test probe)= 10 pF,<br>Sens = 0.1%/G, $f_{PWM} = f_{PWM(slow)}$                             | -    | 100   | _    | ms                |
| Fower-Off filme*                  | t <sub>PO</sub>        | $T_A = 25$ °C, $C_L$ (of test probe)= 10 pF,<br>Sens = 0.1%/G, $f_{PWM} = f_{PWM(fast)}$                             | ı    | 25    | _    | ms                |
| Supply Zener Clamp Voltage        | V <sub>Z</sub>         | $T_A = 25^{\circ}C$ , $I_{CC} = I_{CC}(max) + 3 mA$                                                                  | 28.5 | 32    | _    | V                 |
| Internal Bandwidth                | BWi                    | Small signal –3 dB, 100 G <sub>(P-P)</sub> magnetic input signal                                                     | -    | 200   | _    | Hz                |
| Chopping Frequency <sup>5</sup>   | f <sub>C</sub>         | T <sub>A</sub> = 25°C                                                                                                | _    | 200   | _    | kHz               |
| OUTPUT CHARACTERISTICS            | ·                      |                                                                                                                      |      |       |      |                   |
| Response Time <sup>4</sup>        |                        | T <sub>A</sub> = 25°C, Impulse magnetic field of 300 G,<br>Sens = 0.1%/G, f <sub>PWM</sub> = f <sub>PWM</sub> (slow) | -    | 100   | _    | ms                |
| Response Time*                    | t <sub>RESPONSE</sub>  | T <sub>A</sub> = 25°C, Impulse magnetic field of 300 G,<br>Sens = 0.1%/G, f <sub>PWM</sub> = f <sub>PWM</sub> (fast) | -    | 25    | -    | ms                |
| Clama Duty Cycloofi               | D <sub>CLP(HIGH)</sub> | T <sub>A</sub> = 25°C                                                                                                | 90   | 92.5  | 95   | %                 |
| Clamp Duty Cycles <sup>6</sup>    | D <sub>CLP(LOW)</sub>  | T <sub>A</sub> = 25°C                                                                                                | 5    | 7.5   | 10   | %                 |
| Duty Cycle Jitter <sup>4,7</sup>  | Jitter <sub>PWM</sub>  | T <sub>A</sub> = -10°C to 85°C, Sens = 0.12%/G, Measured over 1000 Output PWM clock periods                          | -    | ±0.05 | -    | %                 |
| Duty Cycle Resolution             | Res <sub>PWM</sub>     | $T_A = -10^{\circ}$ C to 85°C, Sens = 0.12%/G, Measured over 1000 Output PWM clock periods                           | -    | ±0.42 | -    | G                 |

<sup>&</sup>lt;sup>1</sup>1 G (gauss) = 0.1 mT (millitesla).



3

<sup>2</sup>Supply voltage, V<sub>CC</sub>, is defined as the voltage drop between pin 1 and pin 4 of the device. It does not include the voltage drop across R<sub>SENS</sub>.

 $<sup>^3</sup>I_{CC}$  ratio is defined as  $I_{CC(HIGH)}\,/\,I_{CC(LOW)}$  for a given PWM cycle.

<sup>&</sup>lt;sup>4</sup>See Characteristic Definitions section.

<sup>&</sup>lt;sup>5</sup>f<sub>C</sub> varies up to approximately ±20% over the full operating ambient temperature range, T<sub>A</sub>, and process.

<sup>&</sup>lt;sup>6</sup>Clamp duty cycles are tested with the maximum sensitivity code addressed and an applied magnetic field that is at least 25% greater than the dynamic range.

<sup>7</sup> Jitter is dependent on the sensitivity of the device. Values are based on characterization only and are not guaranteed via production testing.

### $\textbf{PROGRAMMING CHARACTERISTICS} \ \ \text{Valid over full operating voltage range and } \ T_{A} = 25^{\circ}\text{C}, \ \text{unless otherwise noted}$

| Characteristics                                                    | Symbol                     | Test Conditions            | Min.  | Тур.                        | Max.  | Unit <sup>1</sup> |
|--------------------------------------------------------------------|----------------------------|----------------------------|-------|-----------------------------|-------|-------------------|
| PRE-PROGRAMMING TARGET <sup>2</sup>                                |                            |                            |       |                             |       |                   |
| Pre-Programming Quiescent Duty Cycle<br>Output                     | D <sub>(Q)PRE</sub>        | B = 0 G                    | -     | 50                          | _     | %                 |
| Pre-Programming Sensitivity                                        | Sens <sub>PRE</sub>        |                            | _     | 0.08                        | _     | %/G               |
| Pre-Programming PWM Output Carrier Frequency                       | f <sub>PWMPRE</sub>        |                            | -     | 150                         | _     | Hz                |
| QUIESCENT DUTY CYCLE PROGRAMM                                      | /ING                       |                            |       |                             |       |                   |
| Initial Ouiseasant Duty Cycle Output3                              | D <sub>(Q)UNIinit</sub>    | Unipolar device, B = 0 G   | _     | 20                          | -     | %                 |
| Initial Quiescent Duty Cycle Output <sup>3</sup>                   | D <sub>(Q)Blinit</sub>     | Bipolar device, B = 0 G    | _     | D <sub>(Q)PRE</sub>         | _     | %                 |
| Guaranteed Quiescent Duty Cycle                                    | D <sub>(Q)UNI</sub>        | Unipolar device, B = 0 G   | 10    | -                           | 30    | %                 |
| Programming Range <sup>4</sup>                                     | D <sub>(Q)BI</sub>         | Bipolar device, B = 0 G    | 40    | _                           | 60    | %                 |
| Quiescent Duty Cycle Output <sup>5</sup>                           |                            | Coarse (range programming) | _     | 1                           | _     | bit               |
| Programming Bits                                                   |                            | Fine (value adjustment)    | _     | 9                           | _     | bit               |
| Average Quiescent Duty Cycle Output Step Size <sup>6,7</sup>       | Step <sub>D(Q)</sub>       |                            | 0.055 | 0.075                       | 0.095 | %                 |
| Quiescent Duty Cycle Output<br>Programming Resolution <sup>8</sup> | Err <sub>PGD(Q)</sub>      |                            | -     | Step <sub>D(Q)</sub> × ±0.5 | -     | %                 |
| SENSITIVITY PROGRAMMING                                            |                            |                            | ·     |                             |       |                   |
| Initial Sensitivity                                                | Sens <sub>init</sub>       |                            | _     | Sens <sub>PRE</sub>         | _     | %/G               |
| Guaranteed Sensitivity Programming Range <sup>9</sup>              | Sens                       |                            | 0.1   | _                           | 0.2   | %/G               |
| Sensitivity Programming Bits                                       |                            |                            | _     | 8                           | _     | bit               |
| Average Sensitivity Step Size <sup>6,7</sup>                       | Step <sub>SENS</sub>       |                            | 600   | 800                         | 900   | μ%/G              |
| Sensitivity Programming Resolution <sup>8</sup>                    | Err <sub>PGSENS</sub>      |                            | -     | Step <sub>SENS</sub> × ±0.5 | -     | μ%/G              |
| CARRIER FREQUENCY PROGRAMMIN                                       | G                          |                            | ·     |                             |       |                   |
| Initial Carrier Fraguency                                          | f <sub>PWM(slow)init</sub> |                            | _     | 19                          | _     | Hz                |
| Initial Carrier Frequency                                          | f <sub>PWM(fast)init</sub> |                            | _     | f <sub>PWMPRE</sub>         | _     | Hz                |
| Guaranteed Carrier Frequency                                       | f <sub>PWM(slow)</sub>     |                            | 12    | -                           | 15.5  | Hz                |
| Programming Range <sup>9</sup>                                     | f <sub>PWM(fast)</sub>     |                            | 95    | -                           | 115   | Hz                |
| Coarse Carrier Frequency Programming                               |                            | Coarse (range programming) | _     | 1                           | -     | bit               |
| Bits <sup>10</sup>                                                 |                            | Fine (value adjustment)    | _     | 4                           | -     | bit               |
| Average Carrier Frequency Step Size <sup>6,7</sup>                 | Step <sub>fPWM(slow)</sub> |                            | 0.5   | 0.8                         | 1.1   | Hz                |
| Average Carrier Frequency Step Size                                | Step <sub>fPWM(fast)</sub> |                            | 4.5   | 6.4                         | 8.3   | Hz                |
| Carrier Frequency Programming Resolution <sup>8</sup>              | Err <sub>PGfPWM</sub>      |                            | _     | Step <sub>fPWM</sub> × ±0.5 | _     | Hz                |

Continued on the next page...



### A1354

## High Precision 2-Wire Linear Hall Effect Sensor IC with Pulse Width Modulated Output

### PROGRAMMING CHARACTERISTICS (continued) Valid over full operating temperature range, TA, and VCC, unless otherwise noted

| Characteristics                     | Symbol | Test Conditions | Min. | Тур. | Max. | Unit <sup>1</sup> |
|-------------------------------------|--------|-----------------|------|------|------|-------------------|
| CALIBRATION TEST MODE PROGRAM       | MING   |                 |      |      |      |                   |
| Calibration Test Mode Selection Bit |        |                 | _    | 1    | _    | bit               |
| LOCK BIT PROGRAMMING                |        |                 |      |      |      |                   |
| Overall Programming Lock Bit        |        |                 | _    | 1    | _    | bit               |

<sup>&</sup>lt;sup>1</sup>1 G (gauss) = 0.1 mT (millitesla).



<sup>&</sup>lt;sup>2</sup>Raw device characteristic values before any programming.

 $<sup>^3</sup>D_{(Q)UNlinit}$  may be below the clamp duty cycle  $D_{CLP(LOW)}$ .  $D_{(Q)}$  will not appear to respond to programming pulses until  $D_{(Q)} > D_{CLP(LOW)}$ .  $^4D_{(Q)}$  (max) is the value guaranteed with all programming fuses blown (maximum programming code set). The  $D_{(Q)}$  range is the total range from  $D_{(Q)init}$  up to and including  $D_{(Q)}(max)$ . See Characteristic Definitions section.

<sup>&</sup>lt;sup>5</sup>Bit for selecting between  $D_{(Q)BI}$  and  $D_{(Q)UNI}$  programming ranges.

<sup>&</sup>lt;sup>6</sup>Step size is larger than required, in order to provide for manufacturing spread. See Characteristic Definitions section.

Non-ideal behavior in the programming D-to-A converter (DAC) can cause the step size at each significant bit rollover code to be greater than twice the maximum specified value of  $Step_{D(Q)},\,Step_{SENS},\,or\,Step_{fPWM}$ 

<sup>8</sup>Overall programming value accuracy. See Characteristic Definitions section.

<sup>9</sup>f<sub>PWM</sub>(max) is the value available with all programming fuses blown (maximum programming code set). f<sub>PWM</sub> range is the total range from f<sub>PWMinit</sub> up to and including f<sub>PWM</sub>(max). See Characteristic Definitions section.

<sup>&</sup>lt;sup>10</sup>Bit for selecting between f<sub>PWM(fast)</sub> and f<sub>PWM(slow)</sub> programming ranges.

## A1354

# High Precision 2-Wire Linear Hall Effect Sensor IC with Pulse Width Modulated Output

## **OPERATING CHARACTERISTICS (B)** Valid with $C_{BYPASS} = 0.01 \ \mu\text{F}$ , over full operating temperature range, $T_A$ , and $V_{CC}$ , unless otherwise noted

| Characteristics                                                              | Symbol               | Test Conditions                                                     | Min. | Тур.   | Max. | Unit |  |
|------------------------------------------------------------------------------|----------------------|---------------------------------------------------------------------|------|--------|------|------|--|
| FACTORY PROGRAMMED SENSITIVITY TEMPERATURE COEFFICIENT AND SENSITIVITY DRIFT |                      |                                                                     |      |        |      |      |  |
| Sensitivity Temperature Coefficient <sup>1</sup>                             | TC <sub>Sens</sub>   |                                                                     | -    | 0.12   | _    | %/°C |  |
| Maximum Sensitivity Drift Through Temperature Range <sup>2,3</sup>           | ∆Sens <sub>TC</sub>  | Sens = Sens <sub>PRE</sub> , D = $D_{(Q)PRE}$ , calculated at 125°C | -    | < ±2   | -    | %    |  |
| Sensitivity Drift Due to Package<br>Hysteresis <sup>3,4</sup>                | ΔSens <sub>PKG</sub> | T <sub>A</sub> = 25°C, after temperature cycling                    | -    | < ±1.2 | _    | %    |  |
| FACTORY PROGRAMMED DUTY CYCL                                                 | E DRIFT              |                                                                     |      |        |      |      |  |
| Duty Cycle Drift <sup>1,3</sup>                                              | $\Delta D_{(Q)}$     | B = 0 G                                                             | _    | 0      | _    | %    |  |
| Duty Cycle Drift Error <sup>3</sup>                                          | $Err_{\DeltaD(Q)}$   | B = 0 G, Sens = Sens <sub>PRE</sub> , D = D <sub>(Q)pre</sub>       | -    | < ±0.3 | _    | %    |  |
| ERROR COMPONENTS                                                             |                      |                                                                     |      |        |      |      |  |
| Linearity Sensitivity Error <sup>3</sup>                                     | Lin <sub>ERR</sub>   |                                                                     | _    | < ±1.0 | _    | %    |  |
| Symmetry Sensitivity Error <sup>3,5</sup>                                    | Sym <sub>ERR</sub>   |                                                                     | -    | < ±1.5 | _    | %    |  |

<sup>&</sup>lt;sup>1</sup>Programmed at 125°C and calculated relative to 25°C.



 $<sup>^2</sup>$ Sensitivity drift from expected value at  $T_A$  after programming  $TC_{SENS}$ . See Characteristic Definitions section.

<sup>3</sup>Specification unit is defined in percent as result of the calculation shown in the Characteristics Definitions section.

<sup>&</sup>lt;sup>4</sup>See Characteristic Definitions section.

<sup>&</sup>lt;sup>5</sup>Symmetry error is only valid for bipolar devices.

#### Thermal Characteristics may require derating at maximum conditions

| Characteristic             | Symbol          | Test Conditions*                               | Value | Units |
|----------------------------|-----------------|------------------------------------------------|-------|-------|
| Package Thermal Resistance | $R_{\theta JA}$ | 1-layer PCB with copper limited to solder pads | 174   | °C/W  |

<sup>\*</sup>Additional thermal information available on Allegro website.

### **Power Dissipation versus Ambient Temperature** Power Dissipation, PD (mW) Temperature, T<sub>A</sub> (°C)



## V<sub>CC</sub> at Various Duty Cycles 4 µs per division

≈10% Duty Cycle (Low Clamp)



 $t_{High}$  – duration of high voltage

 $t_{\text{Low}}$  – duration of the low voltage

T<sub>Period</sub> – one full frequency cycle

Duty Cycle =  $(t_{High} / T_{Period}) \times 100\%$ 

 $\approx 50\%$  Duty Cycle



#### Unidirectional Field Detection

| Duty Cycle | Field Detection   |
|------------|-------------------|
| 10%        | 0 G               |
| 10%-90%    | 0 to +n G (south) |

#### **Bidirectional Field Detection**

| Duty Cycle | Field Detection           |
|------------|---------------------------|
| 50%        | 0 G                       |
| 50%-90%    | 0 to +n G (south)         |
| 50%-10%    | 0 to − <i>n</i> G (north) |

≈ 90% Duty Cycle (High Clamp)



8

#### **Characteristic Definitions**

Quiescent Voltage Output and Duty Cycle The operating output voltage, V<sub>OUT</sub>, is determined by the PWM output voltage duty cycle, D. In turn, D is proportional to a change in air gap between the A1354 Hall element and the magnetic target. The output duty cycle in the quiescent state (no significant magnetic field: B = 0 G),  $D_{(O)}$ , remains steady at the specific programmed duty cycle throughout the entire operating ranges of V<sub>CC</sub> and ambient temperature, T<sub>A</sub>.

**Power-On Time** When the supply is ramped to its operating voltage, the device requires a finite time to power its internal components before supplying a valid PWM output duty cycle. Power-On Time, t<sub>PO</sub>, is defined as the time it takes, with no applied magnetic field (quiescent state), for the PWM output voltage duty cycle,  $D_{(O)}$ , to settle within  $\pm 5\%$  of its steady state value, after the power supply has reached its minimum specified operating voltage,  $V_{CC}(min)$ .

**Response Time** The time interval, t<sub>RESPONSE</sub>, between a) when the applied magnetic field reaches 90% of its final value, and b) when the device reaches 90% of its output level corresponding to the applied magnetic field. t<sub>RESPONSE</sub> depends on the signal delay defined by the device filter bandwidth, BW<sub>i</sub>, and a full PWM period, which is required for output update.

**Guaranteed Quiescent Duty Cycle Output Range The** quiescent duty cycle output, D(O), can be programmed within the guaranteed quiescent duty cycle range limits: D<sub>(O)</sub>(min) and  $D_{(O)}(max)$ . The available guaranteed programming range for  $D_{(O)}$ falls within the distributions of the initial duty cycle, D<sub>(O)init</sub>, and of the maximum programming code for setting  $D_{(O)}$ , as shown in figure 1.

Average Quiescent Duty Cycle Output Step Size The average quiescent duty cycle output step size, Step<sub>D(O)</sub>, for a single device is determined using the following calculation:

$$Step_{D(Q)} = \frac{D_{(Q)maxcode} - D_{(Q)mincode}}{2^{n} - 1} , \qquad (1)$$

where:

n is the number of available programming bits in the trim range, 2<sup>n</sup>-1 is the value of the maximum programming code in the range, and

 $D_{(Q)maxcode}$  is the quiescent output duty cycle at code  $2^n\!-\!1$ .

#### **Quiescent Duty Cycle Output Programming Resolution**

The programming resolution for any device is half of its programming step size. Therefore, the typical programming resolution is:

$$Err_{PGD(Q)}(typ) = 0.5 \times Step_{D(Q)}(typ) \qquad (2)$$

**Quiescent Output Duty Cycle Drift Through Tempera**ture Range Due to internal component tolerances and thermal considerations, the quiescent duty cycle temperature coefficient,  $TC_{D(O)}$ , may drift from its nominal value over the range of the operating ambient temperature, T<sub>A</sub>. For purposes of specification, the Quiescent Duty Cycle Output Drift Through Temperature Range,  $\Delta D_{(O)}$  (%), is defined as:

$$\Delta D_{(Q)} = D_{(Q)(\Delta TA)} - D_{(Q)(25^{\circ}C)}$$
 (3)

 $\Delta D_{(O)}$  should be calculated using the actual measured values of  $D_{(Q)(\Delta TA)}$  and  $D_{(Q)(25^{\circ}C)}$  rather than ideal programming target

**Sensitivity** The presence of a south polarity magnetic field, perpendicular to the branded face of the package, increases the output duty cycle from its quiescent value toward the maximum duty cycle limit. The amount of the output duty cycle increase is proportional to the magnitude of the magnetic field applied. Conversely, the application of a north polarity field decreases the output duty cycle from its quiescent value. This proportionality is specified as the magnetic sensitivity, Sens (%/G), of the device, and it is defined for bipolar devices as:

Sens = 
$$\frac{D_{\text{(BPOS)}} - D_{\text{(BNEG)}}}{\text{BPOS} - \text{BNEG}} , \tag{4}$$



Figure 1. Quiescent output duty cycle versus time



and for unipolar devices as:

Sens = 
$$\frac{D_{\text{(BPOS)}} - D_{\text{(Q)}}}{\text{BPOS}} , \qquad (5)$$

where BPOS and BNEG are two magnetic fields with opposite polarities.

**Guaranteed Sensitivity Range** The magnetic sensitivity, Sens, can be programmed around its nominal value within the sensitivity range limits: Sens(min) and Sens(max). Refer to the Guaranteed Quiescent Duty Cycle Output Range section for a conceptual explanation of how value distributions and ranges are related.

**Average Sensitivity Step Size** Refer to the Average Quiescent Duty Cycle Output Step Size section for a conceptual explanation.

**Sensitivity Programming Resolution** Refer to the Quiescent Duty Cycle Output Programming Resolution section for a conceptual explanation.

**Guaranteed Carrier Frequency Range** The PWM output signal carrier frequency,  $f_{PWM}$ , can be programmed around its nominal value in fast mode or slow mode.

**Average Carrier Frequency Step Size** Refer to the Average Quiescent Duty Cycle Output Step Size section for a conceptual explanation.

**Carrier Frequency Programming Resolution** Refer to the Quiescent Duty Cycle Output Programming Resolution section for a conceptual explanation.

**Sensitivity Temperature Coefficient** Device Sensitivity changes as temperature changes, with respect to its programmed sensitivity temperature coefficient,  $TC_{SENS}$ .  $TC_{SENS}$  is programmed at 125°C, and calculated relative to the nominal sensitivity programming temperature of 25°C.  $TC_{SENS}$  (%/°C) is defined as:

$$TC_{Sens} = \left(\frac{Sens_{T2} - Sens_{T1}}{Sens_{T1}} \times 100\%\right) \left(\frac{1}{T2 - TI}\right) , \qquad (6)$$

where T1 is the nominal Sens programming temperature of 25°C, and T2 is the  $TC_{SENS}$  programming temperature of 125°C. The expected value of Sens over the full ambient temperature range,

Sens<sub>EXPECTED(TA)</sub>, is defined as:

$$Sens_{EXPECTED(TA)} = \frac{Sens_{T1} \times [100\% + TC_{SENS} (T_A - TI)]}{100\%}$$
(7)

 $Sens_{EXPECTED(TA)}$  should be calculated using the actual measured values of  $Sens_{T1}$  and  $TC_{SENS}$  rather than ideal programming target values.

Sensitivity Drift Through Temperature Range Second order sensitivity temperature coefficient effects cause the magnetic sensitivity, Sens, to drift from its expected value over the operating ambient temperature range,  $T_A$ . For purposes of specification, the sensitivity drift through temperature range,  $\Delta Sens_{TC}$ , is defined as:

$$\Delta Sens_{TC} = \frac{Sens_{TA} - Sens_{EXPECTED(TA)}}{Sens_{EXPECTED(TA)}} \times 100\% . \tag{8}$$

Sensitivity Drift Due to Package Hysteresis Package stress and stress relaxation can cause the device sensitivity at  $T_A = 25^{\circ}\text{C}$  to change during and after temperature cycling.

For purposes of specification, the sensitivity drift due to package hysteresis,  $\Delta Sens_{PKG}$ , is defined as:

$$\Delta Sens_{PKG} = \frac{Sens_{(25^{\circ}C)2} - Sens_{(25^{\circ}C)1}}{Sens_{(25^{\circ}C)1}} \times 100\% , \qquad (9)$$

where  $Sens_{(25^{\circ}C)1}$  is the programmed value of sensitivity at  $T_A = 25^{\circ}C$ , and  $Sens_{(25^{\circ}C)2}$  is the value of sensitivity at  $T_A = 25^{\circ}C$ , after temperature cycling  $T_A$  up to  $125^{\circ}C$ , down to  $-40^{\circ}C$ , and back to up  $25^{\circ}C$ .

**Linearity Sensitivity Error** The A1354 is designed to provide a linear output in response to a ramping applied magnetic field. Consider two magnetic fields, B1 and B2. Ideally, the sensitivity of a device is the same for both fields, for a given supply voltage and temperature. Linearity error is present when there is a difference between the sensitivities measured at B1 and B2.



Linearity Error is calculated separately for the positive (Lin<sub>ERRPOS</sub>) and negative (Lin<sub>ERRNEG</sub>) applied magnetic fields. Linearity error (%) is measured and defined as:

$$\mathrm{Lin}_{\mathrm{ERRPOS}} = \left(1 - \frac{D_{(+\mathrm{B})} - D_{(\mathrm{Q})}}{2 \left(D_{(+\mathrm{B}/\!\!/_{\! 2})} - D_{(\mathrm{Q})}\right)}\right) \times 100\% \ ,$$

$$Lin_{ERRNEG} = \left(1 - \frac{D_{(-B)} - D_{(Q)}}{2(D_{(-B/2)} - D_{(Q)})}\right) \times 100\% , \qquad (10)$$

where:

Sens<sub>Bx</sub> = 
$$\frac{|D_{(Bx)} - D_{(Q)}|}{B_x}$$
 (11)

Then:

$$Lin_{ERR} = max(Lin_{ERRPOS}, Lin_{ERRNEG})$$
 (12)

Note that unipolar devices only have positive linearity error (LIN<sub>ERRPOS</sub>).

**Symmetry Sensitivity Error** The magnetic sensitivity of an A1354 device is constant for any two applied magnetic fields of equal magnitude and opposite polarities. Symmetry error,

Sym<sub>ERR</sub> (%), is measured and defined as:

$$Sym_{ERR} = \left(1 - \frac{D_{(+B)} - D_{(Q)}}{D_{(Q)} - D_{(-B)}}\right) \times 100\% , \qquad (13)$$

where  $Sens_{Bx}$  is as defined in equation 11, and BPOS and BNEG are positive and negative magnetic fields such that |BPOS| = |BNEG|. Note that the symmetry error specification is only valid for bipolar devices.

**Jitter** The duty cycle of the PWM output may vary slightly over time despite the presence of a constant applied magnetic field and a constant carrier frequency for the PWM signal. This phenomenon is known as jitter, Jitter<sub>PWM</sub> (%), and is defined as:

$$Jitter_{PWM} = \pm \frac{D_{Bmax} - D_{Bmin}}{2} , \qquad (14)$$

where  $D_{Bmax}$  and  $D_{Bmin}$  are the maximum and minimum duty cycles measured the over 1000 PWM clock periods with a constant applied magnetic field.

**Resolution** The ability to derive the value of the applied magnetic field from the device output is affected by jitter. The resolution of the magnetic field,  $RES_{PWM}$  (G), is defined as:

$$RES_{PWM} = \frac{Jitter_{PWM}}{Sens} . (15)$$



### **Typical Application Drawings**





### **Chopper Stabilization Technique**

When using Hall-effect technology, a limiting factor for switchpoint accuracy is the small signal voltage developed across the Hall element. This voltage is disproportionally small relative to the offset that can be produced at the output of the Hall element. This makes it difficult to process the signal while maintaining an accurate, reliable output over the specified operating temperature and voltage ranges. Chopper stabilization is a unique approach used to minimize Hall offset on the chip. The patented Allegro technique, namely Dynamic Quadrature Offset Cancellation, removes key sources of the output drift induced by thermal and mechanical stresses. This offset reduction technique is based on a signal modulation-demodulation process. The undesired offset signal is separated from the magnetic fieldinduced signal in the frequency domain, through modulation. The subsequent demodulation acts as a modulation process for the offset, causing the magnetic field-induced signal to recover

its original spectrum at base band, while the DC offset becomes a high frequency signal. The magnetic-sourced signal then can pass through a low-pass filter, while the modulated DC offset is suppressed. The chopper stabilization technique uses a 200 kHz high frequency clock. For demodulation process, a sample and hold technique is used, where the sampling is performed at twice the chopper frequency (400 kHz). This high-frequency operation allows a greater sampling rate, which results in higher accuracy and faster signal-processing capability. This approach desensitizes the chip to the effects of thermal and mechanical stresses, and produces devices that have extremely stable quiescent Hall output voltages and precise recoverability after temperature cycling. This technique is made possible through the use of a BiCMOS process, which allows the use of low-offset, low-noise amplifiers in combination with high-density logic integration and sample-and-hold circuits.





### **Programming Guidelines**

#### Overview

Programming is accomplished by sending a series of input voltage pulses serially through the VCC pin of the device. Unique combinations of different voltage amplitude pulses control the internal programming logic of the device to select a programmable parameter and set its value. There are three voltage levels that must be taken into account when programming using a *high* voltage pulse, VPH (consisting of a  $V_{P(LOW)} - V_{P(HIGH)} - V_{P(LOW)}$  sequence), and a *mid* voltage pulse, VPM (consisting of a  $V_{P(LOW)} - V_{P(MID)} - V_{P(LOW)}$  sequence). The *low* voltage level,  $V_{P(LOW)}$ , separates the VPH and VPM programming pulses.

The 1354 features Try mode, Blow mode, and Lock mode:

- In Try mode, the value of multiple programmable parameters may be set and measured simultaneously. The parameter values are stored temporarily, and reset after cycling the supply voltage.
- In Blow mode, the value of a single programmable parameter may be set, measured, and permanently set by blowing solidstate fuses internal to the device. Additional parameters may be blown sequentially. This mode is used for blowing the devicelevel fuse, which permanently blocks the further programming of all parameters.
- Lock mode prevents all future programming of the device. This is accomplished by blowing a special fuse using blow mode.

The programming sequence is designed to help prevent the device from being programmed accidentally; for example, as a result of noise on the supply line. Although any programmable variable power supply can be used to generate the pulse waveforms, Allegro highly recommends using the Allegro Sensor IC Evaluation Kit, available on the Allegro website On-line Store. The manual for that

kit is available for download free of charge, and provides additional information on programming these devices.

#### **Definition of Terms**

**Register** The section of the programming logic that controls the choice of programmable modes and parameters.

**Bitfield** The internal fuses unique to each register, represented as a binary number. Incrementing the bitfields of a particular register causes its programmable parameter to change, based on the internal programming logic.

**Key** A series of mid voltage pulses used to select a register, with a value expressed as the decimal equivalent of the binary value. The LSB of a register is denoted as key 1, or bitfield 0.

**Code** The number used to identify the combination of fuses activated in a bitfield, expressed as the decimal equivalent of the binary value. The LSB of a bitfield is denoted as code 1, or bit 0.

**Addressing** Incrementing the bit field code of a selected register by serially applying a pulse train through the VCC pin of the device. Each parameter can be measured during the addressing process, but the internal fuses must be blown before the programming code (and parameter value) becomes permanent.

**Fuse Blowing** Applying a high pulse of sufficient duration to permanently set an addressed bit by blowing a fuse internal to the device. Once a bit (fuse) has been blown, it cannot be reset.

**Blow Pulse** A high pulse of sufficient duration to blow the addressed fuse.

**Cycling the Supply** Powering-down, and then powering-up the supply voltage. Cycling the supply is used to clear the programming settings in Try mode.

### Programming Pulse Requirements, Protocol at T<sub>A</sub> = 25 °C

| Characteristic         | Symbol               | Notes                                                                                                                                                                                                                                                                                                                                                                       | Min. | Тур. | Max. | Unit |
|------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|
|                        | V <sub>P(LOW)</sub>  |                                                                                                                                                                                                                                                                                                                                                                             | 4.5  | 5    | 5.5  | V    |
| Programming Voltage    | V <sub>P(MID)</sub>  | Measured at the VCC pin.                                                                                                                                                                                                                                                                                                                                                    | 13   | 15   | 16   | V    |
| renage                 | V <sub>P(HIGH)</sub> |                                                                                                                                                                                                                                                                                                                                                                             | 26   | 27   | 28   | V    |
| Programming<br>Current | l <sub>P</sub>       | Minimum supply current required to ensure proper fuse blowing. In addition, a minimum capacitance, C <sub>BLOW</sub> = 0.1 µF, must be connected between the VCC and GND pins during programming to provide the current necessary for fuse blowing. The blowing capacitor should be removed and the load capacitance used for properly programming duty cycle measurements. |      | ı    | -    | mA   |
|                        | t <sub>LOW</sub>     | Duration of $V_{P(LOW)}$ for separating $V_{P(MID)}$ and $V_{P(HIGH)}$ pulses.                                                                                                                                                                                                                                                                                              | 40   | _    | _    | μs   |
| Pulse Width            | t <sub>ACTIVE</sub>  | Duration of $V_{P(MID)}$ and $V_{P(HIGH)}$ pulses for register selection or bitfield addressing.                                                                                                                                                                                                                                                                            | 40   | _    | _    | μs   |
|                        | t <sub>BLOW</sub>    | Duration of V <sub>P(HIGH)</sub> pulses for fuse blowing.                                                                                                                                                                                                                                                                                                                   | 40   | _    | _    | μs   |
| Pulse Rise Time        | t <sub>Pr</sub>      | Rise time required for transitions from $V_{P(LOW)}$ to either $V_{P(MID)}$ or $V_{P(HIGH)}$ .                                                                                                                                                                                                                                                                              |      | _    | 100  | μs   |
| Pulse Fall Time        | t <sub>Pf</sub>      | Fall time required for transitions from $V_{P(HIGH)}$ to either $V_{P(MID)}$ or $V_{P(LOW)}$ .                                                                                                                                                                                                                                                                              | 5    | _    | 100  | μs   |



#### **Mode and Parameter Register Selection**

Each mode and programmable parameter can be accessed through a specific register. To select a register, a sequence of voltage pulses consisting of a VPH pulse, a series of VPM pulses, and a VPH pulse (with no VCC supply interruptions) must be applied serially to the VCC pin. The number of VPM pulses is called the *key*, and uniquely identifies each register. The pulse train used for selection of the first register, key 1, is shown in figure 2.

The A1354 has two registers that select among the three programming modes:

Register 1:

Blow and Lock

Register 2:

Try

Also, it has four registers that select among the seven programmable parameters:

Register 1:

Sensitivity, Sens

Coarse quiescent duty cycle, D<sub>(O)</sub>

Register 2:

Fine quiescent duty cycle output,  $D_{(O)}$ 

Register 3:

Coarse pulse width modulated carrier frequency

Pulse width modulated carrier frequency, f<sub>PWM</sub>

Register 5:

Calibration Test Mode

Overall device Lock Bit, LOCK



Figure 2. Parameter selection pulse train. This shows the sequence for selecting the register corresponding to key 1, indicated by a single VPM pulse.

#### **Bitfield Addressing**

After a parameter register has been selected, a VPH pulse transitions the programming logic into the bitfield addressing state. Applying a series of VPM pulses to the VCC pin of the device, as shown in figure 3, increments the bitfield of the selected parameter.

When addressing the bitfield, the number of VPM pulses is represented by a decimal number called the *code*. Addressing activates the corresponding fuse locations in the given bitfield by incrementing the binary value of an internal DAC. The value of the bitfield (and code) increments by one with the falling edge of each VPM pulse, up to the maximum possible code for the register (see the Programming Logic table). As the code increases, the value of the programmable parameter changes. Measurements can be taken after each VPM pulse to determine if the desired result for the programmable parameter has been reached. Cycling the supply voltage resets all the locations in the bitfield that have unblown fuses to their initial states.

#### **Fuse Blowing**

After the required code is found for a given parameter, its value can be set permanently by blowing individual fuses in the appropriate register bitfield. Blowing is accomplished by applying a VPH pulse, called a *blow pulse*, of sufficient duration at the  $V_{P(HIGH)}$  level to permanently set an addressed bit by blowing a fuse internal to the device. Due to power requirements, the fuse for each bit in the bitfield must be blown individually. To accomplish this, the code representing the desired parameter value must be translated to a binary number. For example, as shown in figure 4, decimal code 5 is equivalent to the binary number 101. Therefore bit 2 (code 4) must be addressed and blown, the device power supply cycled, and then bit 0 (code 1) addressed and blown. An appropriate sequence for blowing code 5 is shown



Figure 3. Bitfield addressing pulse train. Addressing the bitfield by incrementing the code causes the programmable parameter value to change. The number of bits available for a given programming code, n, varies among parameters; for example, the bitfield for  $D_{(Q)}$  has 6 bits available, which allows 63 separate codes to be used.



in figure 5. The order of blowing bits, however, is not important. Blowing bit 0 first, and then bit 2 is acceptable.

Note: After blowing, the programming is not reversible, even after cycling the supply power. Although a register bitfield fuse cannot be reset after it is blown, additional bits within the same register can be blown at any time until the device is locked. For example, if bit 1 (binary 10) has been blown, it is still possible to blow bit 0. The end result would be binary 11 (decimal code 3).

#### **Locking the Device**

After the desired code for each parameter is programmed, the device can be locked to prevent further programming of any parameters.



Figure 4. Example of code 5 broken into its binary components, which are code 4 and code 1.

#### **Additional Guidelines**

The additional guidelines in this section should be followed to ensure the proper behavior of these devices:

- A 0.1  $\mu$ F blowing capacitor,  $C_{BLOW}$ , must be mounted between the VCC pin and the GND pin during programming, to ensure enough current is available to blow fuses.
- The C<sub>BLOW</sub> blowing capacitor must be replaced in the final application with a 10 nF bypass capacitor for proper operation.
- The application capacitance, C<sub>BYPASS</sub>, should be used when measuring the output duty cycle during programming. The blowing capacitor, C<sub>BLOW</sub>, should be removed during measurement and should only be applied when blowing fuses.
- The power supply used for programming must be capable of delivering at least 26 V and 300 mA.
- Be careful to observe the t<sub>LOW</sub> delay time before powering down the device after blowing each bit.
- The following programming sequence is recommended:
  - 1. Coarse f<sub>PWM</sub>
- 2. Fine f<sub>PWM</sub>
- 3. Coarse D<sub>(O)</sub>
- 4. Sens
- 5. Fine D<sub>(O)</sub>
- 6. LOCK (only after all other parameters have been programmed and validated, because this prevents any further programming of the device)



Figure 5. Example of Blow mode programming pulses applied to the VCC pin. In this example, Fine  $D_{(Q)}$  (Parameter Key 2) is addressed to code 4 (corresponding to bit 2) and its value is permanently blown.



#### **Programming Modes**

**Try Mode** This mode allows multiple programmable parameters to be tested simultaneously without permanently setting any values. In this mode, each VPH pulse will indefinitely loop the programming logic through the Mode Select, Register Select, and Bitfield Select states, as long as there are no interruptions in the VCC supply.

To enter Try mode, after powering the VCC supply and entering the Initial state, send one VPH pulse to enter Mode Select state, and then two VPM pulses (Mode Selection key 2).

Select the required parameter register and address its bitfield. When addressing the bitfield, each VPM pulse increments the value of the parameter register, up to the maximum possible code (see the Programming Logic table). The addressed parameter value is stored in the device, even after the programming drive voltage is removed from the VCC pin, allowing its value to be measured. To test an additional programmable parameter in conjunction with the original, enter an additional VPH pulse on the VCC pin to re-enter the parameter selection field. Select a different parameter register, and address its bitfield without any supply interruptions. Both parameter values are stored and can be measured after removing the programming drive voltage. Multiple programming combinations can be tested to achieve optimal application accuracy. See figure 6 for an example of the Try mode pulse train.

When testing the device in Try mode, it is recommended to select parameter register 4, the null register, before tests. This recommendation is because the programming voltage levels overlap the  $V_{CC}$  operating levels, so varying  $V_{CC}$  during tests in Try mode may unintentionally result in device programming.

Registers can be addressed and re-addressed an indefinite number of times, and in any order. After the required code is found for each register, cycle the supply voltage and blow the bitfield fuse using Blow mode. Note that for accurate time measurements, the blow capacitor,  $C_{\rm BLOW}$ , should be removed during output voltage measurement.

**Blow Mode** After the required value of the programmable parameter is found using Try mode, the corresponding code should be blown to make the value permanent. To do this, select the required parameter register, and address and blow each required bit separately (as described in the Fuse Blowing section). The supply must be cycled between blowing each bit of a given code. After a bit is blown, cycling the supply will not reset its value.

Single parameters can still be addressed in Blow mode before fuse blowing (simultaneous addressing of multiple parameters, as in Try mode, is not possible). After powering the VCC supply, select the required parameter register and address its bitfield. When addressing the bitfield, each VPM pulse increments the value of the parameter register, up to the maximum possible code (see Programming Logic table). The addressed parameter value is stored in the device, even after the programming drive voltage is removed from the VCC pin, allowing its value to be measured. Note that for accurate time measurements, the blow capacitor, C<sub>BLOW</sub>, should be removed during output voltage measurement. It is not possible to decrement the value of the register without resetting the parameter bitfield. To reset the bit field, and thus the value of the programmable parameter, cycle the supply voltage.

It is possible to switch between Try and Blow modes where single programmable parameters can be blown in Blow mode while other parameters can still be tested in Try mode.

**Lock Mode** To lock the device, address the LOCK bit, and apply a blow pulse with  $C_{BLOW}$  in place. After locking the device, no future programming of any parameter is possible.



Figure 6. Example of Try mode programming pulses applied to the VCC pin. In this example, Sensitivity (Parameter Key 1) is addressed to code 3, and  $D_{(Q)}$  (Parameter Key 2) is addressed to code 2. The values set in the Sensitivity and  $D_{(Q)}$  registers are stored in the device until the supply is cycled. Permanent fuse blowing cannot be accomplished in Try mode.



### **Programming State Machine**



**Initial State** A known state to which the programming logic is reset after system power-up. All the bitfield locations that have intact fuses are reset to logic 0. VPM pulses have no effect. To enter the Mode Select state, apply a single VPH pulse to the VCC pin.

**Mode Select State** This state allows the selection of the Mode register. To select a Mode register, increment through the keys by applying VPM pulses to the VCC pin. Register keys select among the following programing modes:

- 1 pulse Blow and Lock
- 2 pulses Try

To enter the Parameter Select state, apply 2 VPH pulses to the VCC pin.

**Parameter Select State** This state allows the selection of the Parameter register containing the bitfields to be programmed. Applying VPM pulses to the VCC pin increments through the Parameter registers:

- 1 pulse Sensitivity / Coarse D<sub>(O)</sub>
- 2 pulses Fine D<sub>(O)</sub>
- 3 pulses PWM Frequency / Coarse PWM Frequency
- 4 pulses Null
- 5 pulses Calibration Test Mode / Device LOCK

To enter the Bitfield Select state, apply 1 VPH pulse to the VCC pin.

**Bitfield Select State** This state allows the selection of the individual bitfields to be programmed in the selected Parameter register (see the Programming Logic table). Applying VPM pulses to the VCC pin increments the bitfield.

In Try mode, to re-enter the Parameter Selection state, apply 1 VPH pulse on the VCC pin. The previously addressed parameter retains its value as long as  $V_{\rm CC}$  is not cycled.

In Blow or Lock mode, to leave the Bitfield Select state requires either cycling  $V_{CC}$  or blowing the fuses for the selected code. Note: Merely addressing the bitfield does not permanently set the value of the selected programming parameter; fuses must be blown to do so.

**Fuse Blowing State** To blow an addressed bitfield, apply a VPH pulse to the VCC pin. Power to the device should then be cycled before additional programming is attempted. Note: Each bit representing a decimal code must be blown individually (see the Fuse Blowing section).



1.508.853.5000: www.allegromicro.com

## A1354

# High Precision 2-Wire Linear Hall Effect Sensor IC with Pulse Width Modulated Output

### **Programming Logic**

|                                       | Bitfield                     | l Address                    |                                                                                                                                    |
|---------------------------------------|------------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Register Selection Key                | Binary Format<br>(MSB → LSB) | Decimal Equivalent<br>Code   | Description                                                                                                                        |
|                                       |                              | Mode Register Selection      |                                                                                                                                    |
| Blow / Lock                           |                              |                              |                                                                                                                                    |
| 1                                     | 01                           | 1                            | Blow or Lock                                                                                                                       |
| Try                                   |                              |                              |                                                                                                                                    |
| 2                                     | 10                           | 2                            | Try                                                                                                                                |
|                                       |                              | Parameter Register Selection | r                                                                                                                                  |
| Sensitivity / Coarse D <sub>(Q)</sub> |                              |                              |                                                                                                                                    |
|                                       | 00000000                     | 0                            | Initial value; $D_{(Q)} = D_{(Q)PRE}$ , Sens = Sens <sub>PRE</sub>                                                                 |
|                                       | 011111111                    | 255                          | Maximum gain value in range                                                                                                        |
| 1 100000000                           |                              | 256                          | Enable Coarse $D_{(Q)}$ bit; switch from bidirectional programming to unidirectional programming, $D_{(Q)} = D_{(Q)UNlinit}$       |
| Fine D <sub>(Q)</sub> (B = 0 gauss)   |                              |                              |                                                                                                                                    |
|                                       | 00000000                     | 0                            | Initial value                                                                                                                      |
|                                       | 011111111                    | 255                          | Maximum D <sub>(Q)</sub> in range                                                                                                  |
| 2                                     | 10000000                     | 256                          | Switch from programming increasing $D_{(Q)}$ to programming decreasing $D_{(Q)}$                                                   |
|                                       | 111111111                    | 511                          | Minimum D <sub>(Q)</sub> in range                                                                                                  |
| PWM Frequency /Coarse PWM             | Frequency                    |                              |                                                                                                                                    |
|                                       | 00000                        | 0                            | Initial value; f <sub>PWM</sub> = f <sub>PWMPRE</sub>                                                                              |
|                                       | 01111                        | 15                           | Minimum f <sub>PWM</sub> in f <sub>PWM(fast)</sub> range                                                                           |
| 3                                     | 10000                        | 16                           | Enable Coarse $f_{PWM}$ bit; switch from $f_{PWM(fast)}$ programming to $f_{PWM(slow)}$ programming, $f_{PWM} = f_{PWM(slow)init}$ |
|                                       | 11111                        | 63                           | Minimum f <sub>PWM</sub> in f <sub>PWM(slow)</sub> range                                                                           |
| Null                                  |                              |                              |                                                                                                                                    |
| 4                                     | _                            | _                            | Recommended to be selected before and during test measurements performed in Try mode                                               |
| Calibration Test Mode / Lock All      |                              |                              |                                                                                                                                    |
|                                       | 000000000                    | 0                            | Initial value                                                                                                                      |
| 5                                     | 0000010000                   | 16                           | Enable 50% duty cycle Calibration Test Mode bit                                                                                    |
|                                       | 100000000                    | 512                          | LOCK bit; lock all device registers                                                                                                |



### Programming Example

This example demonstrates the programming of the device. The recommended sequence for programming is shown in the Additional Guidelines section, but for this example, we start at setting the register for Fine Duty Cycle and then go on to final locking of the device.

To find the correct duty cycle value:

- 1. Power-on the system. This resets all unprogrammed bits in all registers to 0. The device enters the Initial state.
- 2. Send one VPH pulse to enter the Mode Select state.
- 3. Send two VPM pulses to select the Try mode.
- 4. Send two VPH pulses to enter the Register Select state.
- 5. Send two VPM pulses to select the Fine  $D_{(O)}$  register.
- 6. Send one VPH pulse to enter the Bitfield Select state. The Fine  $D_{(O)}$  register is reset to 000000000.
- 7. For this example, send one hundred and twenty-eight VPM pulses to set bitfield 7 (010000000, decimal 128).

Now we can measure the device output to see if this is the required value. Assume for this example that the value is slightly too low. So we proceed to change it, as follows:

8. Send one VPM pulse to increment the Fine  $D_{(O)}$  code by 1. This yields a total register value of 129 by setting bitfield 0: 010000001.

Assume we measure the device and find this is the correct duty cycle value we require. We are finished trying values for this parameter, and now want to set the value permanently by blowing the corresponding bitfield fuses. Blowing fuses is done one bitfield (one fuse) at a time. We are setting two bitfields, so we have to blow them in two stages:

- 9. Reset the device by powering it off and on. The device returns to the Initial state.
- 10. Send one VPH pulse to enter the Mode Select state.
- 11. Send one VPM pulse to select the Blow mode.

- 12. Send two VPH pulses to enter the Register Select state.
- 13. Send two VPM pulses to select the Fine  $D_{(O)}$  register.
- 14. Send one VPH pulse to enter the Bitfield Select state. The Fine  $D_{(O)}$  register is reset to 000000000.
- 15. Send one hundred and twenty-eight VPM pulses to set bitfield 7. (The bitfields can be set in any order.)
- 16. Send one VPH pulse to exit the Bitfield Select state. The bitfield fuse is blown.

One of the two bitfields is programmed. Now we program the other bitfield:

- 17. Repeat steps 9 to 14 to select the Fine  $D_{(Q)}$  register again and enter the Bitfield Select state. This time, however, the register resets to 010000000, because bit 7 has been permanently set.
- 18. Send one VPM pulse to set bit 0.
- 19. Send one VPH pulse to exit the Bitfield Select state. The bitfield fuse is blown.

Program the remaining parameter by repeating the above steps. After programming all parameters, we can lock the device:

- 20. Reset the device by powering it off and on. The device returns to the Initial state.
- 21. Send one VPH pulse to enter the Mode Select state.
- 22. Send one VPM pulse to select the Lock mode.
- 23. Send two VPH pulses to enter the Register Select state.
- 24. Send five VPM pulses to select the LOCK register. The register resets either to 0000000000, or to 0000010000 if Calibration Test mode has been previously enabled.
- 25. Send one VPH pulse to enter the Bitfield Select state.
- 26. Send five hundred and twelve VPM pulses to set the LOCK bit, bitfield 9.
- 27. Send one VPH pulse to exit the Bitfield Select state. The bitfield fuse is blown. Programming of the device is complete. Optionally, test the results, or power-off the device.



19

#### **Calibration Test Mode**

The Calibration Test mode is provided so that the user can compensate for differences in the ground potential between the A1354 and any interface circuitry used to measure the pulse width of the A1354 output. This test mode is optional and must be enabled by blowing its programming bit. After the test mode bit has been blown, the device enters Calibration Test mode every time the device is powered-up.

In customer applications the PWM interface circuitry (body control module: BCM in figure 7) and the A1354 may be powered via different power and ground circuits. As a result, the ground reference for the A1354 may differ from the ground reference of

the BCM. In some customer applications this ground difference can be as large as  $\pm$  0.5 V.

Differences in the ground reference for the A1354 and the BCM can result in variations in the threshold voltage used to measure the duty cycle of the A1354. If the PWM conversion threshold voltage varies, then the duty cycle will vary because there is a finite rise time,  $t_{\rm r}$ , and fall time,  $t_{\rm f}$ , in the PWM waveform. This problem is shown in figure 8.

The Calibration Test mode allows end users to compensate for any threshold errors that result from a difference in system ground potentials. While the A1354 is in the test period, the



Figure 7: In many applications the A1354 may be powered using a different ground reference than the BCM. This may cause the ground reference for the A1354 (GND 1) to differ from the ground reference of the BCM (GND 2) by as much as to  $\pm 0.5$  V.



Figure 8. When the threshold voltage is correctly centered between  $V_{OH}$  and  $V_{OL}$ , the duty cycle accurately coincides with the applied magnetic field. If the threshold voltage is raised, the output duty cycle appears shorter than expected. Conversely, if the threshold voltage is lowered, the output duty cycle is longer than expected.



device output waveform is a fixed 50% duty cycle (the programmed quiescent duty cycle value) regardless of the applied external magnetic field. After powering-up, the A1354 outputs its quiescent duty cycle waveform for 800 ms, regardless of the applied magnetic field (see figure 9). This allows the BCM to compare the measured quiescent duty cycle with an ideal 50% duty cycle.

After the initial 800 ms has elapsed, the duty cycle corresponds to an applied magnetic field as expected. The 800 ms calibration test time corresponds to a PWM frequency of 125 Hz. If the PWM frequency is programmed away from its target of 125 Hz, the duration of the calibration test time will scale inversely with the change in PWM frequency.



Figure 9. Calibration Test Mode. After powering-on, the A1354 outputs a 50% duty cycle for the first 800 ms, regardless of the applied magnetic field (Calibration Test mode in effect). After the initial 800 ms has elapsed, the output responds to a magnetic field as expected. The example in this figure assumes that a large +B (south polarity) field is applied to the device after the initial 800 ms.



### Package KT, 4-Pin SIP



Copyright ©2009, Allegro MicroSystems, Inc.

The products described herein are manufactured under one or more of the following U.S. patents: 5,045,920; 5,264,783; 5,442,283; 5,389,889; 5,581,179; 5,517,112; 5,619,137; 5,621,319; 5,650,719; 5,686,894; 5,694,038; 5,729,130; 5,917,320; and other patents pending.

Allegro MicroSystems, Inc. reserves the right to make, from time to time, such departures from the detail specifications as may be required to permit improvements in the performance, reliability, or manufacturability of its products. Before placing an order, the user is cautioned to verify that the information being relied upon is current.

Allegro's products are not to be used in life support devices or systems, if a failure of an Allegro product can reasonably be expected to cause the failure of that life support device or system, or to affect the safety or effectiveness of that device or system.

The information included herein is believed to be accurate and reliable. However, Allegro MicroSystems, Inc. assumes no responsibility for its use; nor for any infringement of patents or other rights of third parties which may result from its use.

For the latest version of this document, visit our website:

www.allegromicro.com

