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

#ifndef PYTHONIC_NUMPY_EDIFF1D_HPP
#define PYTHONIC_NUMPY_EDIFF1D_HPP

#include "pythonic/include/numpy/ediff1d.hpp"

#include "pythonic/numpy/asarray.hpp"

PYTHONIC_NS_BEGIN

namespace numpy
{
  template <class E>
  types::ndarray<typename E::dtype, types::pshape<long>> ediff1d(E const &expr)
  {
    auto arr = asarray(expr);
    long n = arr.flat_size() - 1;
    types::ndarray<typename E::dtype, types::pshape<long>> out(
        types::pshape<long>(n), builtins::None);
    // Compute adjacent difference except for the first element
    std::adjacent_difference(arr.fbegin() + 1, arr.fend(), out.fbegin());
    // First element can be done now
    (*out.fbegin()) = *(arr.fbegin() + 1) - *(arr.fbegin());
    return out;
  }

  template <class E>
  auto ediff1d(types::list<E> const &expr) -> decltype(ediff1d(asarray(expr)))
  {
    return ediff1d(asarray(expr));
  }
}
PYTHONIC_NS_END

#endif

Zerion Mini Shell 1.0