Difference between revisions of "Function:XOR"

From CUVI Wiki
Line 46: Line 46:
|}
|}


===Image Type Support===
====Image Type Support====
 
{|
|style="font-size:75%;"|
{| class="wikitable"
{| class="wikitable"
|-
|-
Line 69: Line 70:
| 16uC3
| 16uC3
| 16uC3
| 16uC3
|}
|}
|}



Revision as of 20:30, 18 October 2022

Bitwise XOR operation of an image with another image or a constant value.

Function

CuviStatus XOR(const CuviImage& src1,
               const CuviImage& src2,
               CuviImage& dst,
               const CuviStream& stream = CuviStream());

CuviStatus XOR(const CuviImage& src,
               const Cuvi32s value,
               CuviImage& dst,
               const CuviStream& stream = CuviStream());

Parameters

Name Type Description
src1 const CuviImage& First Input Image
src2 const CuviImage& Second Input Image
dst CuviImage& Resultant Image
stream const CuviStream& GPU stream ID for execution

Image Type Support

Input 1 Input 2 Output
8uC1 8uC1 8uC1
8uC3 8uC3 8uC3
16uC1 16uC1 16uC1
16uC3 16uC3 16uC3

Sample

Error creating thumbnail: Unable to save thumbnail to destination
First Input Image
Error creating thumbnail: Unable to save thumbnail to destination
Second Input Image
Error creating thumbnail: Unable to save thumbnail to destination
Resultant Image


Example

CuviImage input1 = cuvi::io::loadImage(path);
CuviImage input2 = cuvi::io::loadImage(path);
CuviImage output;

//XOR Operation
cuvi::arithmeticLogical::XOR(input1,input2,output);

//The same can be achieved by using XOR operator
output = input1 ^ input2;

//Inverting last 4 bits of each pixel of the image
output ^= 0x0f;