2015-08-27 15:53:44 +02:00
|
|
|
#ifndef _TEST_UTILS_HPP_
|
|
|
|
#define _TEST_UTILS_HPP_
|
|
|
|
|
2015-12-15 13:55:43 +01:00
|
|
|
#include "opencv2/core/hal/intrin.hpp"
|
2015-08-27 15:53:44 +02:00
|
|
|
#include "opencv2/ts.hpp"
|
|
|
|
#include <ostream>
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
template <typename R> struct Data;
|
|
|
|
template <int N> struct initializer;
|
|
|
|
|
|
|
|
template <> struct initializer<16>
|
|
|
|
{
|
|
|
|
template <typename R> static R init(const Data<R> & d)
|
|
|
|
{
|
|
|
|
return R(d[0], d[1], d[2], d[3], d[4], d[5], d[6], d[7], d[8], d[9], d[10], d[11], d[12], d[13], d[14], d[15]);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
template <> struct initializer<8>
|
|
|
|
{
|
|
|
|
template <typename R> static R init(const Data<R> & d)
|
|
|
|
{
|
|
|
|
return R(d[0], d[1], d[2], d[3], d[4], d[5], d[6], d[7]);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
template <> struct initializer<4>
|
|
|
|
{
|
|
|
|
template <typename R> static R init(const Data<R> & d)
|
|
|
|
{
|
|
|
|
return R(d[0], d[1], d[2], d[3]);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
template <> struct initializer<2>
|
|
|
|
{
|
|
|
|
template <typename R> static R init(const Data<R> & d)
|
|
|
|
{
|
|
|
|
return R(d[0], d[1]);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
//==================================================================================================
|
|
|
|
|
|
|
|
template <typename R> struct Data
|
|
|
|
{
|
|
|
|
typedef typename R::lane_type LaneType;
|
|
|
|
Data()
|
|
|
|
{
|
|
|
|
for (int i = 0; i < R::nlanes; ++i)
|
|
|
|
d[i] = (LaneType)(i + 1);
|
|
|
|
}
|
|
|
|
Data(LaneType val)
|
|
|
|
{
|
|
|
|
fill(val);
|
|
|
|
}
|
|
|
|
Data(const R & r)
|
|
|
|
{
|
|
|
|
*this = r;
|
|
|
|
}
|
|
|
|
operator R ()
|
|
|
|
{
|
|
|
|
return initializer<R::nlanes>().init(*this);
|
|
|
|
}
|
|
|
|
Data<R> & operator=(const R & r)
|
|
|
|
{
|
|
|
|
v_store(d, r);
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
template <typename T> Data<R> & operator*=(T m)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < R::nlanes; ++i)
|
|
|
|
d[i] *= (LaneType)m;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
template <typename T> Data<R> & operator+=(T m)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < R::nlanes; ++i)
|
|
|
|
d[i] += (LaneType)m;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
void fill(LaneType val)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < R::nlanes; ++i)
|
|
|
|
d[i] = val;
|
|
|
|
}
|
|
|
|
void reverse()
|
|
|
|
{
|
|
|
|
for (int i = 0; i < R::nlanes / 2; ++i)
|
|
|
|
std::swap(d[i], d[R::nlanes - i - 1]);
|
|
|
|
}
|
|
|
|
const LaneType & operator[](int i) const
|
|
|
|
{
|
|
|
|
CV_Assert(i >= 0 && i < R::nlanes);
|
|
|
|
return d[i];
|
|
|
|
}
|
|
|
|
LaneType & operator[](int i)
|
|
|
|
{
|
|
|
|
CV_Assert(i >= 0 && i < R::nlanes);
|
|
|
|
return d[i];
|
|
|
|
}
|
|
|
|
const LaneType * mid() const
|
|
|
|
{
|
|
|
|
return d + R::nlanes / 2;
|
|
|
|
}
|
|
|
|
LaneType * mid()
|
|
|
|
{
|
|
|
|
return d + R::nlanes / 2;
|
|
|
|
}
|
|
|
|
bool operator==(const Data<R> & other) const
|
|
|
|
{
|
|
|
|
for (int i = 0; i < R::nlanes; ++i)
|
|
|
|
if (d[i] != other.d[i])
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
void clear()
|
|
|
|
{
|
|
|
|
fill(0);
|
|
|
|
}
|
|
|
|
bool isZero() const
|
|
|
|
{
|
|
|
|
return isValue(0);
|
|
|
|
}
|
|
|
|
bool isValue(uchar val) const
|
|
|
|
{
|
|
|
|
for (int i = 0; i < R::nlanes; ++i)
|
|
|
|
if (d[i] != val)
|
|
|
|
return false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
LaneType d[R::nlanes];
|
|
|
|
};
|
|
|
|
|
|
|
|
template<typename R> struct AlignedData
|
|
|
|
{
|
|
|
|
Data<R> CV_DECL_ALIGNED(16) a; // aligned
|
|
|
|
char dummy;
|
|
|
|
Data<R> u; // unaligned
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename R> std::ostream & operator<<(std::ostream & out, const Data<R> & d)
|
|
|
|
{
|
|
|
|
out << "{ ";
|
|
|
|
for (int i = 0; i < R::nlanes; ++i)
|
|
|
|
{
|
|
|
|
// out << std::hex << +V_TypeTraits<typename R::lane_type>::reinterpret_int(d.d[i]);
|
|
|
|
out << +d.d[i];
|
|
|
|
if (i + 1 < R::nlanes)
|
|
|
|
out << ", ";
|
|
|
|
}
|
|
|
|
out << " }";
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|