// Matrix Construct // // Copyright (C) Matrix Construct Developers, Authors & Contributors // Copyright (C) 2016-2021 Jason Volk // // Permission to use, copy, modify, and/or distribute this software for any // purpose with or without fee is hereby granted, provided that the above // copyright notice and this permission notice is present in all copies. The // full license for this software is available in the LICENSE file. #pragma once #define HAVE_IRCD_SIMT_NORM_H #ifdef __OPENCL_VERSION__ /// Normalize the input, placing the result in possibly overlapping output. /// This procedure requires an additional temporary buffer. inline void ircd_simt_math_norm_f4lldr(__local float4 *const out, __local const float4 *const in, __local float4 *const restrict tmp, const uint ln, const uint li) { ircd_simt_math_mean_f4lldr(tmp, in, ln, li); const float4 sub_mean = in[li] - tmp[li]; tmp[li] = pow(sub_mean, 2); ircd_simt_math_mean_f4lldr(out, tmp, ln, li); const float4 epsilon = 0.00001f, s = sqrt(out[li] + epsilon); out[li] = sub_mean / s; } #endif