// This file is part of OpenCV project. // It is subject to the license terms in the LICENSE file found in the top-level directory // of this distribution and at http://opencv.org/license.html. // Copyright (C) 2016, Intel Corporation, all rights reserved. // Third party copyrights are property of their respective owners. /* Test for Tensorflow models loading */ #if defined(ENABLE_TF_INCEPTION_TESTS) #include "test_precomp.hpp" #include "npy_blob.hpp" namespace cvtest { using namespace cv; using namespace cv::dnn; template static std::string _tf(TString filename) { return (getOpenCVExtraDir() + "/dnn/") + filename; } TEST(Test_TensorFlow, read_inception) { Net net; { Ptr importer = createTensorflowImporter(_tf("tensorflow_inception_graph.pb")); ASSERT_TRUE(importer != NULL); importer->populateNet(net); } Mat sample = imread(_tf("grace_hopper_227.png")); ASSERT_TRUE(!sample.empty()); Mat input; resize(sample, input, Size(224, 224)); input -= 128; // mean sub dnn::Blob inputBlob = dnn::Blob::fromImages(input); net.setBlob("_input.input", inputBlob); net.forward(); Blob out = net.getBlob("softmax2"); std::cout << out.dims() << std::endl; } TEST(Test_TensorFlow, inception_accuracy) { Net net; { Ptr importer = createTensorflowImporter(_tf("tensorflow_inception_graph.pb")); ASSERT_TRUE(importer != NULL); importer->populateNet(net); } Mat sample = imread(_tf("grace_hopper_227.png")); ASSERT_TRUE(!sample.empty()); resize(sample, sample, Size(224, 224)); cv::cvtColor(sample, sample, cv::COLOR_BGR2RGB); dnn::Blob inputBlob = dnn::Blob::fromImages(sample); net.setBlob(".input", inputBlob); net.forward(); Blob out = net.getBlob("softmax2"); Blob ref = blobFromNPY(_tf("tf_inception_prob.npy")); normAssert(ref, out); } } #endif