Supported by...
Only supported on some PL-D, PL-X, and PL-U cameras.
Description
Enabling this feature for a given pixel format, will enable the camera to output compressed images, using the specified compression scheme, when streaming that particular pixel format. Note that the images received from the camera are de-compressed by the Pixelink host software, so that images received from the API (via either PxLGetNextCompressedFrame, or a Frame Callback) will still appear uncompressed in the expected pixel format.
API Control
Feature | Num Params | Parameters | Units | Restrictions |
FEATURE_COMPRESSION | 2 | fPixelFormat | N/A | Integer only (see Pixel Format) |
fCompressionStrategy | N/A | Integer only (see Parameter Compression Strategy below) |
Feature Flags
Camera | Presence | Read Only | Auto | Manual | One-time Auto | Off | Settable While Streaming | Persistable | CiD |
Only on some PL-D, PL-U, PL-X Cameras | Yes | No | No | Yes | No | Yes | No | Yes | No |
Paramerter Compression Strategy
See the PixeLINKTypes.h file for more detailed information.
Name | Value | Meaning | Restrictions |
None | 0 | Compression is disabled for the specified pixel format | None |
Pixelink10 | 1 | This is a proprietary lossless compression strategy that achieves a 2:1 compression ratio for a wide variety of images. Much higher compression ratios can be achieved for images whose dynamic range is more limited, whereby the histogram of these images appear 'peaky'. See Note below for more information. |
|
Notes:
Pixelink10 compression strategy:
As per above, Pixelink10 is a Pixelink created lossless compression scheme that can be applied to either MONO8 or BAYER8 type pixel formats. While enabled, all images are compressed within the camera and transmitted to the host. The Pixelink API can then decompress the images. This decompression can be done as the frames arrive from the camera and prior to delivery to the application (via either PxLGetNextFrame or a CALLBACK_FRAME type callback), or at a later time via the PxLDecompressFrame function if the application had chosen to receive the compressed frame from the API (via PxLGetNextCompressedFrame or a CALLBACK_COMPRESSED_FRAME type callback). The compression ratio achieved is image dependant, but ratios between 2:1 and 5:1 are common.
The Pixelink host software uses highly tuned decompression algorithms to minimize the impact to user applications. For instance, typical 5 MPixel MONO8 images can be compressed in less than 7 ms*. However, this algorithm uses AVX2 instruction extensions so decompression can only be done on computers using Intel processors (or equivalent) utilizing Haswell architecture or newer. Enabling compression from a computer with an incompatible processor type, will return a warning (ApiCompressionNotPossibleWarning). Attempting to stream compressed images from this same computer, will return an error (ApiDecompressionNotPossibleError).
If compression is being applied, some camera models will permit the user to increase the camera’s frame rate beyond the link throughput limit for uncompressed images. However, in the unusual circumstance whereby the images achieve poor compression ratios, increasing the frame rate in these circumstances could lead to frame loss.
*Tested using a single thread on a 2.8 GHz i7 system