Commit 27961cd8 authored by Vladislav Sovrasov's avatar Vladislav Sovrasov

text: fix wrong channel swap in TestDetectorCNN

parent 7031316c
...@@ -106,4 +106,3 @@ int main(int argc, const char * argv[]) ...@@ -106,4 +106,3 @@ int main(int argc, const char * argv[])
waitKey(); waitKey();
return 0; return 0;
} }
...@@ -74,22 +74,20 @@ public: ...@@ -74,22 +74,20 @@ public:
void detect(InputArray inputImage_, std::vector<Rect>& Bbox, std::vector<float>& confidence) void detect(InputArray inputImage_, std::vector<Rect>& Bbox, std::vector<float>& confidence)
{ {
CV_Assert(inputImage_.channels() == inputChannelCount_); CV_Assert(inputImage_.channels() == inputChannelCount_);
Size inputSize = inputImage_.getMat().size(); Mat inputImage = inputImage_.getMat();
Bbox.resize(0); Bbox.resize(0);
confidence.resize(0); confidence.resize(0);
for(size_t i = 0; i < sizes_.size(); i++) for(size_t i = 0; i < sizes_.size(); i++)
{ {
Size inputGeometry = sizes_[i]; Size inputGeometry = sizes_[i];
Mat inputImage = inputImage_.getMat().clone(); net_.setInput(blobFromImage(inputImage, 1, inputGeometry, Scalar(123, 117, 104), false, false), "data");
resize(inputImage, inputImage, inputGeometry);
net_.setInput(blobFromImage(inputImage, 1, inputGeometry, Scalar(123, 117, 104)), "data");
Mat outputNet = net_.forward(); Mat outputNet = net_.forward();
int nbrTextBoxes = outputNet.size[2]; int nbrTextBoxes = outputNet.size[2];
int nCol = outputNet.size[3]; int nCol = outputNet.size[3];
int outputChannelCount = outputNet.size[1]; int outputChannelCount = outputNet.size[1];
CV_Assert(outputChannelCount == 1); CV_Assert(outputChannelCount == 1);
getOutputs((float*)(outputNet.data), nbrTextBoxes, nCol, Bbox, confidence, inputSize); getOutputs((float*)(outputNet.data), nbrTextBoxes, nCol, Bbox, confidence, inputImage.size());
} }
} }
}; };
......
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