Commit aa0d8060 authored by Aleksandr Rybnikov's avatar Aleksandr Rybnikov Committed by Maksim Shabunin

Added possibility of getting any intermediate blob with thrifty memory management

parent b18e3579
...@@ -337,19 +337,35 @@ namespace dnn //! This namespace is used for dnn module functionlaity. ...@@ -337,19 +337,35 @@ namespace dnn //! This namespace is used for dnn module functionlaity.
* In fact, this layer provides the only way to pass user data into the network. * In fact, this layer provides the only way to pass user data into the network.
* As any other layer, this layer can label its outputs and this function provides an easy way to do this. * As any other layer, this layer can label its outputs and this function provides an easy way to do this.
*/ */
CV_WRAP void setNetInputs(const std::vector<String> &inputBlobNames); CV_WRAP void setInputsNames(const std::vector<String> &inputBlobNames);
/** @brief Initializes and allocates all layers. */ /** @brief Runs forward pass to compute output of layer with name @p outputName.
CV_WRAP void allocate(); * @param outputName name for layer which output is needed to get
* @return blob for first output of specified layer.
/** @brief Runs forward pass to compute output of layer @p toLayer.
* @details By default runs forward pass for the whole network. * @details By default runs forward pass for the whole network.
*/ */
CV_WRAP void forward(LayerId toLayer = String()); CV_WRAP Mat forward(const String& outputName = String());
/** @brief Runs forward pass to compute output of layer @p toLayer, but computations start from @p startLayer */
void forward(LayerId startLayer, LayerId toLayer); /** @brief Runs forward pass to compute output of layer with name @p outputName.
/** @overload */ * @param outputBlobs contains all output blobs for specified layer.
void forward(const std::vector<LayerId> &startLayers, const std::vector<LayerId> &toLayers); * @param outputName name for layer which output is needed to get
* @details If @p outputName is empty, runs forward pass for the whole network.
*/
CV_WRAP void forward(std::vector<Mat>& outputBlobs, const String& outputName = String());
/** @brief Runs forward pass to compute outputs of layers listed in @p outBlobNames.
* @param outputBlobs contains blobs for first outputs of specified layers.
* @param outBlobNames names for layers which outputs are needed to get
*/
CV_WRAP void forward(std::vector<Mat>& outputBlobs,
const std::vector<String>& outBlobNames);
/** @brief Runs forward pass to compute outputs of layers listed in @p outBlobNames.
* @param outputBlobs contains all output blobs for each layer specified in @p outBlobNames.
* @param outBlobNames names for layers which outputs are needed to get
*/
CV_WRAP void forward(std::vector<std::vector<Mat> >& outputBlobs,
const std::vector<String>& outBlobNames);
//TODO: //TODO:
/** @brief Optimized forward. /** @brief Optimized forward.
...@@ -369,7 +385,7 @@ namespace dnn //! This namespace is used for dnn module functionlaity. ...@@ -369,7 +385,7 @@ namespace dnn //! This namespace is used for dnn module functionlaity.
* specific target. For layers that not represented in scheduling file * specific target. For layers that not represented in scheduling file
* or if no manual scheduling used at all, automatic scheduling will be applied. * or if no manual scheduling used at all, automatic scheduling will be applied.
*/ */
void compileHalide(const std::string& scheduler = ""); void setHalideScheduler(const String& scheduler);
/** /**
* @brief Ask network to use specific computation backend where it supported. * @brief Ask network to use specific computation backend where it supported.
...@@ -379,19 +395,13 @@ namespace dnn //! This namespace is used for dnn module functionlaity. ...@@ -379,19 +395,13 @@ namespace dnn //! This namespace is used for dnn module functionlaity.
void setPreferableBackend(int backendId); void setPreferableBackend(int backendId);
/** @brief Sets the new value for the layer output blob /** @brief Sets the new value for the layer output blob
* @param outputName descriptor of the updating layer output blob. * @param name descriptor of the updating layer output blob.
* @param blob new blob. * @param blob new blob.
* @see connect(String, String) to know format of the descriptor. * @see connect(String, String) to know format of the descriptor.
* @note If updating blob is not empty then @p blob must have the same shape, * @note If updating blob is not empty then @p blob must have the same shape,
* because network reshaping is not implemented yet. * because network reshaping is not implemented yet.
*/ */
CV_WRAP void setBlob(String outputName, const Mat &blob); CV_WRAP void setInput(const Mat &blob, const String& name = "");
/** @brief Returns the layer output blob.
* @param outputName the descriptor of the returning layer output blob.
* @see connect(String, String)
*/
CV_WRAP Mat getBlob(String outputName);
/** @brief Sets the new value for the learned param of the layer. /** @brief Sets the new value for the learned param of the layer.
* @param layer name or id of the layer. * @param layer name or id of the layer.
......
...@@ -3,6 +3,7 @@ typedef dnn::DictValue LayerId; ...@@ -3,6 +3,7 @@ typedef dnn::DictValue LayerId;
typedef std::vector<dnn::MatShape> vector_MatShape; typedef std::vector<dnn::MatShape> vector_MatShape;
typedef std::vector<std::vector<dnn::MatShape> > vector_vector_MatShape; typedef std::vector<std::vector<dnn::MatShape> > vector_vector_MatShape;
typedef std::vector<size_t> vector_size_t; typedef std::vector<size_t> vector_size_t;
typedef std::vector<std::vector<Mat> > vector_vector_Mat;
template<> template<>
bool pyopencv_to(PyObject *o, dnn::DictValue &dv, const char *name) bool pyopencv_to(PyObject *o, dnn::DictValue &dv, const char *name)
......
...@@ -119,16 +119,14 @@ int main(int argc, char **argv) ...@@ -119,16 +119,14 @@ int main(int argc, char **argv)
//! [Prepare blob] //! [Prepare blob]
//! [Set input blob] //! [Set input blob]
net.setBlob(".data", inputBlob); //set the network input net.setInput(inputBlob, "data"); //set the network input
//! [Set input blob] //! [Set input blob]
//! [Make forward pass] //! [Make forward pass]
net.forward(); //compute output Mat prob = net.forward("prob"); //compute output
//! [Make forward pass] //! [Make forward pass]
//! [Gather output] //! [Gather output]
Mat prob = net.getBlob("prob"); //gather output of "prob" layer
int classId; int classId;
double classProb; double classProb;
getMaxClass(prob, &classId, &classProb);//find the best class getMaxClass(prob, &classId, &classProb);//find the best class
......
...@@ -134,19 +134,16 @@ int main(int argc, char **argv) ...@@ -134,19 +134,16 @@ int main(int argc, char **argv)
//! [Prepare blob] //! [Prepare blob]
//! [Set input blob] //! [Set input blob]
net.setBlob(".data", inputBlob); //set the network input net.setInput(inputBlob, "data"); //set the network input
//! [Set input blob] //! [Set input blob]
//! [Make forward pass] //! [Make forward pass]
double t = (double)cv::getTickCount(); double t = (double)cv::getTickCount();
net.forward(); //compute output Mat score = net.forward("score"); //compute output
t = (double)cv::getTickCount() - t; t = (double)cv::getTickCount() - t;
printf("processing time: %.1fms\n", t*1000./getTickFrequency()); printf("processing time: %.1fms\n", t*1000./getTickFrequency());
//! [Make forward pass] //! [Make forward pass]
//! [Gather output]
Mat score = net.getBlob("score");
Mat colorize; Mat colorize;
colorizeSegmentation(score, colors, colorize); colorizeSegmentation(score, colors, colorize);
Mat show; Mat show;
......
...@@ -93,7 +93,7 @@ int main(int argc, char **argv) ...@@ -93,7 +93,7 @@ int main(int argc, char **argv)
//! [Prepare blob] //! [Prepare blob]
//! [Set input blob] //! [Set input blob]
net.setBlob("", inputBlob); // Set the network input. net.setInput(inputBlob); // Set the network input.
//! [Set input blob] //! [Set input blob]
//! [Enable Halide backend] //! [Enable Halide backend]
...@@ -101,15 +101,15 @@ int main(int argc, char **argv) ...@@ -101,15 +101,15 @@ int main(int argc, char **argv)
//! [Enable Halide backend] //! [Enable Halide backend]
//! [Compile Halide pipeline] //! [Compile Halide pipeline]
net.compileHalide(); // Compile Halide pipeline. // net.compileHalide(); // Compile Halide pipeline.
//! [Compile Halide pipeline] //! [Compile Halide pipeline]
//! [Make forward pass] //! [Make forward pass]
net.forward(); // Compute output. Mat prob = net.forward("prob"); // Compute output.
//! [Make forward pass] //! [Make forward pass]
//! [Gather output] //! [Gather output]
Mat prob = net.getBlob("prob"); // Gather output of "prob" layer. // net.getBlob(); // Gather output of "prob" layer.
int classId; int classId;
double classProb; double classProb;
......
...@@ -108,15 +108,13 @@ int main(int argc, char** argv) ...@@ -108,15 +108,13 @@ int main(int argc, char** argv)
//! [Prepare blob] //! [Prepare blob]
//! [Set input blob] //! [Set input blob]
net.setBlob(".data", inputBlob); //set the network input net.setInput(inputBlob, "data"); //set the network input
//! [Set input blob] //! [Set input blob]
//! [Make forward pass] //! [Make forward pass]
net.forward(); //compute output Mat detection = net.forward("detection_out"); //compute output
//! [Make forward pass] //! [Make forward pass]
//! [Gather output]
Mat detection = net.getBlob("detection_out");
Mat detectionMat(detection.size[2], detection.size[3], CV_32F, detection.ptr<float>()); Mat detectionMat(detection.size[2], detection.size[3], CV_32F, detection.ptr<float>());
float confidenceThreshold = parser.get<float>("min_confidence"); float confidenceThreshold = parser.get<float>("min_confidence");
......
...@@ -26,7 +26,7 @@ const String keys = ...@@ -26,7 +26,7 @@ const String keys =
"https://storage.googleapis.com/download.tensorflow.org/models/inception5h.zip }" "https://storage.googleapis.com/download.tensorflow.org/models/inception5h.zip }"
"{model m |tensorflow_inception_graph.pb| path to TensorFlow .pb model file }" "{model m |tensorflow_inception_graph.pb| path to TensorFlow .pb model file }"
"{image i || path to image file }" "{image i || path to image file }"
"{i_blob | .input | input blob name) }" "{i_blob | input | input blob name) }"
"{o_blob | softmax2 | output blob name) }" "{o_blob | softmax2 | output blob name) }"
"{c_names c | imagenet_comp_graph_label_strings.txt | path to file with classnames for class id }" "{c_names c | imagenet_comp_graph_label_strings.txt | path to file with classnames for class id }"
"{result r || path to save output blob (optional, binary format, NCHW order) }" "{result r || path to save output blob (optional, binary format, NCHW order) }"
...@@ -101,21 +101,18 @@ int main(int argc, char **argv) ...@@ -101,21 +101,18 @@ int main(int argc, char **argv)
//! [Prepare blob] //! [Prepare blob]
inputBlob -= 117.0; inputBlob -= 117.0;
//! [Set input blob] //! [Set input blob]
net.setBlob(inBlobName, inputBlob); //set the network input net.setInput(inputBlob, inBlobName); //set the network input
//! [Set input blob] //! [Set input blob]
cv::TickMeter tm; cv::TickMeter tm;
tm.start(); tm.start();
//! [Make forward pass] //! [Make forward pass]
net.forward(); //compute output Mat result = net.forward(outBlobName); //compute output
//! [Make forward pass] //! [Make forward pass]
tm.stop(); tm.stop();
//! [Gather output]
Mat result = net.getBlob(outBlobName); //gather output of "prob" layer
if (!resultFile.empty()) { if (!resultFile.empty()) {
CV_Assert(result.isContinuous()); CV_Assert(result.isContinuous());
......
...@@ -73,32 +73,19 @@ int main(int argc, char **argv) ...@@ -73,32 +73,19 @@ int main(int argc, char **argv)
//! [Prepare blob] //! [Prepare blob]
//! [Set input blob] //! [Set input blob]
net.setBlob("", inputBlob); //set the network input net.setInput(inputBlob, ""); //set the network input
//! [Set input blob] //! [Set input blob]
const int N = 3;
TickMeter tm; TickMeter tm;
//! [Make forward pass]
for( int i = 0; i < N; i++ )
{
TickMeter tm_;
tm_.start();
net.forward(); //compute output
tm_.stop();
if( i == 0 || tm_.getTimeTicks() < tm.getTimeTicks() )
tm = tm_;
}
//! [Gather output]
String oBlob = net.getLayerNames().back(); String oBlob = net.getLayerNames().back();
if (!parser.get<String>("o_blob").empty()) if (!parser.get<String>("o_blob").empty())
{ {
oBlob = parser.get<String>("o_blob"); oBlob = parser.get<String>("o_blob");
} }
Mat result = net.getBlob(oBlob); //gather output of "prob" layer //! [Make forward pass]
Mat result = net.forward(oBlob);
if (!resultFile.empty()) { if (!resultFile.empty()) {
CV_Assert(result.isContinuous()); CV_Assert(result.isContinuous());
......
...@@ -277,7 +277,7 @@ public: ...@@ -277,7 +277,7 @@ public:
addedBlobs.push_back(BlobNote(net.input(inNum), 0, inNum)); addedBlobs.push_back(BlobNote(net.input(inNum), 0, inNum));
netInputs[inNum] = net.input(inNum); netInputs[inNum] = net.input(inNum);
} }
dstNet.setNetInputs(netInputs); dstNet.setInputsNames(netInputs);
} }
for (int li = 0; li < layersSize; li++) for (int li = 0; li < layersSize; li++)
......
This diff is collapsed.
...@@ -703,7 +703,7 @@ void TFImporter::populateNet(Net dstNet) ...@@ -703,7 +703,7 @@ void TFImporter::populateNet(Net dstNet)
std::vector<String> netInputs(1); std::vector<String> netInputs(1);
netInputs[0] = name; netInputs[0] = name;
layer_id[name] = 0; layer_id[name] = 0;
dstNet.setNetInputs(netInputs); dstNet.setInputsNames(netInputs);
} }
else if (type == "Split") { else if (type == "Split") {
// TODO: determing axis index remapping by input dimensions order of input blob // TODO: determing axis index remapping by input dimensions order of input blob
......
...@@ -824,13 +824,20 @@ struct TorchImporter : public ::cv::dnn::Importer ...@@ -824,13 +824,20 @@ struct TorchImporter : public ::cv::dnn::Importer
mergeParams.set("axis", module->params.get<int>("dimension") - 1); mergeParams.set("axis", module->params.get<int>("dimension") - 1);
splitId = net.addLayer(generateLayerName("torchSplit"), "Split", splitParams); splitId = net.addLayer(generateLayerName("torchSplit"), "Split", splitParams);
mergeId = net.addLayer(generateLayerName("torchMerge"), "Concat", mergeParams);
net.connect(prevLayerId, prevOutNum, splitId, 0); net.connect(prevLayerId, prevOutNum, splitId, 0);
std::vector<int> branchIds;
for (int i = 0; i < (int)module->modules.size(); i++) for (int i = 0; i < (int)module->modules.size(); i++)
{ {
newId = fill(module->modules[i], addedModules, splitId, i); newId = fill(module->modules[i], addedModules, splitId, i);
net.connect(newId, 0, mergeId, i); branchIds.push_back(newId);
}
mergeId = net.addLayer(generateLayerName("torchMerge"), "Concat", mergeParams);
for (int i = 0; i < branchIds.size(); i++)
{
net.connect(branchIds[i], 0, mergeId, i);
} }
addedModules.push_back(std::make_pair(mergeId, module)); addedModules.push_back(std::make_pair(mergeId, module));
...@@ -847,15 +854,22 @@ struct TorchImporter : public ::cv::dnn::Importer ...@@ -847,15 +854,22 @@ struct TorchImporter : public ::cv::dnn::Importer
reshapeParams.set("num_axes", 1); reshapeParams.set("num_axes", 1);
splitId = net.addLayer(generateLayerName("torchSplit"), "Slice", splitParams); splitId = net.addLayer(generateLayerName("torchSplit"), "Slice", splitParams);
mergeId = net.addLayer(generateLayerName("torchMerge"), "Concat", mergeParams);
reshapeId = net.addLayer(generateLayerName("torchReshape"), "Reshape", reshapeParams); reshapeId = net.addLayer(generateLayerName("torchReshape"), "Reshape", reshapeParams);
net.connect(prevLayerId, prevOutNum, splitId, 0); net.connect(prevLayerId, prevOutNum, splitId, 0);
std::vector<int> branchIds;
for (int i = 0; i < (int)module->modules.size(); i++) for (int i = 0; i < (int)module->modules.size(); i++)
{ {
net.connect(splitId, i, reshapeId, i); net.connect(splitId, i, reshapeId, i);
newId = fill(module->modules[i], addedModules, reshapeId, i); newId = fill(module->modules[i], addedModules, reshapeId, i);
net.connect(newId, 0, mergeId, i); branchIds.push_back(newId);
}
mergeId = net.addLayer(generateLayerName("torchMerge"), "Concat", mergeParams);
for (int i = 0; i < branchIds.size(); i++)
{
net.connect(branchIds[i], 0, mergeId, i);
} }
addedModules.push_back(std::make_pair(mergeId, module)); addedModules.push_back(std::make_pair(mergeId, module));
......
...@@ -94,10 +94,8 @@ TEST(Reproducibility_AlexNet, Accuracy) ...@@ -94,10 +94,8 @@ TEST(Reproducibility_AlexNet, Accuracy)
if (sample.size() != inputSize) if (sample.size() != inputSize)
resize(sample, sample, inputSize); resize(sample, sample, inputSize);
net.setBlob(".data", blobFromImage(sample, 1.)); net.setInput(blobFromImage(sample, 1.), "data");
net.forward(); Mat out = net.forward("prob");
Mat out = net.getBlob("prob");
Mat ref = blobFromNPY(_tf("caffe_alexnet_prob.npy")); Mat ref = blobFromNPY(_tf("caffe_alexnet_prob.npy"));
normAssert(ref, out); normAssert(ref, out);
} }
...@@ -125,10 +123,8 @@ TEST(Reproducibility_FCN, Accuracy) ...@@ -125,10 +123,8 @@ TEST(Reproducibility_FCN, Accuracy)
std::vector<size_t> weights, blobs; std::vector<size_t> weights, blobs;
net.getMemoryConsumption(shape(1,3,227,227), layerIds, weights, blobs); net.getMemoryConsumption(shape(1,3,227,227), layerIds, weights, blobs);
net.setBlob(".data", blobFromImage(sample, 1.)); net.setInput(blobFromImage(sample, 1.), "data");
net.forward(); Mat out = net.forward("score");
Mat out = net.getBlob("score");
Mat ref = blobFromNPY(_tf("caffe_fcn8s_prob.npy")); Mat ref = blobFromNPY(_tf("caffe_fcn8s_prob.npy"));
normAssert(ref, out); normAssert(ref, out);
} }
...@@ -155,9 +151,8 @@ TEST(Reproducibility_SSD, Accuracy) ...@@ -155,9 +151,8 @@ TEST(Reproducibility_SSD, Accuracy)
resize(sample, sample, Size(300, 300)); resize(sample, sample, Size(300, 300));
Mat in_blob = blobFromImage(sample); Mat in_blob = blobFromImage(sample);
net.setBlob(".data", in_blob); net.setInput(in_blob, "data");
net.forward(); Mat out = net.forward("detection_out");
Mat out = net.getBlob("detection_out");
Mat ref = blobFromNPY(_tf("ssd_out.npy")); Mat ref = blobFromNPY(_tf("ssd_out.npy"));
normAssert(ref, out); normAssert(ref, out);
......
...@@ -72,12 +72,30 @@ static void launchGoogleNetTest() ...@@ -72,12 +72,30 @@ static void launchGoogleNetTest()
inpMats.push_back( imread(_tf("googlenet_1.png")) ); inpMats.push_back( imread(_tf("googlenet_1.png")) );
ASSERT_TRUE(!inpMats[0].empty() && !inpMats[1].empty()); ASSERT_TRUE(!inpMats[0].empty() && !inpMats[1].empty());
net.setBlob(".data", blobFromImages(inpMats)); net.setInput(blobFromImages(inpMats), "data");
net.forward(); Mat out = net.forward("prob");
Mat out = net.getBlob("prob");
Mat ref = blobFromNPY(_tf("googlenet_prob.npy")); Mat ref = blobFromNPY(_tf("googlenet_prob.npy"));
normAssert(out, ref); normAssert(out, ref);
std::vector<String> blobsNames;
blobsNames.push_back("conv1/7x7_s2");
blobsNames.push_back("conv1/relu_7x7");
blobsNames.push_back("inception_4c/1x1");
blobsNames.push_back("inception_4c/relu_1x1");
std::vector<Mat> outs;
Mat in = blobFromImage(inpMats[0]);
net.setInput(in, "data");
net.forward(outs, blobsNames);
CV_Assert(outs.size() == blobsNames.size());
for (int i = 0; i < blobsNames.size(); i++)
{
std::string filename = blobsNames[i];
std::replace( filename.begin(), filename.end(), '/', '#');
Mat ref = blobFromNPY(_tf("googlenet_" + filename + ".npy"));
normAssert(outs[i], ref, "", 1E-4, 1E-2);
}
} }
TEST(Reproducibility_GoogLeNet, Accuracy) TEST(Reproducibility_GoogLeNet, Accuracy)
......
...@@ -118,9 +118,8 @@ void testLayerUsingCaffeModels(String basename, bool useCaffeModel = false, bool ...@@ -118,9 +118,8 @@ void testLayerUsingCaffeModels(String basename, bool useCaffeModel = false, bool
Mat inp = blobFromNPY(inpfile); Mat inp = blobFromNPY(inpfile);
Mat ref = blobFromNPY(outfile); Mat ref = blobFromNPY(outfile);
net.setBlob(".input", inp); net.setInput(inp, "input");
net.forward(); Mat out = net.forward("output");
Mat out = net.getBlob("output");
normAssert(ref, out); normAssert(ref, out);
} }
...@@ -244,9 +243,8 @@ static void test_Reshape_Split_Slice_layers() ...@@ -244,9 +243,8 @@ static void test_Reshape_Split_Slice_layers()
RNG rng(0); RNG rng(0);
rng.fill(input, RNG::UNIFORM, -1, 1); rng.fill(input, RNG::UNIFORM, -1, 1);
net.setBlob(".input", input); net.setInput(input, "input");
net.forward(); Mat output = net.forward("output");
Mat output = net.getBlob("output");
normAssert(input, output); normAssert(input, output);
} }
......
...@@ -42,10 +42,9 @@ TEST(Test_TensorFlow, read_inception) ...@@ -42,10 +42,9 @@ TEST(Test_TensorFlow, read_inception)
Mat inputBlob = blobFromImage(input, 1.); Mat inputBlob = blobFromImage(input, 1.);
net.setBlob("_input.input", inputBlob); net.setInput(inputBlob, "input");
net.forward(); Mat out = net.forward("softmax2");
Mat out = net.getBlob("softmax2");
std::cout << out.dims << std::endl; std::cout << out.dims << std::endl;
} }
...@@ -64,10 +63,9 @@ TEST(Test_TensorFlow, inception_accuracy) ...@@ -64,10 +63,9 @@ TEST(Test_TensorFlow, inception_accuracy)
resize(sample, sample, Size(224, 224)); resize(sample, sample, Size(224, 224));
Mat inputBlob = blobFromImage(sample, 1.); Mat inputBlob = blobFromImage(sample, 1.);
net.setBlob(".input", inputBlob); net.setInput(inputBlob, "input");
net.forward(); Mat out = net.forward("softmax2");
Mat out = net.getBlob("softmax2");
Mat ref = blobFromNPY(_tf("tf_inception_prob.npy")); Mat ref = blobFromNPY(_tf("tf_inception_prob.npy"));
normAssert(ref, out); normAssert(ref, out);
......
...@@ -87,17 +87,17 @@ static void runTorchNet(String prefix, String outLayerName = "", ...@@ -87,17 +87,17 @@ static void runTorchNet(String prefix, String outLayerName = "",
ASSERT_NO_THROW( inp = readTorchBlob(_tf(prefix + "_input" + suffix), isBinary) ); ASSERT_NO_THROW( inp = readTorchBlob(_tf(prefix + "_input" + suffix), isBinary) );
ASSERT_NO_THROW( outRef = readTorchBlob(_tf(prefix + "_output" + suffix), isBinary) ); ASSERT_NO_THROW( outRef = readTorchBlob(_tf(prefix + "_output" + suffix), isBinary) );
net.setBlob(".0", inp);
net.forward();
if (outLayerName.empty()) if (outLayerName.empty())
outLayerName = net.getLayerNames().back(); outLayerName = net.getLayerNames().back();
Mat out = net.getBlob(outLayerName);
normAssert(outRef, out); net.setInput(inp, "0");
std::vector<Mat> outBlobs;
net.forward(outBlobs, outLayerName);
normAssert(outRef, outBlobs[0]);
if (check2ndBlob) if (check2ndBlob)
{ {
Mat out2 = net.getBlob(outLayerName + ".1"); Mat out2 = outBlobs[1];
Mat ref2 = readTorchBlob(_tf(prefix + "_output_2" + suffix), isBinary); Mat ref2 = readTorchBlob(_tf(prefix + "_output_2" + suffix), isBinary);
normAssert(out2, ref2); normAssert(out2, ref2);
} }
...@@ -132,12 +132,12 @@ TEST(Torch_Importer, run_linear) ...@@ -132,12 +132,12 @@ TEST(Torch_Importer, run_linear)
TEST(Torch_Importer, run_paralel) TEST(Torch_Importer, run_paralel)
{ {
runTorchNet("net_parallel", "l2_torchMerge"); runTorchNet("net_parallel", "l5_torchMerge");
} }
TEST(Torch_Importer, run_concat) TEST(Torch_Importer, run_concat)
{ {
runTorchNet("net_concat", "l2_torchMerge"); runTorchNet("net_concat", "l5_torchMerge");
} }
TEST(Torch_Importer, run_deconv) TEST(Torch_Importer, run_deconv)
...@@ -185,14 +185,21 @@ TEST(Torch_Importer, ENet_accuracy) ...@@ -185,14 +185,21 @@ TEST(Torch_Importer, ENet_accuracy)
Mat sample = imread(_tf("street.png", false)); Mat sample = imread(_tf("street.png", false));
Mat inputBlob = blobFromImage(sample, 1./255); Mat inputBlob = blobFromImage(sample, 1./255);
net.setBlob("", inputBlob); net.setInput(inputBlob, "");
net.forward(); Mat out = net.forward();
Mat out = net.getBlob(net.getLayerNames().back());
Mat ref = blobFromNPY(_tf("torch_enet_prob.npy", false)); Mat ref = blobFromNPY(_tf("torch_enet_prob.npy", false));
// Due to numerical instability in Pooling-Unpooling layers (indexes jittering) // Due to numerical instability in Pooling-Unpooling layers (indexes jittering)
// thresholds for ENet must be changed. Accuracy of resuults was checked on // thresholds for ENet must be changed. Accuracy of resuults was checked on
// Cityscapes dataset and difference in mIOU with Torch is 10E-4% // Cityscapes dataset and difference in mIOU with Torch is 10E-4%
normAssert(ref, out, "", 0.00044, 0.44); normAssert(ref, out, "", 0.00044, 0.44);
const int N = 3;
for (int i = 0; i < N; i++)
{
net.setInput(inputBlob, "");
Mat out = net.forward();
normAssert(ref, out, "", 0.00044, 0.44);
}
} }
} }
......
...@@ -172,11 +172,10 @@ bool TrackerGOTURNImpl::updateImpl(const Mat& image, Rect2d& boundingBox) ...@@ -172,11 +172,10 @@ bool TrackerGOTURNImpl::updateImpl(const Mat& image, Rect2d& boundingBox)
Mat targetBlob = dnn::blobFromImage(targetPatch); Mat targetBlob = dnn::blobFromImage(targetPatch);
Mat searchBlob = dnn::blobFromImage(searchPatch); Mat searchBlob = dnn::blobFromImage(searchPatch);
net.setBlob(".data1", targetBlob); net.setInput(targetBlob, ".data1");
net.setBlob(".data2", searchBlob); net.setInput(searchBlob, ".data2");
net.forward(); Mat resMat = net.forward("scale").reshape(1, 1);
Mat resMat = net.getBlob("scale").reshape(1, 1);
curBB.x = targetPatchRect.x + (resMat.at<float>(0) * targetPatchRect.width / INPUT_SIZE) - targetPatchRect.width; curBB.x = targetPatchRect.x + (resMat.at<float>(0) * targetPatchRect.width / INPUT_SIZE) - targetPatchRect.width;
curBB.y = targetPatchRect.y + (resMat.at<float>(1) * targetPatchRect.height / INPUT_SIZE) - targetPatchRect.height; curBB.y = targetPatchRect.y + (resMat.at<float>(1) * targetPatchRect.height / INPUT_SIZE) - targetPatchRect.height;
......
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