# 1/3-Inch CMOS Digital Image Sensor ## **AR0330CS Data Sheet** For the latest data sheet, refer to Aptina's Web site: www.aptina.com #### **Features** - 2.2µm pixel with Aptina™ A-Pix™ technology - Superior low-light performance - 3.4Mp (3:2) and 3.15Mp (4:3)still images - Support for external mechanical shutter - Support for external LED or Xenon flash - Data interfaces: two-lane serial MIPI or parallel interface - On-chip phase-locked loop (PLL) oscillator - Integrated position-based color and lens shading correction - Simple two-wire serial interface - · Auto black level calibration - 12-to-10 bit output A-Law compression - Slave mode for precise frame-rate control and for synchronizing two sensors # **Applications** - 1080P30 high-definition digital video camcorder - Web cameras and video conferencing cameras - Security # **General Description** Aptina's AR0330CS is a 1/3-inch CMOS digital image sensor with an active-pixel array of 2304Hx1536V. It can support 3.15 megapixel (2048H x 1536V) digital still image capture and a 1080p30+20%EIS (2304H x 1296V) digital video mode. It incorporates sophisticated on-chip camera functions such as windowing, mirroring, column and row subsampling modes, and snapshot modes. ## **Ordering Information** Table 1: Available Part Numbers | Part Number | Description | |-------------------|-----------------------------| | AR0330CS1C12SPKA0 | CSP (Parallel/MIPI) 12° CRA | | AR0330SR1C00SUKA0 | CSP (Parallel/MIPI) 0° CRA | Table 2: Key Parameters | Paramet | er | Typical Value | | | | |-----------------------|-------------------------------------|-------------------------------------|--|--|--| | Optical f | ormat | 1/3-inch (6.0 mm) | | | | | | | Entire Array: 6.09mm | | | | | | | Still Image: 5.63mm (4:3) | | | | | | | HD Image: 5.82mm (16:9) | | | | | Active pi | xels | 2304(H) x 1536(V): (entire array): | | | | | | | 5.07mm(H) x 3.38mm(V) | | | | | | | 2048(H) x 1536(V) (4:3, still mode) | | | | | | | 2304(H) x 1296(V) (16:9, sHD mode) | | | | | Pixel size | 2 | 2.2μm x 2.2μm | | | | | Color filt | er array | RGB Bayer | | | | | Shutter t | ype | ERS and GRR | | | | | Input clo | ck range | 6 – 27 MHz | | | | | Output o | lock maximum | 98 Mp/s (parallel or 2-lane MIPI) | | | | | Respons | vity | 2.0 V/lux-sec | | | | | Power Co | onsumption | 1080P30 MIPI Mode: 282mW. | | | | | | | 1080P30 Parallel Mode: 252mW | | | | | SNR <sub>MAX</sub> | | 39 dB | | | | | Dynamic | range | 69.5 dB | | | | | Supply | I/O/Digital | 1.7–1.9V (1.8V nominal) or | | | | | voltage | | 2.4–3.1V (2.8V nominal) | | | | | | Digital | 1.7–1.9V (1.8 V nominal) | | | | | | Analog | 2.7–2.9V | | | | | Operatin<br>(junction | g temperature<br>ı) -T <sub>J</sub> | -30°C to +70° C | | | | | Package | options | 6.28 mm x 6.65 mm CSP | | | | PDF: 5062883023 / Source: 1734113223 AR0330CS\_DS - Rev. C Pub. 11/12 EN 1 # AR0330CS: 1/3-Inch CMOS Digital Image Sensor Table of Contents # **Table of Contents** | Features | 1 | |-------------------------------------------|----| | Applications | 1 | | General Description | 1 | | Ordering Information | 1 | | General Description | 6 | | Functional Overview | 6 | | Working Modes | 7 | | Pin Descriptions | 10 | | Sensor Initialization | 12 | | Power-Up Sequence | | | Power-Down Sequence | 14 | | Electrical Characteristics | 15 | | Electrical Definitions | | | Timing Definitions | | | Transmitter Eye Mask | 21 | | Clock Signal | | | Sequencer | | | Sensor PLL | | | VCO | | | Dual Readout Paths | | | Parallel PLL Configuration | | | Serial PLL Configuration | | | Pixel Output Interfaces | | | Parallel Interface | | | Configuration of the Pixel Data Interface | | | MIPI Interface | | | Serial Configuration | | | Pixel Sensitivity | | | Gain Stages | | | Data Pedestal | | | Sensor Readout | | | Image Acquisition Modes | | | Window Control | | | Readout Modes | | | Horizontal Mirror | | | Vertical Flip. | | | Subsampling | | | Sensor Frame Rate | 40 | | Row Period (T <sub>ROW</sub> ) | | | Row Periods Per Frame | | | Slave Mode | | | Frame Readout | | | Changing Sensor Modes | | | Register Changes | | | Real-Time Context Switching | | | Compression | | | Test Patterns | | | Solid Color. | | | Vertical Color Bars. | | | Walking 1s | | | Two-Wire Serial Register Interface | | # AR0330CS: 1/3-Inch CMOS Digital Image Sensor Table of Contents | | Protocol | 48 | |----|----------------------------------------------|----| | | Start Condition | 48 | | | Stop Condition | | | | Data Transfer | 48 | | | Slave Address/Data Direction Byte | 49 | | | Message Byte | 49 | | | Acknowledge Bit | 49 | | | No-Acknowledge Bit | | | | Typical Sequence | | | | Single READ From Random Location | | | | Single READ From Current Location | | | | Sequential READ, Start From Random Location | | | | Sequential READ, Start From Current Location | | | | Single WRITE to Random Location | | | | Sequential WRITE, Start at Random Location | | | Sr | ectral Characteristics | | | | SP Packages | | | | ckage Orientation in Camera Design | | | | vision History | | | | • | | # AR0330CS: 1/3-Inch CMOS Digital Image Sensor List of Figures # **List of Figures** | Figure 1: | Block Diagram | | |------------|-------------------------------------------------------------------------------------|-----| | Figure 2: | Typical Configuration: Serial MIPI | .8 | | Figure 3: | Typical Configuration: Parallel Pixel Data Interface | .9 | | Figure 4: | Power Up | 12 | | Figure 5: | Power Down | | | Figure 6: | Two-Wire Serial Interface Timing Parameters | 16 | | Figure 7: | I/O Timing Diagram | | | Figure 8: | Single-Ended and Differential Signals | 19 | | Figure 9: | DC Test Circuit | 19 | | Figure 10: | Clock-to-Data Skew Timing Diagram | | | Figure 11: | Differential Skew | | | Figure 12: | Transmitter Eye Mask | | | Figure 13: | Clock Duty Cycle | | | Figure 14: | Clock Jitter | 22 | | Figure 15: | Relationship Between Readout Clock and Peak Pixel Rate | | | Figure 16: | Sensor Dual Readout Paths | | | Figure 17: | PLL for the Parallel Interface | | | Figure 18: | PLL for the Serial Interface | 26 | | Figure 19: | Integration Control in ERS Readout | | | Figure 20: | Example of 8.33ms Integration in 16.6ms Frame | 31 | | Figure 21: | Row Read and Row Reset Showing Fine Integration | 31 | | Figure 22: | The Row Integration Time is Greater Than the Frame Readout Time | | | Figure 23: | Gain Stages in AR0330CS Sensor | .33 | | Figure 24: | Effect of Horizontal Mirror on Readout Order | | | Figure 25: | Effect of Vertical Flip on Readout Order | 37 | | Figure 26: | Horizontal Binning in the AR0330CS Sensor | 38 | | Figure 27: | Vertical Row Binning in the AR0330CS Sensor | 38 | | Figure 28: | Frame Period Measured in Clocks | | | Figure 29: | Slave Mode Active State and Vertical Blanking | 42 | | Figure 30: | Slave Mode Example with Equal Integration and Frame Readout Periods | | | Figure 31: | Slave Mode Example Where the Integration Period is Half of the Frame Readout Period | | | Figure 32: | Example of Changing the Sensor from Context A to Context B | 46 | | Figure 33: | Single READ From Random Location | | | Figure 34: | Single READ From Current Location | | | Figure 35: | Sequential READ, Start From Random Location | 51 | | Figure 36: | Sequential READ, Start From Current Location. | | | Figure 37: | Single WRITE to Random Location. | | | Figure 38: | Sequential WRITE, Start at Random Location | | | Figure 39: | Bare Die Quantum Efficiency. | 53 | | Figure 40: | CSP Parallel/MIPI Package | | | Figure 41: | Image Orientation With Relation To Camera Lens | | | Figure 42: | First Clear Pixel and Pin Location | .bb | # AR0330CS: 1/3-Inch CMOS Digital Image Sensor List of Tables ## **List of Tables** | Table 1: | Available Part Numbers | 1 | |-----------|---------------------------------------------------------------------------------|----| | Table 2: | Key Parameters | 1 | | Table 3: | Available Aspect Ratios in the AR0330CS Sensor | 7 | | Table 4: | Available Working Modes in the AR0330CS Sensor | 7 | | Table 5: | CSP Package Pinout | | | Table 6: | CSP (Parallel/MIPI) Package Pinout | | | Table 7: | Power-Up Sequence | 13 | | Table 8: | Power-Down Sequence | 14 | | Table 9: | DC Electrical Definitions and Characteristics (MIPI Mode) | 15 | | Table 10: | Absolute Maximum Ratings | 15 | | Table 11: | Two-Wire Serial Interface Electrical Characteristics | 15 | | Table 12: | Two-Wire Serial Interface Timing Specifications | 16 | | Table 13: | I/O Parameters | 17 | | Table 14: | I/O Timing | 18 | | Table 15: | Parallel I/O Rise Slew Rate | 18 | | Table 16: | PLL Parameters for the Parallel Interface | 26 | | Table 17: | Example PLL Configuration for the Parallel Interface | 26 | | Table 18: | PLL Parameters for the Serial Interface | 27 | | Table 19: | Example PLL Configurations for the Serial Interface | 27 | | Table 20: | Configuration of the Pixel Data Interface | 28 | | Table 21: | Recommended MIPI Timing Configuration | 30 | | Table 22: | Recommended Sensor Analog Gain Tables | 33 | | Table 23: | Pixel Column Configuration | 36 | | Table 24: | Pixel Row Configuration | | | Table 25: | Available Skip and Bin Modes in the AR0330CS Sensor | 38 | | Table 26: | Configuration for Horizontal Subsampling | 39 | | Table 27: | Configuration for Vertical Subsampling | 39 | | Table 28: | Minimum Vertical Blanking Configuration | 41 | | Table 29: | Serial SYNC Codes Included with Each Protocol Included with the AR0330CS Sensor | | | Table 30: | List of Configurable Registers for Context A and Context B | 45 | | Table 31: | A-Law Compression Table for 12-10 bits | 47 | | Table 32: | Test Pattern Modes | | | Table 33: | Chief Ray Angle (CRA) 12 ° | 54 | | | | | AR0330CS: 1/3-Inch CMOS Digital Image Sensor General Description # **General Description** The AR0330CS can be operated in its default mode or programmed for frame size, exposure, gain, and other parameters. The default mode output is a 2304 x 1296 image at 30 frames per second (fps). The sensor outputs 10- or 12-bit raw data, using either the parallel or serial (MIPI) output ports. ## **Functional Overview** The AR0330CS is a progressive-scan sensor that generates a stream of pixel data at a constant frame rate. It uses an on-chip, phase-locked loop (PLL) that can generate all internal clocks from a single master input clock running between 6 and 27 MHz. The maximum output pixel rate is 98 Mp/s using a 2-lane MIPI serial interface and 98 Mp/s using the parallel interface. Figure 1 shows a block diagram of the sensor. Figure 1: Block Diagram User interaction with the sensor is through the two-wire serial bus, which communicates with the array control, analog signal chain, and digital signal chain. The core of the sensor is a 3.4Mp active- pixel sensor array. The timing and control circuitry sequences through the rows of the array, resetting and then reading each row in turn. In the time interval between resetting a row and reading that row, the pixels in the row integrate incident light. The exposure is controlled by varying the time interval between reset and readout. Once a row has been read, the signal from the column is amplified in a column amplifier and then digitized in an analog-to-digital converter (ADC). The output from the ADC is a 12-bit value for each pixel in the array. The ADC output passes through a digital processing signal chain (which provides further data path corrections and applies digital gain). AR0330CS: 1/3-Inch CMOS Digital Image Sensor Working Modes # **Working Modes** The AR0330CS sensor working modes are specified from the following aspect ratios: Table 3: Available Aspect Ratios in the AR0330CS Sensor | | Aspect Ratio | Sensor Array Usage | |-------|-----------------|---------------------| | 4:3 | Still Format #1 | 2256 (H) x 1296 (V) | | 16:10 | Still Format #2 | 2256 (H) x 1504 (V) | | 16:9 | HD Format | 2304 (H) x 1296 (V) | The AR0330CS supports the following working modes. To operate the sensor at full speed 98Mp/s the sensor must use 2-Lane MIPI or parallel interface. The sensor will operate at full-speed (98 Mp/s) when using the parallel interface. Table 4: Available Working Modes in the AR0330CS Sensor | Mode | Aspect Ratio | Active Readout<br>Window | Sensor Output<br>Resolution | FPS<br>(2-Lane MIPI<br>Interface) | FPS (Parallel<br>Interface) | Subsampling | FOV | |---------------------------|--------------|--------------------------|-----------------------------|-----------------------------------|-----------------------------|-------------|------| | 1080p + EIS | 16:9 | 2304 x 1296 | 2304 x 1296 | 30 | 30 | _ | 100% | | 3M Still | 4:3 | 2048 x 1536 | 2048 x 1536 | 30 | 25 | _ | 100% | | | 3:2 | 2256 x 1504 | 2256 x 1504 | 30 | 25 | _ | 100% | | WVGA + EIS | 16:9 | 2304 x 1296 | 1152 x 648 | 60 | 60 | 2x2 | 100% | | WVGA + EIS<br>Slow-motion | 16:9 | 2304 x 1296 | 1152 x 648 | 120 | N/A | 2x2 | 100% | | VGA Video | 16:10 | 2256 x 1440 | 752 x 480 | 60 | 60 | 3x3 | 96% | | VGA Video<br>Slow-motion | 16:10 | 2256 x 1440 | 752 x 480 | 215 | 107 | 3x3 | 96% | Figure 2: Typical Configuration: Serial MIPI Notes: - 1. All power supplies must be adequately decoupled. Aptina recommends having 10μF and 0.1μF decoupling capacitors for every power supply. If space is a concern, then priority must be given in the following order: VAA, VAA\_PIX, VDD\_PLL, VDD\_MIPI, VDD\_IO, and VDD. Actual values and results may vary depending on layout and design considerations. - 2. To allow for space constraints, Aptina recommends having $0.1\mu\text{F}$ decoupling capacitor inside the module as close to the pads as possible. In addition, place a $10\mu\text{F}$ capacitor for each supply off-module but close to each supply. - 3. Aptina recommends a resistor value of $1.5k\Omega$ , but a greater value may be used for slower two-wire speed. - 4. The pull-up resistor is not required if the controller drives a valid logic level on SCLK at all times. - 5. Aptina recommends that analog power planes are placed in a manner such that coupling with the digital power planes is minimized. - 6. TEST pin must be tied to DGND for the MIPI configuration. - 7. Aptina recommends that GND MIPI be tied to DGND. - 8. VDD\_MIPI is tied to VDD\_PLL in the CSP package. Aptina strongly recommends that VDD\_MIPI must be connected to a VDD\_PLL in a module design since VDD\_PLL and VDD\_MIPI are tied together in the die. - 9. The package pins or die pads used for the parallel interface must be left floating. - 10. If the SHUTTER or FLASH pins or pads are not used, then they must be left floating. - 11. If the TRIGGER pin or pad is not used, then it should be tied to DGND. Figure 3: Typical Configuration: Parallel Pixel Data Interface Notes: - All power supplies must be adequately decoupled. Aptina recommends having 10μF and 0.1μF decoupling capacitors for every power supply. If space is a concern, then priority must be given in the following order: VAA, VAA\_PIX, VDD\_PLL, VDD\_IO, and VDD. Actual values and results may vary depending on layout and design considerations. - 2. To allow for space constraints, Aptina recommends having $0.1\mu F$ decoupling capacitor inside the module as close to the pads as possible. In addition, place a $10\mu F$ capacitor for each supply off-module but close to each supply. - 3. Aptina recommends a resistor value of 1.5k $\Omega$ , but a greater value may be used for slower two-wire speed. - 4. The pull-up resistor is not required if the controller drives a valid logic level on SCLK at all times. - 5. Aptina recommends that analog power planes are placed in a manner such that coupling with the digital power planes is minimized. - 6. TEST pin should be tied to the ground. - 7. The data and clock package pins or die pads used for the MIPI interface must be left floating. - 8. The VDD\_MIPI package pin and sensor die pad should be connected to a 2.8V supply as it is tied to the VDD\_PLL supply both in the package routing and also within the sensor die itself. - 9. If the SHUTTER or FLASH pins or pads are not used, then they must be left floating. - 10. If the TRIGGER pin or pad is not used, then it should be tied to DGND. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Pin Descriptions # **Pin Descriptions** ## Table 5: CSP Package Pinout | | _ | | |-------------|--------|-------------------------------------------------------------------------------------------------------------------------------| | Name | Туре | Description | | RESET_BAR | Input | Asynchronous reset (active LOW). All settings are restored to factory default. | | EXTCLK | Input | Master input clock, range 6 - 27 MHz | | TRIGGER | Input | Receives slave mode VD signal for frame rate synchronization and trigger to start a GRR frame. | | Saddr | Input | Two-wire serial address select. | | Sclk | Input | Two-wire serial clock input. | | Sdata | I/O | Two-wire serial data I/O. | | PIXCLK | Output | Pixel clock out. Do∪⊤ is valid on rising edge of this clock. | | Dоит[11:0] | Output | Parallel pixel data output. | | FLASH | Output | Flash output. Synchronization pulse for external light source. Can be left floating if not used. | | FRAME_VALID | Output | Asserted when Dout data is valid. | | LINE_VALID | Output | Asserted when Dout data is valid. | | VDD | Power | Digital power. | | VDD_IO | Power | IO supply power. | | VDD_PLL | Power | PLL power supply. The MIPI power supply (VDD_MIPI) is tied to VDD_PLL in both packages. | | DGND | Power | Digital GND. | | Vaa | Power | Analog power. | | VAA_PIX | Power | Pixel power. | | AGND | Power | Analog GND. | | TEST | Input | Enable manufacturing test modes. Tie to DGND for normal sensor operation. | | SHUTTER | Output | Control for external mechanical shutter. Can be left floating if not used. | | DATA1_P | Output | MIPI serial data, lane 1, differential P | | DATA1_N | Output | MIPI serial data, lane 1, differential N | | DATA2_P | Output | MIPI serial data, lane 2, differential P | | DATA2_N | Output | MIPI serial data, lane 2, differential N | | DATA3_P | Output | MIPI serial data, lane 3, differential P | | DATA3_N | Output | MIPI serial data, lane 3, differential N | | DATA4_P | Output | MIPI serial data, lane 4, differential P | | DATA4_N | Output | MIPI serial data, lane 4, differential N | | CLK_P | Output | Output MIPI serial clock, differential P | | CLK N | Output | Output MIPI serial clock, differential N | | VDD_MIPI | Power | 1.8V power port to MIPI digital logic | | VAAHV_NPIX | Power | Power supply pin used to program the sensor OTPM (one-time programmable memory). This pin should be open if OTPM is not used. | # Table 6: CSP (Parallel/MIPI) Package Pinout | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | |---|--------|------------|----------------|-----------------------|---------|--------|---------|-----------| | Α | VAA | VAAHV_NPIX | AGND | DNC | VAA_PIX | VAA | VDD_IO | VDD | | В | VDD | Sdata | FRAME_VALID | DGND | AGND | DGND | TEST | SHUTTER | | С | Saddr | FLASH | LINE_VALID | DGND | DGND | DGND | TRIGGER | RESET_BAR | | D | Sclk | VDD_IO | Dоит <b>10</b> | DGND | VDD_IO | VDD_IO | EXTCLK | DATA_N | | E | PIXCLK | Dout11 | <b>Д</b> оит9 | <b>D</b> оит <b>7</b> | VDD_IO | DGND | CLK_N | DATA_P | AR0330CS: 1/3-Inch CMOS Digital Image Sensor Pin Descriptions ## Table 6: CSP (Parallel/MIPI) Package Pinout | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | |---|------|------|-------|---------------|--------|-----------------------|---------|----------| | F | - | _ | Dоит8 | <b>D</b> оит6 | Dоит4 | VDD_IO | CLK_P | VDD_PLL | | G | Dgnd | VDD | Dout5 | <b>D</b> оит3 | Dout1 | <b>D</b> оит <b>0</b> | DATA2_N | VDD | | Н | _ | DGND | DGND | Dоит2 | VDD_IO | VDD_MIPI | DATA2_P | VDD_MIPI | Note: DNC = Do not connect. For manufacturing test purpose only. ### **Sensor Initialization** ## **Power-Up Sequence** The recommended power-up sequence for the AR0330CS is shown in Figure 4. The available power supplies (VDD\_IO, VDD\_PLL, VDD\_MIPI, VAA, VAA\_PIX) must have the separation specified below. - 1. Turn on VDD\_PLL and VDD\_MIPI power supplies - 2. After 100µs, turn on VAA and VAA\_PIX power supply. - 3. After 100µs, turn on VDD power supply. - 4. After 100μs, turn on VDD\_IO power supply. - 5. After the last power supply is stable, enable EXTCLK. - 6. Assert RESET BAR for at least 1ms. - 7. Wait 150000 EXTCLKs (for internal initialization into software standby. - 8. Configure PLL, output, and image settings to desired values. - 9. Wait 1ms for the PLL to lock. - 10. Set streaming mode (R0x301A[2] = 1). Figure 4: Power Up Note: The sensor must be receiving the external input clock (EXTCLK) before the reset pin is toggled. The sensor will begin an internal initialization sequence when the reset pin toggle from LOW to HIGH. This initialization sequence will run using the external input clock. Power on default state is software standby state, need to apply two-wire serial commands to start streaming. Above power up sequence is a general power up sequence. For different interface configurations, MIPI, and Parallel, some power rails are not needed. Those not needed power rails should be ignored in the general power up sequence. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sensor Initialization Table 7: Power-Up Sequence | Definition | Symbol | Min | Тур | Max | Unit | |-----------------------------------------------|--------|----------------|-----------------|-----|---------| | VDD_PLL, VDD_MIPI to VAA/VAA_PIX <sup>3</sup> | t0 | 0 | 100 | _ | μS | | VAA/VAA_PIX to VDD | t1 | 0 | 100 | _ | μS | | VDD to VDD_IO | t2 | 0 | 100 | _ | μS | | External clock settling time | tx | _ | 30 <sup>1</sup> | _ | mS | | Hard Reset | t3 | 1 <sup>2</sup> | _ | _ | mS | | Internal Initialization | t4 | 150000 | _ | _ | EXTCLKS | | PLL Lock Time | t5 | 1 | - | - | mS | #### Notes: - 1. External clock settling time is component-dependent, usually taking about 10 100 mS. - Hard reset time is the minimum time required after power rails are settled. In a circuit where Hard reset is held down by RC circuit, then the RC time must include the all power rail settle time and Xtal settle time. - 3. It is critical that VDD\_PLL is not powered up after the other power supplies. It must be powered before or at least at the same time as the others. If the case happens that VDD\_PLL is powered after other supplies then sensor may have functionality issues and will experience high current draw on this supply. - 4. VDD\_MIPI is tied to VDD\_PLL in the CSP package and must be powered to 2.8V. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sensor Initialization #### **Power-Down Sequence** The recommended power-down sequence for the AR0330CS is shown in Figure 5. The available power supplies (VDD\_IO, VDD\_PLL, VDD\_MIPI., VAA, VAA\_PIX) must have the separation specified below. - 1. Disable streaming if output is active by setting standby R0x301a[2] = 0 - 2. The soft standby state is reached after the current row or frame, depending on configuration, has ended. - 3. Turn off VDD\_IO. - 4. Turn off VDD - 5. Turn off VAA/VAA\_PIX. - 6. Turn off VDD\_PLL, VDD\_MIPI. Figure 5: Power Down Table 8: Power-Down Sequence | Definition | Symbol | Minimum | Typical | Maximum | Unit | |-----------------------------|--------|---------|---------|---------|------| | VDD_IO | t0 | 0 | _ | - | μS | | VDD_IO to VDD | t1 | 0 | _ | - | μS | | VDD to VAA/VAA_PIX | t2 | 0 | _ | - | μS | | VAA/VAA_PIX to VDD_PLL | t3 | 0 | _ | - | μS | | PwrDn until Next PwrUp Time | t4 | 100 | _ | - | mS | Note: t4 is required between power down and next power up time; all decoupling caps from regulators must be completely discharged. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Electrical Characteristics # **Electrical Characteristics** Table 9: DC Electrical Definitions and Characteristics (MIPI Mode) $\label{eq:fextolk} $^{\rm fEXTCLK} = 24~\rm MHz; \ VDD = 1.8V; \ VDD\_IO = 1.8V; \ VAA = 2.8V; \ VAA\_PIX = 2.8V; \ VDD\_PLL = 2.8V; \ Output \ Ioad = 68.5pF; \ T_J = 60°C; \ Data \ Rate = 588~Mbps; \ DLL \ set \ to \ 0; \ 2304x1296 \ at \ 30~fps$ | Definition | Symbol | Min | Тур | Max | Unit | |--------------------------------|----------|-----|-----|-----|------| | Core digital voltage | VDD | 1.7 | 1.8 | 1.9 | V | | I/O digital voltage | VDD_IO | 1.7 | 1.8 | 1.9 | V | | | | 2.4 | 2.8 | 3.1 | V | | Analog voltage | VAA | 2.7 | 2.8 | 2.9 | V | | Pixel supply voltage | VAA_PIX | 2.7 | 2.8 | 2.9 | V | | PLL supply voltage | VDD_PLL | 2.7 | 2.8 | 2.9 | V | | MIPI supply voltage | VDD_MIPI | 2.7 | 2.8 | 2.9 | V | | Digital operating current | | - | 114 | - | mA | | I/O digital operating current | | - | 0 | - | mA | | Analog operating current | | - | 41 | - | mA | | Pixel supply current | | - | 9.9 | - | mA | | PLL supply current | | - | 15 | - | mA | | MIPI digital operating current | | - | 35 | - | mA | Caution Stresses greater than those listed in Table 10 may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Table 10: Absolute Maximum Ratings | Symbol | Definition | Min | Max | Unit | |-----------------|----------------------|------|-----|------| | VDD_MAX | Core digital voltage | -0.3 | 2.4 | V | | VDD_IO_MAX | I/O digital voltage | -0.3 | 4 | V | | VAA_MAX | Analog voltage | -0.3 | 4 | V | | VAA_PIX | Pixel supply voltage | -0.3 | 4 | V | | VDD_PLL | PLL supply voltage | -0.3 | 4 | V | | t <sub>ST</sub> | Storage temperature | -40 | 85 | °C | Note: Exposure to absolute maximum rating conditions for extended periods may affect reliability. **Table 11:** Two-Wire Serial Interface Electrical Characteristics VDD = 1.7-1.9V; VAA = 2.7-2.9V; $VDD_IO = 1.7-1.9V$ ; Environment temperature = -30°C to 50°C | Symbol | Parameter | Condition | Min | Тур | Max | Unit | |--------|-----------------------|----------------------------------------------|-------|-------|--------------|------| | VIL | Input LOW voltage | | -0.5 | 0.73 | 0.3 x VDD_IO | V | | lin | Input leakage current | No pull up resistor;<br>VIN = VDD_IO or DGND | -2 | | 2 | μΑ | | Vol | Output LOW voltage | At specified 2mA | 0.031 | 0.032 | 0.035 | V | | lol | Output LOW current | At specified Vol 0.1V | | | 3 | mA | | CIN | Input pad capacitance | | | | 6 | pF | | CLOAD | Load capacitance | | | | | pF | Table 12: Two-Wire Serial Interface Timing Specifications VDD = 1.7-1.9V; VAA = 2.7 -2.9V; VDD\_IO = 1.7-1.9V; Environment temperature = -30°C to 50°C | Symbol | Definition | Min | Max | Unit | |--------|--------------------------------------|-----|------|------| | fsclk | SCLK Frequency | 0 | 400 | KHz | | thigh | SCLK High Period | 0.6 | _ | μς | | tlow | SCLK Low Period | 1.3 | _ | μς | | tsrts | START Setup Time | 0.6 | _ | μς | | tsrth | START Hold Time | 0.6 | _ | μς | | tsds | Data Setup Time | 100 | _ | ns | | tsdh | Data Hold Time | 0 | Note | μς | | tsdv | Data Valid Time | _ | 0.9 | μς | | tacv | Data Valid Acknowledge Time | _ | 0.9 | μς | | tstps | STOP Setup Time | 0.6 | _ | μς | | tBUF | Bus Free Time between STOP and START | 1.3 | _ | μς | | tr | SCLK and SDATA Rise Time | _ | 300 | ns | | tr | SCLK and SDATA Fall Time | _ | 300 | ns | Note: Max tsdH could be $0.9\mu s$ but must be less than max of tsdV and tACV by a transition time. Figure 6: Two-Wire Serial Interface Timing Parameters Figure 7: I/O Timing Diagram # AR0330CS: 1/3-Inch CMOS Digital Image Sensor Electrical Characteristics \*PLL disabled for <sup>t</sup>CP Table 13: I/O Parameters fEXTCLK = 24 MHz; VDD = 1.8V; VAA = 2.8V; VAA\_PIX = 2.8V; VDD\_PLL = 2.8V; Output load = 68.5pF; T<sub>J</sub> = 60°C; CLK\_OP = 98 MPixel/s | Symbol | Definition | Conditions | Min | Max | Units | | |--------|----------------------------------|----------------------------------------|---------------|--------------|-------|--| | VIH | Input HIGH voltage | VDD_IO = 1.8V | 1.4 | VDD_IO + 0.3 | | | | | | VDD_IO = 2.8V | 2.4 | | | | | VIL | Input LOW voltage | VDD_IO = 1.8V | GND - 0.3 | 0.4 | V | | | | | VDD_IO = 2.8V | GND - 0.3 | 0.8 | | | | lin | Input leakage current | No pull-up resistor; VIN = VDD OR DGND | -20 | 20 | μΑ | | | Vон | Output HIGH voltage | At specified Iон | VDD_IO - 0.4V | _ | V | | | Vol | Output LOW voltage | At specified IOL | _ | 0.4 | V | | | Іон | Output HIGH current | At specified VOH | _ | -12 | mA | | | IOL | Output LOW current | At specified Vol | _ | 9 | mA | | | loz | Tri-state output leakage current | | _ | 10 | μΑ | | AR0330CS: 1/3-Inch CMOS Digital Image Sensor Electrical Characteristics ## Table 14: I/O Timing $^{f}$ EXTCLK = 24 MHz; VDD = 1.8V; VDD\_IO = 1.8V; VAA = 2.8V; VAA\_PIX = 2.8V; VDD\_PLL = 2.8V; Output load = 68.5pF; $^{f}$ T\_J = 60°C; CLK\_OP = 98 MPixel/s | Symbol | Definition | Conditions | Min | Тур | Max | Units | |---------------------|----------------------------|--------------|-----|-----|-----|-------| | <sup>f</sup> EXTCLK | Input clock frequency | PLL enabled | 6 | 24 | 27 | MHz | | <sup>t</sup> EXTCLK | Input clock period | PLL enabled | 166 | 41 | 20 | ns | | <sup>t</sup> R | Input clock rise time | | 0.1 | - | 1 | V/ns | | <sup>t</sup> F | Input clock fall time | | 0.1 | _ | 1 | V/ns | | | Clock duty cycle | | 45 | 50 | 55 | % | | <sup>t</sup> JITTER | Input clock jitter | | - | - | 0.3 | ns | | Output pin slew | Fastest | CLOAD = 15pF | _ | 0.7 | _ | V/ns | | <sup>f</sup> PIXCLK | PIXCLK frequency | Default | _ | 80 | _ | MHz | | <sup>t</sup> PD | PIXCLK to data valid | Default | - | - | 3 | ns | | <sup>t</sup> PFH | PIXCLK to FRAME_VALID HIGH | Default | - | - | 3 | ns | | <sup>t</sup> PLH | PIXCLK to LINE_VALID HIGH | Default | - | - | 3 | ns | | <sup>t</sup> PFL | PIXCLK to FRAME_VALID LOW | Default | - | - | 3 | ns | | <sup>t</sup> PLL | PIXCLK to LINE_VALID LOW | Default | _ | - | 3 | ns | ## Table 15: Parallel I/O Rise Slew Rate $^{f}$ EXTCLK = 24 MHz; VDD = 1.8V; VAA = 2.8V; VAA\_PIX = 2.8V; VDD\_PLL = 2.8V; Output load = 68.5pF; $T_{J}$ = 60°C; CLK\_OP = 98 MPixel/s | | Parallel Slew Rate (R0x306E[15:13]) | | | | | | | | | |--------|-------------------------------------|-------|-------|-------|-------|-------|-------|-------|-------| | VDD_IO | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | Units | | 1.70V | 0.069 | 0.115 | 0.172 | 0.239 | 0.325 | 0.43 | 0.558 | 0.836 | V/ns | | 1.80V | 0.078 | 0.131 | 0.195 | 0.276 | 0.375 | 0.507 | 0.667 | 1.018 | | | 1.95V | 0.093 | 0.156 | 0.233 | 0.331 | 0.456 | 0.62 | 0.839 | 1.283 | | | 2.50V | 0.15 | 0.252 | 0.377 | 0.539 | 0.759 | 1.07 | 1.531 | 2.666 | | | 2.80V | 0.181 | 0.305 | 0.458 | 0.659 | 0.936 | 1.347 | 1.917 | 3.497 | | | 3.10V | 0.212 | 0.361 | 0.543 | 0.78 | 1.114 | 1.618 | 2.349 | 4.14 | | ## **Electrical Definitions** Figure 8 is the diagram defining differential amplitude $V_{OD}$ , $V_{CM}$ , and rise and fall times. To measure $V_{OD}$ and $V_{CM}$ use the DC test circuit shown in Figure 9 and set the MIPI PHY to constant Logic 1 and Logic 0. Measure $V_{oa}$ , $V_{ob}$ and $V_{CM}$ with voltmeters for both Logic 1 and Logic 0. Figure 8: Single-Ended and Differential Signals Single-ended signals #### Differential signal Figure 9: DC Test Circuit $$V_{OD}(m) = |V_{oa}(m) - V_{ob}(m)|$$ where 'm' is either "1" for logic 1 or "0" for logic 0 (EQ 1) $$V_{OD} = \frac{V_{OD}(1) + V_{OD}(0)}{2}$$ (EQ 2) ## AR0330CS: 1/3-Inch CMOS Digital Image Sensor Electrical Definitions $$V_{diff} = V_{OD}(1) + V_{OD}(0)$$ (EQ 3) $$\Delta V_{OD} = |V_{OD}(1) - V_{OD}(0)|$$ (EQ 4) $$V_{CM} = \frac{V_{CM}(1) + V_{CM}(0)}{2}$$ (EQ 5) $$\Delta V_{CM} = |V_{CM}(1) - V_{CM}(0)|$$ (EQ 6) Both $V_{OD}$ and $V_{CM}$ are measured for all output channels. The worst case $\Delta V_{OD}$ is defined as the largest difference in $V_{OD}$ between all channels regardless of logic level. And the worst case $\Delta V_{CM}$ is similarly defined as the largest difference in $V_{CM}$ between all channels regardless of logic level. ## **Timing Definitions** - 1. Timing measurements are to be taken using the Square Wave test mode. - 2. Rise and fall times are measured between 20% to 80% positions on the differential waveform, as shown in Figure 8: "Single-Ended and Differential Signals," on page 19. - 3. Mean Clock-to-Data skew should be measured from the 0V crossing point on Clock to the 0V crossing point on any Data channel regardless of edge, as shown in Figure 10 on page 20. This time is compared with the ideal Data transition point of 0.5UI with the difference being the Clock-to-Data Skew (see Equation 7 on page 20). Figure 10: Clock-to-Data Skew Timing Diagram $$t_{CHSKEW}(ps) = \Delta t - \frac{t_{pw}}{2}$$ (EQ 7) $$t_{CHSKEW}(UI) = \frac{\Delta t}{t_{pw}} - 0.5 \tag{EQ 8}$$ 4. The differential skew is measured on the two single-ended signals for any channel. The time is taken from a transition on $V_{oa}$ signal to corresponding transition on $V_{ob}$ signal at $V_{CM}$ crossing point. Figure 11: Differential Skew Figure 11 on page 21 also shows the corresponding AC $V_{CM}$ common-mode signal. Differential skew between the $V_{oa}$ and $V_{ob}$ signals can cause spikes in the common-mode, which the receiver needs to be able to reject. $V_{CM\_AC}$ is measured as the absolute peak deviation from the mean DC $V_{CM}$ common-mode. ## **Transmitter Eye Mask** Figure 12: Transmitter Eye Mask Figure 12 defines the **eye mask** for the transmitter. 0.5 UI point is the instantaneous crossing point of the Clock. The area in white shows the area Data is prohibited from crossing into. The **eye mask** also defines the minimum eye height, the data $t_{pre}$ and $t_{post}$ times, and the **total jitter pk-pk+mean skew** ( $t_{TISKEW}$ ) for Data. #### **Clock Signal** $t_{HCLK}$ is defined as the high clock period, and $t_{LCLK}$ is defined as the low clock period as shown in Figure 13. The clock duty cycle $D_{CYC}$ is defined as the percentage time the clock is either high $(t_{HCLK})$ or low $(t_{LCLK})$ compared with the clock period T. Figure 13: Clock Duty Cycle $$D_{CYC}(1) = \frac{t_{HCLK}}{T}$$ (EQ 9) $$D_{CYC}(0) = \frac{t_{LCLK}}{T}$$ (EQ 10) $$t_{pw} = \frac{T}{2}$$ (i.e, 1 UI) (EQ 11) $$Bitrate = \frac{1}{t_{pw}}$$ (EQ 12) Figure 14 shows the definition of clock jitter for both the period and the cycle-to-cycle jitter. Figure 14: Clock Jitter # AR0330CS: 1/3-Inch CMOS Digital Image Sensor Electrical Definitions Period Jitter ( $t_{CKJIT}$ ) is defined as the deviation of the instantaneous clock $t_{PW}$ from an ideal 1UI. This should be measured for both the clock high period variation $\Delta t_{HCLK}$ , and the clock low period variation $\Delta t_{LCLK}$ taking the RMS or 1-sigma standard deviation and quoting the worse case jitter between $\Delta t_{HCLK}$ and $\Delta t_{LCLK}$ . Cycle-to-cycle jitter ( $t_{CYCJIT}$ ) is defined as the difference in time between consecutive clock high and clock low periods $t_{HCLK}$ and $t_{LCLK}$ , quoting the RMS value of the variation $\Delta(t_{HCLK} - t_{LCLK})$ . If pk-pk jitter is also measured, this should be limited to ±3-sigma. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sequencer # Sequencer The sequencer digital block determines the order and timing of operations required to sample pixel data from the array during each row period. It is controlled by an instruction set that is programmed into RAM from the sensor OTPM (One Time Programmable Memory). The OTPM is configured during production. The instruction set determines the length of the sequencer operation that determines the "ADC Readout Limitation" (Equation 5) listed in the Sensor Frame-Rate section. The instruction set can be shortened through register writes in order to achieve faster frame rates. Instructions for shortening the sequencer can be found in the AR0330CS Developer Guide. The sequencer digital block can be reprogrammed using the following instructions: Program a new sequencer. - 1. Place the sensor in standby. - 2. Write 0x8000 to R0x3088 ("seq\_ctrl\_port"). - 3. Write each instruction incrementally to R0x3086. Each write must be 16-bit consisting of two bytes $\{Byte[N], Byte[N+1]\}$ . - 4. If the sequencer consists of an odd number of bytes, set the last byte to "0". Read the instructions stored in the sequencer. - 1. Place the sensor in standby. - 2. Write 0xC000 to R0x3088 ("seq\_ctrl\_port"). - 3. Sequentially read 2-bytes at a time from R0x3086. #### **Sensor PLL** #### **VCO** Figure 15: Relationship Between Readout Clock and Peak Pixel Rate The sensor contains a phase-locked loop (PLL) that is used for timing generation and control. The required VCO clock frequency is attained through the use of a pre-PLL clock divider followed by a multiplier. The multiplier is followed by set of dividers used to generate the output clocks required for the sensor array, the pixel analog and digital readout paths, and the output parallel and serial interfaces. #### **Dual Readout Paths** There are two readout paths within the sensor digital block. The sensor PLL should be configured so that the total pixel rate across both readout paths equals the total pixel Relationship Between Sensor Clock Configuration and Peak Pixel Rate Figure 16: Sensor Dual Readout Paths The sensor row time calculations refers to each data-path individually. For example, the sensor default configuration uses 1248 clocks per row (line\_length\_pck) to output 2304 active pixels per row. The aggregate clocks per row seen by the receiver will be 2496 clocks (1248 x 2 readout paths). #### **Parallel PLL Configuration** #### Figure 17: PLL for the Parallel Interface The parallel interface has a maximum output data-rate of 98MPixel/s. The maximum output of the parallel interface is 98 Mpixel/s (CLK\_OP). This will limit the readout clock (CLK\_PIX) to 49 Mpixel/s. The sensor will not use the $F_{SERIAL}$ , $F_{SERIAL}$ , or CLK\_OP when configured to use the parallel interface. Table 16: PLL Parameters for the Parallel Interface | Parameter | Symbol | Min | Max | Unit | |----------------|------------------|-----|-----|----------| | External Clock | EXTCLK | 6 | 27 | MHz | | VCO Clock | F <sub>VCO</sub> | 384 | 768 | MHz | | Readout Clock | CLK_PIX | | 49 | Mpixel/s | | Output Clock | CLK_OP | | 98 | Mpixel/s | Table 17: Example PLL Configuration for the Parallel Interface | Parameter | Value | Output | |-------------------|-------|------------------------------| | F <sub>VCO</sub> | | 588 MHz (Max) | | vt_sys_clk_div | 1 | | | vt_pix_clk_div | 6 | | | CLK_PIX | | 49 Mpixel/s (= 588 MHz / 12) | | CLK_OP | | 98 Mpixel/s (= 588 MHz / 6) | | Output pixel rate | | 98 MPixel/s | # **Serial PLL Configuration** Figure 18: PLL for the Serial Interface The sensor will use op\_sys\_clk\_div and op\_pix\_clk\_div to configure the output clock per lane (CLK\_OP). The configuration will depend on the number of active lanes (1 or 2) configured. To configure the sensor protocol and number of lanes, refer to "Serial Configuration" on page 29. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sensor PLL Table 18: PLL Parameters for the Serial Interface | Parameter | Symbol | Min | Max | Unit | |------------------------------------|-------------------------|------------|------------|----------| | External Clock | EXTCLK | 6 | 27 | MHz | | VCO Clock | F <sub>VCO</sub> | 384 | 768 | MHz | | Readout Clock | CLK_PIX | | 98 | Mpixel/s | | Output Clock | CLK_OP | | 98 | Mpixel/s | | Output Serial Data Rate Per Lane | F <sub>SERIAL</sub> | 384 (MIPI) | 768 (MIPI) | Mbps | | Output Serial Clock Speed Per Lane | F <sub>SERIAL_CLK</sub> | 192 (MIPI) | 384 (MIPI) | MHz | The serial output should be configured so that it adheres to the following rules: - The maximum data-rate per lane (F<sub>SERIAL</sub>) is 768 Mbps/lane (MIPI). - The output pixel rate per lane (CLK\_OP) should be configured so that the sensor output pixel rate matches the peak pixel rate (2 x CLK\_PIX). - 2-lane: 2 x CLK\_OP = 2 x CLK\_PIX = Pixel Rate (max: 98 Mpixel/s) - 1-lane: 1 x CLK\_OP = 2 x CLK\_PIX = Pixel Rate (max: 76 Mpixel/s) Table 19: Example PLL Configurations for the Serial Interface | | 2-lane | | 1-lane | | | | |-------------------------|--------|--------|--------|--------|-------|----------| | Parameter | 12-bit | 10-bit | 12-bit | 10-bit | 8-bit | Notes | | F <sub>VCO</sub> | 588 | 490 | 768 | 768 | 768 | MHz | | vt_sys_clk_div | 2 | 2 | 4 | 4 | 4 | | | vt_pix_clk_div | 6 | 5 | 6 | 5 | 4 | | | op_sys_clk_div | 1 | 1 | 1 | 1 | 1 | | | op_pix_clk_div | 12 | 10 | 12 | 10 | 8 | | | F <sub>SERIAL</sub> | 588 | 490 | 768 | 768 | 768 | MHz | | F <sub>SERIAL CLK</sub> | 294 | 245 | 384 | 384 | 384 | MHz | | CLK_PIX | 49 | 49 | 32 | 38.4 | 48 | Mpixel/s | | CLK_OP | 49 | 49 | 64 | 76.8 | 96 | Mpixel/s | | Pixel Rate | 98 | 98 | 64 | 76.8 | 96 | Mpixel/s | AR0330CS: 1/3-Inch CMOS Digital Image Sensor Pixel Output Interfaces # **Pixel Output Interfaces** #### **Parallel Interface** The parallel pixel data interface uses these output-only signals: - FV - LV - PIXCLK - DOUT[11:0] The parallel pixel data interface is disabled by default at power up and after reset. It can be enabled by programming R0x301A. Table 20 on page 28 shows the recommended settings. When the parallel pixel data interface is in use, the serial data output signals can be left unconnected. Set reset\_register[12] to disable the serializer while in parallel output mode. #### **Configuration of the Pixel Data Interface** Fields in R0x301A are used to configure the operation of the pixel data interface. The supported combinations are shown in Table 20. Table 20: Configuration of the Pixel Data Interface | Serializer<br>Disable<br>R0x301<br>A-B[12] | Parallel<br>Enable<br>R0x301A–B[7] | Standby<br>End-of-Frame<br>R0x301A–B[4] | Description | |--------------------------------------------|------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | 1 | Power up default. Serial pixel data interface and its clocks are enabled. Transitions to soft standby are synchronized to the end of frames on the serial pixel data interface. | | 1 | 1 | 0 | Parallel pixel data interface, sensor core data output. Serial pixel data interface and its clocks disabled to save power. Transitions to soft standby are synchronized to the end of the current row readout on the parallel pixel data interface. | | 1 | 1 | 1 | Parallel pixel data interface, sensor core data output. Serial pixel data interface and its clocks disabled to save power. Transitions to soft standby are synchronized to the end of frames in the parallel pixel data interface. | AR0330CS: 1/3-Inch CMOS Digital Image Sensor Pixel Output Interfaces #### **MIPI Interface** The serial pixel data interface uses the following output-only signal pairs: - DATA1\_P - DATA1 N - DATA2\_P - DATA2\_N - CLK\_P - CLK N The signal pairs use both single-ended and differential signaling, in accordance with the the MIPI Alliance Specification for D-PHY v1.00.00. The serial pixel data interface is enabled by default at power up and after reset. The DATA0\_P, DATA0\_N, DATA1\_P, DATA1\_N, CLK\_P and CLK\_N pads are set to the Ultra Low Power State (ULPS) if the serial disable bit is asserted (R0x301A-B[12]=1) or when the sensor is in the hardware standby or soft standby system states. When the serial pixel data interface is used, the LINE\_VALID, FRAME\_VALID, PIXCLK and Dout[11:0] signals (if present) can be left unconnected. ## **Serial Configuration** The serial format should be configured using R0x31AC. This register should be programmed to 0x0C0C when using the parallel interface. The R0x0112-3 register can be programmed to any of the following data format settings that are supported: - 0x0C0C Sensor supports RAW12 uncompressed data format - 0x0C0A The sensor supports RAW12 compressed format (10-bit words) using 12-10 bit A-LAW Compression. See "Compression" on page 47. - 0x0A0A Sensor supports RAW10 uncompressed data format. This mode is supported by discarding all but the upper 10 bits of a pixel value. - 0x0808 Sensor supports RAW8 uncompressed data format. This mode is supported by discarding all but the upper 8 bits of a pixel value (MIPI only). The serial\_format register (R0x31AE) register controls which serial interface is in use when the serial interface is enabled (reset\_register[12] = 0). The following serial formats are supported: - 0x0201 Sensor supports single-lane MIPI operation - 0x0202 Sensor supports dual-lane MIPI operation The MIPI timing registers must be configured differently for 10-bit or 12-bit modes. These modes should be configured when the sensor streaming is disabled. See Table 21 on page 30 | Table 21: Recommended MIPI Timing Configuration | able 21: | Recommended MIPI Timing Configurati | ion | |-------------------------------------------------|----------|-------------------------------------|-----| |-------------------------------------------------|----------|-------------------------------------|-----| | | Confi | | | |----------|----------------------|----------------------|--------------------| | Register | 10-bit, 490Mbps/lane | 12-bit, 588Mbps/lane | | | | Clocking: | Continuous | Description | | 0x31B0 | 40 | 36 | Frame Preamble | | 0x31B2 | 14 | 12 | Line Preamble | | 0x31B4 | 0x2743 | 0x2643 | MIPI Timing 0 | | 0x31B6 | 0x114E | 0x114E | MIPI Timing 1 | | 0x31B8 | 0x2049 | 0x2048 | MIPI Timing 2 | | 0x31BA | 0x0186 | 0x0186 | MIPI Timing 3 | | 0x31BC | 0x8005 | 0x8005 | MIPI Timing 4 | | 0x31BE | 0x2003 | 0x2003 | MIPI Config Status | # **Pixel Sensitivity** Figure 19: Integration Control in ERS Readout A pixel's integration time is defined by the number of clock periods between a row's reset and read operation. Both the read followed by the reset operations occur within a row period $(T_{ROW})$ where the read and reset may be applied to different rows. The read and reset operations will be applied to the rows of the pixel array in a consecutive order. The integration time in an ERS frame is defined as: $$T_{INTEGRATION} = T_{COARSE} - T_{FINE}$$ (EQ 13) The coarse integration time is defined by the number of row periods ( $T_{ROW}$ ) between a row's reset and the row read. The row period is the defined as the time between row read operations (see Sensor Frame Rate). $$T_{COARSE} = T_{ROW} * coarse\_integration\_time$$ (EQ 14) Figure 20: Example of 8.33ms Integration in 16.6ms Frame The fine integration is then defined by the number of pixel clock periods between the row reset and row read operation within $T_{ROW}$ . This period is defined by the $fine\_integration\_time$ register. Figure 21: Row Read and Row Reset Showing Fine Integration The maximum allowed value for fine\_integration\_time is *line\_length\_pck - 1204*. Aptina recommends that the fine\_integration\_time in the AR0330CS be left at zero. Figure 22: The Row Integration Time is Greater Than the Frame Readout Time The minimum frame-time is defined by the number of row periods per frame and the row period. The sensor frame-time will increase if the *coarse\_integration\_time* is set to a value equal to or greater than the *frame\_length\_lines*. The maximum integration time can be limited to the frame time by setting R0x30CE[5] to 1. # **Gain Stages** The analog gain stages of the AR0330CS sensor are shown in Figure 23. The sensor analog gain stage consists of column amplifiers and a variable ADC reference. The sensor will apply the same analog gain to each color channel. Digital gain can be configured to separate levels for each color channel. Figure 23: Gain Stages in AR0330CS Sensor The level of analog gain applied is controlled by the coarse\_gain and fine\_gain registers. The analog readout can be configured differently for each gain level. The recommended gain tables are listed in Table 22. It is recommended that these registers are configured before streaming images. Table 22: Recommended Sensor Analog Gain Tables | COARSE_GAIN | | FINE_GAIN | | Total Gain | | COARSE_GAIN | | FINE_GAIN | | Total Gain | | |--------------|-------------|--------------|-------------|------------|------|--------------|-------------|-----------|-------------|------------|-------| | Reg<br>Value | Gain<br>(x) | Reg<br>Value | Gain<br>(x) | (x) | (dB) | Reg<br>Value | Gain<br>(x) | Reg Value | Gain<br>(x) | (x) | (dB) | | 0 | 1 | 0 | 1.00 | 1.00 | 0.00 | 0 | 1x | 15 | 1.88 | 1.88 | 5.49 | | 0 | 1 | 1 | 1.03 | 1.03 | 0.26 | 1 | 2x | 0 | 1.00 | 2.00 | 6.00 | | 0 | 1 | 2 | 1.07 | 1.07 | 0.56 | 1 | 2x | 2 | 1.07 | 2.13 | 6.58 | | 0 | 1 | 3 | 1.10 | 1.10 | 0.86 | 1 | 2x | 4 | 1.14 | 2.29 | 7.18 | | 0 | 1 | 4 | 1.14 | 1.14 | 1.16 | 1 | 2x | 6 | 1.23 | 2.46 | 7.82 | | 0 | 1 | 5 | 1.19 | 1.19 | 1.46 | 1 | 2x | 8 | 1.33 | 2.67 | 8.52 | | 0 | 1 | 6 | 1.23 | 1.23 | 1.80 | 1 | 2x | 10 | 1.45 | 2.91 | 9.28 | | 0 | 1 | 7 | 1.28 | 1.28 | 2.14 | 1 | 2x | 12 | 1.60 | 3.20 | 10.10 | | 0 | 1 | 8 | 1.33 | 1.33 | 2.50 | 1 | 2x | 14 | 1.78 | 3.56 | 11.02 | | 0 | 1 | 9 | 1.39 | 1.39 | 2.87 | 2 | 4x | 0 | 1.00 | 4.00 | 12.00 | | 0 | 1 | 10 | 1.45 | 1.45 | 3.25 | 2 | 4x | 4 | 1.14 | 4.57 | 13.20 | | 0 | 1 | 11 | 1.52 | 1.52 | 3.66 | 2 | 4x | 8 | 1.33 | 5.33 | 14.54 | | 0 | 1 | 12 | 1.60 | 1.60 | 4.08 | 2 | 4x | 12 | 1.60 | 6.40 | 16.12 | | 0 | 1 | 13 | 1.68 | 1.68 | 4.53 | 3 | 8x | 0 | 1.00 | 8.00 | 18.00 | | 0 | 1 | 14 | 1.78 | 1.78 | 5.00 | | - | | | - | | #### AR0330CS: 1/3-Inch CMOS Digital Image Sensor Data Pedestal Each digital gain can be configured from a gain of 0 to 15.992. The digital gain supports 128 gain steps per 6dB of gain. The format of each digital gain register is "xxxx.yyyyyy" where "xxxx" refers an integer gain of 1 to 15 and "yyyyyyy" is a fractional gain ranging from 0/128 to 127/128. The sensor includes a digital dithering feature to reduce quantization resulting from using digital gain can be implemented by setting R0x30BA[5] to 1. The default value is 0. Refer to "Real-Time Context Switching" on page 47 for the analog and digital gain registers in both context A and context B modes. Refer to "Real-Time Context Switching" on page 45 for the analog and digital gain registers in both context A and context B modes. #### **Data Pedestal** The data pedestal is a constant offset that is added to pixel values at the end of datapath. The default offset is 168 and is a 12-bit offset. This offset matches the maximum range used by the corrections in the digital readout path. The data pedestal value can be changed if the lock register bit (R0x301A[3]) is set to "0". This bit is set to "1" by default. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sensor Readout #### **Sensor Readout** ## **Image Acquisition Modes** The AR0330CS supports two image acquisition modes: #### 1. Electronic rolling shutter (ERS) mode This is the normal mode of operation. When the AR0330CS is streaming; it generates frames at a fixed rate, and each frame is integrated (exposed) using the ERS. When the ERS is in use, timing and control logic within the sensor sequences through the rows of the array, resetting and then reading each row in turn. In the time interval between resetting a row and subsequently reading that row, the pixels in the row integrate incident light. The integration (exposure) time is controlled by varying the time between row reset and row readout. For each row in a frame, the time between row reset and row readout is the same, leading to a uniform integration time across the frame. When the integration time is changed (by using the two-wire serial interface to change register settings), the timing and control logic controls the transition from old to new integration time in such a way that the stream of output frames from the AR0330CS switches cleanly from the old integration time to the new while only generating frames with uniform integration. See "Changes to Integration Time" in the AR0330CS Register Reference. #### 2. Global reset mode This mode can be used to acquire a single image at the current resolution. In this mode, the end point of the pixel integration time is controlled by an external electromechanical shutter, and the AR0330CS provides control signals to interface to that shutter. The benefit of using an external electromechanical shutter is that it eliminates the visual artifacts associated with ERS operation. Visual artifacts arise in ERS operation, particularly at low frame rates, because an ERS image effectively integrates each row of the pixel array at a different point in time. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sensor Readout #### **Window Control** The sequencing of the pixel array is controlled by the x\_addr\_start, y\_addr\_start, x\_addr\_end, and y\_addr\_end registers. The x\_addr\_start equal to 6 is the minimum setting value. The y\_addr\_start equal to 6 is the minimum setting value. Please refer to Table 23 and Table 24 for details. Table 23: Pixel Column Configuration | | Column Address | Number | Туре | Notes | |---|----------------|--------|--------|----------------| | Ī | 0–5 | 6 | Active | Border columns | | Ī | 6–2309 | 2304 | Active | Active columns | | | 2310–2315 | 6 | Active | Border columns | **Table 24:** Pixel Row Configuration | Row Address | Number | Туре | Notes | |-------------|--------|--------|------------------------------------| | 2–5 | 4 | Active | Not used in case of "edge effects" | | 6–1549 | 1544 | Active | Active rows | | 1550–1555 | 6 | Active | Not used in case of "edge effects" | #### **Readout Modes** #### **Horizontal Mirror** When the horizontal\_mirror bit (R0x3040[14]) is set in the image\_orientation register, the order of pixel readout within a row is reversed, so that readout starts from x\_addr\_end + 1 and ends at x\_addr\_start. Figure 24 on page 36 shows a sequence of 6 pixels being read out with R0x3040[14] = 0 and R0x3040[14] = 1. Changing R0x3040[14] causes the Bayer order of the output image to change; the new Bayer order is reflected in the value of the pixel order register. Figure 24: Effect of Horizontal Mirror on Readout Order #### **Vertical Flip** When the vertical\_flip bit (R0x3040[15]) is set in the image\_orientation register, the order in which pixel rows are read out is reversed, so that row readout starts from y\_addr\_end and ends at y\_addr\_start. Figure 30 shows a sequence of 6 rows being read out with ## AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sensor Readout R0x3040[15] = 0 and R0x3040[15] = 1. Changing this bit causes the Bayer order of the output image to change; the new Bayer order is reflected in the value of the pixel\_order register. Figure 25: Effect of Vertical Flip on Readout Order # Subsampling The AR0330CS supports subsampling. Subsampling allows the sensor to read out a smaller set of active pixels by either skipping or binning pixels within the readout window. The working modes described in the data sheet that use subsampling are configured to use either 2x2 or 3x3 subsampling. Figure 26: Horizontal Binning in the AR0330CS Sensor Horizontal binning is achieved either in the pixel readout or the digital readout. The sensor will sample the combined 2x or 3x adjacent pixels within the same color plane. Figure 27: Vertical Row Binning in the AR0330CS Sensor Vertical row binning is applied in the pixel readout. Row binning can be configured of 2x rows within the same color plane. Pixel skipping can be configured up to 2x and 3x in both the x-direction and y-direction. Skipping pixels in the x-direction will not reduce the row time. Skipping pixels in the y-direction will reduce the number of rows from the sensor effectively reducing the frame time. Skipping will introduce image artifacts from aliasing. Table 25: Available Skip and Bin Modes in the AR0330CS Sensor | Subsampling Method | Horizontal | Vertical | |--------------------|------------|----------| | Skipping | 2x, 3x | 2x, 3x | | Binning | 2x | 2x | The sensor increments its x and y address based on the x\_odd\_inc and y\_odd\_inc value. The value indicates the addresses that are skipped after each pair of pixels or rows has been read. The sensor will increment x and y addresses in multiples of 2. This indicates that a GreenR and Red pixel pair will be read together. As well, that the sensor will read a Gr-R row first followed by a B-Gb row. x subsampling factor = $$\frac{1 + x\_odd\_inc}{2}$$ y subsampling factor = $$\frac{1 + y\_odd\_inc}{2}$$ A value of 1 is used for $x_odd_inc$ and $y_odd_inc$ when no pixel subsampling is indicated. In this case, the sensor is incrementing x and y addresses by 1+1 so that it reads consecutive pixel and row pairs. To implement a 2x skip in the x direction, the $x_odd_inc$ is set to 3 so that the x address increment is 1+3, meaning that sensor will skip every other Gr-R pair. Table 26: Configuration for Horizontal Subsampling | | x_odd_inc | Restrictions: | |----------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------| | No subsampling | x_odd_inc = 1<br>skip = (1+1)*0.5 = 1x | | | Skip 2x | x_odd_inc = 3<br>skip = (1+3)*0.5 = 2x | | | Skip 3x | x_odd_inc = 5<br>skip = (1+5)*0.5 = 3x | The horizontal FOV must be programmed to meet the following rule: | | Analog Bin 2x | x_odd_inc = 3<br>skip = (1+3)*0.5 =2x<br>col_sf_bin_en = 1 | $\frac{x \text{ addr end} - x \text{ addr start} + 1}{(x \text{ odd_inc} + 1)/2} = \text{even number}$ | | Digital Bin 2x | x_odd_inc = 3<br>skip = (1+3)*0.5 =2x<br>col_bin =1 | | | Digital Bin 3x | x_odd_inc = 5<br>skip = (1+5)*0.5 = 3x<br>col_bin = 1 | | Table 27: Configuration for Vertical Subsampling | | y_odd_inc | Restrictions: | |----------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | No subsampling | y_odd_inc = 1<br>skip = (1+1)*0.5 = 1x<br>row_bin = 0 | | | Skip 2x | y_odd_inc = 3<br>skip = (1+3)*0.5 =2x<br>row_bin = 0 | The vertical FOV must be programmed to meet the following rule: | | Skip 3x | y_odd_inc = 5<br>skip = (1+5)*0.5 =3x<br>row_bin = 0 | $\frac{y \text{ addr end} - y \text{ addr start} + 1}{(y \text{ odd}_{\text{inc}} + 1)/2} = \text{even number}$ | | Analog Bin 2x | y_odd_inc = 3<br>skip = (1+3)*0.5 =2x<br>row_bin = 1 | | AR0330CS: 1/3-Inch CMOS Digital Image Sensor Sensor Frame Rate #### **Sensor Frame Rate** The time required to read out an image frame ( $T_{FRAME}$ ) can be derived from the number of clocks required to output each image and the pixel clock. The frame-rate is the inverse of the frame period. $$fps=1/T_{FRAME}$$ (EQ 16) The number of clocks can be simplified further into the following parameters: - The number of clocks required for each sensor row (line\_length\_pck) This parameter also determines the sensor row period when referenced to the sensor readout clock. (T<sub>ROW</sub> = line\_length\_pck x 1/CLK\_PIX) - The number of row periods per frame (frame\_length\_lines) - An extra delay between frames used to achieve a specific output frame period (extra\_delay) $T_{FRAME}=1/(CLK\_PIX)\times[frame\_length\_lines\times line\_length\_pck+extra\_delay] \tag{EQ 17}$ Figure 28: Frame Period Measured in Clocks ## Row Period (T<sub>ROW</sub>) The $line\_length\_pck$ will determine the number of clock periods per row and the row period ( $T_{ROW}$ ) when combined with the sensor readout clock. The $line\_length\_pck$ includes both the active pixels and the horizontal blanking time per row. The sensor utilizes two readout paths, as seen in Figure 16 on page 25, allowing the sensor to output two pixels during each pixel clock. The minimum *line\_length\_pck* is defined as the maximum of the following three equations: #### **ADC Readout Limitation:** $$1204(ADC\_HIGH\_SPEED) = 0$$ $$or$$ $$1116(ADC\_HIGH\_SPEED) = 1(0)$$ (EQ 18) Options to modify this limit, as mentioned in the "Sequencer" section, can be found in the AR0330CS Developer Guide. #### **Digital Readout Limitation:** $$\frac{1}{3} \times \left[ \frac{x\_addr\_end - x\_addr\_start}{(x \ odd \ inc + 1) \times 0.5} \right]$$ (EQ 19) #### **Output Interface Limitations:** $$\frac{1}{2} \times \left[ \frac{x\_addr\_end - x\_addr\_start}{(x\_odd\_inc + 1) \times 0.5} \right] + 96$$ (EQ 20) #### **Row Periods Per Frame** The $frame\_length\_lines$ determines the number of row periods ( $T_{ROW}$ ) per frame. This includes both the active and blanking rows. The $minimum\_vertical\_blanking$ value is defined by the number of OB rows read per frame, two embedded data rows, and two blank rows. $$Minimum\ frame\_length\_lines = \frac{y\_addr\_end - y\_addr\_start}{(y\_odd\_inc + 1)/2} + min\_frame\_length\_lines \qquad (EQ\ 21)$$ The sensor is configured to output frame information in two embedded data rows by setting R0x3064[8] to 1 (default). If R0x3064[8] is set to 0, the sensor will instead output two blank rows. The data configured in the two embedded rows is defined in MIPI CSI-2 Specification V1.00. Table 28: Minimum Vertical Blanking Configuration | R0x3180[0x00F0] | OB Rows | min_frame_length_lines | |-----------------|-----------|------------------------| | 0x8 (Default) | 8 OB Rows | 8 OB + 4 = 12 | | 0x4 | 4 OB Rows | 4 OB + 4 = 8 | | 0x2 | 2 OB Rows | 2 OB + 4 = 6 | The locations of the OB rows, embedded rows, and blank rows within the frame readout are identified in Figure 29: "Slave Mode Active State and Vertical Blanking," on page 42. #### Slave Mode The slave mode feature of the AR0330CS supports triggering the start of a frame readout from a VD signal that is supplied from an external ASIC. The slave mode signal allows for precise control of frame rate and register change updates. The VD signal is input to the trigger pin. Both the GPI\_EN (R0x301A[8]) and the SLAVE\_MODE (R0x30CE[4]) bits must be set to "1" to enable the slave mode. Figure 29: Slave Mode Active State and Vertical Blanking If the slave mode is disabled, the new frame will begin after the extra delay period is finished. The slave mode will react to the rising edge of the input VD signal if it is in an active state. When the VD signal is received, the sensor will begin the frame readout and the slave mode will remain inactive for the period of one frame time minus 16 clock periods ( $T_{FRAME}$ - (16 / CLK\_PIX)). After this period, the slave mode will re-enter the active state and will respond to the VD signal. Figure 30: Slave Mode Example with Equal Integration and Frame Readout Periods The integration of the last row is therefore started before the end of the programmed integration for the first row. The row shutter and read operations will stop when the slave mode becomes active and is waiting for the VD signal. The following should be considered when configuring the sensor to use the slave mode: - 1. The frame period ( $T_{FRAME}$ ) should be configured to be less than the period of the input VD signal. The sensor will disregard the input VD signal if it appears before the frame readout is finished. - 2. If the sensor integration time is configured to be less than the frame period, then the sensor will not have reset all of the sensor rows before it begins waiting for the input VD signal. This error can be minimized by configuring the frame period to be as close as possible to the desired frame rate (period between VD signals). #### Figure 31: Slave Mode Example Where the Integration Period is Half of the Frame Readout Period The sensor read pointer will have paused at row 0 while the shutter pointer pauses at row N/2. The extra integration caused by the slave mode delay will only be seen by rows 0 to N/2. The example below is for a frame readout period of 16.6ms while the integration time is configured to 8.33ms. When the slave mode becomes active, the sensor will pause both row read and row reset operations. **Note:** The row integration period is defined as the period from row reset to row read. When the AR0330CS is working in slave mode, the external trigger signal VD must have accurately controlled timing to avoid uneven exposure in the output image. The VD timing control should make the slave mode "wait period" less than 32 pixel clocks. To avoid uneven exposure, programmed integration time cannot be larger than VD period. To increase integration time more than current VD period, the AR0330CS must be configured to work at a lower frame rate and read out image with new VD to match the new timing. The period between slave mode pulses must also be greater than the frame period. If the rising edge of the VD pulse arrives while the slave mode is inactive, the VD pulse will be ignored and will wait until the next VD pulse has arrived. AR0330CS: 1/3-Inch CMOS Digital Image Sensor Frame Readout ## **Frame Readout** The sensor readout begins with vertical blanking rows followed by the active rows. The frame readout period can be defined by the number of row periods within a frame (*frame\_length\_lines*) and the row period (*line\_length\_pck/cockpits*). The sensor will read the first vertical blanking row at the beginning of the frame period and the last active row Table 29: Serial SYNC Codes Included with Each Protocol Included with the AR0330CS Sensor | Interface/Protocol | Start of Vertical<br>Blanking Row (SOV) | Start of Frame<br>(SOF) | Start of Active Line<br>(SOA) | End of Line<br>(EOL) | End of Frame<br>(EOF) | | |--------------------|-----------------------------------------|-------------------------|-------------------------------|-----------------------|--------------------------|--| | Parallel | Parallel interface uses FRA | ME VALID(FV) an | d LINE VALID (LV) output | s to denote start and | d end of line and frame. | | | MIPI | No SYNC Code | Yes | Yes | Yes | Yes | | Figure illustrates how the sensor active readout time can be minimized while reducing the frame rate. ## **Changing Sensor Modes** ## **Register Changes** All register writes are delayed by 1x frame. A register that is written to during the readout of frame n will not be updated to the new value until the readout of frame n+2. This includes writes to the sensor gain and integration registers. ## **Real-Time Context Switching** In the AR0330CS, the user may switch between two full register sets A and B by writing to a context switch change bit in R0x30B0[13]. When the context switch is configured to context A the sensor will reference the "Context A Registers". If the context switch is changed from A to B during the readout of frame n, the sensor will then reference the context B $coarse\_integration\_time$ registers in frame n+1 and all other context B registers at the beginning of reading frame n+2. The sensor will show the same behavior when changing from context B to context A. Table 30: List of Configurable Registers for Context A and Context B | Contex | t A | Context B | | | | | | |-------------------------|-------------|----------------------------|---------------|--|--|--|--| | Register Description | Address | Register Description | Address | | | | | | Coarse_integration_time | 0x3012 | Coarse_integration_time_CB | 0x3016 | | | | | | Fine_integration_time | 0x3014 | Fine_integration_time_CB | 0x3018 | | | | | | Line_length_pck | 0x300C | Line_length_pck_CB | 0x303E | | | | | | Frame_length_lines | 0x300A | Frame_length_lines_CB | 0x30AA | | | | | | COL_SF_BIN_EN | 0x3040[9] | COL_SF_BIN_EN_CB | 0x3040[8] | | | | | | ROW_BIN | 0x3040[12] | ROW_BIN_CB | 0x3040[10] | | | | | | COL_BIN | 0x3040[13] | COL_BIN_CB | 0x3040[11] | | | | | | FINE_GAIN | 0x3060[3:0] | FINE_GAIN_CB | 0x3060[11:8] | | | | | | COARSE_GAIN | 0x3060[5:4] | COARSE_GAIN_CB | 0x3060[13:12] | | | | | | x_addr_start | 0x3004 | x_addr_start_CB | 0x308A | | | | | | y_addr_start | 0x3002 | y_addr_start_CB | 0x308C | | | | | | x_addr_end | 0x3008 | x_addr_end_CB | 0x308E | | | | | | y_addr_end | 0x3006 | y_addr_end_CB | 0x3090 | | | | | Table 30: List of Configurable Registers for Context A and Context B (continued) | Con | text A | | Context B | | | | | | |----------------------|-----------|----------------------|-----------|--|--|--|--|--| | Register Description | Address | Register Description | Address | | | | | | | Y_odd_inc | 0x30A6 | Y_odd_inc_CB | 0x30A8 | | | | | | | X_odd_inc | 0x30A2 | X_odd_inc_CB | 0x30AE | | | | | | | ADC_HIGH_SPEED | 0x30BA[6] | ADC_HIGH_SPEED_CB | 0x30BA[7] | | | | | | | GREEN1_GAIN | 0x3056 | GREEN1_GAIN_CB | 0x30BC | | | | | | | BLUE_GAIN | 0x3058 | BLUE_GAIN_CB | 0x30BE | | | | | | | RED_GAIN | 0x305A | RED_GAIN_CB | 0x30C0 | | | | | | | GREEN2_GAIN | 0x305C | GREEN2_GAIN_CB | 0x30C2 | | | | | | | GLOBAL_GAIN | 0x305E | GLOBAL_GAIN_CB | 0x30C4 | | | | | | Note: Aptina recommends leaving fine\_integration\_time at 0. Figure 32: Example of Changing the Sensor from Context A to Context B AR0330CS: 1/3-Inch CMOS Digital Image Sensor Compression ## Compression The sensor can optionally compress 12-bit data to 10-bit using A-law compression. The compression is applied after the data pedestal has been added to the data. See Figure 1: "Block Diagram," on page 6. The A-law compression is disabled by default and can be enabled by setting R0x31D0 from "0" to "1". Table 31: A-Law Compression Table for 12-10 bits | | | Input Values | | | | | | | | | C | omp | ress | ed C | odew | ord | | | | | | | |--------------|----|--------------|---|---|---|---|---|---|---|---|---|-----|------|------|------|-----|---|---|---|---|---|---| | Input Range | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0 to 127 | 0 | 0 | 0 | 0 | 0 | a | b | С | d | е | f | g | 0 | 0 | 0 | а | b | С | d | е | f | g | | 128 to 255 | 0 | 0 | 0 | 0 | 1 | a | b | С | d | е | f | g | 0 | 0 | 1 | а | b | С | d | e | f | g | | 256 to 511 | 0 | 0 | 0 | 1 | a | b | С | d | е | f | g | Χ | 0 | 1 | 0 | а | b | С | d | e | f | g | | 512 to 1023 | 0 | 0 | 1 | a | b | С | d | е | f | g | Х | Х | 0 | 1 | 1 | а | b | С | d | e | f | g | | 1024 to 2047 | 0 | 1 | a | b | С | d | е | f | g | h | Χ | Х | 1 | 0 | a | b | С | d | е | f | g | h | | 2048 to 4095 | 1 | a | b | С | d | e | f | g | h | Х | Χ | Χ | 1 | 1 | а | b | С | d | e | f | g | h | ## **Test Patterns** The AR0330CS has the capability of injecting a number of test patterns into the top of the datapath to debug the digital logic. With one of the test patterns activated, any of the datapath functions can be enabled to exercise it in a deterministic fashion. Test patterns are selected by Test\_Pattern\_Mode register (R0x3070). Only one of the test patterns can be enabled at a given point in time by setting the Test\_Pattern\_Mode register according to Table 32. When test patterns are enabled the active area will receive the value specified by the selected test pattern and the dark pixels will receive the value in Test\_Pattern\_Green (R0x3074 and R0x3078) for green pixels, Test\_Pattern\_Blue (R0x3076) for blue pixels, and Test\_Pattern\_Red (R0x3072) for red pixels. **Table 32:** Test Pattern Modes | Test_Pattern_Mode | Test Pattern Output | |-------------------|------------------------------------| | 0 | No test pattern (normal operation) | | 1 | Solid Color | | 2 | 100% Vertical Color Bars | | 3 | Fade-to-Gray Vertical Color Bars | | 256 | Walking 1s test pattern (12-bit) | #### **Solid Color** When the color field mode is selected, the value for each pixel is determined by its color. Green pixels will receive the value in Test\_Pattern\_Green, red pixels will receive the value in Test\_Pattern\_Red, and blue pixels will receive the value in Test\_Pattern\_Blue. #### **Vertical Color Bars** When the vertical color bars mode is selected, a typical color bar pattern will be sent through the digital pipeline. ## Walking 1s When the walking 1s mode is selected, a walking 1s pattern will be sent through the digital pipeline. The first value in each row is 1. ## **Two-Wire Serial Register Interface** The two-wire serial interface bus enables read/write access to control and status registers within the AR0330CS. This interface is designed to be compatible with the electrical characteristics and transfer protocols of the I<sup>2</sup>C specification. The interface protocol uses a master/slave model in which a master controls one or more slave devices. The sensor acts as a slave device. The master generates a clock (SCLK) that is an input to the sensor and is used to synchronize transfers. Data is transferred between the master and the slave on a bidirectional signal (SDATA). SDATA is pulled up to VDD\_IO off-chip by a $1.5 \mathrm{k}\Omega$ resistor. Either the slave or master device can drive SDATA LOW—the interface protocol determines which device is allowed to drive SDATA at any given time. The protocols described in the two-wire serial interface specification allow the slave device to drive SCLK LOW; the AR0330CS uses SCLK as an input only and therefore never drives it LOW. #### **Protocol** Data transfers on the two-wire serial interface bus are performed by a sequence of low-level protocol elements: - 1. a (repeated) start condition - 2. a slave address/data direction byte - 3. an (a no-) acknowledge bit - 4. a message byte - 5. a stop condition The bus is idle when both SCLK and SDATA are HIGH. Control of the bus is initiated with a start condition, and the bus is released with a stop condition. Only the master can generate the start and stop conditions. #### **Start Condition** A start condition is defined as a HIGH-to-LOW transition on SDATA while SCLK is HIGH. At the end of a transfer, the master can generate a start condition without previously generating a stop condition; this is known as a "repeated start" or "restart" condition. ## **Stop Condition** A stop condition is defined as a LOW-to-HIGH transition on SDATA while SCLK is HIGH. #### **Data Transfer** Data is transferred serially, 8 bits at a time, with the MSB transmitted first. Each byte of data is followed by an acknowledge bit or a no-acknowledge bit. This data transfer mechanism is used for both the slave address/data direction byte and for message bytes. One data bit is transferred during each SCLK clock period. SDATA can change when SCLK is LOW and must be stable while SCLK is HIGH. ### **Aptina Confidential and Proprietary** AR0330CS: 1/3-Inch CMOS Digital Image Sensor Two-Wire Serial Register Interface #### Slave Address/Data Direction Byte Bits [7:1] of this byte represent the device slave address and bit [0] indicates the data transfer direction. A "0" in bit [0] indicates a WRITE, and a "1" indicates a READ. The default slave addresses used by the AR0330CS sensor are 0x20 (write address) and 0x21 (read address). Alternate slave addresses of 0x30 (WRITE address) and 0x31 (READ address) can be selected by asserting the SADDR signal (tie HIGH). Alternate slave addresses can also be programmed through R0x31FC. #### Message Byte Message bytes are used for sending register addresses and register write data to the slave device and for retrieving register read data. #### **Acknowledge Bit** Each 8-bit data transfer is followed by an acknowledge bit or a no-acknowledge bit in the SCLK clock period following the data transfer. The transmitter (which is the master when writing, or the slave when reading) releases SDATA. The receiver indicates an acknowledge bit by driving SDATA LOW. As for data transfers, SDATA can change when SCLK is LOW and must be stable while SCLK is HIGH. #### No-Acknowledge Bit The no-acknowledge bit is generated when the receiver does not drive SDATA LOW during the SCLK clock period following a data transfer. A no-acknowledge bit is used to terminate a read sequence. ## **Typical Sequence** A typical READ or WRITE sequence begins by the master generating a start condition on the bus. After the start condition, the master sends the 8-bit slave address/data direction byte. The last bit indicates whether the request is for a read or a write, where a "0" indicates a write and a "1" indicates a read. If the address matches the address of the slave device, the slave device acknowledges receipt of the address by generating an acknowledge bit on the bus. If the request was a WRITE, the master then transfers the 16-bit register address to which the WRITE should take place. This transfer takes place as two 8-bit sequences and the slave sends an acknowledge bit after each sequence to indicate that the byte has been received. The master then transfers the data as an 8-bit sequence; the slave sends an acknowledge bit at the end of the sequence. The master stops writing by generating a (re)start or stop condition. If the request was a READ, the master sends the 8-bit write slave address/data direction byte and 16-bit register address, the same way as with a WRITE request. The master then generates a (re)start condition and the 8-bit read slave address/data direction byte, and clocks out the register data, eight bits at a time. The master generates an acknowledge bit after each 8-bit transfer. The slave's internal register address is automatically incremented after every 8 bits are transferred. The data transfer is stopped when the master sends a no-acknowledge bit. ## **Single READ From Random Location** This sequence (Figure 33) starts with a dummy WRITE to the 16-bit address that is to be used for the READ. The master terminates the WRITE by generating a restart condition. The master then sends the 8-bit read slave address/data direction byte and clocks out one byte of register data. The master terminates the READ by generating a no-acknowledge bit followed by a stop condition. Figure 33 shows how the internal register address maintained by the AR0330CS is loaded and incremented as the sequence proceeds. Figure 33: Single READ From Random Location ## **Single READ From Current Location** This sequence (Figure 34) performs a read using the current value of the AR0330CS internal register address. The master terminates the READ by generating a no-acknowledge bit followed by a stop condition. The figure shows two independent READ sequences. Figure 34: Single READ From Current Location ## **Sequential READ, Start From Random Location** This sequence (Figure 35) starts in the same way as the single READ from random location (Figure 33). Instead of generating a no-acknowledge bit after the first byte of data has been transferred, the master generates an acknowledge bit and continues to perform byte READs until "L" bytes have been read. Figure 35: Sequential READ, Start From Random Location ## **Sequential READ, Start From Current Location** This sequence (Figure 36) starts in the same way as the single READ from current location (Figure 34 on page 50). Instead of generating a no-acknowledge bit after the first byte of data has been transferred, the master generates an acknowledge bit and continues to perform byte READs until "L" bytes have been read. Figure 36: Sequential READ, Start From Current Location ## **Single WRITE to Random Location** This sequence (Figure 37) begins with the master generating a start condition. The slave address/data direction byte signals a WRITE and is followed by the HIGH then LOW bytes of the register address that is to be written. The master follows this with the byte of write data. The WRITE is terminated by the master generating a stop condition. Figure 37: Single WRITE to Random Location ## **Sequential WRITE, Start at Random Location** This sequence (Figure 38) starts in the same way as the single WRITE to random location (Figure 37 on page 51). Instead of generating a stop condition after the first byte of data has been transferred, the master continues to perform byte WRITEs until 'L' bytes have been written. The WRITE is terminated by the master generating a stop condition. Figure 38: Sequential WRITE, Start at Random Location # **Spectral Characteristics** Figure 39: Bare Die Quantum Efficiency AR0330CS: 1/3-Inch CMOS Digital Image Sensor **Spectral Characteristics** Table 33: Chief Ray Angle (CRA) 12° Note: The CRA listed in the advanced datasheet described the 2048x1536 field of view (2.908mm image height). This information was sufficient for configuring the sensor to read both the 4:3 (2048x1536) and 16:9 (2304x1296) aspect ratios. The CRA information listed in the datasheet has now been updated to represent the entire pixel array (2304x1536). # **CSP Packages** Figure 40: CSP Parallel/MIPI Package AR0330CS: 1/3-Inch CMOS Digital Image Sensor Package Orientation in Camera Design # **Package Orientation in Camera Design** In a camera design, the package should be placed in a PCB so that the first clear pixel is located at the bottom left of the package (look at the package). This orientation will ensure that the image captured using a lens will be oriented correctly. Figure 41: Image Orientation With Relation To Camera Lens The package pin locations after the sensor has been oriented correctly can be shown below. Figure 42: First Clear Pixel and Pin Location (Looking Down on Cover Glass) ## **Aptina Confidential and Proprietary** AR0330CS: 1/3-Inch CMOS Digital Image Sensor Revision History # **Revision History** | Rev. C | | |--------|---------------------------------------------------------------------------------------| | | • Updated Table 1, "Available Part Numbers," on page 1 | | | Updated Figure 2: "Typical Configuration: Serial MIPI," on page 8 | | | • Updated Figure 3: "Typical Configuration: Parallel Pixel Data Interface," on page 9 | | | • Updated note for Figure 4: "Power Up," on page 12 | | | • Updated Table 5, "CSP Package Pinout," on page 10 | | | • Updated Table 14, "I/O Timing," on page 18 | | | Updated first paragraph on page 34 | | | • Updated "Slave Address/Data Direction Byte" on page 49 | | | • Updated Figure 40: "CSP Parallel/MIPI Package," on page 55 | | | • Updated Figure 41: "Image Orientation With Relation To Camera Lens," on page 56 | | | • Deleted Table 34. | | Rev. B | 9/6/12 | | | <ul> <li>Added Table 5, "CSP Package Pinout," on page 10</li> </ul> | | | • Updated Figure 40: "CSP Parallel/MIPI Package," on page 55 | | Rev. A | | | | Initial release | 10 Eunos Road 8 13-40, Singapore Post Center, Singapore 408600 prodmktg@aptina.com www.aptina.com Aptina, Aptina Imaging, HiSPi, A-Pix, and the Aptina logo are the property of Aptina Imaging Corporation All other trademarks are the property of their respective owners.