%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /lib/python3/dist-packages/pythran/pythonic/numpy/
Upload File :
Create Path :
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

Zerion Mini Shell 1.0