2021-10-13 10:00:23 +00:00
|
|
|
// Copyright (c) 2021, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
|
2021-10-07 09:55:26 +00:00
|
|
|
//
|
|
|
|
// NVIDIA CORPORATION and its licensors retain all intellectual property
|
|
|
|
// and proprietary rights in and to this software, related documentation
|
|
|
|
// and any modifications thereto. Any use, reproduction, disclosure or
|
|
|
|
// distribution of this software and related documentation without an express
|
|
|
|
// license agreement from NVIDIA CORPORATION is strictly prohibited.
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
// CUDA kernel parameters.
|
|
|
|
|
|
|
|
struct bias_act_kernel_params
|
|
|
|
{
|
|
|
|
const void* x; // [sizeX]
|
|
|
|
const void* b; // [sizeB] or NULL
|
|
|
|
const void* xref; // [sizeX] or NULL
|
|
|
|
const void* yref; // [sizeX] or NULL
|
|
|
|
const void* dy; // [sizeX] or NULL
|
|
|
|
void* y; // [sizeX]
|
|
|
|
|
|
|
|
int grad;
|
|
|
|
int act;
|
|
|
|
float alpha;
|
|
|
|
float gain;
|
|
|
|
float clamp;
|
|
|
|
|
|
|
|
int sizeX;
|
|
|
|
int sizeB;
|
|
|
|
int stepB;
|
|
|
|
int loopX;
|
|
|
|
};
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|
|
|
|
// CUDA kernel selection.
|
|
|
|
|
|
|
|
template <class T> void* choose_bias_act_kernel(const bias_act_kernel_params& p);
|
|
|
|
|
|
|
|
//------------------------------------------------------------------------
|