[IE][VPU]: Makes ROIAlign to use 2 stage pipeline (to support ma2485) (#2123)
This commit is contained in:
parent
1721a9cc5a
commit
676ce76650
@ -19,7 +19,7 @@ set(VPU_SUPPORTED_FIRMWARES usb-ma2450 usb-ma2x8x pcie-ma248x)
|
||||
# Default packages
|
||||
#
|
||||
|
||||
set(FIRMWARE_PACKAGE_VERSION 1378)
|
||||
set(FIRMWARE_PACKAGE_VERSION 1388)
|
||||
set(VPU_CLC_MA2X8X_VERSION "movi-cltools-20.09.1")
|
||||
|
||||
#
|
||||
|
@ -17,11 +17,18 @@ VPU_DECLARE_ENUM(ROIAlignMode,
|
||||
Max = 1
|
||||
)
|
||||
|
||||
VPU_DECLARE_ENUM(ROIAlignStep,
|
||||
Repacking = 0,
|
||||
ROIAlignCHWc = 1,
|
||||
ROIAlign = 2
|
||||
)
|
||||
|
||||
static const char s_mode[] = "mode";
|
||||
static const char s_pooled_w[] = "pooled_w";
|
||||
static const char s_pooled_h[] = "pooled_h";
|
||||
static const char s_sampling_ratio[] = "sampling_ratio";
|
||||
static const char s_spatial_scale[] = "spatial_scale";
|
||||
static const char s_step_number[] = "step_number";
|
||||
|
||||
namespace {
|
||||
|
||||
@ -52,7 +59,11 @@ private:
|
||||
}
|
||||
|
||||
void initialCheckImpl() const override {
|
||||
assertInputsOutputsTypes(this, {{DataType::FP16}, {DataType::FP16}, {DataType::S32}}, {{DataType::FP16}});
|
||||
const auto step_number = attrs().get<ROIAlignStep>(s_step_number);
|
||||
std::vector<EnumSet<DataType>> repackingInputs = {{DataType::FP16}};
|
||||
std::vector<EnumSet<DataType>> ROIAlignInputs = {{DataType::FP16}, {DataType::FP16}, {DataType::S32}};
|
||||
|
||||
assertInputsOutputsTypes(this, (step_number == ROIAlignStep::Repacking) ? repackingInputs : ROIAlignInputs, {{DataType::FP16}});
|
||||
}
|
||||
|
||||
void serializeParamsImpl(BlobSerializer& serializer) const override {
|
||||
@ -61,14 +72,14 @@ private:
|
||||
const auto sampling_ratio = attrs().get<int>(s_sampling_ratio);
|
||||
const auto spatial_scale = attrs().get<float>(s_spatial_scale);
|
||||
const auto mode = attrs().get<ROIAlignMode>(s_mode);
|
||||
const auto use_buffer = !tempBuffers().empty();
|
||||
const auto step_number = attrs().get<ROIAlignStep>(s_step_number);
|
||||
|
||||
serializer.append(static_cast<uint32_t>(pooled_w));
|
||||
serializer.append(static_cast<uint32_t>(pooled_h));
|
||||
serializer.append(static_cast<uint32_t>(sampling_ratio));
|
||||
serializer.append(static_cast<float>(spatial_scale));
|
||||
serializer.append(static_cast<ROIAlignMode>(mode));
|
||||
serializer.append(static_cast<uint32_t>(use_buffer));
|
||||
serializer.append(static_cast<ROIAlignStep>(step_number));
|
||||
}
|
||||
|
||||
void serializeDataImpl(BlobSerializer& serializer) const override {
|
||||
@ -77,47 +88,51 @@ private:
|
||||
}
|
||||
|
||||
outputEdge(0)->output()->serializeBuffer(serializer);
|
||||
const auto use_buffer = !tempBuffers().empty();
|
||||
if (use_buffer)
|
||||
tempBuffer(0)->serializeBuffer(serializer);
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace
|
||||
|
||||
void FrontEnd::parseROIAlign(const Model& model, const ie::CNNLayerPtr& layer, const DataVector& inputs, const DataVector& outputs) const {
|
||||
VPU_THROW_UNLESS(inputs.size() == 3,
|
||||
"ROIAlign stage with name {} has invalid number of inputs: expected 3, "
|
||||
VPU_THROW_UNLESS(inputs.size() == 3 || inputs.size() == 1,
|
||||
"ROIAlign stage with name {} has invalid number of inputs: expected 3 or 1 "
|
||||
"actually provided {}", layer->name, inputs.size());
|
||||
|
||||
VPU_THROW_UNLESS(outputs.size() == 1,
|
||||
"ROIAlign stage with name {} has invalid number of outputs: expected 1, "
|
||||
"actually provided {}", layer->name, outputs.size());
|
||||
|
||||
const auto stage = model->addNewStage<ROIAlignStage>(layer->name, StageType::ROIAlign, layer, inputs, outputs);
|
||||
const auto mode = layer->GetParamAsString("mode", "");
|
||||
VPU_THROW_UNLESS(mode == "avg" || mode == "max", "Layer with name {} supports only (avg, max) mode", layer->name);
|
||||
ROIAlignMode roi_align_mode = (mode == "avg") ? ROIAlignMode::Average : ROIAlignMode::Max;
|
||||
|
||||
if (mode == "avg") {
|
||||
stage->attrs().set<ROIAlignMode>(s_mode, ROIAlignMode::Average);
|
||||
} else if (mode == "max") {
|
||||
stage->attrs().set<ROIAlignMode>(s_mode, ROIAlignMode::Max);
|
||||
} else {
|
||||
VPU_THROW_FORMAT("Layer with name {} supports only (avg, max) mode", layer->name);
|
||||
const auto width = inputs[0]->desc().dim(Dim::W);
|
||||
const auto is_input_static = (inputs[0]->parentDataToShapeEdge() == nullptr);
|
||||
const auto use_chwc_repacking = (width >= 200) && (roi_align_mode == ROIAlignMode::Average) && is_input_static;
|
||||
auto repackedInput = inputs[0];
|
||||
|
||||
if (use_chwc_repacking) {
|
||||
repackedInput = model->duplicateData(inputs[0], formatString("@ROIAlignRepacked"));
|
||||
|
||||
const auto repacking_stage = model->addNewStage<ROIAlignStage>(layer->name + "Repacking",
|
||||
StageType::ROIAlign, layer,
|
||||
{inputs[0]}, {repackedInput});
|
||||
|
||||
repacking_stage->attrs().set<int>(s_pooled_w, layer->GetParamAsInt("pooled_w"));
|
||||
repacking_stage->attrs().set<int>(s_pooled_h, layer->GetParamAsInt("pooled_h"));
|
||||
repacking_stage->attrs().set<int>(s_sampling_ratio, layer->GetParamAsInt("sampling_ratio"));
|
||||
repacking_stage->attrs().set<float>(s_spatial_scale, layer->GetParamAsFloat("spatial_scale"));
|
||||
repacking_stage->attrs().set<ROIAlignMode>(s_mode, ROIAlignMode::Average);
|
||||
repacking_stage->attrs().set<ROIAlignStep>(s_step_number, ROIAlignStep::Repacking);
|
||||
}
|
||||
|
||||
const auto stage = model->addNewStage<ROIAlignStage>(layer->name, StageType::ROIAlign, layer, {repackedInput, inputs[1], inputs[2]}, outputs);
|
||||
|
||||
stage->attrs().set<ROIAlignMode>(s_mode, roi_align_mode);
|
||||
stage->attrs().set<int>(s_pooled_w, layer->GetParamAsInt("pooled_w"));
|
||||
stage->attrs().set<int>(s_pooled_h, layer->GetParamAsInt("pooled_h"));
|
||||
stage->attrs().set<int>(s_sampling_ratio, layer->GetParamAsInt("sampling_ratio"));
|
||||
stage->attrs().set<float>(s_spatial_scale, layer->GetParamAsFloat("spatial_scale"));
|
||||
|
||||
const int width = inputs[0]->desc().dim(Dim::W);
|
||||
const int height = inputs[0]->desc().dim(Dim::H);
|
||||
const int channels = inputs[0]->desc().dim(Dim::C);
|
||||
const int buffer_size = sizeof(int16_t) * width * height * channels;
|
||||
const bool use_buffer = (width >= 200) && (mode == "avg");
|
||||
|
||||
if (use_buffer)
|
||||
model->addTempBuffer(stage, DataDesc({buffer_size}));
|
||||
stage->attrs().set<ROIAlignStep>(s_step_number, use_chwc_repacking ? ROIAlignStep::ROIAlignCHWc : ROIAlignStep::ROIAlign);
|
||||
}
|
||||
|
||||
} // namespace vpu
|
||||
|
@ -11,3 +11,11 @@ INSTANTIATE_TEST_CASE_P(accuracy, myriadLayersTestsROIAlign_smoke,
|
||||
::testing::ValuesIn(s_ROIAlignNumROIs),
|
||||
::testing::ValuesIn(s_ROIAlignMode)),
|
||||
);
|
||||
|
||||
INSTANTIATE_TEST_CASE_P(accuracy_faster, myriadLayersTestsROIAlign_smoke,
|
||||
::testing::Combine(
|
||||
::testing::ValuesIn(s_ROIAlignLayerInput_Faster),
|
||||
::testing::ValuesIn(s_ROIAlignLayerParam_Faster),
|
||||
::testing::ValuesIn(s_ROIAlignNumROIs_Faster),
|
||||
::testing::ValuesIn(s_ROIAlignMode_Faster)),
|
||||
);
|
||||
|
@ -243,16 +243,26 @@ TEST_P(myriadLayersTestsROIAlign_smoke, ROIAlign) {
|
||||
static std::vector<Dims> s_ROIAlignLayerInput = {
|
||||
{{5, 256, 160, 157}},
|
||||
};
|
||||
|
||||
static std::vector<roi_align_param> s_ROIAlignLayerParam = {
|
||||
{{640, 640, 7, 9, 2, 1.4f}},
|
||||
};
|
||||
|
||||
static std::vector<number_rois> s_ROIAlignNumROIs = {
|
||||
53
|
||||
};
|
||||
|
||||
static std::vector<roi_align_mode> s_ROIAlignMode = {
|
||||
std::string("avg"),
|
||||
std::string("max")
|
||||
std::string("avg"),
|
||||
std::string("max")
|
||||
};
|
||||
|
||||
static std::vector<Dims> s_ROIAlignLayerInput_Faster = {
|
||||
{{1, 256, 200, 257}},
|
||||
};
|
||||
static std::vector<roi_align_param> s_ROIAlignLayerParam_Faster = {
|
||||
{{640, 640, 7, 7, 2, 0.25f}},
|
||||
};
|
||||
static std::vector<number_rois> s_ROIAlignNumROIs_Faster = {
|
||||
750
|
||||
};
|
||||
static std::vector<roi_align_mode> s_ROIAlignMode_Faster = {
|
||||
std::string("avg")
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user