Shifts bits in pixel values to the right.
Case 1: Not-in-place operation on one-channel data
IppStatus ippiRShiftC_<mod>(const Ipp<datatype>* pSrc, int srcStep, Ipp32u value, Ipp<datatype>* pDst, int dstStep, IppiSize roiSize);
Supported values for mod:
8u_C1R |
8s_C1R |
16u_C1R |
16s_C1R |
32s_C1R |
Case 2: Not-in-place operation on multi-channel data
IppStatus ippiRShiftC_<mod>(const Ipp<datatype>* pSrc, int srcStep, const Ipp32u value[3], Ipp<datatype>* pDst, int dstStep, IppiSize roiSize);
Supported values for mod:
8u_C3R |
8s_C3R |
16u_C3R |
16s_C3R |
32s_C3R |
8u_AC4R |
8s_AC4R |
16u_AC4R |
16s_AC4R |
32s_AC4R |
IppStatus ippiRShiftC_<mod>(const Ipp<datatype>* pSrc, int srcStep, const Ipp32u value[4], Ipp<datatype>* pDst, int dstStep, IppiSize roiSize);
Supported values for mod:
8u_C4R |
8s_C4R |
16u_C4R |
16s_C4R |
32s_C4R |
Case 3: In-place operation on one-channel data
IppStatus ippiRShiftC_<mod>(Ipp32u value, Ipp<datatype>* pSrcDst, int srcDstStep, IppiSize roiSize);
Supported values for mod:
8u_C1IR |
8s_C1IR |
16u_C1IR |
16s_C1IR |
32s_C1IR |
Case 4: In-place operation on multi-channel data
IppStatus ippiRShiftC_<mod>(const Ipp32u value[3], Ipp<datatype>* pSrcDst, int srcDstStep, IppiSize roiSize);
Supported values for mod:
8u_C3IR |
8s_C3IR |
16u_C3IR |
16s_C3IR |
32s_C3IR |
8u_AC4IR |
8s_AC4IR |
16u_AC4IR |
16s_AC4IR |
32s_AC4IR |
IppStatus ippiRShiftC_<mod>(const Ipp32u value[4], Ipp<datatype>* pSrcDst, int srcDstStep, IppiSize roiSize);
Supported values for mod:
8u_C4IR |
8s_C4IR |
16u_C4IR |
16s_C4IR |
32s_C4IR |
pSrc |
Pointer to the source image ROI. |
srcStep |
Distance in bytes between starts of consecutive lines in the source image. |
value |
The number of bits to shift (constant vector in case of multi-channel images). |
pDst |
Pointer to the destination image ROI. |
dstStep |
Distance in bytes between starts of consecutive lines in the destination image. |
pSrcDst |
Pointer to the source and destination image ROI for the in-place operation. |
srcDstStep |
Distance in bytes between starts of consecutive lines in the source and destination image for the in-place operation. |
roiSize |
Size of the source and destination ROI in pixels. |
The function ippiRShiftC is declared in the ippi.h file. It operates with ROI (see Regions of Interest in Intel IPP).
This function decreases the intensity of pixels in the source image ROI by shifting the bits in each pixel value by value bits to the right. The positions vacated after shifting the bits are filled with the sign bit. In case of multi-channel data, each color channel can have its own shift value. This operation is equivalent to dividing the pixel values by a constant power of 2.
Note that the functions with the AC4 descriptor do not process alpha channels.
ippStsNoErr |
Indicates no error. Any other value indicates an error or a warning. |
ippStsNullPtrErr |
Indicates an error condition if one of the specified pointers is NULL. |
ippStsSizeErr |
Indicates an error condition if roiSize has a field with a zero or negative value. |
ippStsStepErr |
Indicates an error condition if srcStep, dstStep, or srcDstStep has a zero or negative value. |
Copyright © 2000 - 2011, Intel Corporation. All rights reserved.