2015-01-12 13:20:53 -05:00
|
|
|
#ifndef ATIDLAS_TYPES_H
|
|
|
|
#define ATIDLAS_TYPES_H
|
|
|
|
|
|
|
|
#include "atidlas/cl/cl.hpp"
|
2015-01-19 21:29:47 -05:00
|
|
|
#include "atidlas/exception/unknown_datatype.h"
|
2015-01-12 13:20:53 -05:00
|
|
|
|
|
|
|
namespace atidlas
|
|
|
|
{
|
|
|
|
|
2015-01-18 14:52:45 -05:00
|
|
|
typedef int int_t;
|
|
|
|
|
|
|
|
struct size4
|
|
|
|
{
|
|
|
|
size4(int_t s1, int_t s2 = 1) : _1(s1), _2(s2){ }
|
|
|
|
int_t prod() const { return _1*_2; }
|
|
|
|
bool operator==(size4 const & other) const { return _1==other._1 && _2==other._2; }
|
|
|
|
int_t _1;
|
|
|
|
int_t _2;
|
|
|
|
};
|
|
|
|
inline int_t prod(size4 const & s) { return s._1*s._2; }
|
|
|
|
inline int_t max(size4 const & s) { return std::max(s._1, s._2); }
|
|
|
|
inline int_t min(size4 const & s) { return std::min(s._1, s._2); }
|
|
|
|
|
|
|
|
struct repeat_infos
|
|
|
|
{
|
|
|
|
int_t sub1;
|
|
|
|
int_t sub2;
|
|
|
|
int_t rep1;
|
|
|
|
int_t rep2;
|
|
|
|
};
|
2015-01-12 13:20:53 -05:00
|
|
|
|
|
|
|
|
|
|
|
enum numeric_type
|
|
|
|
{
|
|
|
|
INVALID_NUMERIC_TYPE = 0,
|
|
|
|
CHAR_TYPE,
|
|
|
|
UCHAR_TYPE,
|
|
|
|
SHORT_TYPE,
|
|
|
|
USHORT_TYPE,
|
|
|
|
INT_TYPE,
|
|
|
|
UINT_TYPE,
|
|
|
|
LONG_TYPE,
|
|
|
|
ULONG_TYPE,
|
|
|
|
HALF_TYPE,
|
|
|
|
FLOAT_TYPE,
|
|
|
|
DOUBLE_TYPE
|
|
|
|
};
|
|
|
|
|
|
|
|
inline std::string numeric_type_to_string(numeric_type const & type)
|
|
|
|
{
|
|
|
|
switch (type)
|
|
|
|
{
|
|
|
|
case CHAR_TYPE: return "char";
|
|
|
|
case UCHAR_TYPE: return "uchar";
|
|
|
|
case SHORT_TYPE: return "short";
|
|
|
|
case USHORT_TYPE: return "ushort";
|
|
|
|
case INT_TYPE: return "int";
|
|
|
|
case UINT_TYPE: return "uint";
|
|
|
|
case LONG_TYPE: return "long";
|
|
|
|
case ULONG_TYPE: return "ulong";
|
|
|
|
case FLOAT_TYPE : return "float";
|
|
|
|
case DOUBLE_TYPE : return "double";
|
2015-01-19 21:29:47 -05:00
|
|
|
default : throw unknown_datatype(type);
|
2015-01-12 13:20:53 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
template<class T> struct to_numeric_type;
|
|
|
|
template<> struct to_numeric_type<cl_char> { static const numeric_type value = CHAR_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_uchar> { static const numeric_type value = UCHAR_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_short> { static const numeric_type value = SHORT_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_ushort> { static const numeric_type value = USHORT_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_int> { static const numeric_type value = INT_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_uint> { static const numeric_type value = UINT_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_long> { static const numeric_type value = LONG_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_ulong> { static const numeric_type value = ULONG_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_float> { static const numeric_type value = FLOAT_TYPE; };
|
|
|
|
template<> struct to_numeric_type<cl_double> { static const numeric_type value = DOUBLE_TYPE; };
|
|
|
|
|
|
|
|
inline unsigned int size_of(numeric_type type)
|
|
|
|
{
|
|
|
|
switch (type)
|
|
|
|
{
|
|
|
|
case UCHAR_TYPE:
|
|
|
|
case CHAR_TYPE: return 1;
|
|
|
|
|
|
|
|
case USHORT_TYPE:
|
|
|
|
case SHORT_TYPE:
|
|
|
|
case HALF_TYPE: return 2;
|
|
|
|
|
|
|
|
case UINT_TYPE:
|
|
|
|
case INT_TYPE:
|
|
|
|
case FLOAT_TYPE: return 4;
|
|
|
|
|
|
|
|
case ULONG_TYPE:
|
|
|
|
case LONG_TYPE:
|
|
|
|
case DOUBLE_TYPE: return 8;
|
|
|
|
|
2015-01-19 21:29:47 -05:00
|
|
|
default: throw unknown_datatype(type);
|
2015-01-12 13:20:53 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
enum expression_type
|
|
|
|
{
|
|
|
|
SCALAR_AXPY_TYPE,
|
|
|
|
VECTOR_AXPY_TYPE,
|
|
|
|
MATRIX_AXPY_TYPE,
|
|
|
|
REDUCTION_TYPE,
|
|
|
|
ROW_WISE_REDUCTION_TYPE,
|
|
|
|
COL_WISE_REDUCTION_TYPE,
|
|
|
|
MATRIX_PRODUCT_NN_TYPE,
|
|
|
|
MATRIX_PRODUCT_TN_TYPE,
|
|
|
|
MATRIX_PRODUCT_NT_TYPE,
|
|
|
|
MATRIX_PRODUCT_TT_TYPE,
|
|
|
|
INVALID_EXPRESSION_TYPE
|
|
|
|
};
|
|
|
|
|
|
|
|
struct slice
|
|
|
|
{
|
|
|
|
slice(int_t _start, int_t _end, int_t _stride = 1) : start(_start), size((_end - _start)/_stride), stride(_stride) { }
|
|
|
|
int_t start;
|
|
|
|
int_t size;
|
|
|
|
int_t stride;
|
|
|
|
};
|
|
|
|
typedef slice _;
|
|
|
|
|
|
|
|
class obj_base{};
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|