Commit f7ea45e6 authored by Tomasz Socha's avatar Tomasz Socha Committed by Scott Cyphers

[SPEC] Add new v1::FloorMod operator (#3852)

* [SPEC] Add new v1::FloorMod operator

* Review Fix I
parent 5259bf21
...@@ -213,6 +213,8 @@ set (SRC ...@@ -213,6 +213,8 @@ set (SRC
op/strided_slice.hpp op/strided_slice.hpp
op/floor.cpp op/floor.cpp
op/floor.hpp op/floor.hpp
op/floor_mod.cpp
op/floor_mod.hpp
op/gather.cpp op/gather.cpp
op/gather.hpp op/gather.hpp
op/gather_nd.cpp op/gather_nd.cpp
......
...@@ -130,6 +130,7 @@ namespace ngraph ...@@ -130,6 +130,7 @@ namespace ngraph
#include "ngraph/op/experimental/tile.hpp" #include "ngraph/op/experimental/tile.hpp"
#include "ngraph/op/experimental/transpose.hpp" #include "ngraph/op/experimental/transpose.hpp"
#include "ngraph/op/floor.hpp" #include "ngraph/op/floor.hpp"
#include "ngraph/op/floor_mod.hpp"
#include "ngraph/op/fused/clamp.hpp" #include "ngraph/op/fused/clamp.hpp"
#include "ngraph/op/fused/conv_fused.hpp" #include "ngraph/op/fused/conv_fused.hpp"
#include "ngraph/op/fused/depth_to_space.hpp" #include "ngraph/op/fused/depth_to_space.hpp"
......
//*****************************************************************************
// Copyright 2017-2019 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//*****************************************************************************
#include "ngraph/op/floor_mod.hpp"
using namespace std;
using namespace ngraph;
constexpr NodeTypeInfo op::v1::FloorMod::type_info;
op::v1::FloorMod::FloorMod(const Output<Node>& arg0,
const Output<Node>& arg1,
const AutoBroadcastSpec& auto_broadcast)
: BinaryElementwiseArithmetic(arg0, arg1, auto_broadcast)
{
constructor_validate_and_infer_types();
}
shared_ptr<Node> op::v1::FloorMod::copy_with_new_args(const NodeVector& new_args) const
{
check_new_args_count(this, new_args);
return make_shared<FloorMod>(new_args.at(0), new_args.at(1), this->get_autob());
}
//*****************************************************************************
// Copyright 2017-2019 Intel Corporation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//*****************************************************************************
#pragma once
#include <memory>
#include "ngraph/op/util/binary_elementwise_arithmetic.hpp"
namespace ngraph
{
namespace op
{
namespace v1
{
/// \brief Elementwise FloorMod operation.
///
class FloorMod : public util::BinaryElementwiseArithmetic
{
public:
NGRAPH_API
static constexpr NodeTypeInfo type_info{"FloorMod", 1};
const NodeTypeInfo& get_type_info() const override { return type_info; }
/// \brief Constructs an uninitialized addition operation
FloorMod() = default;
/// \brief Constructs an Floor Mod operation.
///
/// \param arg0 Output that produces the first input tensor.<br>
/// `[d0, ...]`
/// \param arg1 Output that produces the second input tensor.<br>
/// `[d0, ...]`
/// \param auto_broadcast Auto broadcast specification
///
/// Output `[d0, ...]`
///
FloorMod(const Output<Node>& arg0,
const Output<Node>& arg1,
const AutoBroadcastSpec& auto_broadcast = AutoBroadcastType::NUMPY);
std::shared_ptr<Node> copy_with_new_args(const NodeVector& new_args) const override;
};
} // namespace v1
using v1::FloorMod;
} // namespace op
} // namespace ngraph
...@@ -94,6 +94,7 @@ NGRAPH_OP(Equal, ngraph::op) ...@@ -94,6 +94,7 @@ NGRAPH_OP(Equal, ngraph::op)
NGRAPH_OP(Erf, ngraph::op) NGRAPH_OP(Erf, ngraph::op)
NGRAPH_OP(Exp, ngraph::op) NGRAPH_OP(Exp, ngraph::op)
NGRAPH_OP(Floor, ngraph::op) NGRAPH_OP(Floor, ngraph::op)
NGRAPH_OP(FloorMod, ngraph::op)
NGRAPH_OP(Gather, ngraph::op) NGRAPH_OP(Gather, ngraph::op)
NGRAPH_OP(GatherND, ngraph::op) NGRAPH_OP(GatherND, ngraph::op)
NGRAPH_OP(GenerateMask, ngraph::op) NGRAPH_OP(GenerateMask, ngraph::op)
......
...@@ -1867,6 +1867,7 @@ private: ...@@ -1867,6 +1867,7 @@ private:
case OP_TYPEID::DynPad: case OP_TYPEID::DynPad:
case OP_TYPEID::Tile: case OP_TYPEID::Tile:
case OP_TYPEID::DynReplaceSlice: case OP_TYPEID::DynReplaceSlice:
case OP_TYPEID::FloorMod:
throw unsupported_op("Unsupported op '" + node.description() + "'"); throw unsupported_op("Unsupported op '" + node.description() + "'");
#if defined(__GNUC__) && !(__GNUC__ == 4 && __GNUC_MINOR__ == 8) #if defined(__GNUC__) && !(__GNUC__ == 4 && __GNUC_MINOR__ == 8)
#pragma GCC diagnostic pop #pragma GCC diagnostic pop
......
...@@ -70,6 +70,7 @@ ...@@ -70,6 +70,7 @@
#include "ngraph/op/experimental/tile.hpp" #include "ngraph/op/experimental/tile.hpp"
#include "ngraph/op/experimental/transpose.hpp" #include "ngraph/op/experimental/transpose.hpp"
#include "ngraph/op/floor.hpp" #include "ngraph/op/floor.hpp"
#include "ngraph/op/floor_mod.hpp"
#include "ngraph/op/fused/clamp.hpp" #include "ngraph/op/fused/clamp.hpp"
#include "ngraph/op/fused/conv_fused.hpp" #include "ngraph/op/fused/conv_fused.hpp"
#include "ngraph/op/fused/depth_to_space.hpp" #include "ngraph/op/fused/depth_to_space.hpp"
...@@ -1544,6 +1545,12 @@ shared_ptr<Node> JSONDeserializer::deserialize_node(json node_js) ...@@ -1544,6 +1545,12 @@ shared_ptr<Node> JSONDeserializer::deserialize_node(json node_js)
node = make_shared<op::Floor>(args[0]); node = make_shared<op::Floor>(args[0]);
break; break;
} }
case OP_TYPEID::FloorMod:
{
node = make_shared<op::FloorMod>(
args[0], args[1], read_auto_broadcast(node_js, "auto_broadcast"));
break;
}
case OP_TYPEID::Gather: case OP_TYPEID::Gather:
{ {
if (op_version == 0) if (op_version == 0)
...@@ -3389,6 +3396,15 @@ json JSONSerializer::serialize_node(const Node& n) ...@@ -3389,6 +3396,15 @@ json JSONSerializer::serialize_node(const Node& n)
} }
case OP_TYPEID::Floor: { break; case OP_TYPEID::Floor: { break;
} }
case OP_TYPEID::FloorMod:
{
auto tmp = static_cast<const op::FloorMod*>(&n);
if (tmp->get_autob().m_type != op::AutoBroadcastType::NONE)
{
node["auto_broadcast"] = write_auto_broadcast(tmp->get_autob());
}
break;
}
case OP_TYPEID::Gather: case OP_TYPEID::Gather:
{ {
if (op_version == 0) if (op_version == 0)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment