2018-07-25 02:31:40 +08:00
|
|
|
// 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.
|
|
|
|
|
|
|
|
#include "precomp.hpp"
|
|
|
|
#include "opencv2/core/bindings_utils.hpp"
|
|
|
|
#include <sstream>
|
2021-08-27 20:01:09 +08:00
|
|
|
#include <iomanip>
|
2018-07-25 02:31:40 +08:00
|
|
|
|
|
|
|
namespace cv { namespace utils {
|
|
|
|
|
|
|
|
String dumpInputArray(InputArray argument)
|
|
|
|
{
|
|
|
|
if (&argument == &noArray())
|
|
|
|
return "InputArray: noArray()";
|
|
|
|
std::ostringstream ss;
|
|
|
|
ss << "InputArray:";
|
|
|
|
try {
|
|
|
|
do {
|
|
|
|
ss << (argument.empty() ? " empty()=true" : " empty()=false");
|
|
|
|
ss << cv::format(" kind=0x%08llx", (long long int)argument.kind());
|
|
|
|
ss << cv::format(" flags=0x%08llx", (long long int)argument.getFlags());
|
|
|
|
if (argument.getObj() == NULL)
|
|
|
|
{
|
|
|
|
ss << " obj=NULL";
|
|
|
|
break; // done
|
|
|
|
}
|
|
|
|
ss << cv::format(" total(-1)=%lld", (long long int)argument.total(-1));
|
2020-06-12 18:07:58 +08:00
|
|
|
int dims = argument.dims(-1);
|
|
|
|
ss << cv::format(" dims(-1)=%d", dims);
|
|
|
|
if (dims <= 2)
|
|
|
|
{
|
|
|
|
Size size = argument.size(-1);
|
|
|
|
ss << cv::format(" size(-1)=%dx%d", size.width, size.height);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
int sz[CV_MAX_DIM] = {0};
|
|
|
|
argument.sizend(sz, -1);
|
|
|
|
ss << " size(-1)=[";
|
|
|
|
for (int i = 0; i < dims; i++)
|
|
|
|
{
|
|
|
|
if (i > 0)
|
|
|
|
ss << ' ';
|
|
|
|
ss << sz[i];
|
|
|
|
}
|
|
|
|
ss << "]";
|
|
|
|
}
|
2018-07-25 02:31:40 +08:00
|
|
|
ss << " type(-1)=" << cv::typeToString(argument.type(-1));
|
|
|
|
} while (0);
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
2019-02-10 05:29:54 +08:00
|
|
|
ss << " ERROR: exception occurred, dump is non-complete"; // need to properly support different kinds
|
2018-07-25 02:31:40 +08:00
|
|
|
}
|
|
|
|
return ss.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
CV_EXPORTS_W String dumpInputArrayOfArrays(InputArrayOfArrays argument)
|
|
|
|
{
|
|
|
|
if (&argument == &noArray())
|
|
|
|
return "InputArrayOfArrays: noArray()";
|
|
|
|
std::ostringstream ss;
|
|
|
|
ss << "InputArrayOfArrays:";
|
|
|
|
try {
|
|
|
|
do {
|
|
|
|
ss << (argument.empty() ? " empty()=true" : " empty()=false");
|
|
|
|
ss << cv::format(" kind=0x%08llx", (long long int)argument.kind());
|
|
|
|
ss << cv::format(" flags=0x%08llx", (long long int)argument.getFlags());
|
|
|
|
if (argument.getObj() == NULL)
|
|
|
|
{
|
|
|
|
ss << " obj=NULL";
|
|
|
|
break; // done
|
|
|
|
}
|
|
|
|
ss << cv::format(" total(-1)=%lld", (long long int)argument.total(-1));
|
|
|
|
ss << cv::format(" dims(-1)=%d", argument.dims(-1));
|
|
|
|
Size size = argument.size(-1);
|
|
|
|
ss << cv::format(" size(-1)=%dx%d", size.width, size.height);
|
|
|
|
if (argument.total(-1) > 0)
|
|
|
|
{
|
|
|
|
ss << " type(0)=" << cv::typeToString(argument.type(0));
|
2020-06-12 18:07:58 +08:00
|
|
|
int dims = argument.dims(0);
|
|
|
|
ss << cv::format(" dims(0)=%d", dims);
|
|
|
|
if (dims <= 2)
|
|
|
|
{
|
|
|
|
Size size0 = argument.size(0);
|
|
|
|
ss << cv::format(" size(0)=%dx%d", size0.width, size0.height);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
int sz[CV_MAX_DIM] = {0};
|
|
|
|
argument.sizend(sz, 0);
|
|
|
|
ss << " size(0)=[";
|
|
|
|
for (int i = 0; i < dims; i++)
|
|
|
|
{
|
|
|
|
if (i > 0)
|
|
|
|
ss << ' ';
|
|
|
|
ss << sz[i];
|
|
|
|
}
|
|
|
|
ss << "]";
|
|
|
|
}
|
2018-07-25 02:31:40 +08:00
|
|
|
}
|
|
|
|
} while (0);
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
2019-02-10 05:29:54 +08:00
|
|
|
ss << " ERROR: exception occurred, dump is non-complete"; // need to properly support different kinds
|
2018-07-25 02:31:40 +08:00
|
|
|
}
|
|
|
|
return ss.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
CV_EXPORTS_W String dumpInputOutputArray(InputOutputArray argument)
|
|
|
|
{
|
|
|
|
if (&argument == &noArray())
|
|
|
|
return "InputOutputArray: noArray()";
|
|
|
|
std::ostringstream ss;
|
|
|
|
ss << "InputOutputArray:";
|
|
|
|
try {
|
|
|
|
do {
|
|
|
|
ss << (argument.empty() ? " empty()=true" : " empty()=false");
|
|
|
|
ss << cv::format(" kind=0x%08llx", (long long int)argument.kind());
|
|
|
|
ss << cv::format(" flags=0x%08llx", (long long int)argument.getFlags());
|
|
|
|
if (argument.getObj() == NULL)
|
|
|
|
{
|
|
|
|
ss << " obj=NULL";
|
|
|
|
break; // done
|
|
|
|
}
|
|
|
|
ss << cv::format(" total(-1)=%lld", (long long int)argument.total(-1));
|
2020-06-12 18:07:58 +08:00
|
|
|
int dims = argument.dims(-1);
|
|
|
|
ss << cv::format(" dims(-1)=%d", dims);
|
|
|
|
if (dims <= 2)
|
|
|
|
{
|
|
|
|
Size size = argument.size(-1);
|
|
|
|
ss << cv::format(" size(-1)=%dx%d", size.width, size.height);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
int sz[CV_MAX_DIM] = {0};
|
|
|
|
argument.sizend(sz, -1);
|
|
|
|
ss << " size(-1)=[";
|
|
|
|
for (int i = 0; i < dims; i++)
|
|
|
|
{
|
|
|
|
if (i > 0)
|
|
|
|
ss << ' ';
|
|
|
|
ss << sz[i];
|
|
|
|
}
|
|
|
|
ss << "]";
|
|
|
|
}
|
2018-07-25 02:31:40 +08:00
|
|
|
ss << " type(-1)=" << cv::typeToString(argument.type(-1));
|
|
|
|
} while (0);
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
2019-02-10 05:29:54 +08:00
|
|
|
ss << " ERROR: exception occurred, dump is non-complete"; // need to properly support different kinds
|
2018-07-25 02:31:40 +08:00
|
|
|
}
|
|
|
|
return ss.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
CV_EXPORTS_W String dumpInputOutputArrayOfArrays(InputOutputArrayOfArrays argument)
|
|
|
|
{
|
|
|
|
if (&argument == &noArray())
|
|
|
|
return "InputOutputArrayOfArrays: noArray()";
|
|
|
|
std::ostringstream ss;
|
|
|
|
ss << "InputOutputArrayOfArrays:";
|
|
|
|
try {
|
|
|
|
do {
|
|
|
|
ss << (argument.empty() ? " empty()=true" : " empty()=false");
|
|
|
|
ss << cv::format(" kind=0x%08llx", (long long int)argument.kind());
|
|
|
|
ss << cv::format(" flags=0x%08llx", (long long int)argument.getFlags());
|
|
|
|
if (argument.getObj() == NULL)
|
|
|
|
{
|
|
|
|
ss << " obj=NULL";
|
|
|
|
break; // done
|
|
|
|
}
|
|
|
|
ss << cv::format(" total(-1)=%lld", (long long int)argument.total(-1));
|
|
|
|
ss << cv::format(" dims(-1)=%d", argument.dims(-1));
|
|
|
|
Size size = argument.size(-1);
|
|
|
|
ss << cv::format(" size(-1)=%dx%d", size.width, size.height);
|
|
|
|
if (argument.total(-1) > 0)
|
|
|
|
{
|
|
|
|
ss << " type(0)=" << cv::typeToString(argument.type(0));
|
2020-06-12 18:07:58 +08:00
|
|
|
int dims = argument.dims(0);
|
|
|
|
ss << cv::format(" dims(0)=%d", dims);
|
|
|
|
if (dims <= 2)
|
|
|
|
{
|
|
|
|
Size size0 = argument.size(0);
|
|
|
|
ss << cv::format(" size(0)=%dx%d", size0.width, size0.height);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
int sz[CV_MAX_DIM] = {0};
|
|
|
|
argument.sizend(sz, 0);
|
|
|
|
ss << " size(0)=[";
|
|
|
|
for (int i = 0; i < dims; i++)
|
|
|
|
{
|
|
|
|
if (i > 0)
|
|
|
|
ss << ' ';
|
|
|
|
ss << sz[i];
|
|
|
|
}
|
|
|
|
ss << "]";
|
|
|
|
}
|
2018-07-25 02:31:40 +08:00
|
|
|
}
|
|
|
|
} while (0);
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
2019-02-10 05:29:54 +08:00
|
|
|
ss << " ERROR: exception occurred, dump is non-complete"; // need to properly support different kinds
|
2018-07-25 02:31:40 +08:00
|
|
|
}
|
|
|
|
return ss.str();
|
|
|
|
}
|
|
|
|
|
2021-08-27 20:01:09 +08:00
|
|
|
static inline std::ostream& operator<<(std::ostream& os, const cv::Rect& rect)
|
|
|
|
{
|
|
|
|
return os << "[x=" << rect.x << ", y=" << rect.y << ", w=" << rect.width << ", h=" << rect.height << ']';
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class T, class Formatter>
|
|
|
|
static inline String dumpVector(const std::vector<T>& vec, Formatter format)
|
|
|
|
{
|
|
|
|
std::ostringstream oss("[", std::ios::ate);
|
|
|
|
if (!vec.empty())
|
|
|
|
{
|
|
|
|
oss << format << vec[0];
|
|
|
|
for (std::size_t i = 1; i < vec.size(); ++i)
|
|
|
|
{
|
|
|
|
oss << ", " << format << vec[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
oss << "]";
|
|
|
|
return oss.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline std::ostream& noFormat(std::ostream& os)
|
|
|
|
{
|
|
|
|
return os;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline std::ostream& floatFormat(std::ostream& os)
|
|
|
|
{
|
|
|
|
return os << std::fixed << std::setprecision(2);
|
|
|
|
}
|
|
|
|
|
|
|
|
String dumpVectorOfInt(const std::vector<int>& vec)
|
|
|
|
{
|
|
|
|
return dumpVector(vec, &noFormat);
|
|
|
|
}
|
|
|
|
|
|
|
|
String dumpVectorOfDouble(const std::vector<double>& vec)
|
|
|
|
{
|
|
|
|
return dumpVector(vec, &floatFormat);
|
|
|
|
}
|
|
|
|
|
|
|
|
String dumpVectorOfRect(const std::vector<Rect>& vec)
|
|
|
|
{
|
|
|
|
return dumpVector(vec, &noFormat);
|
|
|
|
}
|
|
|
|
|
2018-07-25 02:31:40 +08:00
|
|
|
}} // namespace
|