# mail

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





#### Features

- 30× More Sensitive Than the TSL2560/61 Device
- Approximates Human Eye Response
- Programmable ALS Interrupt Function with User-Defined Upper and Lower Threshold Settings
- 16-Bit Digital Output with I<sup>2</sup>C Fast-Mode at 400 kHz
- Programmable Analog Gain and Integration Time Supporting 1,000,000-to-1 Dynamic Range
- Available in Ultra-Small 1.25 mm × 1.75 mm Chipscale Package and Small 2 mm × 2 mm Flat No-Lead Package
- Automatically Rejects 50/60-Hz Lighting Ripple
- Low Quiescent Current 3 μA in Power Down Mode
- RoHS Compliant

#### Applications

 Ambient Light Sensor (ALS) for Display Brightness Control

# TSL2581, TSL2583 LIGHT-TO-DIGITAL CONVERTER

TAOS134 - MARCH 2011





#### Package Drawings are Not to Scale

#### **End Products and Market Segments**

- HDTVs
- Laptops and Tablets
- Mobile Handsets
- Monitors

#### Description

The TSL2581 and TSL2583 are very-high sensitivity light-to-digital converters that transform light intensity to a digital signal output capable of direct I<sup>2</sup>C interface. Each device combines one broadband photodiode (visible plus infrared) and one infrared-responding photodiode on a single CMOS integrated circuit capable of providing a near-photopic response over an effective 16-bit dynamic range (16-bit resolution). Two integrating ADCs convert the photodiode currents to a digital output that represents the irradiance measured on each channel. This digital output can be input to a microprocessor where illuminance (ambient light level) in lux is derived using an empirical formula to approximate the human eye response. The TSL2581 device supports a traditional level style interrupt that remains asserted until the firmware clears it.

While useful for general purpose light sensing applications, the TSL2581/83 devices are designed particularly for displays (LCD, OLED, etc.) with the purpose of extending battery life and providing optimum viewing in diverse lighting conditions. Display panel backlighting, which can account for up to 50 to 60 percent of total platform power, can be automatically managed. Both devices are also ideal for controlling keyboard illumination based upon ambient lighting conditions. Illuminance information can further be used to manage exposure control in digital cameras. The TSL2581/83 devices are ideal in notebook/tablet PCs, LCD monitors, flat-panel televisions, cell phones, and digital cameras. In addition, other applications include street light control, security lighting, sunlight harvesting, machine vision, and automotive instrumentation clusters.

The LUMENOLOGY ® Company

Texas Advanced Optoelectronic Solutions Inc. 1001 Klein Road • Suite 300 • Plano, TX 75074 • (972) 673-0759 www.taosinc.com

TAOS134 – MARCH 2011

#### Functional Block Diagram



#### **Detailed Description**

The TSL2581 and TSL2583 are second-generation ambient light sensor devices. Each contains two integrating analog-to-digital converters (ADC) that integrate currents from two photodiodes. Integration of both channels occurs simultaneously. Upon completion of the conversion cycle, the conversion result is transferred to the Channel 0 and Channel 1 data registers, respectively. The transfers are double-buffered to ensure that the integrity of the data is maintained. After the transfer, the device automatically begins the next integration cycle.

Communication to the device is accomplished through a standard, two-wire I<sup>2</sup>C serial bus. Consequently, the TSL258x device can be easily connected to a microcontroller or embedded controller. No external circuitry is required for signal conditioning, thereby saving PCB real estate as well. Because the output of the TSL258x device is digital, the output is effectively immune to noise when compared to an analog signal.

The TSL258x devices also support an interrupt feature that simplifies and improves system efficiency by eliminating the need to poll a sensor for a light intensity value. The primary purpose of the interrupt function is to detect a meaningful change in light intensity. The concept of a *meaningful change* can be defined by the user both in terms of light intensity and time, or persistence, of that change in intensity. The TSL258x devices have the ability to define a threshold above and below the current light level. An interrupt is generated when the value of a conversion exceeds either of these limits.

Copyright © 2011, TAOS Inc.



The LUMENOLOGY ® Company

TAOS134 - MARCH 2011

#### **Terminal Functions**

| TERMINAL        |     |      | Prochiption                                              |
|-----------------|-----|------|----------------------------------------------------------|
| NAME            | NO. | TYPE | DESCRIPTION                                              |
| ADDR SEL        | 2   | I    | Address select — three-state.                            |
| GND             | 3   |      | Power supply ground. All voltages are referenced to GND. |
| INT             | 5   | 0    | Interrupt — open drain.                                  |
| SCL             | 4   | I    | Serial clock input terminal — clock signal.              |
| SDA             | 6   | I/O  | Serial data I/O terminal — serial data I/O.              |
| V <sub>DD</sub> | 1   |      | Supply voltage.                                          |

#### **Available Options**

| DEVICE               | PACKAGE – LEADS | INTERFACE TYPE                         | ORDERING NUMBER |
|----------------------|-----------------|----------------------------------------|-----------------|
| TSL2581              | CS–6            | l <sup>2</sup> C Bus = V <sub>DD</sub> | TSL2581CS       |
| TSL2581              | FN–6            | l <sup>2</sup> C Bus = V <sub>DD</sub> | TSL2581FN       |
| TSL2583 <sup>†</sup> | CS–6            | l <sup>2</sup> C Bus = 1.8 V           | TSL2583CS       |
| TSL2583              | FN–6            | l <sup>2</sup> C Bus = 1.8 V           | TSL2583FN       |

<sup>†</sup> Contact TAOS for availability.

#### Absolute Maximum Ratings over operating free-air temperature range (unless otherwise noted)<sup>†</sup>

| Supply voltage, V <sub>DD</sub> (see Note 1) | 3.8 V          |
|----------------------------------------------|----------------|
| Digital output voltage range, V <sub>O</sub> |                |
| Digital output current, Io                   | –1 mA to 20 mA |
| Storage temperature range, T <sub>stg</sub>  | –40°C to 85°C  |
| ESD tolerance, human body model              | 2000 V         |

<sup>†</sup> 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 under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

NOTE 1: All voltages are with respect to GND.

#### **Recommended Operating Conditions**

|                                                |                  | MIN          | NOM | MAX           | UNIT |
|------------------------------------------------|------------------|--------------|-----|---------------|------|
| Supply voltage, V <sub>DD</sub>                |                  | 2.7          | 3   | 3.6           | V    |
| Operating free-air temperature, T <sub>A</sub> |                  | -30          |     | 70            | °C   |
| SCL SDA input low voltage V                    | TSL2581 (Note 2) |              |     | $0.3  V_{DD}$ | v    |
| SCL, SDA input low voltage, VIL                | TSL2583 (Note 3) |              |     | 0.54          | v    |
| SCL SDA input high voltage V                   | TSL2581 (Note 2) | $0.7 V_{DD}$ |     |               | v    |
| SCL, SDA input high voltage, VIII              | TSL2583 (Note 3) | 1.25         |     |               | v    |

NOTES: 2. Meets I<sup>2</sup>C specifications where  $V_{BUS} = V_{DD}$ .

3. Meets I<sup>2</sup>C specifications where  $V_{BUS} = 1.8$  V.



TAOS134 – MARCH 2011

# Electrical Characteristics over recommended operating free-air temperature range (unless otherwise noted)

|                   | PARAMETER                    | TEST CONDITIONS                        | MIN | TYP | MAX | UNIT |
|-------------------|------------------------------|----------------------------------------|-----|-----|-----|------|
|                   | Current current              | Active                                 |     | 175 | 250 | μA   |
| IDD               | Supply current               | Power down — I <sup>2</sup> C activity |     | 3   | 10  | μA   |
|                   |                              | 3 mA sink current                      | 0   |     | 0.4 | V    |
| V <sub>OL</sub>   | IN I, SDA output low voltage | 6 mA sink current                      | 0   |     | 0.6 | V    |
| I <sub>LEAK</sub> | Leakage current              |                                        | -5  |     | 5   | μA   |

# Operating Characteristics, $V_{DD} = 3 V$ , $T_A = 25^{\circ}C$ , (unless otherwise noted) (Notes 1, 2, 3, and 4)

|                           | PARAMETER                      | TEST CONDITIONS                                                             | CHANNEL | MIN  | ТҮР  | MAX   | UNIT                       |
|---------------------------|--------------------------------|-----------------------------------------------------------------------------|---------|------|------|-------|----------------------------|
| $\mathbf{f}_{\text{OSC}}$ | Oscillator frequency           |                                                                             |         |      |      |       | kHz                        |
|                           |                                | $E_{e} = 0$ , ATIME = 0xB6 (200 ms),                                        | Ch0     | 0    | 1    | 5     |                            |
|                           | Dark ADC count value           | gain = $16 \times$                                                          | Ch1     | 0    | 1    | 5     | counts                     |
|                           |                                |                                                                             | Ch0     |      |      | 37887 |                            |
|                           |                                | ATIME = 0XDB (100  ms)                                                      | Ch1     |      |      | 37887 |                            |
|                           | Full scale ADC count value     |                                                                             | Ch0     |      |      | 65535 | counts                     |
|                           |                                | ATIME = 0.000 (400  ms)                                                     | Ch1     |      |      | 65535 |                            |
| ADC cour                  |                                | $\lambda_{p} = 625 \text{ nm}, \text{ATIME} = 0 \text{xF6} (27 \text{ ms})$ | Ch0     | 4000 | 5000 | 6000  |                            |
|                           |                                | $E_{e} = 171.6 \mu\text{W/cm}^{2}$ , gain = 16×                             | Ch1     |      | 700  |       | counts                     |
|                           | ADC count value                | $\lambda_{p} = 850 \text{ nm}, \text{ATIME} = 0 \text{xF6} (27 \text{ ms})$ | Ch0     | 4000 | 5000 | 6000  |                            |
|                           |                                | $E_e = 220 \mu\text{W/cm}^2$ , gain = 16×                                   | Ch1     |      | 2750 |       |                            |
|                           | ADO south using ratios Ob1/Ob0 | $\lambda_p = 625 \text{ nm}$                                                | 10.8    | 15.8 | 20.8 | 0/    |                            |
|                           | ADC count value ratio: Ch1/Ch0 | $\lambda_p = 850 \text{ nm}$                                                | 41      | 55   | 68   | %     |                            |
|                           |                                |                                                                             | Ch0     |      | 29.1 |       |                            |
|                           |                                | $\lambda_{\rm p} = 625$ nm, ATIME = 0xF6 (27 ms)                            | Ch1     |      | 4    |       | counts/                    |
| н <sub>е</sub>            | irradiance responsivity        |                                                                             | Ch0     |      | 22.8 |       | (μνν/<br>cm <sup>2</sup> ) |
|                           |                                | $\lambda_{\rm p} = 850$ nm, ATIME = 0xF6 (27 ms)                            | Ch1     |      | 12.5 |       | - ,                        |
|                           |                                |                                                                             | Ch0     | 7    | 8    | 9     |                            |
|                           |                                | 8×                                                                          | Ch1     | 7    | 8    | 9     | ×                          |
|                           |                                | 101                                                                         | Ch0     | 15   | 16   | 17    |                            |
|                           | Gain scaling (relative to 1×)  | 16×                                                                         | Ch1     | 15   | 16   | 17    |                            |
|                           |                                |                                                                             | Ch0     | 97   | 107  | 115   |                            |
|                           |                                |                                                                             | Ch1     | 100  | 115  | 125   |                            |

NOTES: 1. Optical measurements are made using small-angle incident radiation from light-emitting diode optical sources. Visible 640 nm LEDs and infrared 850 nm LEDs are used for final product testing for compatibility with high-volume production.

2. The 625 nm irradiance  $E_e$  is supplied by an AIInGaP light-emitting diode with the following characteristics: peak wavelength  $\lambda p=625$  nm and spectral halfwidth  $\Delta\lambda \mathcal{V}_2=20$  nm.

3. The 850 nm irradiance E<sub>e</sub> is supplied by a light-emitting diode with the following characteristics: peak wavelength  $\lambda p = 850$  nm and spectral halfwidth  $\Delta \lambda \frac{1}{2} = 42$  nm.

4. The integration time  $T_{int}$ , is dependent on internal oscillator frequency ( $f_{osc}$ ) and on the number of integration cycles (ATIME) in the Timing Register (0xFF) as described in the Register section. For nominal  $f_{osc}$  = 750 kHz, nominal  $T_{int}$  = 2.7 ms × ATIME.



TAOS134 - MARCH 2011

|                      | PARAMETER <sup>†</sup>                                                                       | TEST CONDITIONS | MIN | TYP | MAX | UNIT |
|----------------------|----------------------------------------------------------------------------------------------|-----------------|-----|-----|-----|------|
| t <sub>(CONV)</sub>  | Conversion time                                                                              |                 | 2.7 |     | 688 | ms   |
| f <sub>(SCL)</sub>   | Clock frequency                                                                              |                 | 0   |     | 400 | kHz  |
| t <sub>(BUF)</sub>   | Bus free time between start and stop condition                                               |                 | 1.3 |     |     | μs   |
| t <sub>(HDSTA)</sub> | Hold time after (repeated) start condition. After this period, the first clock is generated. |                 | 0.6 |     |     | μs   |
| t <sub>(SUSTA)</sub> | Repeated start condition setup time                                                          |                 | 0.6 |     |     | μs   |
| t <sub>(SUSTO)</sub> | Stop condition setup time                                                                    |                 | 0.6 |     |     | μs   |
| t <sub>(HDDAT)</sub> | Data hold time                                                                               |                 | 0   |     | 0.9 | μs   |
| t <sub>(SUDAT)</sub> | Data setup time                                                                              |                 | 100 |     |     | ns   |
| t <sub>(LOW)</sub>   | SCL clock low period                                                                         |                 | 1.3 |     |     | μs   |
| t <sub>(HIGH)</sub>  | SCL clock high period                                                                        |                 | 0.6 |     |     | μs   |
| t <sub>F</sub>       | Clock/data fall time                                                                         |                 |     |     | 300 | ns   |
| t <sub>R</sub>       | Clock/data rise time                                                                         |                 |     |     | 300 | ns   |
| Ci                   | Input pin capacitance                                                                        |                 |     |     | 10  | pF   |

# AC Electrical Characteristics, $V_{DD}$ = 3 V, $T_A$ = 25°C (unless otherwise noted)

<sup>†</sup> Specified by design and characterization; not production tested.



Figure 1. Timing Diagrams

TAOS134 - MARCH 2011



**TYPICAL CHARACTERISTICS** 

Copyright © 2011, TAOS Inc.



The LUMENOLOGY <sup>®</sup> Company

TAOS134 - MARCH 2011

# PRINCIPLES OF OPERATION

#### **Analog-to-Digital Converter**

The TSL258x contains two integrating analog-to-digital converters (ADC) that integrate the currents from the channel 0 and channel 1 photodiodes. Integration of both channels occurs simultaneously, and upon completion of the conversion cycle the conversion result is transferred to the channel 0 and channel 1 data registers, respectively. The transfers are double buffered to ensure that invalid data is not read during the transfer. After the transfer, the device automatically begins the next integration cycle.

#### **Digital Interface**

Interface and control of the TSL258x is accomplished through a two-wire serial interface to a set of registers that provide access to device control functions and output data. The serial interface is compatible with I<sup>2</sup>C bus Fast-Mode. The TSL258x offers three slave addresses that are selectable via an external pin (ADDR SEL). The slave address options are shown in Table 1.

| ADDR SEL TERMINAL LEVEL | SLAVE ADDRESS |
|-------------------------|---------------|
| GND                     | 0101001       |
| Float                   | 0111001       |
| V <sub>DD</sub>         | 1001001       |

#### **Table 1. Slave Address Selection**

NOTE: A read/write bit should be appended to the slave address by the master device to properly communicate with the TSL258x device.



#### TAOS134 – MARCH 2011

#### I<sup>2</sup>C Protocol

Interface and control are accomplished through an  $I^2C$  serial compatible interface (standard or fast mode) to a set of registers that provide access to device control functions and output data. The devices support the 7-bit  $I^2C$  addressing protocol.

The I<sup>2</sup>C standard provides for three types of bus transaction: read, write, and a combined protocol (Figure 4). During a write operation, the first byte written is a command byte followed by data. In a combined protocol, the first byte written is the command byte followed by reading a series of bytes. If a read command is issued, the register address from the previous command will be used for data access. Likewise, if the MSB of the command is not set, the device will write a series of bytes at the address stored in the last valid command with a register address. The command byte contains either control information or a 5-bit register address. The control commands can also be used to clear interrupts.

The I<sup>2</sup>C bus protocol was developed by Philips (now NXP). For a complete description of the I<sup>2</sup>C protocol, please review the NXP I<sup>2</sup>C design specification at http://www.i2c-bus.org/references/.



I<sup>2</sup>C Read Protocol — Combined Format

Figure 4. I<sup>2</sup>C Protocols



The LUMENOLOGY ® Company

#### **Register Set**

The TSL258x is controlled and monitored by sixteen registers and a command register accessed through the serial interface. These registers provide for a variety of control functions and can be read to determine results of the ADC conversions. The register set is summarized in Table 2.

| ADDRESS | RESISTER NAME | REGISTER FUNCTION                      | R/W         |
|---------|---------------|----------------------------------------|-------------|
|         | COMMAND       | Specifies register address             | W           |
| 00h     | CONTROL       | Control of basic functions             |             |
| 01h     | TIMING        | Integration time/gain control          |             |
| 02h     | INTERRUPT     | Interrupt control                      |             |
| 03h     | TLLOW         | Low byte of low interrupt threshold    | <b>D</b> 44 |
| 04h     | TLHIGH        | High byte of low interrupt threshold   | R/W         |
| 05h     | THLOW         | Low byte of high interrupt threshold   |             |
| 06h     | THHIGH        | High byte of high interrupt threshold  |             |
| 07h     | ANALOG        | Analog control register                |             |
| 12h     | ID            | Part number / Rev ID                   |             |
| 14h     | DATA0LOW      | ADC channel 0 LOW data register        |             |
| 15h     | DATA0HIGH     | ADC channel 0 HIGH data register       |             |
| 16h     | DATA1LOW      | ADC channel 1 LOW data register        | R           |
| 17h     | DATA1HIGH     | ADC channel 1 HIGH data register       |             |
| 18h     | TIMERLOW      | Manual integration timer LOW register  |             |
| 19h     | TIMERHIGH     | Manual integration timer HIGH register |             |
| 1Eh     | ID2           | TSL2581 / TSL2583 ID                   | R/W         |

#### Table 2. Register Address

The mechanics of accessing a specific register is given in the I<sup>2</sup>C Protocol section. In general, the COMMAND register is written first to specify the specific control/status register for following read/write operations.



TAOS134 - MARCH 2011

#### **Command Register**

The command register specifies the address of the target register for subsequent read and write operations and contains eight bits as described in Table 3. The command register defaults to 00h at power on.

| Bit:        | 7   | 6                                                      | 5                                           | 4                                                                                                                                                                                                                  | 3                                               | 2                                                     | 1                                                    | 0                                                 |                               |  |
|-------------|-----|--------------------------------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------|------------------------------------------------------|---------------------------------------------------|-------------------------------|--|
|             | CMD | TRANSACTIO                                             | DN                                          | ADDRESS                                                                                                                                                                                                            |                                                 |                                                       |                                                      |                                                   | Reset<br>00h                  |  |
| FIELD       | BIT |                                                        |                                             |                                                                                                                                                                                                                    | DES                                             | SCRIPTION                                             |                                                      |                                                   |                               |  |
| CMD         | 7   | Select comma                                           | nd regi                                     | register. Must write as 1 when addressing COMMAND register.                                                                                                                                                        |                                                 |                                                       |                                                      |                                                   |                               |  |
|             |     | Select type of                                         | transac                                     | tion to follow                                                                                                                                                                                                     | in subsequen                                    | t data transfei                                       | rs:                                                  |                                                   |                               |  |
|             |     | FIELD VALUE                                            |                                             |                                                                                                                                                                                                                    |                                                 | DESCRI                                                | PTION                                                |                                                   |                               |  |
|             |     | 00                                                     | Rep                                         | peated byte pr                                                                                                                                                                                                     | otocol transad                                  | ction                                                 |                                                      |                                                   |                               |  |
| TRANSACTION | 6:5 | 01                                                     | Aut                                         | o-increment p                                                                                                                                                                                                      | rotocol transa                                  | iction                                                |                                                      |                                                   |                               |  |
|             | 0.0 | 10                                                     | Res                                         | erved — Do r                                                                                                                                                                                                       | not use                                         |                                                       |                                                      |                                                   |                               |  |
|             |     | 11                                                     | 11 Special function — See description below |                                                                                                                                                                                                                    |                                                 |                                                       |                                                      |                                                   |                               |  |
|             |     | Transaction ty<br>Transaction ty                       | be 00 v<br>be 01 v                          | vill repeatedly<br>vill provide an                                                                                                                                                                                 | read the sam<br>auto-increme                    | e register with<br>ent function to                    | n each data ao<br>read success                       | ccess.<br>sive register b                         | ytes.                         |  |
|             |     | Address field/s<br>specifies a spe<br>read transaction | pecial<br>cial fur<br>ns. Th                | function field.<br>nction comma<br>e field values                                                                                                                                                                  | Depending or<br>nd or selects<br>listed below a | n the transacti<br>the specific co<br>upply only to s | on type, see a<br>ontrol-status-r<br>pecial function | above, this fie<br>egister for fol<br>n commands: | eld either<br>owing write and |  |
|             |     | FIELD VALUE                                            |                                             |                                                                                                                                                                                                                    |                                                 | DESCRI                                                | PTION                                                |                                                   |                               |  |
|             |     | 00000                                                  | Res                                         | erved. Write                                                                                                                                                                                                       | as 0000b.                                       |                                                       |                                                      |                                                   |                               |  |
|             |     | 00001                                                  | Cle                                         | ar any pendin                                                                                                                                                                                                      | g interrupt and                                 | d is a write-or                                       | nce-to-clear b                                       | oit                                               |                               |  |
| ADDRESS     | 4:0 | 00010                                                  | Wh<br>set<br>may                            | en the Timing<br>to 0010b will s<br>/ be read in th                                                                                                                                                                | Register is se<br>stop a manua<br>le MANUAL II  | et to 00h, a Se<br>l integration. T<br>NTEGRATION     | endByte comn<br>The actual len<br>I TIMER Regi       | nand with the<br>gth of the inte<br>ster.         | ADDRESS field                 |  |
|             |     | 00011                                                  | Wh<br>set<br>may                            | When the Timing Register is set to 00h, a SendByte command with the ADDRE set to 0011b will start a manual integration. The actual length of the integration may be read in the MANUAL INTEGRATION TIMER Register. |                                                 |                                                       |                                                      |                                                   |                               |  |
|             |     | x11xx                                                  | Res                                         | erved. Write                                                                                                                                                                                                       | as 11xxb.                                       |                                                       |                                                      |                                                   |                               |  |

#### **Table 3. Command Register**

NOTE: An I<sup>2</sup>C block transaction will continue until the Master sends a stop condition. Only the Send Byte Protocol should be used when clearing interrupts.

Copyright © 2011, TAOS Inc.



The LUMENOLOGY <sup>®</sup> Company

TAOS134 - MARCH 2011

#### **Control Register (00h)**

The CONTROL register primarily used to power the TSL258x device up and down as shown in Table 4.

|                      | Table 4. Control Register                                                                                                                                     |             |                |                  |                  |              |                 |               |              |  |  |  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|------------------|------------------|--------------|-----------------|---------------|--------------|--|--|--|
| Bit: 7 6 5 4 3 2 1 0 |                                                                                                                                                               |             |                |                  |                  |              |                 |               |              |  |  |  |
| Address<br>00h       | Rese                                                                                                                                                          | erved       | ADC_INTR       | ADC_VALID        | Reser            | ved          | ADC_EN          | POWER         | Reset<br>00h |  |  |  |
| FIELD                | BIT DESCRIPTION                                                                                                                                               |             |                |                  |                  |              |                 |               |              |  |  |  |
| Reserved             | 7:6                                                                                                                                                           | Reserved.   | Write as 0.    |                  |                  |              |                 |               |              |  |  |  |
| ADC_INTR             | 5                                                                                                                                                             | ADC Interru | pt. Read only  | y. Indicates the | at the device is | s asserting  | an interrupt.   |               |              |  |  |  |
| ADC_VALID            | 4                                                                                                                                                             | ADC Valid.  | Read only. In  | ndicates that th | ne ADC chann     | el has com   | pleted an integ | ration cycle. |              |  |  |  |
| Reserved             | 3:2                                                                                                                                                           | Reserved.   | Write as 0.    |                  |                  |              |                 |               |              |  |  |  |
| ADC_EN               | ADC_EN 1 ADC Enable. This field enables the two ADC channels to begin integration. Writing a 1 activates the ADC channels, and writing a 0 disables the ADCs. |             |                |                  |                  |              |                 |               |              |  |  |  |
| POWER                | 0                                                                                                                                                             | Power On.   | Writing a 1 po | owers on the d   | evice, and writ  | ting a 0 tur | ns it off.      |               |              |  |  |  |

NOTE: ADC\_EN and POWER must be asserted before the ADC changes will operate correctly. After POWER is asserted, a 2-ms delay is required before asserting ADC\_EN.

NOTE: The TSL258x device registers should be configured before ADC\_EN is asserted.

#### Timing Register (01h)

The LUMENOLOGY ® Company

The TIMING register controls the internal integration time of the ADC channels in 2.7-ms increments. The TIMING register defaults to 00h at power on.

#### Table 5. Timing Register

| Bit:           | 7   | 6                                                                                      | 5                                                                                                                  | 4                                                                                                          | 3                                                                                                                         | 2                                                                                   | 1                                                                                                           | 0                                                                                                          |                                                                                       |  |  |  |  |
|----------------|-----|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|--|
| Address<br>01h |     |                                                                                        |                                                                                                                    | AT                                                                                                         | IME                                                                                                                       |                                                                                     |                                                                                                             |                                                                                                            | Reset<br>00h                                                                          |  |  |  |  |
| FIELD          | BIT |                                                                                        | DESCRIPTION                                                                                                        |                                                                                                            |                                                                                                                           |                                                                                     |                                                                                                             |                                                                                                            |                                                                                       |  |  |  |  |
|                |     | Integration<br>compleme<br>2.7-ms int<br>0xFF sho<br>is 688.5 n<br>Writing a<br>MANUAL | n Cycles. Sp<br>ent number. St<br>tervals require<br>uld be written<br>ns (0000001<br>0x00 to this r<br>INTEGRATIC | ecifies the in<br>So, to quickly<br>ed, and (2) th<br>. For 2 × 2.7<br>b).<br>egister is a s<br>DN TIMER R | tegration time in<br>y work out the co<br>en take the 2's o<br>'-ms intervals, 0x<br>pecial case and<br>egisters for othe | 2.7-ms inter<br>rrect value<br>complemen<br>FE should<br>indicates m<br>r device op | ervals. Time is<br>to write: (1) c<br>t. For exampl<br>be written. Th<br>anual timing r<br>tions related to | s expressed a<br>determine the<br>le, for a $1 \times 2$<br>ne maximum i<br>mode. See Co<br>o manual integ | is a 2's<br>number of<br>.7-ms interval,<br>ntegration time<br>ONTROL and<br>gration. |  |  |  |  |
|                |     | INT                                                                                    | EG_CYCLES                                                                                                          |                                                                                                            | TIME                                                                                                                      |                                                                                     |                                                                                                             | VALUE                                                                                                      |                                                                                       |  |  |  |  |
| ΔΤΙΜΕ          | 7.0 |                                                                                        | -                                                                                                                  |                                                                                                            | Manual integra                                                                                                            | tion                                                                                | 0000000                                                                                                     |                                                                                                            |                                                                                       |  |  |  |  |
| , (THWIE       | 7.0 |                                                                                        | 1                                                                                                                  |                                                                                                            | 2.7 ms                                                                                                                    |                                                                                     | 11111111                                                                                                    |                                                                                                            |                                                                                       |  |  |  |  |
|                |     |                                                                                        | 2                                                                                                                  |                                                                                                            | 5.4 ms                                                                                                                    |                                                                                     | 11111110                                                                                                    |                                                                                                            |                                                                                       |  |  |  |  |
|                |     |                                                                                        | 19                                                                                                                 |                                                                                                            | 51.3 ms                                                                                                                   |                                                                                     | 11101101                                                                                                    |                                                                                                            |                                                                                       |  |  |  |  |
|                |     |                                                                                        | 37                                                                                                                 |                                                                                                            | 99.9 ms                                                                                                                   |                                                                                     | 11011011                                                                                                    |                                                                                                            |                                                                                       |  |  |  |  |
|                |     |                                                                                        | 74                                                                                                                 |                                                                                                            | 199.8 ms                                                                                                                  |                                                                                     | 10110110                                                                                                    |                                                                                                            |                                                                                       |  |  |  |  |
|                |     |                                                                                        | 148                                                                                                                |                                                                                                            | 399.6 ms                                                                                                                  |                                                                                     | 01101100                                                                                                    |                                                                                                            |                                                                                       |  |  |  |  |
|                |     |                                                                                        | 255                                                                                                                |                                                                                                            | 688.5 ms                                                                                                                  |                                                                                     | 0000001                                                                                                     |                                                                                                            |                                                                                       |  |  |  |  |

NOTE: The Send Byte protocol cannot be used when ATIME is greater than 127 (for example ATIME[7] = 1) since the upper bit is set aside for write transactions in the COMMAND register.



TAOS134 - MARCH 2011

#### Interrupt Register (02h)

The INTERRUPT register controls the extensive interrupt capabilities of the device. The open-drain interrupt pin is active low and requires a pull-up resistor to  $V_{BUS}$  in order to pull high in the inactive state. The Interrupt Register provides control over when a meaningful interrupt will occur. The concept of meaningful change can be defined by the user both in terms of light intensity and time, or persistence of that change in intensity. The value must cross the threshold (as configured in the Threshold Registers 03h through 06h) and persist for some period of time, as outlined in Table 8.

When a level Interrupt is selected, an interrupt is generated whenever the last conversion results in a value outside of the programmed threshold window. The interrupt is active-low and remains asserted until cleared by writing an 11 in the TRANSACTION field in the COMMAND register.

Note: Interrupts are based on the value of Channel 0 only.



| FIELD     | BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|-----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Resv      | 7    | Reserved. Write as 0.                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| INTR_STOP | 6    | Stop ADC integration on interrupt. When high, ADC integration will stop once an interrupt is asserted. To resume operation (1) de-assert ADC_EN using CONTROL register, (2) clear interrupt using COMMAND register, and (3) re-assert ADC_EN using CONTROL register. <b>Note</b> : Use this bit to isolate a particular condition when the sensor is continuously integrating. |  |  |  |
| Resv      | 5    | Reserved. Write as 0.                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| INTR      | 4    | INTR Control Select. This field determines mode of interrupt logic according to Table 7, below.                                                                                                                                                                                                                                                                                |  |  |  |
| PERSIST   | 3:0  | Interrupt persistence. Controls rate of interrupts to the host processor as shown in Table 8, below.                                                                                                                                                                                                                                                                           |  |  |  |

#### Table 7. Interrupt Control Select

| INTR FIELD VALUE | READ VALUE                |
|------------------|---------------------------|
| 0                | Interrupt output disabled |
| 1                | Level Interrupt           |





TAOS134 - MARCH 2011

| PERSIST FIELD VALUE | INTERRUPT PERSIST FUNCTION               |  |  |  |  |
|---------------------|------------------------------------------|--|--|--|--|
| 0000                | Every ADC cycle generates interrupt      |  |  |  |  |
| 0001                | Any value outside of threshold range     |  |  |  |  |
| 0010                | 2 integration time periods out of range  |  |  |  |  |
| 0011                | 3 integration time periods out of range  |  |  |  |  |
| 0100                | 4 integration time periods out of range  |  |  |  |  |
| 0101                | 5 integration time periods out of range  |  |  |  |  |
| 0110                | 6 integration time periods out of range  |  |  |  |  |
| 0111                | 7 integration time periods out of range  |  |  |  |  |
| 1000                | 8 integration time periods out of range  |  |  |  |  |
| 1001                | 9 integration time periods out of range  |  |  |  |  |
| 1010                | 10 integration time periods out of range |  |  |  |  |
| 1011                | 11 integration time periods out of range |  |  |  |  |
| 1100                | 12 integration time periods out of range |  |  |  |  |
| 1101                | 13 integration time periods out of range |  |  |  |  |
| 1110                | 14 integration time periods out of range |  |  |  |  |
| 1111                | 15 integration time periods out of range |  |  |  |  |

#### **Table 8. Interrupt Persistence Select**





#### TAOS134 - MARCH 2011

#### Interrupt Threshold Registers (03h – 06h)

The interrupt threshold registers store the values to be used as the high and low trigger points for the comparison function for interrupt generation. If the value generated by channel 0 crosses below or is equal to the low threshold specified, an interrupt is asserted on the interrupt pin. If the value generated by channel 0 crosses above the high threshold specified, an interrupt is asserted on the interrupt pin. If the value generated by channel 0 crosses above the high threshold specified, an interrupt is asserted on the interrupt pin. Registers TLLOW and TLHIGH provide the low byte and high byte, respectively, of the lower interrupt threshold. Registers THLOW and THHIGH provide the low and high bytes, respectively, of the upper interrupt threshold. The high and low bytes from each set of registers are combined to form a 16-bit threshold value. The interrupt threshold registers default to 00h on power up.

| REGISTER | ADDRESS | BITS | DESCRIPTION                                    |
|----------|---------|------|------------------------------------------------|
| TLLOW    | 3h      | 7:0  | ADC channel 0 lower byte of the low threshold  |
| TLHIGH   | 4h      | 7:0  | ADC channel 0 upper byte of the low threshold  |
| THLOW    | 5h      | 7:0  | ADC channel 0 lower byte of the high threshold |
| THHIGH   | 6h      | 7:0  | ADC channel 0 upper byte of the high threshold |

#### **Table 9. Interrupt Threshold Registers**

NOTE: Since two 8-bit values are combined for a single 16-bit value for each of the high and low interrupt thresholds, the Send Byte protocol should not be used to write to these registers. Any values transferred by the Send Byte protocol with the MSB set would be interpreted as the COMMAND field and stored as an address for subsequent read/write operations and not as the interrupt threshold information as desired. The Write Word protocol should be used to write byte-paired registers. For example, the TLLOW and TLHIGH registers (as well as the THLOW and THHIGH registers) can be written together to set the 16-bit ADC value in a single transaction.

#### Analog Register (07h)

The ANALOG register provides eight bits of control to the analog block. These bits control the analog gain settings of the device.

|  | Table | 10. | Analog | Register |
|--|-------|-----|--------|----------|
|--|-------|-----|--------|----------|

| Bi             | t: 7             | 6                                                                                  | 5           | 4     | 3 | 2          | 1 | 0   |              |
|----------------|------------------|------------------------------------------------------------------------------------|-------------|-------|---|------------|---|-----|--------------|
| Address<br>07h |                  |                                                                                    | RESV        |       |   | GAIN       |   |     | Reset<br>00h |
| FIELD          | BITS DESCRIPTION |                                                                                    |             |       |   |            |   |     |              |
| Resv           | 7:3              | Reserved. V                                                                        | Vrite as 0. |       |   |            |   |     |              |
| Gain           | 2:0              | Gain Control. Sets the analog gain of the device according to the following table. |             |       |   |            |   |     |              |
|                |                  |                                                                                    | FIELD       | VALUE |   | GAIN VALUE |   |     |              |
|                |                  |                                                                                    | х           | 00    |   | 1×         |   |     |              |
|                |                  |                                                                                    | х           | 01    |   | 8×         |   |     |              |
|                |                  |                                                                                    | х           | 10    |   | 16×        |   |     |              |
|                |                  |                                                                                    | Х           | 11    |   |            | 1 | 11× |              |



#### ID Register (12h)

The ID register provides the value for both the part number and silicon revision number for that part number. It is a read-only register whose value never changes.

|                      |      |                                |                                               |  | 5 |    |     |  |       |
|----------------------|------|--------------------------------|-----------------------------------------------|--|---|----|-----|--|-------|
| Bit: 7 6 5 4 3 2 1 0 |      |                                |                                               |  |   |    |     |  |       |
| Address PARTNO       |      |                                |                                               |  |   | RE | VNO |  | Reset |
| FIELD                | BITS |                                | DESCRIPTION                                   |  |   |    |     |  |       |
| PARTNO               | 7:4  | Part Numbe                     | Part Number Identification: field value 1001b |  |   |    |     |  |       |
| REVNO                | 3:0  | Revision number identification |                                               |  |   |    |     |  |       |

#### Table 11. ID Register

#### ADC Channel Data Registers (14h - 17h)

The ADC channel data are expressed as 16-bit values spread across two registers. The ADC channel 0 data registers, DATA0LOW and DATA0HIGH provide the lower and upper bytes, respectively, of the ADC value of channel 0. Registers DATA1LOW and DATA1HIGH provide the lower and upper bytes, respectively, of the ADC value of value of channel 1. All channel data registers are read-only and default to 00h on power up.

| REGISTER  | ADDRESS | BITS | DESCRIPTION              |
|-----------|---------|------|--------------------------|
| DATA0LOW  | 14h     | 7:0  | ADC channel 0 lower byte |
| DATA0HIGH | 15h     | 7:0  | ADC channel 0 upper byte |
| DATA1LOW  | 16h     | 7:0  | ADC channel 1 lower byte |
| DATA1HIGH | 17h     | 7:0  | ADC channel 1 upper byte |

 Table 12. ADC Channel Data Registers

The upper byte data registers can only be read following a read to the corresponding lower byte register. When the lower byte register is read, the upper eight bits are strobed into a shadow register, which is read by a subsequent read to the upper byte. The upper register will read the correct value even if additional ADC integration cycles end between the reading of the lower and upper registers.

NOTE: The Read Word protocol can be used to read byte-paired registers. For example, the DATA0LOW and DATA0HIGH registers (as well as the DATA1LOW and DATA1HIGH registers) may be read together to obtain the 16-bit ADC value in a single transaction

#### Manual Integration Timer Registers (18h – 19h)

The MANUAL INTEGRATION TIMER registers provide the number of cycles in 10.9  $\mu$ s increments that occurred during a manual start/stop integration period. The timer is expressed as a 16-bit value across two registers. See CONTROL and TIMING Registers for further instructions in configuring a manual integration. The maximum time that can be derived without an overflow is 714.3 ms.



#### Table 13. Manual Integration Timer Registers

The LUMENOLOGY 
<sup>®</sup> Company



#### TAOS134 - MARCH 2011

#### ID2 Register (1Eh)

In combination with the ID register, the ID2 register provides a means to identify the device as a TSL2581 or a TSL2583. Although this is a W/R register, it is strongly advised that this register not be written to. Any value written to this register could adversely affect the performance of the device.

#### Table 14. ID2 Register Bit: 7 6 5 4 3 2 0 1 Address Reset Reserved ID Reserved 00h 00h FIELD BIT DESCRIPTION Reserved 7:6 Reserved. ID 5:4 ID. 00b = TSL2581, 11b = TSL2583 Reserved 3:0 Reserved.

Copyright © 2011, TAOS Inc.



The LUMENOLOGY ® Company

TAOS134 - MARCH 2011

#### **APPLICATION INFORMATION: SOFTWARE**

#### **Basic Operation**

After applying  $V_{DD}$ , the device will initially be in the power-down state. To operate the device, issue a command to access the CONTROL register followed by the data value 01h to the CONTROL register to power up the device. The TIMING register should be configured for the preferred integration period, and then the ADC\_EN should be set to 1 to enable both ADC channels.



Figure 5. State Diagram



TAOS134 - MARCH 2011

#### **APPLICATION INFORMATION: SOFTWARE**

The following pseudo code illustrates a procedure for reading the TSL258x device (ALS) using word transactions:

Command = 0x80//Set Command bit and Control Reg Power On = 0x01//Power on device WriteByte (Address, Command, Power On) //Set Command bit and ALS Timing Reg Command = 0x81ATIME = 0xb6//200 ms integration cycle //Configure ALS Timing Register for 200 ms integration cycle WriteByte (Address, Command, ATIME) Command = 0x80//Set Command bit and Control Reg ADC En = 0x03//Enable ADC Channels //Keep device powered on and enable ADC prior to reading channel data WriteByte (Address, Command, ADC\_En | Power\_On) // Read ADC Channels Using Read Word Protocol - RECOMMENDED //Address the Ch0 lower data register and configure for Read Word Command = 0Xb4//Set Command bit and Word bit //Reads two bytes from sequential registers 0x14 and 0x15 //Results are returned in DataLow and DataHigh variables ReadWord (Address, Command, DataLow, DataHigh) Channel0 = 256 \* DataHigh + DataLow //Address the Ch1 lower data register and configure for Read Word Command = 0xb6//Set Command bit and Word bit //Reads two bytes from sequential registers 0x16 and 0x17 //Results are returned in DataLow and DataHigh variables ReadWord (Address, Command, DataLow, DataHigh)

Copyright © 2011, TAOS Inc.

Channel1 = 256 \* DataHigh + DataLow



The LUMENOLOGY ® Company

//Shift DataHigh to upper byte

TAOS134 - MARCH 2011

#### **APPLICATION INFORMATION: SOFTWARE**

#### Interrupts

The interrupt feature of the TSL258x device simplifies and improves system efficiency by eliminating the need to poll the sensor for a light intensity value. Interrupt mode is determined by the INTR field in the INTERRUPT CONTROL Register. The interrupt feature may be disabled by writing a field value of 00h to the Interrupt Control Register (02h) so that polling can be performed.

The versatility of the interrupt feature provides many options for interrupt configuration and usage. The primary purpose of the interrupt function is to signal a meaningful change in light intensity. However, it can also be used as an end-of-conversion signal. The concept of a meaningful change can be defined by the user both in terms of light intensity and time, or persistence, of that change in intensity. The TSL258x device implements two 16-bit-wide interrupt threshold registers that allow the user to define thresholds above and below a desired light level. An interrupt will then be generated when the value of a conversion exceeds either of these limits. For simplicity of programming, the threshold comparison is accomplished only with Channel 0. This simplifies calculation of thresholds that are based, for example, on a percent of the current light level. It is adequate to use only one channel when calculating light intensity differences because, for a given light source, the channel 0 and channel 1 values are linearly proportional to each other and thus both values scale linearly with light intensity.

To further control when an interrupt occurs, the TSL258x device provides an interrupt persistence feature. This feature allows the user to specify a number of conversion cycles for which a light intensity exceeding either interrupt threshold must persist before actually generating an interrupt. This can be used to prevent transient changes in light intensity from generating an unwanted interrupt. With a value of 1, an interrupt occurs immediately whenever either threshold is exceeded. With values of *N*, where *N* can range from 2 to 15, *N* consecutive conversions must result in values outside the interrupt window for an interrupt to be generated. For example, if *N* is equal to 10 and the integration time is 402 ms, then an interrupt will not be generated unless the light level persists for more than 4 seconds outside the threshold.

The interrupt line goes active low and remains low until the interrupt is cleared by selecting the Special Function in the COMMAND register and writing a 0 to the Interrupt Clear field value.

To configure the interrupt as an end-of-conversion signal so that every ADC integration cycle generates an interrupt, the interrupt PERSIST field in the Interrupt Control Register (02h) is set to 0000b. An interrupt will be generated upon completion of each conversion. The interrupt threshold registers are ignored.



TAOS134 - MARCH 2011

## **APPLICATION INFORMATION: SOFTWARE**

#### **Calculating Lux**

The TSL258x is intended for use in ambient light detection applications such as display backlight control, where adjustments are made to display brightness or contrast based on the brightness of the ambient light, as perceived by the human eye. Conventional silicon detectors respond strongly to infrared light, which the human eye does not see. This can lead to significant error when the infrared content of the ambient light is high, such as with incandescent lighting, due to the difference between the silicon detector response and the brightness perceived by the human eye.

This problem is overcome in the TSL258x through the use of two photodiodes. One of the photodiodes (channel 0) is sensitive to both visible and infrared light, while the second photodiode (channel 1) is sensitive primarily to infrared light. An integrating ADC converts the photodiode currents to digital outputs. Channel 1 digital output is used to compensate for the effect of the infrared component of light on the channel 0 digital output. The ADC digital outputs from the two channels are used in a formula to obtain a value that approximates the human eye response in the commonly used Illuminance unit of Lux:

#### **Chipscale Package**

For CH1/CH0 = 0.00 to 0.25 For CH1/CH0 = 0.25 to 0.38 For CH1/CH0 = 0.38 to 0.45 For CH1/CH0 = 0.45 to 0.60 For CH1/CH0 > 0.60

# $\label{eq:Lux} \begin{array}{l} Lux = 0.105 \times CH0 - 0.208 \times CH1 \\ Lux = 0.1088 \times CH0 - 0.2231 \times CH1 \\ Lux = 0.0729 \times CH0 - 0.1286 \times CH1 \\ Lux = 0.060 \times CH0 - 0.10 \times CH1 \\ Lux/CH0 = 0 \end{array}$

#### **FN Package**

For CH1/CH0 = 0.00 to 0.30For CH1/CH0 = 0.30 to 0.38For CH1/CH0 = 0.38 to 0.45For CH1/CH0 = 0.45 to 0.54For CH1/CH0 > 0.54  $\begin{array}{l} \text{Lux} = 0.130 \times \text{CH0} - 0.240 \times \text{CH1} \\ \text{Lux} = 0.1649 \times \text{CH0} - 0.3562 \times \text{CH1} \\ \text{Lux} = 0.0974 \times \text{CH0} - 0.1786 \times \text{CH1} \\ \text{Lux} = 0.062 \times \text{CH0} - 0.100 \times \text{CH1} \\ \text{Lux/CH0} = 0 \end{array}$ 

The formulas shown above were obtained by optical testing with fluorescent and incandescent light sources, and apply only to open-air applications. Optical apertures (e.g. light pipes) will affect the incident light on the device.

#### **Simplified Lux Calculation**

Below is the argument and return value including source code (shown on following page) for calculating lux with the TSL2583FN. The source code is intended for embedded and/or microcontroller applications. All floating point arithmetic operations have been eliminated since embedded controllers and microcontrollers generally do not support these types of operations. Because floating point has been removed, scaling must be performed prior to calculating illuminance if the integration time is not 400 msec and/or if the gain is not  $1 \times$  as denoted in the source code on the following pages.

TAOS134 - MARCH 2011

```
11
// Copyright 2004-2008 TAOS, Inc.
11
// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
// KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
// PURPOSE.
//
// Module Name:
// lux.cpp
//
#define LUX_SCALE 16 // scale by 2^16
#define RATIO_SCALE 9 // scale ratio by 2^9
//-----
// Integration time scaling factors
//-----
#define CH SCALE 16 // scale channel values by 2^16
#define NOM_INTEG_CYCLE 148 // Nominal 400 ms integration. See Timing Register
//-----
                            _____
// Gain scaling factors
//------
#define CH0GAIN128X 107 // 128X gain scalar for Ch0
#define CH1GAIN128X 115 // 128X gain scalar for Ch1
//-----
// FN Package coefficients
//-----
                                 _____
// For Ch1/Ch0=0.00 to 0.30:
.
||
||
             Lux=0.130*Ch0-0.240*Ch1
// For Ch1/Ch0=0.30 to 0.38:
11
             Lux=0.1649*Ch0-0.3562*Ch1
// For Ch1/Ch0=0.38 to 0.45:
||
||
             Lux=0.0974*Ch0-0.1786*Ch1
   For Ch1/Ch0=0.45 to 0.54:
||
||
             Lux=0.062*Ch0-0.10*Ch1
  For Ch1/Ch0>0.54:
             Lux/Ch0=0
//
//-----
                                 ------
#define K1C 0x009A // 0.30 * 2<sup>RATIO</sup> SCALE
#define B1C 0x2148 // 0.130 * 2<sup>LUX</sup> SCALE
#define M1C 0x3d71 // 0.240 * 2<sup>LUX</sup>SCALE
#define K2C 0x00c3 // 0.38 * 2^RATIO_SCALE
#define B2C 0x2a37 // 0.1649 * 2^LUX_SCALE
#define M2C 0x5b30 // 0.3562 * 2^LUX_SCALE
#define K3C 0x00e6 // 0.45 * 2^RATIO_SCALE
#define B3C 0x18ef // 0.0974 * 2^LUX_SCALE
#define M3C 0x2db9 // 0.1786 * 2^LUX_SCALE
#define K4C 0x0114 // 0.54 * 2^RATIO_SCALE
#define B4C 0x0fdf // 0.062 * 2^LUX_SCALE
#define M4C 0x199a // 0.10 * 2<sup>LUX</sup>SCALE
#define K5C 0x0114 // 0.54 * 2^RATIO_SCALE
#define B5C 0x0000 // 0.00000 * 2^LUX_SCALE
#define M5C 0x0000 // 0.00000 * 2^LUX_SCALE
```

The LUMENOLOGY ® Company



TAOS134 - MARCH 2011

```
// Routine: unsigned int CalculateLux(unsigned int ch0, unsigned int ch0, int iType)
//
11
  Description: Calculate the approximate illuminance (lux) given the raw
              channel values of the TSL2583. The equation if implemented
11
11
              as a piece-wise linear approximation.
11
  Arguments: unsigned int iGain - gain, where 0:1X, 1:8X, 2:16X, 3:128X
11
            unsigned int tIntCycles - INTEG CYCLES defined in Timing Register
            unsigned int ch0 - raw channel value from channel 0 of TSL2583
unsigned int ch1 - raw channel value from channel 1 of TSL2583
11
11
            unsigned int iType - package type (1:CS)
1
  Return:
            unsigned int - the approximate illuminance (lux)
unsigned int CalculateLux(unsigned int iGain, unsigned int tIntCycles, unsigned int ch0,
unsigned int ch1, int iType)
  //-----
  // first, scale the channel values depending on the gain and integration time
  // 1X, 400ms is nominal setting
 unsigned long chScale0;
 unsigned long chScale1;
  unsigned long channel1;
 unsigned long channel0;
// No scaling if nominal integration (148 cycles or 400 ms) is used
  if (tIntCycles == NOM INTEG CYCLE)
     chScale0 = (1 << CH SCALE);
  else
     chScale0 = (NOM INTEG CYCLE << CH SCALE) / tIntCycles;
  switch (iGain)
  {
      case 0: // 1x gain
           chScale1 = chScale0;
                                     // No scale. Nominal setting
           break;
      case 1: // 8x gain
           chScale0 = chScale0 >> 3;
                                      // Scale/multiply value by 1/8
           chScale1 = chScale0;
           break:
     case 2: // 16x gain
           chScale0 = chScale0 >> 4;
                                      // Scale/multiply value by 1/16
            chScale1 = chScale0;
           break;
     case 3: // 128x gain
           chScale1 = chScale0 / CH1GAIN128X; //Ch1 gain correction factor applied
            chScale0 = chScale0 / CH0GAIN128X; //Ch0 gain correction factor applied
           break;
  }
  // scale the channel values
  channel0 = (ch0 * chScale0) >> CH SCALE;
  channel1 = (ch1 * chScale1) >> CH_SCALE;
  //_____
                                       _____
  // find the ratio of the channel values (Channel1/Channel0)
  // protect against divide by zero
```

Copyright © 2011, TAOS Inc.



The LUMENOLOGY ® Company

TAOS134 - MARCH 2011

```
unsigned long ratio1 = 0;
  if (channel0 != 0) ratio1 = (channel1 << (RATIO_SCALE+1)) / channel0;
  // round the ratio value
  unsigned long ratio = (ratio1 + 1) >> 1;
  // is ratio <= eachBreak?</pre>
  unsigned int b, m;
  switch (iType)
  {
      case 1: // CS package
             if ((ratio >= 0) && (ratio <= K1C))
                    {b=B1C; m=M1C;}
             else if (ratio <= K2C)
                    {b=B2C; m=M2C; }
             else if (ratio <= K3C)
                    {b=B3C; m=M3C;}
             else if (ratio <= K4C)
                    {b=B4C; m=M4C;}
             else if (ratio > K5C)
                     {b=B5C; m=M5C;}
             break;
  }
  unsigned long temp;
  unsigned long lux;
  temp = ((channel0 * b) - (channel1 * m));
  // round lsb (2^(LUX_SCALE-1))
  temp += (1 << (LUX_SCALE-1));</pre>
  // strip off fractional portion
  lux = temp >> LUX_SCALE;
  return(lux);
}
```



TAOS134 - MARCH 2011

## **APPLICATION INFORMATION: HARDWARE**

#### **Power Supply Decoupling and Application Hardware Circuit**

The power supply lines must be decoupled with a 0.1  $\mu$ F capacitor placed as close to the device package as possible (Figure 6). The bypass capacitor should have low effective series resistance (ESR) and low effective series inductance (ESI), such as the common ceramic types, which provide a low impedance path to ground at high frequencies to handle transient currents caused by internal logic switching.



#### Figure 6. Bus Pull-Up Resistors

Pull-up resistors (R<sub>P</sub>) maintain the SCL and SDA lines at a *high* level when the bus is free and ensure the signals are pulled up from a low to a high level within the required rise time. The I<sup>2</sup>C bus protocol was developed by Philips (now NXP). The pull-up resistor (R<sub>P</sub>) value is a function of the I<sup>2</sup>C bus speed, the supply voltage, and the capacitive bus loading. Users should consult the NXP I<sup>2</sup>C design specification (http://www.i2c-bus.org/references/) for assistance. With a lightly loaded bus running at 400 kbps and V<sub>BUS</sub> = 3 V, 1.5 k\Omega resistors have been found to be viable.

A pull-up resistor ( $R_{Pl}$ ) is also required for the interrupt (INT), which functions as a wired-AND signal in a similar fashion to the SCL and SDA lines. A typical impedance value between 10 k $\Omega$  and 100 k $\Omega$  can be used.



TAOS134 - MARCH 2011

## **APPLICATION INFORMATION: HARDWARE**

#### **PCB Pad Layouts**

Suggested PCB pad layout guidelines for the CS chipscale package are shown in Figure 7.



NOTES: A. All linear dimensions are in millimeters. B. This drawing is subject to change without notice.

#### Figure 7. Suggested CS Package PCB Layout

Suggested PCB pad layout guidelines for the Dual Flat No-Lead (FN) surface mount package are shown in Figure 8.



NOTES: A. All linear dimensions are in millimeters.

B. This drawing is subject to change without notice.

#### Figure 8. Suggested FN Package PCB Layout

