blob: 876a3667d887a607a5a08dff74e8484961d0e9e8 [file] [log] [blame]
#include "caffe2/operators/index_hash_ops.h"
namespace caffe2 {
namespace {
REGISTER_CPU_OPERATOR(IndexHash, IndexHashOp<CPUContext>);
OPERATOR_SCHEMA(IndexHash)
.NumInputs(1)
.NumOutputs(1)
.SetDoc(R"DOC(
This operator translates a list of indices into a list of hashed indices.
A seed can be fed as an argument to change the behavior of the hash function.
If a modulo is specified, all the hashed indices will be modulo the
specified number. All input and output indices are enforced to be positive.
)DOC")
.Input(0, "Indices", "Input feature indices.")
.Output(0, "HashedIndices", "Hashed feature indices.")
.AllowOneToOneInplace()
.Arg("seed", "seed for the hash function")
.Arg("modulo", "must be > 0, hashed ids will be modulo this number")
.TensorInferenceFunction([](const OperatorDef& /* unused */,
const vector<TensorShape>& in) {
std::vector<TensorShape> out(1);
std::vector<int64_t> output_dims = GetDimsVector(in[0]);
out[0] = CreateTensorShape(output_dims, in[0].data_type());
return out;
});
SHOULD_NOT_DO_GRADIENT(IndexHash);
} // namespace
} // namespace caffe2
C10_EXPORT_CAFFE2_OP_TO_C10_CPU(
IndexHash,
"_caffe2::IndexHash(Tensor indices, int seed, int modulo) -> Tensor hashed_indices",
caffe2::IndexHashOp<caffe2::CPUContext>);