blob: 66bbec49d29cd93ca5b6a05d7ad35948480e4077 [file] [log] [blame]
#include "THCUNN.h"
#include "THCHalf.h"
#include "THCHalfAutoNumerics.cuh"
#include <THC/THCApply.cuh>
template <typename T>
struct squareupdateOutput_functor
{
__device__ void operator()(T* output, const T* input) const
{
*output = (*input) * (*input);
}
};
template <typename T>
struct squareupdateGradInput_functor
{
__device__ void operator()(T* gradInput, const T* input, const T* gradOutput) const
{
*gradInput = ScalarConvert<double, T>::to(2.0) * (*gradOutput) * (*input);
}
};
#include "generic/Square.cu"
#include "THCGenerateFloatTypes.h"