static const char* posterize_cl_source = "/* This file is an image processing operation for GEGL \n" " * \n" " * GEGL is free software; you can redistribute it and/or \n" " * modify it under the terms of the GNU Lesser General Public \n" " * License as published by the Free Software Foundation; either \n" " * version 3 of the License, or (at your option) any later version. \n" " * \n" " * GEGL is distributed in the hope that it will be useful, \n" " * but WITHOUT ANY WARRANTY; without even the implied warranty of \n" " * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU \n" " * Lesser General Public License for more details. \n" " * \n" " * You should have received a copy of the GNU Lesser General Public \n" " * License along with GEGL; if not, see . \n" " * \n" " * Copyright 2013 Carlos Zubieta \n" " */ \n" " \n" "__kernel void cl_posterize(__global const float4 *in, \n" " __global float4 *out, \n" " float levels) \n" "{ \n" " int gid = get_global_id(0); \n" " float4 in_v = in[gid]; \n" " \n" " in_v.xyz = trunc(in_v.xyz * levels + (float3)(0.5f)) / levels; \n" " out[gid] = in_v; \n" "} \n" ;