%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/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