

# Fully integrated Light-Barrier Chips with 2-Wire Bus Interface



# **General Description**

The epc120 is a general purpose, fully integrated self-contained CMOS circuit to be used in light-barrier applications. The chips contain a controller which drives an LED, typically an IR-LED. The LED is used in a pulsed mode to increase the signal-to-noise ratio even when there is very strong sunlight biasing the photo diode.

It contains also a high sensitive photo diode amplifier and a signal conditioning circuitry to cancel unwanted environmental light including strong sunlight and pulsed light sources. The receiver is built around a synchronous demodulator circuitry. Two output signals with a different threshold level are implemented in order to trigger the light barriers output or to indicate light reserve.

The chips also include a power supply circuitry to establish all internally required voltages from the 2-wire bus.

They contain a 2-wire communication interface which is capable to operate as many as 1023 devices on a 2-wire bus at a speed of up to 2MBit/s over the power supply. This feature allows to design of a distributed light barrier system.

# Features

- Fully integrated light barrier chip
- Needs just a photo diode and an LED with an LED driver
- Configurable
- High speed 2-wire bus
- Integrated clock generator
   CSP10 package with very small footprint or
- standard QFN16 package available
- Versions without 2-wire bus interface available (epc11x family)

# Applications

- Light barriers ranging from millimeters to tens of meters
- Smoke detectors
- Liquid detectors





| Absolute Maximum Ratings (No                            | otes 1, 2)         | Recommended Operating Conditions                |      |      |       |  |  |  |
|---------------------------------------------------------|--------------------|-------------------------------------------------|------|------|-------|--|--|--|
| Voltage to any pin except $V_{\text{DD}}$               | -0.3V to VDD+0.3 V |                                                 | Min. | Max. | Units |  |  |  |
| Supply Voltage on 2-wire bus $V_{\mbox{\tiny DD}}$      | -0.3V to +8.0V     | Operating Voltage on 2-wire bus $V_{\text{DD}}$ | 4.5  | 5.5  | V     |  |  |  |
| Programming Voltage on 2-wire bus $V_{\mbox{\tiny DD}}$ | -0.3V to +8.0V     | Programming Voltage on $V_{DD}$                 | 7.0  | 8.0  | V     |  |  |  |
| Input current at any pin except LED                     | -6mA to +6 mA      |                                                 |      |      |       |  |  |  |
| Power consumption with maximum load                     | 125mW              |                                                 |      |      |       |  |  |  |
| Storage Temperature Range (Ts)                          | -55°C to +155°C    | Operating Temperature (T $_{o}$ )               | -40° | +85  | °C    |  |  |  |
| Lead Temperature solder, 4 sec. ( $T_L$ )               | +260°C             | Relative Humidity (non-condensing)              | +5   | +95  | %     |  |  |  |
|                                                         |                    |                                                 |      |      |       |  |  |  |

Note 1: Absolute Maximum Ratings indicate limits beyond which damage to the device may occur. Recommended operating conditions indicate conditions for which the device is intended to be functional, but do not guarantee specific performance limits. For guaranteed specific - ations and test conditions, see Electrical Characteristics.

**Note 2:** This device is a highly sensitive CMOS ac current amplifier with an ESD rating of JEDEC HBM class 0 (<250V). Handling and assembly of this device should only be done at ESD protected workstations.

# **Electrical Characteristics**

 $V_{DD}$  = 4.5V ... 5.5V, -40°C < T<sub>A</sub> < +85°C, unless otherwise specified

# **General Data**

| Symbol               | Parameter                                    | Conditions/Comments                                     |                                                                | Values                |      | Units               |                   |
|----------------------|----------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------|-----------------------|------|---------------------|-------------------|
|                      |                                              |                                                         |                                                                | Min.                  | Тур. | Max.                |                   |
| V <sub>PP</sub>      | Ripple on supply voltage,                    | 2-wire interface V <sub>det</sub>                       | Input pulse IPD NST                                            |                       |      |                     |                   |
|                      | peak to peak                                 | 50mV                                                    | 48nA                                                           |                       |      | 150                 | mV                |
|                      |                                              | 100mV                                                   | 72nA                                                           |                       |      | 350                 | mV                |
|                      |                                              | 200mV                                                   | 108nA                                                          |                       |      | 600                 | mV                |
| I <sub>DD_OP</sub>   | Current consumption                          | in operation mode I <sub>PD</sub> = 0 m/                | A                                                              |                       |      | 2                   | mA                |
| V <sub>det</sub>     | Detection level for 2-wire interface         | configurable                                            |                                                                | 50                    |      | 200                 | mV                |
| I <sub>MOD</sub>     | Modulation current for 2-wire inter-<br>face |                                                         | 6.4                                                            |                       | 9.8  | mA                  |                   |
| f <sub>clk</sub>     | Reference clock                              | Internal oscillator                                     |                                                                |                       | 1    |                     | MHz               |
| df <sub>clk</sub>    | Temperature drift of the oscillator          |                                                         |                                                                |                       | 640  |                     | ppm/K             |
| V <sub>PUP</sub>     | Power-up Threshold Voltage                   | The voltage at VDD33 when                               | 2.4                                                            |                       | 3    | V                   |                   |
| VIH                  | INPUT                                        | Logical high (V <sub>N</sub> can be eithe               | er VDD or VDD33)                                               | 0.7 *V <sub>N</sub>   |      | V <sub>N</sub>      | V                 |
| VIL                  | INPUT                                        | Logical low ( $V_N$ can be eithe                        | r VDD or VDD33)                                                | GND                   |      | 0.3 *V <sub>N</sub> | V                 |
| I <sub>LEAKD</sub>   | Input leakage current                        |                                                         |                                                                |                       |      | 10                  | μA                |
| V <sub>он</sub>      | Output high voltage                          | @ 4mA sink except pin SCK                               | (/LED                                                          | V <sub>DD</sub> - 0.5 |      |                     | V                 |
| V <sub>OL</sub>      | Output low voltage                           | @ 4mA source                                            |                                                                |                       |      | 0.5                 | V                 |
| I <sub>SCK/LED</sub> | Source current                               | @ PIN SCK / LED                                         |                                                                | 0.7                   |      | 1.3                 | mA                |
| V <sub>Hist</sub>    | Schmitt Trigger Hysteresis                   |                                                         |                                                                | 0.1                   |      |                     | V                 |
| R <sub>PU</sub>      | Pull-Up Resistor                             |                                                         |                                                                | 30                    |      | 200                 | kΩ                |
| IPDDC                | DC Photo Diode Current                       | generated by ambient light v sensitivity                | with no effect to the                                          | 0.0                   |      | 2                   | mA                |
| CPD                  | Photodiode Capacitance                       | Photodiode Capacitance                                  |                                                                |                       |      | 40                  | pF                |
| I <sub>N_lmin</sub>  | Input related noise                          | @ I <sub>PDDC</sub> =0                                  |                                                                |                       |      | 15                  | nA <sub>RMS</sub> |
| I <sub>N_Imax</sub>  | Input related noise                          | @ I <sub>PDDC</sub> = I <sub>PDDCMax</sub>              |                                                                |                       |      | 20                  | nA <sub>RMS</sub> |
| I <sub>PDN</sub>     | Photo Current Sensitivity, normal threshold  | Parameter SENSN = 011 (6<br>Photodiode pulse to generat | 0nA). T <sub>Pulse</sub> = 6µs<br>te a status "pulse detected" | 45                    | 60   | 75                  | nA                |
| I <sub>PDH</sub>     | Photo Current Sensitivity, upper threshold   | Parameter SENSH = 011 (9<br>Photodiode pulse to generat | 6nA). T <sub>Pulse</sub> = 6µs<br>te a status "pulse detected" | 1.4                   | 1.6  | 1.8                 | I <sub>PDN</sub>  |









| 10-Pin<br>CSP | 16-Pin<br>QFN             | Pin Name   | Туре                       | Description                                                                                               |
|---------------|---------------------------|------------|----------------------------|-----------------------------------------------------------------------------------------------------------|
| 1             | 9                         | VDD        | Power supply               | Positive power supply                                                                                     |
| 2             | 7                         | GND        | Power supply               | Negative power supply pin.                                                                                |
| 3             | 6                         | PD         | Analog Input               | Photo diode input.                                                                                        |
| 4             | 4                         | CS         | Digital Input              | SPI Interface: Chip Select. Active low, with pull up                                                      |
| 6             | 1                         | SO         | Digital Output             | SPI interface serial out                                                                                  |
| 7             | 15                        | SI         | Digital Output             | SPI interface serial input                                                                                |
| 8             | 14                        | LED<br>SCK | Digital In / Out           | Light barrier: LED control<br>SPI Interface: Shift Clock                                                  |
| 9             | 12                        | VDD33      | Power Supply<br>Decoupling | A power supply filter capacitor is connected to this pin.                                                 |
| 10            | 10                        | VDD18      | Analog Out                 | 1.8V regulator output, used to connect a filter capacitor. Must not be used to supply any other circuits. |
| 5             | 2                         | NC         |                            | Not connected. Leave that pin floating.                                                                   |
| n/a           | 3, 5, 8,<br>11, 13,<br>16 | NC         |                            | Not connected. Connect this pin with VSS.                                                                 |



# 1. Application Information

The epc120 chip set is a general purpose CMOS integrated circuit for light barrier applications. Up to 1023 devices may be connected to two respectively four wires in parallel. Each device can be individually addressed by an epc100 chip which acts as the interface between a microcontroller and the 2-wire bus. It manages the bus traffic between the microcontroller and the individual epc120 elements. Programmable fuses i.e. for the address, sensitivity, LED light pulse width, etc. allow the device to be parametrized in the final system (OTP memory).

The bus controller activates the emitting side of the epc120 and reads the status of the levels at the photodiode input. The status of the answers to the interface chip can be 'no light pulse received', 'low level light pulse received' and 'high level light pulse received'.

Each chip can be put into 'standby mode' or 'operating mode' to reduce power consumption. During 'standby mode', power consumption is reduced and the photo diode is shorted. In the 'operation mode', the device is active and ready to receive a light pulse generated by an LED activated by the LED pin. During a scan, the bus controller addresses one device after the other and fetches the light barrier status.

This manual describes the various operation and programming modes in order to use epc120. For the interface chip epc100 please refer to the epc10x "Reference Manual".

# 2. Hardware Design Information

Figure 2 shows the epc120 as an example in a long range light barrier application as a single bus module in a bus-chain configuration with minimal part count. The LED emits a light pulse when the chip is addressed by the bus controller. Light of the LED is reflected from a reflecting object or a retro reflector back to the photo diode PD. If the received light is strong enough it triggers the internal thresholds OUTN/H. The status of the receiver result can be read by the bus controller.



Figure 2: Long range light barrier chain application with minimal part count

The output to drive the LED is a current source capable to drive typically 1mA. For a high performance light barrier, an LED peak current of up to 2A is needed. To generate such a high LED current, an external amplifier is necessary. The circuitry in Figure 2 is a simple implementation of such an amplifier. The complementary Darlington circuit with T1 and T2 and R2 and R3 does the job. In order to avoid interference on the supply voltage, the supply is isolated (filtered) with R1 and C1. The high peak LED pulse current is delivered by the capacitor C1, which itself is charged more or less constantly by R1. Make sure, that there is no coupling of the high LED current to the ground and the supplies of the epot20 or to the cathode of the photo diode. This driver amplifier operates with a VDD LED in a range of 5 to 30 VDC.

## **Design Precautions**

The sensitivity at pin PD is very high in order to achieve a long operation range of light barriers even without lenses in front of the IR LED and/or the photo diode. Thus, the pin PD is very sensitive to EMI. Special care should be taken to keep the PCB track at pin PD as short as possible (a few mm only!). This track should be kept away from the IR LED signal tracks and from other sources which may induce unwanted signals. It is strongly recommended to cover the chip, the photodiode and all passive components around the chip with a metal shield. A recommended part is shown in Figure 3. The pins at the bottom are to solder the shield to the PCB with electrical connection to GND. The hole in the front is the opening window for the photo diode. The back side of the PCB below the sensitive area (PD, epc120) shall be a polygon connected to GND to shield the circuit from the back side as well.



Figure 3: Recommended EMC shield

## Ambient Light

Photodiode DC current can be generated by ambient light, e.g. sun light. DC currents at pin PD do not generate a DC output signal. However, if IPDDC is above the stated maximal value, the input is saturated which blocks the detection of AC current pulses.







In more detail, such a sequential operation is typically like as follows:

- 1. The first epc120 element is turned on (active mode).
- 2. On a second command this element sends a short light pulse towards his reflector or object, forming the active light beam 0.
- 3. If there is no obstacle between epc120 and his reflector, the element receives this light pulse and stores it into a local memory.
- 4. The bus controller reads out the content of the memory in the epc120 chip and stores the status (light beam interrupted or not interrupted) into its data memory.
- 5. Finally, epc120 is turned off (standby mode).

This sequence, which is also called 'scan', is repeated until all beams are checked and their status is stored in the beam status memory of the bus controller.

The above mentioned sequence is repeated until power is switched off. Because of the fact, that an object can enter into a light beam right after a beam has been checked with the above mentioned procedure, up to two full scan sequences are necessary to reliably detect an object. Thus, the overall maximum response time of the system will be

$$t_R = 2 * (n * t_{beam} + t_{eval}) \qquad (1)$$

where

- t<sub>R</sub> = response time of the system
- n = number of elements or light beams
- t<sub>beam</sub> = time to evaluate one beam
- $t_{eval}$  = time to evaluate the beam status memory and generate the output signal

For further reference in optical design considerations please refer to the respective application notes available from epc.

Figure 5 shows the epc120 in a distributed light barrier system application. The epc100 acts as a bus controller.



#### Figure 5: epc120 in the light barrier application as receivers and the interface chip to the microcontroller

From the point of view of the microcontroller, the whole system looks like a single device with several addressable sensors: the microcontroller activates one epc120 element and fetches the results after a predefined time.

In the circuit in Figure 5, the LED current is defined by a common current source in the  $I_{LED}$  line. The resistor  $R_{LED}$  limits the current through the LED and is not needed in non-safety applications. If such a resistor is inserted, a failure mode can be detected, if more than one LED is active due to a short circuit or a failure in the epc100. It is also possible to have a common voltage supply and to generate the LED current by a resistor.



# 4. 2-Wire Bus

The 2-wire bus and the power supply utilize the same two wires. The data is transmitted by modulating the current on the power-line. The modulated current, together with the resistor in the power supply, produce a voltage signal on the line. All devices receive this signal. The system is designed to operate with a line impedance of  $50\Omega$  (±5%). An inductor in parallel of the resistor or a DC regulator with a lowpass feedback shape the pulses and keep the the DC voltage drop over the resistor low. The required corner frequency of this L/R-filter is listed in the table below.

The communication interface has been designed to be used for line lengths of up to 100m and with up to 1023 sensor devices. For line lengths of up to 3m it is possible to operate the line without termination<sup>2</sup>. Above this length the line has to be terminated by a resistor of  $50\Omega$  (±5%) which is equal to the line impedance and a capacitor of 100nF in series.

The data rate on the 2-wire bus is set by the parameter DRATE. It also defines T<sub>SCANmin</sub> (refer to Chapter Error: Reference source not found) and the required inductor according to Table 1. The maximum data rate allowed on the 2-wire bis is depending on the bus length. The longer the bus wire, the lower the data rate. Table 1 shows the possible bus wire length according to the data rate.

| DRATE | k | Data Rate on the<br>2-Wire Bus | Minimal Data Rate<br>Required on SPI<br>Interface | Corner<br>Frequency L/R | Inductor | Bus Wire<br>Length <sup>3</sup> |
|-------|---|--------------------------------|---------------------------------------------------|-------------------------|----------|---------------------------------|
| 00    | 8 | 250 kbit/s                     | 300 kbit/s                                        | 0.5 MHz                 | 16µH     | 12 100m                         |
| 01    | 4 | 500 kbit/s                     | 600 kbit/s                                        | 1 MHz                   | 8µH      | 6 12m                           |
| 10    | 2 | 1 Mbit/s                       | 1.2 Mbit/s                                        | 2 MHz                   | 4µH      | 3 6m                            |
| 11    | 1 | 2 Mbit/s                       | 2.4 Mbit/s                                        | 4 MHz                   | 2µH      | ≤ 3m                            |

Table 1: Data rate of the 2-wire communication

The default value of DRATE is 00. The parameter DRATE has to be identical for all devices on one physical 2-wire bus.

The SPI bus should be faster than the 2-wire bus, otherwise the communication does not work. Since the command length dependent on the command type, the delay time to the next command has to be adjusted to the previous command. The time delay can be calculated with the given data length in Table 7 on page 19.

The parameter CDET defines the optimal signal amplitude for the receiver. The maximum rate at pin VDDR (5.5V) should not be exceeded and signals which are smaller than 70% of the recommended values are not detected.

Since the command length is dependent on the command type, the delay time to the next command has to be adjusted to the previous command. The time delay can be calculated with the given data length in Table 7 on page 19. The data handling chain of the 2-wire communication channel is shown in Figure 6.





Figure 7 shows the different messages with the parity bits. From the interface to the sensor/transmitter device the "normal command" is used except for the register write command. In the other direction only the register readout has a different format. Notice the different start bits which identify the direction of the transmission: 00 for the direction interface to sensor devices and 01 in the other direction. Between the telegrams, an idle time of 2 clock periods are need to detect the start of the transmission. P.  $\left( \mathsf{P}_{2} \right) \left( \mathsf{P}_{3} \right) \left( \mathsf{P}_{4} \right)$ A<sub>0</sub>XA<sub>1</sub>XA<sub>2</sub>XA<sub>3</sub>XA<sub>4</sub> XA<sub>6</sub>XA<sub>7</sub>XA C IC.Y С Normal Command Device Address Parity Bits Command C, P.VP С IC. R. (R\_\R\_\R, ID.ID. Write Command Device Address Parity Bits Command Register Data Parity Bits  $D_0(D_1)$  $\langle D_{9} \rangle D_{10} \rangle A_{0} \rangle A_{1} \rangle A_{2} \rangle$  $\langle A_8 \rangle \langle A_9 \rangle \langle P_0 \rangle \langle P_1 \rangle$ (P<sub>s</sub>∦P<sub>s</sub> Results Data Device Address Parity Bits R, (R, (R, )R R D D1 **Register Readout** Register Data Parity Bits Figure 7: Message Structure **Bus Wire Considerations** The electromechanical design of a system using multiple epc10x devices on a twisted pair cable with an impedance of typically 100 Ohms has an impact on the overall impedance of the system. Figure 8 shows the change of the cable impedance with smaller element pitch. 120 100 Impedance [Ohm] 80 60 40 20 0 1.8 3.2 5.6 10.0 17.8 31.6 56.2 100.0 1.0 Pitch [cm] Figure 8: Line impedance as a function of the element pitch on a 100 Ohm twisted pair cable It is highly recommended to terminate the bus line on both sides with an AC terminator network (shown in Figure 9) which matches the overall impedance of the system according to Figure 8. In order to avoid high DC currents in the termination resistor, a capacitor of 100nF should be connected in series to the termination resistor. 100nF R Figure 9: Bus termination network



Another aspect is the distribution velocity of the electrical signals on the 2-wire bus. Since the bus wire itself as well as the individual elements on the bus present a significant capacitance, the distribution velocity decreases with the number of elements and the pitch between the elements.



Figure 10: Delay vs Pitch. Parameter: Line length [m]

It is important that the overall delay is less than 50% of the clock period of the transmission. E.g. if the system is operated with 2 MBit/s data rate, the max. accepted delay must not be more than 125ns. Figure 10 shows, that a system operated at the full speed of 2 Mbit/s, a cable length of up to 5m are possible with an element pitch down to 1cm.

#### Example:

If we have a system that contains 100 elements in a pitch of 10cm, the total bus length is 10m. According to Figure 10, the delay time of a proper terminated bus is a little bit more than 100ns. Thus, such a system can be operated with the full speed of 2MBit/s.

### **Bus Signal Waveform**

Figure 11 pictures the Manchester encoding and the signal on the bus. The signal on the bus can be monitored with an oscilloscope and should look like in the drawing.

![](_page_9_Figure_10.jpeg)

Figure 11: Manchester encoded signal on the bus

CDET is the threshold set in the 2-wire communication receiver of the chip to detect the communication signal on the bus. This parameter, described in Table 6 and Table 10, can be adjusted to mach the specific system requirements. Thus, the voltage swing  $V_s$  of the communication signal on the bus shall match this setting. A good principle is that the voltage swing  $V_s$  measured on the bus should be min. 25% and max. 150% above the CDET value.

#### Example:

If CDET is set to 200mV, the voltage swing V $_{s}$  should be in a range of 250 to 500 mV. Ideal for this setting is a swing voltage V $_{s}$  of 400mV.

#### Attention:

Make sure that the voltage swing  $V_s$  is in the given tolerance range at every physical location of the bus. Due to reflections in the cable, losses of the wires (capacitive, inductive, and resistive), and the high bandwidth of the communication signals, significant differences can occur.

![](_page_10_Picture_0.jpeg)

![](_page_10_Picture_1.jpeg)

### **Parameter Memory**

The epc120 device contains a memory to store the application parameters. The following classes of data are stored on each device:

- Unique chip ID and chip adjustments (factory set)
- · Physical device address in the application, representing the beam number
- Application parameters

This data can be permanently stored in a read-only memory<sup>4</sup> and is mirrored in a volatile memory<sup>5</sup>. At power up, the data (except the chip ID) is copied from the ROM to the RAM. During operation, the data from the RAM is used. Both memories are organized in 16 registers at 16 bits each. The data can be accessed on a 16-bit register base. The following table shows the memory organization:

| Non-Volatile Memory Address<br>Range<br>(Register no.) | Volatile Memory Address<br>Range<br>(Register no.) | Description                          |  |  |  |
|--------------------------------------------------------|----------------------------------------------------|--------------------------------------|--|--|--|
| 0 - 3                                                  | 16 – 19                                            | Application parameters               |  |  |  |
| 4 - 6                                                  | 20 – 22                                            | Trim values, factory set             |  |  |  |
| 7                                                      | 23                                                 | Device Address                       |  |  |  |
| 8 – 15                                                 | -                                                  | Chip ID, factory set                 |  |  |  |
| -                                                      | 24 – 31                                            | For factory test purpose. Read only. |  |  |  |

| Tahle | 2.         | Memory | man | overview  |
|-------|------------|--------|-----|-----------|
| uvic  | <i>4</i> . | memory | mup | UVCIVICIV |

As shown in the table above, registers 0 - 3 and 7 are used for configuring the chip in the application. Before the devices can be used in a given light curtain system, the required application parameters and the physical address of the chip in the system have to be stored into the devices memories. The following table shows a parameter memory overview:

| ROM | RAM | 15    | 14   | 13   | 12 | 11   | 10   | 9    | 8      | 7     | 6 | 5     | 4 | 3      | 2          | 1    | 0       |                |
|-----|-----|-------|------|------|----|------|------|------|--------|-------|---|-------|---|--------|------------|------|---------|----------------|
| 0   | 16  | VMODE |      | MODE |    | SOFF | DR   | ATE  |        | TSTMP |   |       |   | TPULSE |            | POL  | FUSEBIT |                |
| 1   | 17  |       | TPER |      |    | ·    |      |      |        |       |   | •     |   |        |            |      | FUSEBIT | Application    |
| 2   | 18  |       | TSET |      |    |      |      | SENS | IVCOFF | SLOW  |   | SENSH |   | SEN    | ISN / VTHF | RLED | FUSEBIT | parameters     |
| 3   | 19  |       |      |      |    | CD   | DET  | C2X  |        |       |   |       |   |        |            |      |         |                |
| 4   | 20  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |
| 5   | 21  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         | Trimming       |
| 6   | 22  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |
| 7   | 23  |       |      |      |    | Add  | ress |      |        |       |   |       |   |        |            |      |         | Device Address |
| 8   | 24  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |
| 9   | 25  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |
| 10  | 26  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |
| 11  | 27  |       |      |      |    |      |      |      | Chi    | n ID  |   |       |   |        |            |      |         | Chin ID        |
| 12  | 28  |       |      |      |    |      |      |      | 011    | рю    |   |       |   |        |            |      |         | Ollipid        |
| 13  | 29  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |
| 14  | 30  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |
| 15  | 31  |       |      |      |    |      |      |      |        |       |   |       |   |        |            |      |         |                |

#### Figure 12: Detailed memory map

Parameters in white fields only shall be programmed. Never change the memory content of gray marked cells. Because only complete registers can be programmed, the bits which are gray marked must be set to zero.

The RAM can only be written, if the corresponding ROM memory hasn't been written before or if the volatile mode is active (VMODE, refer to Table 3 on page 11). The last bit of each 16-bit ROM register serves as write inhibit bit. To write to the ROM, the microcontroller has to write to the RAM first. From there, the microcontroller can first double check the data integrity. When a memory section is verified, the content can be transferred from the RAM memory using the command PROG to the ROM (refer to chapter Command PROG).

The device is fully operational as well without programming the ROM but data will be lost at power down. Operating the chips in this mode is helpful during the development of the product. However, in the final application, the parameters must be stored into the ROM memory.

The non-volatile memory is a one-time-programmable memory (OTP). Once the memory is programmed, the programmed values cannot be overwritten anymore! This memory type is hereinafter called ROM.
 Hereinafter called RAM.

![](_page_11_Picture_0.jpeg)

| Parameter | Regist | er No. | Bit      | No.        |                                         | Function                                                                     |                       |              |                                                       |                                   |  |  |  |  |  |
|-----------|--------|--------|----------|------------|-----------------------------------------|------------------------------------------------------------------------------|-----------------------|--------------|-------------------------------------------------------|-----------------------------------|--|--|--|--|--|
| Name      | RAM    | ROM    |          |            |                                         |                                                                              |                       |              |                                                       |                                   |  |  |  |  |  |
| FUSEBIT   | 0      | 16     |          | 0          |                                         | This bit will                                                                | automatically b       | e set v      | when register 16 is pro                               | ogrammed.                         |  |  |  |  |  |
|           |        |        | 0        | Val        | ues                                     |                                                                              |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        | 0        | Reg        | gister                                  | 16 is not                                                                    |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        |          | pro<br>Rec | gram<br>vister                          | 16 is prograu                                                                | ed<br>6 is programmed |              |                                                       |                                   |  |  |  |  |  |
|           |        |        | <u> </u> | 1.05       | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                                                              |                       |              |                                                       |                                   |  |  |  |  |  |
| POL       | 0      | 16     |          | 1          |                                         | Polarity of the LED pulse. Setting is depending on the LED driver circuitry. |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        | 1        | Val        | ues                                     |                                                                              | Default Sett          | ting         |                                                       |                                   |  |  |  |  |  |
|           |        |        | 0        | acti       | ve lo                                   | w                                                                            | X                     |              |                                                       |                                   |  |  |  |  |  |
|           |        |        | 1        | acti       | ve hi                                   | ah                                                                           |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        |          | _          |                                         |                                                                              |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        | 10     |          |            |                                         |                                                                              |                       |              |                                                       |                                   |  |  |  |  |  |
| IPULSE    |        | 10     | 4        | Z          |                                         | required re                                                                  | sponse time of t      | the sys      | stem, the scan rate, the                              | e operating range, the lens, etc. |  |  |  |  |  |
|           |        |        | 4        | 3          | 2                                       | Values                                                                       | Default<br>Setting    | Reco         | ommended Setting                                      |                                   |  |  |  |  |  |
|           |        |        | 0        | 0          | 0                                       | 1µs                                                                          | x                     |              |                                                       |                                   |  |  |  |  |  |
|           |        |        | 0        | 0          | 1                                       | 2µs                                                                          |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        |          | 1          | 0                                       | 3µs                                                                          |                       |              |                                                       | _                                 |  |  |  |  |  |
|           |        |        |          | 0          | 0                                       | 4µs<br>5us                                                                   |                       |              | X (typical setting)                                   | _                                 |  |  |  |  |  |
|           |        |        | 1        | 0          | 1                                       | 6µs                                                                          |                       |              | (i)pical couldy                                       | -                                 |  |  |  |  |  |
|           |        |        | 1        | 1          | 0                                       | 7µs                                                                          |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        | 1        | 1          | 1                                       | 8µs                                                                          |                       |              |                                                       |                                   |  |  |  |  |  |
| n/a       | 0      | 16     |          | 5          |                                         | no function                                                                  | must be set to        | "0"          |                                                       |                                   |  |  |  |  |  |
| TSTMP     | 0      | 16     | 8        | 6          | +                                       | Time stamp                                                                   | p. The LED puls       | e is ge      | enerates in the middle                                | of the time stamp range.          |  |  |  |  |  |
|           |        |        | 8        | 7          | 6                                       | Values                                                                       | Default Setting       | Reco         | ommended Setting                                      |                                   |  |  |  |  |  |
|           |        |        | 0        | 0          | 0                                       | 30µs                                                                         | Х                     | This         | parameter should be set                               | to the same length as the         |  |  |  |  |  |
|           |        |        | 0        | 0          | 1                                       | 60µs                                                                         |                       | the n        | nicrocontroller. I.e., if the                         | time between the SCAN             |  |  |  |  |  |
|           |        |        |          | 1          | 1                                       | 90µs<br>120µs                                                                |                       | comi<br>para | mands issued by the micr<br>meter should be set to 60 | o processor is 60µs, this         |  |  |  |  |  |
|           |        |        |          | 0          | 0                                       | 150µs                                                                        |                       | -            |                                                       |                                   |  |  |  |  |  |
|           |        |        | 1        | 0          | 1                                       | 180µs                                                                        |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        | 1        | 1          | 0                                       | 210µs                                                                        |                       | -            |                                                       |                                   |  |  |  |  |  |
|           |        |        | 1        | 1          | 1                                       | 240µs                                                                        |                       |              |                                                       |                                   |  |  |  |  |  |
| DRATE     | 0      | 16     | 1(       | 09         | Т                                       | Data rate o                                                                  | n the 2-wire bus      | 6            |                                                       |                                   |  |  |  |  |  |
|           |        |        | 10       | 9          |                                         | Values                                                                       | Default Setting       | Reco         | mmended Setting                                       |                                   |  |  |  |  |  |
|           |        |        | 0        | 0          | 2                                       | 250 kbit/s                                                                   | Х                     | if the       | e physical 2-wire bus leng                            | th is up to 100 meters            |  |  |  |  |  |
|           |        |        | 0        | 1          | 5                                       | 00 kbit/s                                                                    |                       |              |                                                       |                                   |  |  |  |  |  |
|           |        |        |          | 1          | -                                       | 1 MDIt/S<br>2 Mbit/s                                                         |                       | if the       | hysical 2-wire hus long                               | th is less than 3 meters          |  |  |  |  |  |
|           |        |        | 11 L     | 1 1        | 1                                       | - 1010103                                                                    |                       | 1            | , priyorour z-wire buo leriy                          |                                   |  |  |  |  |  |

...continued on next page ...

© 2011 ESPROS Photonics Corporation Characteristics subject to change without notice

![](_page_12_Picture_0.jpeg)

| Parameter | Regist | er No. | Bit | No.    | Fund  | ction                                        |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
|-----------|--------|--------|-----|--------|-------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--|--|--|--|
| Name      | RAM    | ROM    |     |        |       |                                              |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
| SOFF      | 0      | 16     | 1   | 11     | Statu | Status of voltage regulator for internal VDD |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
|           |        |        | 11  | Values | Def   | fault Setting                                | Recommended Setting                                                                                                                                                                                                                                                                                                                                                        |                                                           |  |  |  |  |
|           |        |        | 0   | On     |       | Х                                            | when used a receiver                                                                                                                                                                                                                                                                                                                                                       |                                                           |  |  |  |  |
|           |        |        | 1   | Off    |       |                                              | when used as interface chip with 3.3V micro controller                                                                                                                                                                                                                                                                                                                     |                                                           |  |  |  |  |
|           |        |        |     |        |       |                                              |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
| MODE      | 0      | 16     | 14  | 12     | Mode  | e for epc120                                 | usage                                                                                                                                                                                                                                                                                                                                                                      |                                                           |  |  |  |  |
|           |        |        | 14  | 13     | 12    | Value                                        |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
|           |        |        | 1   | 1      | 0     | 6                                            |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
|           |        |        | L   | 1 1    | I     |                                              |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
| VMODE     | 0      | 16     | 1   | 5      | Volat | tile mode                                    |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |
|           |        |        | 15  | Values | Def   | fault Setting                                | Recommended Setting                                                                                                                                                                                                                                                                                                                                                        |                                                           |  |  |  |  |
|           |        |        | 0   | On     |       | Х                                            | This setting allows to overwrite the RAM contents, which is useful debugging. Once the system is fully developed, this parameter sho "1". This setting could also be useful, if the system parameters sho changed "on the fly" in dynamic systems. it is recommended to pro address and burn it into the ROM first. All other parameters can the downloaded upon power-up. | during<br>ould be set to<br>ould be<br>ogram the<br>en be |  |  |  |  |
|           |        |        | 1   | Off    |       |                                              | Set to "1" in the final product to avoid accidentally overwriting of the the RAM registers                                                                                                                                                                                                                                                                                 | e contents of                                             |  |  |  |  |
|           |        |        |     |        |       |                                              |                                                                                                                                                                                                                                                                                                                                                                            |                                                           |  |  |  |  |

Table 3: epc120 Registers 0 and 16

# 6. Parameter Setting Registers 1/17

| Parameter | Regist | er No. | Bit No.                   | Function                                                           |
|-----------|--------|--------|---------------------------|--------------------------------------------------------------------|
| Name      | ROM    | RAM    |                           |                                                                    |
| FUSEBIT   | 1      | 17     | 0                         | This bit will automatically be set when register 17 is programmed. |
|           |        |        | 0Values0Register1Register | 17 is not programmed<br>17 is programmed                           |
| n/a       | 1      | 17     | 121                       | no function, must be set to "0"                                    |
| TPER      | 1      | 17     | 1513                      | must be set to "010"                                               |
|           |        |        | <b>15 14 1</b><br>0 1     | <b>3</b><br>0                                                      |

Table 4: epc120 Registers 1 and 17

![](_page_13_Picture_0.jpeg)

#### 7. Parameter Setting Registers 2/18 Bit No. Register No. Function Parameter Name ROM RAM FUSEBIT This bit will automatically be set when register 18 is programmed. 2 18 0 0 Values 0 Register 18 is not programmed Register 18 is programmed 1 SENSN 2 18 Lower threshold setting of the receiver input (sensitivity). A lower value increases the sens -3..1 itivity. A too sensitive setting leads to false readings because of shot noise of the receiver photo diode and the internal amplifier (typ. input noise level is 7nA RMS without photo di ode). Also induced EMI can lead to false readings if the sensitivity is set too low. The EMI sensitivity is heavily depending on the system architecture and the electromechanical design. The better the shielding of the chip and the photo diode and the better the PCB layout, the better the EMI immunity. The tolerance of the threshold is approx. ±25%. 3 2 1 Values Default Setting **Recommended Setting** 0 0 0 24nA Х 0 0 1 36nA 48nA 0 1 0 0 Х 1 1 60nA 1 0 0 72nA 1 0 1 84nA 1 1 0 96nA 1 1 1 108nA 2 SENSH 18 6..4 Upper threshold setting of the receiver input (light reserve level). The tolerance of the threshold is approx. ±25%. 6 5 4 Values **Default Setting Recommended Setting** 0 0 0 60nA Х Set this value 50% above the value set at SENSN, 0 0 1 72nA i.e., if SENSN is set to 84nA 0 0 1 48nA, set SENSH to 72nA 0 96nA 1 1 0 0 108nA 1 120nA 1 0 1 1 1 0 132nA 1 1 1 144nA SLOW no function, must be set to "1" 2 18 7 IVCOFF 8 2 18 no function, must be set to "0" SENSLC 9 2 must be set to "1" 18 2 n/a 18 12..10 no function, must be set to "0" TSET 2 18 15..13 Settling time delay from inactive to active mode. 15 14 13 Values **Default Setting** Comments 0 0 0 0 Х If T<sub>SCAN</sub> >=60µs If T<sub>SCAN</sub> <60µs 0 0 1 1 Table 5: epc120 Registers 2 and 18

![](_page_14_Picture_0.jpeg)

| Parameter | Regist | er No. | Bit No                  | •                       | Fund               | ction                                         |                        |                                             |  |  |  |  |  |
|-----------|--------|--------|-------------------------|-------------------------|--------------------|-----------------------------------------------|------------------------|---------------------------------------------|--|--|--|--|--|
| Name      | RAM    | ROM    |                         |                         |                    |                                               |                        |                                             |  |  |  |  |  |
| FUSEBIT   | 3      | 19     | 0                       |                         | This               | bit will automatically                        | be set when register 1 | 8 is programmed.                            |  |  |  |  |  |
|           |        |        | 0 Val<br>0 Reg<br>1 Reg | ues<br>gister<br>gister | 18 is n<br>18 is p | ot programmed<br>rogrammed                    |                        |                                             |  |  |  |  |  |
| n/a       | 3      | 19     | 81                      |                         | no fu              | no function, must be set to "0"               |                        |                                             |  |  |  |  |  |
| C2X       | 3      | 19     | 9                       |                         | Curre              | ent amplitude on the                          | 2-wire bus             |                                             |  |  |  |  |  |
|           |        |        | 9 V                     | alues                   | 5                  | Default Setting                               | Recommended Settin     | ng                                          |  |  |  |  |  |
|           |        |        | 0                       | 8mA                     |                    | Х                                             | Х                      |                                             |  |  |  |  |  |
|           |        |        |                         | 6mA                     |                    |                                               |                        |                                             |  |  |  |  |  |
| CDET      | 3      | 19     | 1110                    |                         | Dete<br>nal a      | ction level for the co<br>mplitude on the bus | mparator on the 2-wire | bus. The level represents the optimum sig - |  |  |  |  |  |
|           |        |        | 11 10                   | V                       | alues              | Default Setting                               | Recommended<br>Setting |                                             |  |  |  |  |  |
|           |        |        | 0 0                     | 5                       | i0mV               | Х                                             |                        |                                             |  |  |  |  |  |
|           |        |        | 0 1                     | 1                       | n/a                |                                               |                        |                                             |  |  |  |  |  |
|           |        |        | 1 1                     | 20                      | 00mV               |                                               | Х                      |                                             |  |  |  |  |  |
|           |        |        |                         |                         |                    | I I                                           |                        |                                             |  |  |  |  |  |
| TPER      | 3      | 17     | 1513                    |                         | must               | t be set to "010"                             |                        |                                             |  |  |  |  |  |
|           |        |        | 15 1                    | 4                       | 13                 |                                               |                        |                                             |  |  |  |  |  |
|           |        |        | 0                       |                         | 0                  |                                               |                        |                                             |  |  |  |  |  |
|           |        |        |                         |                         |                    |                                               |                        |                                             |  |  |  |  |  |

### Table 6: epc120 Registers 3 and 19

All other registers are factory set and must not be used or altered.

# 8. Sample Parameter Setting

If we are going to use a system with a maximum cable length of 3 meters, and the maximum speed on the 2-wire bus, it is recommended to set the registers as follows:

![](_page_14_Figure_7.jpeg)

![](_page_15_Picture_0.jpeg)

# 9. Timing

#### Overview

To operate the individual elements at the 2-wire bus, some steps per element are necessary. The following drawing shows the concept:

![](_page_15_Figure_5.jpeg)

Figure 14: Basic sequence to operate one light beam. Note that the process in the receiver and in the transmitter are running concurrently.

The individual epc120 elements at the 2-wire bus are normally in a sleep mode in order to keep the overall power consumption as low as possible. Thus, an epc120 element has to be activated before it can be used. This wakeup procedure needs a certain time until all internal operating levels have been stabilized. This time is called settling time which can be set with the parameter TSET. Then, the receive window can be opened and the internal LED driver send a pulse out through the LED pin, which the chip can receive, if no obstacle is in the light beam. After that, the receive window must be turned off which also puts the receiver to standby. Finally, the receive results which are stored in the expl20 element can be read.

In fact, there are several steps to operate one light beam only. This needs quite a long time if everything is done in a strictly sequential way. In order to improve the performance of the whole system, certain steps can be done in parallel. The following chapters describe the timing processes in more detail.

### Timing

The microprocessor in the bus controller controls epc120 with SCAN commands. Every SCAN command includes an address which selects the requested epc120 element.

**PD PIN operation:** A first SCAN command switches the selected epc120 element from standby into operation mode. The process from standby to operation requires a certain time which is called settling time (see Figure 15). The settling time minimum is 60µs. The second SCAN command opens the the reception window, there also the pulse at the LED PIN is sent, where a third SCAN command closes the reception window and puts the epc120 element back to standby. The fourth SCAN command fetches the received results.

LED PIN operation: A first SCAN command switches the selected epc120 element from standby into operation mode. The process from standby to operation requires a certain time which is called settling time (see Figure 15). The second SCAN command starts the light pulse window. After the time PDELAY, one light pulse of the length TPULSE is generated. A third SCAN command puts the element back to standby. If the TSTMP and the period of the SCAN commands of the microprocessor are equal the pulse will be emitted exactly in the middle of the reception window.

The whole operation is optimized for shortest possible scan periods. Figure 15 shows the timing for a settling time of one scan period (TSET=0) and the addresses given in the shortest possible sequence.

![](_page_16_Picture_0.jpeg)

![](_page_16_Figure_2.jpeg)

Figure 15: Timing of the scan process

where

*n* = *element number* 

 $T_{SCAN}$  = interval between two scan commands which is given by the micro processor

The minimum delay time between the first SCAN command and the earliest possible access of the result can be calculated as a function of the parameter TSET and the scan period  $T_{SCAN}$ :

$$T_{DEL} = (TSET + 3) \cdot T_{SCAN}$$

The sensor device counts the number of SCAN commands on the bus to present its result at the right time. If the number of a SCAN command is n, the result will arrive with the SCAN command n+TSET+3.

The timing of the emitter commands have to be adjusted in order to emit the light pulse near the center of the reception window of the corresponding receiver. E.g. if the reception window length is set to 30  $\mu$ s, the light pulse shall be generated 15 $\mu$ s after the opening of the receive window. The length of the reception window is defined by the time elapsed between the second and the third SCAN command. The parameter TSTMP defines the time window to measure the arrival time of the received light pulse. This result is returned in the result TIMESTAMP. The timing position of the following light pulses can be optimized to the center of the receiving window. The resolution of TIMESTAMP is 4 bits. Thus, the value is 0000 if the pulse is received at the beginning of the window, and 1111 if it arrived at the end. A light pulse received approx. In the middle of the receive window would be represented as 0011, 0100 or 0101.

The minimal scan period, which is the time between two consecutive SCAN commands, is given by the communication on the 2-wire bus: 62 bits for the command and the results have to be transmitted in this time. The minimal scan period is then

$$T_{SCANmin} = 31 * T_{CLK} * k$$

k is given by the parameter DRATE and varies between 1 and 8 (refer to Table 1, Table 3 and Table 7). T<sub>CLK</sub> is 1µs. Thus, the minimal scan period is 31µs.

### Special Cases

- If the same device is addressed again at the end of its reception window, it continues waiting for pulses. This procedure allows to synchronize the receiver with the transmitter on an optical basis, if there is no electrical synchronization.
- If a device detects a command during a scan operation which is not the command SCAN, it is put into standby mode.
- A SCAN command with address 0 can be used to fetch the results without starting a new scan command.

![](_page_17_Picture_1.jpeg)

# 10. SPI Interface

The SPI interface allows the microcontroller to communicate with the sensors over the 2-wire bus system via the interface device.

While data are sent to the interface chip by the microcontroller, the result of the last (or more generally: a previous) command is sent from the interface chip to the microcontroller according to the SPI protocol. The timing diagram is shown in Figure 16).

![](_page_17_Figure_5.jpeg)

### Figure 16: SPI bus timing

### **Timing Specification SPI Interface**

| Symbol                               | Parameter                  | Conditions/Comments |      | Values |      | Units |
|--------------------------------------|----------------------------|---------------------|------|--------|------|-------|
|                                      |                            |                     | Min. | Тур.   | Max. |       |
| f <sub>SCK</sub>                     | SCK Clock frequency        |                     |      |        | 10   | MHz   |
| t <sub>H</sub> / t∟                  | HIGH and LOW period of SCK |                     | 50   |        |      | ns    |
| $t_{su}$ / $t_{Hold}$                | Set-up and hold time SI    |                     | 15   |        |      | ns    |
| t <sub>1</sub>                       | Edge time CSB - SCK        |                     | 50   |        |      | ns    |
| t <sub>rf</sub> / t <sub>rfSCK</sub> | Rise / fall time           | SO, SCK             |      |        | 20   | ns    |
| t <sub>D</sub>                       | Data valid after SCK edge  | SO                  |      |        | 20   | ns    |

### **Command Overview**

### **General Description**

Communication is based on telegrams, which are sent and received over the 2-wire bus. Such telegrams are initiated by the respective command to the SPI interface. The epc10x chips accept two types of commands:

- 1. Commands which communicate to the interface chips, also called "Direct Commands" (Figure 17).
- 2. Commands which communicate to the chips at the 2-wire bus, also called "Broadcast Commands" (Figure 18).

The first bit in the data stream from the microprocessor to the interface chip (SI pin) defines whether it is a command to the interface chip (a "0") or the the chips on the 2-wire bus (a "1").

![](_page_17_Figure_15.jpeg)

![](_page_18_Picture_0.jpeg)

![](_page_18_Figure_2.jpeg)

Figure 18: Communication to the sensor devices (Broadcast Command)

### Command List

| Name  | Command<br>Code<br>C <sub>0</sub> C <sub>2</sub> | Command<br>Extension Code<br>R₀ R₄ | Function                   | Mode      | Number of data bits<br>on 2-wire bus<br>D₀Dn | Returned<br>Data |
|-------|--------------------------------------------------|------------------------------------|----------------------------|-----------|----------------------------------------------|------------------|
| SCAN  | 000                                              |                                    | Scan                       | Broadcast | 62                                           | Yes              |
| NOP   | 000                                              |                                    | No operation               | Direct    | 0                                            | Yes              |
| READ  | 010                                              | Register address                   | Read                       | both      | 97                                           | Yes              |
| WRITE | 011                                              | Register address                   | Write to volatile register | both      | 62                                           | No               |
| ADRA  | 101                                              |                                    | Address allocation         | Broadcast | 62                                           | No               |
| PROG  | 110                                              | Register address                   | Program                    | both      | 62                                           | No               |
| TEST  | 111                                              | 10000                              | Test mode                  | both      | 80                                           | Yes              |
| RESET | 111                                              | 11001                              | Reset the device           | both      | 62                                           | No               |

Table 7: Command list

#### Remarks:

- · Additional SCK clock cycles have no effect.
- The telegram length on the 2-wire bus is given in the number of data clock cycles. It allows to calculate the minimum interval between two commands.
- If an SPI command is given while another command is being transmitted on the 2-wire bus, the new command is ignored.
- The READ and WRITE commands in the direct access mode require 2 additional SCK cycles.

#### Command SCAN

The command SCAN enables the addressed device, times the ongoing operation or fetches the scan result. The operation of the command SCAN is described more in detail in Chapter Error: Reference source not found.

![](_page_18_Figure_14.jpeg)

![](_page_19_Picture_1.jpeg)

| Data Bits                       | Function                                            |                                             |  |  |
|---------------------------------|-----------------------------------------------------|---------------------------------------------|--|--|
| Ν                               | Indica                                              | Indicates, if new data is available         |  |  |
|                                 | N                                                   | Values                                      |  |  |
|                                 | 0                                                   | no new data available                       |  |  |
|                                 | 1                                                   | new data available                          |  |  |
| D <sub>0</sub> D <sub>3</sub>   | Times                                               | tamp                                        |  |  |
| D <sub>4</sub>                  | Status                                              | Status of receiver threshold "normal"       |  |  |
|                                 | D <sub>4</sub>                                      | D <sub>4</sub> Values                       |  |  |
|                                 | 0                                                   | Receiver threshold set by SENSN not reached |  |  |
|                                 | 1                                                   | Receiver threshold set by SENSN exceeded    |  |  |
| D₅                              | Status of receiver threshold "high" (light reserve) |                                             |  |  |
|                                 | D <sub>4</sub>                                      | Values                                      |  |  |
|                                 | 0                                                   | Receiver threshold set by SENSH not reached |  |  |
|                                 | 1                                                   | Receiver threshold set by SENSH exceeded    |  |  |
| D₅ D <sub>10</sub>              | empty, not used                                     |                                             |  |  |
| D <sub>11</sub> D <sub>20</sub> | Devic                                               | Device address                              |  |  |
| E <sub>0</sub> E <sub>3</sub>   | Error codes, refer to Chapter Error Codes           |                                             |  |  |

Table 8: Result of a SCAN command

### Command NOP

The command NOP can be used to fetch the last received data without sending a new command. With this command it is possible to monitor the 2-wire interface by a second interface device in a redundant system.

#### Command TEST

The command TEST issues an internal test pulse or a DC current at the PD input pin on a specific receiver. It simulates basically a received light pulse or DC sunlight influence to check the proper functionality of the receiver(s) without using an emitter. This mode is initialized by the command TEST and is left after a complete SCAN sequence.

| Code                          | Extension | Amplitude                                                                   |                                                      | Current Shape                                |
|-------------------------------|-----------|-----------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------|
| C <sub>0</sub> C <sub>2</sub> | R₀ … R₄   | D₀ … D₄                                                                     |                                                      |                                              |
| 111                           | 10000     | 1xxxxx<br>x1xxxx<br>xx1xxx<br>xxx1xx<br>xxx1xx<br>xxxx1x<br>xxxx1x<br>xxxx1 | 25nA<br>50nA<br>100nA<br>100µA<br>500µA DC<br>2mA DC | Pulse<br>Pulse<br>Pulse<br>Pulse<br>DC<br>DC |

#### Table 9: Self Test

The applied current is the sum of different current sources: In column "Pulse Amplitude" of Table 9 a "1" means, that the corresponding current is added. Example: 110000 generates a pulse of 75nA without DC.

#### Command RESET

The command RESET resets the device and initiates a startup. All devices can be reset simultaneously by using address 0.

#### Command ADRA

ADRA is used during the configuration of a light curtain system to allocate a logical address to the physical position of the the emitter or receiver element.

The command ADRA stores the device address to the volatile memory only (RAM). If the device address has to be stored permanently, the command PROG has to be used to copy the previous stored device address from the RAM register into the ROM register. ADRA can only be used if there was no previous PROG command to the address register.

The address 0 is reserved to address all devices together or none and must not be used as an individual address.

The command ADRA generates no result.

For details refer to Chapter Address Programming.

![](_page_20_Picture_0.jpeg)

![](_page_20_Picture_1.jpeg)

### Command READ

The RAM and ROM can be read by the command READ. The command is extended by the register address.

![](_page_20_Figure_4.jpeg)

Figure 20: Timing Result Data

The bit N indicates whether a new result has been received (broadcast mode).  $D_0...D_4$  contains the address,  $D_{11}...D_{20}$  contains the returned data.

| Data Bits                      | Function                                     |  |  |  |
|--------------------------------|----------------------------------------------|--|--|--|
| N                              | Indicates, if new data is available          |  |  |  |
|                                | N Values                                     |  |  |  |
|                                | 0 no new data available                      |  |  |  |
|                                | 1 new data available                         |  |  |  |
|                                |                                              |  |  |  |
| $D_0 \dots  D_4$               | 5 bit register address                       |  |  |  |
| D <sub>5</sub> D <sub>20</sub> | 16 bit returned data (one complete register) |  |  |  |

Table 10: Result of a READ command

### Command WRITE

Data can be written into the RAM by using the command WRITE. The command is extended by the register address and the data. It is only possible to write to registers if the corresponding register in the ROM has not been written yet. It is not possible to write directly to a ROM register. If the data has to be stored into the ROM register, a subsequent command PROG has to be used.

### Command PROG

The command PROG transfers the data from the RAM register to the corresponding ROM register. See chapter Address Programming for a detailed description.

### **Returned Results**

The results at pin SO depends on one of the previous commands and can be fetched by any command or just by toggling SCK while CS is low (=NOP).

- The data is represented with the LSB first.
- · After an SPI communication the data register is cleared.
- By holding the CS line to 0 it is possible to trigger on a positive edge of SO.
- If more clock toggles SCK are issued than data can be fetched, zeros are transmitted.

![](_page_21_Picture_0.jpeg)

# 11. Address Programming

### **General Description**

The device address is initially set to "0000" and the devices are not parametrized. However, all devices hold a unique chip ID. However, due to the 2-wire bus concept, the physical location of an individual device is not known to the microcontroller. In order to operate the light curtain, the microcontroller needs to allocate a specific receiver to a specific emitter. Usually, the receiver at one end of the 2-wire bus gets the address 1, the next receiver the address 2 and so on. The same must be done on the emitter side. Once all devices on the receiver and on the emitter side got their address, the microcontroller can operate the light curtain. The address allocation, meaning the allocation of a physical location to a logical address, is usually done in the factory of the light curtain manufacturer.

To do so, a specific address allocation procedure together with the parametrization of the devices must be executed first. The following procedure is an example how to allocate a unique address and how to parametrize each device.

| No. | Step                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|-----|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1   | Set the address of the interface device    | Set the address of the interface device with a direct command to a fix number, which should not be 0. It is recommended to use generally the address 1023 for the interface device.                                                                                                                                                                                                                                                                                        |  |  |
| 2   | Parametrize the devices on the 2- wire bus | The data rate DRATE of the 2-wire interface is initially set to 300 kbit/s. It shall be set to the correct value by addressing all devices, which are initially at address 0, simultaneously. During this step, all other parameters in register 16 can also be set.                                                                                                                                                                                                       |  |  |
| 3   | Parametrize the interface device           | The data rate of the 2-wire interface is initially set to 300 kbit/s. It has to be set to the same value like the other devices on the same 2-wire bus.                                                                                                                                                                                                                                                                                                                    |  |  |
| 4   | Set all other<br>registers                 | For the address allocation the following parameters should be set:<br>TPER = 2<br>SENSN = 7<br>SLOW=1<br>This can be done to all devices at the same time by writing the registers to device 0.                                                                                                                                                                                                                                                                            |  |  |
| 5   | Address allocation                         | Since the devices have an open receive window, all of them are able to receive light pulses. This mode is used to allocate the logical address to the physical location. The procedure is as follows:                                                                                                                                                                                                                                                                      |  |  |
|     |                                            | <ul> <li>Issue the command ADRA using address n</li> <li>flash a light pulse to the photo diode which is connected to the chip at the physical position n (make sure that all the other photo diodes cannot receive a light pulse). By receiving a light pulse, the address n is stored into the RAM of the element at the physical position n. Thus, the device, which receives a light pulse, memorizes the address n as its own address in the final system.</li> </ul> |  |  |
|     |                                            | This procedure has to be repeated for every individual element on the 2-wire bus. It is recommended to start with the address 1 for the element which is closest to the controller and increment the address by 1 with every individual element. In the case of a 20-beam light curtain, addresses from 1 to 20 on the receiv - er and on the emitter side are accessible. However, the interface chip is usually located at address 1023.                                 |  |  |
| 6   | Address check                              | It is recommended to check the correct address setting by addressing every device in the system using the READ command. All devices addressed shall response to the READ command.                                                                                                                                                                                                                                                                                          |  |  |
| 7   | Address<br>programming                     | Once all addresses of all devices at the 2-wire bus are stored into the RAM (register 23), the address should be transferred to the ROM (register 7) for each device separately by using the command PROG. Please refer to chapter 11. Address Programming.                                                                                                                                                                                                                |  |  |
| 8   | Set parameters                             | Parameters like TSTMP, MODE, VMODE, TPULSE etc. are stored into the RAM of all devices using the command WRITE. If the global address "0" is used, all devices receive the parameters at the same time. Since the internal voltage regulator of the interface device is not needed, the parameter SOFF has to be set to "1" (refer to Table 3). All other devices at the 2-wire bus must have a "0" for SOFF.                                                              |  |  |
| 9   | Check<br>parameters                        | The parameters should be checked by reading them back from each device using the READ command.                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 10  | Program<br>parameters                      | If all parameters are stored correctly, store the parameters into the non-volatile memory by using the command PROG.                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 11  | Test<br>programming and<br>addressing      | To check the programming of addresses and parameters, turn off the power supply or reset all devices and readout all addresses and parameters again.                                                                                                                                                                                                                                                                                                                       |  |  |
|     |                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |

![](_page_22_Picture_0.jpeg)

#### Programming Procedure

Programming the device is a transfer of the data from the RAM to the corresponding ROM register. Each 16-bit register must be transferred individually. Thus, register 16 is transferred to register 0, register 17 to register 1, register 18 to register 2, register 19 to register 3, and register 23 to register 7. All other registers must not be used.

Figure 21 shows the timing of the programming sequence for one register:

![](_page_22_Figure_5.jpeg)

- Each register can be programmed once only (OTP).
- After programming a register, bit no. 0 of this register becomes automatically a one to indicate that the register is programmed.

![](_page_23_Picture_0.jpeg)

# 12. Considerations for Safety Applications

Since the epc120-family chips can be used in safety related products, like machine safety light products, certain data integrity mechanisms have been integrated. The safety concept on chip and communication level are described in this chapter.

### Data Integrity on the 2-Wire Power-Bus

Several mechanisms on different layers are implemented to guarantee a low residual error rate on the 2-wire power-bus.

### **Physical layer**

- · Modulation and medium: Current modulation on a twisted pair line is highly immune to interference.
- Start bit detection: The start pulse must have the correct orientation. Otherwise, the pulse is discarded.
- Pulse alternation: Since Manchester coding is used, the pulses need to alternate. An error is detected, if this is not the case.
- Pulse timing: The timing of the information pulses is fixed. A missing bit (too long pause) is detected as an error.
- End bit detection: Since current modulation is used and the current is switched off when the message is completed, the last pulse has a specified orientation.
- · Sequence length: The message length is well known. A too short or too long message is detected as an error.

#### Data link layer

- Error control coding: If no errors have been detected on the physical layer, the received pulse sequence is processed by an error control algorithm. Depending on the application, *either* 2 errors can be corrected, *or* 4 errors can be detected. A higher number of errors can be detected with a reliability of 1000:1.
- · Strict master-slave system: A sensor may only respond, if a request from the microcontroller was correctly received.
- Explicit addressing: Each message (master > slave and slave > master) contains the address of the sensor element. Even if the wrong sensor replies to the microcontroller call, the error will be detected.

### **Residual Error Rate**

Although no explicit calculations have been done yet, the residual error rate of the 2-wire power-bus is at least as good as in the ASi. The ASi has an residual error probability of a system with Hamming distance 5 (HD5) and belongs to the DIN 19244 data integrity class I2 for an error probability p=1e-2, and to class I3 for p=1e-3.

### **Error Cases**

Each sensor device has its unique address. The microprocessor addresses each device individually and fetches the result some scan periods later. The result includes also the address of the answering device.

| Error Cases                         | Consequences                                                                                                                            |  |  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2 sensor answer on the same address | Collision during the transmission of the result.<br>$\rightarrow$ Error detection in the interface device<br>$\rightarrow$ Error state. |  |  |
| Error during the scan command       | No device answers $\rightarrow$ no data (all zero).                                                                                     |  |  |
| Error during result transmission    | Error detection in the interface device $\rightarrow$ Error state.                                                                      |  |  |

### Error Codes

### Different error states are monitored:

|   | Device    | Error                                          | Action                   | Error Code<br>E0 E3 |
|---|-----------|------------------------------------------------|--------------------------|---------------------|
| 1 | Sensor    | Non-correctable error in the received telegram | Device doesn't response  | -                   |
| 2 | Sensor    | Command to fetch the result too early          | Normal answer            | -                   |
| 4 | Interface | No answer from the sensor device               | Result data zero         | -                   |
| 5 | Interface | Non-correctable error in the received telegram | Error reported           | 1xxx *)             |
| 6 | Interface | Return telegram not complete                   | Error handling procedure | 0100                |

Table 11: Error states

\*) The last three error bits contain the number of detected errors.

![](_page_24_Picture_0.jpeg)

![](_page_24_Figure_2.jpeg)

![](_page_25_Picture_0.jpeg)

# **Reflow Solder Profile**

For infrared or conventional soldering the solder profile has to follow the recommendations of IPC/JEDEC J-STD-020C (min. revision C) for Pb-free assembly for both types of packages. The peak soldering t emperature ( $T_L$ ) should not exceed +260°C for a maximum of 4 sec.

# Packaging Information (all measures in mm)

### **Tape & Reel Information**

The devices are mounted on embossed tape for automatic placement systems. The tape is wound on 178 mm (7 inch) or 330 mm (13 inch) reels and individually packaged for shipment. General tape-and-reel specification data are available in a separate data sheet and indicate the tape sizes for various package types. Further tape-and-reel specifications can be found in the Electronic Industries Association (EIA) standard 481-1, 481-2, 481-3.

![](_page_25_Figure_7.jpeg)

Figure 26: CSP10 and QFN16 Tape Dimensions

ESPROS Photonics AG does not guarantee that there are no empty cavities. Thus, the pick-and-place machine should check the presence of a chip during picking.

# **Ordering Information**

| Туре         | Package | RoHS compliance | Packaging<br>Method |
|--------------|---------|-----------------|---------------------|
| epc120-CSP10 | CSP10   | Yes             | Reel                |
| epc120-QFN16 | QFN16   | Yes             | Reel                |

![](_page_26_Picture_0.jpeg)

# **IMPORTANT NOTICE**

ESPROS Photonics AG and its subsidiaries (epc) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to epc's terms and conditions of sale supplied at the time of order acknowledgment.

epc warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with epc's standard warranty. Testing and other quality control techniques are used to the extent epc deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

epc assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using epc components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

epc does not warrant or represent that any license, either express or implied, is granted under any epc patent right, copyright, mask work right, or other epc intellectual property right relating to any combination, machine, or process in which epc products or services are used. Information published by epc regarding third-party products or services does not constitute a license from epc to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from epc under the patents or other intellectual property of epc.

Resale of epc products or services with statements different from or beyond the parameters stated by epc for that product or service voids all express and any implied warranties for the associated epc product or service. epc is not responsible or liable for any such statements.

epc products are not authorized for use in safety-critical applications (such as life support) where a failure of the epc product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of epc products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by epc. Further, Buyers must fully indemnify epc and its representatives against any damages arising out of the use of epc products in such safety-critical applications.

epc products are neither designed nor intended for use in military/aerospace applications or environments unless the epc products are specifically designated by epc as military-grade or "enhanced plastic." Only products designated by epc as military-grade meet military specifications. Buyers acknowledge and agree that any such use of epc products which epc has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

epc products are neither designed nor intended for use in automotive applications or environments unless the specific epc products are designated by epc as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, epc will not be responsible for any failure to meet such requirements.