%PDF- %PDF-
Direktori : /lib/python3/dist-packages/pythran/pythonic/numpy/ |
Current File : //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