

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

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

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



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832

Email & Skype: info@chipsmall.com Web: www.chipsmall.com

Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China











# AP0101CS High-Dynamic Range (HDR) Image Signal Processor (ISP)

AP0101CS Datasheet, Rev. 7

For the latest product datasheet, please visit www.onsemi.com

#### **Features**

- Supports ON Semiconductor sensors with up to 1.2 Mp (1280x960)
- 45 fps at 1.2 Mp, 60 fps at 720p
- Optimized for operation with HDR sensors
- Color and gamma correction
- Auto exposure, auto white balance, 50/60 Hz flicker avoidance
- Adaptive Local Tone Mapping (ALTM)
- Test Pattern Generator
- Two-wire serial programming interface
- Interface to low-cost Flash or EPROM through SPI bus (to configure and load patches)
- High-level host command interface
- Standalone operation supported
- Up to 5 GPIO
- Fail-safe IO
- Multi-Camera synchronization support
- Dual Band IR filter support

# **Applications**

- SMPTE296 HDCCTV cameras
- Surveillance network IP cameras

#### Table 1: Key Performance Parameters

| Paramete                 | r                                 | Value                              |  |  |  |
|--------------------------|-----------------------------------|------------------------------------|--|--|--|
| Primary camera interface |                                   | Parallel                           |  |  |  |
| _                        | amera input                       | RAW12 Linear/Companded Bayer       |  |  |  |
| format                   |                                   | data                               |  |  |  |
| Output in                | terface                           | Up to 20-bit Parallel <sup>1</sup> |  |  |  |
|                          |                                   | YUV422 8-bit,10-bit, and           |  |  |  |
| Output fo                | rmat                              | SMPTE296M                          |  |  |  |
|                          |                                   | 10-, 12-bit tone-mapped Bayer      |  |  |  |
| Maximum                  | resolution                        | 1280x960 (1.2 Mp)                  |  |  |  |
| Input cloc               | _                                 | 6-30 MHz                           |  |  |  |
| Maximum                  | n frame rate <sup>3</sup>         | 45 fps at 1.2 Mp, 60 fps at 720p   |  |  |  |
| Maximum frequency        | output clock                      | Parallel clock up to 84 MHz        |  |  |  |
|                          | VDDIO_S                           | 1.8 or 2.8 V nominal               |  |  |  |
| Supply                   | VDDIO_H                           | 2.5 or 3.3 V nominal               |  |  |  |
| voltage                  | VDD_REG                           | 1.8V nominal                       |  |  |  |
|                          | VDDIO_OTPM                        | 2.5 or 3.3 V nominal               |  |  |  |
| Operating (ambient       | temperature<br>- T <sub>A</sub> ) | −30°C to +70°C                     |  |  |  |
| Typical po<br>consumpt   |                                   | 130 mW                             |  |  |  |

Notes: 1. 20-bit in one pixel clock format is only available in SMPTE mode with the use of 4 GPIOs.

- With input clock below 10 MHz, the two wire serial interface is supported only up to 100 KHz
- 3. Maximum frame rate depends on output interface and data format configuration used.
- 4. 720p HDR 60 fps 74.25 MHz YCbCr\_422\_16



# **Ordering Information**

Table 2: Available Part Numbers

| Part Number             | Product Description              | Orderable Product Attribute Description |
|-------------------------|----------------------------------|-----------------------------------------|
| AP0101CS2L00SPGA0-DR1   | 1Mp Co-Processor, 100-ball VFBGA | Drypack                                 |
| AP0101CS2L00SPGAD3-GEVK | AP0101CS Demo Kit                |                                         |
| AP0101CS2L00SPGAH-GEVB  | AP0101CS Head Board              |                                         |

See the ON Semiconductor Device Nomenclature document (TND310/D) for a full description of the naming convention used for image sensors. For reference documentation, including information on evaluation kits, please visit our web site at www.onsemi.com.

AP0101CS/D Rev. 7, 1/16 EN 2 @Semiconductor Components Industries, LLC, 2016.

#### ON Semiconductor®



## **Table of Contents**

| Features                             | 1  |
|--------------------------------------|----|
| Applications                         |    |
| Ordering Information                 |    |
| General Description                  | 4  |
| Functional Overview                  |    |
| System Interfaces                    |    |
| Multi-Camera Synchronization Support | 14 |
| Image Flow Processor                 | 15 |
| Camera Control and Auto Functions    | 21 |
| AE Track Driver                      | 21 |
| Auto White Balance                   |    |
| Dual Band IRCF                       |    |
| Exposure and White Balance Modes     |    |
| Flicker Avoidance                    |    |
| Output Formatting                    |    |
| Sensor Embedded Data                 |    |
| Slave Two-Wire Serial Interface      |    |
| Protocol                             |    |
| Usage Modes                          |    |
| Host Command Interface               | 34 |
| Electrical Specifications            |    |
| Two-Wire Serial Register Interface   | 39 |
| Package and Die Ontions              | 41 |



## **General Description**

The ON Semiconductor AP0101CS is a high-performance, ultra-low power in-line, digital image processor optimized for use with High Dynamic Range (HDR) sensors. The AP0101CS provides full auto-functions support (AWB and AE) and Adaptive Local Tone Mapping (ALTM) to enhance HDR images and advanced noise reduction which enables excellent low-light performance.

## **Functional Overview**

Figure 1 shows the typical configuration of the AP0101CS in a camera system. On the host side, a two-wire serial interface is used to control the operation of the AP0101CS, and image data is transferred using the parallel bus between the AP0101CS and the host. The AP0101CS interface to the sensor also uses a parallel interface.

Figure 1: AP0101CS Connectivity



# **System Interfaces**

Figure 2 on page 5 shows typical AP0101CS device connections.

All power supply rails must be decoupled from ground using capacitors as close as possible to the package.

The AP0101CS signals to the sensor and host interfaces can be at different supply voltage levels to optimize power consumption and maximize flexibility. Table 4 on page 7 provides the signal descriptions for the AP0101CS.



Figure 2: Typical Configuration



Notes:

- 1. This typical configuration shows only one scenario out of multiple possible variations for this sensor.
- 2. ON Semiconductor recommends a  $1.5k\Omega$  resistor value for the two-wire serial interface RPULL-UP; however, greater values may be used for slower transmission speed.
- 3. RESET BAR has an internal pull-up resistor and can be left floating if not used.
- 4. The decoupling capacitors for the regulator input and output should have a value of 1.0uF. The capacitors should be ceramic and need to have X5R or X7R dielectric.
- 5. TRST BAR connects to GND for normal operation.
- 6. ON Semiconductor recommends that  $0.1\mu F$  and  $1\mu F$  decoupling capacitors for each power supply are mounted as close as possible to the pin. Actual values and numbers may vary depending on layout and design consideration



The following table summarizes the key signals when using the internal regulator. (The internal regulator has to be used for AP0101AT.)

Table 3: Key Signals When Using the Regulator

| Signal Name | Internal Regulator |
|-------------|--------------------|
| Vdd_REG     | 1.8V               |
| FB_SENSE    | 1.2V (input)       |
| LDO_OP      | 1.2V (output)      |

AP0101CS/D Rev. 7, 1/16 EN ©Semiconductor Components Industries, LLC, 2016.

#### **Crystal Usage**

As an alternative to using an external oscillator, a crystal may be connected between EXTCLK and XTAL. Two small loading capacitors and a feedback resistor should be added, as shown in Figure 3.

Figure 3: Using a Crystal Instead of an External Oscillator



Rf represents the feedback resistor, an Rf value of  $1M\Omega$  would be sufficient for AP0101CS. C1 and C2 are decided according to the crystal or resonator CL specification. In the steady state of oscillation, CL is defined as  $(C1 \times C2)/(C1+C2)$ . In fact, the I/O ports, the bond pad, package pin and PCB traces all contribute the parasitic capacitance to C1 and C2. Therefore, CL can be rewritten to be  $(C1^* \times C2^*)/(C1^*+C2^*)$ , where  $C1^*=(C1+Cin, stray)$  and  $C2^*=(C2+Cout, stray)$ . The stray capacitance for the IO ports, bond pad and package pin are known which means the formulas can be rewritten as  $C1^*=(C1+1.5pF+Cin, PCB)$  and  $C2^*=(C2+1.3pF+Cout, PCB)$ .

Table 4: Pin Descriptions

| Name       | Туре     | Description                                                                                                                                                                  |
|------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXTCLK     | Input    | Master input clock. This can either be a square-wave generated from an oscillator (in which case the XTAL input must be left unconnected) or direct connection to a crystal. |
| XTAL       | Output   | If EXTCLK is connected to one pin of a crystal, the other pin of the crystal is connected to XTAL pin; otherwise this signal must be left unconnected.                       |
| RESET_BAR  | Input/PU | Master reset signal, active LOW. This signal has an internal pull up.                                                                                                        |
| Sclk       | Input    | Two-wire serial interface clock (host interface).                                                                                                                            |
| Sdata      | I/O      | Two-wire serial interface data (host interface).                                                                                                                             |
| SADDR      | Input    | Selects device address for the two-wire slave serial interface. When connected to GND the device ID is 0x90. When wired to VDDIO_H, a device ID of 0xBA is selected.         |
| FRAME_SYNC | Input    | This input can be used to set the output timing of the APO101CS. This signal should be connected to GND if not used.                                                         |
| STANDBY    | Input    | Standby mode control, active HIGH.                                                                                                                                           |
| SPI_SCLK   | Output   | Clock output for interfacing to an external SPI flash or EEPROM memory.                                                                                                      |



Table 4: Pin Descriptions (Continued)

| Name          | Туре   | Description                                                                                                                                                                                                                                                                                                                  |
|---------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_SDI       | Input  | Data in from SPI flash or EEPROM memory. When no SPI device is fitted, this signal is used to determine whether the AP0101CS should auto-configure:  0: Do not auto-configure; two-wire interface will be used to configure the device (host-config mode)  1: Auto-configure.  This signal has an internal pull-up resistor. |
| SPI_SDO       | Output | Data out to SPI flash or EEPROM memory.                                                                                                                                                                                                                                                                                      |
| SPI_CS_BAR    | Output | Chip select out to SPI flash or EEPROM memory.                                                                                                                                                                                                                                                                               |
| FV_OUT        | Output | Host frame valid output (synchronous to PIXCLK_OUT)                                                                                                                                                                                                                                                                          |
| LV_OUT        | Output | Host line valid output (synchronous to PIXCLK_OUT)                                                                                                                                                                                                                                                                           |
| PIXCLK_OUT    | Output | Host pixel clock output.                                                                                                                                                                                                                                                                                                     |
| Douт[15:0]    | Output | Host pixel data output (synchronous to PIXCLK_OUT) DOUT[15:0].  Note 20-bit output (SMPTE) also uses GPIO[5:2].                                                                                                                                                                                                              |
| GPIO [5:1]    | I/O    | General purpose digital I/O. Note: 20-bit output (SMPTE) also uses GPIO[5:2]                                                                                                                                                                                                                                                 |
| TRST_BAR      | Input  | Must be tied to GND in normal operation.                                                                                                                                                                                                                                                                                     |
| EXT_CLK_OUT   | Output | Clock to external sensor.                                                                                                                                                                                                                                                                                                    |
| RESET_BAR_OUT | Output | Reset signal to external sensor.                                                                                                                                                                                                                                                                                             |
| M_Sclk        | Output | Two-wire serial interface clock (Master).                                                                                                                                                                                                                                                                                    |
| M_SDATA       | I/O    | Two-wire serial interface clock (Master).                                                                                                                                                                                                                                                                                    |
| FV_IN         | Input  | Sensor frame valid input.                                                                                                                                                                                                                                                                                                    |
| LV_IN         | Input  | Sensor line valid input.                                                                                                                                                                                                                                                                                                     |
| PIXCLK_IN     | Input  | Sensor pixel clock input.                                                                                                                                                                                                                                                                                                    |
| DIN[11:0]     | Input  | Sensor pixel data input DIN[11:0]                                                                                                                                                                                                                                                                                            |
| TRIGGER_OUT   | Output | Trigger signal for external sensor.                                                                                                                                                                                                                                                                                          |
| VDDIO_S       | Supply | Sensor I/O power supply.                                                                                                                                                                                                                                                                                                     |
| GND           | Supply | Ground for sensor IO, host IO, PLL, VDDIO_OTPM, and VDD.                                                                                                                                                                                                                                                                     |
| VDD_REG       | Supply | Input to on-chip 1.8V to 1.2V regulator.                                                                                                                                                                                                                                                                                     |
| LDO_OP        | Output | Output from on-chip 1.8V to 1.2V regulator. Note: The regulator on the APO101CS must be used.                                                                                                                                                                                                                                |
| FB_SENSE      | Input  | On-chip regulator sense signal.                                                                                                                                                                                                                                                                                              |
| GND_REG       | Supply | Ground for on-chip regulator                                                                                                                                                                                                                                                                                                 |
| VDD_PLL       | Supply | PLL supply.                                                                                                                                                                                                                                                                                                                  |
| VDD           | Supply | Core supply.                                                                                                                                                                                                                                                                                                                 |
| VDDIO_OTPM    | Supply | OTPM power supply.                                                                                                                                                                                                                                                                                                           |
| VDDIO_H       | Supply | Host I/O power supply.                                                                                                                                                                                                                                                                                                       |



Table 5: Package Pinout

|   | 1             | 2       | 3         | 4              | 5                         | 6                | 7                         | 8                        | 9               |
|---|---------------|---------|-----------|----------------|---------------------------|------------------|---------------------------|--------------------------|-----------------|
| Α | EXTCLK        | XTAL    | SCLK      | SPI_SDO        | <b>D</b> оυт[ <b>15</b> ] | <b>D</b> оυт[13] | <b>D</b> оυт[ <b>10</b> ] | <b>D</b> оит[9]          | Dout[8]         |
| В | VDD           | VDDIO_H | SDATA     | SPI_SDI        | <b>D</b> оυт[14]          | <b>D</b> оυт[12] | <b>D</b> оυт[11]          | <b>D</b> оит[ <b>7</b> ] | <b>D</b> оυт[6] |
| С | EXT_CLK_OUT   | VDDIO_S | SADDR     | SPI_CS_BA<br>R | GND                       | PIXCLK_OUT       | FV_OUT                    | Douт[5]                  | Dout[4]         |
| D | RESET_BAR_OUT | VDD     | GND       | SPI_SCLK       | GND                       | TRST_BAR         | LV_OUT                    | Dout[3]                  | Dout[2]         |
| E | DIN[3]        | DIN[7]  | GND       | FB_SENSE       | GND                       | GND              | VDD_PLL                   | Dout[1]                  | Dout[0]         |
| F | DIN[11]       | DIN[2]  | LDO_OP    | GND_REG        | GND                       | GND              | VDD_PLL                   | VDD_PLL                  | VDDIO_OTPM      |
| G | DIN[6]        | DIN[1]  | Din[4]    | VDD_REG        | VDDIO_S                   | VDD              | RESET_BAR                 | GPIO[4]                  | GPIO[5]         |
| Н | DIN[10]       | DIN[0]  | DIN[8]    | FV_IN          | M_SDATA                   | VDDIO_H          | FRAME_SYNC                | GPIO[2]                  | GPIO[3]         |
| J | DIN[5]        | DIN[9]  | PIXCLK_IN | LV_IN          | M_Sclk                    | VDD              | STANDBY                   | TRIGGER_OUT              | GPIO[1]         |

## **Power-Up and Down Sequence**

Powering up and down the AP0101CS requires voltages to be applied in a particular order, as seen in Figure 4. The timing requirements are shown in Table 6. The AP0101CS includes a power-on reset feature that initiates a reset upon power up of the AP0101CS.

Figure 4: Power-Up and Power-Down Sequence



AP0101CS/D Rev. 7, 1/16 EN 9 ©Semiconductor Components Industries, LLC, 2016.

| Table 6: | Power-Up and Power-Down Signal Timing |
|----------|---------------------------------------|
|----------|---------------------------------------|

| Symbol | Parameter                                 | Min    | Тур | Max | Unit          |
|--------|-------------------------------------------|--------|-----|-----|---------------|
| t1     | Delay from VDDIO_H to VDDIO_S, VDDIO_OTPM | 0      | _   | 50  | ms            |
| t2     | Delay from VDDIO_H to VDD_REG             | 0      | _   | 50  | ms            |
| t3     | EXTCLK activation                         | t2 + 1 | _   | _   | ms            |
| t4     | First serial command                      | 100    | _   | _   | EXTCLK cycles |
| t5     | EXTCLK cutoff                             | t6     | _   | _   | ms            |
| t6     | Delay from VDD_REG to VDDIO_H             | 0      | _   | 50  | ms            |
| t7     | Delay from VDDIO_S, VDDIO_OTPM to VDDIO_H | 0      | _   | 50  | ms            |
| dv/dt  | Power supply ramp time (slew rate)        | _      | _   | 0.1 | V/µs          |

Note:

If the system cannot support this power supply slew rate, then power supplies must be designed to overcome inrush currents in Table 24, "Inrush Current," on page 38.

#### Reset

The AP0101CS has 3 types of reset available:

- A hard reset is issued by toggling the RESET\_BAR signal
- A soft reset is issued by writing commands through the two-wire serial interface
- An internal power-on reset

Table 7 shows the output states when the part is in various states.

Table 7: Output States

|            | Hardware States Firmware States  |                    |                            |                            |                            |                            |                                                                     |
|------------|----------------------------------|--------------------|----------------------------|----------------------------|----------------------------|----------------------------|---------------------------------------------------------------------|
| Name       | Reset State                      | Default State      | Hard Standby               | Soft Standby               | Streaming                  | Idle                       | Notes                                                               |
| EXTCLK     | (clock<br>running or<br>stopped) | (clock<br>running) | (clock running or stopped) | (clock<br>running)         | (clock<br>running)         | (clock<br>running)         | Input                                                               |
| XTAL       | n/a                              | n/a                | n/a                        | n/a                        | n/a                        | n/a                        | Input                                                               |
| RESET_BAR  | (asserted)                       | (negated)          | (negated)                  | (negated)                  | (negated)                  | (negated)                  | Input                                                               |
| SCLK       | n/a                              | n/a                | (clock running or stopped) | Input. Must always<br>be driven to a valid<br>logic level           |
| SDATA      | High-<br>impedance               | High-<br>impedance | High-<br>impedance         | High-<br>impedance         | High-<br>impedance         | High-<br>impedance         | Input/Output. A valid logic level should be established by pull- up |
| SADDR      | n/a                              | n/a                | n/a                        | n/a                        | n/a                        | n/a                        | Input. Must always<br>be driven to a valid<br>logic level           |
| FRAME_SYNC | n/a                              | n/a                | n/a                        | n/a                        | n/a                        | n/a                        | Input. Must always<br>be driven to a valid<br>logic level           |
| STANDBY    | n/a                              | (negated)          | (asserted)                 | (negated)                  | (negated)                  | (negated)                  | Input. Must always<br>be driven to a valid<br>logic level           |

AP0101CS/D Rev. 7, 1/16 EN OSemiconductor Components Industries, LLC, 2016.



## Table 7: Output States

|                                                 | Hardware States Firmware States |                                   |                              |                              |                    |                    |                                                                                          |
|-------------------------------------------------|---------------------------------|-----------------------------------|------------------------------|------------------------------|--------------------|--------------------|------------------------------------------------------------------------------------------|
| Name                                            | Reset State                     | Default State                     | Hard Standby                 | Soft Standby                 | Streaming          | Idle               | Notes                                                                                    |
| SPI_SCLK                                        | High-<br>impedance              | driven, logic 0                   | driven, logic 0              | driven, logic 0              |                    |                    | Output                                                                                   |
| SPI_SDI                                         | Internal pull-<br>up enabled    | Internal pull-<br>up enabled      | Internal pull-<br>up enabled | internal pull-<br>up enabled |                    |                    | Input. Internal pull-<br>up permanently<br>enabled.                                      |
| SPI_SDO                                         | High-<br>impedance              | driven, logic 0                   | driven, logic 0              | driven, logic 0              |                    |                    | Output                                                                                   |
| SPI_CS_BAR                                      | High-<br>impedance              | driven, logic 1                   | driven, logic 1              | driven, logic 1              |                    |                    | Output                                                                                   |
| EXT_CLK_OUT                                     | driven, logic<br>0              | driven, logic 0                   | driven, logic 0              | driven, logic 0              |                    |                    | Output                                                                                   |
| RESET_BAR_O<br>UT                               | driven, logic<br>0              | driven, logic 0                   | driven, logic 1              | driven, logic 1              |                    |                    | Output. Firmware will release sensor reset                                               |
| M_Sclk                                          | High-<br>impedance              | High-<br>impedance                | High-<br>impedance           | High-<br>impedance           |                    |                    | Input/Output. A valid logic level should be established by pull- up                      |
| M_SDATA                                         | High-<br>impedance              | High-<br>impedance                | High-<br>impedance           | High-<br>impedance           |                    |                    | Input/Output. A valid logic level should be established by pull- up                      |
| FV_IN ,LV_IN,<br>PIXCLK_IN,<br>DIN[11:0]        | n/a                             | n/a                               | n/a                          | n/a                          |                    | n/a                | Input. Must always<br>be driven to a valid<br>logic level                                |
| FV_OUT,<br>LV_OUT,<br>PIXCLK_OUT,<br>DOUT[15:0] | High-<br>impedance              | Varied                            | Driven if used               | Driven if used               | Driven if used     | Driven if used     | Output. Default state dependent on configuration                                         |
| GPIO[5:2]                                       | High-<br>impedance              | Input, then<br>high-<br>impedance | Driven if used               | Driven if used               | Driven if used     | Driven if used     | Input/Output. After reset these pins are sampled as inputs as part of autoconfiguration. |
| GPIO1                                           | High-<br>impedance              | High-<br>impedance                | High-<br>impedance           | High-<br>impedance           | High-<br>impedance | High-<br>impedance |                                                                                          |
| TRIGGER_OUT                                     | High-<br>impedance              | High-<br>impedance                | Driven if used               | Driven if used               | Driven if used     | Driven if used     |                                                                                          |
| TRST_BAR                                        | n/a                             | n/a                               | (negated)                    | (negated)                    | (negated)          | (negated)          | Input. Must always<br>be driven to a valid<br>logic level.                               |

AP0101CS/D Rev. 7, 1/16 EN 

©Semiconductor Components Industries, LLC, 2016.

#### **Hard Reset**

The AP0101CS enters the reset state when the external RESET\_BAR signal is asserted LOW, as shown in Figure 5. All the output signals will be in High-Z state.

Figure 5: Hard Reset Operation



Note: This assumes auto-config.

Table 8: Hard Reset

| Symbol         | Definition                                                            | Min | Тур | Max | Unit   |
|----------------|-----------------------------------------------------------------------|-----|-----|-----|--------|
| t <sub>1</sub> | RESET_BAR pulse width                                                 | 50  | _   | _   |        |
| t <sub>2</sub> | Active EXTCLK required after RESET_BAR asserted                       | 10  | _   | _   | EXTCLK |
| t <sub>3</sub> | Active EXTCLK required before RESET_BAR deasserted                    | 10  | _   | _   | cycles |
| t <sub>4</sub> | First two-wire serial interface communication after RESET_BAR is HIGH | 100 | _   | _   |        |

#### **Soft Reset**

A soft reset sequence to the AP0101CS can be activated by writing to a register through the two-wire serial interface.

## **Hard Standby Mode**

The AP0101CS can enter hard standby mode by using the external STANDBY signal, as shown in Figure 6.

#### **Entering Standby Mode**

1. Assert STANDBY signal HIGH.

#### **Exiting Standby Mode**

1. De-assert STANDBY signal LOW.



Figure 6: Hard Standby Operation



Table 9: Hard Standby Signal Timing

| Symbol         | Parameter                                            | Min | Тур | Max      | Unit    |
|----------------|------------------------------------------------------|-----|-----|----------|---------|
| <sup>t</sup> 1 | Standby entry complete                               | _   | _   | 2 Frames | Lines   |
| <sup>t</sup> 2 | Active EXTCLK required after going into STANDBY mode | 10  | -   | -        | EXTCLKs |
| t <sub>3</sub> | Active EXTCLK required before STANDBY de-asserted    | 10  | -   | -        | EXTCLKs |

AP0101CS/D Rev. 7, 1/16 EN 

©Semiconductor Components Industries, LLC, 2016.

# **Multi-Camera Synchronization Support**

The AP0101CS supports multi-camera synchronization via the FRAME\_SYNC pin. The host (or controlling entity) 'broadcasts' a sync-pulse to all cameras within the system that triggers streaming start. The AP0101CS will propagate the signal to the TRIG-GER\_OUT pin to the sensor's TRIGGER pin.

The AP0101CS supports two different trigger modes. The first mode supported is 'single-shot'; this is when the trigger pulse will cause one frame to be output from the image sensor and AP0101CS (see Figure 7).

Figure 7: Single-Shot Mode



Table 10: Trigger Timing

| Parameter                    | Name                      | Conditions | Min                                      | Тур | Max | Unit          |
|------------------------------|---------------------------|------------|------------------------------------------|-----|-----|---------------|
| FRAME_SYNC to FV_OUT         | <sup>t</sup> frmsync_fvh  |            | 8 lines+ exposure<br>time + sensor delay | _   | -   | Lines         |
| FRAME_SYNC to<br>TRIGGER_OUT | t <sub>trigger_prop</sub> |            | -                                        | 1   | 9   | ns            |
| t <sub>FRAME_SYNC</sub>      | t <sub>FRAMESYNC</sub>    |            | 3                                        | -   | -   | EXTCLK cycles |



The second mode supported is called 'continuous'; this is when a trigger pulse will cause the part to continuously output frames, see Figure 8. This mode would be especially useful for applications which have multiple sensors and need to have their video streams synchronized (for example, surround view or panoramic view applications).

Figure 8: Continuous Mode



Note: This diagram is not to scale.

When two or more cameras have a signal applied to the FRAME\_SYNC input at the same time, the respective FV\_OUT signals would be synchronized within 5 PIXCLK\_OUT cycles. This assumes that all cameras have the same configuration settings and that the exposure time is the same.

## **Image Flow Processor**

Image and color processing in the AP0101CS is implemented as an image flow processor (IFP) coded in hardware logic. During normal operation, the embedded microcontroller will automatically adjust the operating parameters. For normal operation of the AP0101CS, a stream of raw image data from the attached image sensor is fed into the color pipeline. The user also has the option to select a number of test patterns to be input instead of sensor data. The test pattern is fed to the IFP for testing the image pipeline without sensor operation.

The test patterns can be selected by programming variables. To select enter test pattern mode, set R0xC88F to 0x02 and issue a Change- Config request; to exit this mode, set R0xC88F to 0x00.

AP0101CS/D Rev. 7, 1/16 EN Semiconductor Components Industries, LLC, 2016.



Figure 9: AP0101CS IFP



## **Test Patterns**

Figure 10: Color Bar Test Pattern

| Test Pattern                                                                                                                                                                                                                                                                                                                                      | Example |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| FLAT FIELD FIELD_WR= CAM_MODE_SELECT, 0x02 FIELD_WR= CAM_MODE_TEST_PATTERN_SELECT, 0x01 FIELD_WR= CAM_MODE_TEST_PATTERN_RED, 0x000FFFFF FIELD_WR= CAM_MODE_TEST_PATTERN_GREEN, 0x000FFFFF FIELD_WR= CAM_MODE_TEST_PATTERN_BLUE, 0x000FFFFF Load = Change-Config Changing the values in R0xC890-R0xC898 will change the color of the test pattern. |         |
| 100% Color Bar  FIELD_WR= CAM_MODE_SELECT, 0x02  FIELD_WR= CAM_MODE_TEST_PATTERN_SELECT, 0x02  Load = Change-Config                                                                                                                                                                                                                               |         |
| Pseudo-Random  FIELD_WR= CAM_MODE_SELECT, 0x02  FIELD_WR= CAM_MODE_TEST_PATTERN_SELECT, 0x05  Load = Change-Config                                                                                                                                                                                                                                |         |
| Fade-to-Gray  FIELD_WR= CAM_MODE_SELECT, 0x02  FIELD_WR= CAM_MODE_TEST_PATTERN_SELECT, 0x08  Load = Change-Config                                                                                                                                                                                                                                 |         |
| Linear Ramp  FIELD_WR= CAM_MODE_SELECT, 0x02  FIELD_WR= CAM_MODE_TEST_PATTERN_SELECT, 0x09  Load = Change-Config                                                                                                                                                                                                                                  |         |



#### **Defect Correction**

After data decompanding the image stream processing starts with defect correction.

To obtain defect free images, the pixels marked defective during sensor readout and the pixels determined defective by the defect correction algorithms are replaced with values derived from the non-defective neighboring pixels. This image processing technique is called defect correction.

## **AdaCD (Adaptive Color Difference)**

Automotive applications require good performance in extremely low light, even at high temperature conditions. In these stringent conditions the image sensor is prone to higher noise levels, and so efficient noise reduction techniques are required to circumvent this sensor limitation and deliver a high quality image to the user.

The AdaCD Noise Reduction Filter is able to adapt its noise filtering process to local image structure and noise level, removing most objectionable color noise while preserving edge details.

## **Black Level Subtraction and Digital Gain**

After noise reduction, the pixel data goes through black level subtraction and multiplication of all pixel values by a programmable digital gain. Independent color channel digital gain can be adjusted with registers. Black level subtract (to compensate for sensor data pedestal) is a single value applied to all color channels. If the black level subtraction produces a negative result for a particular pixel, the value of this pixel is set to 0.

## Positional Gain Adjustments (PGA)

Lenses tend to produce images whose brightness is significantly attenuated near the edges. There are also other factors causing fixed pattern signal gradients in images captured by image sensors. The cumulative result of all these factors is known as image shading. The AP0101CS has an embedded shading correction module that can be programmed to counter the shading effects on each individual R, Gb, Gr, and B color signal.

#### **The Correction Function**

The correction functions can then be applied to each pixel value to equalize the response across the image as follows:

$$P_{corrected}(row, col) = P_{sensor}(row, col) \times f(row, col)$$
 (EQ 1)

where P are the pixel values and f is the color dependent correction functions for each color channel.



## **Adaptive Local Tone Mapping (ALTM)**

Real world scenes often have very high dynamic range (HDR) that far exceeds the electrical dynamic range of the imager. Dynamic range is defined as the luminance ratio between the brightest and the darkest object in a scene. In recent years many technologies have been developed to capture the full dynamic range of real world scenes. For example, the multiple exposure method is a widely adopted method for capturing high dynamic range images, which combines a series of low dynamic range images of the same scene taken under different exposure times into a single HDR image.

Even though the new digital imaging technology enables the capture of the full dynamic range, low dynamic range display devices are the limiting factor. Today's typical LCD monitor has contrast ratio around 1,000:1; however, it is not atypical for an HDR image having contrast ratio around 250,000:1. Therefore, in order to reproduce HDR images on a low dynamic range display device, the captured high dynamic range must be compressed to the available range of the display device. This is commonly called tone mapping.

Tone mapping methods can be classified into global tone mapping and local tone mapping. Global tone mapping methods apply the same mapping function to all pixels. While global tone mapping methods provide computationally simple and easy to use solutions, they often cause loss of contrast and detail. A local tone mapping is thus necessary in addition to global tone mapping for the reproduction of visually more appealing images that also reveal scene details that are important for automotive safety and surveillance applications. Local tone mapping methods use a spatially varying mapping function determined by the neighborhood of a pixel, which allows it to increase the local contrast and the visibility of some details of the image. Local methods usually yield more pleasing results because they exploit the fact that human vision is more sensitive to local contrast.

ON Semiconductor's ALTM solution significantly improves the performance over global tone mapping. ALTM is directly applied to the Bayer domain to compress the dynamic range from 20-bit to 12-bit. This allows the regular color pipeline to be used for HDR image rendering.

#### **Color Interpolation**

In the raw data stream fed by the sensor core to the IFP, each pixel is represented by a 20-or 12-bit integer number, which can be considered proportional to the pixel's response to a one-color light stimulus, red, green, or blue, depending on the pixel's position under the color filter array. Initial data processing steps, up to and including ALTM, preserve the one-color-per-pixel nature of the data stream, but after ALTM it must be converted to a three-colors-per-pixel stream appropriate for standard color processing. The conversion is done by an edge-sensitive color interpolation module. The module pads the incomplete color information available for each pixel with information extracted from an appropriate set of neighboring pixels. The algorithm used to select this set and extract the information seeks the best compromise between preserving edges and filtering out high frequency noise in flat field areas. The edge threshold can be set through register settings.

### **Color Correction and Aperture Correction**

To achieve good color fidelity of the IFP output, interpolated RGB values of all pixels are subjected to color correction. The IFP multiplies each vector of three pixel colors by a 3 x 3 color correction matrix. The three components of the resulting color vector are all sums of three 10-bit numbers. The color correction matrix can be either programmed by



the user or automatically selected by the auto white balance (AWB) algorithm implemented in the IFP. Color correction should ideally produce output colors that are corrected for the spectral sensitivity and color crosstalk characteristics of the image sensor. The optimal values of the color correction matrix elements depend on those sensor characteristics and on the spectrum of light incident on the sensor. The color correction variables can be adjusted through register settings.

To increase image sharpness, a programmable 2D aperture correction (sharpening filter) is applied to color-corrected image data. The gain and threshold for 2D correction can be defined through register settings.

#### **Gamma Correction**

The gamma correction curve is implemented as a piecewise linear function with 33 knee points, taking 12-bit arguments and mapping them to 10-bit output. The abscissas of the knee points are fixed at 0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 448, 512, 640, 768, 896, 1024, 1280, 1536, 1792, 2048, 2560, 3072, 3584, and 4096. The 10-bit ordinates are programmable through variables.

The AP0101CS has the ability to calculate the 33-point knee points based on the tuning of cam\_ll\_gamma and cam\_ll\_contrast\_gradient\_bright. The other method is for the host to program the 33 knee point curve themselves.

Also included in this block is a Fade-to Black curve which sets all knee points to zero and causes the image to go black in extreme low light conditions.

#### **Color Kill**

To remove high-or low-light color artifacts, a color kill circuit is included. It affects only pixels whose luminance exceeds a certain preprogrammed threshold. The U and V values of those pixels are attenuated proportionally to the difference between their luminance and the threshold.

#### **YUV Color Filter**

As an optional processing step, noise suppression by one-dimensional low-pass filtering of Y and/or UV signals is possible. A 3- or 5-tap filter can be selected for each signal.



#### **Camera Control and Auto Functions**

## **Auto Exposure**

The auto exposure algorithm optimizes scene exposure to minimize clipping and saturation in critical areas of the image. This is achieved by controlling exposure time and analog gains of the sensor core as well as digital gains applied to the image.

The auto exposure module analyzes image statistics collected by the exposure measurement engine, makes a decision, and programs the sensor and color pipeline to achieve the desired exposure. The measurement engine subdivides the image into 25 windows organized as a  $5 \times 5$  grid.

Figure 11: 5 x 5 Grid

| W 0,0 | W 0,1 | W 0,2 | W 0,3 | W 0,4 |
|-------|-------|-------|-------|-------|
| W 1,0 | W 1,1 | W 1,2 | W 1,3 | W 1,4 |
| W 2,0 | W 2,1 | W 2,2 | W 2,3 | W 2,4 |
| W 3,0 | W 3,1 | W 3,2 | W 3,3 | W 3,4 |
| W 4,0 | W 4,1 | W 4,2 | W 4,3 | W 4,4 |



## **AE Track Driver**

Other algorithm features include the rejection of fast fluctuations in illumination (time averaging), control of speed of response, and control of the sensitivity to small changes. While the default settings are adequate in most situations, the user can program target brightness, measurement window, and other parameters described above.

The driver changes AE parameters (integration time, gains, and so on) to drive scene brightness to the programmable target.

To avoid unwanted reaction of AE on small fluctuations of scene brightness or momentary scene changes, the AE track driver uses a temporal filter for luma and a threshold around the AE luma target. The driver changes AE parameters only if the difference between the AE luma target and the filtered luma is larger than the AE target step and pushes the luma beyond the threshold.

AP0101CS/D Rev. 7, 1/16 EN 21 ©Semiconductor Components Industries, LLC, 2016.



#### **Auto White Balance**

The AP0101CS has a built-in AWB algorithm designed to compensate for the effects of changing spectra of the scene illumination on the quality of the color rendition. The algorithm consists of two major parts: a measurement engine performing statistical analysis of the image and a driver performing the selection of the optimal color correction matrix and IFP digital gain. While default settings of these algorithms are adequate in most situations, the user can reprogram base color correction matrices, place limits on color channel gains, and control the speed of both matrix and gain adjustments. The AP0101CS AWB displays the current AWB position in color temperature, the range of which will be defined when programming the CCM matrixes.

The region of interest can be controlled through the combination of an inclusion window and an exclusion window.

#### **Dual Band IRCF**

For some applications a day/night filter would be switched in/out, this option is an additional cost to the camera system. The AP0101CS supports the use of dual band IRCF, which removes the need for the switching day/night filter. Tuning support is provided for this usage case. Refer to the AP0101CS developer guide for details.

## **Exposure and White Balance Modes**

AP0101CS supports auto and manual exposure and white balance modes. In addition, it will operate within synchronized multi-camera systems. In this use case, one camera within the system will be the 'master', and the others 'slaves'. The master is used to calculate the appropriate exposure and white balance. This is then applied to all slaves concurrently under host control.

#### **Auto Mode**

In Auto Exposure mode the AE algorithm is responsible for calculating the appropriate exposure to keep the desired scene brightness, and for applying the exposure to the underlying hardware. In Auto White Balance mode the AWB algorithm is responsible for calculating the color temperature of the scene and applying the appropriate red and blue gains.

### **Triggered Auto mode**

The Triggered Auto Exposure and Triggered Auto White Balance modes are intended for the multi-camera use cases, where a host is controlling the exposure and white balance of a number of cameras. The idea is that one camera is in triggered-auto mode (the master), and the others in host-controlled mode (slaves). The master camera must calculate the exposure and gains, the host then copies this to the slaves, and all changes are then applied at the same time.

#### **Manual Mode**

Manual mode is intended to allow simple manual exposure and white balance control by the host. The host needs to set the CAM\_AET\_EXPOSURE\_TIME\_MS, CAM\_AET\_EXPOSURE\_GAIN and CAM\_AWB\_COLOR\_TEMPERATURE controls, the camera will calculate the appropriate integration times and gains.



#### **Host Controlled**

The Host Controlled mode is intended to give the host full control over exposure and gains.

#### Flicker Avoidance

Flicker occurs when the integration time is not an integer multiple of the period of the light intensity. The AP0101CS can be programmed to avoid flicker for 50 or 60 Hertz. For integration times less than the light intensity period (10ms for 50Hz environment), flicker cannot be avoided. The AP0101CS supports an indoor AE mode, that will ensure flicker-free operation.

## **Output Formatting**

The AP0101CS can output pixel data as an 8 or 10 bit word, over one or two clocks per pixel. AP0101AT supports parallel output & SMPTE modes.

## **Uncompressed YCbCr Data Ordering**

The AP0101CS supports swapping YCbCr mode, as illustrated in Table 11.

Table 11: YCbCr Output Data Ordering

| Mode              | Data Sequence |     |      |      |
|-------------------|---------------|-----|------|------|
| Default (no swap) | Cbi           | Yi  | Cri  | Yi+1 |
| Swapped CrCb      | Cri           | Yi  | Cbi  | Yi+1 |
| Swapped YC        | Yi            | Cbi | Yi+1 | Cri  |
| Swapped CrCb, YC  | Yi            | Cri | Yi+1 | Cbi  |

The data ordering for the YCbCr output modes for AP0101CS are shown in Table 12 and Table 13:

Table 12: YCbCr Output Modes (cam\_port\_parallel\_msb\_align=0x1, cam\_port\_parallel\_swap\_bytes = 0, cam\_output\_format\_yuv\_swap\_red\_blue = 0)

| Mode            | Byte                 | Pixel i | Pixel i+1 | Notes                                            |
|-----------------|----------------------|---------|-----------|--------------------------------------------------|
| YCbCr 422 8 8   | Odd (Douт [15:8])    | Cbi     | Cri       | Data range of 0-255 (Y=16-235 and C=16-240)      |
| 10001_422_8_8   | Even (Douт [15:8])   | Yi      | Yi+1      |                                                  |
| YCbCr_422_10_10 | Odd (Dout [15:6])    | Cbi     | Cri       | Data range of 0-1023 (Y=64-940 and C=64-<br>960) |
|                 | Even (Douт [15:6])   | Yi      | Yi+1      |                                                  |
| YCbCr_422_16    | Single (Dout [15:0]) | Cbi_Yi  | Cri_Yi+1  | Data range of 0-255 (Y=16-235 and C=16-240)      |

Note: Odd means first cycle; even means second cycle.

Table 13: YCbCr Output Modes (cam\_port\_parallel\_msb\_align=0x0, cam\_port\_parallel\_swap\_bytes = 0, cam\_output\_format\_yuv\_swap\_red\_blue = 0)

| Mode          | Byte             | Pixel i | Pixel i+1 | Notes                                       |
|---------------|------------------|---------|-----------|---------------------------------------------|
| YCbCr 422 8 8 | Odd (Dουτ[7 :0]) | Cbi     | Cri       | Data range of 0-255 (Y=16-235 and C=16-240) |
| 10001_422_8_8 | Even (Dout [7:0] | Yi      | Yi+1      |                                             |



Table 13: YCbCr Output Modes (cam\_port\_parallel\_msb\_align=0x0, cam\_port\_parallel\_swap\_bytes = 0, cam\_output format yuv swap\_red\_blue = 0)

| Mode            | Byte                 | Pixel i | Pixel i+1 | Notes                                         |
|-----------------|----------------------|---------|-----------|-----------------------------------------------|
| YCbCr 422 10 10 | Odd (Dout [9:0])     | Cbi     | Cri       | Data range of 0-1023 (Y=64-940 and C=64-960)" |
| TCDC1_422_10_10 | Even (Dout [9:0])    | Yi      | Yi+1      |                                               |
| YCbCr_422_16    | Single (DOUT [15:0]) | Cbi_Yi  | Cri_Yi+1  | Data range of 0-255 (Y=16-235 and C=16-240)   |

Figure 12: 8- bit YCbCr Output (YCbCr 422 8 8)



Note: cam\_port\_parallel\_msb\_align = 0 cam\_port\_parallel\_swap\_bytes = 1 cam\_output\_format\_yuv\_swap\_red\_blue = 0

AP0101CS/D Rev. 7, 1/16 EN QSemiconductor Components Industries, LLC, 2016.



Figure 13: 10-bit YCbCr Output (YCbCr\_422\_10\_10)



Note: cam\_port\_parallel\_msb\_align = 1 cam\_port\_parallel\_swap\_bytes = 1 cam\_output\_format\_yuv\_swap\_red\_blue = 0

AP0101CS/D Rev. 7, 1/16 EN Semiconductor Components Industries, LLC, 2016.