Made tests record in the XML output which parallel framework was used.

This commit is contained in:
Roman Donchenko 2013-06-17 21:06:15 +04:00
parent 843094a07f
commit 24d84a45b1
4 changed files with 42 additions and 21 deletions

View File

@ -50,6 +50,8 @@
#include <vector> #include <vector>
#include "cvconfig.h"
#if defined WIN32 || defined _WIN32 #if defined WIN32 || defined _WIN32
# ifndef WIN32 # ifndef WIN32
# define WIN32 # define WIN32
@ -184,6 +186,30 @@ CV_INLINE IppiSize ippiSize(int width, int height)
# include "opencv2/core/eigen.hpp" # include "opencv2/core/eigen.hpp"
#endif #endif
#ifdef _OPENMP
# define HAVE_OPENMP
#endif
#ifdef __APPLE__
# define HAVE_GCD
#endif
#if defined _MSC_VER && _MSC_VER >= 1600
# define HAVE_CONCURRENCY
#endif
#if defined HAVE_TBB && TBB_VERSION_MAJOR*100 + TBB_VERSION_MINOR >= 202
# define CV_PARALLEL_FRAMEWORK "tbb"
#elif defined HAVE_CSTRIPES
# define CV_PARALLEL_FRAMEWORK "cstripes"
#elif defined HAVE_OPENMP
# define CV_PARALLEL_FRAMEWORK "openmp"
#elif defined HAVE_GCD
# define CV_PARALLEL_FRAMEWORK "gcd"
#elif defined HAVE_CONCURRENCY
# define CV_PARALLEL_FRAMEWORK "ms-concurrency"
#endif
#ifdef __cplusplus #ifdef __cplusplus
namespace cv namespace cv

View File

@ -61,17 +61,6 @@
#endif #endif
#endif #endif
#ifdef _OPENMP
#define HAVE_OPENMP
#endif
#ifdef __APPLE__
#define HAVE_GCD
#endif
#if defined _MSC_VER && _MSC_VER >= 1600
#define HAVE_CONCURRENCY
#endif
/* IMPORTANT: always use the same order of defines /* IMPORTANT: always use the same order of defines
1. HAVE_TBB - 3rdparty library, should be explicitly enabled 1. HAVE_TBB - 3rdparty library, should be explicitly enabled
@ -110,10 +99,6 @@
#endif #endif
#endif #endif
#if defined HAVE_TBB || defined HAVE_CSTRIPES || defined HAVE_OPENMP || defined HAVE_GCD || defined HAVE_CONCURRENCY
#define HAVE_PARALLEL_FRAMEWORK
#endif
namespace cv namespace cv
{ {
ParallelLoopBody::~ParallelLoopBody() {} ParallelLoopBody::~ParallelLoopBody() {}
@ -121,7 +106,7 @@ namespace cv
namespace namespace
{ {
#ifdef HAVE_PARALLEL_FRAMEWORK #ifdef CV_PARALLEL_FRAMEWORK
class ParallelLoopBodyWrapper class ParallelLoopBodyWrapper
{ {
public: public:
@ -218,7 +203,7 @@ public:
static SchedPtr pplScheduler; static SchedPtr pplScheduler;
#endif #endif
#endif // HAVE_PARALLEL_FRAMEWORK #endif // CV_PARALLEL_FRAMEWORK
} //namespace } //namespace
@ -226,7 +211,7 @@ static SchedPtr pplScheduler;
void cv::parallel_for_(const cv::Range& range, const cv::ParallelLoopBody& body, double nstripes) void cv::parallel_for_(const cv::Range& range, const cv::ParallelLoopBody& body, double nstripes)
{ {
#ifdef HAVE_PARALLEL_FRAMEWORK #ifdef CV_PARALLEL_FRAMEWORK
if(numThreads != 0) if(numThreads != 0)
{ {
@ -281,7 +266,7 @@ void cv::parallel_for_(const cv::Range& range, const cv::ParallelLoopBody& body,
} }
else else
#endif // HAVE_PARALLEL_FRAMEWORK #endif // CV_PARALLEL_FRAMEWORK
{ {
(void)nstripes; (void)nstripes;
body(range); body(range);
@ -290,7 +275,7 @@ void cv::parallel_for_(const cv::Range& range, const cv::ParallelLoopBody& body,
int cv::getNumThreads(void) int cv::getNumThreads(void)
{ {
#ifdef HAVE_PARALLEL_FRAMEWORK #ifdef CV_PARALLEL_FRAMEWORK
if(numThreads == 0) if(numThreads == 0)
return 1; return 1;
@ -333,7 +318,7 @@ int cv::getNumThreads(void)
void cv::setNumThreads( int threads ) void cv::setNumThreads( int threads )
{ {
(void)threads; (void)threads;
#ifdef HAVE_PARALLEL_FRAMEWORK #ifdef CV_PARALLEL_FRAMEWORK
numThreads = threads; numThreads = threads;
#endif #endif

View File

@ -1,4 +1,6 @@
#include "opencv2/core/core.hpp"
#include "opencv2/core/core_c.h" #include "opencv2/core/core_c.h"
#include "opencv2/core/internal.hpp"
#include "opencv2/ts/ts.hpp" #include "opencv2/ts/ts.hpp"
#ifdef GTEST_LINKED_AS_SHARED_LIBRARY #ifdef GTEST_LINKED_AS_SHARED_LIBRARY

View File

@ -2958,6 +2958,14 @@ void printVersionInfo(bool useStdOut)
::testing::Test::RecordProperty("inner_version", ver); ::testing::Test::RecordProperty("inner_version", ver);
if(useStdOut) std::cout << ver << std::endl; if(useStdOut) std::cout << ver << std::endl;
} }
#ifdef CV_PARALLEL_FRAMEWORK
::testing::Test::RecordProperty("cv_parallel_framework", CV_PARALLEL_FRAMEWORK);
if (useStdOut)
{
std::cout << "Parallel framework: " << CV_PARALLEL_FRAMEWORK << std::endl;
}
#endif
} }
} //namespace cvtest } //namespace cvtest