The Shading Correction camera feature allows you to reduce non-uniformities in the image caused by differing light sensitivities of the sensor pixels. Also artifacts caused by the illumination and illumination optics can be minimized.
Shading correction is based on files that are stored on the camera and contain appropriate correction data. During image acquisition, these are applied to the original pixel values, which results in an improved image.
The Shading Correction feature is only available on racer 2 cameras.
Shading correction minimizes image artifacts caused by dark signal non-uniformities (DSNU) and photo response non-uniformities (PRNU). The following two types of shading correction are available on the camera:
DSNU correction: When the camera captures a line in complete darkness, all of the pixel values in the line should be near zero and they should be equal. In practice, slight variations in the performance of the pixels in the sensor will cause some variation in the pixel values output from the camera when the camera is capturing lines in darkness. DSNU correction corrects for this type of variation. It works by adding an individual gray value (offset) to each pixel value in the lines acquired.
PRNU correction: When the camera captures a line while being pointed at a bright, homogeneously illuminated surface, all of the pixel values in the line should be near their maximum gray value and they should be equal. In practice, slight variations in the performance of the pixels in the sensor as well as variations in the optics and in lighting will cause variations in the pixel values output from the camera. PRNU correction corrects for this type of variation. It works by applying an individual multiplier (gain) to each pixel value in the lines acquired.
Shading correction is a pixel-to-pixel calibration method, i.e., a correction value is calculated for each single pixel.
Info
You can set the camera to only perform DSNU correction, to only perform PRNU correction, or to perform both types of shading correction. If you perform both types of shading correction, the camera first performs DSNU correction, then PRNU correction.
The correction values used for DSNU and PRNU correction are stored in files referred to as shading correction sets. There are the following two types:
Factory correction set: Contains correction values that were stored on the camera during the camera production process. The factory correction set can only reduce image artifacts caused by dark signal non-uniformities (DSNU).
User correction set: Contains correction values that must be created by the user and stored on the camera.
Depending on your camera model, you can create up to 32 User correction sets.
You need the following items before you start creating a user-defined shading correction set:
An appropriate object to completely cover the lens, e.g., the lens cap
A target with a uniform background, e.g., a white sheet of paper
Info
For best results, adjust the optics, line rate, exposure time, gain, and camera temperature as you would for normal operation. Basler recommends acquiring the dark and bright field images in your actual application environment.
Basler recommends setting the Width and Height parameters of the image ROI to their maximum values.
racer 2 L cameras: In Dual Line sensor acquisition mode, the status of a shading correction set created in Single Line mode will be indicated as empty (BslShadingCorrectionSetStatus = Empty), although correction data already exist in this set. If you want to create a new shading correction set in Dual Line mode, check the index numbers of your correction sets created in Single Line mode and choose another index number for your new set. Otherwise, the correction data will be overwritten and replaced by the new correction values.
Execute the BslShadingCorrectionSetCreate command to create a new shading correction set. A total of 256 dark images are acquired and evaluated. The resulting DSNU correction data are generated, collected in the shading correction set defined, and saved to the camera's flash memory. If the shading correction set with, e.g., index number 1, already contains correction data, these are overwritten and replaced by the new correction values.
Info
If a PRNU correction set is enabled while creating DSNU correction data, the PRNU correction values will be ignored for the calculation.
The created shading correction set is enabled automatically.
To verify the result of the shading correction set creation, get the value of the BslShadingCorrectionSetCreateResult parameter.
Illuminate the sensor homogeneously to 70 % saturation, e.g., by placing a white sheet of paper in the camera's entire field of view.
Set the BslShadingCorrectionSelector parameter to PRNU.
Set the BslShadingCorrectionMode parameter to User.
Set the BslShadingCorrectionSetIndex parameter to the desired index number of the set to be created, e.g., 2.
Click the Continuous Shot button in the toolbar of the pylon Viewer to start image acquisition.
Execute the BslShadingCorrectionSetCreate command to create a new shading correction set. A total of 256 bright images are acquired and evaluated. The resulting PRNU correction data are generated, collected in the shading correction set selected, and saved to the camera's flash memory. If the shading correction set with, e.g., index number 2, already contains correction data, these are overwritten and replaced by the new correction values.
Info
If a DSNU correction set is enabled while creating PRNU correction data, the DSNU correction values are taken into account for the calculation.
The created shading correction set is enabled automatically.
To verify the result of the shading correction set creation, get the value of the BslShadingCorrectionSetCreateResult parameter.
Adjusting the Target Gray Value for PRNU Correction#
During the creation of a PRNU correction set, the camera detects the maximum brightness value in the bright field image. However, you may want to adjust the relative target gray value of the sensor brightness you want to achieve. Possible reasons for this are, e.g.:
Your shading correction set can't be created because the correction values are outside the allowed range.
Bright spots on the image (e.g., caused by light reflections) result in a high maximum brightness value detected by the camera during the creation of the correction set. You may want to reduce this value, which is relevant for calculating the correction data, to improve your correction data.
To adjust the target gray value, set the BslShadingCorrectionTargetValue parameter to the desired relative target gray value.
Only pixels with an absolute target gray value lower than the value of the maximum measured value are corrected.
For racer 2 L cameras operated in Dual Linesensor acquisition mode and racer 2 S color cameras, adjusting the target gray value may show unpredictable results. Use the Single Line mode and a mono pixel format instead.
Further parameters:
BslShadingCorrectionAbsoluteTargetValue: Absolute target value of the sensor brightness. This is the actual brightness value that has been calculated based on the sensor bit depth of your camera.
BslShadingCorrectionMaximumMeasuredValue: Maximum brightness value detected by the camera during the creation of a PRNU correction set.
Set the BslShadingCorrectionMode parameter to User, if you want to enable a user-defined correction set, or to Factory, if you want to enable the factory correction set.
Set the BslShadingCorrectionSetIndex parameter to the index number of the set to be used, e.g., index number 2.
The shading correction set is enabled automatically.
To verify whether this process was successful, get the value of the BslShadingCorrectionSetStatus parameter. If the value is Ok, the shading set has been enabled successfully. The camera now performs shading correction based on the correction values in the shading correction set selected.
Info
Changing a shading correction set is possible during image acquisition. However, slight image artifacts may occur during that process.
// Set the type of shading correction to DSNUcamera.BslShadingCorrectionSelector.SetValue(BslShadingCorrectionSelector_DSNU);// Set the shading correction mode to Usercamera.BslShadingCorrectionMode.SetValue(BslShadingCorrectionMode_User);// Set the desired index number of the set to be createdcamera.BslShadingCorrectionSetIndex.SetValue(BslShadingCorrectionSetIndex_1);// Create new shading correction data for the shading correction set selectedcamera.BslShadingCorrectionSetCreate.Execute();// Get the status of the shading correction set selectedBslShadingCorrectionSetStatussetStatus=camera.BslShadingCorrectionSetStatus.GetValue();
INodeMap&nodemap=camera.GetNodeMap();// Set the type of shading correction to DSNUCEnumParameter(nodemap,"BslShadingCorrectionSelector").SetValue("DSNU");// Set the shading correction mode to UserCEnumParameter(nodemap,"BslShadingCorrectionMode").SetValue("User");// Set the desired index number of the set to be createdCEnumParameter(nodemap,"BslShadingCorrectionSetIndex").SetValue("");// Create new shading correction data for the shading correction set selectedCCommandParameter(nodemap,"BslShadingCorrectionSetCreate").Execute();// Get the status of the shading correction set selectedString_tsetStatus=CEnumParameter(nodemap,"BslShadingCorrectionSetStatus").GetValue();
// Set the type of shading correction to DSNUcamera.Parameters[PLCamera.BslShadingCorrectionSelector].SetValue(PLCamera.BslShadingCorrectionSelector.DSNU);// Set the shading correction mode to Usercamera.Parameters[PLCamera.BslShadingCorrectionMode].SetValue(PLCamera.BslShadingCorrectionMode.User);// Set the desired index number of the set to be createdcamera.Parameters[PLCamera.BslShadingCorrectionSetIndex].SetValue(PLCamera.BslShadingCorrectionSetIndex.);// Create new shading correction data for the shading correction set selectedcamera.Parameters[PLCamera.BslShadingCorrectionSetCreate].Execute();// Get the status of the shading correction set selectedstringsetStatus=camera.Parameters[PLCamera.BslShadingCorrectionSetStatus].GetValue();
/* Macro to check for errors */#define CHECK(errc) if (GENAPI_E_OK != errc) printErrorAndExit(errc)GENAPIC_RESULTerrRes=GENAPI_E_OK;/* Return value of pylon methods */size_tlen=0;charsetStatus_str[64]={0};/* Set the type of shading correction to DSNU */errRes=PylonDeviceFeatureFromString(hdev,"BslShadingCorrectionSelector","DSNU");CHECK(errRes);/* Set the shading correction mode to User */errRes=PylonDeviceFeatureFromString(hdev,"BslShadingCorrectionMode","User");CHECK(errRes);/* Set the desired index number of the set to be created */errRes=PylonDeviceFeatureFromString(hdev,"BslShadingCorrectionSetIndex","");CHECK(errRes);/* Create new shading correction data for the shading correction set selected */errRes=PylonDeviceExecuteCommandFeature(hdev,"BslShadingCorrectionSetCreate");CHECK(errRes);/* Get the status of the shading correction set selected */len=sizeof(setStatus_str);errRes=PylonDeviceFeatureToString(hdev,"BslShadingCorrectionSetStatus",setStatus_str,&len);CHECK(errRes);
# Set the type of shading correction to DSNUcamera.BslShadingCorrectionSelector.Value="DSNU"# Set the shading correction mode to Usercamera.BslShadingCorrectionMode.Value="User"# Set the desired index number of the set to be createdcamera.BslShadingCorrectionSetIndex.Value=""# Create new shading correction data for the shading correction set selectedcamera.BslShadingCorrectionSetCreate.Execute()# Get the status of the shading correction set selectedsetStatus=camera.BslShadingCorrectionSetStatus.Value