4Kp60 Multi-Sensor HDR Camera Solution System Example Design for Agilex™ 5 Devices - ISP Functional Description¶
The 4Kp60 Multi-Sensor HDR Camera Solution System Example Design demonstrates a practical glass-to-glass camera solution using standard Altera® Connectivity and Video and Vision Processing (VVP) Suite IP Cores available through the Quartus® Prime Design Software (QPDS).
The design ingests the video input through industry-standard MIPI directly connected to each sensor. The selected sensor video is then processed through the Image Signal Processing (ISP) pipeline before output through DisplayPort (DP). The pipeline also utilizes additional non-ISP IP Cores from the VVP Suite, such as Test Pattern Generators (TPG) and VVP AXI4-S Switches. Furthermore, the design runs an embedded Linux Software Application (SW App) on the Hard Processor System (HPS) to provide real-time auto white balance (AWB) and auto exposure (AE) functions.
The following block diagram shows the main components and subsystems of the 4Kp60 Multi-Sensor HDR Camera Solution System Example Design. Note that where an IP has been used multiple times, its instance number is shown (bottom right corner of the IP) and can be used for identification in the detail that follows.
4Kp60 Multi-Sensor HDR Camera Solution System Example Design Top Block Diagram
The Framos FSM:GO IMX678 optical sensor module with PixelMate MIPI-CSI-2 connection uses a 4-lane MIPI interface. The sensor is a Sony Starvis2 8MP IMX678 that outputs a Color Filter Array (CFA) image (also known as a Bayer image) and can support up to a UHD 4K resolution at 60 FPS.
A CFA is typically a 2x2 mosaic of tiny colored filters (usually red, green, and blue) placed over a monochromatic image sensor to effectively capture single color pixels. The CFA typically contains twice the number of green filters to align with human vision which is more sensitive to light in the yellow-green part of the spectrum. The example below shows a typical RGGB (Red, Green, Green, Blue) CFA pattern which repeats over the entire image (an 8x8 image in this example). Pixels arrive left to right, top to bottom, as alternating Red and Green pixels on the first line, and then alternating Green and Blue pixels on the next line. This pattern repeats on the next pair of lines, and so on.
8x8 RGGB Color Filter Array (Bayer) Image Example
Using a single color pixels reduces the overall bandwidth requirements of the sensor. A demosaic algorithm can be used to rebuild the full color image. Note that in the CFA domain, 4 color channels actually exist (Red, Green1, Green2, and Blue - using our example from above). Therefore, any given pixel belongs to one of these color channels when processing.
The sensor also contains a Clear HDR feature that when enabled allows the sensor to capture two images simultaneously, one with a low gain level set to the bright region and the other with a high gain level set to the dark region. Post sensor processing can be used to combine the two images to produce a 16-bit HDR image. Since images are captured simultaneously, there are no motion chromatic aberrations or other artifacts. However, this mode reduces the frame rate to 25 FPS.
The Altera® MIPI D-PHY IP interfaces the FPGA directly to 2 Framos optical sensor modules via Framos connectors on the Modular Development board and PixelMate CSI-2 Flex-Cables. The design showcases a 3840x2160 sensor resolution up to 60 FPS using 12-bit Bayer pixel samples using MIPI lane rates of 1782 Mbps to provide sufficient bandwidth. The MIPI D-PHY is configured for 2 links (one per sensor) of x4 lanes at 1782 Mbps with no skew calibration and non-continuous clock mode. Each sensor module has additional pins, including Power on Reset, Master/Slave mode, as well as sync signals and a slave I2C interface for control and status. The MAX10 device on the Modular Development board drives some of these signals which can be controlled via the FPGA using another, separate I2C interface. All the I2C interfaces are connected via HPS I2C controllers. The SW App auto-detects and sets up all detected cameras for 1782 Mbps lane speed, 3840x2160 resolution, RAW12 pixel samples, no skew calibration, and blanking for 60 FPS.
The design connects an Altera® MIPI CSI-2 IP to each of the MIPI D-PHY IP Rx links from each optical sensor module using a 4-lane 16-bit PHY Protocol Interface (PPI) bus. The bus effectively runs at 93.312 MHz (calculated as 3840x2160x60FPSx12b/(4x16b)). The design configures each CSI-2 IP output at 4 PIP (Pixels In Parallel) using a 297MHz clock. A VVP Protocol Converter IP converts each CSI-2 IP VVP AXI4-S protocol from Full to Lite.
In Clear HDR configuration, the two simultaneous captured sensor images are sent over the single MIPI interface and output as 2 separate image streams by the MIPI CSI-2 IP. The non-QPDS Exposure Fusion IP (supplied with the source project) accepts both image streams and provides preliminary support to combine them into a single HDR image stream. By default, the example design does not enable Clear HDR and the IP operates in bypass. Regardless of the mode of operation, the output is always 16-bits, MSB aligned.
To reduce FPGA resources, a VVP PIP Converter IP follows to reduce the PIP from 4 to 2. The PIP Converter contains 2 lines of video buffer for accommodating back-pressuring from downstream IPs.
Descriptions of the IPs¶
This section summarizes notable IPs instanced in the 4Kp60 Multi-Sensor HDR Camera Solution System Example Design:
- Input Test Pattern Generator
- Black Level Statistics
- Clipper
- Defective Pixel Correction
- Adaptive Noise Reduction
- Black Level Correction
- Vignette Correction
- White Balance Statistics
- White Balance Correction
- Demosaic
- Histogram Statistics
- Color Correction Matrix
- 1D LUT
- 3D LUT
- Tone Mapping Operator
- Unsharp Mask Filter
- Warp
- Logo Overlay
- Frame Writer
Input Test Pattern Generator¶
The Input TPG IP (Instance 0) allows you to test the design without a sensor module input. It uses the VVP Test Pattern Generator IP and a non-QPDS IP called Remosaic (RMS) (supplied with the source project). The TPG has an RGB output which cannot be processed by the ISP as it supports a CFA image. The RMS is used to convert the RGB image into a CFA image by discarding color information for pixels based on the CFA pattern supported by the sensor. The TPG features several modes, including SMPTE color bars and solid colors. The Bayer Switch - VVP Switch IP (Instance 1), is used to select the Input source.
Related Information
Black Level Statistics¶
Black Level Statistics Block Diagram
The Black Level Statistics (BLS) IP accumulates pixel values in a Region of Interest (ROI), which is usually associated with a shielded area of an imaging sensor called an Optical Black Region (OBR). The SW App, using these statistics, may choose to keep the sensor's black-level value constant and compensate for any deviations caused by various external factors like temperature changes, voltage drifts, or aging.
The BLS calculates statistics across an OBR of the 2x2 CFA input from the sensor. The IP has dedicated accumulators for each CFA channel that calculates 4 independent pixel sums. The SW App uses the BLS IP to set the offset and scalar coefficients of the Black Level Correction (BLC) IP. The BLS passes the input image to its output unchanged.
Note that although the hardware design includes BLS IP as part of the video pipeline, the SW App does not configure the imaging sensor and the MIPI connectivity IPs to pass the OBR for processing the statistics real time. The SW App reads these statistics as part of a hidden and unsupported offline calibration flow.
Related Information
Clipper¶
The Clipper IP crops an active area from an input image and discards the remainder. The SW App may choose to use this IP to discard unwanted regions of the video like OBR from the sensor input or perform digital zoom. Currently, the SW App configures the sensor to output 4K video at the input, therefore it configures the Clipper IP to bypass the input image.
Related Information
Defective Pixel Correction¶
The Defective Pixel Correction (DPC) IP removes impulse noise associated with defective pixels in the sensor image. Such impulse noise is usually the result of defective pixel circuitry within image sensor for a given pixel, and it manifests itself in those pixels to respond to light drastically differently compared to their neighboring pixels. The DPC IP operates on 2x2 Bayer CFA images, identifying defective pixels using a configurable non-linear filter, and then corrects them.
Defective Pixel Correction Block Diagram
The DPC IP works on a 5x5 pixel neighborhood. The IP gathers the 9 pixels of the same color channel closest to the current pixel (the center pixel in the neighborhood) and sorts them according to their pixel values. A non-linear filter calculates a corrected pixel value from the sorted group of pixels depending on the sensitivity setting.
A Bayer CFA for a 6x6 section of an image and an example pixel neighborhood for green, red, and blue pixels
The DPC IP dynamically identifies and filters defect pixels and does not support static defective pixel correction of predetermined pixels. When you set the sensitivity level to the weakest value, the pixel value is altered only if its original value falls outside the value range of its whole pixel neighborhood. As the sensitivity increases the IP approximates a class of median filter.
Related Information
Adaptive Noise Reduction¶
The Adaptive Noise Reduction (ANR) IP is an edge-preserving smoothing filter that mainly reduces the independent pixel noise of an image. The IP operates on 2x2 Bayer CFA images.
Adaptive Noise Reduction Block Diagram
The ANR IP uses a spatial weighted averaging filter that analyzes the scene and correlates similar pixels dynamically while generating the weights on the fly. The IP utilizes two LUTs when correlating the pixels, one for correlating pixel intensities and the other for correlating the spatial distance between the pixels.
The design provides the intensity range LUT pre-calibrated offline using the difference in noise level between two video images with identical content but different temporal noise. The noise level is a function of the sensors analog gain. Therefore, the calibration file contains a table of LUT parameters for a range of sensor analog gain settings. Using a LUT allows you to program different denoising strengths across the pixel intensities. For example, you may opt for stronger denoising of dark content to reduce shadow noise more aggressively while preserving the details on the mid-tones and highlights.
The spatial distance LUT is used to make the ANR more versatile. It is programmed to create a weight distribution from the center pixel to the neighboring pixels. Traditional distributions like a Hamming or Hanning window can be used to reduce ringing artifacts, or the same value entries can be used for a rectangular distribution to maximize denoising capability. By default, the software configures a Gaussian distribution into the spatial distance LUT.
Related Information
Black Level Correction¶
The Black Level Correction (BLC) IP operates on a 2x2 CFA input image and adjusts the minimum brightness level of the image, ensuring an actual black value is represented by the minimum pixel intensity. A camera system typically adds a pedestal value as an offset to the image at the sensor side. Artificially increasing black level creates foot room for preserving noise distribution of the black pixels and prevents artifacts in the final image. The design positions the BLC IP after the ANR IP where the noise is reduced as much as desired.
Black Level Correction Block Diagram
The BLC IP subtracts the pedestal value from the input video stream and scales the result back to the full dynamic range. The scaler part of BLC multiplies the pedestal remover value by the scaler coefficient, clipping to the maximum output pixel value should the calculation overflow.
BLC Function
The SW App sets the pedestal and scaler coefficients for each of the 2x2 CFA color channels dynamically during runtime. These values can be pre-calibrated, or calculated dynamically from statistics obtained from the BLS IP using OBR of the sensor. You can configure the BLC IP to reflect negative values around zero or clip them to zero.
Effects of Reflection Around Zero
Note that for this design, the SW App provided does not utilize the BLS IP to read the OBR of the sensor and relies on pre-calibrated coefficients as a function of analog gain of the sensor.
Related Information
Vignette Correction¶
The Vignette Correction (VC) IP compensates for non-uniform intensity across the image caused by uneven light-gathering limitation of the sensor and optics. In the usual case, the non-uniformity can be caused by lens geometry transforms such as zoom, aperture, etc., where the center of the lens gathers more light compared to the outer regions. The VC IP corrects uniformity using a runtime mesh of coefficients and interpolating coefficients for any given pixel.
Vignette Correction Block Diagram
The VC IP uses a rectangular mesh of coefficients to adjust the pixel intensities across an image, therefore tuning out vignetting and other sensor non-uniformities. The VC IP operates independently on the 4 color channels of the 2x2 CFA input image. For all color channels, you may calculate the mesh coefficients with a calibration process in a controlled imaging environment and configure the SW App to write them to the VC IP. The precision of a mesh coefficient is fixed-point unsigned 8.11, with 8 integer bits and 11 fractional bits. The mesh divides the image into rectangular zones, with mesh points residing at the corners of the zones. For each pixel, the IP selects the 4 mesh points corresponding to the corners of the pixel's zone and interpolates them using the distance from the pixel location to the mesh points. A multiplier scales the input pixels using this interpolated coefficient.
Note that the vignetting effect is very low for the sensor module used in this design, therefore, the design does not contain a pre-calibrated mesh of coefficients.
A Mesh Zone with a Pixel of Interest
Related Information
White Balance Statistics¶
White Balance Statistics Block Diagram
The White Balance Statistics IP (WBS) operates on a 2x2 Bayer CFA image and calculates red-green and blue-green ratios within a Region of Interest (ROI). The ROI is divided into 7x7 zones, and the WBS calculates independent statistics for all 49 zones. The SW App uses the WBS to set the White Balance Correction IP.
Packing Order of the Zones within a Region of Interest
Each 2x2 Bayer region creates a virtual pixel from grouping 4 pixels. The IP then calculates a red-green and a blue-green ratio for each virtual pixel within the ROI.
Example of ratio calculation for 2x2 virtual pixels for a 6x6 Section of Image
The WBS IP checks both ratios against runtime programmable lower and upper range thresholds and increments a zone virtual pixel count only if both ratios fall between their respective threshold values. If at least one of the ratios is out of range, the IP discards both ratios for that 2x2 virtual pixel and therefore do not contribute to the final statistics of that zone. Ratios of all virtual pixels that are not marked out of range are accumulated, and along with the zone virtual pixel count are transferred to the zone memory at the end of the zone.
The SW App reads each zone memory and calculates an average ratio by dividing the accumulated ratio by the virtual pixel count. If the number of counted pixels is too low, it indicates a zone with mixed content and is therefore unsuitable for inclusion in calculating white imbalance of the image. The Auto White Balance (AWB) algorithm is a feedback loop inside the SW App that continuously reads the white balance statistics and guesses the color temperature of the image scene.
The WBS IP passes its input image to its output unchanged.
Related Information
White Balance Correction¶
The White Balance Correction (WBC) IP adjusts colors in a CFA image to eliminate color casts, which occur due to lighting conditions or differences in the light sensitivity of the pixels of different color. The IP ensures that gray and white objects appear truly gray and white without, unwanted color tinting.
White Balance Correction Block Diagram
The WBC IP multiplies the color channels of a 2x2 CFA input image by scalar coefficients per color channel, clipping to the maximum output pixel value should the calculation overflow.
The design provides a table of WBC scalars pre-calibrated for the sensor for a range of color temperatures. The white balance algorithm in the SW App uses color temperature information of the scene to look up WBC scalars from the calibration table and configures the WBC IP over the Avalon® memory-mapped interface. The SW App uses AWB to guess the color temperature in automatic mode. The SW App also supports many fixed color temperature options.
Related Information
Demosaic¶
Demosaic Block Diagram
The Demosaic IP (DMS) is a color reconstruction IP for converting a 2x2 Bayer CFA input image to an RGB output image. The DMS interpolates missing colors for each pixel based on its neighboring pixels.
An example of a 2x2 RGGB Bayer Color Filter Array (for an 8x8 pixel section of the image)
The DMS analyzes the neighboring pixels for every CFA input pixel and interpolates the missing colors to produce an RGB output pixel. The IP uses line buffers to construct pixel neighborhood information, maps the pixels in the neighborhood depending on the position on the 2x2 CFA pattern, and interpolates missing colors to calculate the RGB output.
Related Information
Histogram Statistics¶
The Histogram Statistics (HS) IP operates on RGB images. It analyzes the pixel values for every frame to collects data to form a histogram of light intensity.
Histogram Statistics Block Diagram
The HS IP calculates two light intensity histograms on the RGB input image - a whole image histogram and a ROI image histogram. The RGB to intensity conversion is performed according to the ITU-R BT.709 standard.
The Automatic Exposure (AE) algorithm is a feedback loop in the SW App that guesses the optimum exposure of the scene. It continuously reads the HS IP and guesses whether the capture is underexposed or overexposed and adjust camera sensor exposure settings accordingly.
The HS IP passes its input to its output unmodified.
Related Information
Color Correction Matrix¶
The Color Correction Matrix (CCM) functionality is provided by the VVP Color Space Converter (CSC) IP. A CCM correction is necessary to untangle the undesired color bleeding across CFA color channels on the sensor. This is mainly caused by each colored pixel being sensitive to color spectrums other than their intended color.
The design configures the CSC IP to multiply the input RGB values of each pixel with a 3x3 CCM to obtain the color corrected output RGB values.
The design provides a table of CCM coefficients pre-calibrated for the sensor for a range of color temperatures. The AWB algorithm in the SW App uses color temperature information of the scene to look up the CCM coefficients from the calibration table and configures the CSC IP over the Avalon® memory-mapped interface. The SW App uses AWB to guess the color temperature in automatic mode. The SW App also supports many fixed color temperature options.
The SW App also provides many post-processing options to modulate the CCM coefficients for adding an artistic effect on top of the pre-calibrated accurate representation of the scene.
Related Information
1D LUT¶
The 1D LUT IP uses a runtime configurable LUT to apply an input output transfer function to the image. You may use it to implement OOTF, OETF, and EOTF transfer functions defined for video standards and legacy gamma compression or decompression. You may also change the LUT content arbitrarily for other transfer functions or to apply an artistic effect to the image.
1D LUT Block Diagram
The 1D LUT IP calculates LUT addresses from the input pixels. It interpolates fractional differences between LUT values to generate output pixel values. The IP uses an independent LUT for each color plane. The SW App uses the Avalon® memory-mapped interface to configure the LUTs.
The example design contains 2 instances of 1D LUT.
Instance 0 is used for traditional Gamma, High Dynamic Range Perceptual Quantizer (HDR PQ) and Hybrid Log-Gamma (HDR HLG) correction. The 1D LUT is configured as a 9-bit LUT and the output is increased to 16-bits to support the Capture Switch that follows.
Instance 1 is used to facilitate the following 3D LUT IP where the available .cube files do not support linear video. To minimize logic resource, this 1D LUT is configured as a 12-bit LUT and the output is reduced to 14-bits.
Related Information
3D LUT¶
The 3D LUT IP maps an image's color space to another using interpolated values from a lookup table.
Typical applications include:
- Color space conversion
- Chroma keying
- Dynamic range conversion (standard to high and high to standard)
- Artistic effects (sepia, hue rotation, color volume adjustment, etc.)
3D LUT Color Transform Examples (From top left to right: original, saturation, brightness increase, colorize (purple), colorize (green), desaturation)
3D LUT Block Diagram
The 3D LUT uses the most significant bits (MSBs) of the 3 RGB color component inputs to retrieve data values from the LUT and the least significant bits (LSBs) to interpolate the final output value. The SW App connected to the Avalon® memory-mapped interface handles runtime control and LUT programming.
The example design uses 2 back to back 3D LUT IPs to support combinations of conversions and will be application specific. If a 3D LUT isn't required, it can be placed in bypass mode. The output of the final 3D LUT IP is reduced to 12-bits.
Generating LUT Files¶
You are responsible for sourcing or generating LUTs for the example design. LUTs are generally developed based on input (optical system, sensor, ISP, etc.) and display parameters. Various tools are available under open-source licenses to produce LUTs. One such tool is LUTCalc, which can be used online. When using it to generate LUTs for the 3D LUT IP, ensure that:
- The LUT is set to 3D
- Size matches the 3D LUT IP parameters (i.e. 17, 33, or 65 cube)
- Input and Output Range are 100%
- LUT Type is "General cube LUT (.cube)"
LUTCalc Format Settings
In general, any LUT file used with this example design must follow these formatting conventions:
- RGB component order
- Components change first from left to right, i.e., R first, G second, B third
- The data type must match the IP GUI parameter and may either be:- normalized fixed- or floating-point numbers between 0.0 to 1.0
- integers between 0 and 2LUT_DEPTH-1 (for example, 10-bit: 0 to 1023)
 
- The data type must be the same for the whole file
Related Information
Tone Mapping Operator¶
The Tone Mapping Operator (TMO) IP implements a tile-based local tone mapping algorithm. It improves the visibility of latent image details and enhances the overall viewing experience.
Before (left) and after (right) TMO is applied to an example image
TMO Block Diagram
The luminance extractor converts the RGB input to LUMA. The image statistics calculator uses LUMA to calculate a set of global and local statistics regarding the contrast of the input image over a 4x4 grid. The LUT generator software runs on an embedded Nios® V CPU which analyzes the statistics, generates a set of mapping transfer functions, and converts them to LUTs. The contrast enhancement engine applies mapping transfer functions locally for better granularity. The image enhancer combines the information and calculates a set of weights that are applied to the input to generate the contrast-enhanced output. The output is reduced down to 10-bits for the USM IP that follows.
The TMO does not use image buffers and therefore the statistics collected from the previous image are used to enhance the current image.
The SW App configures the TMO IP over the Avalon® memory-mapped interface.
Related Information
Unsharp Mask Filter¶
The Unsharp Mask (USM) IP applies a sharpening algorithm to the input image by implementing an unsharp mask filter.
The IP firstly converts the RGB input to LUMA. The LUMA input is then passed through a low-pass Gaussian blur filter. The IP subtracts the blurred input from the original LUMA input to generate a high frequency component. A strength scaler is applied to the high frequency component which is then used to scale the input RGB image to generate the output RGB image.
The unsharp mask has an agent Avalon® memory-mapped interface to allow runtime control for changing the sharpening strength. You can configure a positive or negative strength value for sharpening or blurring the image. Setting the strength to 0 is equivalent to bypass i.e. passing the input to the output unmodified.
Related Information
Warp¶
The Warp IP applies an arbitrary warp (or image transform) to an input image. It allows for lens distortion corrections (fisheye for instance) and the ability to scale, rotate, and mirror the image.
Warp Transform Examples (From left: arbitrary warp with a 5x5 array of control points, four corner warp with some radial distortion.)
Warp Mirror and Rotation Examples (From top left clockwise: original image, mirrored, 90° rotate and 180° rotate.)
Warp Block Diagram
The block diagram shows an external memory which is used to buffer the incoming and outgoing image data. The external memory also stores the coefficient tables used to control the Warp IPs operation and define the required image transform.
The IP uses its Warp engines to operate on the input images stored in the input buffers and to construct warped, output images from the output buffers.
The example design configures the Warp IP with two engines to support any arbitrary transformation at 4K resolution.
Logo Overlay¶
The Altera® logo overlay feature uses a VVP Test Pattern Generator IP, a VVP Mixer IP, and a non-QPDS Icon IP (supplied with the source project). The TPG (Instance 1) is used for the screensaver function and is configured as a 4K solid black image. It is also the base layer for the Mixer IP and is mixed with the ISP pipeline video layer and the Icon IP layer. The opacity of the Icon layer can be changed on the fly using the Avalon® Memory-Mapped interface.
Related Information
Frame Writer¶
The Frame Writer function uses a Video Frame Writer IP which receives and stores frames in external DDR memory connected to the FPGA. The IP has a host Avalon® memory-mapped interface to allow connection to the external memory and an agent Avalon® memory-mapped interface connected to the HPS to allow runtime control.
The Video Frame Writer IP operates in a single shot mode on RGB 16-bit images. The Capture Switch (VVP Switch IP - Instance 5) is used to feed the Video Frame Writer with the raw sensor input via either the Raw Capture Switch (VVP Switch IP - Instance 4) or the ISP output via the 1D LUT IP (Instance 0). The raw sensor input image uses a single color for each pixel and so a Color Plane Manager IP is used to copy the single color into all 3 color planes to generate a grayscale RGB raw sensor image.
The HPS has a host Avalon® memory-mapped interface to the FPGA external DDR, allowing it to read out captured images.
The output of the Capture Switch when not feeding the Video Frame Writer IP, feeds the 16-bit ISP output image into a Pixel Adapter IP to reduce it back down to 10-bit ready for the Display Port output.
Related Information
Video Frame Writer IP 
Color Plane Manager IP 
Bits per Color Sample Adapter IP 
Protocol Converter IP 
Pixels in Parallel Converter IP
Hard Processor System¶
Hard Processor System (HPS) runs the application software that configures the
external optical sensor module and the internal IPs, and provides various
control loops like AWB and AE. In addition, it runs a web server that allows
you to interact with the demo via an Ethernet connection. The HPS has its own
external DDR that is used exclusively by the software stack. Additionally, the
HPS is connected to the external FPGA fabric DDR to process the data of the
Warp and Frame Writer IPs.
Additional Reference Information¶
- Video and Vision Processing Suite Altera® FPGA IP User Guide
- Altera® FPGA Streaming Video Protocol Specification
- AMBA 4 AXI4-Stream Protocol Specification
- Avalon® Interface Specifications – Avalon® Streaming Interfaces
Created: October 6, 2025


























