mirror of
https://github.com/zebrajr/pytorch.git
synced 2025-12-07 12:21:27 +01:00
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
50 lines
1.3 KiB
C++
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_
|