pytorch/caffe2/utils/math/half_utils.h
Xiaomeng Yang 2db847b3a7 Separate elementwise level2 math functions (#16753)
Summary:
Pull Request resolved: https://github.com/pytorch/pytorch/pull/16753

Separate elementwise level2 math functions

i-am-not-moving-c2-to-c10

Reviewed By: houseroad

Differential Revision: D13954928

fbshipit-source-id: 1ca7a5d3da96e32510f502e5e4e79168854bee67
2019-02-07 18:38:26 -08:00

50 lines
1.3 KiB
C++

#ifndef CAFFE2_UTILS_MATH_HALF_UTILS_H_
#define CAFFE2_UTILS_MATH_HALF_UTILS_H_
#include "caffe2/core/common.h"
#include "caffe2/core/types.h"
#include "caffe2/utils/conversions.h"
#include "caffe2/utils/math/utils.h"
namespace caffe2 {
namespace math {
namespace utils {
struct HalfAddFunctor {
MATH_UTILS_DECL at::Half operator()(const at::Half a, const at::Half b)
const {
return convert::To<float, at::Half>(
convert::To<at::Half, float>(a) + convert::To<at::Half, float>(b));
}
};
struct HalfSubFunctor {
MATH_UTILS_DECL at::Half operator()(const at::Half a, const at::Half b)
const {
return convert::To<float, at::Half>(
convert::To<at::Half, float>(a) - convert::To<at::Half, float>(b));
}
};
struct HalfMulFunctor {
MATH_UTILS_DECL at::Half operator()(const at::Half a, const at::Half b)
const {
return convert::To<float, at::Half>(
convert::To<at::Half, float>(a) * convert::To<at::Half, float>(b));
}
};
struct HalfDivFunctor {
MATH_UTILS_DECL at::Half operator()(const at::Half a, const at::Half b)
const {
return convert::To<float, at::Half>(
convert::To<at::Half, float>(a) / convert::To<at::Half, float>(b));
}
};
} // namespace utils
} // namespace math
} // namespace caffe2
#endif // CAFFE2_UTILS_MATH_HALF_UTILS_H_