

#### **General Description**

The MAXQ3183 is a dedicated electricity measurement front-end that collects and calculates polyphase voltage, current, power, energy, and many other metering and power-quality parameters of a polyphase load. The computed results can be retrieved by an external master through the on-chip serial peripheral interface (SPI™) bus. This bus is also used by the external master to configure the operation of the MAXQ3183 and monitor the status of operations.

The MAXQ3183 performs voltage and current measurements using an integrated ADC that can measure up to seven external differential signal pairs. An eighth differential signal pair is used to measure the die temperature. An internal amplifier automatically adjusts the current channel gain to compensate for low-current channel-signal levels.

#### **Applications**

3-Phase Multifunction Electricity Meters

#### **Features**

- ♦ Compatible with 3-Phase/3-Wire, 3-Phase/4-Wire
- ◆ Active Power and Energy of Each Phase and Combined 3-Phase (kWh), Positive and Negative
- ♦ Reactive Power and Energy of Each Phase and Combined 3-Phase, Positive and Negative
- **♦** Apparent Power and Energy of Each Phase and **Combined 3-Phase**
- **♦ Neutral Line Current Measurement**
- ♦ Vector Sum of 3-Phase Currents and Neutral Current
- **♦ Line Frequency (Hz)**
- **♦ Power Factors**
- ♦ Voltage Phasor Angles
- ♦ Voltage and Current Phase Sequence Indications
- **♦ Phase Voltage Absence Detection**
- ♦ Voltage and Current Harmonic Measurement

- ♦ Phase Current THDN
- ♦ Fundamental and Total Power and Energy
- ♦ AC/DC Mode Current and Voltage Measurement
- **♦ Two Pulse Outputs: Configurable for Active,** Reactive, and Apparent Powers
- Programmable Meter Constants and Pulse Widths
- ♦ Programmable No-Load Current Threshold
- **♦** Programmable Thresholds for Undervoltage and **Overvoltage Detection**
- **♦** Programmable Threshold for Overcurrent Detection
- ♦ Programmable Vector Sum Threshold for Bypass Detection
- ♦ Amp-Hours in Absence of Voltage Signals
- ♦ On-Chip Digital Temperature Sensor
- ♦ Precision Internal Voltage Reference 2.048V (30ppm/°C typical), Also Supports An External Voltage Reference
- **♦** Supports Software Meter Calibration
- ♦ Up to 3-Point Multipoint Calibration to Compensate for Transducer Nonlinearity
- ♦ Power-Fail Detection
- ♦ Bidirectional Reset Input/Output
- ♦ SPI-Compatible Serial Interface with Interrupt Request (IRQ) Output
- ♦ Single 3.3V Supply, Low Power (35mW typical)

#### **Ordering Information**

| PART |               | TEMP RANGE     | PIN-PACKAGE |  |  |
|------|---------------|----------------|-------------|--|--|
|      | MAXQ3183-RAN+ | -40°C to +85°C | 28 TSSOP    |  |  |

<sup>+</sup>Denotes a lead(Pb)-free/RoHS-compliant package.

Pin Configuration and Typical Application Circuit appear at end of data sheet.

MAXQ is a registered trademark of Maxim Integrated Products, Inc. SPI is a trademark of Motorola, Inc.

Note: Some revisions of this device may incorporate deviations from published specifications known as errata. Multiple revisions of any device may be simultaneously available through various sales channels. For information about device errata, go to: www.maxim-ic.com/errata.

df.dzsc.com

Maxim Integrated Products 1

| TABLE OF CONTENTS                           |    |
|---------------------------------------------|----|
| Absolute Maximum Ratings                    | 10 |
| Metering Specifications                     | 10 |
| Electrical Characteristics                  | 10 |
| SPI Slave Mode Timing                       | 12 |
| Block Diagram                               | 13 |
| Pin Description                             | 14 |
| Detailed Description                        | 15 |
| Analog Front-End                            | 15 |
| Digital Signal Processor                    | 15 |
| Precision Pulse Generators                  | 15 |
| SPI Peripheral                              | 15 |
| Operating Modes                             | 15 |
| Run Mode                                    | 15 |
| Stop Mode                                   | 15 |
| Reset Sources                               | 16 |
| External Reset                              | 16 |
| Power-On Reset                              | 17 |
| Watchdog Reset                              | 17 |
| Software Reset                              |    |
| Power-Supply Monitoring                     | 18 |
| Clock Sources                               |    |
| External High-Frequency Crystal             | 18 |
| External High-Frequency Clock               | 19 |
| Internal RC Oscillator                      | 19 |
| Master Communications                       |    |
| SPI Communications Rate and Format          | 19 |
| SPI Communications Protocol                 |    |
| Host Software Design                        |    |
| Register Set                                |    |
| RAM-Based Registers                         | 28 |
| General Operating Registers                 |    |
| Global Status Register (STATUS) (0x000)     |    |
| Operating Mode Register 0 (OPMODE0) (0x001) |    |
| Operating Mode Register 1 (OPMODE1) (0x002) |    |
| Operating Mode Register 2 (OPMODE2) (0x003) | 30 |

| TABLE OF CONTENTS (continued)                                                                  |    |
|------------------------------------------------------------------------------------------------|----|
| Global Interrupt Registers                                                                     | 32 |
| Interrupt Request Flag Register (IRQ_FLAG) (0x004)                                             | 32 |
| Interrupt Mask Register (IRQ_MASK) (0x006)                                                     | 33 |
| Meter Pulse Configuration                                                                      | 34 |
| Pulse Configuration—CFP Output (PLSCFG1) (0x01E)                                               | 34 |
| Pulse Configuration—CFQ Output (PLSCFG2) (0x01F)                                               | 35 |
| CFP Pulse Width (PLS1_WD) (0x020)                                                              | 35 |
| CFP Pulse Threshold (THR1) (0x022)                                                             | 36 |
| CFQ Pulse Width (PLS2_WD) (0x026)                                                              | 36 |
| CFQ Pulse Threshold (THR2) (0x028)                                                             |    |
| Calibration Registers                                                                          | 37 |
| Current Gain, Phase X = A/B/C/N (X.I_GAIN) (A: 0x130, B: 0x21C, C: 0x308, N: 0x12E)            |    |
| Voltage Gain, Phase X = A/B/C (X.V_GAIN) (A: 0x132, B: 0x21E, C: 0x30A)                        |    |
| Energy Gain, Phase X = A/B/C (X.E_GAIN) (A: 0x134, B: 0x220, C: 0x30C)                         |    |
| Phase-Angle Compensation, High Range, Phase X = A/B/C (X.PA0) (A: 0x13E, B: 0x22A, C: 0x316)   |    |
| Phase-Angle Compensation, Medium Range, Phase X = A/B/C (X.PA1) (A: 0x140, B: 0x22C, C: 0x318) |    |
| Phase-Angle Compensation, Low Range, Phase X = A/B/C (X.PA2) (A: 0x142, B: 0x22E, C: 0x31A)    | 39 |
| Limit Registers                                                                                |    |
| Overcurrent Level (OCLVL) (0x044)                                                              | 39 |
| Overvoltage Level (OVLVL) (0x046)                                                              | 40 |
| Undervoltage Level (UVLVL) (0x048)                                                             | 40 |
| No-Load Level (NOLOAD) (0x04A)                                                                 | 40 |
| Current Vector Sum Threshold (ISUMLVL) (0x054)                                                 | 41 |
| Phase Status Registers                                                                         | 41 |
| Interrupt Flags, Phase X = A/B/C (X.FLAGS) (A: 0x144, B: 0x230, C: 0x31C)                      | 41 |
| Interrupt Mask, Phase X = A/B/C (X.MASK) (A: 0x145, B: 0x231, C: 0x31D)                        | 42 |
| Energy Overflow Flags, Phase X = A/B/C (X.EOVER) (A: 0x146, B: 0x232, C: 0x31E)                | 42 |
| Measurements                                                                                   | 43 |
| Line Frequency (LINEFR) (0x062)                                                                | 43 |
| Power Factor, Phase X = A/B/C (X.PF) (A: 0x1C6, B: 0x2B2, C: 0x39E)                            | 43 |
| RMS Voltage, Phase X = A/B/C (X.VRMS) (A: 0x1C8, B: 0x2B4, C: 0x3A0)                           | 43 |
| RMS Current, Phase X = A/B/C (X.IRMS) (A: 0x1CC, B: 0x2B8, C: 0x3A4)                           | 44 |
| Energy, Real Positive, Phase X = A/B/C (X.EAPOS) (A: 0x1E8, B: 0x2D4, C: 0x3C0)                | 44 |
| Energy, Real Negative, Phase X = A/B/C (X.EANEG) (A: 0x1EC, B: 0x2D8, C: 0x3C4)                | 45 |
| Energy, Reactive Positive, Phase X = A/B/C (X.ERPOS) (A: 0x1F0, B: 0x2DC, C: 0x3C8)            | 45 |
| Energy, Reactive Negative, Phase X = A/B/C (X.ERNEG) (A: 0x1F4, B: 0x2E0, C: 0x3CC)            | 46 |
| Energy, Apparent, Phase X = A/B/C (X.ES) (A: 0x1F8, B: 0x2E4, C: 0x3D0)                        | 46 |
|                                                                                                |    |

| TABLE OF CONTENTS (continued)                                                       |    |
|-------------------------------------------------------------------------------------|----|
| Virtual Register Conversion Coefficients                                            |    |
| Voltage Units Conversion Coefficient (VOLT_CC) (0x014)                              | 47 |
| Current Units Conversion Coefficient (AMP_CC) (0x016)                               | 47 |
| Power Units Conversion Coefficient (PWR_CC) (0x018)                                 | 48 |
| Energy Units Conversion Coefficient (ENR_CC) (0x01A)                                | 49 |
| Temperature Conversion Coefficient (TEMP_CC) (0x060)                                | 50 |
| Virtual Registers                                                                   | 51 |
| Power                                                                               | 51 |
| Real Power, Phase X = A/B/C/T (PWRP.X) (A: 0x801, B: 0x802, C: 0x804, T: 0x807)     | 51 |
| Reactive Power, Phase X = A/B/C/T (PWRQ.X) (A: 0x811, B: 0x812, C: 0x814, T: 0x817) | 51 |
| Apparent Power, Phase X = A/B/C/T (PWRS.X) (A: 0x821, B: 0x822, C: 0x824, T: 0x827) | 52 |
| Voltage and Current                                                                 | 52 |
| RMS Volts, Phase X = A/B/C (V.X) (A: 0x831, B: 0x832, C: 0x834)                     | 52 |
| RMS Amps, Phase X = A/B/C/N (I.X) (A: 0x841, B: 0x842, C: 0x844, N: 0x840)          | 52 |
| Power Factor                                                                        | 53 |
| Power Factor (PF.T) (0x867)                                                         | 53 |
| Energy                                                                              | 53 |
| Real Energy, Phase A/B/C/T (ENRP.X) (A: 0x8C1, B: 0x8C2, C: 0x8C4, T: 0x8C7)        | 53 |
| Reactive Energy, Phase A/B/C/T (ENRQ.X) (A: 0x8D1, B: 0x8D2, C: 0x8D4, T: 0x8D7)    | 53 |
| Apparent Energy, Phase A/B/C/T (ENRS.X) (A: 0x871, B: 0x872, C: 0x874, T: 0x877)    | 53 |
| Theory of Operation                                                                 | 54 |
| Analog Front-End Operation                                                          | 54 |
| Digital Signal Processing (DSP) Terminology                                         | 54 |
| Digital Processing                                                                  | 54 |
| Per Sample Operations                                                               | 55 |
| Per DSP Cycle Operations                                                            | 55 |
| Energy Accumulation                                                                 | 57 |
| No-Zero-Crossing Detection                                                          | 58 |
| Phase Sequence Status                                                               | 58 |
| RMS Voltage, RMS Current, and Energy Calculation                                    | 58 |
| Power Calculation (Active, Reactive, Apparent)                                      | 58 |
| Energy Accumulation Start Delay                                                     | 59 |
| No-Load Feature                                                                     | 59 |
| On Demand Calculations                                                              | 59 |
| RMS Volts, RMS Amps                                                                 | 59 |
| Power                                                                               | 60 |
| Power Factor                                                                        | 60 |

| TABLE OF CONTENTS (continued)                       |    |
|-----------------------------------------------------|----|
| Line Frequency                                      |    |
| Phasor Angles                                       |    |
| Energy                                              |    |
| Meter Pulse                                         | 61 |
| Generating Pulses                                   | 61 |
| Meter Constant                                      | 61 |
| Interrupts                                          | 61 |
| Overvoltage and Overcurrent Detection               |    |
| Meter Units to Real Units Conversion                |    |
| Units Conversion Examples                           | 62 |
| Calibration Procedure                               | 64 |
| Calibration Overview                                | 64 |
| Calibrating Voltage                                 | 65 |
| Calibrating Current                                 |    |
| Calibrating Phase Offset                            |    |
| Interfacing the MAXQ3183 to External Hardware       |    |
| Connections to the Power Source                     |    |
| Sensor Selection                                    |    |
| Voltage Sensors                                     |    |
| Voltage-Divider                                     |    |
| Voltage Transformer                                 |    |
| Current Sensors                                     |    |
| Current Shunt                                       |    |
| Current Transformer                                 |    |
| Advanced Operation                                  |    |
| Modifying the ADC Operation                         |    |
| Fine-Tuning the DSP Controls                        |    |
| Fine-Tuning the Line Frequency Measurement          | 69 |
| Fundamental Mode Registers                          |    |
| Harmonic Measurement                                | 69 |
| Current Total Harmonic Distortion Plus Noise (THDN) |    |
| Current Vector Sum                                  |    |
| Low-Power Measurement Mode (LOWPM)                  |    |
| Temperature                                         |    |
| Advanced Calibrations                               |    |
| Calibrating Current Offset                          |    |
| Calibrating Linearity                               |    |
|                                                     |    |

| TABLE OF CONTENTS (continued)                                                           |    |
|-----------------------------------------------------------------------------------------|----|
| Calibrating Power/Energy Gain                                                           |    |
| Multipoint Phase Offset Calibration                                                     | 72 |
| dvanced Register Configurations                                                         | 73 |
| Analog Scan Configuration Registers                                                     | 73 |
| Time Slot Assignment—Current Channel X = A/B/C (SCAN_IX) (A: 0x008, B: 0x00C, C: 0x00A) | 73 |
| Time Slot Assignment—Voltage Channel X = A/B/C (SCAN_VX) (A: 0x009, B: 0x00D, C: 0x00B) | 74 |
| Time Slot Assignment—Neutral Current Channel (SCAN_IN) (0x00E)                          | 75 |
| Time Slot Assignment—Temperature Channel (SCAN_TE) (0x00F)                              | 76 |
| Neutral Current and Harmonics                                                           | 77 |
| Auxiliary Channel Configuration (AUX_CFG) (0x010)                                       | 77 |
| DSP System Configuration                                                                | 78 |
| System Clock Frequency (SYS_KHZ) (0x012)                                                | 78 |
| Cycle Count (CYCNT) (0x01C)                                                             | 78 |
| Number of Scan Frames per DSP Cycle (NS) (0x040)                                        | 79 |
| Filter Coefficients                                                                     | 79 |
| Line Cycle Noise Rejection Filter (REJ_NS) (0x02C)                                      | 79 |
| Line Cycle Averaging Filter (AVG_NS) (0x02E)                                            |    |
| Meter Measurement Averaging Filter (AVG_C) (0x030)                                      | 80 |
| Meter Measurement Highpass Filter (HPF_C) (0x032)                                       | 81 |
| Fundamental Filter Feed-Forward Coefficient (B0FUND) (0x034)                            |    |
| Fundamental Filter Feedback Coefficient (A1FUND) (0x036)                                | 82 |
| Harmonic Filter Feed-Forward Coefficient (B0HARM) (0x03A)                               |    |
| Harmonic Filter Feedback Coefficient (A1HARM) (0x03C)                                   |    |
| Zero-Cross Lowpass Filter (ZC_LPF) (0x05A)                                              |    |
| Hardware Mirror Registers                                                               |    |
| ADC Configuration (R_ACFG) (0x04C)                                                      |    |
| ADC Conversion Rate (R_ADCRATE) (0x04E)                                                 |    |
| ADC Settling Time (R_ADCACQ) (0x050)                                                    |    |
| SPI Configuration (R_SPICF) (0x052)                                                     |    |
| Timeouts                                                                                |    |
| Communications Timeout (COM_TIMO) (0x056)                                               |    |
| Energy Accumulation Timeout (ACC_TIMO) (0x058)                                          |    |
| Phase-Angle Compensation                                                                |    |
| Phase Offset Current Threshold 1 (I1THR) (0x05C)                                        |    |
| Phase Offset Current Threshold 2 (I2THR) (0x05E)                                        | 87 |

| TABLE OF CONTENTS (continued)                                                                     |      |
|---------------------------------------------------------------------------------------------------|------|
| Miscellaneous Gain                                                                                | 87   |
| Neutral Current Gain (N.I_GAIN) (0x12E)                                                           | 87   |
| Gain, Fundamental Energy, Phase X = A/B/C (X.EF_GAIN) (A: 0x136, B: 0x222, C: 0x30E)              | 88   |
| Linearity Compensation                                                                            | 88   |
| Linearity Offset, High Range, Phase X = A/B/C (X.OFFS_HI) (A: 0x138, B: 0x224, C: 0x310)          | 88   |
| Linearity Gain Coefficient, Low Range, Phase X = A/B/C (X.GAIN_LO) (A: 0x13A, B: 0x226, C: 0x312) | 88   |
| Linearity Offset, Low Range, Phase X = A/B/C (X.OFFS_LO) (A: 0x13C, B: 0x228, C: 0x314)           | 89   |
| Measurements—RAM Registers                                                                        | 89   |
| On-Demand RMS Result (N.IRMS) (0x11C)                                                             | 89   |
| Fundamental Energy                                                                                | 90   |
| Fundamental Energy Overflow Flags, Phase X = A/B/C (X.EFOVER) (A: 0x147, B: 0x233, C: 0x31F)      | 90   |
| Energy, Fundamental, Real Positive, Phase X = A/B/C (X.EAFPOS) (A: 0x1FC, B: 0x2E8, C: 0x3D4)     | 90   |
| Energy, Fundamental, Real Negative, Phase $X = A/B/C$ (X.EAFNEG) (A: 0x200, B: 0x2EC, C: 0x3D8)   | 91   |
| Energy, Fundamental, Reactive Positive, Phase X = A/B/C (X.ERFPOS) (A: 0x204, B: 0x2F0, C: 0x3DC) | 91   |
| Energy, Fundamental, Reactive Negative, Phase X = A/B/C (X.ERFNEG) (A: 0x208, B: 0x2F4, C: 0x3E0) | .92  |
| Energy Fundamental, Apparent, Phase X = A/B/C (X.ESF) (A: 0x20C, B: 0x2F8, C: 0x3E4)              | 92   |
| Energy Accumulated in the Last DSP Cycle                                                          | 93   |
| Real Energy, Phase $X = A/B/C$ (X.ACT) (A: 0x1D0, B: 0x2BC, C: 0x3A8)                             | 93   |
| Reactive Energy, Phase X = A/B/C (X.REA) (A: 0x1D4, B: 0x2C0, C: 0x3AC)                           | 93   |
| Apparent Energy, Phase $X = A/B/C$ (X.APP) (A: 0x1D8, B: 0x2C4, C: 0x3B0)                         |      |
| Fundamental Energy Accumulated in the Last DSP Cycle                                              |      |
| Fundamental Real Energy, Phase X = A/B/C (X.ACTF) (A: 0x1DC, B: 0x2C8, C: 0x3B4)                  |      |
| Fundamental Reactive Energy, Phase X = A/B/C (X.REAF) (A: 0x1E0, B: 0x2CC, C: 0x3B8)              |      |
| Fundamental Apparent Energy, Phase X = A/B/C (X.APPF) (A: 0x1E4, B: 0x2D0, C: 0x3BC)              |      |
| Checksum (CHKSUM) (0x066)                                                                         |      |
| Measurements—Virtual Registers                                                                    |      |
| Fundamental Real Power, Phase A/B/C/T (PWRPF.X) (A: 0x881, B: 0x882, C: 0x884, T: 0x887)          |      |
| Fundamental Reactive Power, Phase A/B/C/T (PWRQF.X) (A: 0x891, B: 0x892, C: 0x894, T: 0x897)      |      |
| Fundamental Apparent Power, Phase A/B/C/T (PWRSF.X) (A: 0x8A1, B: 0x8A2, C: 0x8A4, T: 0x8A7)      |      |
| Fundamental Real Energy, Phase A/B/C/T (ENRPF.X) (A: 0x8E1, B: 0x8E2, C: 0x8E4, T: 0x8E7)         |      |
| Fundamental Reactive Energy, Phase A/B/C/T (ENRQF.X) (A: 0x8F1, B: 0x8F2, C: 0x8F4, T: 0x8F7)     |      |
| Fundamental Apparent Energy, Phase A/B/C/T (ENRSF.X) (A: 0x8B1, B: 0x8B2, C: 0x8B4, T: 0x8B7)     |      |
| Current Total Harmonic Distortion Plus Noise, Phase A/B/C (THDN.X) (A: 0x859, B:0x85A, C: 0x85C)  |      |
| Phasors                                                                                           |      |
| Phase B Phasor (VBPH: 0x852)                                                                      |      |
| Phase C Phasor (VCPH: 0x854)                                                                      | .100 |

| TABLE OF CONTENTS (continued)                             |     |
|-----------------------------------------------------------|-----|
| Harmonics                                                 |     |
| RMS Voltage, Harmonic (V.HARM) (0x830)                    |     |
| RMS Current, Harmonic/Neutral (I.N, I.HARM) (0x840)       |     |
| Ratio of Harmonic/Fundamental (HARM_NF) (0x850)           |     |
| Special Commands                                          |     |
| Applications Information                                  |     |
| Grounds and Bypassing                                     |     |
| Specific Design Considerations for MAXQ3183-Based Systems |     |
| Additional Documentation                                  |     |
| Technical Support                                         |     |
| Pin Configuration                                         |     |
| Typical Application Circuit                               | 102 |

| LIST OF FIGURES                                          |     |
|----------------------------------------------------------|-----|
| Figure 1. External Reset                                 |     |
| Figure 2. Brownout Reset                                 |     |
| Figure 3. Simplified Clock Sources                       |     |
| Figure 4a. SPI Interface Timing (CKPHA = 0)              |     |
| Figure 4b. SPI Interface Timing (CKPHA = 1)              |     |
| Figure 5. Read SPI Transfer                              |     |
| Figure 6. Write SPI Transfer                             |     |
| Figure 7. Flowchart for Reading from MAXQ3183            |     |
| Figure 8. Flowchart for Writing to MAXQ3183              |     |
| Figure 9. Per Sample Operations                          |     |
| Figure 10. Computation of RMS Values                     |     |
| Figure 11. Phase Compensation for Energy Calculations    |     |
| Figure 12. Apparent and Reactive Energy Calculations     |     |
| Figure 13. Sample Voltage Input Circuit                  |     |
| Figure 14. Sample Current Input Circuit                  |     |
| Figure 15. Offset Testing Setup                          |     |
| Figure 16. Phase Offset vs. Input Current Calibration    |     |
| LIST OF TABLES                                           |     |
| Table 1. Command Format for SPI Register Read            | 22  |
| Table 2. Command Format for SPI Register Write           |     |
| Table 3. RAM Register Map                                |     |
| Table 4. Virtual Register Map                            |     |
| Table 5. Meter Unit Definitions                          |     |
| Table 6. Virtual Register Coefficients                   |     |
| Table 7 Virtual Registers That Activate Special Commands | 100 |

#### **ABSOLUTE MAXIMUM RATINGS**

| Voltage Range on DVDD Relative to DGND0.3V to +4.0V | Voltage Range on VxP, IxN Relative to AGND0.3V to +4.0V |
|-----------------------------------------------------|---------------------------------------------------------|
| Voltage Range on AVDD Relative to AGND0.3V to +4.0V | Operating Temperature Range40°C to +85°C                |
| Voltage Range on AGND Relative to DGND0.3V to +0.3V | Junction Temperature+150°C                              |
| Voltage Range on AVDD Relative to DVDD0.3V to +0.3V | Storage Temperature Range65°C to +150°C                 |
| Voltage Range on Any Pin Relative to                | Lead Soldering TemperatureRefer to the IPC/             |
| DGND except VxP, IxN Pins0.3V to +4.0V              | JEDEC J-STD-020 Specification.                          |

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

#### **METERING SPECIFICATIONS**

(VAVDD = VDVDD = VRST to 3.6V, Current Channel Dynamic Range 1000:1 at TA = +25°C, unless otherwise noted.) (Note 1)

| PARAMETER                       | CONDITIONS | MIN TYP MAX | UNITS |  |
|---------------------------------|------------|-------------|-------|--|
| Active Energy Linearity Error   | DR 1000:1  | 0.1         | %     |  |
| Reactive Energy Linearity Error | DR 1000:1  | 0.2         | %     |  |
| Apparent Energy Linearity Error | DR 1000:1  | 0.5         | %     |  |
| RMS Voltage Linearity Error     | DR 20:1    | 0.5         | %     |  |
| DMC Current Linearity Error     | DR 500:1   | 1.0         | - %   |  |
| RMS Current Linearity Error     | DR 20:1    | 0.5         |       |  |
| Line Frequency Error            |            | 0.5         | %     |  |
| Power Factor Error              |            | 1.0         | %     |  |

#### **ELECTRICAL CHARACTERISTICS**

 $(V_{AVDD} = V_{DVDD} = V_{RST}$  to 3.6V,  $T_A = -40^{\circ}C$  to  $+85^{\circ}C$ , unless otherwise noted.) (Note 2)

| PARAMETER                             | SYMBOL            | CONDITIONS                                 | MIN                        | TYP   | MAX                        | UNITS |
|---------------------------------------|-------------------|--------------------------------------------|----------------------------|-------|----------------------------|-------|
| POWER-SUPPLY SPECIFICATION            | ONS               |                                            |                            |       |                            |       |
| Digital Supply Voltage                | V <sub>DVDD</sub> |                                            | VRST                       |       | 3.6                        | V     |
| Power-Fail Interrupt Trip Point       | VPFW              | Active mode, EPWRF = 1                     | 2.84                       |       | 3.13                       | V     |
| Power-Fail Reset Trip Point           | V <sub>RST</sub>  | Active mode                                | 2.70                       |       | 2.99                       | V     |
| Analog Supply Voltage                 | VAVDD             |                                            | VRST                       |       | 3.6                        | V     |
| Analog Supply Current                 | lavdd             | f <sub>CLK</sub> = 8MHz                    |                            | 0.9   | 1.8                        | mA    |
| Digital Supply Current                | IDVDD             | f <sub>CLK</sub> = 8MHz                    |                            | 8.5   | 13                         | mA    |
| Low-Power Measurement Mode<br>Current | ILOWPM            | LOWPM = 1 (Note 1)                         |                            | 4.2   |                            | mA    |
| Stop-Mode Current                     |                   |                                            |                            | 0.2   | 12                         | μΑ    |
| DIGITAL I/O SPECIFICATIONS            |                   |                                            |                            |       |                            |       |
| Input High Voltage                    | VIH               |                                            | 0.7 x<br>V <sub>DVDD</sub> |       |                            | V     |
| Input Low Voltage                     | VIL               |                                            |                            |       | 0.3 x<br>V <sub>DVDD</sub> | V     |
| Input Hysteresis                      | VIHYS             | $V_{DVDD} = 3.3V$                          |                            | 500   |                            | mV    |
| Input Leakage                         | IL                | $V_{IN} = DGND$ or $V_{DVDD}$ , pullup off |                            | ±0.01 | ±1                         | μΑ    |

#### **ELECTRICAL CHARACTERISTICS (continued)**

 $(V_{AVDD} = V_{DVDD} = V_{RST}$  to 3.6V,  $T_A = -40$ °C to +85°C, unless otherwise noted.) (Note 2)

| PARAMETER                                 | SYMBOL            | CONDITIONS                             | MIN                         | TYP   | MAX    | UNITS  |
|-------------------------------------------|-------------------|----------------------------------------|-----------------------------|-------|--------|--------|
| Input Low Current                         | Ι <sub>Ι</sub> L  | V <sub>IN</sub> = 0.4V, weak pullup on | -50                         |       |        | μΑ     |
| RESET Pullup Resistance                   | RRESET            |                                        | 50                          | 150   | 200    | kΩ     |
| Output High Voltage (Except               | Vон               | I <sub>OH</sub> = -4mA                 | V <sub>D</sub> VDD<br>- 0.4 |       |        | V      |
| RESET)                                    | VOH               | I <sub>OH</sub> = -6mA                 | V <sub>D</sub> VDD<br>- 0.5 |       |        | v      |
| Output Low Voltage                        | V <sub>OL</sub>   | $I_{OL} = 4mA$                         |                             |       | 0.4    | V      |
| Output Low Voltage                        | VOL               | I <sub>OL</sub> = 6mA                  |                             |       | 0.5    | V      |
| SYSTEM CLOCK SOURCES                      |                   |                                        |                             |       |        |        |
| External Clock Input Frequency            |                   |                                        | 0                           |       | 8.12   | MHz    |
| External Clock Input Duty Cycle           |                   |                                        | 45                          |       | 55     | %      |
| External HF Crystal Frequency             | fsys              | Fundamental mode                       |                             |       | 8.12   | MHz    |
| XTAL1, XTAL2 Internal Load<br>Capacitance |                   |                                        |                             | 16    |        | pF     |
| Internal RC Oscillator Frequency          |                   |                                        | 7.4                         | 7.6   | 8.6    | MHz    |
| Internal RC Oscillator Accuracy           |                   |                                        |                             | ±2    |        | %      |
| Internal RC Oscillator Current            |                   |                                        |                             | 50    | 120    | μΑ     |
| Internal RC Oscillator Startup<br>Delay   |                   | (Note 1)                               |                             | 0.45  |        | μs     |
| ANALOG-TO-DIGITAL CONVERTE                | R                 | 1                                      | l                           |       |        | l      |
| Input Voltage Range                       |                   |                                        | 0                           |       | VREF   | V      |
| Common-Mode Bias                          | V <sub>СОММ</sub> |                                        |                             | 1.14  |        | V      |
| Offset Error                              |                   |                                        |                             | ±2    |        | mV     |
| Offset Error Drift                        |                   |                                        |                             | ±8    |        | μV/°C  |
| Gain Error (G = 1)                        |                   |                                        |                             | 0.05  |        | %      |
| Spurious-Free Dynamic Range               | SFDR              |                                        |                             | 90    |        | dB     |
| Total Harmonic Distortion                 | THD               |                                        |                             | 90    |        | dB     |
| Input Bandwidth (-3dB)                    |                   | (Note 1)                               |                             | 7     |        | kHz    |
| INTERNAL VOLTAGE REFERENCE                | CE                |                                        |                             |       |        | •      |
| Temperature Coefficient                   |                   | (Note 1)                               |                             | 30    |        | ppm/°C |
| Output Voltage                            | V <sub>REF</sub>  |                                        |                             | 2.048 |        | V      |
| INTERNAL TEMPERATURE SEN                  |                   |                                        |                             |       |        |        |
| Temperature Error                         |                   | (Note 1)                               | -4                          |       | +4     | °C     |
| SPI SLAVE-MODE INTERFACE T                | IMING             |                                        | •                           |       |        |        |
| Maximum SPI Clock Rate                    |                   |                                        |                             |       | fsys/4 | MHz    |
| SCLK Input Pulse-Width High               | tsch              | (Note 3)                               | 4 x<br>tsys                 |       |        | ns     |
| SCLK Input Pulse-Width Low                | tscl              | (Note 3)                               | 4 x<br>tsys                 |       |        | ns     |

#### **ELECTRICAL CHARACTERISTICS (continued)**

 $(V_{AVDD} = V_{DVDD} = V_{RST}$  to 3.6V,  $T_A = -40$ °C to +85°C, unless otherwise noted.) (Note 2)

| PARAMETER                                      | SYMBOL          | CONDITIONS | MIN               | TYP | MAX                      | UNITS |
|------------------------------------------------|-----------------|------------|-------------------|-----|--------------------------|-------|
| SSEL Low to First SCLK Edge (Slave Enable)     | tse             | (Note 3)   | 4t <sub>SYS</sub> |     |                          | ns    |
| Last SCLK Edge to SSEL High (Slave Disable)    | t <sub>SD</sub> |            | tsys +<br>5       |     |                          | ns    |
| MOSI Valid to SCLK Sample<br>Edge (MOSI Setup) | tsis            |            | 5                 |     |                          | ns    |
| SCLK Sample Edge to MOSI<br>Change (MOSI Hold) | tsıн            |            | tsys +<br>5       |     |                          | ns    |
| SCLK Shift Edge to MISO Valid (MISO Hold)      | tsov            |            |                   |     | 3t <sub>SYS</sub><br>+ 5 | ns    |

**Note 1:** Specifications guaranteed by design but not production tested.

Note 2: Specifications to -40°C are guaranteed by design and are not production tested.

Note 3:  $t_{SYS} = 1/f_{SYS}$ .

#### **SPI Slave Mode Timing**



12 \_\_\_\_\_\_\_/VIXI/M

#### **Block Diagram**



#### **Pin Description**

| PIN      | NAME                     | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
|----------|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
|          | •                        | POWER PINS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
| 17, 22   | DVDD                     | Digital Supply Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| 25       | AVDD                     | Analog Supply Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
| 18       | DGND                     | Digital Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
| 9        | AGND                     | Analog Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
| 23       | VCOMM                    | Voltage Bias. This pin can be used to create an input common-mode DC offset for ADC channel conversions.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |
| 24       | VREF                     | Voltage Reference. Reference voltage for the ADC. An external reference voltage can be connected to this pin when extremely high accuracy is required.                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|          | VOLTAGE AND CURRENT PINS |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| 26, 3, 4 | VOP, IOP,<br>ION         | Phase A Voltage and Current Analog Inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| 27, 5, 6 | V1P, I1P,<br>I1N         | Phase B Voltage and Current Analog Inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| 28, 7, 8 | V2P, I2P,<br>I2N         | Phase C Voltage and Current Analog Inputs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| 1        | VN                       | Analog Input for Common Voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| 2        | INP                      | Analog Input for Neutral Current                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|          |                          | CLOCK PINS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
| 10       | XTAL2<br>XTAL1           | High-Frequency Crystal Input/Output. When using an external high-frequency crystal, the crystal oscillator circuit should be connected between XTAL1 and XTAL2. When using an externally driven clock (EXTCLK = 1), the clock should be input at XTAL1, with XTAL2 left unconnected.                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
| 12       | ĪRQ                      | Interrupt Request Output. This line is driven low by the device to indicate to the master that an unmasked interrupt has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |
| 13       | SSEL                     | Slave Select Input. This line is the active-low slave select input for the SPI interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| 14       | SCLK                     | Slave Clock Input. This line is the clock input for the SPI interface.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
| 15       | MOSI                     | Master Out-Slave In Input. This line is used by the master to transmit data to the slave (the MAXQ3183) over the SPI interface.                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
| 16       | MISO                     | Master In-Slave Out Output. This line is used by the MAXQ3183 (the slave) to transmit data back to the master over the SPI interface.                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
| 19       | CFP                      | Pulse Output 1. Configurable to represent energy or RMS voltage or current.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
| 20       | CFQ                      | Pulse Output 2. Configurable to represent energy or RMS voltage or current.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
| 21       | RESET                    | Active-Low Reset Input/Output. An external master can reset the MAXQ3183 by driving this pin low. This pin includes a weak pullup resistor to allow for a combination of wired-OR external reset sources. An RC circuit is not required for power-up, as this function is provided internally. This pin also acts as a reset output when the source of the reset is internal to the device (power-fail, watchdog reset, etc.). In this case, the RESET pin is held low by the device until it exits the reset state, then the RESET pin is released. |  |  |  |  |  |  |  |  |

#### **Detailed Description**

The MAXQ3183 contains four major subsections: the analog front-end, the digital signal processor, the precision pulse generators, and an SPI peripheral for communication to the host processor.

#### **Analog Front-End**

The analog front-end (AFE) is an 8-channel analog-todigital converter (ADC). It operates autonomously in the standard configuration, assigning three channels to phase A, B, and C voltage; three channels to phase A, B, and C current; one channel to neutral current; and the last channel to a temperature sensor.

Each channel also contains a programmable-gain amplifier capable of providing a gain of 1, 2, 4, 8, 16, or 32 incoming signals. Only the voltage channels permit gain scaling by the host processor. The MAXQ3183 DSP firmware automatically sets the gain on current channels.

#### **Digital Signal Processor**

The DSP code is permanently embedded in masked ROM and accepts raw current and voltage samples for each of three phases and continuously calculates a host of values including RMS volts, RMS amps, real energy, reactive energy, apparent energy, fundamental and harmonic energy, and power factor.

The MAXQ3183 DSP core processes incoming samples from the analog front-end according to user configurations. The host sets these operating parameters by specifying addresses within the device RAM space. When a calculation cycle is complete, the results are placed back into RAM as well. Thus, the DSP core uses the RAM block as both its input (for operating parameters) and output (for calculation results) medium. See the *SPI Peripheral* section for how the host writes operating parameters and reads results from the RAM.

The DSP also calculates certain values such as line frequency and active and reactive powers only when demanded by the host.

#### **Precision Pulse Generators**

The MAXQ3183 includes two precision pulse generators that generate a pulse whenever certain conditions are met. In the MAXQ3183, many meter quantities can be selected for conversion to meter pulses including absolute energy, net energy, reactive energy, voltage, and current.

The pulse generators are accumulators. On each DSP cycle, whatever quantity is being measured—real energy, reactive energy, current, or something else—is

added to the pulse accumulator. The pulse accumulator is then tested to determine if the value in the accumulator is greater than the threshold. If it is greater, the threshold value is subtracted from the accumulator value and the meter pulse starts.

#### **SPI Peripheral**

The SPI controller is a slave-only device that can read or write any location in the data RAM. Additionally, it can request data from on-demand registers.

The MAXQ3183 implements a truly full-duplex communication, rather than the pseudo half-duplex mode used by other SPI peripherals. That is, each time a character is received by the MAXQ3183, a meaningful character is returned to the host. Often, this is a protocol character. In this way, the host can be assured that the command has been received and is valid. Optional error checking can also be enabled to further guarantee proper operation.

#### **Operating Modes**

The MAXQ3183 has two basic modes of operation, each of which is described in the following sections. The Initialization Mode is the default mode upon power-up or following reset; entry to and exit from the other operating modes is only performed as a result of commands sent by the master.

#### Run Mode

This mode is the normal operating mode for the MAXQ3183. In this mode, the MAXQ3183 continuously executes the following operations:

- Scans analog front-end channels and collects raw voltage and current samples.
- Processes voltage and current samples through DSP filters as enabled and configured.
- Calculates power, energy, and other required quantities and stores these values in RAM registers.
- Responds to register write and read commands from the master.
- Outputs power pulses on CFP and CFQ as configured.
- Drives IRQ when an interrupt condition has been detected and the interrupt is not masked.

#### Stop Mode

This mode places the MAXQ3183 into a power-saving state where it consumes the least possible amount of current. In Stop Mode, all functions are suspended, including the ADC and power and voltage measurement and processing. The MAXQ3183 does not respond to any commands from the master in this operating state.

Entry into Stop Mode only occurs at the request of the master. To place the MAXQ3183 into Stop Mode, the master must read the ENTER STOP (0xC02) register. Once this register has been read, the MAXQ3183 enters Stop Mode immediately, before the transmission of the final ACK byte by the MAXQ3183.

There are three possible ways to bring the MAXQ3183 back out of Stop Mode.

- Power Cycle. The MAXQ3183 automatically exits Stop Mode if a power-on reset occurs. Following exit from Stop Mode, all registers are cleared back to their default states, and the MAXQ3183 transitions to Initialization Mode.
- External Reset. The MAXQ3183 exits Stop Mode if an external reset is triggered by driving RESET low. Once the RESET pin is released and allowed to return to a high state, the MAXQ3183 comes out of reset and goes into Initialization Mode. All registers are cleared to their default states when exiting Stop Mode in this manner.
- External Interrupt. Driving the SSEL pin low causes the MAXQ3183 to exit Stop Mode without undergoing a reset cycle. When exiting Stop Mode in this manner, all register and configuration settings are retained, and the MAXQ3183 automatically resumes electric-metering functions and sample processing.

Note that when the master is communicating with the

MAXQ3183, the SSEL line is normally driven low at the beginning of each SPI command. This means that if the master sends an SPI command after the MAXQ3183 enters Stop Mode, the MAXQ3183 automatically exits Stop Mode.

#### **Reset Sources**

There are several different sources that can cause the MAXQ3183 to undergo a reset cycle. For any type of hardware reset, the RESET pin is driven low when a reset occurs.

#### External Reset

This hardware reset is initiated by an external source (such as the master controller or a manual pushbutton press) driving the RESET pin on the MAXQ3183 low. The RESET line must be held low for at least four cycles of the currently selected clock for the external reset to take effect. Once the external reset takes effect, it remains in effect indefinitely as long as RESET is held low. Once the external reset has been released, the MAXQ3183 clears all registers to their default states and resumes execution in Initialization Mode.

When an external reset occurs outside of Stop Mode, execution (in Initialization Mode) resumes after four cycles of the currently selected clock (external high-frequency crystal for Run Mode, 1MHz internal RC oscillator for LOWPM Mode). As the MAXQ3183 enters Initialization Mode, the LOWPM bit is always cleared



Figure 1. External Reset

\_\_ /N/1X1/N

to 0, meaning that the MAXQ3183 always switches to the high-frequency clock before it begins accepting commands in Initialization Mode.

When an external reset occurs from Stop Mode, execution (in Initialization Mode) resumes after 128 cycles of the internal RC oscillator (or approximately 128µs).

#### Power-On Reset

When the MAXQ3183 is first powered up, or when the power supply, V<sub>DVDD</sub>, drops below the V<sub>RST</sub> power-fail trip point (outside of Stop Mode), the MAXQ3183 is held in power-on reset. Once the power supply rises above the V<sub>RST</sub> level, the power-on reset state is released and all registers are reset to their defaults and execution resumes in Initialization Mode. The high-frequency external crystal (LOWPM = 0) is always selected as the clock source following any power-on or brownout reset.

In Stop Mode brownout detection is disabled, so a power-on reset does not occur until V<sub>DVDD</sub> drops to a lower level (V<sub>POR</sub>). From the master's perspective,

power-on resets and brownout resets both cause the MAXQ3183 to reset in the same way.

#### Watchdog Reset

The MAXQ3183 includes a hardware watchdog timer that is armed and periodically reset automatically during normal operation. Under normal circumstances, the MAXQ3183 always resets the watchdog timer often enough to prevent it from expiring. However, if an internal error of some kind causes the MAXQ3183 to lock up or enter an endless execution loop, the watchdog timer expires and triggers an automatic hardware reset. There is no register flag to indicate to the master that a watchdog reset has occurred, but the RESET line strobes low briefly.

The watchdog timer does not run during Stop Mode.

#### Software Reset

The master initiates a software reset by setting the SWRES (OPMODE0.3) bit to 1. When a software reset occurs, the MAXQ3183 clears all registers to their default states and returns to Initialization Mode, in the



Figure 2. Brownout Reset

same manner as if an external reset had taken place. Unlike a hardware reset, however, a software reset does not cause the MAXQ3183 to drive the RESET line low.

#### **Power-Supply Monitoring**

In addition to the hardware reset provided by the power-on reset and brownout reset circuits, the MAXQ3183 includes the capability to detect a low power supply on the DVDD pin and alert the master through the interrupt ( $\overline{\text{IRQ}}$ ) mechanism before a hardware reset occurs. This function, which is always enabled outside of Stop Mode, causes the RAM status register flag PWRF (IRQ\_FLAG.0) to be set to 1 whenever VDVDD drops below the VPFW trip point. Once PWRF has been set to 1 by hardware, it can only be cleared by the master (or by a system reset). Whenever PWRF = 1, if the EPWRF interrupt masking bit is also set to 1, the MAXQ3183 drives  $\overline{\text{IRQ}}$  low to signal to the master that an interrupt condition (in this case, a powerfail warning) exists and requires attention.

#### **Clock Sources**

All operations including ADC sampling and SPI communications are synchronized to a single system clock. This clock can be obtained from any one of three selectable sources, as shown in Figure 3.

#### External High-Frequency Crystal

The default system clock source for the MAXQ3183 is an external high-frequency crystal oscillator circuit connected between XTAL1 and XTAL2. When clocked with an external crystal, a parallel-resonant, AT-cut crystal oscillating in the fundamental mode is required.

When using a high-frequency crystal, the fundamental oscillation mode of the crystal operates as inductive reactance in parallel resonance with external capacitors C1 and C2. The typical values of these external capacitors vary with the type of crystal being used and should be selected based on the load capacitance as suggested by the crystal manufacturer.

Since noise at XTAL1 and XTAL2 can adversely affect device timing, the crystal and capacitors should always be placed as close as possible to the XTAL1 and XTAL2 pins, with connection traces between the crystal and the device kept as short and direct as possible. In multiple layer boards, avoid running other high-speed digital signals underneath the crystal oscillator circuit if possible, as this could inject unwanted noise into the clock circuit.

Following power-up or any system reset, the high-frequency clock is automatically selected as the system clock source. However, before this clock can be used



Figure 3. Simplified Clock Sources

for system execution, a crystal warmup timer must count 65,536 cycles of the high-frequency clock. While this warmup time period is in effect, execution continues using the internal 1MHz oscillator. Once the 65,536-cycle count completes (which requires approximately 8.2ms at 8MHz), the device automatically switches over to the high-frequency clock. This crystal warmup timer is also activated upon exit from Stop Mode, since the high-frequency crystal oscillator is shut down during Stop Mode.

#### External High-Frequency Clock

Instead of using a crystal oscillator to generate the high-frequency clock, it is also possible to input a high-frequency clock that has been generated by another source (such as a digital oscillator IC) directly into the XTAL1 pin of the MAXQ3183.

To use an external high-frequency clock as the system clock source, the XTAL1 pin should be used as the clock input and the XTAL2 pin should be left unconnected. The master should also shut down the internal crystal oscillator circuit by setting the EXTCLK bit (OPMODE0.4) to 1. This bit is only cleared by the MAXQ3183 if a power-on or brownout reset occurs and is unaffected by other resets.

When using an external high-frequency clock, the clock signal should be generated by a CMOS driver. If the clock driver is a TTL gate, its output must be connected to DVDD through a pullup resistor to ensure that the correct logic levels are generated. To minimize system noise in the clock circuitry, the external clock source must meet the maximum rise and fall times and the minimum high and low times specified for the clock source in the *Electrical Characteristics* table.

#### Internal RC Oscillator

When the external high-frequency crystal is warming up, or when the MAXQ3183 is placed into LOWPM mode, the system clock is sourced from an internal RC oscillator. This internal oscillator is designed to provide the system approximately 1MHz, although the exact frequency varies over temperature and supply voltage.

If no external crystal circuit or high-frequency clock will be used, the MAXQ3183 can be forced to operate infinitely from the internal oscillator by grounding XTAL1. This ensures that the crystal warmup count never completes, so the MAXQ3183 runs from the internal oscillator in all active modes.

#### **Master Communications**

Before the MAXQ3183 can begin performing electric-metering operations, the master must initialize a number of configuration parameters. Since the MAXQ3183 does not contain internal nonvolatile memory, these parameters (stored in internal registers) must be set by the master each time a power-up or reset cycle occurs, or each time a switch is made between LOWPM Mode and Run Mode.

The external master communicates with the MAXQ3183 over a standard SPI bus, using commands to read and write values to internal registers on the MAXQ3183. These registers include, among many other items:

- Operating mode settings (Stop Mode, LOWPM Mode, external clock mode, etc.)
- Status and interrupt flags (power-supply failure, overcurrent/overvoltage detection, etc.)
- Masking control for interrupts to determine which conditions cause IRQ to be driven low
- Configuration settings for analog channel scanning
- Power pulse output configuration
- Filter coefficients and configuration
- Read-only registers containing accumulated power and energy data

As the MAXQ3183 obtains voltage and current measurements in Run Mode or LOWPM Mode, it accumulates, filters, and performs a number of calculations on the collected data. Many of these operations (including the various filtering stages) are configured by settings in registers written by the master. The output results can then be read by the master from various read-only registers in parallel with the ongoing measurement and processing operations.

#### SPI Communications Rate and Format

The SPI is an interdevice bus protocol that provides fast, synchronous, full-duplex communications between a designated master device and one or more slave devices. In a MAXQ3183-based design, the MAXQ3183 would be the slave device connected to a designated master microcontroller.

The external master initiates all communications transfers. The interrupt request line  $\overline{\text{IRQ}}$ , while not technically part of the SPI bus interface, is also used for master/slave communications because it allows the MAXQ3183 to notify the master that an interrupt condition exists. Some SPI peripherals sacrifice speed in favor of simulating a half-duplex operation. This is not the case with the MAXQ3183; it is truly a full-duplex SPI slave.

During an SPI transfer, data is simultaneously transmitted and received over two serial data lines (MISO and MOSI) with respect to a single serial shift clock (SCLK). The polarity and phase of the serial shift clock are the primary components in defining the SPI data transfer format. The polarity of the serial clock corresponds to the idle logic state of the clock line and, therefore, also defines which clock edge is the active edge. To define a serial shift clock signal that idles in a logic-low state (active clock edge = rising), the clock polarity select (CKPOL; R\_SPICF.0) bit should be configured to a 0, while setting CKPOL = 1 causes the shift clock to idle in a logic-high state (active clock edge = falling). The phase of the serial clock selects which edge is used to sample the serial shift data. The clock phase select (CKPHA; R\_SPICF.1) bit controls whether the active or

inactive clock edge is used to latch the data. When CKPHA is set to a logic 1, data is sampled on the inactive clock edge (clock returning to the idle state). When CKPHA is set to a logic 0, data is sampled on the active clock edge (clock transition to the active state). Together, the CKPOL and CKPHA bits allow four possible SPI data transfer formats.

Transfers over the SPI interface always start with the most significant bit and end with the least significant bit. All SPI data transfers to and from the MAXQ3183 are always 8 bits (one byte) in length. The MAXQ3183 SPI interface does not support 16-bit character lengths.

The default format (upon power-up or system reset) for the MAXQ3183 SPI interface is represented in Figure 4a (CKPOL = 0; CKPHA = 0). In this format, the



Figure 4a. SPI Interface Timing (CKPHA = 0)



Figure 4b. SPI Interface Timing (CKPHA = 1)

\_\_\_\_\_\_/N/XI/N

SPI clock idle state is low, and data is shifted in and out on the rising edge of SCLK. Once SPI communication with the MAXQ3183 has been established, it is possible to alter the CKPOL and CKPHA format settings (as well as changing the SSEL signal from active low to active high) if desired by writing to the R\_SPICF mirror register and then reading from the special command register UPD\_SFR to copy the R\_SPICF value into the internal SPI configuration register.

Whenever the active clock edge is used for sampling (CKPHA = 0), the transfer cycle must be started with assertion of the SSEL signal. This requirement means that the SSEL signal be deasserted and reasserted between successive transfers. Conversely, when the inactive edge is used for sampling (CKPHA = 1), the SSEL signal may remain low through successive transfers, allowing the active clock edge to signal the start of a new transfer.

The clock rate used for the SPI interface is determined by the bus master, since the MAXQ3183 always operates as an SPI slave device. However, the maximum clock rate is limited by the system clock frequency of the MAXQ3183. For proper communications operation, the SPI clock frequency used by the master must be less than or equal to the MAXQ3183's clock frequency divided by 4. For example, when the MAXQ3183 is running at 8MHz, the SPI clock frequency must be 2MHz or less. And if the MAXQ3183 is running in LOWPM Mode (or if the crystal is still warming up), the SPI clock frequency must remain at 250kHz or less for proper communications operation.

In addition to limiting the overall SPI bus clock rate, the master must also include a communications delay following each byte transmit/receive cycle. This delay, which provides the MAXQ3183 with time to process an ADC sample, should be a minimum of 400 system clocks. With default settings and running at 8MHz, this delay time is 50µs. Reducing the system clock frequency to 1MHz (LOWPM mode) would increase this delay period by a factor of 8 to 400µs.

#### **SPI Communications Protocol**

All transactions between the master and the MAXQ3183 consist of the master writing to or reading from one of the MAXQ3183's registers. To the host, the MAXQ3183 looks like a memory array that consists of both RAM and ROM. This is because the ROM firmware in the MAXQ3183 reads its operational parameters from RAM and places its results in RAM. Consequently, configuring a MAXQ3183 is as simple as performing a block write to its RAM locations.

Some read-only memory locations in the MAXQ3183 trigger actions within the device to calculate electricity-metering results on the fly. The specific function and purpose of RAM and virtual ROM locations are given in the register map. There are several different categories of internal registers on the MAXQ3183.

- RAM Registers. The values of these registers are stored in the internal RAM of the MAXQ3183. Some can be read and written by the master, while others are read-only. RAM registers are either 2 or 4 bytes long (16 or 32 bits), although in some registers not all the bits have defined values. Read/write registers are generally either status/flag registers (which can be written by either the MAXQ3183 or the master), configuration registers (which are written by the master and read by the MAXQ3183 firmware), or data registers (which are read-only and are written by the MAXQ3183 firmware and read by the master).
- Virtual Registers. These read-only registers are not stored in RAM; instead, they contain values that are calculated on the fly by the MAXQ3183 firmware when the master reads them. These registers are used by the master to obtain values such as phase A, B, and C active, reactive, and apparent power; power factor; and RMS voltage and current, which are calculated from currently collected data on an as-needed basis. Most virtual registers are 8 bytes in length.
- Hardware Registers. These registers control core functions of the MAXQ3183 including the ADC and the SPI slave bus controller. Each of these registers (R\_ACFG, R\_ADCRATE, R\_ADCACQ, R\_SPICF, and OPMODE0 (bit 4, EXTCLK only)) has a register location in RAM that "shadows" the value of the hardware register. To read from a hardware register, the master must first read from the special command register UPD\_MIR (A00h) to copy the values from the hardware registers to the mirror registers in RAM, and then the mirror register in RAM can be read. To write to a hardware register, the master reverses the process by writing to the mirror RAM register and then reading from the special command register UPD\_SFR (900h) to copy the values from the mirror registers to the hardware registers.
- Special Command Registers. These registers (UPD\_SFR and UPD\_MIR) do not return meaningful data when read but instead trigger an operation. Reading UPD\_SFR causes values to be copied from the mirror registers to hardware, and reading UPD\_MIR causes values to be copied from the hardware to mirror registers.

Every defined register on the MAXQ3183 has a 12-bit address (from 0 to 4095). This address is used when addressing the register for either a read or write operation. Addresses 0 to 1023 (000h to 3FFh) are used to address RAM registers. Registers with addresses from 1024 to 4095 (400h to FFFh) are used for virtual registers and special command registers.

Each command consists of a read/write command code, a data length (1, 2, 4, or 8 bytes), a 12-bit register address, and the specified number of data bytes followed optionally by a cyclic redundancy check (CRC). Since SPI is a full-duplex interface, the master and slave must both transmit the same number of bytes during the command. When a multiple-byte register is read or written (2/4/8 byte length), the least significant byte is read or written first in the command.

Every transaction begins with the master sending 2 bytes that contain the command (read or write), the address to access, and the number of bytes to transfer. Every SPI peripheral must return 1 byte for every byte it receives. If the master is reading 1 or more bytes from the MAXQ3183, it must send dummy bytes during the

cycles when it is receiving a multibyte response to a request, meeting the "send a byte to get a byte" requirement. But the MAXQ3183 could require time to calculate the result, and thus might not have it ready when the master sends the dummy byte. For this reason, the MAXQ3183 always sends zero or more bytes of a NAK character (0x4E or ASCII 'N') followed by an ACK character (0x41, or ASCII 'A') before sending the data.

If the master is writing 1 or more bytes, it sends the data to be written immediately after sending the command. The MAXQ3183 returns ACK (0x41) for each data byte. It then returns NAK (0x4E) until the write cycle is complete, after which it returns a final ACK.

Immediately after the final ACK, the MAXQ3183 is ready to begin the next transaction; there is no need to wait for any other event. It is not even necessary to toggle SSEL to begin the next transaction. The MAXQ3183 knows that the first transaction is over and is ready for the next.

If, for whatever reason, it is necessary to reset the communications between the host and the MAXQ3183 (for

Table 1. Command Format for SPI Register Read

| BYTE                         | TRANSFERS                                                            | BIT | DESCRIPTION                                                                                                                                   |
|------------------------------|----------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|
|                              |                                                                      | 7:6 | Command Code: 00 Read 01 Reserved 10 Write 11 Reserved                                                                                        |
| 1st byte                     | Master sends command;<br>Slave sends 0xC1 byte                       | 5:4 | Data Length: 00 1 Byte 01 2 Bytes 10 4 Bytes 11 8 Bytes                                                                                       |
|                              |                                                                      | 3:0 | MSB portion of data address.                                                                                                                  |
| 2nd byte                     | Master sends address;<br>Slave sends 0xC2 byte                       | 7:0 | LSB portion of data address.                                                                                                                  |
| Sync bytes                   | Master sends dummy;<br>Slave sends ACK (0x41) or<br>NACK (0x4E) byte | 7:0 | Master sends dummy byte; Slave responds with NACK if busy, or with ACK when processing complete.  Master must receive ACK, then receive data. |
| 3rd byte<br>(1st data byte)  | Master sends dummy;<br>Slave sends data                              | 7:0 | Data, LSB                                                                                                                                     |
|                              |                                                                      |     |                                                                                                                                               |
| Nth byte<br>(Last data byte) | Master sends dummy;<br>Slave sends data                              | 7:0 | Data, MSB                                                                                                                                     |
| (N + 1) byte                 | Master sends dummy;<br>Slave sends CRC                               | 7:0 | Optional CRC                                                                                                                                  |

**Table 2. Command Format for SPI Register Write** 

| ВҮТЕ                        | TRANSFERS                                                            | BIT | DESCRIPTION                                                                                                                                                     |  |  |  |
|-----------------------------|----------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                             | M                                                                    | 7:6 | Command code: 00 Read 01 Reserved 10 Write 11 Reserved                                                                                                          |  |  |  |
| 1st byte                    | Master sends command;<br>Slave sends 0xC1 byte                       | 5:4 | Data Length: 00 1 Byte 01 2 Bytes 10 4 Bytes 11 8 Bytes                                                                                                         |  |  |  |
|                             |                                                                      | 3:0 | MSB portion of data address.                                                                                                                                    |  |  |  |
| 2nd byte                    | Master sends address;<br>Slave sends 0xC2 byte                       | 7:0 | LSB portion of data address.                                                                                                                                    |  |  |  |
| 3rd byte<br>(1st data byte) | Master sends data;<br>Slave sends ACK (0x41)                         | 7:0 | Data, LSB                                                                                                                                                       |  |  |  |
|                             |                                                                      |     |                                                                                                                                                                 |  |  |  |
| Nth byte (Last data byte)   | Master sends data;<br>Slave sends ACK (0x41)                         | 7:0 | Data, MSB                                                                                                                                                       |  |  |  |
| (N + 1) byte                | Master sends CRC;<br>Slave sends ACK (0x41)                          | 7:0 | Optional CRC                                                                                                                                                    |  |  |  |
| Sync bytes                  | Master sends dummy;<br>Slave sends ACK (0x41) or<br>NACK (0x4E) byte | 7:0 | Master sends dummy byte; Slave responds with NACK if busy, or with ACK when processing complete.  Master must receive ACK before starting the next transaction. |  |  |  |

example, if synchronization is lost), the host only needs to wait for the SPI to time out before restarting communication from the first command byte. SPI timeout count starts after receiving the first command byte from the master (after the 8th SPI clock of the first byte). The count stops and clears after receiving the last byte of a transaction (after the 8th SPI clock of the last byte).

If the timeout count expires (exceeds COM\_TIMO) before the transaction completes, the MAXQ3183 abandons the unfinished transaction and resets the SPI logic to be ready for the next transaction. The default SPI timeout is 360ms.

Optionally, a CRC byte can be appended to each transaction. For write commands, the CRC byte is sent by the master, and for read commands the CRC byte is sent by the MAXQ3183. The CRC mode is enabled when the CRCEN bit is set to 1 in OPMODE1 register. Otherwise, the MAXQ3183 assumes no CRC byte is used. The 8-bit CRC is calculated for all bytes in a transaction, from the first command byte sent by the

master through the last data byte excluding sync bytes, using the polynomial  $P = x^8 + x^5 + x^4 + 1$ . If the transmitted CRC byte does not match the calculated CRC byte (for a write command), the MAXQ3183 ignores the command.

The length of the transfer is defined by the first command byte and the status of the CRCEN bit in the OPMODE1 register. There is no special synchronization mechanism provided in this simple protocol. Therefore, the master is responsible for sending/receiving the correct number of bytes. If the master mistakenly sends more bytes than are required by the current command, the extra bytes are either ignored (if the MAXQ3183 is busy processing the previous command) or are interpreted as the beginning of a new command. If the master sends fewer bytes than are required by the current command, the MAXQ3183 waits for SPI timeout, then drops the transaction and resets the communication channel. The duration of the timeout can be configured through the COM\_TIMO register.



Figure 5. Read SPI Transfer



Figure 6. Write SPI Transfer

Figures 5 and 6 show typical 2-byte reading and writing transfers (without CRC byte).

#### Host Software Design

Individual message bytes sent through the SPI are processed in a software routine contained in the ROM firmware. For this reason, it is necessary to provide a delay between successive bytes. This byte spacing must be no less than 400 system clocks to ensure that the MAXQ3183 has a chance to read and process the byte before the arrival of the next one. It is strongly recommended that CRC be enabled for both read and write to achieve reliable operations.

#### \_Register Set

Data and device command and control information are located in internal registers. Registers range from 8 to 64 bits in length and are divided into RAM-based registers

and virtual registers. The RAM-based registers contain both operating parameters and measurement results.

To read any virtual power registers, the host must first confirm that the DSPRDY bit of the IRQ\_FLAG register is set, which indicates the last DSP cycle has completed, then proceed to reading all the desired virtual power registers. For best communication efficiency, it is recommended to complete reading the virtual power registers before reading other registers. Virtual power register reads must be completed within 50% of DSP cycle time, from the moment DSPRDY bit is set. Do not forget to clear the DSPRDY bit, otherwise, host software is not able to detect the completion of the new DSP cycle. The MAXQ3183 does not clear the bit; it only sets the bit whenever a DSP cycle processing is completed. Users can clear the bit directly after the confirmation that the bit is set. Clearing the DSPRDY bit does not affect the DSP processing.



Figure 7. Flowchart for Reading from MAXQ3183

WRITE MAXQ3183 SPI TIMEOUT (360ms) SEND COMMAND BYTE 1 GET 0xC1? DELAY > 400 SYSCLK SEND COMMAND BYTE 2 GET 0xC2? DELAY > 400 SYSCLK SEND DATA BYTE GET 0x41? DELAY > 400 SYSCLK SEND 0x00 GET 0x4E? GET 0x41? **EXIT** 

Figure 8. Flowchart for Writing to MAXQ3183

The virtual registers contain calculated values derived from one or more real registers. They are calculated at the time they are requested, and thus can involve additional time to return a value. Most virtual registers are 8 bytes in length and are delivered least significant byte first

#### **Table 3. RAM Register Map**

|        | x0h         | x1h         | x2h         | x3h          | x4h   | x5h            | x6h          | x7h          | x8h         | x9h         | xAh         | xBh         | xCh               | xDh         | xEh         | xFh          |
|--------|-------------|-------------|-------------|--------------|-------|----------------|--------------|--------------|-------------|-------------|-------------|-------------|-------------------|-------------|-------------|--------------|
| 0x00   | STATUS      | OP<br>MODE0 | OP<br>MODE1 | OP<br>MODE2  | IRQ_  | FLAG           | IRQ_I        | MASK         | SCAN<br>_IA | SCAN<br>_VA | SCAN<br>_IC | SCAN<br>_VC | SCAN<br>_IB       | SCAN<br>_VB | SCAN<br>_IN | SCAN<br>_TE  |
| 0x01   | AUX         | _CFG        | SYS.        | _KHZ         | VOL   | Γ_CC           | AMF          | CC.          | PWF         | R_CC        | ENF         | CC          | CYC               | ONT         | PLSCFG<br>1 | PLSCFG<br>2  |
| 0x02   | PLS         | I_WD        |             | TH           | IR1   |                | PLS2         | <br>WD       |             | TH          | IR2         |             | REJ               | _NS         | AVG         | i_NS         |
| 0x03   |             | <br>G_C     | HP          | F_C          |       | UND            |              | A1F          | UND         |             |             | ARM         |                   |             | ARM         |              |
| 0x04   |             |             | IS          |              |       | LVL            | OV           | LVL          |             | LVL         |             | .OAD        | R_ACFG            |             | R_AD        | CRATE        |
| 0x05   | R_AD        | CACQ        | R_<br>SPICF |              |       | ЛLVL           |              | _TIMO        | ACC_        | TIMO        | ZC_         | LPF         | I1T               | HR          |             | HR           |
| 0x06   | TEM         | P_CC        | LIN         | EFR          |       |                | CHK          | SUM          |             |             |             |             |                   |             |             |              |
| 0x11   |             | Ī           |             |              |       |                |              |              |             | 1           | 1           | 1           |                   | N.II        | RMS         | l            |
| 0x12   |             |             |             |              |       |                |              |              |             |             |             |             |                   | 1           | N.I.        | GAIN         |
| 0,7,12 |             |             | l           |              | PH    | ASE A C        | L<br>ALIBRAT | ION AND      | STATUS      | REGIST      | TERS        |             |                   | 1           |             | G.7 11.1     |
| 0x13   | I AL        | GAIN        | AV          | GAIN         |       | GAIN           |              | GAIN         |             | FS_HI       |             | IN_LO       | A OFF             | S_LO        | I AF        | PA0          |
| 0x14   |             | PA1         |             | PA2          | Α.    | A.<br>MASK     | Α.           | A.<br>EFOVER |             |             |             |             |                   |             |             |              |
|        |             |             |             |              |       |                |              | ION AND      | STATH       | REGIST      | FRS         |             |                   |             |             |              |
| 0x21   |             |             | I           |              | F11/  | AGE B C        | LIBRAI       | ION AND      | JIAIUS      | nedisi      | Lns         |             | DI/               |             | D.V         | GAIN         |
|        | DE          | GAIN        | D EE        | _GAIN        | P OE  | FS_HI          | P C A        | IN I O       | B.OFF       | EQ 1.0      | DI          | PA0         | B.I_0             | GAIN<br>DA1 | _           | PA2          |
| 0x22   | <u> </u>    | 1           |             | 1            | B.Ur  | го <u>_</u> пі | B.GAI        | IN_LO        | B.OF        | -S_LU       | D.1         | AU          | D.F               | AI          | D.F         | AZ           |
| 0x23   | B.<br>FLAGS | B.<br>MASK  | B.<br>EOVER | B.<br>EFOVER |       |                |              |              |             |             |             |             |                   |             |             |              |
|        |             |             |             |              | PH    | ASE C C        | ALIBRAT      | ION AND      | 1           |             |             |             |                   |             |             |              |
| 0x30   |             |             |             |              |       |                |              |              | C.I_0       | GAIN        | C.V_        | GAIN        |                   | GAIN        | 1           | _GAIN        |
| 0x31   | C.OF        | FS_HI       | C.GA        | IN_LO        | C.OFF | S_LO           | C.F          | PA0          | C.F         | PA1         | C.I         | PA2         | C.<br>FLAGS       | C.<br>MASK  | C.<br>EOVER | C.<br>EFOVER |
| 0x32   |             |             |             |              |       |                |              |              |             |             |             |             |                   |             |             |              |
|        |             |             |             |              |       | PHASE          | A MEAS       | SUREME       | NT REG      | STERS*      |             |             |                   |             |             |              |
| 0x1C   |             |             |             |              |       |                | Α.           | PF           |             | A.V         | RMS         |             |                   | A.II        | RMS         |              |
| 0x1D   |             | A.A         | \CT         |              |       | A.F            | REA          |              |             | Α./         | APP         |             |                   | A.A         | CTF         |              |
| 0x1E   |             | A.R         | EAF         |              |       | A.A            | .PPF         |              |             | A.E         | APOS        |             |                   | A.EA        | ANEG        |              |
| 0x1F   |             | A.EF        | RPOS        |              |       | A.EF           | RNEG         |              |             |             |             |             | A.EA              | FPOS        |             |              |
| 0x20   |             | A.EA        | FNEG        |              |       | A.ER           | FPOS         |              |             | A.ER        | FNEG        |             |                   | A.I         | ESF         |              |
|        |             |             |             |              |       | PHASE          | B MEAS       | SUREME       | NT REG      | STERS*      |             |             |                   |             |             |              |
| 0x2B   |             |             | В.          | .PF          |       | B.VI           | RMS          |              |             | B.If        | RMS         |             |                   | В.          | ACT         |              |
| 0x2C   |             | B.F         | REA         |              |       | B.A            | \PP          |              |             | B.A         | CTF         |             |                   | B.R         | EAF         |              |
| 0x2D   |             | B.A         | PPF         |              |       | B.EA           | APOS         |              |             | B.EA        | NEG         |             |                   | B.EF        | RPOS        |              |
| 0x2E   |             | B.EF        | RNEG        |              |       | В.             | ES           |              |             | B.EA        | FPOS        |             |                   | B.EA        | FNEG        |              |
| 0x2F   |             | B.ER        | FPOS        |              |       | B.ER           | FNEG         |              |             | B.I         | ESF         |             |                   |             |             |              |
|        | 1           |             |             |              |       |                |              | SUREME       | NT REG      | STERS*      |             |             | •                 |             | •           |              |
| 0x39   |             |             |             |              |       |                |              |              |             |             |             |             |                   |             | C.          | PF           |
| 0x3A   |             | C.VI        | RMS         |              |       | C.IF           | RMS          |              |             | C./         | ACT         |             |                   | C.F         | REA         |              |
| 0x3B   |             |             | APP         |              |       |                | CTF          |              |             |             | EAF         |             | C.APPF            |             |             |              |
| 0x3C   |             |             | APOS        |              |       |                | NEG          |              |             |             | RPOS        |             | C.APPP<br>C.ERNEG |             |             |              |
| 0x3D   |             |             | ES          |              |       |                | FPOS         |              |             |             | FNEG        |             | C.ERFPOS          |             |             |              |
| 0x3E   |             |             | FNEG        |              |       |                | ESF          |              |             | 3.27        | 1           |             |                   | 0.21        | 1           |              |
| UNUL   |             | U.LI1       |             |              | I     | U.I            | _01          |              |             |             | 1           | 1           | <u> </u>          | 1           | 1           |              |

<sup>\*</sup>Read-only.

**Table 4. Virtual Register Map** 

|      | х0                         | x1      | x2            | х3             | x4            | х7      | х9     | хA     | хC     |  |
|------|----------------------------|---------|---------------|----------------|---------------|---------|--------|--------|--------|--|
| 0x80 |                            | PWRP.A  | PWRP.B        |                | PWRP.C        | PWRP.T  |        |        |        |  |
| 0x81 |                            | PWRQ.A  | PWRQ.B        |                | PWRQ.C        | PWRQ.T  |        |        |        |  |
| 0x82 |                            | PWRS.A  | PWRS.B        |                | PWRS.C        | PWRS.T  |        |        |        |  |
| 0x83 | V.HARM                     | V.A     | V.B           |                | V.C           |         |        |        |        |  |
| 0x84 | I.N, I.HARM                | I.A     | I.B           |                | I.C           |         |        |        |        |  |
| 0x85 | HARM_NF                    |         | VBPH          |                | VCPH          |         | THDN.A | THDN.B | THDN.C |  |
| 0x86 |                            |         |               |                |               | PF.T    |        |        |        |  |
| 0x87 |                            | ENRS.A  | ENRS.B        |                | ENRS.C        | ENRS.T  |        |        |        |  |
| 0x88 |                            | PWRPF.A | PWRPF.B       |                | PWRPF.C       | PWRPF.T |        |        |        |  |
| 0x89 |                            | PWRQF.A | PWRQF.B       |                | PWRQF.C       | PWRQF.T |        |        |        |  |
| 0x8A |                            | PWRSF.A | PWRSF.B       |                | PWRSF.C       | PWRSF.T |        |        |        |  |
| 0x8B |                            | ENRSF.A | ENRSF.B       |                | ENRSF.C       | ENRSF.T |        |        |        |  |
| 0x8C |                            | ENRP.A  | ENRP.B        |                | ENRP.C        | ENRP.T  |        |        |        |  |
| 0x8D |                            | ENRQ.A  | ENRQ.B        |                | ENRQ.C        | ENRQ.T  |        |        |        |  |
| 0x8E |                            | ENRPF.A | ENRPF.B       |                | ENRPF.C       | ENRPF.T |        |        |        |  |
| 0x8F |                            | ENRQF.A | ENRQF.B       |                | ENRQF.C       | ENRQF.T |        |        |        |  |
|      | SPECIAL FUNCTION REGISTERS |         |               |                |               |         |        |        |        |  |
| 0xC0 | DSPVER                     | TEMP_C  | ENTER<br>STOP | ENTER<br>LOWPM | EXIT<br>LOWPM |         |        |        |        |  |

Note: All virtual registers are read-only.

#### RAM-Based Registers

The RAM-based registers contain both operating parameters and measurement results. They are divided into a number of categories that are described in the following sections.

### General Operating Registers Global Status Register (STATUS) (0x000)

| Bit:   | 7 | 6     | 5    | 4    | 3      | 2      | 1      | 0      |
|--------|---|-------|------|------|--------|--------|--------|--------|
| Name:  | _ | CROFF | PORF | WDTR | PHSEQI | PHSEQV | REVCFQ | REVCFP |
| Reset: | 0 | 0     | 0    | 0    | 0      | 0      | 0      | 0      |

This register contains bits that reflect the global status of the device.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                                                           |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | _      | Reserved.                                                                                                                                                                                                                                          |
| 6   | CROFF  | When set, the high-frequency crystal has failed and the MAXQ3183 is operating from its internal ring oscillator. Under these circumstances, energy accumulation is not accurate and the SPI bus does not operate at full speed.                    |
| 5   | PORF   | When set, the last reset was due to power-on-reset. Host should clear this bit to allow the next POR detection.                                                                                                                                    |
| 4   | WDTR   | When set, the last reset was caused by expired watchdog. The bit should be cleared (set to 0) by the host to allow the next watchdog reset detection.                                                                                              |
| 3   | PHSEQI | 0 = The sequence of currents presented to the inputs is (-A-B-C-). 1 = The sequence of currents presented to the inputs is (-A-C-B-).                                                                                                              |
| 2   | PHSEQV | 0 = The sequence of voltages presented to the voltage inputs is (-A-B-C-). 1 = The sequence of voltages presented to the voltage inputs is reversed (-A-C-B-). This bit is meaningful only for connection systems that include all three voltages. |
| 1   | REVCFQ | 0 = The quantity being output on the CFQ pin is positive (direct).<br>1 = The quantity being output on the CFQ pin is negative (reverse).                                                                                                          |
| 0   | REVCFP | 0 = The quantity being output on the CFP pin is positive (direct).<br>1 = The quantity being output on the CFP pin is negative (reverse).                                                                                                          |

#### Operating Mode Register 0 (OPMODE0) (0x001)

| Bit:   | 7 | 6 | 5 | 4      | 3     | 2      | 1     | 0 |
|--------|---|---|---|--------|-------|--------|-------|---|
| Name:  | _ | _ | _ | EXTCLK | SWRES | DSPDIS | LOWPM | _ |
| Reset: | 0 | 0 | 0 | 0      | 0     | 0      | 0     | 0 |

| BIT    | NAME   | FUNCTION                                                                                                                                                                                                                                                                                                                                |
|--------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5, 0 | _      | Reserved.                                                                                                                                                                                                                                                                                                                               |
| 4      | EXTCLK | When set, the high-frequency crystal oscillator is disabled and the XTAL1 pin is configured to be a clock input for the device. This is used when it is desired to operate multiple devices from the same clock source for purposes of maintaining synchronization.                                                                     |
| 3      | SWRES  | When set, forces the internal software to restart from the reset vector. This has the same effect as a power-on reset, but does not specifically reset any hardware peripherals. This bit is automatically cleared after the reset.                                                                                                     |
| 2      | DSPDIS | When set, disables the signal processing software routines. The CPU continues to run at full speed, but only to perform supervisory functions (such as servicing the SPI port).                                                                                                                                                         |
| 1      | LOWPM  | When set, causes the CPU to switch its clock source from the external crystal to an internal ring oscillator that operates at a nominal frequency of 1MHz. In this mode, the CPU continues to run, but the host must reconfigure the parameters configured for crystal operation (such as filter settings, timeouts, and pulse widths). |

#### **Operating Mode Register 1 (OPMODE1) (0x002)**

| Bit:   | 7 | 6 | 5 | 4 | 3     | 2     | 1 | 0 |
|--------|---|---|---|---|-------|-------|---|---|
| Name:  | _ |   |   | _ | CRCEN | POPOL |   | _ |
| Reset: | 0 | 0 | 0 | 0 | 0     | 0     | 0 | 0 |

| BIT      | NAME  | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4, 1:0 | _     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3        | CRCEN | If set, a 1-byte CRC is appended to the end of each SPI read and is expected at the end of each SPI write. See the <i>SPI Communications Protocol</i> section for details about how to use the CRC byte for error checking on the SPI bus.                                                                                                                                                                                                                                                        |
| 2        | POPOL | This bit sets the polarity of the output pulse generators. If clear, the pulse outputs are active low; that is, they remain in the high state until a pulse event occurs, at which time they switch low for one pulse-width interval before reverting to the high state. If set, the pulse outputs are active high; that is, they remain in the low state until a pulse event occurs, at which time they switch to the high state for one pulse-width interval before reverting to the low state. |

#### Operating Mode Register 2 (OPMODE2) (0x003)

| Bit:   | 7 | 6     | 5     | 4    | 3 | 2   | 1   | 0      |
|--------|---|-------|-------|------|---|-----|-----|--------|
| Name:  | _ | DHARA | DFUNA | DFUN | _ | WIR | SYS | APPSEL |
| Reset: | 0 | 0     | 0     | 0    | 0 | 0   | 0   | 0      |

| BIT  | NAME   | FUNCTION                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7, 3 | _      | Reserved.                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 6    | DHARA  | set by the host software, the host must establish the operating frequency of thi the MAXQ3183 automatically determine                                                                                                                               | When set, disables automatic determination of the filter parameters for the harmonic filter coefficient. If set by the host software, the host must set a value in the A1HARM filter coefficient register to establish the operating frequency of this filter if harmonic-mode calculations are used. When cleared, the MAXQ3183 automatically determines the value of the harmonic filter coefficient based on the measured line frequency and the harmonic-order requested (AUX_CFG.ORDH).                       |  |  |  |  |  |
| 5    | DFUNA  | set by the host software, the host must the operating frequency of this filter if fu                                                                                                                                                                | Then set, disables automatic determination of the filter parameters for the fundamental-mode filter. If set by the host software, the host must set a value in the A1FUND filter coefficient register to establish the operating frequency of this filter if fundamental-mode calculations are used. When clear, the AXQ3183 automatically determines the value of the fundamental-mode filter coefficient based on the leasured line frequency.                                                                   |  |  |  |  |  |
| 4    | DFUN   | information about power and energy that from any harmonics that could be presented but allows the MAXQ3183 to calculate                                                                                                                             | When set, fundamental-mode calculations are disabled. Fundamental-mode calculations provide information about power and energy that are consumed only at the fundamental line frequency apart from any harmonics that could be present. Setting this bit disables all fundamental frequency registers but allows the MAXQ3183 to calculate other parameters at a higher rate. Set this bit when (1) fundamental mode values do not need to be read, and (2) R_ADCRATE needs to be reduced below its default value. |  |  |  |  |  |
| 2:1  | WIRSYS | These bits select the coefficient used in calculating apparent power. 00 = 1-phase, 3-wire (1P3W), or 3-phase, 4-wire (3P4W) (C = 1) 01 = 3-phase, 3-wire (3P3W) (C = $\sqrt{3}/2$ ) 10 = three voltages, three currents (3V3A) (C = $\sqrt{3}/3$ ) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|      |        | 3P3W Wiring (01)                                                                                                                                                                                                                                    | V <sub>CB</sub>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |

#### **Operating Mode Register 2 (OPMODE2) (0x003) (continued)**

| BIT | NAME   |                                                                                                                                                         | FUNCTION                                                                                                                               |  |  |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|
|     |        | 3P4W Wiring (00)                                                                                                                                        | V <sub>B</sub> N <sub>D</sub> |  |  |
| 2:1 | WIRSYS | 3V3A (10)                                                                                                                                               | V <sub>AB</sub> V <sub>AC</sub> V <sub>BC</sub>                                                                                        |  |  |
|     |        | 1P3W (00)                                                                                                                                               | V <sub>AN</sub> V <sub>BN</sub>                                                                                                        |  |  |
|     |        | Selects the mechanism to use for calculating apparent power.                                                                                            |                                                                                                                                        |  |  |
| 0   | APPSEL | 0: S = V <sub>RMS</sub> × I <sub>RMS</sub> Apparent power is calculated by multiplying, on a per-DSP cycle basis product of the RMS volts and RMS amps. |                                                                                                                                        |  |  |
|     |        | 1: $S = \sqrt{P^2 + Q^2}$ Apparent power is calculated by finding the length of the power vector                                                        |                                                                                                                                        |  |  |

### Global Interrupt Registers Interrupt Request Flag Register (IRQ\_FLAG) (0x004)

| Bit:   | 15    | 14     | 13   | 12   | 11      | 10   | 9     | 8    |
|--------|-------|--------|------|------|---------|------|-------|------|
| Name:  | DSPOR | DSPRDY | DCHR | DCHA | NOZX    | UV   | OV    | OC   |
| Reset: | 0     | 0      | 0    | 0    | 0       | 0    | 0     | 0    |
|        |       |        |      |      |         |      |       |      |
| Bit:   | 7     | 6      | 5    | 4    | 3       | 2    | 1     | 0    |
| Name:  | _     | _      | _    | _    | ISUMOVF | EOVF | CHSCH | PWRF |
| Reset: | 0     | 0      | 0    | 0    | 0       | 0    | 0     | 0    |

The interrupt request flag register contains bits that indicate the reason the  $\overline{IRQ}$  pin has become active. The active bit must be cleared by the host to avoid continuing firing of the interrupt by the MAXQ3183.

| BIT | NAME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | DSPOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | When set, the DSP was unable to complete processing one cycle when another cycle was due to begin. This indicates that the R_ADCRATE is set too low, and that samples are arriving more quickly than they can be processed. Either increase the value of the R_ADCRATE register or set the DFUN bit in the OPMODE2 register to disable fundamental frequency calculations to reduce the load on the DSP. |
| 14  | DSPRDY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Set when the DSP cycle completes.                                                                                                                                                                                                                                                                                                                                                                        |
| 13  | DCHR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | When set, the direction of reactive energy flow has changed (that is, from capacitive to inductive or from inductive to capacitive).                                                                                                                                                                                                                                                                     |
| 12  | DCHA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | When set, the direction of real energy flow has changed (that is, from toward the load to away from the load, or from away from the load to toward the load).                                                                                                                                                                                                                                            |
| 11  | NOZX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | When set, the MAXQ3183 has failed to detect zero crossings on one or more voltage channels in one complete DSP cycle.                                                                                                                                                                                                                                                                                    |
| 10  | UV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | When set, the absolute instantaneous voltage level in one or more voltage channels failed to exceed the trip level set in the UVLVL (Undervoltage Level) register for one DSP cycle.                                                                                                                                                                                                                     |
| 9   | OV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | When set, the absolute instantaneous voltage level in one or more voltage channels has exceeded the trip level set in the OVLVL (Overvoltage Level) register.                                                                                                                                                                                                                                            |
| 8   | OC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | When set, the absolute instantaneous current in one or more current channels has exceeded the trip level set in the OCLVL (Overcurrent Level) register.                                                                                                                                                                                                                                                  |
| 7:4 | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                |
| 3   | ISUMOVF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | When set, the vector sum of currents (3 or 4) exceeds the threshold.                                                                                                                                                                                                                                                                                                                                     |
| 2   | EOVF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | When set, one or more energy accumulators have an MSB overflow condition.                                                                                                                                                                                                                                                                                                                                |
| 1   | When set, indicates a change of the CHKSUM. The CHKSUM is computed over the configuration 1  CHSCH  CHSCH |                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0   | PWRF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | When set, a power-supply failure is imminent and the supervisory processor should begin taking steps to save its state and prepare for a loss of power.                                                                                                                                                                                                                                                  |

#### Interrupt Mask Register (IRQ\_MASK) (0x006)

| Bit:   | 15     | 14      | 13    | 12    | 11    | 10    | 9      | 8     |
|--------|--------|---------|-------|-------|-------|-------|--------|-------|
| Name:  | EDSPOR | EDSPRDY | EDCHR | EDCHA | ENOZX | EUV   | EOV    | EOC   |
| Reset: | 0      | 0       | 0     | 0     | 0     | 0     | 0      | 0     |
|        |        |         |       |       |       |       |        |       |
| Bit:   | 7      | 6       | 5     | 4     | 3     | 2     | 1      | 0     |
| Name:  | _      | _       | _     | _     | EISUM | EEOVF | ECHSCH | EPWRF |
| Reset: | 0      | 0       | 0     | 0     | 0     | 0     | 0      | 0     |

| BIT | NAME    | FUNCTION                                                                   |
|-----|---------|----------------------------------------------------------------------------|
| 15  | EDSPOR  | When set, the DSPOR flag causes the $\overline{IRQ}$ pin to become active. |
| 14  | EDSPRDY | When set, the DSPRDY flag causes the IRQ pin to become active.             |
| 13  | EDCHR   | When set, the DCHR flag causes the IRQ pin to become active.               |
| 12  | EDCHA   | When set, the DCHA flag causes the IRQ pin to become active.               |
| 11  | ENOZX   | When set, the NOZX flag causes the IRQ pin to become active.               |
| 10  | EUV     | When set, the UV flag causes the IRQ pin to become active.                 |
| 9   | EOV     | When set, the OV flag causes the IRQ pin to become active.                 |
| 8   | EOC     | When set, the OC flag causes the IRQ pin to become active.                 |
| 7:4 | _       | Reserved.                                                                  |
| 3   | EISUM   | When set, the ISUMOVF flag causes the IRQ pin to become active.            |
| 2   | EEOVF   | When set, the EOVF flag causes the IRQ pin to become active.               |
| 1   | ECHSCH  | When set, the CHSCH flag enables the IRQ pin to become active.             |
| 0   | EPWRF   | When set, the PWRF flag causes the IRQ pin to become active.               |

|        |   |       |     |             | M          | eter Puls | se Config | guration   |
|--------|---|-------|-----|-------------|------------|-----------|-----------|------------|
|        |   |       | Pu  | ılse Config | guration—( | CFP Outpu | t (PLSCFG | 1) (0x01E) |
| Bit:   | 7 | 6     | 5   | 4           | 3          | 2         | 1         | 0          |
| Name:  |   | QNSEL |     |             |            |           | PHASEB    | PHASEA     |
| Reset: |   |       | 0x0 |             |            | 0         | 0         | 0          |

This register selects which phases are included in the CFP pulse output and also selects which quantity is accumulated to drive the pulse output.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3 | QNSEL  | CFP Pulse Output Source Select. This five-bit field determines what meter value will be accumulated in each of the phases to produce the CFP pulse output. All other values are reserved.  00000 = Net real energy 00001 = Absolute real energy 00010 = Net reactive energy 00011 = Absolute reactive energy 00100 = Apparent energy 00110 = I <sub>RMS</sub> 00111 = V <sub>RMS</sub> 01100 = Real energy delivered to load 01001 = Real energy delivered to line 01010 = Reactive energy, quadrant I 01011 = Reactive energy, quadrant III 01100 = Reactive energy, quadrant IIII 01101 = Reactive energy, quadrant IV |
| 2   | PHASEC | CFP Phase C Inclusion. When this bit is set, phase C is included in CFP pulse generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1   | PHASEB | CFP Phase B Inclusion. When this bit is set, phase B is included in CFP pulse generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0   | PHASEA | CFP Phase A Inclusion. When this bit is set, phase A is included in CFP pulse generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### Pulse Configuration—CFQ Output (PLSCFG2) (0x01F)

| Bit:   | 7 | 6 | 5     | 4      | 3      | 2      | 1 | 0 |
|--------|---|---|-------|--------|--------|--------|---|---|
| Name:  |   |   | QNSEL | PHASEC | PHASEB | PHASEA |   |   |
| Reset: |   |   | 0x0   |        |        | 0      | 0 | 0 |

This register selects which phases are included in the CFQ pulse output and also selects which quantity is accumulated to drive the pulse output.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:3 | QNSEL  | CFQ Pulse Output Source Select. This five-bit field determines what meter value is accumulated in each of the phases to produce the CFQ pulse output. All other values are reserved.  00000 = Net real energy 00001 = Absolute real energy 00010 = Net reactive energy 00110 = Absolute reactive energy 00100 = Apparent energy 00110 = IRMS 00111 = VRMS 01000 = Real energy delivered to load 01001 = Real energy delivered to line 01010 = Reactive energy, quadrant II 01101 = Reactive energy, quadrant III 01101 = Reactive energy, quadrant III |
| 2   | PHASEC | CFQ Phase C Inclusion. When this bit is set, phase C is included in CFQ pulse generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1   | PHASEB | CFQ Phase B Inclusion. When this bit is set, phase B is included in CFQ pulse generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0   | PHASEA | CFQ Phase A Inclusion. When this bit is set, phase A is included in CFQ pulse generation.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### CFP Pulse Width (PLS1\_WD) (0x020)

| Bit:   | 15                        | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
|--------|---------------------------|----|----|----|----|----|---|---|--|
| Name:  | CFP Pulse-Width High Byte |    |    |    |    |    |   |   |  |
| Reset: | 0x00                      |    |    |    |    |    |   |   |  |
|        |                           |    |    |    |    |    |   |   |  |
| Bit:   | 7                         | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |
| Name:  | CFP Pulse-Width Low Byte  |    |    |    |    |    |   |   |  |
| Reset: | 0x9C                      |    |    |    |    |    |   |   |  |

This register designates the width of the CFP pulse, that is, the duration of the period that the CFP pulse is in the active state. This value is given in ADC frame times (about 360µs). The default value of 0x9C (156 decimal) provides a pulse width of about 50ms.

|        | CFP Pulse Threshold (THR1) (0x022) |    |    |    |    |    |    |    |  |  |
|--------|------------------------------------|----|----|----|----|----|----|----|--|--|
| Bit:   | 31                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |  |
| Name:  | THR1 Byte 3                        |    |    |    |    |    |    |    |  |  |
| Reset: | 0x00                               |    |    |    |    |    |    |    |  |  |
|        |                                    |    |    |    |    |    |    |    |  |  |
| Bit:   | 23                                 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |  |
| Name:  | THR1 Byte 2                        |    |    |    |    |    |    |    |  |  |
| Reset: | 0x10                               |    |    |    |    |    |    |    |  |  |
|        |                                    |    |    |    |    |    |    |    |  |  |
| Bit:   | 15                                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
| Name:  | THR1 Byte 1                        |    |    |    |    |    |    |    |  |  |
| Reset: | 0x00                               |    |    |    |    |    |    |    |  |  |
|        |                                    |    |    |    |    |    |    |    |  |  |
| Bit:   | 7                                  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
| Name:  | THR1 Byte 0                        |    |    |    |    |    |    |    |  |  |
| Reset: | 0x00                               |    |    |    |    |    |    |    |  |  |

This register designates the threshold of the CFP pulse. This value is used to set the meter constant for the CFP pulse output. When the CFP pulse accumulator exceeds the value set in this register, the CFP pulse output is activated and the CFP pulse accumulator is reduced by the amount in this register.

|        |                           |    |    |    | CFQ P | ulse Width | n (PLS2_W | D) (0x026) |  |  |
|--------|---------------------------|----|----|----|-------|------------|-----------|------------|--|--|
| Bit:   | 15                        | 14 | 13 | 12 | 11    | 10         | 9         | 8          |  |  |
| Name:  | CFQ Pulse-Width High Byte |    |    |    |       |            |           |            |  |  |
| Reset: | 0x00                      |    |    |    |       |            |           |            |  |  |
|        |                           |    |    |    |       |            |           |            |  |  |
| Bit:   | 7                         | 6  | 5  | 4  | 3     | 2          | 1         | 0          |  |  |
| Name:  | CFQ Pulse-Width Low Byte  |    |    |    |       |            |           |            |  |  |
| Reset: | 0x9C                      |    |    |    |       |            |           |            |  |  |
|        | •                         |    |    |    |       |            |           |            |  |  |

This register designates the width of the CFQ pulse; that is, the duration of the period that the CFQ pulse is in the active state. This value is given in ADC frame times (about 360µs). The default value of 0x9C (156 decimal) provides a pulse width of about 50ms.

#### CFQ Pulse Threshold (THR2) (0x028)

| Bit:   | 31 | 30 | 29 | 28   | 27     | 26 | 25 | 24 |
|--------|----|----|----|------|--------|----|----|----|
| Name:  |    |    |    | THR2 | Byte 3 |    |    |    |
| Reset: |    |    |    | 0x   | 00     |    |    |    |
|        |    |    |    |      |        |    |    |    |
| Bit:   | 23 | 22 | 21 | 20   | 19     | 18 | 17 | 16 |
| Name:  |    |    |    | THR2 | Byte 2 |    |    |    |
| Reset: |    |    |    | 0x   | 10     |    |    |    |
|        |    |    |    |      |        |    |    |    |
| Bit:   | 15 | 14 | 13 | 12   | 11     | 10 | 9  | 8  |
| Name:  |    |    |    | THR2 | Byte 1 |    |    |    |
| Reset: |    |    |    | 0x   | 00     |    |    |    |
|        |    |    |    |      |        |    |    |    |
| Bit:   | 7  | 6  | 5  | 4    | 3      | 2  | 1  | 0  |
| Name:  |    |    |    | THR2 | Byte 0 |    |    |    |
| Reset: |    |    |    | 0x   | 00     |    |    |    |
|        |    |    |    |      |        |    |    |    |

This register designates the threshold of the CFQ pulse. This value is used to set the meter constant for the CFQ pulse output. When the CFQ pulse accumulator exceeds the value set in this register, the CFQ pulse output is activated and the CFQ pulse accumulator is reduced by the amount in this register.

### Calibration Registers

### Current Gain, Phase X = A/B/C/N (X.I\_GAIN) (A: 0x130, B: 0x21C, C: 0x308, N: 0x12E)

| Bit:   | 15                                 | 14   | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
|--------|------------------------------------|------|----|----|----|----|---|---|--|--|
| Name:  | Current Gain Coefficient High Byte |      |    |    |    |    |   |   |  |  |
| Reset: |                                    | 0x40 |    |    |    |    |   |   |  |  |
|        |                                    |      |    |    |    |    |   |   |  |  |
| Bit:   | 7                                  | 6    | 5  | 4  | 3  | 2  | 1 | 0 |  |  |
| Name:  | Current Gain Coefficient Low Byte  |      |    |    |    |    |   |   |  |  |
| Reset: | 0x00                               |      |    |    |    |    |   |   |  |  |

This register contains gain coefficient for phase X current channel. The raw values are taken from the selected measurement quantity and scaled by the factor:

$$\frac{\text{X.I\_GAIN}}{2^{14}}$$

**Note:** Bit 15 of this register must be set to zero for correct operation.

#### Voltage Gain, Phase X = A/B/C (X.V\_GAIN) (A: 0x132, B: 0x21E, C: 0x30A)

| Bit:   | 15                                | 14   | 13 | 12             | 11              | 10  | 9 | 8 |  |
|--------|-----------------------------------|------|----|----------------|-----------------|-----|---|---|--|
| Name:  |                                   |      | Vo | Itage Gain Coe | fficient High B | yte |   |   |  |
| Reset: |                                   | 0x40 |    |                |                 |     |   |   |  |
|        |                                   |      |    |                |                 |     |   |   |  |
| Bit:   | 7                                 | 6    | 5  | 4              | 3               | 2   | 1 | 0 |  |
| Name:  | Voltage Gain Coefficient Low Byte |      |    |                |                 |     |   |   |  |
| Reset: | 0x00                              |      |    |                |                 |     |   |   |  |

This register contains gain coefficient for phase X voltage channel. The raw values are taken from the selected measurement quantity and scaled by the factor:

$$\frac{\text{X.V\_GAIN}}{2^{14}}$$

Note: Bit 15 of this register must be set to zero for correct operation.

### Energy Gain, Phase X = A/B/C (X.E\_GAIN) (A: 0x134, B: 0x220, C: 0x30C)

| Bit:   | 15                                | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
|--------|-----------------------------------|----|----|----|----|----|---|---|--|
| Name:  | Energy Gain Coefficient High Byte |    |    |    |    |    |   |   |  |
| Reset: | 0x40                              |    |    |    |    |    |   |   |  |
|        |                                   |    |    |    |    |    |   |   |  |
| Bit:   | 7                                 | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |
| Name:  | Energy Gain Coefficient Low Byte  |    |    |    |    |    |   |   |  |
| Reset: | 0x00                              |    |    |    |    |    |   |   |  |

This register contains gain coefficient for phase X energy. The raw values are taken from the selected measurement quantity and scaled by the factor:

$$\frac{X.E\_GAIN}{2^{14}}$$

Note: Bit 15 of this register must be set to zero for correct operation.

#### Phase-Angle Compensation, High Range, Phase X = A/B/C (X.PA0) (A: 0x13E, B: 0x22A, C: 0x316)

| Bit:   | 15                          | 14 | 13 | 12            | 11              | 10 | 9 | 8 |  |
|--------|-----------------------------|----|----|---------------|-----------------|----|---|---|--|
| Name:  |                             |    |    | Phase-Angle O | ffset High Byte |    |   |   |  |
| Reset: | 0x00                        |    |    |               |                 |    |   |   |  |
|        |                             |    |    |               |                 |    |   |   |  |
| Bit:   | 7                           | 6  | 5  | 4             | 3               | 2  | 1 | 0 |  |
| Name:  | Phase-Angle Offset Low Byte |    |    |               |                 |    |   |   |  |
| Reset: | 0x00                        |    |    |               |                 |    |   |   |  |

This signed register contains the angle as a fraction of one radian to add to the measured phase angle when the measured current is above the value given in I1THR. This signed value ranges from -0.5 radian (at a value of 0x8000) to + $(0.5 - 2^{-16})$  radian (at a value of 0x7FFF).

#### Phase-Angle Compensation, Medium Range, Phase X = A/B/C (X.PA1) (A: 0x140, B: 0x22C, C: 0x318)

| 15                          | 14 | 13 | 12            | 11                                         | 10                                                                         | 9                                                                            | 8                                                                              |  |  |
|-----------------------------|----|----|---------------|--------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|
|                             |    |    | Phase-Angle O | ffset High Byte                            | •                                                                          |                                                                              |                                                                                |  |  |
| 0x00                        |    |    |               |                                            |                                                                            |                                                                              |                                                                                |  |  |
|                             |    |    |               |                                            |                                                                            |                                                                              |                                                                                |  |  |
| 7                           | 6  | 5  | 4             | 3                                          | 2                                                                          | 1                                                                            | 0                                                                              |  |  |
| Phase-Angle Offset Low Byte |    |    |               |                                            |                                                                            |                                                                              |                                                                                |  |  |
| 0x00                        |    |    |               |                                            |                                                                            |                                                                              |                                                                                |  |  |
|                             | 7  |    | 7 6 5         | Phase-Angle O  Oxi  7 6 5 4  Phase-Angle O | Phase-Angle Offset High Byte  0x00  7 6 5 4 3  Phase-Angle Offset Low Byte | Phase-Angle Offset High Byte  0x00  7 6 5 4 3 2  Phase-Angle Offset Low Byte | Phase-Angle Offset High Byte  0x00  7 6 5 4 3 2 1  Phase-Angle Offset Low Byte |  |  |

This signed register contains the angle, as a fraction of one radian, to add to the measured phase angle when the measured current is between the values given in I1THR and I2THR. This signed value ranges from -0.5 radian (at a value of 0x8000) to  $+(0.5 - 2^{-16})$  radian (at a value of 0x7FFF).

#### Phase-Angle Compensation, Low Range, Phase X = A/B/C (X.PA2) (A: 0x142, B: 0x22E, C: 0x31A)

| Bit:   | 15                          | 14 | 13 | 12            | 11              | 10 | 9 | 8 |  |
|--------|-----------------------------|----|----|---------------|-----------------|----|---|---|--|
| Name:  |                             |    |    | Phase-Angle O | ffset High Byte |    |   |   |  |
| Reset: | 0x00                        |    |    |               |                 |    |   |   |  |
|        |                             |    |    |               |                 |    |   |   |  |
| Bit:   | 7                           | 6  | 5  | 4             | 3               | 2  | 1 | 0 |  |
| Name:  | Phase-Angle Offset Low Byte |    |    |               |                 |    |   |   |  |
| Reset: | 0x00                        |    |    |               |                 |    |   |   |  |

This signed register contains the angle, as a fraction of one radian, to add to the measured phase angle when the measured current is below the value given in I2THR. This signed value ranges from -0.5 radian (at a value of 0x8000) to  $+(0.5 - 2^{-16})$  radian (at a value of 0x7FFF).

### \_\_\_\_Limit Registers

|        |    |      |    |                | Over           | current Le | vel (OCLV | L) (0x044) |  |
|--------|----|------|----|----------------|----------------|------------|-----------|------------|--|
| Bit:   | 15 | 14   | 13 | 12             | 11             | 10         | 9         | 8          |  |
| Name:  |    |      |    | Overcurrent Le | evel High Byte |            |           |            |  |
| Reset: |    | 0xFF |    |                |                |            |           |            |  |
|        |    |      |    |                |                |            |           |            |  |
| Bit:   | 7  | 6    | 5  | 4              | 3              | 2          | 1         | 0          |  |
| Name:  |    |      |    | Overcurrent L  | evel Low Byte  |            |           |            |  |
| Reset: |    |      |    | 0×             | :FF            |            |           |            |  |

This register specifies the fraction of full-scale current that is declared to be an overcurrent condition. When X.IRMS exceeds this level for one DSP cycle, the OCF flag in the X.FLAGS register is set. If the OCM flag is set in the X.MASK register, setting the OCF flag will cause the interrupt bit OC to be set in the IRQ\_FLAG register. If the interrupt is enabled, the interrupt pin is driven active. Full scale is represented by 0x10000. The maximum value for this register is 0xFFFF.

#### Overvoltage Level (OVLVL) (0x046)

| Bit:   | 15                         | 14   | 13 | 12            | 11             | 10 | 9 | 8 |  |  |
|--------|----------------------------|------|----|---------------|----------------|----|---|---|--|--|
| Name:  |                            |      |    | Overvoltage L | evel High Byte |    |   |   |  |  |
| Reset: |                            | 0xFF |    |               |                |    |   |   |  |  |
|        |                            |      |    |               |                |    |   |   |  |  |
| Bit:   | 7                          | 6    | 5  | 4             | 3              | 2  | 1 | 0 |  |  |
| Name:  | Overvoltage Level Low Byte |      |    |               |                |    |   |   |  |  |
| Reset: | 0xFF                       |      |    |               |                |    |   |   |  |  |

This register specifies the fraction of full-scale voltage that is declared to be an overvoltage condition. When X.VRMS exceeds this level for one DSP cycle, the OVF flag in the X.FLAGS register is set. If the OVM flag is set in the X.MASK register, setting the OVF flag will cause the interrupt bit OV to be set in the IRQ\_FLAG register. If the interrupt is enabled, the interrupt pin is driven active. Full scale is represented by 0x10000. The maximum value for this register is 0xFFFF.

#### **Undervoltage Level (UVLVL) (0x048)**

| Bit:   | 15                           | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
|--------|------------------------------|----|----|----|----|----|---|---|--|
| Name:  | Undervoltage Level High Byte |    |    |    |    |    |   |   |  |
| Reset: | 0x00                         |    |    |    |    |    |   |   |  |
|        |                              |    |    |    |    |    |   | _ |  |
| Bit:   | 7                            | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |
| Name:  | Undervoltage Level Low Byte  |    |    |    |    |    |   |   |  |
| Reset: | 0x00                         |    |    |    |    |    |   |   |  |

This register specifies the fraction of full-scale voltage below which an undervoltage condition is declared. When X.VRMS falls below this level for one DSP cycle, the UVF flag in the X.FLAGS register is set. If the UVM flag is set in the X.MASK register, setting the UVF flag will cause the interrupt bit UV to be set in the IRQ\_FLAG register. If the interrupt is enabled, the interrupt pin is driven active. Full scale is represented by 0x10000. The maximum value for this register is 0xFFFF.

#### No-Load Level (NOLOAD) (0x04A)

| Bit:   | 15                      | 14   | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
|--------|-------------------------|------|----|----|----|----|---|---|--|--|
| Name:  | No-Load Level High Byte |      |    |    |    |    |   |   |  |  |
| Reset: |                         | 0x00 |    |    |    |    |   |   |  |  |
|        |                         |      |    |    |    |    |   |   |  |  |
| Bit:   | 7                       | 6    | 5  | 4  | 3  | 2  | 1 | 0 |  |  |
| Name:  | No-Load Level Low Byte  |      |    |    |    |    |   |   |  |  |
| Reset: | 0x03                    |      |    |    |    |    |   |   |  |  |

This register specifies the fraction of full-scale current below which a no-load condition is declared. When X.IRMS falls below this level, the MAXQ3183 no longer accumulates power for phase X. Full scale is represented by 0x10000. The maximum value for this register is 0xFFFF.

#### **Current Vector Sum Threshold (ISUMLVL) (0x054)**

| Bit:   | 15                            | 14 | 13 | 12             | 11            | 10 | 9 | 8 |  |
|--------|-------------------------------|----|----|----------------|---------------|----|---|---|--|
| Name:  |                               |    | V  | ector Sum Thre | shold High By | te |   |   |  |
| Reset: | 0xFF                          |    |    |                |               |    |   |   |  |
|        |                               |    |    |                |               |    |   |   |  |
| Bit:   | 7                             | 6  | 5  | 4              | 3             | 2  | 1 | 0 |  |
| Name:  | Vector Sum Threshold Low Byte |    |    |                |               |    |   |   |  |
| Reset: | 0xFF                          |    |    |                |               |    |   |   |  |
|        |                               |    |    |                |               |    |   | _ |  |

This register specifies the threshold value for the vector sum (of three phase currents or three phase currents plus the neutral current, configurable in the AUX\_CFG register) as a fraction of the full-scale current. When the vector sum (RMS) value exceeds this threshold value in one DSP cycle, the ISUMOVF flag in the IRQ\_FLAG register is set. If the IRQ\_MASK.EISUM bit is set, the interrupt pin is driven active. The host must clear the interrupt flag. Full scale is represented by 0x10000. The maximum value allowed is 0xFFFF.

### **Phase Status Registers**

#### Interrupt Flags, Phase X = A/B/C (X.FLAGS) (A: 0x144, B: 0x230, C: 0x31C)

| Bit:   | 7 | 6 | 5     | 4     | 3     | 2   | 1   | 0   |
|--------|---|---|-------|-------|-------|-----|-----|-----|
| Name:  |   | _ | DCHRF | DCHAF | NOZXF | UVF | OVF | OCF |
| Reset: | 0 | 0 | 0     | 0     | 0     | 0   | 0   | 0   |

The X.FLAGS register contains condition flags that relate to the function of phase X (A/B/C) measurements. Once set, these bits can be cleared only by the host.

| BIT | NAME  | FUNCTION                                                                                                                                                                                                                                              |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | _     | Reserved.                                                                                                                                                                                                                                             |
| 5   | DCHRF | Reactive Energy Direction Change. Set when the direction of reactive power flow changes (from capacitive to inductive or from inductive to capacitive). If the DCHRM bit is set, this bit sets the DCHR flag in the IRQ_FLAG register.                |
| 4   | DCHAF | Real Energy Direction Change. Set when the direction of real power flow changes (from toward the load to toward the line, or from toward the line to toward the load). If the DCHAM bit is set, this bit sets the DCHA flag in the IRQ_FLAG register. |
| 3   | NOZXF | No-Zero Crossing. Set when the voltage waveform in phase X fails to exhibit a zero crossing during one DSP cycle. If the NOZXM bit is set, this bit sets the NOZX flag in the IRQ_FLAG register.                                                      |
| 2   | UVF   | Undervoltage. Set when the RMS voltage in phase X falls below the undervoltage threshold set in UVLVL. If the UVM bit is set, this bit sets the UV flag in the IRQ_FLAG register.                                                                     |
| 1   | OVF   | Overvoltage. Set when the RMS voltage in phase X exceeds the overvoltage threshold set in OVLVL. If the OVM bit is set, this bit sets the OV flag in the IRQ_FLAG register.                                                                           |
| 0   | OCF   | Overcurrent. Set when the RMS current in phase X exceeds the overcurrent threshold set in OCLVL. If the OCM bit is set, this bit sets the OC flag in the IRQ_FLAG register.                                                                           |

### Interrupt Mask, Phase X = A/B/C (X.MASK) (A: 0x145, B: 0x231, C: 0x31D)

| Bit:   | 7     | 6     | 5     | 4     | 3     | 2   | 1   | 0   |
|--------|-------|-------|-------|-------|-------|-----|-----|-----|
| Name:  | DIR_R | DIR_A | DCHRM | DCHAM | NOZXM | UVM | OVM | OCM |
| Reset: | 0     | 0     | 0     | 0     | 0     | 0   | 0   | 0   |

| BIT | NAME  | FUNCTION                                                                                                                                                |
|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | DIR_R | Reactive Energy Direction Status 0 = positive 1 = negative                                                                                              |
| 6   | DIR_A | Active Energy Direction Status 0 = positive 1 = negative                                                                                                |
| 5   | DCHRM | Reactive Energy Direction Change Mask. If set, a change in reactive power direction on phase X causes the DCHR flag in the IRQ_FLAG register to be set. |
| 4   | DCHAM | Real Energy Direction Change Mask. If set, a change in real power direction on phase X causes the DCHA flag in the IRQ_FLAG register to be set.         |
| 3   | NOZXM | No-Zero Crossing Mask. If set, a no-zero crossing on phase X causes the NOZX flag in the IRQ_FLAG register to be set.                                   |
| 2   | UVM   | Undervoltage Mask. If set, an undervoltage condition on phase X causes the UV flag in the IRQ_FLAG register to be set.                                  |
| 1   | OVM   | Overvoltage Mask. If set, an overvoltage condition on phase X causes the OV flag in the IRQ_FLAG register to be set.                                    |
| 0   | ОСМ   | Overcurrent Mask. If set, an overcurrent condition on phase X causes the OC flag in the IRQ_FLAG register to be set.                                    |

#### Energy Overflow Flags, Phase X = A/B/C (X.EOVER) (A: 0x146, B: 0x232, C: 0x31E)

| Bit:   | 7 | 6 | 5 | 4   | 3    | 2    | 1    | 0    |
|--------|---|---|---|-----|------|------|------|------|
| Name:  | _ | _ | _ | SOV | RNOV | RPOV | ANOV | APOV |
| Reset: | 0 | 0 | 0 | 0   | 0    | 0    | 0    | 0    |

These bits indicate that an overflow condition has occurred on an energy accumulator. An overflow condition is **not** an error condition. Rather, it simply indicates that the value in the energy accumulator could be smaller than the previous reading due to the overflow in the counter. To obtain the actual energy usage since the previous reading, 0x100000000 must be added to the difference. These bits, once set, can be cleared only by the host.

| BIT | NAME | FUNCTION                                                                               |
|-----|------|----------------------------------------------------------------------------------------|
| 7:5 | _    | Reserved.                                                                              |
| 4   | SOV  | When set, indicates an overflow condition on the apparent energy accumulator.          |
| 3   | RNOV | When set, indicates an overflow condition on the reactive negative energy accumulator. |
| 2   | RPOV | When set, indicates an overflow condition on the reactive positive energy accumulator. |
| 1   | ANOV | When set, indicates an overflow condition on the real negative energy accumulator.     |
| 0   | APOV | When set, indicates an overflow condition on the real positive energy accumulator.     |

\_\_\_\_\_\_\_/N/XI/N

|        |    |                          |    |    | Measurements |           |           |            |  |  |  |
|--------|----|--------------------------|----|----|--------------|-----------|-----------|------------|--|--|--|
|        |    |                          |    |    | Lin          | e Frequen | cy (LINEF | R) (0x062) |  |  |  |
| Bit:   | 15 | 14                       | 13 | 12 | 11           | 10        | 9         | 8          |  |  |  |
| Name:  |    | Line Frequency High Byte |    |    |              |           |           |            |  |  |  |
| Reset: |    |                          |    |    |              |           |           |            |  |  |  |
|        |    |                          |    |    |              |           |           |            |  |  |  |
| Bit:   | 7  | 6                        | 5  | 4  | 3            | 2         | 1         | 0          |  |  |  |
| Name:  |    | Line Frequency Low Byte  |    |    |              |           |           |            |  |  |  |
| Reset: |    |                          |    |    |              |           |           |            |  |  |  |

Line frequency, LSB = 0.001Hz.

#### Power Factor, Phase X = A/B/C (X.PF) (A: 0x1C6, B: 0x2B2, C: 0x39E)

| Bit:   | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
|--------|------------------------|----|----|----|----|----|---|---|--|--|
| Name:  | Power Factor High Byte |    |    |    |    |    |   |   |  |  |
| Reset: | 0x00                   |    |    |    |    |    |   |   |  |  |
|        |                        |    |    |    |    |    |   |   |  |  |
| Bit:   | 7                      | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |  |
| Name:  | Power Factor Low Byte  |    |    |    |    |    |   |   |  |  |
| Reset: | 0x00                   |    |    |    |    |    |   |   |  |  |

Power factor of phase A/B/C, LSB =  $1/2^{14}$ . Note that the power factors are signed integers, and a negative value indicates a reversed power flow direction.

#### RMS Voltage, Phase X = A/B/C (X.VRMS) (A: 0x1C8, B: 0x2B4, C: 0x3A0)

| Bit:  | 31                 | 30                 | 29 | 28        | 27        | 26 | 25 | 24 |  |  |  |
|-------|--------------------|--------------------|----|-----------|-----------|----|----|----|--|--|--|
| Name: |                    | RMS Voltage Byte 3 |    |           |           |    |    |    |  |  |  |
|       |                    |                    |    |           |           |    |    |    |  |  |  |
| Bit:  | 23                 | 22                 | 21 | 20        | 19        | 18 | 17 | 16 |  |  |  |
| Name: | RMS Voltage Byte 2 |                    |    |           |           |    |    |    |  |  |  |
|       |                    |                    |    |           |           |    |    |    |  |  |  |
| Bit:  | 15                 | 14                 | 13 | 12        | 11        | 10 | 9  | 8  |  |  |  |
| Name: |                    |                    |    | RMS Volta | ge Byte 1 |    |    |    |  |  |  |
|       |                    |                    |    |           |           |    |    |    |  |  |  |
| Bit:  | 7                  | 6                  | 5  | 4         | 3         | 2  | 1  | 0  |  |  |  |
| Name: |                    |                    |    | RMS Volta | ge Byte 0 |    |    |    |  |  |  |

This register provides the raw RMS voltage over the most recent DSP cycle, LSB = VFS/2<sup>24</sup>.

| RMS Current | t, Phase | X = A/B/C | (X.IRMS) ( | A: 0x1CC, l | B: 0x2B8 | , C: 0x3A4) |
|-------------|----------|-----------|------------|-------------|----------|-------------|
| 30          | 20       | 28        | 27         | 26          | 25       | 24          |

| Bit:  | 31                 | 30 | 29 | 28       | 27         | 26 | 25 | 24 |  |
|-------|--------------------|----|----|----------|------------|----|----|----|--|
| Name: |                    |    |    | RMS Curr | ent Byte 3 |    |    |    |  |
|       |                    |    |    |          |            |    |    |    |  |
| Bit:  | 23                 | 22 | 21 | 20       | 19         | 18 | 17 | 16 |  |
| Name: |                    |    |    | RMS Curr | ent Byte 2 |    |    |    |  |
|       |                    |    |    |          |            |    |    |    |  |
| Bit:  | 15                 | 14 | 13 | 12       | 11         | 10 | 9  | 8  |  |
| Name: |                    |    |    | RMS Curr | ent Byte 1 |    |    |    |  |
|       |                    |    |    |          |            |    |    |    |  |
| Bit:  | 7                  | 6  | 5  | 4        | 3          | 2  | 1  | 0  |  |
| Name: |                    |    |    | RMS Curr | ent Byte 0 |    |    |    |  |
| Name: | RMS Current Byte 0 |    |    |          |            |    |    |    |  |

This register provides the raw RMS current over the most recent DSP cycle, LSB =  $I_{FS}/2^{24}$ .

#### Energy, Real Positive, Phase X = A/B/C (X.EAPOS) (A: 0x1E8. B: 0x2D4. C: 0x3C0)

|       |                    |                    |    |           |           | <i></i> | -: UX :, | C. CACCO, |  |  |
|-------|--------------------|--------------------|----|-----------|-----------|---------|----------|-----------|--|--|
| Bit:  | 31                 | 30                 | 29 | 28        | 27        | 26      | 25       | 24        |  |  |
| Name: |                    | Real Energy Byte 3 |    |           |           |         |          |           |  |  |
|       |                    |                    |    |           |           |         |          |           |  |  |
| Bit:  | 23                 | 22                 | 21 | 20        | 19        | 18      | 17       | 16        |  |  |
| Name: | Real Energy Byte 2 |                    |    |           |           |         |          |           |  |  |
|       |                    |                    |    |           |           |         |          |           |  |  |
| Bit:  | 15                 | 14                 | 13 | 12        | 11        | 10      | 9        | 8         |  |  |
| Name: |                    |                    |    | Real Ener | gy Byte 1 |         |          |           |  |  |
|       |                    |                    |    |           |           |         |          |           |  |  |
| Bit:  | 7                  | 6                  | 5  | 4         | 3         | 2       | 1        | 0         |  |  |
| Name: |                    |                    |    | Real Ener | gy Byte 0 |         |          |           |  |  |

On every DSP cycle, the contents of the X.ACT register are tested, and, if positive, are added to this register. When this register overflows, the APOV bit in the X.EOVER register is set.

#### Energy, Real Negative, Phase X = A/B/C (X.EANEG) (A: 0x1EC, B: 0x2D8, C: 0x3C4)

|       |                    |                    |    |           |           | · · , | ,  |    |  |
|-------|--------------------|--------------------|----|-----------|-----------|-------|----|----|--|
| Bit:  | 31                 | 30                 | 29 | 28        | 27        | 26    | 25 | 24 |  |
| Name: |                    |                    |    | Real Ener | gy Byte 3 |       |    |    |  |
|       |                    |                    |    |           |           |       |    |    |  |
| Bit:  | 23                 | 22                 | 21 | 20        | 19        | 18    | 17 | 16 |  |
| Name: | Real Energy Byte 2 |                    |    |           |           |       |    |    |  |
|       |                    |                    |    |           |           |       |    |    |  |
| Bit:  | 15                 | 14                 | 13 | 12        | 11        | 10    | 9  | 8  |  |
| Name: |                    |                    |    | Real Ener | gy Byte 1 |       |    |    |  |
|       |                    |                    |    |           |           |       |    |    |  |
| Bit:  | 7                  | 6                  | 5  | 4         | 3         | 2     | 1  | 0  |  |
| Name: |                    | Real Energy Byte 0 |    |           |           |       |    |    |  |
|       | •                  | •                  | •  | •         | •         | -     | -  | -  |  |

On every DSP cycle, the contents of the X.ACT register are tested, and, if negative, absolute values are added to this register. When this register overflows, the ANOV bit in the X.EOVER register is set.

#### Energy, Reactive Positive, Phase X = A/B/C (X.ERPOS) (A: 0x1F0, B: 0x2DC, C: 0x3C8)

| Bit:  | 31                     | 30 | 29 | 28          | 27          | 26 | 25 | 24 |  |
|-------|------------------------|----|----|-------------|-------------|----|----|----|--|
| Name: |                        |    |    | Reactive En | ergy Byte 3 |    |    |    |  |
|       |                        |    |    |             |             |    |    |    |  |
| Bit:  | 23                     | 22 | 21 | 20          | 19          | 18 | 17 | 16 |  |
| Name: | Reactive Energy Byte 2 |    |    |             |             |    |    |    |  |
|       |                        |    |    |             |             |    |    |    |  |
| Bit:  | 15                     | 14 | 13 | 12          | 11          | 10 | 9  | 8  |  |
| Name: |                        |    |    | Reactive En | ergy Byte 1 |    |    |    |  |
|       |                        |    |    |             |             |    |    |    |  |
| Bit:  | 7                      | 6  | 5  | 4           | 3           | 2  | 1  | 0  |  |
| Name: | Reactive Energy Byte 0 |    |    |             |             |    |    |    |  |

On every DSP cycle, the contents of the X.REA register are tested, and, if positive, are added to this register. When this register overflows, the RPOV bit in the X.EOVER register is set.

### Energy, Reactive Negative, Phase X = A/B/C (X.ERNEG) (A: 0x1F4. B: 0x2E0. C: 0x3CC)

|       |                        |    |    |             | (           | A. UXII <del>I</del> , | D. UXZEU, | o. oxoco, |  |
|-------|------------------------|----|----|-------------|-------------|------------------------|-----------|-----------|--|
| Bit:  | 31                     | 30 | 29 | 28          | 27          | 26                     | 25        | 24        |  |
| Name: |                        |    |    | Reactive Er | ergy Byte 3 |                        |           |           |  |
|       |                        |    |    |             |             |                        |           |           |  |
| Bit:  | 23                     | 22 | 21 | 20          | 19          | 18                     | 17        | 16        |  |
| Name: | Reactive Energy Byte 2 |    |    |             |             |                        |           |           |  |
|       |                        |    |    |             |             |                        |           |           |  |
| Bit:  | 15                     | 14 | 13 | 12          | 11          | 10                     | 9         | 8         |  |
| Name: |                        |    |    | Reactive Er | ergy Byte 1 |                        |           |           |  |
|       |                        |    |    |             |             |                        |           |           |  |
| Bit:  | 7                      | 6  | 5  | 4           | 3           | 2                      | 1         | 0         |  |
| Name: | Reactive Energy Byte 0 |    |    |             |             |                        |           |           |  |
|       | ·                      | ·  | ·  | ·           |             | ·                      |           | ·         |  |

On every DSP cycle, the contents of the X.REA register are tested, and, if negative, absolute values are added to this register. When this register overflows, the RNOV bit in the X.EOVER register is set.

#### Energy, Apparent, Phase X = A/B/C (X.ES) (A: 0x1F8, B: 0x2E4, C: 0x3D0)

| Bit:  | 31                     | 30 | 29 | 28          | 27           | 26 | 25 | 24 |  |  |
|-------|------------------------|----|----|-------------|--------------|----|----|----|--|--|
| Name: |                        |    |    | Apparent Er | ergy Byte 3  |    |    |    |  |  |
|       |                        |    |    |             |              |    |    | _  |  |  |
| Bit:  | 23                     | 22 | 21 | 20          | 19           | 18 | 17 | 16 |  |  |
| Name: | Apparent Energy Byte 2 |    |    |             |              |    |    |    |  |  |
|       |                        |    |    |             |              |    |    | _  |  |  |
| Bit:  | 15                     | 14 | 13 | 12          | 11           | 10 | 9  | 8  |  |  |
| Name: |                        |    |    | Apparent Er | nergy Byte 1 |    |    |    |  |  |
|       |                        |    |    |             |              |    |    |    |  |  |
| Bit:  | 7                      | 6  | 5  | 4           | 3            | 2  | 1  | 0  |  |  |
| Name: | Apparent Energy Byte 0 |    |    |             |              |    |    |    |  |  |
|       | 97 7                   |    |    |             |              |    |    |    |  |  |

On every DSP cycle, the contents of the X.APP register are added to this register. When this register overflows, the SOV bit in the X.EOVER register is set.

### **Virtual Register Conversion Coefficients**

|        |                                               |                                                | Voltag | e Units Co | nversion | Coefficient | t (VOLT_C | C) (0x014) |  |  |  |
|--------|-----------------------------------------------|------------------------------------------------|--------|------------|----------|-------------|-----------|------------|--|--|--|
| Bit:   | 15                                            | 14                                             | 13     | 12         | 11       | 10          | 9         | 8          |  |  |  |
| Name:  |                                               | Voltage Units Conversion Coefficient High Byte |        |            |          |             |           |            |  |  |  |
| Reset: | 0x00                                          |                                                |        |            |          |             |           |            |  |  |  |
|        |                                               |                                                |        |            |          |             |           |            |  |  |  |
| Bit:   | 7                                             | 6                                              | 5      | 4          | 3        | 2           | 1         | 0          |  |  |  |
| Name:  | Voltage Units Conversion Coefficient Low Byte |                                                |        |            |          |             |           |            |  |  |  |
| Reset: |                                               | 0x01                                           |        |            |          |             |           |            |  |  |  |

This register contains the value by which the raw voltage value in each phase (A.VRMS, B.VRMS, and C.VRMS) is multiplied before being presented to the virtual RMS voltage registers (V.A, V.B, and V.C).

To determine the value of VOLT\_CC, a voltage value for the least significant bit (VOLT\_LSB) of the V.X registers must be selected. Typical values might range from 1mV to 1nV. To avoid significant conversion loss, VOLT\_LSB should be chosen such that VOLT\_CC is >1000. Once VOLT\_LSB is determined, calculate VOLT\_CC from the following equation:

$$VOLT\_CC = \frac{V_{FS}}{2^{24} \times VOLT\_LSB}$$

#### **Current Units Conversion Coefficient (AMP\_CC) (0x016)**

| Bit:   | 15                                             | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
|--------|------------------------------------------------|----|----|----|----|----|---|---|--|--|
| Name:  | Current Units Conversion Coefficient High Byte |    |    |    |    |    |   |   |  |  |
| Reset: | 0x00                                           |    |    |    |    |    |   |   |  |  |
|        |                                                |    |    |    |    |    |   |   |  |  |
| Bit:   | 7                                              | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |  |
| Name:  | Current Units Conversion Coefficient Low Byte  |    |    |    |    |    |   |   |  |  |
| Reset  | 0x01                                           |    |    |    |    |    |   |   |  |  |

This register contains the value by which the raw current value in each phase (A.IRMS, B.IRMS, C.IRMS, and N.IRMS) is multiplied before being presented to the virtual RMS current registers (I.A, I.B, I.C, and I.N). To determine the value of AMP\_CC, a current value for the least significant bit (AMP\_LSB) of the I.X registers must be selected. Typical values might range from 1nA to 10µA. To avoid significant conversion loss, AMP\_LSB should be chosen such that AMP\_CC is >1000. Once determined, calculate AMP\_CC from the following equation:

$$AMP\_CC = \frac{I_{FS}}{2^{24} \times AMP LSB}$$

#### **Power Units Conversion Coefficient (PWR\_CC) (0x018)**

| Bit:   | 15                                           | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
|--------|----------------------------------------------|----|----|----|----|----|---|---|--|--|
| Name:  | Power Units Conversion Coefficient High Byte |    |    |    |    |    |   |   |  |  |
| Reset: | 0x00                                         |    |    |    |    |    |   |   |  |  |
|        |                                              |    |    |    |    |    |   | _ |  |  |
| Bit:   | 7                                            | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |  |
| Name:  | Power Units Conversion Coefficient Low Byte  |    |    |    |    |    |   |   |  |  |
| Reset: | 0x01                                         |    |    |    |    |    |   |   |  |  |

This register contains the value by which the raw power value in each phase is multiplied before being presented to the virtual power registers. The table below lists the raw power registers and the corresponding virtual registers.

| DESCRIPTION                                         | RAW    | VIRTUAL |
|-----------------------------------------------------|--------|---------|
| Real power, phase A                                 | A.ACT  | PWRP.A  |
| Real power, phase B                                 | B.ACT  | PWRP.B  |
| Real power, phase C                                 | C.ACT  | PWRP.C  |
| Real power, total                                   | _      | PWRP.T  |
| Reactive power, phase A                             | A.REA  | PWRQ.A  |
| Reactive power, phase B                             | B.REA  | PWRQ.B  |
| Reactive power, phase C                             | C.REA  | PWRQ.C  |
| Reactive power, total                               | _      | PWRQ.T  |
| Apparent power, phase A                             | A.APP  | PWRS.A  |
| Apparent power, phase B                             | B.APP  | PWRS.B  |
| Apparent power, phase C                             | C.APP  | PWRS.C  |
| Apparent power, total                               | _      | PWRS.T  |
| Real power, phase A, fundamental frequency only     | A.ACTF | PWRPF.A |
| Real power, phase B, fundamental frequency only     | B.ACTF | PWRPF.B |
| Real power, phase C, fundamental frequency only     | C.ACTF | PWRPF.C |
| Real power, total, fundamental frequency only       | _      | PWRPF.T |
| Reactive power, phase A, fundamental frequency only | A.REAF | PWRQF.A |
| Reactive power, phase B, fundamental frequency only | B.REAF | PWRQF.B |
| Reactive power, phase C, fundamental frequency only | C.REAF | PWRQF.C |
| Reactive power, total, fundamental frequency only   | _      | PWRQF.T |
| Apparent power, phase A, fundamental frequency only | A.APPF | PWRSF.A |
| Apparent power, phase B, fundamental frequency only | B.APPF | PWRSF.B |
| Apparent power, phase C, fundamental frequency only | C.APPF | PWRSF.C |
| Apparent power, total, fundamental frequency only   |        | PWRSF.T |

PWR\_CC establishes the amount of power represented by one PWR\_LSB of the power registers. To avoid significant conversion loss, PWR\_LSB should be chosen such that PWR\_CC is > 1000. Calculate the value of PWR\_CC according to the following formula:

$$PWR\_CC = \frac{I_{FS} \times V_{FS}}{2^{32} \times PWR\_LSB}$$

\_\_ /V|/|X|/V|

#### **Energy Units Conversion Coefficient (ENR\_CC) (0x01A)**

| Bit:   | 15                                            | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |  |
|--------|-----------------------------------------------|----|----|----|----|----|---|---|--|--|--|
| Name:  | Energy Units Conversion Coefficient High Byte |    |    |    |    |    |   |   |  |  |  |
| Reset: | 0x00                                          |    |    |    |    |    |   |   |  |  |  |
|        |                                               |    |    |    |    |    |   |   |  |  |  |
| Bit:   | 7                                             | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |  |  |
| Name:  | Energy Units Conversion Coefficient Low Byte  |    |    |    |    |    |   |   |  |  |  |
| Reset: | 0x01                                          |    |    |    |    |    |   |   |  |  |  |

This register contains the value by which the raw accumulated energy value in each phase is multiplied before being presented to the virtual energy registers. The table below lists the raw energy accumulators and the corresponding virtual registers.

| DESCRIPTION                                                    | RAW      | VIRTUAL    |
|----------------------------------------------------------------|----------|------------|
| Real energy, phase A, positive direction                       | A.EAPOS  | ENIDD A*   |
| Real energy, phase A, reverse direction                        | A.EANEG  | ENRP.A*    |
| Real energy, phase B, positive direction                       | B.EAPOS  | ENRP.B*    |
| Real energy, phase B, reverse direction                        | B.EANEG  | ENRY.D     |
| Real energy, phase C, positive direction                       | C.EAPOS  | ENRP.C*    |
| Real energy, phase C, reverse direction                        | C.EANEG  | ENRP.C     |
| Real energy, total                                             | _        | ENRP.T     |
| Reactive energy, phase A, positive direction                   | A.ERPOS  | ENRQ.A*    |
| Reactive energy, phase A, reverse direction                    | A.ERNEG  | ENNQ.A     |
| Reactive energy, phase B, positive direction                   | B.ERPOS  | ENRQ.B*    |
| Reactive energy, phase B, reverse direction                    | B.ERNEG  | ENNQ.D     |
| Reactive energy, phase C, positive direction                   | C.ERPOS  | ENRQ.C*    |
| Reactive energy, phase C, reverse direction                    | C.ERNEG  | ENNQ.C     |
| Reactive energy, total                                         | _        | ENRQ.T     |
| Apparent energy, phase A                                       | A.ES     | ENRS.A     |
| Apparent energy, phase B                                       | B.ES     | ENRS.B     |
| Apparent energy, phase C                                       | C.ES     | ENRS.C     |
| Apparent energy, total                                         | _        | ENRS.T     |
| Real energy, phase A, positive direction, fundamental only     | A.EAFPOS | ENRPF.A*   |
| Real energy, phase A, reverse direction, fundamental only      | A.EAFNEG | LINNET.A   |
| Real energy, phase B, positive direction, fundamental only     | B.EAFPOS | ENRPF.B*   |
| Real energy, phase B, reverse direction, fundamental only      | B.EAFNEG | CINNEF.D   |
| Real energy, phase C, positive direction, fundamental only     | C.EAFPOS | ENRPF.C*   |
| Real energy, phase C, reverse direction, fundamental only      | C.EAFNEG | ENREF.C    |
| Real energy, total, fundamental only                           | _        | ENRPF.T    |
| Reactive energy, phase A, positive direction, fundamental only | A.ERFPOS | ENRQF.A*   |
| Reactive energy, phase A, reverse direction, fundamental only  | A.ERFNEG | EINDQF.A   |
| Reactive energy, phase B, positive direction, fundamental only | B.ERFPOS | ENRQF.B*   |
| Reactive energy, phase B, reverse direction, fundamental only  | B.ERFNEG | LIVITQI .D |

<sup>\*</sup>These registers represent the algebraic sum of the positive and reverse energy in the two "raw" registers noted. Thus, the energy returned in these virtual registers represents the net energy.

#### **Energy Units Conversion Coefficient (ENR\_CC) (0x01A) (continued)**

| DESCRIPTION                                                    | RAW      | VIRTUAL    |  |
|----------------------------------------------------------------|----------|------------|--|
| Reactive energy, phase C, positive direction, fundamental only | C.ERFPOS | ENRQF.C*   |  |
| Reactive energy, phase C, reverse direction, fundamental only  | C.ERFNEG | LIVINGI .C |  |
| Reactive energy, total, fundamental only                       | _        | ENRQF.T    |  |
| Apparent energy, phase A, fundamental only                     | A.ESF    | ENRSF.A    |  |
| Apparent energy, phase B, fundamental only                     | B.ESF    | ENRSF.B    |  |
| Apparent energy, phase C, fundamental only                     | C.ESF    | ENRSF.C    |  |
| Apparent energy, total, fundamental only                       | _        | ENRSF.T    |  |

<sup>\*</sup>These registers represent the algebraic sum of the positive and reverse energy in the two "raw" registers noted. Thus, the energy accumulated in these virtual registers represents the net energy.

To avoid significant conversion loss, ENR\_LSB should be chosen such that ENR\_CC is > 1000. Calculate the value of ENR\_CC according to the following formula:

$$ENR\_CC = \frac{I_{FS} \times V_{FS} \times t_{FR}}{2^{16} \times ENR LSB}$$

#### **Temperature Conversion Coefficient (TEMP\_CC) (0x060)**

| Bit:   | 15                                           | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |
|--------|----------------------------------------------|----|----|----|----|----|---|---|--|--|
| Name:  | Temperature Conversion Coefficient High Byte |    |    |    |    |    |   |   |  |  |
| Reset: | 0x00                                         |    |    |    |    |    |   |   |  |  |
|        |                                              |    |    |    |    |    |   |   |  |  |
| Bit:   | 7                                            | 6  | 5  | 4  | 3  | 2  | 1 | 0 |  |  |
| Name:  | Temperature Conversion Coefficient Low Byte  |    |    |    |    |    |   |   |  |  |
| Reset: | 0x00                                         |    |    |    |    |    |   |   |  |  |

This register contains the temperature conversion coefficient that is applied to convert the temperature sensor binary output into degrees Celsius, per the following equation, where RAW\_TEMP is the raw temperature sensor output.

$$T_C = RAW_TEMP \times TEMP_CC/2^{16} - 273.15$$

Note that TEMP\_CC should be obtained by calibrating the temperature sensor at the desired operation condition. Typical approximate value is  $TEMP_CC = 0x0426$ . To read temperature, use the special register command 0xC01.

### Virtual Registers

The virtual registers are calculated values derived from one or more real registers. They are calculated at the time they are requested, and thus could involve additional time to return a value. Most virtual registers are 8 bytes in length and are delivered least significant byte first.

#### Power

### Real Power, Phase X = A/B/C/T (PWRP.X) (A: 0x801, B: 0x802, C: 0x804, T: 0x807)

This signed register contains the real instantaneous power delivered into phase A/B/C or total. Power is calculated from the instantaneous energy measurement according to the following equation:

$$PWRP.X = \frac{X.ACT \times PWR\_CC \times 2^{16}}{NS}$$

The register is 8 bytes long, but the most significant 2 bytes are not used. See the PWR\_CC register description for more details.

| Byte 7 (MSByte unused) | Byte 6 (unused) |  |
|------------------------|-----------------|--|
| Byte 5                 | Byte 4          |  |
| Byte 3                 | Byte 2          |  |
| Byte 1                 | Byte 0 (LSByte) |  |

Note that the sign bit is bit 47 for all 8-byte signed virtual registers.

### Reactive Power, Phase X = A/B/C/T (PWRQ.X) (A: 0x811, B: 0x812, C: 0x814, T: 0x817)

This signed register contains the reactive instantaneous power delivered into phase A/B/C or total. Power is calculated from the instantaneous energy measurement according to the following equation:

$$PWRQ.X = \frac{X.REA \times PWR\_CC \times 2^{16}}{NS}$$

The register is 8 bytes long, but the most significant 2 bytes are not used. See the PWR\_CC register description for more details.

| Byte 7 (MSByte unused) | Byte 6 (unused) |  |
|------------------------|-----------------|--|
| Byte 5                 | Byte 4          |  |
| Byte 3                 | Byte 2          |  |
| Byte 1                 | Byte 0 (LSByte) |  |

#### Apparent Power, Phase X = A/B/C/T (PWRS.X) (A: 0x821, B: 0x822, C: 0x824, T: 0x827)

This register contains the apparent instantaneous power delivered into phase A/B/C or total. Power is calculated from the instantaneous energy measurement according to the following equation:

$$PWRS.X = \frac{X.APP \times PWR\_CC \times 2^{16}}{NS}$$

The register is 8 bytes long, but the most significant 2 bytes are not used. See the PWR\_CC register description for more details.

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

#### **Voltage and Current**

#### RMS Volts, Phase X = A/B/C (V.X) (A: 0x831, B: 0x832, C: 0x834)

This register contains the RMS voltage on phase A/B/C. The units are defined by the VOLT\_CC setting such that V.X = X.VRMS x VOLT\_CC. In this equation, VOLT\_CC is the conversion coefficient. See the VOLT\_CC register for more information.

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

#### RMS Amps, Phase X = A/B/C/N (I.X) (A: 0x841, B: 0x842, C: 0x844, N: 0x840)

This register contains the RMS current on phase A/B/C or the neutral channel. The units are defined by the AMP\_CC setting such that I.X = X.IRMS x AMP\_CC. In this equation, AMP\_CC is the conversion coefficient. See the AMP\_CC register for more information.

| Byte 7 (MSByte unused) | Byte 6 (unused) |  |
|------------------------|-----------------|--|
| Byte 5                 | Byte 4          |  |
| Byte 3                 | Byte 2          |  |
| Byte 1                 | Byte 0 (LSByte) |  |

**Power Factor** 

Power Factor (PF.T) (0x867)

This signed register contains the power factor of the total power. The power factor is calculated as:

$$PF.T = \frac{A.ACT + B.ACT + C.ACT}{A.APP + B.APP + C.APP}$$

It is expressed in units of 0.00001; thus, unity power factor is expressed as decimal 100,000 (0x0000000000186A0). This register is presented as a two's complement value, so that a load delivering real power to the line (that is, reverse power) is seen as having a power factor of -1 (0x0000FFFFFFFE7960).

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

### Energy

#### Real Energy, Phase A/B/C/T (ENRP.X) (A: 0x8C1, B: 0x8C2, C: 0x8C4, T: 0x8C7)

This signed register contains the real accumulated energy delivered into phase A/B/C or total. The register is calculated according to the following formula:

 $ENRP.X = ENR\_CC \times (X.EAPOS - X.EANEG)$ 

| Byte 7 (MSByte unused) | Byte 6 (unused) |  |
|------------------------|-----------------|--|
| Byte 5                 | Byte 4          |  |
| Byte 3                 | Byte 2          |  |
| Byte 1                 | Byte 0 (LSByte) |  |

#### Reactive Energy, Phase A/B/C/T (ENRQ.X) (A: 0x8D1, B: 0x8D2, C: 0x8D4, T: 0x8D7)

This signed register contains the reactive accumulated energy delivered into phase A/B/C or total. The register is calculated according to the following formula:

ENRQ.X = ENR\_CC x (X.ERPOS - X.ERNEG)

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

#### Apparent Energy, Phase A/B/C/T (ENRS.X) (A: 0x871, B: 0x872, C: 0x874, T: 0x877)

This register contains the apparent accumulated energy delivered into phase A/B/C or total. The register is the product of the ENR\_CC and X.ES registers.

| Byte 7 (MSByte unused) | Byte 6 (unused) |  |
|------------------------|-----------------|--|
| Byte 5                 | Byte 4          |  |
| Byte 3                 | Byte 2          |  |
| Byte 1                 | Byte 0 (LSByte) |  |

### **Theory of Operation**

#### **Analog Front-End Operation**

Whenever the MAXQ3183 is in one of the active operating modes (Run Mode or LOWPM Mode), the analog front-end operates continuously, scanning up to eight scan slots depending on the selected front-end configuration. For each analog scan slot that is enabled, one of the eight differential input pairs is measured.

The SCAN\_IX and SCAN\_VX (X = A/B/C), SCAN\_IN, and SCAN\_TE registers contain the settings for each slot, which include whether the slot is enabled and the differential input pair to measure during that scan slot. The logical mapping of the slots is fixed in following order:

- Slot 0—Phase A Current (IA)
- Slot 1—Phase A Voltage (VA)
- Slot 2—Phase C Current (IC)
- Slot 3—Phase C Voltage (VC)
- Slot 4—Phase B Current (IB)
- Slot 5—Phase B Voltage (VB)
- Slot 6—Neutral Current (IN)—disabled by default
- Slot 7—Temperature Measurement—disabled by default

The required time for each analog scan slot measurement (tc) is determined by the MAXQ3183 system clock frequency and the setting of the R\_ADCRATE hardware register, as shown below:

$$t_C = 1/f_{CLK} \times (R\_ADCRATE[8:0] + 1)$$

Using the default register settings (R\_ADCRATE = 167h = 359d), the time for each analog slot measurement (tc) is  $45\mu$ s when the MAXQ3183 is running at 8MHz. Since there are eight analog scan slots in the measurement frame, the total time for all measurements (tFR) is tc x 8. Using the default settings with the MAXQ3183 running at 8MHz, the entire sequence of measurements takes  $360\mu$ s to complete, which, in turn, means that  $360\mu$ s will elapse, for example, between one phase A current measurement and the next.

Even if some of the analog measurement slots (such as neutral current or temperature measurement) are skipped by setting the DADCNV bit in that slot's register to 1, the time period for that slot will remain in the frame, ensuring that the total frame time is always to x 8, regardless of which individual slots are enabled or disabled.

### Digital Signal Processing (DSP) Terminology

Establishing the precise definitions of some of the terms used in this document will assist in understanding how the DSP functions.

**Sample Period:** The amount of time required to measure a single data element; 45µs, by default.

**ADC Frame Period:** The amount of time required for the ADC to sample all analog inputs; always equal to 8 sample periods. The inverse of this value is the *frame rate*; by default 2778 samples per second. This is the rate at which any particular signal is sampled by the MAXQ3183.

**Line Cycle:** The period of time from one positive-going zero crossing on a voltage channel to the next positive-going zero crossing. At 50Hz, this is nominally 20ms; at 60Hz, this is nominally 16.67ms.

**Cycle Count:** The number of line cycles contained in a single DSP cycle. An integer, this is typically set to some value greater than one to minimize the effect of load variations that may not occur in every line cycle. By default, this value is 16.

**DSP Cycle:** The period of time over which line parameters are calculated. Energy and other parameters are accumulated once per DSP cycle. One DSP cycle is the time of a line cycle multiplied by the cycle count.

**NS:** This value represents the number of ADC frame periods in a DSP cycle. This is a noninteger calculated value. For example, if the cycle count is set to unity, and the line frequency is exactly 50Hz, the NS value would be  $20\text{ms}/360\mu\text{s} = 55.6$ .

#### **Digital Processing**

As voltage and current samples are collected, the MAXQ3183 performs a variety of digital filtering, accumulation, and processing calculations to arrive at meter-reading values (such as line frequency, RMS voltage and current, and active and reactive power) that can then be read by the master. The MAXQ3183 calculates and detects values and conditions including the following:

- Zero-crossing detection
- Line frequency and line period calculation
- RMS voltage (phase A, phase B, phase C)
- RMS current (phase A, phase B, phase C, neutral current)

- Power (active, reactive, and apparent) for each phase
- Energy accumulation (including energy pulse output function)
- Overvoltage detection
- Overcurrent detection
- Undervoltage detection

#### **Per Sample Operations**

On every ADC frame, the input samples are processed as follows:

- The voltage and current samples are read. The current sample is shifted to account for the gain applied in the PGA. The phase- and gain-corrected samples are passed to the next stage.
- Both the current and voltage signals are passed through highpass filters (HPF) specified by the HPF\_C variable.
- The current and voltage signals are now split into several components. The first of these components is squared and accumulated to begin the RMS current and voltage process. The second is processed and accumulated to begin the real/reactive power calculation. And a third is processed through a peak filter (specified by B0FUND and A1FUND registers) and then accumulated to provide information for the fundamental frequency power calculations.

The result is a set of accumulated values that represent squared voltage, squared current, and real (active) and reactive (P and Q) energies for both the entire usable spectrum and as filtered by the peak filter. The real and imaginary components of energy at this point do not yet represent real and reactive power; to obtain usable power values further processing is required. Each of these values is further processed at the end of each DSP cycle.

#### **Per DSP Cycle Operations**

At the end of each DSP cycle, accumulated information is available that is used to calculate all other operational results in the meter. DSP cycles track the line frequency and have a duration of the number of cycles specified in the CYCNT register. On each phase, the time required for CYCNT cycles to complete is calculated and this value is used to update the duration of one DSP cycle, specified in the NS register.

NS contains the number of ADC frame periods in a single DSP cycle. Because line frequency varies slightly from cycle to cycle, and because the ADC frame clock is not synchronized to the line, the value of NS is not an integer, and varies slightly from DSP cycle to DSP cycle.

Because the value of NS is so critical to accurate calculation of energy, ensuring that it is correct on every cycle is essential. There are two ways to manage the slight variation of NS from cycle to cycle: first, one could simply replace the old value of NS with the newly calculated value on each DSP cycle. This means that NS (and every other value in the meter, since they depend on NS) would have a significant amount of uncertainty. A better method is to use each newly calculated value of NS as an input to a filter. The *output* of the filter is then the value of NS that is actually used in calculations. In the MAXQ3183, this filter is controlled by the AVG\_NS register.



Figure 9. Per Sample Operations

A second problem with updating NS on every line cycles is the fact that noise impulses that occur at nearly the same time as the zero crossing can shift the zero crossing, affecting the accuracy of the energy measured during the preceding period. For this reason, a second register, REJ\_NS contains a value that specifies how far a particular sample can deviate from the average and still be considered valid. If the period of the newly acquired DSP cycle differs from the previously accumulated average value by more than REJ\_NS ADC frames, NS is not updated with the new period (but the energy is still accumulated).

With this discussion in mind, the signal path for the various reported parameters can be reviewed.

**RMS Volts and RMS Amps:** First, the squared voltage accumulation is divided by NS. This accomplishes the "mean" part of the "root-mean-square" calculation. Then, the square root of the result is taken, producing the raw RMS calculation value.

On the voltage channel, the signal is ready for gain compensation to be applied. But on the current channel, there is an additional twist: depending on the amplitude of the current, there may be a gain factor pre-applied before the raw sample is available. To compensate for inaccuracy in the gain factor for the amplifier and for noise seen in the channel at high gain settings, it may be necessary to provide linearity compensation.

There are three registers that manage the linearization of the current signal: the X.OFFS\_HI (X = A/B/C) register contains a signed value that is added to the raw RMS current signal before further processing; the X.OFFS\_LO register contains a signed value that is

added to the raw RMS current signal when the current signal is below a low current threshold (1/32 of the full scale) value; and the X.GAIN\_LO register contains a gain adjustment that is applied to the current signal when the current signal is below the threshold value. The practical effect of this is to turn what may be a somewhat nonlinear response curve for the current sensor to a much more linear response by two-piece approximation.

The "high current" calibration term X.OFFS\_HI is used so long as the instantaneous current exceeds the low-current threshold at some instant during a DSP cycle. As long as this threshold is crossed during a DSP cycle, the value in X.OFFS\_HI controls the offset current.

When the input stays below the low-current threshold for one DSP cycle, the X.OFFS\_LO and X.GAIN\_LO are applied. The low-current calibration terms (X.GAIN\_LO and X.OFFS\_LO) remain in effect until the peak of input current waveform exceeds 1/32 of full-scale current at any time during a DSP cycle.

As a final step, both voltage and current are passed through an averaging filter that provides smoothing for the signals. The amount of filtering is given in AVG\_C.

**Energy:** The per-sample processing produces a pair of digital signals that represent the complex energy signal. From this complex signal, it is desired to extract the real portion and the reactive portion. At first glance, this seems trivial: the real portion is the real part of the complex signal, and the reactive portion is the imaginary part of the complex signal. Apparent power (in voltamperes) is the magnitude of the complex signal, and power angle is the argument of the complex signal.



Figure 10. Computation of RMS Values

\_\_ /N/1XI/N

But current sensors and other external circuitry components introduce a phase distortion to the current signal, and this phase distortion may not be constant at all current values. Consequently, for the most precise measurements, the phase between the voltage and current signals must be compensated. In the MAXQ3183, the energy signals are compensated for phase offset by performing a complex multiplication of the signal with the contents of the appropriate phase offset register.

Determining which phase offset register is appropriate is a matter of comparing the incoming RMS current for the phase with the contents of the I1THR and I2THR registers. It is the responsibility of the administrative software to ensure that I1THR is greater than or equal to I2THR. If the raw RMS current is greater than or equal to the contents of I1THR, then the angle expressed in PA0 is used to compensate the phase angle. If the raw RMS current is less than I2THR, then the angle expressed in PA2 is used to compensate the phase angle. And if the raw RMS current falls between I1THR and I2THR then PA1 is used to compensate the phase angle. In this way, a three-piece stepwise approximation of the phase response of the current sensor is available.

$$PA = \begin{cases} PA0, \ I_{RMS} \ge I1THR \\ PA1, \ I1THR > I_{RMS} \ge I2THR) \\ PA2, \ I_{RMS} < I2THR \end{cases}$$

To use a constant phase compensation, set I1THR and I2THR to zero and insert the phase compensation value into PA0.

The same processing can be performed to calculate the reactive energy value. But reactive energy can be calculated in another way: calculate apparent energy by multiplying the raw RMS volts and raw RMS current, square this value, then subtract the squared real power. The square root of this value is the reactive energy.

Similarly, apparent energy can be calculated in either of two ways: either as the product of the raw RMS volts and amps, or as the square root of the sum of the squares of the real and reactive energy. Which of these is selected depends on the value of the APPSEL bit in the OPMODE2 register: if 0, then apparent energy is the product of the raw RMS volts and amps and reactive energy is calculated using the difference of squares method; if 1, apparent energy is calculated using the sum of squares method and reactive energy is calculated directly from the complex energy.

Line Frequency and Phasor Angles: Line frequency can be taken directly from the NS value. Recall that NS is the number of frames in a DSP cycle. Since each frame is 360µs, simply multiply NS by 360µs and divide by CYCNT to obtain the line period. The reciprocal of this is the line frequency.

To calculate phasor angles, the numbers of samples between zero crossings on phase A and B and on phase A and C are taken. Since NS is the number of samples during a complete DSP cycle, it is easy to calculate the fraction of a complete cycle. The software then converts this value to degrees and adjusts it such that no negative angles are reported. No calibration is required for line frequency and phasor angle calculation.

#### **Energy Accumulation**

Once real and reactive energy over the most recent DSP cycle has been calculated, it is necessary to accumulate the result.

For reactive energy, the result accumulated during any DSP cycle may be positive (for an inductive load) or



Figure 11. Phase Compensation for Energy Calculations



Figure 12. Apparent and Reactive Energy Calculations

negative (for a capacitive load). These values are separately accumulated. This means that during any one DSP cycle, only positive or negative reactive energy will be accumulated.

Similarly, for real energy, the result accumulated during any DSP cycle can be positive (that is, energy is delivered to the load) or negative (that is, energy is driven back into the line). As is performed for reactive energy, these values are separately accumulated.

Apparent energy is also accumulated, but since this value is always positive or zero, there is only one apparent energy accumulator.

From time to time, the accumulators generate an overflow. When this occurs, the appropriate bit is set in the overflow status register X.EOVER.

When an overflow occurs, supervisory code running on the host processor must make the appropriate adjustments in the reported energy. In many cases, this could simply involve incrementing an overflow counter. The host processor must then clear the overflow indication.

#### **No-Zero-Crossing Detection**

The MAXQ3183 monitors the voltage signal on each phase for zero-crossing events. If no ascending zero crossings are detected within a DSP cycle, the NOZXF (X.FLAGS) flag is set by the MAXQ3183 to notify the master of this condition. If the NOZXM bit is set, this flag sets the NOZX bit in the IRQ\_FLAG. If the interrupt enable bit ENOZX is set to 1, the interrupt signal  $\overline{\text{IRQ}}$  is driven low by the MAXQ3183 whenever NOZX = 1. The master can clear NOZXF and NOZX back to 0 to remove the interrupt condition.

#### **Phase Sequence Status**

Phase sequence status bits PHSEQV and PHSEQI indicate the order in which zero crossings are detected. When a zero-crossing event occurs on the phase A signal, followed by phase B, phase C, and then phase A again, this bit cleared. If a zero crossing on phase A is then followed by a zero crossing on phase C, then phase B, this bit set to 1.

### RMS Voltage, RMS Current, and Energy Calculation

For each of the three phases, the MAXQ3183 calculates RMS voltage and RMS current values, as well as determines active and reactive energy, using a line-cycle-based integration process.

### Power Calculation (Active, Reactive, Apparent)

The power, energy, and RMS calculation process consists of two tasks: continuous accumulation and post-processing triggered every CYCNT line cycles. The accumulation task accumulates raw data obtained from the AFE during CYCNT line cycles. This task is performed continuously in the background by the MAXQ3183. When a CYCNT line cycles accumulation stage has completed, which is determined by a dedicated frame counter exceeding the NS level, the raw integral accumulator values are saved for postprocessing and cleared, beginning the next cycle of accumulation task. Then, the DSP postprocessing is triggered to process saved integrals and calculate energy, power, etc., values. Note that the background accumulation task continues while foreground postprocessing

\_ /N/XI/N

is taking place, i.e., both tasks are executed simultaneously sharing CPU time. It is essential that the DSP postprocessing calculations be completed before the next DSP trigger to avoid losing accumulated data. The master should allow enough processing time by adjusting the R\_ADCRATE register. Default settings provide plenty of CPU time for both tasks.

The MAXQ3183 accumulates raw sums and calculates line-cycle integrals for each voltage-current pair separately. The individual power accumulators are:

- PA = VA x IA
- PB = IB x VB or -IB x VC or -IB x (VA + VC) or -IB x (VA - VC)
- $PC = VC \times IC$

The PA and PC accumulators always operate in a single mode:  $(V_A \times I_A)$  for the PA accumulator,  $(V_C \times I_C)$  for the PC accumulator. Alternately, the operating mode of the PB accumulator is defined by setting the CON-CFG[1:0] bits in the OPMODE1 register.

#### **Energy Accumulation Start Delay**

All filters have a certain settling time before accurate energy readings can be accumulated. To avoid accumulation of invalid data from filters that are still settling, an energy accumulation timeout period can be set in the ACC\_TIMO register. When ACC\_TIMO > 0, computed energy is not accumulated for ACC\_TIMO of DSP cycles. The MAXQ3183 will decrement the ACC\_TIMO register every DSP cycle until it becomes 0. When ACC\_TIMO reaches 0 value, energy accumulation begins (or resumes, if ACC\_TIMO was set to nonzero value by the master). Pulse outputs are also disabled when ACC\_TIMO > 0. The default value of ACC\_TIMO is 0x05.

#### **No-Load Feature**

To avoid "meter creep," no energy accumulation should take place when measured current is less than a certain threshold. The NOLOAD register can be programmed to enable and configure this feature. If the measured X.IRMS value for a phase (A, B, or C) falls below the NOLOAD threshold, the energy accumulators for this phase are not incremented. Setting NOLOAD = 0 disables this feature. Full scale is represented by 0x10000.

#### **On Demand Calculations**

So far in this discussion, the values being calculated and managed in the MAXQ3183 have been based on fundamental units meaningful to the device itself: voltage as a binary fraction of full-scale voltage; current as a binary fraction of full-scale current, and time as a non-integer multiple of the ADC frame time.

But a practical electricity meter must report its results in standard units, such as volts, amperes, and watts. The MAXQ3183 contains a mechanism to convert the internal units ("meter units") to real world units ("display units"). This conversion is performed in the conversion constant (CC) registers.

For some of these values (voltage, current) the calculation is simple: multiply by the conversion constant. For other values (power, energy) the calculation is more complex. In any case, the value in the CC register affects only the conversion from a meter unit to a display unit; calibration is handled separately in the gain adjustment registers for each recorded value.

The results of all on-demand calculations are reported as 8-byte (64-bit) values of which no more than 6 bytes (48 bits) are significant. Eight bytes are used as a common length; however, fewer bytes can be requested for those registers known to have smaller maximum values. For example, the power factor virtual register has a maximum value that is expressed in only 3 bytes; consequently, the register can be requested with a length of 4 bytes without loss of data.

#### RMS Volts, RMS Amps

These registers (V.A, V.B, V.C, I.A, I.B, I.C) are calculated by simply multiplying the calculated RMS value (A.VRMS, B.VRMS, C.VRMS, A.IRMS, B.IRMS, C.IRMS) by the contents of the VOLT\_CC or AMP\_CC register. Since the RMS voltage and RMS current are given in 32-bit registers and the conversion coefficients are given in 16-bit registers, the result of the product is 48 bits.

Regardless of the internal units used, VOLT\_CC and AMP\_CC can be tailored so that the LSB of the virtual register can be any value. For example, if one wished to have a 32-bit value representing milliamps, one could multiply by a value that scaled the register such that the LSB was 2<sup>-16</sup>mA. Then, discard the low-order 16 bits. The result is milliamps with 32 bits of precision; thus, the maximum current that could be represented would be 4,294,967,296mA, or just over 4MA.

The VOLT\_CC and AMP\_CC values can be calculated from the full-scale voltage or full-scale current and the desired value of one LSB in the display register:

$$AMP\_CC = \frac{I_{FS}}{2^{24} \times AMP\_LSB}$$

$$VOLT\_CC = \frac{V_{FS}}{2^{24} \times VOLT\_LSB}$$

**Example:** Assume the full-scale current is 102.4A, and that we desire a 1nA LSB. The calculation would provide an AMP\_CC value of:

$$102.4/(2^{24} \times 10^{-9}) = 6104 = 0 \times 17D8$$

#### **Power**

The MAXQ3183 measures energy. But power is just energy per unit time, and the MAXQ3183 keeps track of the time unit over which energy is accumulated. This is simply the NS value, the fractional number of samples that comprises one DSP cycle. So converting energy to power is as simple as dividing the accumulated energy over one DSP cycle by NS. Multiplying by a conversion constant (PWR\_CC) gives power in user-established units.

The power registers (PWRP.A, PWRP.B, PWRP.C, PWRQ.A, PWRQ.B, PWRQ.C, PWRS.A, PWRS.B, PWRS.C) are calculated by multiplying the accumulated energy (A.ACT, A.REA, A.APP, B.ACT, B.REA, B.APP, C.ACT, C.REA, C.APP) by the conversion coefficient (PWR\_CC) and then dividing by NS. The result is the 48-bit average power over the most recent DSP cycle, in units established by the conversion coefficient.

The PWR\_CC value can be calculated from the full-scale voltage, the full-scale current, and the desired value of one LSB in the display register:

$$PWR\_CC = \frac{I_{FS} \times V_{FS}}{2^{32} \times PWR LSB}$$

**Example:** For this example, assume the full-scale current is 102.4A, the full-scale voltage is 558.1V, and that the desired LSB is milliwatts after discarding the 16 LSB; that is, the desired LSB is 2<sup>-16</sup> milliwatts. Perform the following calculation:

$$102.4 \times 558.1/(2^{32} \times 2^{-16} \times 10^{-3}) = 872 = 0 \times 0368$$

#### **Power Factor**

Power factor is calculated as real power divided by apparent power. But note that apparent power can be calculated in either of two ways: either as a square root of the sum of the squares of the real and reactive power, or more commonly as the product of the RMS

voltage and current measurement. The power factor as reported could change when one or the other of these methods is used.

The power factor is multiplied by 2<sup>14</sup> before it is reported; thus, unity power factor is given by 16,384 decimal (0x4000).

#### Line Frequency

The line frequency is derived directly from the mean NS values over the three phases. It is reported as millihertz; thus, a 50Hz line frequency is reported as decimal 50,000 (0xC350).

#### Phasor Angles

The phasor angles are taken directly from the angular measurement values determined at each DSP cycle. The angle is reported in units of 0.01 degree; thus, a 120° phasor is reported as decimal 12,000 (0x2EE0).

#### Energy

Energy is read as the net energy directly scaled from the appropriate registers. For example, the energy read from the ENRP.A register (real energy, phase A) is composed of the difference between the A.EAPOS (real energy, positive direction, phase A) and A.EANEG (real energy, negative direction, phase A) registers scaled by the ENR\_CC register.

Note that the energy registers (ENRP.A, ENRP.B, ENRP.C, ENRP.T, ENRQ.A, ENRQ.B, ENRQ.C, ENRQ.T, ENRS.A, ENRS.B, ENRS.C, ENRS.T) represent the energy, in every case, since the last overflow event. For this reason, software must keep track of overflow and make adjustments accordingly when using this register set.

To calculate the ENR\_CC register value, begin with the full-scale voltage and full-scale current, the frame time, and the desired LSB value for energy. Then perform the following calculation:

$$ENR\_CC = \frac{I_{FS} \times V_{FS} \times t_{FR}}{2^{16} \times ENR LSB}$$

**Example:** It is essential to ensure that the correct units are maintained throughout the calculation. In this example, assume that the full-scale voltage is 558.1V, the full-scale current is 102.4A, the frame time is the default of 360 $\mu$ s, and the desired LSB is 100 milliwatt-hours after the 32 bits are discarded; that is, the LSB is 0.1 x 2-32 watt-hours. Notice, however, that the frame time is given in microseconds *and must be converted to hours* before the calculation can be performed: 360 $\mu$ s is 100 x 10-9 hours. So the calculation proceeds as follows:

$$102.4 \times 558.1 \times 100 \times 10^{-9}/(2^{16} \times 0.1 \times 2^{-32}) = 3745 = 0 \times 0$$

**MIXIM** 

#### **Meter Pulse**

The purpose of a meter pulse is generally to advance a mechanical counter when such a device is used as a display. Meter pulses are also used during calibration since time intervals can be measured with great precision.

The MAXQ3183 supports two meter pulse outputs. These outputs can be configured for either active positive or active negative pulses by means of the POPOL bit in the OPMODE1 register. When triggered, the pulse goes to its active state and remains there for a period of time defined by the PLS1\_WD or PLS2\_WD register, and then returns to the inactive state (unless triggered again).

The PLS1\_WD and PLS2\_WD registers contain the time in ADC frame periods that the pulses remain in the active state when triggered. By default, these registers contain decimal 156 (0x9C) giving, at the default frame rate, a pulse width of approximately 50ms.

Each pulse generator can select one parameter to be accumulated over any combination of the three phases. For example, one could select real energy accumulated over all three phases for pulse output 1, and reactive energy accumulated over all three phases for pulse output 2. The particular parameters that can be accumulated are given in the register table.

Among the quantities that can be accumulated by the pulse subsystem are the arithmetic active energy (that is, the accumulated positive real energy minus the accumulated negative real energy) and the absolute active energy (that is, accumulated positive real energy plus accumulated negative real energy). Other quantities include RMS voltage and current, positive and negative real energy and reactive energy in each of the four quadrants. Select the desired accumulation value in the QNSEL field of the PLSCFG1 and PLSCFG2 register.

Also in the pulse configuration registers you can select which phases to include in the accumulation. Set any or all the PHASEA, PHASEB, and PHASEC bits in the PLSCFG1 or PLSCFG2 registers to include them in the accumulation.

#### Generating Pulses

On every DSP cycle, the MAXQ3183 adds the value in the selected register (or set of registers) to the pulse accumulator. If the value in the pulse accumulator exceeds the value in the associated threshold register (THR1 or THR2), then a pulse is started and the value in the threshold register is subtracted from the value in the pulse accumulator.

#### **Meter Constant**

A meter constant is the number of pulses that are generated during a standard measurement interval; for example, a meter might specify a meter constant of 1600 pulses per kilowatt-hour. The THR1 and THR2 registers are used to specify the meter constant according to the following formula:

$$THR = \frac{2^{16}}{K_M \times I_{FS} \times V_{FS} \times t_{FR}}$$

In this formula, THR is the value to be written to the threshold register,  $K_M$  is the desired meter constant (in pulses per kilowatt hour), IFS and VFS are the full-scale voltage and current, respectively, and tFR is the frame period in units of hours, as in the previous calculation.

As an example, assume once again a full-scale voltage value of 558.1V = 0.5581kV, a full-scale current value of 102.4A, a desired meter constant of 1600 pulses per kilowatt hour, and a default frame time of  $360\mu s$  ( $88.9 \times 10^{-9}$  hours). The threshold register value can be calculated as:

$$65,536/(1600 \times 102.4 \times 0.5581 \times 100 \times 10^{-9}) = 7,167,174 = 0 \times 6D5CC6$$

Increasing the value of the threshold register *reduces* the meter constant (that is, there are fewer pulses per kilowatt-hour); reducing the threshold register *increases* the meter constant (that is, there are more pulses per kilowatt-hour.)

#### Interrupts

The MAXQ3183 contains an interrupt subsystem to relieve the host processor of the burden of constantly polling the device for status. Instead, under certain circumstances, the MAXQ3183 can activate an external pin to alert the host processor that some condition requiring host attention has occurred.

Interrupts are managed globally by the IRQ\_MASK and IRQ\_FLAG registers. In general, when a bit becomes set in the IRQ\_FLAG register, an interrupt is generated if the corresponding bit is set in the IRQ\_MASK register.

Interrupts can be configured for the following conditions:

**PWRF:** This flag indicates the V<sub>DVDD</sub> to the MAXQ3183 has fallen below its nominal operating threshold (about 2.85V). This can be taken as an indication that power failure is imminent and that the host processor should begin taking steps to ensure an orderly shutdown.

**CHSCH:** This flag indicates that the CHKSUM register changed its value.

**EOVF:** Energy overflow. This flag indicates that one or more energy accumulators (X.EAPOS, X.EANEG, etc.) have overflowed. In a traditional meter, the host processor would poll the MAXQ3183 to determine which of the energy accumulators have overflowed and adjust its internal accounting registers accordingly.

**ISUMOVF:** The vector sum of currents over the most recent DSP cycle has exceeded the vector sum threshold.

**OC:** The RMS current value on one or more of the phases over the most recent DSP cycle has exceeded the value set in the OCLVL register.

**OV:** The RMS voltage on one or more of the phases over the most recent DSP cycle has exceeded the value set in the OVLVL register.

**UV:** The RMS voltage on one or more of the phases over the most recent DSP cycle has failed to exceed the value set in the UVLVL register.

**NOZX:** Zero crossings were not detected on one or more of the phases during the DSP cycle.

**DCHA:** Tells the host processor that the direction of net real energy flow on one of the three phases has changed during the current DSP cycle as compared to the previous DSP cycle.

**DCHR:** Tells the host processor that the direction of net reactive energy flow on one of the three phases has changed during the current DSP cycle as compared to the previous DSP cycle.

**DSPRDY:** Indicates that the latest DSP cycle has just completed.

**DSPOR:** Indicates that the processing for the previous DSP cycle had not been completed before the current DSP cycle became available for processing. This overflow indication should never be seen in the default configuration; however, under some conditions (faster ADC rate, slower CPU clock) the processing requirements may exceed the number of CPU cycles available for DSP processing. Under these circumstances, the clock rate may be increased, the ADC rate may be reduced (that is, the R\_ADCRATE register may be increased), or the functional load (such as fundamental mode calculations) may be cut.

Note that when DSPOR becomes set, all DSP calculations as well as all pulse outputs are invalidated. The appropriate host response is to take the remedial action described above and discard the current set of DSP result values.

Each phase has a local register that contains copies of the OC, OV, UV, NOZX, DCHA, and DCHR bits. Thus, to determine which phase(s) have exception conditions requires four reads: the IRQ\_FLAG register to determine which conditions are active that are causing the interrupt to occur, and then a read to A.FLAGS, B.FLAGS, and C.FLAGS to determine which of the phases have the indicated condition.

Finally, each phase has a pair of local registers that contain overflow flags for each energy accumulator. If the EOVF bit is set in the IRQ\_FLAG register, the host should then read the A.EOVER, B.EOVER, and C.EOVER registers to determine which of the phases have overflow conditions. If fundamental mode operation is enabled, the host should read A.EFOVER, B.EFOVER, and C.EFOVER as well. Each of these registers contains a bit for each of real and reactive energy in both positive and negative direction as well as apparent energy.

#### Overvoltage and Overcurrent Detection

The MAXQ3183 detects overvoltage and overcurrent events and can issue interrupt request signals to the master when these events occur. The overvoltage level can be programmed into the OVLVL register, while the overcurrent level is determined by the OCLVL register. Both OVLVL and OCLVL registers represent the bits 23:8 of the VRMS or IRMS registers. Any time the MAXQ3183 detects the RMS-value exceeding a threshold level, the OV or OC interrupt flag is set. If enabled, any of these flags issues an interrupt request. All interrupt flags are "sticky" bits—the MAXQ3183 never clears them on its own unless a reset occurs. The interrupt flags should be cleared by the master by writing the appropriate register.

#### **Meter Units to Real Units Conversion**

All energy calculations, including various threshold checks, are performed internally in fixed format in meter units. Therefore, the threshold values must be supplied by the user in meter units as well. This section summarizes how to convert real units (V, A, kWh, W, and kAh) into meter units and vice versa.

The conversion factors are based on the settings of tFR, VFS, and IFS, defined by the user's design.

tfR is analog scan frame timing. This parameter is defined by the R\_ADCRATE setting and system clock frequency fsys:

 $t_{FR} = (R\_ADCRATE + 1) \times 8/f_{SYS}$ 

Default conditions are  $R\_ADCRATE = 359$ ,  $f_{SYS} = 8MHz$ .

N/IXI/N

VFS is full-scale voltage. This is the input voltage that produces full-scale ADC output; defined by the hardware voltage transducer ratio VTR and ADC full-scale input voltage VFSADC:

VFS = VFSADC x VTR

Default conditions are  $V_{FSADC} = 1.024V$ .  $V_{TR}$  is design dependent.

IFS is full-scale current. This is the input current that produces full-scale ADC output; defined by the hardware current transducer ratio ITR and ADC full-scale input voltage VFSADC:

IFS = VFSADC x ITR

Default conditions are VFSADC = 1.024V. ITR is design dependent.

Meter units are defined with respect to the base parameters as shown in Table 5.

When reading virtual registers, the MAXQ3183 uses the configurable conversion coefficients AMP\_CC, VOLT\_CC, PWR\_CC, and ENR\_CC to return meaningful data. Table 6 describes how to set the coefficients.

#### **Table 5. Meter Unit Definitions**

| REGISTER OR ACCUMULATOR                                                                                                                                                                           | METER UNIT (1 LSB)                                    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|
| Current RMS: X.IRMS                                                                                                                                                                               |                                                       |
| Pulse output current RMS                                                                                                                                                                          | $MU\_AMP = IFS/2^{24}$                                |
| THR1 or THR2, when pulse output configured to IRMS                                                                                                                                                |                                                       |
| Voltage RMS: X.VRMS                                                                                                                                                                               |                                                       |
| Pulse output RMS voltage                                                                                                                                                                          | $MU_VOLT = V_{FS}/2^{24}$                             |
| THR1, or THR2 when pulse output configured to VRMS                                                                                                                                                |                                                       |
| Energy: X.ACT, X.REA, X.APP, X.EAPOS, X.EANEG, X.ERPOS, X.ERNEG, X.ES Fundamental Energy: X.ACTF, X.REAF, X.APPF, X.EAFPOS, X.EAFNEG, X.ERFPOS, X.ERFNEG, X.ESF Pulse Output Energy: THR1 or THR2 | $MU\_ENR = V_{FS} \times I_{FS} \times t_{FR}/2^{16}$ |
| Power: PWRP.X, PWRQ.X, PWRS.X                                                                                                                                                                     | MU_PWR = VFS x IFS/2 <sup>32</sup>                    |
| When X.ESF Contains Amp-Hours: X.ESF                                                                                                                                                              | $MU\_AH = IFS \times tFR/2^{16}$                      |
| OCLVL, NOLOAD, I1THR, I2THR                                                                                                                                                                       | I <sub>FS</sub> /2 <sup>16</sup>                      |
| OVLVL, UVLVL                                                                                                                                                                                      | VFS/2 <sup>16</sup>                                   |

#### **Table 6. Virtual Register Coefficients**

| VIRTUAL REGISTER                                                | OUTPUT RESOLUTION<br>(1 LSB), DEFINED BY USER | COEFFICIENT                |
|-----------------------------------------------------------------|-----------------------------------------------|----------------------------|
| Power:<br>PWRP.X, PWRQ.X, PWRS.X, PWRPF.X,<br>PWRQF.X, PWRSF.X  | PWR_LSB                                       | PWR_CC = MU_PWR/PWR_LSB    |
| Voltage:<br>V.X                                                 | VOLT_LSB                                      | VOLT_CC = MU_VOLT/VOLT_LSB |
| Current: I.X                                                    | AMP_LSB                                       | AMP_CC = MU_AMP/AMP_LSB    |
| Energy:<br>ENRP.X, ENRQ.X, ENRS.X, ENRPF.X,<br>ENRQF.X, ENRSF.X | ENR_LSB                                       | ENR_CC = MU_ENR/ENR_LSB    |



Figure 13. Sample Voltage Input Circuit

#### **Units Conversion Examples**

The conversions from meter units to physical units are illustrated with the simplified input circuits in Figures 13 and 14. The voltage input circuit is a voltage-divider. Current input is through a current transfer with turn ratio of 2000:1.

The voltage transducer ratio  $(V_{TR}) = (R1 + R2)/R2 = 545$ ,  $V_{FS} = 558.1V$ .

The current transducer ratio (ITR) =  $CT_N/(2 \times R)$  =  $2000/(2 \times 10) = 100 (A/V)$ , IFS = 102.4A.

The input circuits should be designed to avoid getting too close to the ADC input full scale at the specified maximum ratings. So for the above circuits, we would specify the maximum input current = 70A (RMS) and maximum voltage = 390V (RMS), to ensure that peak of sinusoudal waveform never exceeds IFS or VFS.

Use the default ADC timing  $t_{FR} = 360\mu s$ , we get the following meter unit to physical unit conversion coefficients (these coefficients are not part of the MAXQ3183 registers):

$$\begin{split} \text{MU\_AMP} &= \text{IFS/2}^{24} = 6.1\text{E-6 (A)} \\ \text{MU\_VOLT} &= \text{VFS/2}^{24} = 33.3\text{E-6 (V)} \\ \text{MU\_PWR} &= \text{VFS} \times \text{IFS/2}^{32} = 13.3\text{E-6 (W)} \\ \text{MU\_ENR} &= \text{VFS} \times \text{IFS} \times \text{tFR/2}^{16} = 87.2\text{E-9 (Wh)} \end{split}$$

For example, if we get 0x07654AF0 from reading 0x1CC register (phase A current RMS), the current value it represents is

$$0x07654AF0 \times MU\_AMP = 47.33 (A)$$

For some low-end host microcontrollers, doing the above math multiplication above could be difficult. For this reason, the MAXQ3183 provides conversions for some commonly needed parameters through the VOLT\_CC, AMP\_CC, PWR\_CC, and ENR\_CC registers.

For example, if you want to display current in the resolution of 1mA, without having to use a multiplication



Figure 14. Sample Current Input Circuit

operation to convert from the meter unit value 0x07654AF0, you would set AMP\_CC to 0x0190, and read from virtual register 0x831 (phase A RMS current). The output would be 0xB8E45170. Dropping the lower 2 bytes (right shifting 16 bits) gives 0xB8E4, or 47332 decimal (47332mA).

AMP\_CC is computed as follows:

$$AMP\_CC = (IFS/2^{24})/AMP\_LSB = MU\_AMP/AMP\_LSB$$
 
$$AMP\_LSB = 0.001/2^{16} (A)$$
 
$$IFS = 102.4A$$
 
$$AMP\_CC = (102.4/2^{24})/(0.001/2^{16}) = 400d = 0x0190$$

#### **Calibration Procedure**

#### **Calibration Overview**

Calibration ensures that the recorded voltage, current, energy, and power are in accordance with the design criteria. Before creating a calibration regimen, establish the fundamental units of the meter: the full-scale voltage and current. Then adjust the gain registers using calculated calibration constants to produce the expected reading in the raw current, voltage, energy, and power factor registers.

The calibration constants should be stored in non-volatile memory by the host microcontroller. Upon any reset or loss of power, the host microcontroller must reload the MAXQ3183 with the constants.

Calibration always follows a set of fundamental steps:

- Apply a known signal (voltage/current/power) to the meter.
- · Read the meter.
- Calculate the correction factor based on the difference between the applied signal level and the meter reading.
- Write the correction factor to the appropriate register.

Read the meter quantity again to verify the calibration

Note that these steps can occur more than once for a given signal type to verify readings at different signal levels.

There are two methods to read the meter in the above second step. The first is to read the raw register associated with the value under calibration, for example, A.VRMS for the phase A voltage channel; A.IRMS for the phase A current channel, and A.ACT for phase A real power.

The second calibration method assigns a pulse output to the value being calibrated and measures the pulse period. In practical use, the method chosen depends on the specific application and the available equipment. For example, in some applications the voltage and current are of no concern, but the energy accumulation must be very accurate. For these applications, meter calibration sets with built-in pulse measurement facilities can make the most sense.

The calibration procedure involves the following general steps:

- Calibrate voltage for a given phase by applying a known voltage and adjusting the voltage gain (A.V\_GAIN for phase A) until the RMS voltage (A.VRMS for phase A) reads the applied voltage in the designated units.
- Calibrate current by applying a known current and adjusting the current gain (A.I\_GAIN for phase A) until the RMS current (A.IRMS for phase A) reads the applied current in the designated units. If desired, the current can be calibrated at two points (low range and high range) for more accuracy.
- Once the current gain and voltage gain are calibrated, the power/energy should not require any additional adjustment for most situations. Although, a separate power gain register is available for further fine-tuning of the power/energy accuracy. One must keep in mind that anytime voltage or current is recalibrated, the power or energy accuracy is naturally affected. So the power gain should be recalibrated to achieve the desired accumulative effect of voltage, current, and power gains.
- Calibrate the phase offset by applying a power factor load and adjusting the phase angle offset accordingly. If desired, the phase offset can be calibrated at up to three points for more accuracy.

Once these elements are calibrated for each phase, all other information (power factor, reactive power, apparent power, etc.) is also properly calibrated. The

descriptions in the following sections deal specifically with phase A, but the same procedure is followed with phases B and C.

#### **Calibrating Voltage**

Ensure that there is no previous value in the gain register, A.V\_GAIN, by setting this register to 0x4000.

- Apply a known voltage with RMS value close to the desired maximum operating voltage (and less than VFS/√2).
- Read the A.VRMS register. Note the value.
- Convert the known value to meter units by dividing it by MU\_VOLT (= VFS/2<sup>24</sup>).
- Divide the applied value (in meter unit) by the value read from the MAXQ3183. The result should be a value between 0 and 2. If the value falls outside of this range, you have probably miscalculated VFS.
- Multiply the calculated value by 2<sup>14</sup>. The result is the gain value to be programmed into A.V\_GAIN. Ensure the most significant bit is 0.

When the gain value is programmed, wait for 2 to 3 seconds, reread the RMS value from A.VRMS. Check that the measured value is correct by comparing A.VRMS against the applied voltage in meter unit.

#### **Voltage Calibration Example**

Assumptions:  $V_{FS}$  is 558.1V. The applied voltage is 240 VRMS.

- Convert the applied voltage to meter units. This calculation gives 240 x 2<sup>24</sup>/558.1 = 7,214,714 = 0x006E1679.
- Read the A.VRMS register. You read 0x0708029. This is 7,372,841 decimal.
- Divide the applied voltage by the voltage read from the meter. The result is 7,214,714/7,372,841 = 0.97855.
- Convert to integer by multiplying 2<sup>14</sup>: 16,384 x 0.97855 = 16,033 = 0x3EA1. Write this value to the A.V\_GAIN register.

#### **Calibrating Current**

Ensure that there is no previous value in the gain register, A.I\_GAIN, by setting this register to 0x4000.

- Apply a known current with RMS value close to the desired maximum operating current (and much lower than IFS/√2).
- Read the A.IRMS register. Note the value.
- Convert the known value to meter units by dividing it by MU\_AMP (= IFs/2<sup>24</sup>).

- Divide the applied value (in meter unit) by the value read from the MAXQ3183. The result should be a value between 0 and 2. If the value falls outside of this range, you have probably miscalculated IFS.
- Multiply the calculated value by 2<sup>14</sup>. The result is the gain value to be programmed into A.I\_GAIN. Ensure the most significant bit is 0.

When the gain value is programmed, wait for approximately 2 to 3 seconds, then reread the RMS value from A.IRMS. Check that the measured value is correct by comparing A.IRMS against the applied current in meter unit

#### **Current Calibration Example**

Assume IFS is 102.4A and the meter has a base current of 10A and a maximum current of 60A.

- The meter is calibrated at the base current of 10A.
- Convert the applied current to meter units. This calculation gives 10 x  $2^{24}/102.4 = 1,638,400 = 0x00190000$ .
- Read the A.IRMS register. You read 0x0017DC85.
   This is 1,563,781 decimal.
- Divide the applied current by the current read from the meter. The result is 1,638,400/1,563,781 = 1.0477.
- Multiply by 2<sup>14</sup> x 1.0477 = 17,166 = 0x430E. Write this value to the A.I\_GAIN register.

#### **Calibrating Phase Offset**

For this calibration step, it is necessary to have a power factor meter, capable of measuring phase angle, connected in the same circuit as the MAXQ3183 meter. Note that calibration can be performed at any precision power factor setting. We use a pure resistive load (PF = 1.0) load to illustrate the procedure.

- Apply a resistive load to the meter; the current drawn by the load should correspond to the base current of your meter.
- Record the phase angle and direction (capacitive or inductive) reported on the power factor meter.
- Read and record the real and reactive energy from the X.ACT and X.REA registers. Divide the reactive energy by the real energy. This is the tangent of the power-phase angle.
- Read the X.REA register. If the high-order bit is set, the power factor reported in the above step is capacitive. If the high-order bit is clear, the power factor reported in the above step is inductive.
- Now determine the correction factor: treating capacitive values as negative and inductive values as positive, subtract the angle read from the MAXQ3183

- from the angle read from the reference meter. The result is the compensation angle.
- Multiply the compensation angle (in radians) by 65,536. This is the value to write into X.PA0.

If I1THR and I2THR are left at their default values (0x0000), then the value in X.PA0 is applied to the full measurement range. Alternatively, you could write the same value into X.PA0, X.PA1, and X.PA2. Then the same compensation is applied through the whole measurement range regardless of the I1THR and I2THR settings. If desired, calibrate for the phase angle at up to three different current levels to compensate for nonlinearity in the current sensor. See the *Advanced Operation* section for more information.

#### **Phase Offset Calibration Example**

Assume the meter is a 10/60 meter; that is, the base current is 10A and the maximum rated current is 60A. IFS is 102.4A and VFS is 558.1V. The test point is 10A and 240V.

- Connect the MAXQ3183-based meter under test in series with a lab grade reference meter. See the configuration below.
- Apply power to the meter and apply a load of 10A resistive.
- Verify that the I1THR, I2THR, A.PA0, A.PA1, and A.PA2 registers contain zero.
- Read the power factor on the reference meter. You read 1.5° capacitive. This is not unusual. The load might not be truly resistive or reactance in the test configuration could be reflected in the measurement.
- Read the real energy from register A.ACT (0x1D0). You read 0x2865D6 (2,646,510 meter units).
- Read the reactive energy from register A.REA (0x1D4). You read 0xFFFFA5C0 (-23,104 meter units).
- Divide the reactive by the active power: -23,104/ 2,646,510 = -0.009.



Figure 15. Offset Testing Setup

- Take the inverse tangent of this value. You get -0.5°; that is, 0.5° capacitive.
- Subtract the UUT phase offset from the reference meter phase offset. In this case, the phase needs to move 1° toward the capacitive. Convert this value to radians: 1° x π/180° = 0.0175 radians.
- Multiply this value by 65,536. The result is 572 (0x023C).
- Because the phase correction is toward the capacitive, the value must be complemented. The two's complement of 0x023C is 0xFDC4. This is the value that should be written to the PA0 phase compensation register.

At this point, the meter is compensated for a single phase offset. If the phase offset were perfectly flat over all current levels, that would be sufficient (and for many current sensors, particularly current shunts, one point is usually good enough.)

### Interfacing the MAXQ3183 to\_ External Hardware

The MAXQ3183 has all the internal circuitry that is needed for a sophisticated electricity meter, but specific external hardware is required when configuring the meter for a particular application. The most critical decision that must be made is how the load will be connected to the power source, and how the meter will be connected to measure power consumed in the load. This section covers how to select hardware components for a MAXQ3183 electricity meter.

#### **Connections to the Power Source**

Generally, three-phase power as delivered from the utility consists of four wires: three voltage phases and a neutral wire. In one typical three-phase delivery system, measuring from neutral to any phase would read 120V, while measuring from any phase to any other phase would read 208V. Connecting a load so that load current is taken from phase lines and returned to neutral is called a wye-connected load. Connecting a load so that load current is provided by one phase and returned on another phase is called a delta-connected load. The MAXQ3183 can measure power consumed in either a wye-connected or a delta-connected load.

If the load is connected in a wye fashion, the voltage is measured from the neutral lead to each of the phases, and the current measuring device is placed in series with the load, most often in the hot lead. The sensor is not placed in the neutral lead to prevent a customer from defrauding the utility by returning the current to ground rather than neutral. A current sensor placed in the hot lead makes fraud even more difficult.

A delta-connected load can have current measured in two possible ways. If it is primarily desirable to know how much power is delivered to the load, one can place the current sensor in the load circuit between two phases. But if it is more important to know how much current is being drawn from each supply phase, each current sensor is placed in the line circuit of each single phase.

Most utilities are only concerned with the total amount of energy being consumed. If individually accounting for the power delivered by each phase is not a requirement, it is not necessary to measure all three voltages. Instead, knowing only two voltages and the three currents is all that is necessary to measure total energy usage.

There are several ways of doing this. In a wye arrangement, one of the phases—usually phase B—can be considered the voltage reference point instead of neutral. Then the voltage measurements can be made from phase A to phase B and from phase C to phase B. By using some simple arithmetic, the power delivered by phase A, phase B, and phase C can be calculated even though only two voltages are available.

A second mechanism is to have a delta-connected load, but with one leg—usually the BC leg—split into two equal loads. The point where the load is split is defined as the reference. In this arrangement, it is only necessary to know the voltage between phase C and the split and phase A and the split, since  $V_C = -V_A$ .

Finally, there is the connection arrangement in which the load is in a delta configuration with the current sensor at each load, but it is still desired to determine how much current is in each supply branch. The MAXQ3183 supports all of these connection arrangements.

#### Sensor Selection

The MAXQ3183 supports a variety of voltage and current sense elements. This section describes the properties of many of these sensing devices.

### Voltage Sensors

#### Voltage-Divider

A voltage-divider is an ideal voltage-sensing element when there is no need for voltage isolation. Modern resistors have virtually no parasitic capacitance or inductance at the frequencies of interest in an electricity meter and have extremely low variation with temperature. When selecting resistors for a voltage-divider, keep the division ratio high enough so that the peak voltage value cannot exceed the maximum allowable input voltage. In the MAXQ3183, the peak input voltage is about 1V; consequently, a divider in the range of 400:1 to 600:1 is ideal.

The second consideration is the total power dissipation and voltage hold-off requirements of the resistor. It is tempting to design a 400:1 divider with a 400k $\Omega$  resistor in series with a 1k $\Omega$  resistor, but that would force the 400k $\Omega$  resistor to dissipate about 140mW. This is not an excessive amount of power, but if the design is to use small SMT parts, it can handle greater than a 1/10W SMT resistor. It is better to use a series of several smaller components to improve system reliability.

#### Voltage Transformer

If isolation is required between the meter electronics and the line, a voltage transformer is required. A voltage transformer is designed to faithfully transfer an AC voltage applied on the primary side to a sensor on the secondary side. On the primary side, a voltage-divider is used to reduce the voltage to a workable level. On the secondary side, a load resistor is selected so that the current in the transformer windings is safely within the transformer's linear operating region.

Because the impedance seen in the primary side of the transformer is equal to the impedance of the load resistor in the secondary circuit plus impedance of the transformer secondary winding at the operating frequency, it is easy to calculate the value of the required voltage-divider resistors in the primary side. For example, assume we want a 500:1 divider ratio and assume the load resistor is  $600\Omega$  and that the impedance of the transformer secondary is  $200\Omega$ . The resistor required in the primary is

$$(600 + 200) \times 500 = 400 \text{k}\Omega$$

Often, this resistor is constructed from multiple instances of a smaller value resistor; in this case, one might use eight  $50k\Omega$  resistors. Doing so minimizes the voltage requirements for the resistor chain and reduces the possibility that a single point of failure will cause a catastrophic failure.

#### **Current Sensors**

#### **Current Shunt**

A current shunt is a low-value (approximately  $100\mu\Omega$  to a  $100m\Omega$ ) resistor that converts a large-value current into a small voltage. Shunts make good current sensors because the output is an extremely linear representation of the measured current, current shunts can have very low temperature coefficients, and they are inexpensive.

The power dissipated by a current shunt is inversely proportional to its resistance and proportional to the square of the output voltage. Consequently, there is great incentive to reduce the resistance (and hence, the output voltage) of a shunt. Often, full-scale current

in a shunt produces only a few millivolts of output, making a front-end amplifier essential. The MAXQ3183 includes a gain-of-32 amplifier in the current channels that is automatically cycled in and out, depending on the input voltage of the current channels.

Current shunts operate at line voltage, thus, the AFE must be isolated from the line. That means that in a wye-connected meter, the current sensing must be performed in the neutral return circuit (so that all voltages into the current-sense amplifiers are referenced to neutral). It also means that the use of a shunt is precluded for delta-connected meters; the MAXQ3183 cannot tolerate the line-voltage differential between channels.

#### **Current Transformer**

In a current transformer, the primary is usually one turn of thick wire or buss bar and the secondary is often 1000 turns or more of magnet wire. A ferrite core magnetically couples the two. Thus, a large current in the primary turn creates a small current but large voltage in the secondary winding.

For example, assume a current transformer with a 1000 turn secondary. A 10A current in the primary winding induces a 10mA current in the secondary. This current is made to flow through a so-called "burden" resistor, usually  $10\Omega$  to  $20\Omega.$  Assuming a  $20\Omega$  burden, our 10A current thus produces a 200mV signal in the secondary.

### Advanced Operation

### Modifying the ADC Operation

There are several other registers that directly affect the AFE function. These registers directly affect the hardware functionality, and should be modified only when it is explicitly required. For example, if the MAXQ3183 is operated at some frequency other than the nominal 8MHz system clock, modification of these registers by supervisory code becomes necessary to maintain a 360µs frame time.

- R\_ACFG: This register contains bits that disable the ADC entirely, disable the voltage reference buffer amplifier, and disable the ADC interrupt. Modifying this register will likely disable or impair operation of the MAXQ3183 internal firmware.
- R\_ADCRATE: Modify this register to change the rate at which the MAXQ3183 acquires samples. By default, R\_ADCRATE contains 359 decimal, which means that the ADC acquires a sample every 360 system clocks. With an 8MHz clock, this translates to 45µs. If the system clock is slower, it may be advantageous to reduce this value to keep a 45µs per sample time constant.

\_ /N/IXI/N

• **R\_ADCACQ:** Modify this register to change the acquisition time. The acquisition time is the time from ADC power-on until conversion starts, and is provided to allow the input amplifiers to settle. By default this is set to 47 decimal, or 6µs at an 8MHz system clock. If the system clock rate is changed, then R\_ADCACQ should change so that this value remains about 6µs.

#### Fine-Tuning the DSP Controls

#### Fine-Tuning the Line Frequency Measurement

Line frequency measurement is based on zero-crossing detection. For that purpose each voltage signal is passed through a digital lowpass filter, controlled by the ZC\_LPF register. This register specifies the bo coefficient of a first-order LPF using following formula:

$$b_0 = \frac{ZC\_LPF}{2^{16}}$$

The MSB of this register must be zero.

For each phase A, B, and C, the MAXQ3183 counts the number of scan frames (NS) between zero crossings within a DSP cycle. Each individual phase A, B, or C zero-crossing event contributes the raw NS count that plugs as input to lowpass filter:

$$Y_n = Y_{n-1} + (AVG_NS/65,536) \times (X_n - Y_{n-1})$$

The filter coefficient is a signed 16-bit value and can be configured by master. Here Y denotes the global NS value, X denotes individual NS measurements produced by zero-crossing events detected on the phase A, B, or C voltage channel. Note that if all three phase voltages present, the filter above receives three inputs each DSP cycle. The global NS value is used to generate the trigger for DSP processing. Note that the NS value can be configured by the master, which could be necessary if all three voltage signals are lost and no zero-crossings are detected. The line period is then calculated as a product of NS and the scan frame  $t_{\rm FR}$ . The reciprocal of this value is the line frequency, which can be obtained as a fixed-point value with 1 LSB = 0.001Hz by reading the LINEFR register.

#### Fundamental Mode Registers

The MAXQ3183 keeps another set of real and virtual registers to track power and energy at the fundamental line frequency. These "fundamental mode" registers behave identically to the standard power and energy registers, but are prefiltered to exclude harmonic power.

The fundamental mode filter is specified in the B0FUND and A1FUND registers. B0FUND is the feed-forward coefficient and specifies the bandwidth of the fundamental mode filter; A1FUND is the feedback coefficient and specifies the center frequency of the fundamental mode filter.

In most cases, you can leave these filters at their default values. If you wish to change the filter parameters, first choose the desired bandwidth:

$$b_0 = \pi \times bw \times t_{FR}$$

In this equation, bw is the desired bandwidth in hertz and  $t_{FR}$  is the frame period, typically 360µs. Set B0FUND to  $b_0 \times 2^{16}$ . By default, B0FUND contains decimal 145 (0x91) giving a bandwidth of about 2Hz.

To set the center frequency, calculate a<sub>1</sub> according to the following formula:

$$a_1 = 2 - 2(1 - b_0) \times \cos(2\pi \times f_{PK} \times t_{FR})$$

In this equation,  $b_0$  is the previously calculated feed-forward coefficient,  $f_{PK}$  is the desired center frequency in hertz, and  $t_{FR}$  is the ADC frame period. Set A1FUND to  $a_1 \times 2^{16}$ . By default, A1FUND contains decimal 950 (0x3B6) giving a center frequency of approximately 50Hz.

The fundamental mode filter is, by default, quite sharp with 3dB points only 1Hz off of the center frequency. This means that if the frequency drifts even only slightly, the fundamental mode power measurement is likely to have significant inaccuracy.

The MAXQ3183 provides a mechanism to track the frequency by updating the A1FUND register on each DSP cycle. This mechanism is automatically enabled by default.

You may wish to disable the automatic tracking facility under some circumstances, particularly if you have defined a broader bandwidth than default and are comfortable that the frequency will not drift beyond the passband. To disable the filter, set the DFUNA bit in the OPMODE2 register.

You may also elect to disable fundamental mode operation completely. To do this, set the DFUN bit in the OPMODE2 register.

#### **Harmonic Measurement**

In addition to the ability to measure power and energy at the fundamental frequency, the MAXQ3183 provides a mechanism to isolate a particular harmonic on any voltage or current channel and measure the amplitude of that harmonic.

To enable harmonic measurement, first select a voltage or current channel to monitor. This is done in the AUX\_CFG register. The AUX\_MUX field is the 4-bit value that selects one of the three voltage channels or one of the four current channels to monitor.

The order of the harmonic is set in ORDH field of the AUX\_CFG register.

Also in the AUX\_CFG register are two bits that enable the auxiliary channel and enable harmonic measurement on the auxiliary channel. To enable the auxiliary channel, set the ENAUX bit. Once set, the MAXQ3183 will perform an RMS calculation on the selected channel. This is useful only for the IN (neutral current) channel, since every other voltage and current already have RMS calculations applied by default. (The DADCNV bit should be cleared in the SCAN\_IN register in order to enable sampling the IN channel.)

To enable harmonic measurement, set the ENHARM bit. Now, the selected voltage or current signal is passed to a filter that is identical to the second-order fundamental filter, but that has separate parameters (A1HARM, B0HARM).

#### Current Total Harmonic Distortion Plus Noise (THDN)

The MAXQ3183 can output the THDN ratio for selected current channel on-demand. It is calculated as:

$$THDN.X = \frac{X.IRMS^2}{X.IRMS_{fund}^2} - 1$$

This represents the ratio of the power of harmonics plus noise over the power of the fundamental signal. To activate THDN computation, the host must first configure the AUX channel to produce first harmonic (fundamental) on the desired current channel:

- Set AUX\_CFG = 0x01C3 for current phase A
- Set AUX\_CFG = 0x01C5 for current phase B
- Set AUX\_CFG = 0x01C7 for current phase C

Then the THDN ratio can be read from one of the following virtual registers:

- Register 0x859 returns THDN.A for current phase A
- Register 0x85A returns THDN.B for current phase B
- Register 0x85C returns THDN.C for current phase C

Each register returns a raw binary value representing the THDN ratio with LSB =  $2^{-32}$ . Since computation involves signal filtering, the value THDN could require a few seconds to settle before producing stable output.

#### **Current Vector Sum**

The MAXQ3183 supports two forms of current vector sum calculations depending on whether neutral current I<sub>N</sub> is available:

$$IVS3(t) = IA(t) + IB(t) + IC(t)$$

or

$$I_{VS4}(t) = I_{A}(t) + I_{B}(t) + I_{C}(t) + I_{N}(t)$$

The sum must be calculated on instantaneous sample basis. In a balanced 3-phase system, the vector sum Ivs3 should be zero; a nonzero value indicates a current unbalance. When neutral current available, vector sum Ivs4 should be always zero, no matter balanced or unbalanced loads; a nonzero value indicates tamper (energy theft) or wrong meter connection. In the MAXQ3183, the samples for IA, IB, IC, and IN are not simultaneous, therefore the device automatically applies an allpass filter to IB, IC, and IN before calculating vector sum.

The MAXQ3183 calculates the RMS value of Ivs3 or Ivs4 on-demand using the AUX channel. To activate vector sum computations, the host must set following configuration bits:

For IVS3:

- 1) AUX CFG.ENAUX = 1—to enable the AUX channel
- 2) AUX\_CFG.AUX\_MUX = 1001b (0x9)—select IA + IB + IC input to the AUX channel

The above settings result in AUX\_CFG = 0x0049.

For Ivs4:

- 1) SCAN\_IN.DADCNV = 0—to enable ADC sampling neutral current IN (SCAN\_IN = 0x60)
- 2) AUX CFG.ENAUX = 1—to enable the AUX channel
- 3) AUX\_CFG.AUX\_MUX =1111b (0xF)—select IA + IB + IC + IN input to the AUX channel

The above settings result in AUX\_CFG = 0x004F.

Once the above configuration is set, the MAXQ3183 starts accumulating the specified vector sum. The result can then be read from the N.RMS register as raw value or from I.N virtual register as converted value. If the averaging filter is enabled (AVG\_C > 0), the value could require a few seconds to settle before producing stable output. The MAXQ3183 has an additional control bit AUX\_CFG.INREV to reverse the sign of IN current. When the bit is set (AUX\_CFG = 0x006F), the MAXQ3183 calculates the value (IA + IB + IC - IN) instead of (IA + IB + IC + IN). Doing so allows vector sum computation in case of reverse connection of neutral current sensor.

A threshold (ISUMLVL, address 0x054) can also be specified to cause the MAXQ3183 to generate an interrupt when the vector sum exceeds the threshold.

#### **Low-Power Measurement Mode (LOWPM)**

This mode enables a subset of metering functions while operating from the lower frequency internal RC oscillator to conserve power. The actual system clock frequency used is the RC oscillator output frequency divided by 8, which results in a system clock frequency of approximately 1MHz.

The parameters provided in the LOWPM are:

- Voltage RMS
- Current RMS
- Ampere-Hour

The ampere-hour value is readable from the X.ESF registers (X = A/B/C). Entry to LOWPM mode only occurs at the request of the master. The master must set the LOWPM\_E bit (register address 0xC03) to 1 to place the MAXQ3183 into LOWPM mode. Entering LOWPM mode changes the clock frequency, thereby invalidating a number of configuration registers. As a result, the master must immediately reload the configuration registers and filter with new, updated values before metering measurement operations can continue.

The master instructs the MAXQ3183 to exit LOWPM mode by reading the LOWPM\_X bit (register address 0xC04).

#### Temperature

The MAXQ3183 contains a temperature sensor that can be used by host software for any purpose, including compensating power readings for temperature effects. Use the virtual register command (TEMP\_C, address 0xC01) to perform a temperature conversion. The MAXQ3183 returns the value in degrees Celsius, with a resolution of 1°C. Internally, the MAXQ3183 performs a temperature sensor read and scales the sensor output by the TEMP\_CC (address 0x060) coefficient to provide an output in degrees Celsius. The conversion formula is:

TEMP C = RAW TEMP x TEMP CC/
$$2^{16}$$
 - 273.15

Where RAW\_TEMP is raw digitized temperature sensor output that is proportional to absolute temperature. Conversion coefficient TEMP\_CC must be calibrated and set by the host; the default value is 0x0000.

### **Advanced Calibrations**

#### Calibrating Current Offset

Ideal hardware should produce a current reading linearly proportional to the input current. However, due to noise or other factors, the RMS current read by the meter might not be precisely linear. The current offset

 $(X.OFFS\_HI, X = A/B/C)$  can be used to compensate the current channel nonlinearity.

Since the MAXQ3183 tracks the input current to determine what linearity compensation factors to use, the user must choose two points (i $_{lo}$  and i $_{hi}$ ) comfortably above the low current threshold, and get the X.IRMS current readings (r $_{lo}$  and r $_{hi}$ ). Then calculate the Y-intercept of the line drawn between the two points, that is, the offset. To calculate the value for the offset register, use the following formula:

offs = 
$$\frac{r_{hi}i_{lo} - i_{hi}r_{lo}}{2^4(i_{lo} - i_{hi})}$$

In this equation,  $i_{hi}$  and  $r_{hi}$  are the applied current and the current reading, respectively, in meter units at the higher of the two reference currents;  $i_{lo}$  and  $r_{lo}$  are the applied current and the current reading, respectively, in meter units at the lower of the two reference currents.

The gain (X.I\_GAIN) may require recalibration after the offset register updated.

#### Calibrating Linearity

The current channel includes a variable-gain amplifier that introduces a gain of 32 when the current falls below the low current threshold (about 1/32 of full-scale current IFS). Because the gain of the amplifier cannot be controlled with arbitrary precision, and because high gain implies increased noise, it may be necessary to calibrate the MAXQ3183 to maintain linearity at the lowest inputs.

There are two settings that manage low-current linearity: an offset setting, OFFS\_LO; and a gain setting, GAIN\_LO. Setting the offset is simple. Ensure no current is flowing in the current circuit. Read X.IRMS. To calculate offset use following formula:

$$offs = -X.IRMS$$

Program the offs into the OFFS\_LO register.

So, if the user reads 0x0113 from the X.IRMS register, program 0xFEED into the X.OFFS\_LO register. Setting the X.GAIN\_LO register means applying a current below the low-current threshold, reading the value from the MAXQ3183, and adjusting the gain accordingly. Note that the low-end gain is applied in addition to the overall gain provided in the X.I\_GAIN register.

Apply a known current with peak value less than the low-current threshold. Ensure that there is no previous value in the low-current gain register, A.GAIN\_LO, by

setting this register to 0x4000. Read the A.IRMS register (0x1CC). Note the value. Convert the known value to meter units by multiplying the known value (in amperes) by 2<sup>24</sup> and dividing by IFS. Divide the results of this calculation by the value read from the MAXQ3183. The result should be a value between 0 and 2. Convert the integer by multiplying 2<sup>14</sup>, and ensure MSB is zero. The result is the gain value to be programmed into A.GAIN\_LO.

#### Calibrating Power/Energy Gain

Once voltage and current have been calibrated, the energy and power calculation automatically reflects the calibrated voltage and current. However the energy gain factor (X.E\_GAIN, X = A/B/C) can be further tuned to achieve even more accurate power and energy result if necessary. For example, if the voltage and current calibration sources are not as accurate as the power/energy calibration source, then the additional gain calibration may be necessary. The following procedure for power/energy gain calibration is outlined for phase A.

- Apply a precision unity power factor power (applied value) that is close to the desired normal operating point.
- Read the PWRP.A register. Note the value.

- Convert the applied value to meter units by dividing it by MU\_PWR.
- Divide the applied value (in meter unit) by the value read from the MAXQ3183. The result should be a value between 0 and 2. If the value falls outside of this range, IFS and/or VFS have probably been miscalculated.
- Multiply the calculated value by 2<sup>14</sup>, and ensure the MSB is zero. The result is the gain value to be programmed into A.E\_GAIN.
- When the gain value is programmed, wait for 1 to 2 seconds, then reread the power value from PWRP.A. Check that the measured value is correct by comparing PWRP.A against the applied power in meter unit.

#### Multipoint Phase Offset Calibration

To perform the calibration at three current levels, note the raw current value (X.IRMS) at each point. Label the current values, from highest to lowest, I<sub>0</sub>, I<sub>1</sub>, and I<sub>2</sub>. Program X.PAO, X.PA1, and X.PA2 with the phase offset values calculated at I<sub>0</sub>, I<sub>1</sub>, and I<sub>2</sub>, respectively, as described in the *Calibrating Phase Offset* section. Finally, program I1THR with the average of I<sub>0</sub> and I<sub>1</sub>, and program I2THR with the geometric average of I<sub>1</sub> and I<sub>2</sub>. Now as the current changes the phase offset is adjusted accordingly. See Figure 16.



Figure 16. Phase Offset vs. Input Current Calibration

\_ /VIXI/VI

### **Advanced Register Configurations**

### **Analog Scan Configuration Registers**

Time Slot Assignment—Current Channel X = A/B/C (SCAN\_IX) (A: 0x008, B: 0x00C, C: 0x00A)

| Bit:     | 7     | 6  | 5 | 4 | 3      | 2 | 1 | 0 |
|----------|-------|----|---|---|--------|---|---|---|
| Name:    | ADCMX |    |   |   | DADCNV | _ | _ | _ |
| Reset A: | 0x3   |    |   |   | 0      | 0 | 0 | 0 |
| Reset B: | 0x4   |    |   |   | 0      | 0 | 0 | 0 |
| Reset C: |       | 0× | 5 |   | 0      | 0 | 0 | 0 |

These registers configure the time slot normally assigned to current channels A/B/C. We recommend leaving these registers at their default values. If they must be reassigned, one must ensure that all the current and voltage channels are reassigned properly so that the MAXQ3183 computes the power/energy parameters as intended by your setup.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                               |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | ADCMX  | Analog Conversion Select. This four-bit field determines which of the following analog inputs are sampled during this time slot.  0000 = V0P - VN  0001 = V1P - VN  0010 = V2P - VN  0011 = I0P - I0N (Phase A Current: 0011)  0100 = I1P - I1N (Phase B Current: 0100)  0101 = I2P - I2N (Phase C Current: 0101)  0110 = INP - VN  1xxx = Temperature  All other values are reserved. |
| 3   | DADCNV | ADC Disable. When set, disables the ADC for this time slot.                                                                                                                                                                                                                                                                                                                            |
| 2:0 | _      | Reserved.                                                                                                                                                                                                                                                                                                                                                                              |

#### Time Slot Assignment—Voltage Channel X = A/B/C (SCAN\_VX) (A: 0x009, B: 0x00D, C: 0x00B)

| Bit:     | 7     | 6  | 5 | 4 | 3      | 2   | 1   | 0 |  |
|----------|-------|----|---|---|--------|-----|-----|---|--|
| Name:    | ADCMX |    |   |   | DADCNV |     | PGG |   |  |
| Reset A: |       | 0x | 0 |   | 0      | 0x0 |     |   |  |
| Reset B: |       | 0x | 1 |   | 0      |     | 0x0 |   |  |
| Reset C: |       | 0x | 2 |   | 0      |     | 0x0 |   |  |

These registers configure the time slot normally assigned to voltage channels A/B/C. The user may wish to change the PGG settings to match the voltage sensor. However, it is recommended that the user not modify the ADCMX settings.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                                                                                                                                                                               |
|-----|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | ADCMX  | Analog Conversion Select. This four-bit field determines which of the following analog inputs are sampled during this time slot.  0000 = V0P - VN (Phase A Voltage: 0000)  0001 = V1P - VN (Phase B Voltage: 0001)  0010 = V2P - VN (Phase C Voltage: 0010)  0011 = I0P - I0N  0100 = I1P - I1N  0101 = I2P - I2N  0110 = INP - VN  1xxx = Temperature                 |
| 3   | DADCNV | ADC Disable. When set, disables the ADC for this time slot.                                                                                                                                                                                                                                                                                                            |
| 2:0 | PGG    | Programmable Gain Amplifier Select. This three-bit field configures the programmable-gain amplifier at the front-end of the analog input. The field has the following values:  000 = Gain of 1  001 = Gain of 2  010 = Gain of 4  011 = Gain of 8  100 = Gain of 16  101 = Gain of 32  All other values are reserved and can cause unpredictable behavior if selected. |

#### Time Slot Assignment—Neutral Current Channel (SCAN\_IN) (0x00E)

| Bit:   | 7     | 6 | 5 | 4 | 3      | 2 | 1 | 0 |
|--------|-------|---|---|---|--------|---|---|---|
| Name:  | ADCMX |   |   |   | DADCNV | _ | _ | _ |
| Reset: | 0x6   |   |   |   | 1      | 0 | 0 | 0 |

This register configures the time slot normally assigned to the neutral current channel. The user can change the DADCNV bit to enable/disable neutral current sampling. It is recommended to leave the other bits of this register at their default values.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                                                                                                                                                                |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | ADCMX  | Analog Conversion Select. This four-bit field determines which of the following analog inputs are sampled during this time slot. All other values are reserved. By default, this register is set to 0110.  0000 = V0P - VN  0001 = V1P - VN  0010 = V2P - VN  0011 = I0P - I0N  0100 = I1P - I1N  0101 = I2P - I2N  0110 = INP - VN  1xxx = Temperature |
| 3   | DADCNV | ADC Disable. When set, disables the ADC for this time slot.                                                                                                                                                                                                                                                                                             |
| 2:0 | _      | Reserved.                                                                                                                                                                                                                                                                                                                                               |

#### Time Slot Assignment—Temperature Channel (SCAN\_TE) (0x00F)

| Bit:   | 7 | 6   | 5   | 4 | 3      | 2 | 1   | 0 |
|--------|---|-----|-----|---|--------|---|-----|---|
| Name:  |   | ADO | CMX |   | DADCNV |   | PGG |   |
| Reset: |   | 0>  | (8  |   | 1      |   | 0x2 |   |

This register configures the time slot normally assigned to the temperature measurement device. This register is managed by the firmware and should not be modified by the host.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | ADCMX  | Analog Conversion Select. This four-bit field determines which of the following analog inputs are sampled during this time slot.  0000 = V0P - VN  0001 = V1P - VN  0010 = V2P - VN  0011 = I0P - I0N  0100 = I1P - I1N  0101 = I2P - I2N  0110 = INP - VN  0111 = Auto-zero ADC  1xxx = Temperature  By default, this register is set to 1000.                                                                                                         |
| 3   | DADCNV | ADC Disable. When set, disables the ADC for this time slot.                                                                                                                                                                                                                                                                                                                                                                                             |
| 2:0 | PGG    | Programmable Gain Amplifier Select. This three-bit field configures the programmable-gain amplifier at the front end of the analog input. The field has the following values:  000 = Gain of 1  001 = Gain of 2  010 = Gain of 4  011 = Gain of 8  100 = Gain of 16  101 = Gain of 32  All other values are reserved and can cause unpredictable behavior if selected. This register is managed by the firmware and should not be modified by the host. |

### Neutral Current and Harmonics Auxiliary Channel Configuration (AUX\_CFG) (0x010)

| Bit:   | 15     | 14    | 13    | 12 | 11      | 10   | 9 | 8 |
|--------|--------|-------|-------|----|---------|------|---|---|
| Name:  | _      |       |       |    |         | ORDH |   |   |
| Reset: | 0      | 0     | 0     | 0  | 0       | 0    | 0 | 0 |
|        |        |       |       |    |         |      |   |   |
| Bit:   | 7      | 6     | 5     | 4  | 3       | 2    | 1 | 0 |
| Name:  | ENHARM | ENAUX | INREV | _  | AUX_MUX |      |   |   |
| Reset: | 0      | 0     | 0     | 0  | 0       | 0    | 0 | 0 |

The MAXQ3183 can monitor the RMS value of one auxiliary channel in addition to its normal processing. The Auxiliary Channel Configuration register selects which input the auxiliary channel processes and what processing is applied to the auxiliary channel.

| BIT      | NAME    | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:13, 4 | _       | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12:8     | ORDH    | Order of Harmonic (1-21). The output of harmonic voltage is read via virtual register 0x830 and current at 0x840.                                                                                                                                                                                                                                                                                                                                                                             |
| 7        | ENHARM  | Enable Auxiliary Channel Harmonic Filter. When set, the auxiliary channel is processed through the harmonic filter. The parameters for this filter can be set in the B0HARM and A1HARM registers.                                                                                                                                                                                                                                                                                             |
| 6        | ENAUX   | Enable Auxiliary Channel. When set, enables auxiliary channel processing.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5        | INREV   | Sets the sign of the neutral current, used in the vector sum calculation. $0 = positive$ , i.e., $I_N$ is directly summed with $I_A + I_B + I_C$ . $1 = negative$ , $-I_N$ is summed with $I_A + I_B + I_C$ .                                                                                                                                                                                                                                                                                 |
| 3:0      | AUX_MUX | Auxiliary Channel Input or Current Vector Sum Select. The lower three bits select the input to be processed by the auxiliary channel if the MSB (bit 3) is cleared. When MSB is set, this field selects vector sum computation: $1001 = I_A + I_B + I_C$ $1111 = I_A + I_B + I_C + I_N \text{ (INREV} = 0) \text{ or } I_A + I_B + I_C - I_N \text{ (INREV} = -1)}$ $0001 = I_N$ $0010 = V_A$ $0011 = I_A$ $0100 = V_B$ $0101 = I_B$ $0110 = V_C$ $0111 = I_C$ All other values are reserved. |

### DSP System Configuration System Clock Frequency (SYS\_KHZ) (0x012)

| Bit:   | 15 | 14 | 13  | 12             | 11            | 10  | 9 | 8 |
|--------|----|----|-----|----------------|---------------|-----|---|---|
| Name:  |    |    | Sys | stem Clock Fre | quency High B | yte |   |   |
| Reset: |    |    |     | 0x             | 1F            |     |   |   |
|        | •  |    |     |                |               |     |   |   |
| Bit:   | 7  | 6  | 5   | 4              | 3             | 2   | 1 | 0 |
| Name:  |    |    | Sys | stem Clock Fre | quency Low B  | yte |   |   |
| Reset: |    |    |     | 0x-            | 40            |     |   |   |

This register contains the system clock frequency in kHz units. Because the default frequency is 8MHz, this register defaults to 0x1F40.

### Cycle Count (CYCNT) (0x01C)

| Bit:   | 15 | 14 | 13 | 12         | 11          | 10 | 9 | 8 |
|--------|----|----|----|------------|-------------|----|---|---|
| Name:  |    |    |    | Cycle Coun | t High Byte |    |   |   |
| Reset: |    |    |    | 0x         | 00          |    |   |   |
|        |    |    |    |            |             |    |   |   |
| Bit:   | 7  | 6  | 5  | 4          | 3           | 2  | 1 | 0 |
| Name:  |    |    |    | Cycle Cour | nt Low Byte |    |   |   |
| Reset: |    |    |    | 0x         | 10          |    |   |   |

This register contains the number of line cycles that will be accumulated in a single DSP cycle. When CYCNT line cycles have been accumulated, the DSP performs power, power factor, and energy calculations. By default, the cycle count is 0x10 (16 decimal).

#### **Number of Scan Frames per DSP Cycle (NS) (0x040)**

| Bit:   | 31 | 30 | 29 | 28              | 27             | 26 | 25 | 24       |
|--------|----|----|----|-----------------|----------------|----|----|----------|
| Name:  |    |    |    | Integer Portic  | on, High Byte  |    |    |          |
| Reset: |    |    |    | 0x              | 03             |    |    |          |
|        |    |    |    |                 |                |    |    |          |
| Bit:   | 23 | 22 | 21 | 20              | 19             | 18 | 17 | 16       |
| Name:  |    |    |    | Integer Portion | on, Low Byte   |    |    |          |
| Reset: |    |    |    | 0x              | 28             |    |    |          |
|        |    |    |    |                 |                |    |    | <u>.</u> |
| Bit:   | 15 | 14 | 13 | 12              | 11             | 10 | 9  | 8        |
| Name:  |    |    |    | Fractional Port | ion, High Byte |    |    |          |
| Reset: |    |    |    | 0x              | 00             |    |    |          |
|        |    |    |    |                 |                |    |    |          |
| Bit:   | 7  | 6  | 5  | 4               | 3              | 2  | 1  | 0        |
| Name:  |    |    |    | Fractional Por  | tion, Low Byte |    |    |          |
| Reset: |    |    |    | 0x              | 00             |    |    |          |
|        |    |    |    |                 |                |    |    |          |

The NS register defines the fundamental timing for the electricity meter. It defines a DSP cycle in terms the period of the ADC scan frame. Generally, this register is calculated and updated automatically by the MAXQ3183 firmware based on the zero-crossing detection, and whether noise rejection (REJ\_NS) and averaging (AVG\_NS) are enabled. Host code can write to this register in order to set the desired DSP cycle duration. The duration of one scan frame (tfr) is represented as 0x00010000.

### Filter Coefficients Line Cycle Noise Rejection Filter (REJ\_NS) (0x02C)

| Bit:   | 15 | 14 | 13      | 12             | 11               | 10      | 9 | 8 |
|--------|----|----|---------|----------------|------------------|---------|---|---|
| Name:  |    |    | Line Cy | cle Noise Reje | ection Filter Hi | gh Byte |   |   |
| Reset: |    |    |         | 0x             | 00               |         |   |   |
|        |    |    |         |                |                  |         |   |   |
| Bit:   | 7  | 6  | 5       | 4              | 3                | 2       | 1 | 0 |
| Name:  |    |    | Line Cy | ycle Noise Rej | ection Filter Lo | w Byte  |   |   |
| Reset: |    |    |         | 0x             | C8               |         |   |   |

This register establishes the sensitivity of the NS rejection filter setting. NS is a measure of the line frequency. If a line cycle occurs that is shorter or longer than the line cycle represented in the NS register, this filter determines whether the cycle is used to update the NS value. For more information, see the NS register description. If this register is zero, noise rejection is disabled for the line cycle counter.

#### Line Cycle Averaging Filter (AVG\_NS) (0x02E)

| Bit:   | 15 | 14 | 13   | 12           | 11               | 10   | 9 | 8 |
|--------|----|----|------|--------------|------------------|------|---|---|
| Name:  |    |    | Line | Cycle Averag | ing Filter High  | Byte |   |   |
| Reset: |    |    |      | 0x           | 40               |      |   |   |
|        |    |    |      |              |                  |      |   | _ |
| Bit:   | 7  | 6  | 5    | 4            | 3                | 2    | 1 | 0 |
| Name:  |    |    | Line | Cycle Averag | ing Filter Low I | Byte |   |   |
| Reset: |    |    |      | 0x           | 00               |      |   |   |

This register determines whether the NS value is averaged over previous values or whether the most recently measured value is used directly. If the value of this register is nonzero, the NS value is averaged using the following formula:

$$y_n = y_{n-1} + AVG_NS \frac{x_n - y_{n-1}}{2^{16}}$$

If the value of this register is zero, NS is not averaged. The MSB of this register must be zero.

#### Meter Measurement Averaging Filter (AVG\_C) (0x030)

| Bit:   | 15 | 14 | 13       | 12            | 11               | 10        | 9 | 8 |
|--------|----|----|----------|---------------|------------------|-----------|---|---|
| Name:  |    |    | Meter Me | easurement Av | eraging Filter I | High Byte |   |   |
| Reset: |    |    |          | 0x            | 40               |           |   |   |
|        |    |    |          |               |                  |           |   |   |
| Bit:   | 7  | 6  | 5        | 4             | 3                | 2         | 1 | 0 |
| Name:  |    |    | Meter Me | easurement Av | eraging Filter   | Low Byte  |   |   |
| Reset: |    |    |          | 0x            | 00               |           |   |   |

This register determines whether the all other measured values in the electricity meter are averaged over time. If the value of this register is nonzero, all measured meter values are averaged using the following formula:

$$y_n = y_{n-1} + AVG_C \frac{x_n - y_{n-1}}{2^{16}}$$

If the value of this register is zero, no averaging is performed. The MSB of this register must be zero.

#### Meter Measurement Highpass Filter (HPF\_C) (0x032)

| Bit:   | 15 | 14 | 13       | 12             | 11              | 10        | 9 | 8 |
|--------|----|----|----------|----------------|-----------------|-----------|---|---|
| Name:  |    |    | Meter Me | easurement Hig | hpass Filter F  | ligh Byte |   |   |
| Reset: |    |    |          | 0x0            | 00              |           |   |   |
|        |    |    |          |                |                 |           |   |   |
| Bit:   | 7  | 6  | 5        | 4              | 3               | 2         | 1 | 0 |
| Name:  |    |    | Meter Me | easurement Hiç | ghpass Filter L | ow Byte   |   |   |
| Reset: |    |    |          | 0x0            | C8              |           |   |   |

This register specifies the b<sub>0</sub> coefficient of a first-order Butterworth filter using the following formula:

$$b_0 = \frac{HPF\_C}{2^{16}}$$

The MSB of this register must be zero.

### Fundamental Filter Feed-Forward Coefficient (B0FUND) (0x034)

| Bit:   | 15 | 14 | 13          | 12             | 11              | 10            | 9 | 8 |
|--------|----|----|-------------|----------------|-----------------|---------------|---|---|
| Name:  |    |    | Fundamental | Filter Feed-Fo | rward Coefficie | ent High Byte |   |   |
| Reset: |    |    |             | 0x             | 00              |               |   |   |
|        |    |    |             |                |                 |               |   | _ |
| Bit:   | 7  | 6  | 5           | 4              | 3               | 2             | 1 | 0 |
| Name:  |    |    | Fundamental | Filter Feed-Fo | rward Coeffici  | ent Low Byte  |   |   |
| Reset: |    |    |             | 0x             | 91              |               |   |   |

This register specifies the b<sub>0</sub> (feed-forward) coefficient for the fundamental-mode filter using the following formula:

$$b_0 = \frac{BOFUND}{2^{16}}$$

The MSB of this register must be zero.

### Fundamental Filter Feedback Coefficient (A1FUND) (0x036)

| Bit:   | 31 | 30 | 29      | 28               | 27             | 26         | 25 | 24 |
|--------|----|----|---------|------------------|----------------|------------|----|----|
| Name:  |    |    | Fundame | ntal Filter Feed | back Coefficie | ent Byte 3 |    |    |
| Reset: |    |    |         | 0x               | 00             |            |    |    |
|        |    |    |         |                  |                |            |    |    |
| Bit:   | 23 | 22 | 21      | 20               | 19             | 18         | 17 | 16 |
| Name:  |    |    | Fundame | ntal Filter Feed | back Coefficie | ent Byte 2 |    |    |
| Reset: |    |    |         | 0x               | 00             |            |    |    |
|        |    |    |         |                  |                |            |    |    |
| Bit:   | 15 | 14 | 13      | 12               | 11             | 10         | 9  | 8  |
| Name:  |    |    | Fundame | ntal Filter Feed | back Coefficie | ent Byte 1 |    |    |
| Reset: |    |    |         | 0x               | 03             |            |    |    |
|        |    |    |         |                  |                |            |    |    |
| Bit:   | 7  | 6  | 5       | 4                | 3              | 2          | 1  | 0  |
| Name:  |    |    | Fundame | ntal Filter Feed | back Coefficie | ent Byte 0 |    |    |
| Reset: |    |    |         | 0x               | 36             |            |    |    |

This register specifies the a<sub>1</sub> (feedback) coefficient for the fundamental-mode filter using the following formula:

$$a_1 = \frac{A1FUND}{2^{16}}$$

#### Harmonic Filter Feed-Forward Coefficient (B0HARM) (0x03A)

| Bit:   | 15 | 14 | 13         | 12              | 11              | 10          | 9 | 8 |
|--------|----|----|------------|-----------------|-----------------|-------------|---|---|
| Name:  |    |    | Harmonic F | ilter Feed-Forv | ard Coefficien  | t High Byte |   |   |
| Reset: |    |    |            | 0x              | 00              |             |   |   |
|        |    |    |            |                 |                 |             |   |   |
| Bit:   | 7  | 6  | 5          | 4               | 3               | 2           | 1 | 0 |
| Name:  |    |    | Harmonic I | ilter Feed-Forv | vard Coefficier | nt Low Byte |   |   |
| Reset: |    |    |            | 0x              | 91              |             |   |   |

This register specifies the b<sub>0</sub> (feed-forward) coefficient for the harmonic-mode filter using the following formula:

$$b_0 = \frac{B0HARM}{2^{16}}$$

The MSB of this register must be zero.

#### Harmonic Filter Feedback Coefficient (A1HARM) (0x03C)

| Bit:   | 31 | 30 | 29     | 28              | 27             | 26       | 25 | 24 |
|--------|----|----|--------|-----------------|----------------|----------|----|----|
| Name:  |    |    | Harmon | ic Filter Feedb | ack Coefficien | t Byte 3 |    |    |
| Reset: |    |    |        | 0x              | 00             |          |    |    |
|        |    |    |        |                 |                |          |    |    |
| Bit:   | 23 | 22 | 21     | 20              | 19             | 18       | 17 | 16 |
| Name:  |    |    | Harmon | ic Filter Feedb | ack Coefficien | t Byte 2 |    |    |
| Reset: |    |    |        | 0×              | 00             |          |    |    |
|        |    |    |        |                 |                |          |    |    |
| Bit:   | 15 | 14 | 13     | 12              | 11             | 10       | 9  | 8  |
| Name:  |    |    | Harmon | ic Filter Feedb | ack Coefficien | t Byte 1 |    |    |
| Reset: |    |    |        | 0×              | 18             |          |    |    |
|        |    |    |        |                 |                |          |    |    |
| Bit:   | 7  | 6  | 5      | 4               | 3              | 2        | 1  | 0  |
| Name:  |    |    | Harmon | ic Filter Feedb | ack Coefficien | t Byte 0 |    |    |
| Reset: |    |    |        | 0x              | 31             |          |    |    |

This register specifies the a<sub>1</sub> (feedback) coefficient for the harmonic mode filter using the following formula:

$$a_1 = \frac{A1HARM}{2^{16}}$$

#### Zero-Cross Lowpass Filter (ZC\_LPF) (0x05A)

| Bit:   | 15 | 14 | 13   | 12             | 11               | 10   | 9 | 8 |
|--------|----|----|------|----------------|------------------|------|---|---|
| Name:  |    |    | Zero | o-Cross Lowpas | ss Filter High E | Byte |   |   |
| Reset: |    |    |      | 0x0            | )B               |      |   |   |
|        |    |    |      |                |                  |      |   |   |
| Bit:   | 7  | 6  | 5    | 4              | 3                | 2    | 1 | 0 |
| Name:  |    |    | Zer  | o-Cross Lowpa  | ss Filter Low E  | Byte |   |   |
| Reset: |    |    |      | 0xt            | 00               |      |   |   |

This register specifies the lowpass filter applied for zero-cross detection. The MSB of this register must be zero.

### Hardware Mirror Registers ADC Configuration (R\_ACFG) (0x04C)

| Bit:   | 7      | 6     | 5   | 4          | 3     | 2     | 1    | 0    |
|--------|--------|-------|-----|------------|-------|-------|------|------|
| Name:  | ADCASD | ADCRY | ADO | CCD        | ADCBY | ADCIE | ARBE | ADCE |
| Reset: | 0      | 0     | 0:  | <b>(</b> 0 | 0     | 1     | 1    | 1    |

This register is a mirror of a CPU register in the MAXQ3183. This register should not be modified by supervisory code.

| BIT | NAME   | FUNCTION                                                                                                                                                                                                           |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ADCASD | Disable ADC Automatic Shutdown. Normally, the ADC analog section is powered off following a conversion to conserve power. If this bit is set, the ADC leaves the analog section powered on following a conversion. |
| 6   | ADCRY  | ADC Data Ready. When a conversion is complete, this bit is set to indicate that data is available. This bit generates an interrupt if ADCIE is set.                                                                |
| 5:4 | ADCCD  | ADC Clock Divider. Sets the division ratio between the CPU master and ADC clock.  00 = divide by 1  01 = divide by 2  10 = divide by 4  11 = reserved                                                              |
| 3   | ADCBY  | ADC Busy. When set, a single ADC conversion cycle is in progress. The bit is cleared on the conclusion of the conversion cycle.                                                                                    |
| 2   | ADCIE  | ADC Interrupt Enable. If set, the ADC interrupts the CPU at the completion of a conversion cycle.                                                                                                                  |
| 1   | ARBE   | Reference Buffer Enable. If set, the reference buffer is enabled to drive the REFO pin.                                                                                                                            |
| 0   | ADCE   | ADC Enable. If set, the ADC hardware is activated.                                                                                                                                                                 |

#### ADC Conversion Rate (R\_ADCRATE) (0x04E)

| Bit:   | 15 | 14 | 13 | 12            | 11             | 10 | 9   | 8 |
|--------|----|----|----|---------------|----------------|----|-----|---|
| Name:  |    |    | Al | DC Conversion | n Rate High By | te |     |   |
| Reset: | _  | _  |    | _             | _              | _  | _   | 1 |
|        |    |    |    |               |                |    |     | _ |
| Bit:   | 7  | 6  | 5  | 4             | 3              | 2  | 1   | 0 |
| Name:  |    |    | А  | DC Conversion | n Rate Low Byt | е  |     |   |
| Reset: |    |    |    | 0x            | 67             |    |     |   |
|        |    | ·  | ·  | ·             | ·              | ·  | .,, | · |

This register specifies the number of system clock cycles between consecutive ADC conversions. It defaults to 0x167 (359 decimal), which specifies 360 CPU clock cycles between conversions. This register is a mirror of a CPU register in the MAXQ3183.

\_ M/XI/M

#### ADC Settling Time (R\_ADCACQ) (0x050)

| Bit:   | 15 | 14 | 13 | 12             | 11            | 10 | 9 | 8 |
|--------|----|----|----|----------------|---------------|----|---|---|
| Name:  |    |    |    | ADC Settling T | ime High Byte |    |   |   |
| Reset: | _  | _  | _  | _              | _             | _  | _ | _ |
|        |    |    |    |                |               |    |   |   |
| Bit:   | 7  | 6  | 5  | 4              | 3             | 2  | 1 | 0 |
| Name:  |    |    |    | ADC Settling T | ime Low Byte  |    |   |   |
| Reset: | _  |    |    |                | 0x2F          |    |   |   |

This register is a mirror of a CPU register in the MAXQ3183. This register should not be modified by supervisory code. This register specifies the time, in CPU clocks, that the ADC must wait after switching analog mux inputs before beginning its conversion. This register defaults to 0x2F (47 decimal), which specifies a 48 CPU clock-cycle delay from analog mux switching to the start of conversion.

#### SPI Configuration (R\_SPICF) (0x052)

| Bit:   | 7     | 6   | 5 | 4 | 3 | 2   | 1     | 0     |
|--------|-------|-----|---|---|---|-----|-------|-------|
| Name:  | ESPII | SAS | _ | _ |   | CHR | CKPHA | CKPOL |
| Reset: | 1     | 0   | 0 | 0 | 0 | 0   | 0     | 0     |

This register is a mirror of a CPU register in the MAXQ3183. This register configures the SPI port of the MAXQ3183.

| BIT | NAME  | FUNCTION                                                                                                                                                                                                                                                                                                            |
|-----|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | ESPII | Enable SPI Interrupt. If set, arrival of a character on the SPI bus causes a CPU interrupt.                                                                                                                                                                                                                         |
| 6   | SAS   | SPI Slave Select Polarity. If clear, SSEL is assumed to be active low; if set, SSEL is assumed to be active high.                                                                                                                                                                                                   |
| 5:3 | _     | Reserved.                                                                                                                                                                                                                                                                                                           |
| 2   | CHR   | SPI Character Length. If clear, characters on the SPI bus are assumed to be 8 bits; if set, characters on the SPI bus are assumed to be 16 bits.                                                                                                                                                                    |
| 1   | СКРНА | SPI Clock Phase. If clear, data is sampled on the leading edge of the clock (low-to-high if the clock is active high, and high-to-low if the clock is active low). If set, data is sampled on the trailing edge of the clock (high-to-low if the clock is active high, and low-to-high if the clock is active low). |
| 0   | CKPOL | SPI Clock Polarity. If clear, the clock is assumed to be active high; if set, the clock is assumed to be active low.                                                                                                                                                                                                |

#### 

This register specifies the duration of SPI timeout in ADC frames (default 360µs).

|        |    |    |       | Energy Acc    | cumulation     | n Timeout | (ACC_TIM | O) (0x058) |
|--------|----|----|-------|---------------|----------------|-----------|----------|------------|
| Bit:   | 15 | 14 | 13    | 12            | 11             | 10        | 9        | 8          |
| Name:  |    |    | Energ | y Accumulatio | n Timeout High | n Byte    |          |            |
| Reset: |    |    |       | 0x            | 00             |           |          |            |
|        |    |    |       |               |                |           |          |            |
| Bit:   | 7  | 6  | 5     | 4             | 3              | 2         | 1        | 0          |
| Name:  |    |    | Energ | y Accumulatio | n Timeout Low  | Byte      |          |            |
| Reset: |    |    |       | 0x            | 05             |           |          |            |

This register specifies the time in DSP cycles that the MAXQ3183 waits before accumulating energy. If this register is nonzero, it is decremented on each DSP cycle. If the result of the decrement is nonzero, the results of the DSP cycle are discarded and are not accumulated to the energy registers. This register is useful for delaying the initiation of energy accumulation on startup or after some hardware function has been modified.

\_\_ /N/XI/N

### Phase-Angle Compensation Phase Offset Current Threshold 1 (I1THR) (0x05C)

| Bit:   | 15 | 14 | 13        | 12              | 11             | 10        | 9 | 8 |
|--------|----|----|-----------|-----------------|----------------|-----------|---|---|
| Name:  |    |    | Phase Acc | umulator Curre  | nt Threshold 1 | High Byte |   |   |
| Reset: |    |    |           | 0x              | 00             |           |   |   |
|        |    |    |           |                 |                |           |   |   |
| Bit:   | 7  | 6  | 5         | 4               | 3              | 2         | 1 | 0 |
| Name:  |    |    | Phase Acc | cumulator Curre | ent Threshold  | Low Byte  |   |   |
| Reset: |    |    |           | 0x              | 00             |           |   |   |

This register specifies the fraction of full-scale current that causes the MAXQ3183 to switch from PA0 to PA1 to provide phase-angle compensation. For more information, see the PA0, PA1, and PA2 register descriptions. The full-scale current is represented by 0x10000.

#### Phase Offset Current Threshold 2 (I2THR) (0x05E)

| Bit:   | 15 | 14 | 13        | 12              | 11              | 10          | 9 | 8 |
|--------|----|----|-----------|-----------------|-----------------|-------------|---|---|
| Name:  |    |    | Phase Acc | umulator Curre  | ent Threshold 2 | 2 High Byte |   |   |
| Reset: |    |    |           | 0x              | 00              |             |   |   |
|        |    |    |           |                 |                 |             |   |   |
| Bit:   | 7  | 6  | 5         | 4               | 3               | 2           | 1 | 0 |
| Name:  |    |    | Phase Acc | cumulator Curre | ent Threshold 2 | 2 Low Byte  |   |   |
| Reset: |    |    |           | 0x              | 00              |             |   |   |

This register specifies the fraction of full-scale current that causes the MAXQ3183 to switch from PA1 to PA2 to provide phase-angle compensation. For more information, see the PA0, PA1, and PA2 register descriptions. The full-scale current is represented by 0x10000.

### Miscellaneous Gain Neutral Current Gain (N.I\_GAIN) (0x12E)

| Bit:   | 15 | 14 | 13  | 12            | 11               | 10   | 9 | 8 |
|--------|----|----|-----|---------------|------------------|------|---|---|
| Name:  |    |    | Cor | npensation Co | efficient High E | Byte |   |   |
| Reset: |    |    |     | 0x            | 40               |      |   |   |
|        |    |    |     |               |                  |      |   |   |
| Bit:   | 7  | 6  | 5   | 4             | 3                | 2    | 1 | 0 |
| Name:  |    |    | Cor | mpensation Co | efficient Low E  | Byte |   |   |
| Reset: |    |    |     | 0x            | 00               |      |   |   |

This register contains gain compensation coefficient for the neutral current channel measurement. The raw values are taken from the selected measurement quantity and scaled by N.I\_GAIN/2<sup>14</sup>.

#### Gain, Fundamental Energy, Phase X = A/B/C (X.EF\_GAIN) (A: 0x136, B: 0x222, C: 0x30E)

| Bit:   | 15   | 14 | 13 | 12            | 11            | 10 | 9 | 8 |
|--------|------|----|----|---------------|---------------|----|---|---|
| Name:  |      |    |    | Gain Coeffici | ent High Byte |    |   |   |
| Reset: |      |    |    | 0x            | 40            |    |   |   |
|        |      |    |    |               |               |    |   |   |
| Bit:   | 7    | 6  | 5  | 4             | 3             | 2  | 1 | 0 |
| Name:  |      |    |    | Gain Coeffici | ent Low Byte  |    |   |   |
| Reset: | 0x00 |    |    |               |               |    |   |   |

This register contains gain coefficient for phase X fundamental energy. The raw values are taken from the selected measurement quantity and scaled by the following factor:

#### **Linearity Compensation**

#### Linearity Offset, High Range, Phase X = A/B/C (X.OFFS\_HI) (A: 0x138, B: 0x224, C: 0x310)

| Bit:   | 15   | 14 | 13 | 12             | 11           | 10 | 9 | 8 |
|--------|------|----|----|----------------|--------------|----|---|---|
| Name:  |      |    |    | Linearity Offs | et High Byte |    |   |   |
| Reset: |      |    |    | 0x             | 00           |    |   |   |
|        |      |    |    |                |              |    |   |   |
| Bit:   | 7    | 6  | 5  | 4              | 3            | 2  | 1 | 0 |
| Name:  |      |    |    | Linearity Offs | set Low Byte |    |   |   |
| Reset: | 0x00 |    |    |                |              |    |   |   |

This signed register contains the linearity offset for phase X current channel when the programmable gain amplifier is set to unity gain (that is, the measured current is above the low current threshold). The signed value represented by this register is added to the current value according to following formula:

X.IRMS + X.OFFS\_HI x 24

### Linearity Gain Coefficient, Low Range, Phase X = A/B/C (X.GAIN\_LO) (A: 0x13A, B: 0x226, C: 0x312)

| Bit:   | 15   | 14 | 13 | 12               | 11             | 10 | 9 | 8 |
|--------|------|----|----|------------------|----------------|----|---|---|
| Name:  |      |    | l  | _inearity Coeffi | cient High Byt | e  |   |   |
| Reset: |      |    |    | 0x               | 40             |    |   |   |
|        |      |    |    |                  |                |    |   |   |
| Bit:   | 7    | 6  | 5  | 4                | 3              | 2  | 1 | 0 |
| Name:  |      |    |    | Linearity Coeffi | cient Low Byte | Э  |   |   |
| Reset: | 0x00 |    |    |                  |                |    |   |   |

This register contains the linearity coefficient for phase X current channel when the programmable gain amplifier is set to gain of 32 (that is, the measured current is below the low current threshold). The effective gain is given by the equation:

$$\frac{\text{X.GAIN\_LO}}{2^{14}}$$

#### Linearity Offset, Low Range, Phase X = A/B/C (X.OFFS\_LO) (A: 0x13C, B: 0x228, C: 0x314)

| Bit:   | 15 | 14 | 13 | 12             | 11            | 10 | 9 | 8 |
|--------|----|----|----|----------------|---------------|----|---|---|
| Name:  |    |    |    | Linearity Offs | set High Byte |    |   |   |
| Reset: |    |    |    | 0x             | 00            |    |   |   |
|        |    |    |    |                |               |    |   |   |
| Bit:   | 7  | 6  | 5  | 4              | 3             | 2  | 1 | 0 |
| Name:  |    |    |    | Linearity Off  | set Low Byte  |    |   |   |
| Reset: |    |    |    | 0x             | 00            |    |   |   |

This signed register contains the linearity offset for phase X current channel when the programmable gain amplifier is set to gain of 32 (that is, the measured current is below the low current threshold). The signed value represented by this register is added to the current value. The total linearity compensation is applied as follows:

 $X.GAIN_LO/2^{14} \times (X.IRMS + X.OFFS_LO)$ 

Measurements—RAM Registers

2

3

RMS Result, Byte 0

#### On-Demand RMS Result (N.IRMS) (0x11C) 31 Bit: 29 28 25 Name: RMS Result, Byte 3 Reset: Bit: 23 22 21 20 19 18 17 16 RMS Result, Byte 2 Name: Reset: Bit: 15 12 10 9 8 14 13 11 RMS Result, Byte 1 Name: Reset:

This register contains the result of the RMS calculation on the AUX channel. Usually, this is the neutral current channel, but can be defined to be the RMS average of any harmonic of the quantities defined in the AUX\_MUX field of the AUX\_CFG register.

5

Bit:

Name: Reset: 0

#### **Fundamental Energy**

#### Fundamental Energy Overflow Flags, Phase X = A/B/C (X.EFOVER) (A: 0x147, B: 0x233, C: 0x31F)

| Bit:   | 7 | 6 | 5 | 4    | 3     | 2     | 1     | 0     |
|--------|---|---|---|------|-------|-------|-------|-------|
| Name:  | _ | _ | _ | SFOV | RNFOV | RPFOV | ANFOV | APFOV |
| Reset: | 0 | 0 | 0 | 0    | 0     | 0     | 0     | 0     |

These bits indicate an overflow condition has occurred on a fundamental frequency energy accumulator. An overflow condition is **not** an error condition. Rather, it simply indicates that the value in the energy accumulator could be smaller than the previous reading due to the overflow in the counter. To obtain the actual energy usage since the previous reading, 0x100000000 must be added to the difference. These bits, once set, can be cleared only by the host.

| BIT | NAME  | FUNCTION                                                                                                |
|-----|-------|---------------------------------------------------------------------------------------------------------|
| 7:5 | _     | Reserved.                                                                                               |
| 4   | SFOV  | When set, indicates an overflow condition on the apparent fundamental-mode energy accumulator.          |
| 3   | RNFOV | When set, indicates an overflow condition on the reactive negative fundamental-mode energy accumulator. |
| 2   | RPFOV | When set, indicates an overflow condition on the reactive positive fundamental-mode energy accumulator. |
| 1   | ANFOV | When set, indicates an overflow condition on the real negative fundamental-mode energy accumulator.     |
| 0   | APFOV | When set, indicates an overflow condition on the real positive fundamental-mode energy accumulator.     |

### Energy, Fundamental, Real Positive, Phase X = A/B/C (X.EAFPOS) (A: 0x1FC, B: 0x2E8, C: 0x3D4)

| Bit:  | 31 | 30 | 29 | 28        | 27        | 26 | 25 | 24 |
|-------|----|----|----|-----------|-----------|----|----|----|
| Name: |    |    |    | Real Ener | gy Byte 3 |    |    |    |
|       |    |    |    |           |           |    |    |    |
| Bit:  | 23 | 22 | 21 | 20        | 19        | 18 | 17 | 16 |
| Name: |    |    |    | Real Ener | gy Byte 2 |    |    |    |
|       |    |    |    |           |           |    |    |    |
| Bit:  | 15 | 14 | 13 | 12        | 11        | 10 | 9  | 8  |
| Name: |    |    |    | Real Ener | gy Byte 1 |    |    |    |
|       |    |    |    |           |           |    |    |    |
| Bit:  | 7  | 6  | 5  | 4         | 3         | 2  | 1  | 0  |
| Name: |    |    |    | Real Ener | gy Byte 0 |    |    |    |
|       | -  |    |    |           |           |    |    |    |

On every DSP cycle, the contents of the X.ACTF register are tested, and if positive, are added to this register. When this register overflows, the APFOV bit in the X.EFOVER register is set.

\_\_ /VI/IXI/VI

#### Energy, Fundamental, Real Negative, Phase X = A/B/C (X.EAFNEG) (A: $0 \times 200$ . B: $0 \times 2EC$ . C: $0 \times 3D8$ )

|       |    |    |    |           |           | (A. UXZUU, | b. UXZEU, | C. UXSDO) |
|-------|----|----|----|-----------|-----------|------------|-----------|-----------|
| Bit:  | 31 | 30 | 29 | 28        | 27        | 26         | 25        | 24        |
| Name: |    |    |    | Real Ener | gy Byte 3 |            |           |           |
|       |    |    |    |           |           |            |           |           |
| Bit:  | 23 | 22 | 21 | 20        | 19        | 18         | 17        | 16        |
| Name: |    |    |    | Real Ener | gy Byte 2 |            |           |           |
|       |    |    |    |           |           |            |           |           |
| Bit:  | 15 | 14 | 13 | 12        | 11        | 10         | 9         | 8         |
| Name: |    |    |    | Real Ener | gy Byte 1 |            |           |           |
|       |    |    |    |           |           |            |           |           |
| Bit:  | 7  | 6  | 5  | 4         | 3         | 2          | 1         | 0         |
| Name: |    |    |    | Real Ener | gy Byte 0 |            |           |           |
|       |    |    |    |           |           |            |           |           |

On every DSP cycle, the contents of the X.ACTF register are tested, and, if negative, absolute values are added to this register. When this register overflows, the ANFOV bit in the X.EFOVER register is set.

### Energy, Fundamental, Reactive Positive, Phase X = A/B/C (X.ERFPOS) (A: 0x204, B: 0x2F0, C: 0x3DC)

|       |    |    |    |             | 14           |    | UN U, | U. UNUDU, |
|-------|----|----|----|-------------|--------------|----|-------|-----------|
| Bit:  | 31 | 30 | 29 | 28          | 27           | 26 | 25    | 24        |
| Name: |    |    |    | Reactive Er | nergy Byte 3 |    |       |           |
|       |    |    |    |             |              |    |       |           |
| Bit:  | 23 | 22 | 21 | 20          | 19           | 18 | 17    | 16        |
| Name: |    |    |    | Reactive Er | nergy Byte 2 |    |       |           |
|       |    |    |    |             |              |    |       |           |
| Bit:  | 15 | 14 | 13 | 12          | 11           | 10 | 9     | 8         |
| Name: |    |    |    | Reactive Er | nergy Byte 1 |    |       |           |
|       |    |    |    |             |              |    |       |           |
| Bit:  | 7  | 6  | 5  | 4           | 3            | 2  | 1     | 0         |
| Name: |    |    |    | Reactive Er | nergy Byte 0 |    |       |           |
|       |    |    |    |             |              |    |       |           |

On every DSP cycle, the contents of the X.REAF register are tested, and, if positive, are added to this register. When this register overflows, the RPFOV bit in the X.EFOVER register is set.

### Energy, Fundamental, Reactive Negative, Phase X = A/B/C (X.ERFNEG)

|       |    |    |    |             |              | (A: 0x208, | B: 0x2F4, | C: 0x3E0) |
|-------|----|----|----|-------------|--------------|------------|-----------|-----------|
| Bit:  | 31 | 30 | 29 | 28          | 27           | 26         | 25        | 24        |
| Name: |    |    |    | Reactive Er | nergy Byte 3 |            |           |           |
| Bit:  | 23 | 22 | 21 | 20          | 19           | 18         | 17        | 16        |
| Name: |    |    |    | Reactive Er | nergy Byte 2 |            |           |           |
|       |    |    |    |             |              |            |           |           |
| Bit:  | 15 | 14 | 13 | 12          | 11           | 10         | 9         | 8         |
| Name: |    |    |    | Reactive Er | nergy Byte 1 |            |           |           |
| Bit:  | 7  | 6  | 5  | 4           | 3            | 2          | 1         | 0         |
| Name: |    |    |    | Reactive Er | nergy Byte 0 |            |           |           |
|       |    |    |    |             |              |            |           |           |

On every DSP cycle, the contents of the X.REAF register are tested, and, if negative, absolute values are added to this register. When this register overflows, the RNFOV bit in the X.EFOVER register is set.

### Energy Fundamental, Apparent, Phase X = A/B/C (X.ESF) (A: 0x20C. B: 0x2F8. C: 0x3E4)

|       |    |    |    |             |              | AI OALOO, | Di OALI O, | OI ONGET |
|-------|----|----|----|-------------|--------------|-----------|------------|----------|
| Bit:  | 31 | 30 | 29 | 28          | 27           | 26        | 25         | 24       |
| Name: |    |    |    | Apparent Er | ergy Byte 3  |           |            |          |
|       |    |    |    |             |              |           |            |          |
| Bit:  | 23 | 22 | 21 | 20          | 19           | 18        | 17         | 16       |
| Name: |    |    |    | Apparent Er | ergy Byte 2  |           |            |          |
|       |    |    |    |             |              |           |            |          |
| Bit:  | 15 | 14 | 13 | 12          | 11           | 10        | 9          | 8        |
| Name: |    |    |    | Apparent Er | ergy Byte 1  |           |            |          |
|       |    |    |    |             |              |           |            |          |
| Bit:  | 7  | 6  | 5  | 4           | 3            | 2         | 1          | 0        |
| Name: |    |    |    | Apparent Er | nergy Byte 0 |           |            |          |
|       |    |    |    |             |              |           |            |          |

On every DSP cycle, the contents of the X.ESF register are added to this register. When this register overflows, the SFOV bit in the X.EFOVER register is set. When the MAXQ3183 is operating in low-power mode, energy is not accumulated. However, during low-power mode, current values are accumulated to this register, making this register accumulate ampere-hours.

\_\_ /N/1XI/M

### Energy Accumulated in the Last DSP Cycle Real Energy, Phase X = A/B/C (X.ACT) (A: 0x1D0, B: 0x2BC, C: 0x3A8)

| Bit:  | 31 | 30 | 29 | 28        | 27         | 26 | 25 | 24 |
|-------|----|----|----|-----------|------------|----|----|----|
|       | 01 | 30 | 29 |           |            | 20 | 20 |    |
| Name: |    |    |    | Real Ener | gy Byte 3  |    |    |    |
|       |    |    |    |           |            |    |    |    |
| Bit:  | 23 | 22 | 21 | 20        | 19         | 18 | 17 | 16 |
| Name: |    |    |    | Real Ener | gy Byte 2  |    |    |    |
|       |    |    |    |           |            |    |    |    |
| Bit:  | 15 | 14 | 13 | 12        | 11         | 10 | 9  | 8  |
| Name: |    |    |    | Real Ener | gy Byte 1  |    |    |    |
|       |    |    |    |           |            |    |    |    |
| Bit:  | 7  | 6  | 5  | 4         | 3          | 2  | 1  | 0  |
| Name: |    |    |    | Real Ener | rgy Byte 0 |    |    |    |
| Name: |    |    |    | Real Ener | rgy Byte 0 |    |    |    |

This signed register provides the raw real energy accumulated over the most recent DSP cycle. For each ADC sample period, the real instantaneous power calculated from the instantaneous voltage and current is accumulated. At the end of each DSP cycle, the result of the accumulation over the DSP cycle is copied to this register and is accumulated in X.EAPOS or X.EANEG, depending on the sign of the accumulated energy.

LSB of the energy registers is VFS x IFS x tFR/2<sup>16</sup>.

### Reactive Energy, Phase X = A/B/C (X.REA) (A: 0x1D4, B: 0x2C0, C: 0x3AC)

| Bit:  | 31 | 30 | 29 | 28          | 27          | 26 | 25 | 24 |
|-------|----|----|----|-------------|-------------|----|----|----|
| Name: |    |    |    | Reactive En | ergy Byte 3 |    |    |    |
|       |    |    |    |             |             |    |    |    |
| Bit:  | 23 | 22 | 21 | 20          | 19          | 18 | 17 | 16 |
| Name: |    |    |    | Reactive En | ergy Byte 2 |    |    |    |
|       |    |    |    |             |             |    |    |    |
| Bit:  | 15 | 14 | 13 | 12          | 11          | 10 | 9  | 8  |
| Name: |    |    |    | Reactive En | ergy Byte 1 |    |    |    |
|       |    |    |    |             |             |    |    |    |
| Bit:  | 7  | 6  | 5  | 4           | 3           | 2  | 1  | 0  |
| Name: |    |    |    | Reactive En | ergy Byte 0 |    |    |    |

This signed register provides the raw reactive energy accumulated over the most recent DSP cycle. For each ADC sample period, the reactive instantaneous power calculated from the instantaneous voltage and current is accumulated. At the end of each DSP cycle, the result of the accumulation over the DSP cycle is copied to this register and is accumulated in X.ERPOS or X.ERNEG, depending on the sign of the accumulated energy.

|                   | Арј | parent Ene | ergy, Phas | e X = A/B/C | (X.APP) (    | A: 0x1D8, | B: 0x2C4, | C: 0x3B0) |
|-------------------|-----|------------|------------|-------------|--------------|-----------|-----------|-----------|
| Bit:              | 31  | 30         | 29         | 28          | 27           | 26        | 25        | 24        |
| Name:             |     |            |            | Apparent Er | nergy Byte 3 |           |           |           |
| Bit:              | 23  | 22         | 21         | 20          | 19           | 18        | 17        | 16        |
| Name:             |     |            |            | Apparent Er | nergy Byte 2 |           |           |           |
| Bit:              | 15  | 14         | 13         | 12          | 11           | 10        | 9         | 8         |
| Name:             |     |            |            | Apparent Er | nergy Byte 1 |           |           |           |
| Bit:              | 7   | 6          | 5          | 4           | 3            | 2         | 1         | 0         |
| Name <sup>.</sup> |     |            |            | Apparent Fr | neray Byte 0 |           |           |           |

This signed register provides the raw apparent energy accumulated over the most recent DSP cycle.

### Fundamental Energy Accumulated in the Last DSP Cycle Fundamental Real Energy, Phase X = A/B/C (X.ACTF) (A: 0x1DC, B: 0x2C8, C: 0x3B4)

|    | ,  | <b>.</b> .              |                                  | . , .                                                                           | ,                                                                                                          | ,                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                     |
|----|----|-------------------------|----------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 | 30 | 29                      | 28                               | 27                                                                              | 26                                                                                                         | 25                                                                                                                                                                                                                                             | 24                                                                                                                                                                                                                                                                  |
|    |    |                         | Real Ener                        | gy Byte 3                                                                       |                                                                                                            |                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                     |
| 23 | 22 | 21                      | 20                               | 19                                                                              | 18                                                                                                         | 17                                                                                                                                                                                                                                             | 16                                                                                                                                                                                                                                                                  |
|    |    |                         | Real Ener                        | gy Byte 2                                                                       |                                                                                                            |                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                     |
|    |    |                         |                                  |                                                                                 |                                                                                                            |                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                     |
| 15 | 14 | 13                      | 12                               | 11                                                                              | 10                                                                                                         | 9                                                                                                                                                                                                                                              | 8                                                                                                                                                                                                                                                                   |
|    |    |                         | Real Ener                        | gy Byte 1                                                                       |                                                                                                            |                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                     |
|    |    |                         |                                  |                                                                                 |                                                                                                            |                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                     |
| 7  | 6  | 5                       | 4                                | 3                                                                               | 2                                                                                                          | 1                                                                                                                                                                                                                                              | 0                                                                                                                                                                                                                                                                   |
|    |    |                         | Real Ener                        | gy Byte 0                                                                       |                                                                                                            |                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                     |
|    | 23 | 31 30<br>23 22<br>15 14 | 31 30 29<br>23 22 21<br>15 14 13 | 31 30 29 28  Real Ener  23 22 21 20  Real Ener  15 14 13 12  Real Ener  7 6 5 4 | 31 30 29 28 27  Real Energy Byte 3  23 22 21 20 19  Real Energy Byte 2  15 14 13 12 11  Real Energy Byte 1 | 31     30     29     28     27     26       Real Energy Byte 3       23     22     21     20     19     18       Real Energy Byte 2       15     14     13     12     11     10       Real Energy Byte 1       7     6     5     4     3     2 | Real Energy Byte 3         23       22       21       20       19       18       17         Real Energy Byte 2         15       14       13       12       11       10       9         Real Energy Byte 1         7       6       5       4       3       2       1 |

This signed register accumulates energy in the same fashion as the X.ACT register, but only at the fundamental line frequency.

Fundamental Reactive Energy, Phase X = A/B/C (X.REAF) (A: 0x1E0, B: 0x2CC, C: 0x3B8)

| Bit:  | 31 | 30 | 29 | 28          | 27          | 26 | 25 | 24 |
|-------|----|----|----|-------------|-------------|----|----|----|
| Name: |    |    |    | Reactive Er | ergy Byte 3 |    |    |    |
|       |    |    |    |             |             |    |    |    |
| Bit:  | 23 | 22 | 21 | 20          | 19          | 18 | 17 | 16 |
| Name: |    |    |    | Reactive Er | ergy Byte 2 |    |    |    |
|       |    |    |    |             |             |    |    |    |
| Bit:  | 15 | 14 | 13 | 12          | 11          | 10 | 9  | 8  |
| Name: |    |    |    | Reactive Er | ergy Byte 1 |    |    |    |
|       |    |    |    |             |             |    |    |    |
| Bit:  | 7  | 6  | 5  | 4           | 3           | 2  | 1  | 0  |
| Name: |    |    |    | Reactive Er | ergy Byte 0 |    |    |    |
|       |    |    |    |             |             |    |    |    |

This signed register accumulates energy in the same fashion as the X.REA register, but only at the fundamental line frequency.

Fundamental Apparent Energy, Phase X = A/B/C (X.APPF) (A: 0x1E4, B: 0x2D0, C: 0x3BC)

|       |                        |    | <b>3</b> 3) | ,-,-        | / .         | · · , | ,  |    |
|-------|------------------------|----|-------------|-------------|-------------|-------|----|----|
| Bit:  | 31                     | 30 | 29          | 28          | 27          | 26    | 25 | 24 |
| Name: |                        |    |             | Apparent Er | ergy Byte 3 |       |    |    |
|       |                        |    |             |             |             |       |    |    |
| Bit:  | 23                     | 22 | 21          | 20          | 19          | 18    | 17 | 16 |
| Name: | Apparent Energy Byte 2 |    |             |             |             |       |    |    |
|       |                        |    |             |             |             |       |    |    |
| Bit:  | 15                     | 14 | 13          | 12          | 11          | 10    | 9  | 8  |
| Name: | Apparent Energy Byte 1 |    |             |             |             |       |    |    |
|       |                        |    |             |             |             |       |    |    |
| Bit:  | 7                      | 6  | 5           | 4           | 3           | 2     | 1  | 0  |
| Name: |                        |    |             | Apparent En | ergy Byte 0 |       |    |    |
|       |                        |    |             |             |             |       |    |    |

This register accumulates energy in the same fashion as the X.APP register, but only at the fundamental line frequency.

|        |    |    |    |          |            | Cnecksun | 1 (CHKSU | M) (UXU66) |
|--------|----|----|----|----------|------------|----------|----------|------------|
| Bit:   | 15 | 14 | 13 | 12       | 11         | 10       | 9        | 8          |
| Name:  |    |    |    | Checksum | High Byte  |          |          |            |
| Reset: |    |    |    |          |            |          |          |            |
|        |    |    |    |          |            |          |          |            |
| Bit:   | 7  | 6  | 5  | 4        | 3          | 2        | 1        | 0          |
| Name:  |    |    |    | Checksum | n Low Byte |          |          |            |
| Reset: |    |    |    |          |            |          |          |            |

This register contains the calculated 16-bit arithmetic checksum over critical configuration and calibration registers. It is updated on every DSP cycle. In use, the administrative processor records the value in the CHKSUM register and then checks it periodically to verify that no configuration or calibration registers have changed. The MAXQ3183 sets the CHSCH bit when this register's value changes.

The registers included in the checksum calculation include the following:

| SYS_KHZ | THR2   | R_ADCRATE | A.I_GAIN  | B.I_GAIN  | C.I_GAIN  |
|---------|--------|-----------|-----------|-----------|-----------|
| VOLT_CC | REJ_NS | R_ADCACQ  | A.V_GAIN  | B.V_GAIN  | C.V_GAIN  |
| AMP_CC  | AVG_NS | R_SPICF   | A.E_GAIN  | B.E_GAIN  | C.E_GAIN  |
| PWR_CC  | AVG_C  | ISUMLVL   | A.EF_GAIN | B.EF_GAIN | C.EF_GAIN |
| ENR_CC  | HPF_C  | COM_TIMO  | A.OFFS_HI | B.OFFS_HI | C.OFFS_HI |
| CYCNT   | B0FUND | ACC_TIMO  | A.GAIN_LO | B.GAIN_LO | C.GAIN_LO |
| PLSCFG1 | OCLVL  | I1THR     | A.OFFS_LO | B.OFFS_LO | C.OFFS_LO |
| PLSCFG2 | OVLVL  | I2THR     | A.PA0     | B.PA0     | C.PA0     |
| PLS1_WD | UVLVL  | ZC_LPF    | A.PA1     | B.PA1     | C.PA1     |
| THR1    | NOLOAD | N.GAIN    | A.PA2     | B.PA2     | C.PA2     |
| PLS2_WD | R_ACFG | TEMP_CC   |           |           |           |

\_Measurements—Virtual Registers

#### Fundamental Real Power, Phase A/B/C/T (PWRPF.X) (A: 0x881, B: 0x882, C: 0x884, T: 0x887)

This signed register contains the real instantaneous power delivered into phase A/B/C or total at the fundamental line frequency only. Power is calculated from the instantaneous energy measurement according to the following equation:

$$PWRPF.X = \frac{X.ACTF \times PWR\_CC \times 2^{16}}{NS}$$

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

#### Fundamental Reactive Power, Phase A/B/C/T (PWRQF.X) (A: 0x891, B: 0x892, C: 0x894, T: 0x897)

This signed register contains the reactive instantaneous power delivered into phase A/B/C or total at the fundamental line frequency only. Power is calculated from the instantaneous energy measurement according to the following equation:

$$PWRQF.X = \frac{X.REAF \times PWR\_CC \times 2^{16}}{NS}$$

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

### Fundamental Apparent Power, Phase A/B/C/T (PWRSF.X) (A: 0x8A1, B: 0x8A2, C: 0x8A4, T: 0x8A7)

This register contains the instantaneous apparent power delivered into phase A/B/C or total at the fundamental line frequency only. Power is calculated from the instantaneous energy measurement according to the following equation:

$$PWRSF.X = \frac{X.APPF \times PWR\_CC \times 2^{16}}{NS}$$

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

#### Fundamental Real Energy, Phase A/B/C/T (ENRPF.X) (A: 0x8E1, B: 0x8E2, C: 0x8E4, T: 0x8E7)

This signed register contains the real accumulated energy delivered into phase A/B/C or total. The register is calculated according to the following formula:

ENRPF.X = ENR\_CC x (X.EAFPOS - X.EAFNEG)

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

### Fundamental Reactive Energy, Phase A/B/C/T (ENRQF.X) (A: 0x8F1, B: 0x8F2, C: 0x8F4, T: 0x8F7)

This signed register contains the reactive accumulated energy delivered into phase A/B/C or total. The register is calculated according to the following formula:

ENRQF.X = ENR\_CC x (X.ERFPOS - X.ERFNEG)

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

Fundamental Apparent Energy, Phase A/B/C/T (ENRSF.X) (A: 0x8B1, B: 0x8B2, C: 0x8B4, T: 0x8B7)

This register contains the apparent accumulated energy delivered into phase A/B/C or total. The register is the product of the ENR\_CC and X.ESF registers.

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0 (LSByte) |

#### Current Total Harmonic Distortion Plus Noise, Phase A/B/C (THDN.X) (A: 0x859, B:0x85A, C: 0x85C)

This signed register contains for a phase current the total harmonic distortion plus noise (power) ratio, computed as below, where X.IRMS<sub>FUND</sub> is the fundamental current RMS.

$$THDN.X = \frac{X.IRMS^2}{X.IRMS_{FLIND}^2} - 1$$

Note that the sign bit is at the most significant bit of byte 5.

| Byte 7 (MSByte unused) | Byte 6 (unused) |
|------------------------|-----------------|
| Byte 5                 | Byte 4          |
| Byte 3                 | Byte 2          |
| Byte 1                 | Byte 0          |

#### **Phasors**

#### Phase B Phasor (VBPH: 0x852)

This register reports phase angle of voltage phase B with respect to voltage phase A. The value is expressed in units of 0.01 degree; thus, the nominal value is 12000 decimal (0x2EE0). This value is calculated based on zero-crossing detection. It may exhibit noticable error in the presence of harmonics on voltage channels. This register is 2 bytes wide.

#### Phase C Phasor (VCPH: 0x854)

This register reports phase angle of voltage phase C with respect to voltage phase A. The value is expressed in units of 0.01 degree; thus, the nominal value is 24000 decimal (0x5DC0). This value is calculated based on zero-crossing detection. It may exhibit noticable error in the presence of harmonics on voltage channels. This register is 2 bytes wide.

#### **Harmonics**

#### RMS Voltage, Harmonic (V.HARM) (0x830)

This register reports the RMS voltage. The units are defined by the VOLT\_CC setting. Use AUX\_CFG to configure the phase (A/B/C) and harmonic order desired.

#### RMS Current, Harmonic/Neutral (I.N, I.HARM) (0x840)

This register reports the harmonic RMS current of selected phase (A/B/C) and harmonic order, harmonic, or the RMS current of the neutral current channel. The units are defined by the AMP\_CC setting. Use

AUX\_CFG to configure the phase (A/B/C) and harmonic order desired.

#### Ratio of Harmonic/Fundamental (HARM NF) (0x850)

This register reports the ratio of the selected harmonic RMS over the fundamental RMS of the same signal (except IN). The master must configure the AUX\_CFG register to enable the AUX channel, enable harmonics, and select AUX\_MUX before reading this register. This register is 4 bytes wide, LSB = 2<sup>-16</sup>.

#### **Special Commands**

Table 7 shows the read-only virtual registers that activate special commands when read by the master. Some commands return dummy values.

### \_Applications Information

#### **Grounds and Bypassing**

Careful PCB layout significantly minimizes noise on the analog inputs, resulting in less noise on the digital I/O that could cause improper operation. The use of multi-layer boards is essential to allow the use of dedicated power planes. The area under any digital components should be a continuous ground plane if possible. Keep any bypass capacitor leads short for best noise rejection and place the capacitors as close to the leads of the devices as possible.

The MAXQ3183 must have separate ground areas for the analog (AGND) and digital (DGND) portions, connected together at a single point.

Table 7. Virtual Registers That Activate Special Commands

| NAME        | ADDRESS | DESCRIPTION                                                                                                                                                                                                                                      | DATA<br>LENGTH<br>(BYTES) |
|-------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|
| UPD_SFR     | 0x900   | Reading this register copies the mirror registers (R_ADCF, R_ADCRATE, R_ADCACQ, R_SPICF) into hardware SFR registers. The read returns dummy data.                                                                                               | 1                         |
| UPD_MIR     | 0xA00   | Reading this register copies hardware SFR registers into mirror registers (R_ADCF, R_ADCRATE, R_ADCACQ, R_SPICF). The read returns dummy data.                                                                                                   | 1                         |
| DSPVER      | 0xC00   | Reading this register returns the DSP firmware version number.                                                                                                                                                                                   | 2                         |
| TEMP_C      | 0xC01   | Reading this register initiates the on-chip temperature sensor conversion. Upon completion, the temperature value is returned in degree Celsius, with a resolution of 1°C. The TEMP_CC register must be configured before reading this register. | 2                         |
| ENTER STOP  | 0xC02   | Reading this register places the device into Stop Mode.                                                                                                                                                                                          | 1                         |
| ENTER LOWPM | 0xC03   | Reading this register places the device into LOWPM Mode.                                                                                                                                                                                         | 1                         |
| EXIT LOWPM  | 0xC04   | Reading this register exits LOWPM Mode.                                                                                                                                                                                                          | 1                         |

CMOS design guidelines for any semiconductor require that no pin be taken above DVDD or below DGND. Violation of this guideline can result in a hard failure (damage to the silicon inside the device) or a soft failure (unintentional modification of memory contents). Voltage spikes above or below the device's absolute maximum ratings can potentially cause a devastating IC latchup.

Microcontrollers commonly experience negative voltage spikes through either their power pins or general-purpose I/O pins. Negative voltage spikes on power pins are especially problematic as they directly couple to the internal power buses. Devices such as keypads can conduct electrostatic discharges directly into the microcontroller and seriously damage the device. System designers must protect components against these transients that can corrupt system memory.

#### Specific Design Considerations for MAXQ3183-Based Systems

To reduce the possibility of coupling noise into the microcontroller, the system should be designed with a crystal or oscillator in a metal case that is grounded to the digital plane. Doing so reduces the susceptibility of the design to fast transient noise.

Because the MAXQ3183 is designed for use in systems where high voltages are present, care must be taken to route all signal paths, both analog and digital, as far away as possible from the high-voltage components.

It is possible to construct more elaborate metering designs using multiple MAXQ3183 devices. This can be accomplished by using a single SPI bus to connect all the MAXQ3183 devices together but using separate slave select lines to individually select each MAXQ3183.

#### **Additional Documentation**

Designers must ensure they have the latest MAXQ3183 errata documents. Errata sheets contain deviations from published specifications. A MAXQ3183 errata sheet for any specific device revision is available at www.maxim-ic.com/errata.

### **Technical Support**

For technical support, go to <a href="https://support.maxim-ic.com/micro">https://support.maxim-ic.com/micro</a>.

### **Pin Configuration**



### Package Information

For the latest package outline information and land patterns, go to <u>www.maxim-ic.com/packages</u>. Note that a "+", "#", or "-" in the package code indicates RoHS status only. Package drawings may show a different suffix character, but the drawing pertains to the package regardless of RoHS status.

| PACKAGE TYPE | PACKAGE CODE | DOCUMENT NO.   |
|--------------|--------------|----------------|
| 28 TSSOP     | U28+3        | <u>21-0066</u> |

### Typical Application Circuit



Maxim cannot assume responsibility for use of any circuitry other than circuitry entirely embodied in a Maxim product. No circuit patent licenses are implied. Maxim reserves the right to change the circuitry and specifications without notice at any time.