%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/expand_dims.hpp

#ifndef PYTHONIC_NUMPY_EXPAND_DIMS_HPP
#define PYTHONIC_NUMPY_EXPAND_DIMS_HPP

#include "pythonic/include/numpy/expand_dims.hpp"
#include "pythonic/utils/functor.hpp"
#include "pythonic/include/utils/array_helper.hpp"
#include "pythonic/numpy/asarray.hpp"

PYTHONIC_NS_BEGIN

namespace numpy
{
  template <typename T>
  types::ndarray<typename T::dtype, types::array<long, T::value + 1>>
  expand_dims(T const &input, int axis)
  {
    const long N = T::value;
    if (axis == -1)
      axis += N + 1;
    types::array<long, N + 1> dim_array;
    auto in_shape = sutils::getshape(input);
    long ii, jj;
    for (ii = jj = 0; ii < N + 1; ii++) {
      if (ii == axis) {
        dim_array[ii] = 1;
      } else {
        dim_array[ii] = in_shape[jj++];
      }
    }

    return numpy::functor::asarray{}(input).reshape(dim_array);
  }
}
PYTHONIC_NS_END

#endif

Zerion Mini Shell 1.0