2015-04-29 15:50:57 -04:00
|
|
|
#ifndef ISAAC_TYPES_H
|
|
|
|
#define ISAAC_TYPES_H
|
2015-01-12 13:20:53 -05:00
|
|
|
|
2015-01-27 16:14:02 -05:00
|
|
|
#include <CL/cl.hpp>
|
2015-02-01 23:56:05 -05:00
|
|
|
#include <list>
|
2015-04-29 15:50:57 -04:00
|
|
|
#include "isaac/exception/unknown_datatype.h"
|
2015-01-12 13:20:53 -05:00
|
|
|
|
2015-04-29 15:50:57 -04:00
|
|
|
namespace isaac
|
2015-01-12 13:20:53 -05:00
|
|
|
{
|
|
|
|
|
2015-01-18 14:52:45 -05:00
|
|
|
typedef int int_t;
|
|
|
|
|
|
|
|
struct size4
|
|
|
|
{
|
2015-04-29 15:50:57 -04:00
|
|
|
size4(int_t s0, int_t s1 = 1, int_t s2 = 1, int_t s3 = 1)
|
|
|
|
{
|
|
|
|
data_[0] = s0;
|
|
|
|
data_[1] = s1;
|
|
|
|
data_[2] = s2;
|
|
|
|
data_[3] = s3;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool operator==(size4 const & other) const { return (*this)[0]==other[0] && (*this)[1]==other[1]; }
|
|
|
|
int_t operator[](size_t i) const { return data_[i]; }
|
|
|
|
int_t & operator[](size_t i) { return data_[i]; }
|
|
|
|
private:
|
|
|
|
int_t data_[4];
|
2015-01-18 14:52:45 -05:00
|
|
|
};
|
2015-04-29 15:50:57 -04:00
|
|
|
|
|
|
|
inline int_t prod(size4 const & s) { return s[0]*s[1]; }
|
|
|
|
inline int_t max(size4 const & s) { return std::max(s[0], s[1]); }
|
|
|
|
inline int_t min(size4 const & s) { return std::min(s[0], s[1]); }
|
2015-01-18 14:52:45 -05:00
|
|
|
|
|
|
|
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,
|
2015-01-29 15:19:40 -05:00
|
|
|
// BOOL_TYPE,
|
2015-01-12 13:20:53 -05:00
|
|
|
CHAR_TYPE,
|
|
|
|
UCHAR_TYPE,
|
|
|
|
SHORT_TYPE,
|
|
|
|
USHORT_TYPE,
|
|
|
|
INT_TYPE,
|
|
|
|
UINT_TYPE,
|
|
|
|
LONG_TYPE,
|
|
|
|
ULONG_TYPE,
|
2015-01-29 15:19:40 -05:00
|
|
|
// HALF_TYPE,
|
2015-01-12 13:20:53 -05:00
|
|
|
FLOAT_TYPE,
|
|
|
|
DOUBLE_TYPE
|
|
|
|
};
|
|
|
|
|
|
|
|
inline std::string numeric_type_to_string(numeric_type const & type)
|
|
|
|
{
|
|
|
|
switch (type)
|
|
|
|
{
|
2015-01-29 15:19:40 -05:00
|
|
|
// case BOOL_TYPE: return "bool";
|
2015-01-12 13:20:53 -05:00
|
|
|
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";
|
2015-01-29 15:19:40 -05:00
|
|
|
// case HALF_TYPE : return "half";
|
2015-01-12 13:20:53 -05:00
|
|
|
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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
inline unsigned int size_of(numeric_type type)
|
|
|
|
{
|
|
|
|
switch (type)
|
|
|
|
{
|
2015-01-29 15:19:40 -05:00
|
|
|
// case BOOL_TYPE:
|
2015-01-12 13:20:53 -05:00
|
|
|
case UCHAR_TYPE:
|
|
|
|
case CHAR_TYPE: return 1;
|
|
|
|
|
2015-01-29 15:19:40 -05:00
|
|
|
// case HALF_TYPE:
|
2015-01-12 13:20:53 -05:00
|
|
|
case USHORT_TYPE:
|
2015-01-29 15:19:40 -05:00
|
|
|
case SHORT_TYPE: return 2;
|
2015-01-12 13:20:53 -05:00
|
|
|
|
|
|
|
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
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-04 21:23:05 -04:00
|
|
|
template<size_t size, bool is_unsigned>
|
|
|
|
struct to_int_numeric_type_impl;
|
|
|
|
|
|
|
|
#define ISAAC_INSTANTIATE_INT_TYPE_IMPL(SIZE, IS_UNSIGNED, TYPE) \
|
|
|
|
template<> struct to_int_numeric_type_impl<SIZE, IS_UNSIGNED> { static const numeric_type value = TYPE; }
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(1, false, CHAR_TYPE);
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(2, false, SHORT_TYPE);
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(4, false, INT_TYPE);
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(8, false, LONG_TYPE);
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(1, true, UCHAR_TYPE);
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(2, true, USHORT_TYPE);
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(4, true, UINT_TYPE);
|
|
|
|
ISAAC_INSTANTIATE_INT_TYPE_IMPL(8, true, ULONG_TYPE);
|
|
|
|
#undef ISAAC_INSTANTIATE_INT_TYPE_IMPL
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
struct to_int_numeric_type
|
|
|
|
{ static const numeric_type value = to_int_numeric_type_impl<sizeof(T), std::is_unsigned<T>::value>::value; };
|
|
|
|
|
|
|
|
template<class T> struct to_numeric_type { static const numeric_type value = to_int_numeric_type<T>::value; };
|
|
|
|
template<> struct to_numeric_type<float> { static const numeric_type value = FLOAT_TYPE; };
|
|
|
|
template<> struct to_numeric_type<double> { static const numeric_type value = DOUBLE_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 _;
|
|
|
|
|
2015-02-04 22:06:15 -05:00
|
|
|
class array_base{ };
|
|
|
|
|
2015-01-12 13:20:53 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
#endif
|