-// Copyright (C) 2018 Intel Corporation
+// Copyright (C) 2018-2019 Intel Corporation
// SPDX-License-Identifier: Apache-2.0
//
#include <builders/ie_proposal_layer.hpp>
-#include <details/caseless.hpp>
+#include <ie_cnn_layer_builder.h>
#include <vector>
#include <string>
using namespace InferenceEngine;
-Builder::ProposalLayer::ProposalLayer(const std::string& name): LayerFragment("Proposal", name) {
- getLayer().getOutputPorts().resize(1);
- getLayer().getInputPorts().resize(3);
+Builder::ProposalLayer::ProposalLayer(const std::string& name): LayerDecorator("Proposal", name) {
+ getLayer()->getOutputPorts().resize(1);
+ getLayer()->getInputPorts().resize(3);
}
-Builder::ProposalLayer::ProposalLayer(Layer& genLayer): LayerFragment(genLayer) {
- if (!details::CaselessEq<std::string>()(getLayer().getType(), "Proposal"))
- THROW_IE_EXCEPTION << "Cannot create ProposalLayer decorator for layer " << getLayer().getType();
+Builder::ProposalLayer::ProposalLayer(const Layer::Ptr& layer): LayerDecorator(layer) {
+ checkType("Proposal");
+}
+
+Builder::ProposalLayer::ProposalLayer(const Layer::CPtr& layer): LayerDecorator(layer) {
+ checkType("Proposal");
}
Builder::ProposalLayer& Builder::ProposalLayer::setName(const std::string& name) {
- getLayer().getName() = name;
+ getLayer()->setName(name);
return *this;
}
const std::vector<Port>& Builder::ProposalLayer::getInputPorts() const {
- return getLayer().getInputPorts();
+ return getLayer()->getInputPorts();
}
Builder::ProposalLayer& Builder::ProposalLayer::setInputPorts(const std::vector<Port> &ports) {
if (ports.size() != 3)
- THROW_IE_EXCEPTION << "Incorrect number of inputs for Proposal layer.";
- getLayer().getInputPorts() = ports;
+ THROW_IE_EXCEPTION << "Incorrect number of inputs for Proposal getLayer().";
+ getLayer()->getInputPorts() = ports;
return *this;
}
const Port& Builder::ProposalLayer::getOutputPort() const {
- return getLayer().getOutputPorts()[0];
+ return getLayer()->getOutputPorts()[0];
}
Builder::ProposalLayer& Builder::ProposalLayer::setOutputPort(const Port &port) {
- getLayer().getOutputPorts()[0] = port;
+ getLayer()->getOutputPorts()[0] = port;
return *this;
}
size_t Builder::ProposalLayer::getPostNMSTopN() const {
- return getLayer().getParameters()["post_nms_topn"].asUInt();
+ return getLayer()->getParameters().at("post_nms_topn");
}
Builder::ProposalLayer& Builder::ProposalLayer::setPostNMSTopN(size_t topN) {
- getLayer().getParameters()["post_nms_topn"] = topN;
+ getLayer()->getParameters()["post_nms_topn"] = topN;
return *this;
}
size_t Builder::ProposalLayer::getPreNMSTopN() const {
- return getLayer().getParameters()["pre_nms_topn"].asUInt();
+ return getLayer()->getParameters().at("pre_nms_topn");
}
Builder::ProposalLayer& Builder::ProposalLayer::setPreNMSTopN(size_t topN) {
- getLayer().getParameters()["pre_nms_topn"] = topN;
+ getLayer()->getParameters()["pre_nms_topn"] = topN;
return *this;
}
float Builder::ProposalLayer::getNMSThresh() const {
- return getLayer().getParameters()["nms_thresh"].asFloat();
+ return getLayer()->getParameters().at("nms_thresh");
}
Builder::ProposalLayer& Builder::ProposalLayer::setNMSThresh(float thresh) {
- getLayer().getParameters()["nms_thresh"] = thresh;
+ getLayer()->getParameters()["nms_thresh"] = thresh;
return *this;
}
size_t Builder::ProposalLayer::getBaseSize() const {
- return getLayer().getParameters()["base_size"].asUInt();
+ return getLayer()->getParameters().at("base_size");
}
Builder::ProposalLayer& Builder::ProposalLayer::setBaseSize(size_t baseSize) {
- getLayer().getParameters()["base_size"] = baseSize;
+ getLayer()->getParameters()["base_size"] = baseSize;
return *this;
}
size_t Builder::ProposalLayer::getMinSize() const {
- return getLayer().getParameters()["min_size"].asUInt();
+ return getLayer()->getParameters().at("min_size");
}
Builder::ProposalLayer& Builder::ProposalLayer::setMinSize(size_t minSize) {
- getLayer().getParameters()["min_size"] = minSize;
+ getLayer()->getParameters()["min_size"] = minSize;
return *this;
}
size_t Builder::ProposalLayer::getFeatStride() const {
- return getLayer().getParameters()["feat_stride"].asUInt();
+ return getLayer()->getParameters().at("feat_stride");
}
Builder::ProposalLayer& Builder::ProposalLayer::setFeatStride(size_t featStride) {
- getLayer().getParameters()["feat_stride"] = featStride;
+ getLayer()->getParameters()["feat_stride"] = featStride;
return *this;
}
const std::vector<float> Builder::ProposalLayer::getScale() const {
- return getLayer().getParameters()["scale"].asFloats();
+ return getLayer()->getParameters().at("scale");
}
Builder::ProposalLayer& Builder::ProposalLayer::setScale(const std::vector<float>& scales) {
- getLayer().getParameters()["scale"] = scales;
+ getLayer()->getParameters()["scale"] = scales;
return *this;
}
const std::vector<float> Builder::ProposalLayer::getRatio() const {
- return getLayer().getParameters()["ratio"].asFloats();
+ return getLayer()->getParameters().at("ratio");
}
Builder::ProposalLayer& Builder::ProposalLayer::setRatio(const std::vector<float>& ratios) {
- getLayer().getParameters()["ratio"] = ratios;
+ getLayer()->getParameters()["ratio"] = ratios;
return *this;
}
+
+REG_CONVERTER_FOR(Proposal, [](const CNNLayerPtr& cnnLayer, Builder::Layer& layer) {
+ layer.getParameters()["post_nms_topn"] = static_cast<size_t>(cnnLayer->GetParamAsUInt("post_nms_topn", 0));
+ layer.getParameters()["pre_nms_topn"] = static_cast<size_t>(cnnLayer->GetParamAsUInt("pre_nms_topn", 0));
+ layer.getParameters()["nms_thresh"] = cnnLayer->GetParamAsFloat("nms_thresh", 0);
+ layer.getParameters()["min_size"] = static_cast<size_t>(cnnLayer->GetParamAsUInt("base_size", 0));
+ layer.getParameters()["max_size"] = static_cast<size_t>(cnnLayer->GetParamAsUInt("max_size", 0));
+ layer.getParameters()["max_size"] = static_cast<size_t>(cnnLayer->GetParamAsUInt("feat_stride", 0));
+ layer.getParameters()["scale"] = cnnLayer->GetParamAsFloats("scale");
+ layer.getParameters()["ratio"] = cnnLayer->GetParamAsFloats("ratio");
+});
\ No newline at end of file