1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
|
#pragma once
#include "caffe2/operators/resize_3d_op.h"
#include "caffe2/quantization/server/dnnlowp_op.h"
namespace caffe2 {
using ResizeNearest3DFP32Op = ResizeNearest3DOp<float, CPUContext>;
template <typename T>
class ResizeNearest3DDNNLowPOp final
: public DNNLowPOp<T, ResizeNearest3DFP32Op> {
public:
USE_OPERATOR_FUNCTIONS(CPUContext);
USE_DNNLOWP_OPERATOR_BASE_FUNCTIONS(T, ResizeNearest3DFP32Op);
ResizeNearest3DDNNLowPOp(const OperatorDef& operator_def, Workspace* ws)
: BaseType(operator_def, ws),
temporal_scale_(
this->template GetSingleArgument<float>("temporal_scale", 1)),
width_scale_(this->template GetSingleArgument<float>("width_scale", 1)),
height_scale_(
this->template GetSingleArgument<float>("height_scale", 1)) {
CAFFE_ENFORCE_GT(temporal_scale_, 0);
CAFFE_ENFORCE_GT(width_scale_, 0);
CAFFE_ENFORCE_GT(height_scale_, 0);
const auto& order = StringToStorageOrder(
this->template GetSingleArgument<std::string>("order", "NHWC"));
CAFFE_ENFORCE_EQ(order, StorageOrder::NHWC);
}
bool RunOnDevice() override;
private:
float temporal_scale_;
float width_scale_;
float height_scale_;
};
} // namespace caffe2
|