1 //*****************************************************************************
2 // Copyright 2017-2020 Intel Corporation
4 // Licensed under the Apache License, Version 2.0 (the "License");
5 // you may not use this file except in compliance with the License.
6 // You may obtain a copy of the License at
8 // http://www.apache.org/licenses/LICENSE-2.0
10 // Unless required by applicable law or agreed to in writing, software
11 // distributed under the License is distributed on an "AS IS" BASIS,
12 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 // See the License for the specific language governing permissions and
14 // limitations under the License.
15 //*****************************************************************************
17 #include "ngraph/op/max.hpp"
19 #include "ngraph/graph_util.hpp"
20 #include "ngraph/runtime/host_tensor.hpp"
21 #include "ngraph/runtime/reference/max.hpp"
22 #include "ngraph/shape_util.hpp"
25 using namespace ngraph;
29 template <element::Type_t ET>
30 bool evaluate(const HostTensorPtr& arg,
31 const HostTensorPtr& out,
35 out->set_shape(reduce(arg->get_shape(), axes, keep_dims));
36 runtime::reference::max(
37 arg->get_data_ptr<ET>(), out->get_data_ptr<ET>(), arg->get_shape(), axes, keep_dims);
41 bool evaluate_max(const HostTensorPtr& arg,
42 const HostTensorPtr& out,
47 switch (arg->get_element_type())
49 TYPE_CASE(i32)(arg, out, axes, keep_dims);
51 TYPE_CASE(i64)(arg, out, axes, keep_dims);
53 TYPE_CASE(u32)(arg, out, axes, keep_dims);
55 TYPE_CASE(u64)(arg, out, axes, keep_dims);
57 TYPE_CASE(f16)(arg, out, axes, keep_dims);
59 TYPE_CASE(f32)(arg, out, axes, keep_dims);
61 default: rc = false; break;
67 constexpr NodeTypeInfo op::v1::ReduceMax::type_info;
69 op::v1::ReduceMax::ReduceMax(const Output<Node>& arg,
70 const Output<Node>& reduction_axes,
72 : ArithmeticReductionKeepDims(arg, reduction_axes, keep_dims)
74 constructor_validate_and_infer_types();
77 shared_ptr<Node> op::v1::ReduceMax::clone_with_new_inputs(const OutputVector& new_args) const
79 check_new_args_count(this, new_args);
80 return make_shared<op::v1::ReduceMax>(new_args.at(0), new_args.at(1), get_keep_dims());
83 bool op::v1::ReduceMax::evaluate(const HostTensorVector& outputs,
84 const HostTensorVector& inputs) const
86 OV_ITT_SCOPED_TASK(itt::domains::nGraphOp, "op::v1::ReduceMax::evaluate");
87 return maxop::evaluate_max(inputs[0], outputs[0], get_reduction_axes(), get_keep_dims());