#### **PYTHON 480** <u>Python-Company (Company)</u>  $\frac{4}{\sqrt{3}}$

# PYTHON 0.48 Megapixel Gibbon Shutter Children<br>Image Sensor Image Sensor

### **FEATURES**

- 808 x 608 Active Pixels, 1/3.6" Optical Format
- 4.8 µm x 4.8 µm Low Noise Global Shutter Pixels with In-pixel CDS
- Monochrome (SN, SP), Color (SE, SF)
- Wide CRA Options (SP, SF)
- Frame Rate up to 120 fps at Full Resolution
- On−chip 10−bit Analog−to−Digital Converter (ADC)
- 10−bit Output Mode
- One Low Voltage Differential Signaling (LVDS) High Speed Serial Output or Parallel CMOS Output
- Random Programmable Region of Interest (ROI) Readout
- Serial Peripheral Interface (SPI)
- Automatic Exposure Control (AEC)
- Phase Locked Loop (PLL)
- Dual Power Supply (3.3 V and 1.8 V)
- −40°C to +85°C Operational Temperature Range
- 67 pin CSP
- 265 mW / 226 mW Power Dissipation (LVDS 120 fps / 60 fps)
- These Devices are Pb−Free and are RoHS Compliant

### **APPLICATIONS**

- Machine Vision
- Motion Monitoring
- Security
- Bar Code Scanning



### **ON Semiconductor®**

**[www.onsemi.com](http://www.onsemi.com/)**

### **DESCRIPTION**

The PYTHON 480 image sensor utilizes high sensitivity 4.8 µm x 4.8 µm pixels that support low noise "pipelined" and "triggered" global shutter readout modes. In global shutter mode, the sensors support correlated double sampling (CDS) readout, reducing noise and increasing dynamic range.

The image sensors have on−chip programmable gain amplifiers and 10−bit A/D converters. The integration time and gain parameters can be reconfigured without any visible image artifact. Optionally the on−chip automatic exposure control loop (AEC) controls these parameters dynamically. The image's black level is either calibrated automatically or can be adjusted by a user programmable offset.

A high level of programmability using a four wire serial peripheral interface enables the user to read out specific regions of interest. Up to four regions can be programmed, achieving even higher frame rates.

The image data interface consists of one LVDS data lane, facilitating frame rate up to 120 frames per second. A separate synchronization channel containing payload information is provided to facilitate the image reconstruction at the receiving end. The device also provides a parallel CMOS output interface at the same frame rate.

The PYTHON 480 is packaged in a 67−pin CSP package and is available in monochrome and Bayer color configurations with standard and wide CRA options.

### **ORDERING INFORMATION**



NOTE: More details on the part coding can be found at [http://www.onsemi.com/pub\\_link/Collateral/TND310](http://www.onsemi.com/pub_link/Collateral/TND310-D.PDF)−D.PDF

### **PRODUCTION MARK**



where Y is 1-digit year, M is the 1-digit month, NNN is the 3-digit serial number for wafer identification

### **SPECIFICATIONS**

#### **Key Specifications**

#### **Table 1. GENERAL SPECIFICATIONS**



#### **Table 2. ELECTRO−OPTICAL SPECIFICATIONS**



NOTE: All numbers listed are for 1x analog gain condition unless otherwise noted.

NOTE: All numbers listed are for 1x gain condition unless otherwise noted.

#### **Table 3. RECOMMENDED OPERATING RATINGS** (Note 1)



Functional operation above the stresses listed in the Recommended Operating Ranges is not implied. Extended exposure to stresses beyond the Recommended Operating Ranges limits may affect device reliability.

1. Performance parameters may degrade above 60°C.

#### **Table 4. ABSOLUTE MAXIMUM RATINGS** (Note 4)



Stresses exceeding those listed in the Maximum Ratings table may damage the device. If any of these limits are exceeded, device functionality should not be assumed, damage may occur and reliability may be affected.

2. The ADC is 11−bit, down−scaled to 10−bit. The PYTHON uses a larger word−length internally to provide 10−bit on the output.

3. Operating ratings are conditions in which operation of the device is intended to be functional.

4. ON Semiconductor recommends that customers become familiar with, and follow the procedures in JEDEC Standard JESD625−A. Refer to Application Note AN52561. Long term exposure toward the maximum storage temperature will accelerate color filter degradation.

#### <span id="page-3-0"></span>**Table 5. ELECTRICAL SPECIFICATIONS**

**Boldface limits apply for T<sub>J</sub> = T<sub>MIN</sub> to T<sub>MAX</sub>, all other limits T<sub>J</sub> = +30°C. (Notes [5, 6, 7,](#page-4-0) [8](#page-4-0))** 



**Power Supply Parameters − LVDS**  (NOTE: All ground pins (gnd\_18, gnd\_33, gnd\_colpc) should be connected to an external 0 V ground reference.)



#### **Power Supply Parameters − CMOS**



**I/O − LVDS (EIA/TIA−644): Conforming to standard/additional specifications and deviations listed**



**I/O − CMOS 1.8 V Signal levels** (Note [9\)](#page-4-0)



#### **Electrical Interface − LVDS**



Product parametric performance is indicated in the Electrical Characteristics for the listed test conditions, unless otherwise noted. Product performance may not be indicated by the Electrical Characteristics if operated under different conditions.

[5](#page-4-0). All parameters are characterized for DC conditions after thermal equilibrium is established.

[6](#page-4-0). This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is recommended that normal precautions be taken to avoid application of any voltages higher than the maximum rated voltages to this high

impedance circuit.

[7](#page-4-0). Minimum and maximum limits are guaranteed through test and design.

[8](#page-4-0). Refer to ACSPYTHON480 available at the Image Sensor Portal for detailed acceptance criteria specifications.

[9](#page-4-0). CMOS inputs are compatible with 3.3 V signal levels.

[10.](#page-4-0)Longer integration times are possible, but with possible image quality trade−offs.

[11.](#page-4-0) Data is clocked on the rising edge of the output clock. This can be changed to the falling edge by register 130[8]

#### <span id="page-4-0"></span>**Table [5](#page-3-0). ELECTRICAL SPECIFICATIONS** (continued)

**Boldface limits apply for T<sub>J</sub> = T<sub>MIN</sub> to T<sub>MAX</sub>, all other limits T<sub>J</sub> = +30°C. (Notes 5, 6, 7, 8)** 



**Electrical Interface − CMOS**



#### **Frame Specifications − LVDS**



#### **Frame Specifications − CMOS**



Product parametric performance is indicated in the Electrical Characteristics for the listed test conditions, unless otherwise noted. Product performance may not be indicated by the Electrical Characteristics if operated under different conditions.

5. All parameters are characterized for DC conditions after thermal equilibrium is established.

6. This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields. However, it is recommended that normal precautions be taken to avoid application of any voltages higher than the maximum rated voltages to this high impedance circuit.

7. Minimum and maximum limits are guaranteed through test and design.

8. Refer to ACSPYTHON480 available at the Image Sensor Portal for detailed acceptance criteria specifications.

9. CMOS inputs are compatible with 3.3 V signal levels.

10.Longer integration times are possible, but with possible image quality trade−offs.

11. Data is clocked on the rising edge of the output clock. This can be changed to the falling edge by register 130[8]

#### **Color Filter Array**

The sensor is processed with a Bayer RGB color pattern as shown in Figure 1. Pixel (0,0) has a red filter situated to the bottom left.



**Figure 1. Color Filter Array for the Pixel Array**

#### **Quantum Efficiency**



**Figure 2. Quantum Efficiency Curve for Mono and Color**

#### <span id="page-6-0"></span>**Ray Angle and Microlens Array Information**

An array of microlenses is placed over the CMOS pixel array in order to improve the absolute responsivity of the photodiodes. The combined microlens array and pixel array has two important properties:

#### 1. Angular dependency of photoresponse of a pixel

The photoresponse of a pixel with microlens in the center of the array to a fixed optical power with varied incidence angle is as plotted in Figure 3, where definitions of angles  $\phi$ x and  $\phi$ y are as described by Figure [4.](#page-7-0)

#### 2. Microlens shift across array and CRA

The microlens array is fabricated with a slightly smaller pitch than the array of photodiodes. This difference in pitch creates a varying degree of shift of a pixel's microlens with regards to its photodiode. A shift in microlens position

versus photodiode position will cause a tilted angle of peak photoresponse, here denoted Chief Ray Angle (CRA). Microlenses and photodiodes are aligned with 0 shift and CRA in the center of the array, while the shift and CRA increases radially towards its edges, as illustrated by Figure [5](#page-7-0).

The purpose of the shifted microlenses is to improve the uniformity of photoresponse when camera lenses with a finite exit pupil distance are used. The CRA varies nearly linearly with distance from the center as illustrated in Figure [6,](#page-7-0) with a corner CRA of approximately 1.65 degrees. This edge CRA is matching a lens with exit pupil distance of  $\sim 60$  mm.

Another CRA option targetting 23.59 degrees is available for both mono and color versions. The corresponding curves for this version is shown in figures 8 and 9.



Note that the photoresponse peaks near normal incidence for center pixels.

#### **Figure 3. Central Pixel Photoresponse to a Fixed Optical Power with Incidence Angle varied along -x and -y (Low CRA Version)**

<span id="page-7-0"></span>





The Center Axes of the Microlens and the Photodiode Coincide for the Center Pixels. For the Edge Pixels, there is a Shift between the Axes of the Microlens and the Photodiode causing a Peak Response Incidence Angle (CRA) that deviates from the Normal of the Pixel Array.









Note that the photoresponse peaks near normal incidence for center pixels.





**Figure 8. Variation of Peak Responsivity Angle (CRA) as a Function of Distance from the Center of the Array (High CRA Version)**



NOTES:

− Vref\_botplate power needs to allow source and sink; load is < 20 mA

− vdd\_pix is 3.3 V low noise power supply. Verify tolerance allowed in Table 5.

- Place low inductance bypass capacitors as close as possible to all power pins (10 μF and 100 nF)

− LVDS lines: Route the differential output traces close together to maximize common−mode rejection with the 100  $\Omega$  termination resistor close to the receiver. User should pay attention to printed circuit board (PCB) trace lengths to minimize any delay skew.

**Figure 9. Typical Application Diagram**



**Figure 10. Recommended Circuit for Vref\_botplate Signal Generation**

#### **OVERVIEW**

Figure 11 gives an overview of the major functional blocks of the sensor.





#### **Image Core**

The image core consists of:

- Pixel Array
- Address Decoders and Row Drivers
- Pixel Biasing

The PYTHON 480 pixel array contains 808 (H) x 608 (V) readout pixels with a pixel pitch of 4.8 µm, inclusive of 8 pixel rows and 8 pixel columns at every side to allow for reprocessing or color reconstruction. The sensors use in−pixel CDS architecture, which makes it possible to achieve a low noise read out of the pixel array in global shutter mode with CDS.

The function of the row drivers is to access the image array line by line, or all lines together, to reset or read the pixel data. The row drivers are controlled by the on−chip sequencer and can access the pixel array.

The pixel biasing block guarantees that the data on a pixel is transferred properly to the column multiplexer when the row drivers select a pixel line for readout.

#### **Phase Locked Loop**

The PLL accepts a (low speed) clock and generates the required high speed clock. Input clock frequency is 68 MHz.

#### **LVDS Clock Receiver**

The LVDS clock receiver receives an LVDS clock signal and distributes the required clocks to the sensor.

Input clock frequency is 340 MHz. The clock input needs to be terminated with a 100  $\Omega$  resistor.

#### **Column Multiplexer**

All pixels of one image row are stored in the column sample−and−hold (S/H) stages. These stages store both the reset and integrated signal levels.

The data stored in the column S/H stages is read out through 2 parallel differential outputs operating at a frequency of 34 MHz. At this stage, the reset signal and integrated signal values are transferred into an FPN−corrected differential signal. A programmable gain of 1x, 2x, or 3.5x can be applied to the signal. The column multiplexer also supports read−1−skip−1 and read−2−skip−2 mode. Enabling this mode increases the frame rate, with a decrease in resolution but same field of view.

#### **Bias Generator**

The bias generator generates all required reference voltages and bias currents used on chip. An external resistor of 47 k $\Omega$ , connected between pin IBIAS MASTER and gnd\_33, is required for the bias generator to operate properly.

### **Analog Front End**

The AFE contains 2 channels, each containing a PGA and a 10−bit ADC.

For each of the 2 channels, a pipelined 10−bit ADC is used to convert the analog image data into a digital signal, which is delivered to the data formatting block. A black calibration loop is implemented to ensure that the black level is mapped to match the correct ADC input level.

#### **Data Formatting**

The data block receives data from two ADCs and multiplexes this data to one data stream. A cyclic redundancy check (CRC) code is calculated on the passing data.

A frame synchronization data block transmits synchronization codes such as frame start, line start, frame end, and line end indications.

The data block calculates a CRC once per line for every channel. This CRC code can be used for error detection at the receiving end.

### **Serializer and LVDS Interface (LVDS Mode only)**

The serializer and LVDS interface block receives the formatted data from the data formatting block. This data is serialized and transmitted by the LVDS 340 MHz output driver.

The maximum output data rate is 680 Mbps per channel.

In addition to the LVDS data outputs, two extra LVDS outputs are available. One of these outputs carries the output clock, which is skew aligned to the output data channels. The second LVDS output contains frame format synchronization codes to serve system−level image reconstruction.

### **CMOS Interface**

Frame synchronization information is communicated by means of frame and line valid strobes. Both CMOS and LVDS outputs are active at the same time. LVDS channels can be powered down through SPI control when using the CMOS outputs.

#### **Sequencer**

The sequencer:

- Controls the image core. Starts and stops integration and control pixel readout.
- Operates the sensor in master or slave mode.
- Applies the window settings. Organizes readouts so that only the configured windows are read.
- Controls the column multiplexer and analog core. Applies gain settings and subsampling modes at the correct time, without corrupting image data.
- Starts up the sensor correctly when leaving standby mode.

### **Automatic Exposure Control**

The AEC block implements a control system to modulate the exposure of an image. Both integration time and gains are controlled by this block to target a predefined illumination level.

### **OPERATING MODES**

#### **Global Shutter Mode**

The PYTHON 480 operates in pipelined or triggered global shuttering modes. In this mode, light integration takes place on all pixels in parallel, although subsequent readout is sequential. Figure 12 shows the integration and readout sequence for the global shutter. All pixels are light sensitive at the same period of time. The whole pixel core is reset

simultaneously and after the integration time all pixel values are sampled together on the storage node inside each pixel. The pixel core is read out line by line after integration. Note that the integration and readout can occur in parallel or sequentially. The integration starts at a certain period, relative to the frame start.





#### *Pipelined Global Shutter Mode*

In pipelined global shutter mode, the integration and readout are done in parallel. Images are continuously read and integration of frame N is ongoing during readout of the previous frame N−1. The readout of every frame starts with a Frame Overhead Time (FOT), during which the analog value on the pixel diode is transferred to the pixel memory element. After the FOT, the sensor is read out line per line and the readout of each line is preceded by the Row

Overhead Time (ROT). Figure 13 shows the exposure and readout time line in pipelined global shutter mode.

#### *Master Mode*

In this mode, the integration time is set through the register interface and the sensor integrates and reads out the images autonomously. The sensor acquires images without any user interaction.



**Figure 13. Integration and Readout for Pipelined Shutter**

#### *Slave Mode*

The slave mode adds more manual control to the sensor. The integration time registers are ignored in this mode and the integration time is instead controlled by an external pin. As soon as the control pin is asserted, the pixel array goes out

of reset and integration starts. The integration continues until the user or system deasserts the external pin. Upon a falling edge of the trigger input, the image is sampled and the readout begins. Figure [14](#page-14-0) shows the relation between the external trigger signal and the exposure/readout timing.

<span id="page-14-0"></span>

**Figure 14. Pipelined Shutter Operated in Slave Mode**

#### *Triggered Global Shutter Mode*

In this mode, manual intervention is required to control both the integration time and the start of readout. After the integration time, indicated by a user controlled pin, the image core is read out. After this sequence, the sensor goes to an idle mode until a new user action is detected.

The three main differences with the pipelined global shutter mode are:

- Upon user action, one single image is read.
- Normally, integration and readout are done sequentially. However, the user can control the sensor in such a way that two consecutive batches are overlapping, that is, having concurrent integration and readout.
- Integration and readout is under user control through an external pin.

This mode requires manual intervention for every frame. The pixel array is kept in reset state until requested.

The triggered global mode can also be controlled in a master or in a slave mode.

#### *Master Mode*

In this mode, a rising edge on the synchronization pin is used to trigger the start of integration and readout. The integration time is defined by a register setting. The sensor autonomously integrates during this predefined time, after which the FOT starts and the image array is readout sequentially. A falling edge on the synchronization pin does not have any impact on the readout or integration and subsequent frames are started again for each rising edge. Figure 15 shows the relation between the external trigger signal and the exposure/readout timing.

If a rising edge is applied on the external trigger before the exposure time and FOT of the previous frame is complete, it is ignored by the sensor.



**Figure 15. Triggered Shutter Operated in Master Mode**

#### *Slave Mode*

Integration time control is identical to the pipelined shutter slave mode. An external synchronization pin controls the start of integration. When it is de−asserted, the

FOT starts. The analog value on the pixel diode is transferred to the pixel memory element and the image readout can start. A request for a new frame is started when the synchronization pin is asserted again.

### **SENSOR OPERATION**

#### <span id="page-15-0"></span>**Flowchart**

Figure 16 shows the sensor operation flowchart. The sensor has six different 'states'. Every state is indicated with the oval circle. These states are Power off, Low power standby, Standby (1), Standby (2), Idle, Running.



**Figure 16. Sensor Operation Flowchart**

#### <span id="page-16-0"></span>**Sensor States**

#### *Low Power Standby*

In low power standby state, all power supplies are on, but internally every block is disabled. No internal clock is running (PLL / LVDS clock receiver is disabled).

Only a subset of the SPI registers is active for read/write in order to be able to configure clock settings and leave the low power standby state. The only SPI registers that should be touched are the ones required for the 'Enable Clock Management' action described in Enable Clock Management − Part 1 on page NO TAG

### *Standby (1)*

In standby state, the PLL/LVDS clock receiver is running, but the derived logic clock signal is not enabled.

#### *Standby (2)*

In standby state, the derived logic clock signal is running. All SPI registers are active, meaning that all SPI registers can be accessed for read or write operations. All other blocks are disabled.

### *Idle*

In the idle state, all internal blocks are enabled, except the sequencer block. The sensor is ready to start grabbing images as soon as the sequencer block is enabled.

#### *Running*

In running state, the sensor is enabled and grabbing images. The sensor can be operated in global master/slave modes.

#### **User Actions: Power Up Functional Mode Sequences**

#### *Power Up Sequence*

Figure 17 shows the power up sequence of the sensor. The figure indicates that the first supply to ramp−up is the vdd\_18 supply, followed by vdd\_33 and vdd\_pix respectively. It is important to comply with the described sequence. Any other supply ramping sequence may lead to high current peaks and, as consequence, a failure of the sensor power up.

The clock input should start running when all supplies are stabilized. When the clock frequency is stable, the reset\_n signal can be de-asserted. After a wait period of 10 µs, the power up sequence is finished and the first SPI upload can be initiated.

NOTE: The 'clock input' can be LVDS clock input (lvds clock  $\text{inn/p}$ ) in case the PLL is bypassed.



**Figure 17. Power Up Sequence**

#### *Enable Clock Management*

The 'Enable Clock Management' action configures the clock management blocks and activates the clock generation and distribution circuits in a pre−defined way. First, a set of clock settings must be uploaded through the SPI register. These settings are dependent on the desired operation mode of the sensor.

The SPI uploads that need to be executed to configure the sensor for LVDS 10−bit serial mode, with the PLL, as well as all other supported modes are available to customers under NDA at the ON Semiconductor Image Sensor Portal: [https://www.onsemi.com/PowerSolutions/myon/erCispFol](https://www.onsemi.com/PowerSolutions/myon/erCispFolder.do) [der.do](https://www.onsemi.com/PowerSolutions/myon/erCispFolder.do)

In the serial modes, if the PLL is not used, the LVDS clock input must be running.

#### *Use of Phase Locked Loop*

If PLL is used, the PLL is started after the upload of the SPI registers. The PLL requires (dependent on the settings) some time to generate a stable output clock. A lock detect circuit detects if the clock is stable. When complete, this is flagged in a status register.

Check the PLL\_lock flag 24[0] by reading the SPI register. When the flag is set, the 'Enable Clock Management' action can be continued. When PLL is not used, this step can be bypassed as shown in Figure [16](#page-15-0) on page [16](#page-15-0).

### *Required Register Upload*

In this phase, the 'reserved' register settings are uploaded through the SPI register. Different settings are not allowed and may cause the sensor to malfunction. The required uploads can be downloaded from the MyON website.

#### *Soft Power Up*

During the soft power up action, the internal blocks are enabled and prepared to start processing the image data stream. This action exists of a set of SPI uploads.

### *Enable Sequencer*

During the 'Enable Sequencer' action, the frame grabbing sequencer is enabled. The sensor starts grabbing images in the configured operation mode. Refer to Sensor States on page [17](#page-16-0).

The 'Enable Sequencer' action consists of enabling bit 192[0].

#### **User Actions: Functional Modes to Power Down Sequences**

### *Disable Sequencer*

During the 'Disable Sequencer' action, the frame grabbing sequencer is stopped. The sensor stops grabbing images and returns to the idle mode.

The 'Disable Sequencer' action consists of disabling bit 192[0].

### *Soft Power Down*

During the soft power down action, the internal blocks are disabled and the sensor is put in standby state to reduce the current dissipation. This action exists of a set of SPI uploads.

#### *Disable Clock Management*

The 'Disable Clock Management' action stops the internal clocking to further decrease the power dissipation.

#### *Power Down Sequence*

Figure 18 illustrates the timing diagram of the preferred power down sequence. It is important that the sensor is in reset before the clock input stops running. Otherwise, the internal PLL becomes unstable and the sensor gets into an unknown state. This can cause high peak currents.

The same applies for the ramp down of the power supplies. The preferred order to ramp down the supplies is first vdd pix, second vdd 33, and finally vdd 18. Any other sequence can cause high peak currents.

NOTE: The 'clock input' can be the LVDS clock input (lvds clock  $inn/p$ ) in case the PLL is bypassed.



**Figure 18. Power Down Sequence**

#### **Sensor Reconfiguration**

During the standby, idle, or running state several sensor parameters can be reconfigured.

- Frame Rate and Exposure Time: Frame rate and exposure time changes can occur during standby, idle, and running states by modifying registers 199 to 203. Refer to page 30−32 for more information.
- Signal Path Gain: Signal path gain changes can occur during standby, idle, and running states by modifying registers 204/205. Refer to page 37 for more information.
- Windowing: Changes with respect to windowing can occur during standby, idle, and running states. Refer to Multiple Window Readout on page [26](#page-25-0) for more information.
- Subsampling: Changes of the subsampling mode can occur during standby, idle, and running states by modifying register 192. Refer to Subsampling on page [27](#page-26-0) for more information.
- Shutter Mode: The shutter mode can only be changed during standby or idle mode by modifying register 192. Reconfiguring the shutter mode during running state is not supported.

### **Sensor Configuration**

This device contains multiple configuration registers. Some of these registers can only be configured while the sensor is not acquiring images (while register  $192[0] = 0$ ), while others can be configured while the sensor is acquiring images. For the latter category of registers, it is possible to distinguish the register set that can cause corrupted images (limited number of images containing visible artifacts) from the set of registers that are not causing corrupted images.

These three categories are described here.

#### *Static Readout Parameters*

Some registers are only modified when the sensor is not acquiring images. Reconfiguration of these registers while images are acquired can cause corrupted frames or even interrupt the image acquisition. Therefore, it is recommended to modify these static configurations while the sequencer is disabled (register  $192[0] = 0$ ). The registers shown in Table 6 should not be reconfigured during image acquisition. A specific configuration sequence applies for these registers. Refer to the operation flow and startup description.



### **Table 6. STATIC READOUT PARAMETERS**

#### *Dynamic Configuration Potentially Causing Image Artifacts*

The category of registers as shown in Table 7 consists of configurations that do not interrupt the image acquisition process, but may lead to one or more corrupted images during and after the reconfiguration. A corrupted image is an

image containing visible artifacts. A typical example of a corrupted image is an image which is not uniformly exposed.

The effect is transient in nature and the new configuration is applied after the transient effect.

#### **Table 7. DYNAMIC CONFIGURATION POTENTIALLY CAUSING IMAGE ARTIFACTS**



#### *Dynamic Readout Parameters*

It is possible to reconfigure the sensor while it is acquiring images. Frame related parameters are internally resynchronized to frame boundaries, such that the modified parameter does not affect a frame that has already started. However, there can be restrictions to some registers as shown in Table 8. Some reconfiguration may lead to one frame being blanked. This happens when the modification requires more than one frame to settle. The image is blanked out and training patterns are transmitted on the data and sync channels.



#### **Table 8. DYNAMIC READOUT PARAMETERS**

#### *Freezing Active Configurations*

Though the readout parameters are synchronized to frame boundaries, an update of multiple registers can still lead to a transient effect in the subsequent images, as some configurations require multiple register uploads. For example, to reconfigure the exposure time in master global mode, both the fr\_length and exposure registers need to be updated. Internally, the sensor synchronizes these configurations to frame boundaries, but it is still possible that the reconfiguration of multiple registers spans over two or even more frames. To avoid inconsistent combinations, the active configurations can be frozen while altering the SPI registers by disabling synchronization for the corresponding functionality before reconfiguration. When all registers are uploaded, re−enable the synchronization. The sensor's sequencer then updates its active set of

registers and uses them for the coming frames. Freezing of the active set of registers can be programmed in the sync\_configuration registers, which can be found at the SPI address 206.

Figure 19 shows a reconfiguration that does not use the sync configuration option. As depicted, new SPI configurations are synchronized to frame boundaries.

Figure [20](#page-20-0) shows the usage of the sync\_configuration settings. Before uploading a set of registers, the corresponding sync\_configuration is de−asserted. After the upload is completed, the sync\_configuration is asserted again and the sensor resynchronizes its set of registers to the coming frame boundaries. As seen in the figure, this ensures that the uploads performed at the end of frame N+2 and the start of frame N+3 become active in the same frame (frame N+4).



**Figure 19. Frame Synchronization of Configurations (no freezing)**

<span id="page-20-0"></span>

**Figure 20. reconfiguration Using Sync\_configuration**

NOTE: SPI updates are not taken into account while sync\_configuration is inactive. The active configuration is frozen for the sensor. Table 9 lists the several sync\_configuration possibilities along with the respective registers being frozen.





#### **Window Configuration**

Up to 4 windows can be defined in global shutter mode (pipelined or triggered). The windows are defined by registers 256 to 265. Each window can be activated or deactivated separately using register 195. It is possible to reconfigure the inactive windows while the sensor is acquiring images.

Switching between predefined windows is achieved by activation of the respective windows. This way a minimum number of registers need to be uploaded when it is necessary to switch between two or more sets of windows. As an example of this, scanning the scene at higher frame rates using multiple windows and switching to full frame capture when the object is tracked. Switching between the two modes only requires an upload of one register.

### *Black Calibration*

The sensor automatically calibrates the black level for each frame. Therefore, the device generates a configurable number of electrical black lines at the start of each frame. The desired black level in the resulting output interface can be configured and is not necessarily targeted to '0'. Configuring the target to a higher level yields some information on the left side of the black level distribution, while the other end of the distribution tail is clipped to '0' when setting the black level target to '0'.

The black level is calibrated for the 2 columns contained in one kernel. This implies 2 black level offsets are generated and applied to the corresponding columns. Configurable parameters for the black−level algorithm are listed in Table [10](#page-21-0).

### <span id="page-21-0"></span>**Table 10. CONFIGURABLE PARAMETERS FOR BLACK LEVEL ALGORITHM**



### **Black Level Filtering Monitoring**



NOTE: Device will meet the specifications after thermal equilibrium has been established when mounted in a test socket or printed circuit board with maintained transverse airflow greater than 500 lfpm.

### **Serial Peripheral Interface**

The sensor configuration registers are accessed through an SPI. The SPI consists of four wires:

- sck: Serial Clock
- ss\_n: Active Low Slave Select
- mosi: Master Out, Slave In, or Serial Data In
- miso: Master In, Slave Out, or Serial Data Out

The SPI is synchronous to the clock provided by the master (sck) and asynchronous to the sensor's system clock. When the master wants to write or read a sensor's register, it selects the chip by pulling down the Slave Select line (ss\_n). When selected, data is sent serially and synchronous to the SPI clock (sck).

Figure 21 shows the communication protocol for read and write accesses of the SPI registers. The PYTHON 480 image sensors use 9−bit addresses and 16−bit data words.

Data driven by the system is colored blue in Figure 21, while data driven by the sensor is colored yellow. The data in grey indicates high−Z periods on the miso interface. Red markers indicate sampling points for the sensor (mosi sampling); green markers indicate sampling points for the system (miso sampling during read operations).

The access sequence is:

- 3. Select the sensor for read or write by pulling down the ss\_n line.
- 4. One SPI clock cycle after selecting the sensor, the 9−bit data is transferred, most significant bit first.

The sck clock is passed through to the sensor as indicated in Figure 21. The sensor samples this data on a rising edge of the sck clock (mosi needs to be driven by the system on the falling edge of the sck clock).

- 5. The tenth bit sent by the master indicates the type of transfer: high for a write command, low for a read command.
- 6. Data transmission:
- For write commands, the master continues sending the 16−bit data, most significant bit first.
- For read commands, the sensor returns the requested address on the miso pin, most significant bit first. The miso pin must be sampled by the system on the falling edge of sck (assuming nominal system clock frequency and maximum 10 MHz SPI frequency).
- 7. When data transmission is complete, the system deselects the sensor one clock period after the last bit transmission by pulling ss\_n high.

Note that the maximum frequency for the SPI interface scales with the input clock frequency, bit depth and LVDS output multiplexing as described in Table [5.](#page-3-0)

Consecutive SPI commands can be issued by leaving at least two SPI clock periods between two register uploads. Deselect the chip between the SPI uploads by pulling the ss n pin high.



**Figure 21. SPI Read and Write Timing Diagram**

#### **Table 11. SPI TIMING REQUIREMENTS**



\*Value indicated is for nominal operation. The maximum SPI clock frequency depends on the sensor configuration (operation mode, input clock). tsck is defined as  $1/f_{\text{SPI}}$ . See text for more information on SPI clock frequency restrictions.

### **IMAGE SENSOR TIMING AND READOUT**

The following sections describe the configurations for single slope reset mechanism. Extra integration time registers are available.

#### **Pipelined Global Shutter (Master)**

The integration time is controlled by the registers fr length $[15:0]$  and exposure $[15:0]$ . The mult timer configuration defines the granularity of the registers reset length and exposure. It is read as number of system clock cycles (14.706 ns nominal at 68 MHz).

The exposure control for (Pipelined) Global Master mode is depicted in Figure 22.

The pixel values are transferred to the storage node during FOT, after which all photo diodes are reset. The reset state remains active for a certain time, defined by the reset\_length and mult timer registers, as shown in the figure. Note that meanwhile the image array is read out line by line. After this reset period, the global photodiode reset condition is abandoned. This indicates the start of the integration or

exposure time. The length of the exposure time is defined by the registers exposure and mult timer.

- NOTE: The start of the exposure time is synchronized to the start of a new line (during ROT) if the exposure period starts during a frame readout. As a consequence, the effective time during which the image core is in a reset state is extended to the start of a new line.
- Make sure that the sum of the reset time and exposure time exceeds the time required to readout all lines. If this is not the case, the exposure time is extended until all (active) lines are read out.
- Alternatively, it is possible to specify the frame time and exposure time. The sensor automatically calculates the required reset time. This mode is enabled by the fr mode register. The frame time is specified in the register fr\_length.



**Figure 22. Integration Control for (Pipelined) Global Shutter Mode (Master)**

#### *Triggered Global Shutter (Master)*

In master triggered global mode, the start of integration time is controlled by a rising edge on the trigger0 pin. The exposure or integration time is defined by the registers

exposure and mult timer, as in the master pipelined global mode. The fr\_length configuration is not used. This operation is graphically shown in Figure 23.



**Figure 23. Exposure Time Control in Triggered Shutter Mode (Master)**

Notes:

- The falling edge on the trigger pin does not have any impact. Note however the trigger must be asserted for at least 100 ns.
- The start of the exposure time is synchronized to the start of a new line (during ROT) if the exposure period starts during a frame readout. As a consequence, the effective time during which the image core is in a reset state is extended to the start of a new line.
- If the exposure timer expires before the end of readout, the exposure time is extended until the end of the last active line.
- The trigger pin needs to be kept low during the FOT. The monitor pins can be used as a feedback to the FPGA/controller (eg. use monitor0, indicating the very first line when monitor select =  $0x5 - a$  new trigger can be initiated after a rising edge on monitor0).

#### *Triggered Global Shutter (Slave)*

Exposure or integration time is fully controlled by means of the trigger pin in slave mode. The registers fr\_length, exposure and mult timer are ignored by the sensor.

A rising edge on the trigger pin indicates the start of the exposure time, while a falling edge initiates the transfer to the pixel storage node and readout of the image array. In other words, the high time of the trigger pin indicates the integration time, the period of the trigger pin indicates the frame time.

The use of the trigger during slave mode is shown in Figure 24.

Notes:

- The registers exposure, fr\_length, and mult\_timer are not used in this mode.
- The start of exposure time is synchronized to the start of a new line (during ROT) if the exposure period starts during a frame readout. As a consequence, the effective time during which the image core is in a reset state is extended to the start of a new line.
- If the trigger is de−asserted before the end of readout, the exposure time is extended until the end of the last active line.
- The trigger pin needs to be kept low during the FOT. The monitor pins can be used as a feedback to the FPGA/controller (eg. use monitor0, indicating the very first line when monitor select =  $0x5 - a$  new trigger can be initiated after a rising edge on monitor0).



**Figure 24. Exposure Time Control in Global−Slave Mode**

#### **ADDITIONAL FEATURES**

#### <span id="page-25-0"></span>**Multiple Window Readout**

The PYTHON 480 image sensors support multiple window readout, which means that only the user−selected Regions Of Interest (ROI) are read out. This allows limiting data output for every frame, which in turn allows increasing the frame rate. Up to four ROIs can be configured.

#### *Window Configuration*

Figure 25 shows the four parameters defining a region of interest (ROI).



**Figure 25. Region of Interest Configuration**

• x−start[8:0]

x−start defines the x−starting point of the desired window. The sensor reads out 2 pixels in one single clock cycle. As a consequence, the granularity for configuring the x−start position is also 2 pixels for no sub sampling. The value configured in the x−start register is multiplied by 2 to find the corresponding column in the pixel array.

• x−end[8:0]

This register defines the window end point on the x−axis. Similar to x−start, the granularity for this configuration is one kernel. x−end needs to be larger than x−start.

• y−start[9:0]

The starting line of the readout window. The granularity of this setting is one line, except with color sensors where it needs to be an even number.

• y−end[9:0]

The end line of the readout window. y−end must be configured larger than y−start. This setting has the same granularity as the y−start configuration.

Up to four windows can be defined, possibly (partially) overlapping, as illustrated in Figure 26.

NOTE: The least significant configuration bits for x and y parameters are located in separate registers (refer to registers 264−265). One may decide not to reconfigure these bits, in which case the configuration granularity becomes 4 pixels for both x− and y−configurations.



The sequencer analyses each line that need to be read out for multiple windows.

#### *Restrictions*

The following restrictions for each line are assumed for the user configuration:

• Windows are ordered from left to right, based on their x−start address:

> $x$  start roi(i)  $\leq x$  start roi(j)  $AND$  $x$ \_end\_roi(i)  $\leq x$ \_end\_roi(j) Where  $i > i$

#### *Processing Multiple Windows*

The sequencer control block houses two sets of counters to construct the image frame. As previously described, the y−counter indicates the line that needs to be read out and is incremented at the end of each line. For the start of the frame, it is initialized to the y−start address of the first window and it runs until the y−end address of the last window to be read out. The last window is configured by the configuration registers and it is not necessarily window #3.

The x−counter starts counting from the x−start address of the window with the lowest ID which is active on the addressed line. Only windows for which the current y−address is enclosed are taken into account for scanning. Other windows are skipped.

<span id="page-26-0"></span>Figure 27 illustrates a practical example of a configuration with four windows. The current position of the read pointer (ys) is indicated by a red line crossing the image array. For this position of the read pointer, three windows need to be read out. The initial start position for the x−kernel pointer is the x−start configuration of ROI0. Kernels are scanned up to the ROI2 x−end position. From there, the x−pointer jumps to the next window, which is ROI3 in this illustration. When reaching ROI3's x−end position, the read pointer is incremented to the next line and xs is reinitialized to the starting position of ROI0.

Notes:

- The starting point for the readout pointer at the start of a frame is the y−start position of the first active window.
- The read pointer is not necessarily incremented by one, but depending on the configuration, it can jump in y−direction. In Figure 27, this is the case when reaching the end of ROI0 where the read pointer jumps to the y−start position of ROI1
- The x−pointer starting position is equal to the x−start configuration of the first active window on the current line addressed. This window is not necessarily window #0.
- The x−pointer is not necessarily incremented by one each cycle. At the end of a window it can jump to the start of the next window.
- Each window can be activated separately. There is no restriction on which window and how many of the 4 windows are active.



**Figure 27. Scanning the Image Array with Four Windows**

#### **Subsampling**

Subsampling is used to reduce the image resolution. This allows increasing the frame rate. Two subsampling modes are supported: for monochrome sensors (LVDS/CMOS) and color sensors (LVDS/CMOS).

#### *Monochrome Sensors*

For monochrome sensors, the read−1−skip−1 subsampling scheme is used. Subsampling occurs both in x− and y− direction.

#### *Color Sensors*

For color sensors, the read−2−skip−2 subsampling scheme is used. Subsampling occurs both in x– and y– direction. Figure 28 shows which pixels are read and which ones are skipped.



**Figure 28. Subsampling Scheme for Monochrome and Color Sensors**

#### **Reverse Readout**

Reverse readout in y−direction can be done by toggling reverse  $y$  (reg 194[8]). The reference for y\_start and y\_end pointers is reversed.

Reverse readout in x−direction can be done by toggling reverse\_x (reg 194[9]).

#### **Black Reference**

The sensor reads out one or more black lines at the start of every new frame. The number of black lines to be generated is programmable and is minimal equal to 1. The length of the black lines depends on the operation mode. The sensor always reads out the entire line (404 kernels), independent of window configurations.

The black references are used to perform black calibration and offset compensation in the data channels. The raw black pixel data is transmitted over the usual output interface, while the regular image data is compensated (can be bypassed).

On the output interface, black lines can be seen as a separate window, however without Frame Start and Ends (only Line Start/End). The Sync code following the Line Start and Line End indications ("window ID") contains the active window number, which is 0. Black reference data is classified by a BL code.

#### **Reference Lines**

The sensor optionally reads out one or more reference lines after the black lines. The number of reference lines to be generated is programmable. No reference lines shall be generated when set to 0. As for the black lines, the length of the reference lines depends on the operation mode.

The reference lines are not used internally in the sensor. The ROT for these lines can be configured such that these lines contain particular reference data, such as a grey level, in order to perform PRNU correction off−chip. Reference

lines are indicated on the output interface by means of a dedicated Sync pattern (REF).

The black calibration block can be configured to either perform black level correction and compression or not. In the latter case, the LSB is discarded from the ADC word.

Optionally, the black level calibration processor can be configured to transmit the average black level on the reference lines. In this mode, the reference pixel data are replaced by the average black level, as calculated by the black calibration block. Channel differences can easily be observed in this mode (See register reg db ref bcal enable).

### **Signal Path Gain**

#### *Analog Gain Stages*

Referring to Table 12, three gain settings are available in the analog data path to apply gain to the analog signal before it is digitized. The gain amplifier can apply a gain of approximately 1x to 3.5x to the analog signal.

The moment a gain reconfiguration is applied and becomes valid can be controlled by the gain\_lat\_comp configuration.

With 'gain\_lat\_comp' set to '0', the new gain configurations are applied from the very next frame.

With 'gain lat comp' set to '1', the new gain settings are postponed by one extra frame. This feature is useful when exposure time and gain are reconfigured together, as an exposure time update always has one frame latency.



#### **Table 12. SIGNAL PATH GAIN STAGES**

NOTE: The sensor performance specifications are tested at unity gain. Analog gain above 2x affects noise performance. All other gains settings shown in this table are tested for sensor functionality only.

#### *Digital Gain Stage*

The digital gain stage allows fine gain adjustments on the digitized samples. The gain configuration is an absolute 5.7 unsigned number (5 digits before and 7 digits after the decimal point).

#### **Automatic Exposure Control**

The exposure control mechanism has the shape of a general feedback control system. Figure 29 shows the high level block diagram of the exposure control loop.



**Figure 29. Automatic Exposure Control Loop**

Three main blocks can be distinguished:

- The **statistics block** compares the average of the current image's samples to the configured target value for the average illumination of all pixels
- The relative gain change request from the statistics block is filtered through the **AEC Filter block** in the time domain (low pass filter) before being integrated. The output of the filter is the total requested gain in the complete signal path.
- The **enforcer block** accepts the total requested gain and distributes this gain over the integration time and gain stages (both analog and digital)

The automatic exposure control loop is enabled by asserting the aec\_enable configuration in register 160.

#### *AEC Statistics Block*

The statistics block calculates the average illumination of the current image. Based on the difference between the calculated illumination and the target illumination the statistics block requests a relative gain change.

#### *Statistics Subsampling and Windowing*

For average calculation, the statistics block will sub−sample the current image or windows by taking every fourth sample into account. Note that only the pixels read out through the active windows are visible for the AEC. In the case where multiple windows are active, the samples will be selected from the total samples. Samples contained in a region covered by multiple (overlapping) window will be taking into account only once.

It is possible to define an AEC specific sub−window on which the AEC will calculate it's average. For instance, the sensor can be configured to read out a larger frame, while the illumination is measured on a smaller region of interest, e.g. center weighted as shown in Table 13.



#### **Table 13. AEC SAMPLE SELECTION**

### *Target Illumination*

The target illumination value is configured by means of register *desired\_intensity* as shown in Table 14.

#### **Table 14. AEC TARGET ILLUMINATION CONFIGURATION**



### *Color Sensor*

The weight of each color can be configured for color sensors by means of scale factors. Note these scale factor are only used to calculate the statistics in order to compensate for (off−chip) white balancing and/or color matrices. The pixel values itself are not modified.

The scale factors are configured as 3.7 unsigned numbers  $(0x80 =$  unity). Refer to Table 15 for color scale factors. For mono sensors, configure these factors to their default value.

**Table 15. COLOR SCALE FACTORS**

| Register | Name                    | <b>Description</b>                        |  |
|----------|-------------------------|-------------------------------------------|--|
| 162[9:0] | red scale factor        | Red scale factor for AFC<br>statistics    |  |
| 163[9:0] | green1 scale fa<br>ctor | Green1 scale factor for AEC<br>statistics |  |
| 164[9:0] | green2 scale fa<br>ctor | Green2 scale factor for AFC<br>statistics |  |
| 165[9:0] | blue scale factor       | Blue scale factor for AFC<br>statistics   |  |

### *AEC Filter Block*

The filter block low−pass filters the gain change requests received from the statistics block.

The filter can be restarted by asserting the restart filter configuration of register 160.

### *AEC Enforcer Block*

The enforcer block calculates the four different gain parameters, based on the required total gain, thereby respecting a specific hierarchy in those configurations. Some (digital) hysteresis is added so that the (analog) sensor settings don't need to change too often.

#### *Exposure Control Parameters*

The several gain parameters are described below, in the order in which these are controlled by the AEC for large adjustments. Small adjustments are regulated by digital gain only.

• Exposure Time

The exposure is the time between the global image array reset de−assertion and the pixel charge transfer. The granularity of the integration time steps is configured by the *mult\_timer* register.

• Analog Gain

The sensor has two analog gain stages, configurable independently from each other. Typically the AEC shall only regulate the first stage.

• Digital Gain

The last gain stage is a gain applied on the digitized samples. The digital gain is represented by a 5.7 unsigned number (i.e. 7 bits after the decimal point). While the analog gain steps are coarse, the digital gain stage makes it possible to achieve very fine adjustments.

NOTE: The *exposure time* register is ignored when the AEC is enabled. The register *fr\_length* defines the frame time and needs to be configured accordingly.

### *AEC Control Range*

The control range for each of the exposure parameters can be pre−programmed in the sensor. Table 16 lists the relevant registers.

#### **Table 16. MINIMUM AND MAXIMUM EXPOSURE CONTROL PARAMETERS**



#### *AEC Update Frequency*

As an integration time update has a latency of one frame, the exposure control parameters are evaluated and updated every other frame.

Note: The gain update latency must be postpone to match the integration time latency. This is done by asserting the *gain\_lat\_comp* register on address 204[13].

#### *Exposure Control Status Registers*

Configured integration and gain parameters are reported to the user by means of status registers. The sensor provides two levels of reporting: the status registers reported in the AEC address space are updated once the parameters are recalculated and requested to the internal sequencer. The status registers residing in the sequencer's address space on the other hand are updated once these parameters are taking effect on the image readout. Refer to Table 17 reflecting the AEC and Sequencer Status registers.



#### **Table 17. EXPOSURE CONTROL STATUS REGISTERS**

#### **Mode Changes and Frame Blanking**

Dynamically reconfiguring the sensor may lead to corrupted or non-uniformilly exposed frames. For some reconfigurations, the sensor automatically blanks out the image data during one frame. Frame blanking is

summarized in the following table for the sensor's image related modes.

NOTE: Major mode switching (i.e. switching between master, triggered or slave mode) must be performed while the sequencer is disabled  $reg\_seq\_enable = 0x0$ .

#### **Table 18. DYNAMIC SENSOR RECONFIGURATION AND FRAME BLANKING**



### **Monitor Pins**

The internal sequencer has two monitor outputs (Pin 44 and Pin 45) that can be used to communicate the internal states from the sequencer. A three−bit register configures the assignment of the pins as shown in Table 19.



#### **Table 19. MONITOR SELECT**

#### **Sequences of Frame Acquisition with Different Configurations**

Frame dependent configurations require multiple contexts, which are sync'ed upon a start of a new frame. The following configurations are context switchable:

- FOT program
- ROT programs (only for regular ROT in Global Shutter Mode (no muxing for black reference ROT programs))
- Integration Time
- Gain (both digital and analog)
- Active ROI Configuration (not the window

configuration themselves)

When enabled, the sequencer shall automatically select one set of parameters for the even frames and the other set of parameters for the odd frames.

This operation mode is enabled by means of the reg\_seq\_sequence register and can be used in global shutter modes.

The configurations used for even odd frames are summarized in Table 20.

When the sequenced readout is not enabled, the first set of configurations ('Even configurations') is applicable. The second set ('Odd configurations') is ignored by the sequencer.

**Table 20. ODD/EVEN CONFIGURATION**

| Configuration                      | <b>Even Frames</b>      | <b>Odd Frames</b>   |
|------------------------------------|-------------------------|---------------------|
| Integration<br>Time                | reg_seq_exposure0       | reg_seq_exposure1   |
| FR Length                          | reg_seq_fr_length0      | reg_seq_fr_length1  |
| <b>Mult Timer</b>                  | reg_seq_mult_timer0     | reg_seq_mult_timer1 |
| Gain Stage 1                       | reg_seq_mux_gains<br>w0 | reg_seq_mux_gainsw1 |
| Gain Stage 2                       | reg_seq_afe_gain0       | reg_seq_afe_gain1   |
| Digital Gain                       | reg_seq_db_gain0        | reg_seq_db_gain1    |
| <b>ROI Active</b><br>Configuration | reg_seq_roi_active0     | reg_seq_roi_active1 |

#### **DATA OUTPUT FORMAT**

The PYTHON 480 image sensor can be configured in LVDS output mode, which includes one LVDS output channel together with an LVDS clock output and an LVDS synchronization output channel. The PYTHON 480 is also configurable in a CMOS output configuration, which includes a 10−bit parallel CMOS output together with a CMOS clock output and 'frame valid' and 'line valid' CMOS output signals.

#### **LVDS Interface Mode**

#### *LVDS Output Channels*

The image data output occurs through one LVDS data channel where a synchronization LVDS channel and an LVDS output clock signal synchronizes the data.

The one data channel is used to output the image data only. The sync channel transmits information about the data sent over the data channel (includes codes indicating black pixels, normal pixels, and CRC codes).

#### *Frame Format*

The frame format is explained by example of the readout of two (overlapping) windows as shown in Figure [30\(](#page-35-0)a).

The readout of a frame occurs on a line−by−line basis. The read pointer goes from left to right, bottom to top.

Figure [30](#page-35-0) indicates that, after the FOT is completed, the sensor reads out a number of black lines for black calibration purposes. After these black lines, the windows are processed. First a number of lines which only includes

information of 'ROI 0' are sent out, starting at position y0\_start. When the line at position y1\_start is reached, a number of lines containing data of 'ROI 0' and 'ROI 1' are sent out, until the line position of y0 end is reached. From there on, only data of 'ROI 1' appears on the data output channels until line position  $y1$  end is reached

During read out of the image data over the data channels, the sync channel sends out frame synchronization codes which give information related to the image data that is sent over the four data output channels.

Each line of a window starts with a Line Start (LS) indication and ends with a Line End (LE) indication. The line start of the first line is replaced by a Frame Start (FS); the line end of the last line is replaced with a Frame End indication (FE). Each such frame synchronization code is followed by a window ID (range 0 to 7). For overlapping windows, the line synchronization codes of the overlapping windows with lower IDs are not sent out (as shown in the illustration: no LE/FE is transmitted for the overlapping part of window 0).

NOTE: In Figure [30](#page-35-0), only Frame Start and Frame End Sync words are indicated in (b). CRC codes are also omitted from the figure.

> For additional information on the synchronization codes, refer to Application Note AND5001.

<span id="page-35-0"></span>

#### Reset<br>N Exposure Time N  $FOT$  Reset FOT  $\begin{array}{|c|c|c|c|}\n\hline\n\end{array}$  N+1 Exposure Time N+1 FOT ROIO  $||||||||||$   $\frac{1}{4}$  FOT  $\sqrt{2}$  ROIO  $||||||||||$   $\frac{1}{4}$  FOT Integration Time Handling Readout Readout For **B** ROID | ROI 1 Readout Frame N-1 Readout Frame N ROIO | | | | | | | ROI 1  $\begin{array}{|c|c|c|c|c|}\hline \text{R010} & \text{N11} & \text{F01} & \text{F01} & \text{R010} & \text{N11} & \text{F11} \ \hline \end{array}$ É /B ROIO  $||||||||$   $\int_{0}^{1}$  FOT  $\int_{0}^{2}$  ROIO  $|||||||| \int_{0}^{1}$  FOT É B L

(b)

**Figure 30. LVDS Mode: Frame Sync Codes**

Figure 31 shows the detail of a black line readout during global or full−frame readout.



**Figure 31. LVDS Mode: Time Line for Black Line Readout**



Figure 32 shows shows the details of the readout of a number of lines for single window readout, at the beginning of the frame.

**Figure 32. LVDS Mode: Time Line for Single Window Readout (at the start of a frame)**



Figure 33 shows the detail of the readout of a number of lines for readout of two overlapping windows.

**Figure 33. LVDS Mode: Time Line Showing the Readout of Two Overlapping Windows**

#### *Frame Synchronization*

Table 21 shows the structure of the frame synchronization code. Note that the table shows the default data word (configurable). If more than one window is active at the

same time, the sync channel transmits the frame synchronization codes of the window with highest index only.





### <span id="page-37-0"></span>• Window Identification

Frame synchronization codes are always followed by a 3−bit window identification (bits 2:0). This is an integer number, ranging from 0 to 7, indicating the active window. If more than one window is active for the current cycle, the highest window ID is transmitted.

• Data Classification Codes

For the remaining cycles, the sync channel indicates the type of data sent through the data links: black pixel data (BL), image data (IMG), or training pattern (TR). These codes are programmable by a register setting. The default values are listed in Table 22.



### **Table 22. SYNCHRONIZATION CHANNEL DEFAULT IDENTIFICATION CODE VALUES**

### *Training Patterns on Data Channels*

During idle periods, the data channels transmit training patterns, indicated on the sync channel by a TR code. These

training patterns are configurable independent of the training code on the sync channel as shown in Table 23.

### **Table 23. TRAINING CODE ON SYNC CHANNEL IN**



### *Cyclic Redundancy Code*

At the end of each line, a CRC code is calculated to allow error detection at the receiving end. Each data channel transmits a CRC code to protect the data words sent during the previous cycles. Idle and training patterns are not included in the calculation.

The sync channel is not protected. A special character (CRC indication) is transmitted whenever the data channels send their respective CRC code.

The polynomial is  $x^{10} + x^9 + x^6 + x^3 + x^2 + x + 1$ . The CRC encoder is seeded at the start of a new line and updated for every (valid) data word received. The CRC seed is configurable using the crc\_seed register. When '0', the CRC is seeded by all−'0'; when '1' it is seeded with all−'1'.

NOTE: The CRC is calculated for every line. This implies that the CRC code can protect lines from multiple windows.

### *Data Order: LVDS Interface Version*

To read out the image data through the output channel, the pixel array is organized in kernels. The kernel size is two pixels in x−direction by one pixel in y−direction. Figure 34

indicates how the kernels are organized. The first kernel (kernel [0, 0]) is located in the bottom left corner. The pixel data is transmitted in order. The figures in the following paragraphs represent the data order for a non−mirrored readout (i.e. left−to−right readout).





#### • Subsampling disabled

Figure 35 shows how a kernel is read out. The pixels are transferred in order, or in ascending order for normal readout and descending order for mirrored readout.



**Figure 35. P1−SN/SE/FN: Data Output Order when Subsampling is Disabled**

• Subsampling on Monochrome Sensor

During subsampling on a monochrome sensor, every other pixel is read out and the lines are read in a read-1-skip-1 manner. To read out the image data with subsampling enabled on a monochrome sensor, two

neighboring kernels are combined to a single kernel of 4 pixels in the x−direction and one pixel in the y−direction. Only the pixels at the even pixel positions inside that kernel are read out.



**Figure 36. Data Output Order in Subsampling Mode on a Monochrome Sensor**

#### • Subsampling on Color Sensor

During subsampling on a color sensor, lines are read in a read-2-skip−2 manner. To read out the image data with subsampling enabled on a color sensor, two neighboring kernels are combined to a single kernel of 4 pixels in the x−direction and one pixel in the y−direction. Only the pixels 0 and 1 are read out.



### **Figure 37. Data Output Order for the LVDS Output Channel in Subsampling Mode on a Color Sensor**

#### **CMOS Interface Mode**

#### *CMOS Output Signals*

The image data output occurs through a single 10−bit parallel CMOS data output. A CMOS clock output, 'frame valid' and 'line valid' signal synchronizes the output data.

No windowing information is sent out by the sensor.

#### *Frame Format*

Frame timing is indicated by means of two signals: frame\_valid and line\_valid.

• The frame\_valid indication is asserted at the start of a new frame and remains asserted until the last line of the frame is completely transmitted.

- The line\_valid indication serves the following needs:
	- ♦ While the line\_valid indication is asserted, the data channels contain valid pixel data.
	- $\triangle$  The line valid communicates frame timing as it is asserted at the start of each line and it is de−asserted at the end of the line. Low periods indicate the idle time between lines (ROT).
	- ♦ The data channels transmit the calculated CRC code after each line. This can be detected as the data words right after the falling edge of the line valid.



**Figure 38. CMOS Mode: Frame Timing Indication**

The frame format is explained with an example of the readout of two (overlapping) windows as shown in Figure 39 (a).

The readout of a frame occurs on a line−by−line basis. The read pointer goes from left to right, bottom to top. Figure 39 (a) and (b) indicate that, after the FOT is finished, a number of lines which include information of 'ROI 0' are sent out,

starting at position y0\_start. When the line at position y1\_start is reached, a number of lines containing data of 'ROI 0' and 'ROI 1' are sent out, until the line position of y0\_end is reached. Then, only data of 'ROI 1' appears on the data output until line position y1 end is reached. The line\_valid strobe is not shown in Figure 39.



**Figure 39. CMOS Mode: Frame Format to Read Out Image Data**

#### *Black Lines*

Black pixel data is also sent through the data channels. To distinguish these pixels from the regular image data, it is possible to 'mute' the frame and/or line valid indications for the black lines. Refer to Table 24 for black line, frame\_valid and line valid settings.

#### **Table 24. BLACK LINE FRAME\_VALID AND LINE\_VALID SETTINGS**



#### <span id="page-41-0"></span>*Data order: CMOS Interface Mode*

To read out the image data through the parallel CMOS output, the pixel array is divided in kernels. The kernel size is two pixels in x−direction by one pixel in y−direction. Figure [34](#page-37-0) on page [38](#page-37-0) indicates how the kernels are organized.

The pixel data is transmitted in order. The figures in the following paragraphs represent the data order for a non−mirrored readout (i.e. left−to−right readout).

• No Subsampling

Figure 40 shows the pixel sequence of a kernel which is read out over the single CMOS output channel. The pixels are transmitted in order or ascending for a normal readout and descending for a mirrored readout.



**Figure 40. CMOS Mode: Data Output Order without Subsampling**

• Subsampling On Monochrome Sensor

To read out the image data with subsampling enabled on a monochrome sensor, two neighboring kernels are combined to a single kernel of 4 pixels in the x−direction and one pixel in the y−direction. Only the pixels at the even pixel positions inside that kernel are read out. Figure 41 shows the data order.



**Figure 41. CMOS Mode: Data Output Order with Subsampling on a Monochrome Sensor**

• Subsampling On Color Sensor

To read out the image data with subsampling enabled on a color sensor, two neighboring kernels are combined to a

single kernel of 4 pixels in the x−direction and one pixel in the y−direction. Figure 42 shows the data order.



**Figure 42. CMOS Mode: Data Output Order with Subsampling on a Color Sensor**

# **REGISTER MAP**

#### <span id="page-42-0"></span>**Table 25. REGISTER MAP**













9 121 sync\_code4 0x002A 42 LVDS Power Down Configuration RW

10 | 122 | | sync\_code5 | 0x0015 | 21 | Data Formating - BL Indication | RW

11 123 sync\_code6 0x0035 53 Data Formating - IMG Indication RW

12 124 sync\_code7 0x0025 37 Data Formating - IMG Indication RW

[6:0] frame\_sync\_1 0x02A 42 Frame Sync Code LSBs - Odd kernels

[9:0] bl\_1 0x015 21 Black Pixel Identification Sync Code - Odd kernels

[9:0] img\_1 0x035 53 Valid Pixel Identification Sync Code -

[9:0] ref\_1 0x025 37 Reference Pixel Identification Sync Code -

Odd kernels

Odd kernels

























# **PACKAGE INFORMATION**

#### <span id="page-57-0"></span>**Pin List**

The LVDS I/Os comply to the TIA/EIA−644−A Standard and the CMOS I/Os have a 1.8 V signal level.

#### **Table 26. PIN LIST**



### **Table [26](#page-57-0). PIN LIST** (continued)



#### **Mechanical Specifications**



NOTE: Device will meet the specifications after thermal equilibrium has been established when mounted in a test socket or printed circuit board with maintained transverse airflow greater than 500 lfpm.





#### **Package Drawing**



**BOTTOM VIEW** 

**Figure 44. Package Drawing for the ODCSP67 Package**

MOUNTING FOOTPRINT

#### **Packing and Tray Specification**

The PYTHON480 packing specification with ON Semiconductor packing labels is packed as follows:



**Figure 45. Tray Drawing**



**Figure 46. Pin 1 Location**

### **Glass Lid**

The PYTHON 480 image sensors use a glass lid without any coatings. Figure 44 shows the transmission characteristics of the glass lid.

As shown in Figure [42](#page-41-0), no infrared attenuating color filter glass is used. Use of an IR cut filter is recommended in the

> Transmission T [%] 90 70 50 30 10 300 400 500 600 700 800 900 Principle curve\* D=0,15mm Wavelength λ [nm]

**Figure 47. Transmission Characteristics of the Glass Lid**

#### **Protective Foil**

The sensor is delivered with protective foil that is intended to be removed after assembly. The dimensions of the foil are

as illustrated in Figure 48 with tab aligned left center with Pin A1 to the bottom left.



**Figure 48. Dimensions of the Protective Foil**

optical path when color devices are used. (source: http://www.pgo−online.com).

#### **SPECIFICATIONS AND USEFUL REFERENCES**

The following references are available to customers under NDA at the ON Semiconductor Image Sensor Portal: [https://www.onsemi.com/PowerSolutions/myon/erCispFol](https://www.onsemi.com/PowerSolutions/myon/erCispFolder.do) [der.do](https://www.onsemi.com/PowerSolutions/myon/erCispFolder.do)

- Product Acceptance Criteria
- Product Qualification Report
- PYTHON Developer's Guide AND9362/D

#### **Useful References**

For information on ESD and cover glass care and cleanliness, please download the *Image Sensor Handling and Best Practices* Application Note (AN52561/D) from [www.onsemi.com.](http://onsemi.com)

For quality and reliability information, please download the *Quality & Reliability* Handbook (HBD851/D) from [www.onsemi.com.](http://onsemi.com)

For information on Standard terms and Conditions of Sale, please download [Terms and Conditions](http://www.onsemi.com/site/pdf/ONSEMI_T&C.pdf) from [www.onsemi.com.](http://onsemi.com)

For information on acronyms and a glossary of terms used, please download *Image Sensor Terminology* (TND6116/D) from [www.onsemi.com](http://onsemi.com).

#### **Return Material Authorization (RMA)**

Refer to the ON Semiconductor RMA policy procedure at [http://www.onsemi.com/site/pdf/CAT\\_Returns\\_FailureAn](http://www.onsemi.com/site/pdf/CAT_Returns_FailureAnalysis.pdf) [alysis.pdf](http://www.onsemi.com/site/pdf/CAT_Returns_FailureAnalysis.pdf)

ON Semiconductor and (H) are trademarks of Semiconductor Components Industries, LLC dba ON Semiconductor or its subsidiaries in the United States and/or other countries ON Semiconductor owns tne rights to a number of patents, trademarks, copyrights, trade secrets, and other intellectual property. A listing of ON Semiconductor's product/patent<br>coverage may be accessed at <u>www.onsemi.com/si</u> ON Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does ON Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation special, consequential or incidental damages.<br>Buyer is responsible for its pro regardless of any support or applications information provided by ON Semiconductor. "Typical" parameters which may be provided in ON Semiconductor data sheets and/or<br>specifications can and do vary in different applications application by customer's technical experts. ON Semiconductor does not convey any license under its patent rights nor the rights of others. ON Semiconductor products are not designed, intended, or authorized for use as a critical component in life support systems or any FDA Class 3 medical devices or medical devices with a same or similar classification<br>in a foreign jurisdiction or any devices application, Buyer shall indemnify and hold ON Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such<br>claim alleges that ON Semiconductor was literature is subject to all applicable copyright laws and is not for resale in any manner.

#### **PUBLICATION ORDERING INFORMATION**

#### **LITERATURE FULFILLMENT**:

Literature Distribution Center for ON Semiconductor 19521 E. 32nd Pkwy, Aurora, Colorado 80011 USA **Phone**: 303−675−2175 or 800−344−3860 Toll Free USA/Canada **Fax**: 303−675−2176 or 800−344−3867 Toll Free USA/Canada **Email**: orderlit@onsemi.com

**N. American Technical Support**: 800−282−9855 Toll Free USA/Canada

**Order Literature**: http://www.onsemi.com/orderlit

**Europe, Middle East and Africa Technical Support:** Phone: 421 33 790 2910

For additional information, please contact your local Sales Representative

**ON Semiconductor Website**: **www.onsemi.com**



#### **ООО "ЛайфЭлектроникс" "LifeElectronics" LLC**

*ИНН 7805602321 КПП 780501001 Р/С 40702810122510004610 ФАКБ "АБСОЛЮТ БАНК" (ЗАО) в г.Санкт-Петербурге К/С 30101810900000000703 БИК 044030703* 

 *Компания «Life Electronics» занимается поставками электронных компонентов импортного и отечественного производства от производителей и со складов крупных дистрибьюторов Европы, Америки и Азии.*

*С конца 2013 года компания активно расширяет линейку поставок компонентов по направлению коаксиальный кабель, кварцевые генераторы и конденсаторы (керамические, пленочные, электролитические), за счёт заключения дистрибьюторских договоров*

 *Мы предлагаем:*

- *Конкурентоспособные цены и скидки постоянным клиентам.*
- *Специальные условия для постоянных клиентов.*
- *Подбор аналогов.*
- *Поставку компонентов в любых объемах, удовлетворяющих вашим потребностям.*
- *Приемлемые сроки поставки, возможна ускоренная поставка.*
- *Доставку товара в любую точку России и стран СНГ.*
- *Комплексную поставку.*
- *Работу по проектам и поставку образцов.*
- *Формирование склада под заказчика.*
- *Сертификаты соответствия на поставляемую продукцию (по желанию клиента).*
- *Тестирование поставляемой продукции.*
- *Поставку компонентов, требующих военную и космическую приемку.*
- *Входной контроль качества.*
- *Наличие сертификата ISO.*

 *В составе нашей компании организован Конструкторский отдел, призванный помогать разработчикам, и инженерам.*

*Конструкторский отдел помогает осуществить:*

- *Регистрацию проекта у производителя компонентов.*
- *Техническую поддержку проекта.*
- *Защиту от снятия компонента с производства.*
- *Оценку стоимости проекта по компонентам.*
- *Изготовление тестовой платы монтаж и пусконаладочные работы.*



 *Tел: +7 (812) 336 43 04 (многоканальный) Email: [org@lifeelectronics.ru](mailto:org@lifeelectronics.ru)*

#### *www[.lifeelectronics.ru](http://lifeelectronics.ru/)*