All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.syncleus.aparapi.examples.convolution.convolution.cl Maven / Gradle / Ivy

The newest version!
void processPixel(__global float* _convMatrix3x3, __global char* _imageIn, __global char* _imageOut, int _width, int _height, int _x, int _y){
   float accum = 0.0f;
   int count = 0;
   for (int dx = -3; dx<6; dx+=3){
      for (int dy = -1; dy<2; dy++){
         int rgb = 0xff & _imageIn[(((_y + dy) * _width) + (_x + dx))];
         accum = accum + ((float)rgb * _convMatrix3x3[count++]);
      }
   }
   char value = (char )max(0, min((int)accum, 255));
   _imageOut[(_y * _width) + _x]  = value;
   return;
}

__kernel void applyConvolution(
   __global float *_convMatrix3x3,  // only read from kernel
   __global char  *_imageIn, // only read from kernel
   __global char  *_imageOut, // only written to (never read) from kernel
   int _width,
   int _height
){
 int x = get_global_id(0) % (_width * 3);
 int y = get_global_id(0) / (_width * 3);
 if (x>3 && x<((_width * 3) - 3) && y>1 && y<(_height - 1)){
    processPixel(_convMatrix3x3, _imageIn, _imageOut, _width*3, _height, x, y);
 }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy