%PDF- %PDF-
| Direktori : /proc/self/root/lib/python3/dist-packages/pythran/pythonic/numpy/ |
| Current File : //proc/self/root/lib/python3/dist-packages/pythran/pythonic/numpy/atleast_3d.hpp |
#ifndef PYTHONIC_NUMPY_ATLEAST3D_HPP
#define PYTHONIC_NUMPY_ATLEAST3D_HPP
#include "pythonic/include/numpy/atleast_3d.hpp"
#include "pythonic/numpy/asarray.hpp"
PYTHONIC_NS_BEGIN
namespace numpy
{
template <class T>
typename std::enable_if<
types::is_dtype<T>::value,
types::ndarray<T, types::pshape<std::integral_constant<long, 1>,
std::integral_constant<long, 1>,
std::integral_constant<long, 1>>>>::type
atleast_3d(T t)
{
return {types::pshape<std::integral_constant<long, 1>,
std::integral_constant<long, 1>,
std::integral_constant<long, 1>>(),
t};
}
template <class T>
auto atleast_3d(T const &t) -> typename std::enable_if<
(!types::is_dtype<T>::value) && (T::value == 1),
types::ndarray<typename T::dtype,
types::pshape<std::integral_constant<long, 1>,
typename std::tuple_element<
0, typename T::shape_t>::type,
std::integral_constant<long, 1>>>>::type
{
auto r = asarray(t);
return r.reshape(
types::pshape<std::integral_constant<long, 1>,
typename std::tuple_element<0, typename T::shape_t>::type,
std::integral_constant<long, 1>>(
std::integral_constant<long, 1>(), r.template shape<0>(),
std::integral_constant<long, 1>()));
}
template <class T>
auto atleast_3d(T const &t) -> typename std::enable_if<
(!types::is_dtype<T>::value) && (T::value == 2),
types::ndarray<
typename T::dtype,
types::pshape<
typename std::tuple_element<0, typename T::shape_t>::type,
typename std::tuple_element<1, typename T::shape_t>::type,
std::integral_constant<long, 1>>>>::type
{
auto r = asarray(t);
return r.reshape(
types::pshape<typename std::tuple_element<0, typename T::shape_t>::type,
typename std::tuple_element<1, typename T::shape_t>::type,
std::integral_constant<long, 1>>(
r.template shape<0>(), r.template shape<1>(),
std::integral_constant<long, 1>()));
}
template <class T>
auto atleast_3d(T const &t) ->
typename std::enable_if<(!types::is_dtype<T>::value) && T::value >= 3,
decltype(asarray(t))>::type
{
return asarray(t);
}
}
PYTHONIC_NS_END
#endif