Commit 77a703c2 authored by dmyershov's avatar dmyershov Committed by Robert Kimball

IntelGPU backend: Select operation (#1314)

parent f8926a7b
...@@ -220,6 +220,32 @@ bool runtime::intelgpu::IntelGPUBackend::compile(shared_ptr<Function> func) ...@@ -220,6 +220,32 @@ bool runtime::intelgpu::IntelGPUBackend::compile(shared_ptr<Function> func)
strides); strides);
} }
} }
else if ("Select" == op->description())
{
arguments_check(op, 3, 1);
const string& input0_name = op->get_inputs().at(0).get_tensor().get_name();
const Shape& input0_shape = op->get_inputs().at(0).get_shape();
const string& input1_name = op->get_inputs().at(1).get_tensor().get_name();
const Shape& input1_shape = op->get_inputs().at(1).get_shape();
const string& input2_name = op->get_inputs().at(2).get_tensor().get_name();
const Shape& input2_shape = op->get_inputs().at(2).get_shape();
const string& output_name = op->get_outputs().begin()->get_tensor().get_name();
const Shape& output_shape = op->get_outputs().begin()->get_shape();
const element::Type& output_type =
op->get_outputs().begin()->get_tensor().get_element_type();
do_select_operation(topology,
input0_name,
input0_shape,
input1_name,
input1_shape,
input2_name,
input2_shape,
output_name,
output_shape,
output_type);
}
else if ("Add" == op->description()) else if ("Add" == op->description())
{ {
do_eltwise_operation(topology, op, cldnn::eltwise_mode::sum); do_eltwise_operation(topology, op, cldnn::eltwise_mode::sum);
......
...@@ -58,7 +58,7 @@ bool runtime::intelgpu::IntelGPULayout:: ...@@ -58,7 +58,7 @@ bool runtime::intelgpu::IntelGPULayout::
cldnn::data_types cldnn::data_types
runtime::intelgpu::IntelGPULayout::get_cldnn_type(const element::Type& element_type) runtime::intelgpu::IntelGPULayout::get_cldnn_type(const element::Type& element_type)
{ {
if (element_type == ngraph::element::i8) if ((element_type == ngraph::element::i8) || (element_type == ngraph::element::boolean))
{ {
return cldnn::data_types::i8; return cldnn::data_types::i8;
} }
......
...@@ -100,7 +100,8 @@ void runtime::intelgpu::do_bcast_sum_operation_scalar(cldnn::topology& topology, ...@@ -100,7 +100,8 @@ void runtime::intelgpu::do_bcast_sum_operation_scalar(cldnn::topology& topology,
function_name, function_name,
parameters_1inp_1out, parameters_1inp_1out,
string("-DCOUNT=" + to_string(input_count)), string("-DCOUNT=" + to_string(input_count)),
layout); layout,
{1});
topology.add(op_scalar); topology.add(op_scalar);
} }
...@@ -171,6 +172,7 @@ void runtime::intelgpu::do_bcast_sum_operation(cldnn::topology& topology, ...@@ -171,6 +172,7 @@ void runtime::intelgpu::do_bcast_sum_operation(cldnn::topology& topology,
function_name, function_name,
parameters_1inp_1out, parameters_1inp_1out,
"", "",
layout); layout,
{1});
topology.add(op_bcast_sum); topology.add(op_bcast_sum);
} }
...@@ -29,6 +29,8 @@ using namespace ngraph; ...@@ -29,6 +29,8 @@ using namespace ngraph;
static vector<cldnn_arg> parameters_1inp_1out = {{arg_input, 0}, {arg_output, 0}}; static vector<cldnn_arg> parameters_1inp_1out = {{arg_input, 0}, {arg_output, 0}};
static vector<cldnn_arg> parameters_2inp_1out = {{arg_input, 0}, {arg_input, 1}, {arg_output, 0}}; static vector<cldnn_arg> parameters_2inp_1out = {{arg_input, 0}, {arg_input, 1}, {arg_output, 0}};
static vector<cldnn_arg> parameters_3inp_1out = {
{arg_input, 0}, {arg_input, 1}, {arg_input, 2}, {arg_output, 0}};
static string array_dims(const Shape& dimentions) static string array_dims(const Shape& dimentions)
{ {
...@@ -156,7 +158,8 @@ void runtime::intelgpu::do_pad_operation(cldnn::topology& topology, ...@@ -156,7 +158,8 @@ void runtime::intelgpu::do_pad_operation(cldnn::topology& topology,
entry_point_name, entry_point_name,
parameters_2inp_1out, parameters_2inp_1out,
"", "",
layout); layout,
{1});
topology.add(op_scalar); topology.add(op_scalar);
} }
...@@ -450,7 +453,8 @@ void runtime::intelgpu::do_dot_operation(cldnn::topology& topology, ...@@ -450,7 +453,8 @@ void runtime::intelgpu::do_dot_operation(cldnn::topology& topology,
entry_point_name, entry_point_name,
parameters_2inp_1out, parameters_2inp_1out,
"", "",
layout); layout,
{1});
topology.add(op_dot); topology.add(op_dot);
} }
...@@ -500,6 +504,74 @@ void runtime::intelgpu::do_slice_operation(cldnn::topology& topology, ...@@ -500,6 +504,74 @@ void runtime::intelgpu::do_slice_operation(cldnn::topology& topology,
entry_point_name, entry_point_name,
parameters_1inp_1out, parameters_1inp_1out,
"", "",
layout); layout,
{1});
topology.add(op_slice); topology.add(op_slice);
} }
void runtime::intelgpu::do_select_operation(cldnn::topology& topology,
const string& input0_name,
const Shape& input0_shape,
const string& input1_name,
const Shape& input1_shape,
const string& input2_name,
const Shape& input2_shape,
const string& output_name,
const Shape& output_shape,
const element::Type& output_type)
{
const cldnn::layout layout = IntelGPULayout::create_cldnn_layout(output_type, output_shape);
string entry_point_name = "select" + output_name;
codegen::CodeWriter writer;
writer << "__kernel void " << entry_point_name << "(const __global char input0"
<< array_dims(input0_shape) << ", const __global float input1"
<< array_dims(input1_shape) << ", const __global float input2"
<< array_dims(input2_shape) << ", __global float output" << array_dims(output_shape)
<< ")\n";
writer.block_begin();
{
size_t var_idx = 0;
// Main loops
for (auto const& i : output_shape)
{
writer << "for (uint i" << var_idx << " = 0; i" << var_idx << " < " << i << "; ++i"
<< var_idx << ")\n";
writer.block_begin();
++var_idx;
}
writer << "if (input0" << access_dims(input0_shape) << " != 0)\n";
writer.block_begin();
{
writer << "output" << access_dims(output_shape) << " = input1"
<< access_dims(input1_shape) << ";\n";
}
writer.block_end();
writer << "else\n";
writer.block_begin();
{
writer << "output" << access_dims(output_shape) << " = input2"
<< access_dims(input2_shape) << ";\n";
}
writer.block_end();
// Closing brackets for main loops
for (auto const& i : output_shape)
{
writer.block_end();
}
}
writer.block_end();
const cldnn::custom_gpu_primitive op_select(output_name,
{input0_name, input1_name, input2_name},
{writer.get_code()},
entry_point_name,
parameters_3inp_1out,
"",
layout,
{1});
topology.add(op_select);
}
...@@ -58,6 +58,17 @@ namespace ngraph ...@@ -58,6 +58,17 @@ namespace ngraph
const Coordinate& lower_bounds, const Coordinate& lower_bounds,
const Coordinate& uppper_bounds, const Coordinate& uppper_bounds,
const Strides& strides); const Strides& strides);
void do_select_operation(cldnn::topology& topology,
const std::string& input0_name,
const Shape& input0_shape,
const std::string& input1_name,
const Shape& input1_shape,
const std::string& input2_name,
const Shape& input2_shape,
const std::string& output_name,
const Shape& output_shape,
const element::Type& output_type);
} }
} }
} }
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