%PDF- %PDF-
| Direktori : /proc/thread-self/root/lib/python3/dist-packages/pythran/pythonic/numpy/ |
| Current File : //proc/thread-self/root/lib/python3/dist-packages/pythran/pythonic/numpy/insert.hpp |
#ifndef PYTHONIC_NUMPY_INSERT_HPP
#define PYTHONIC_NUMPY_INSERT_HPP
#include "pythonic/include/numpy/insert.hpp"
#include "pythonic/utils/functor.hpp"
#include "pythonic/types/ndarray.hpp"
#include "pythonic/types/traits.hpp"
#include "pythonic/builtins/None.hpp"
#include <algorithm>
PYTHONIC_NS_BEGIN
namespace numpy
{
template <class T, class pS, class I, class F>
typename std::enable_if<types::is_iterable<I>::value &&
types::is_iterable<F>::value,
types::ndarray<T, types::pshape<long>>>::type
insert(types::ndarray<T, pS> in, I const &indices, F const &data,
types::none_type axis)
{
types::ndarray<T, types::pshape<long>> out(
types::pshape<long>(long(
in.flat_size() + std::min(indices.flat_size(), data.flat_size()))),
builtins::None);
auto out_iter = out.fbegin();
auto in_iter = in.fbegin();
auto data_iter = data.begin();
for (long index : indices) {
out_iter = std::copy(in_iter, in.fbegin() + index, out_iter);
*out_iter++ = *data_iter++;
in_iter = in.fbegin() + index;
}
std::copy(in_iter, in.fend(), out_iter);
return out;
}
template <class T, class pS, class I, class F>
typename std::enable_if<types::is_iterable<I>::value &&
!types::is_iterable<F>::value,
types::ndarray<T, types::pshape<long>>>::type
insert(types::ndarray<T, pS> in, I const &indices, F const &data,
types::none_type axis)
{
return insert(in, indices, types::list<F>({data}), axis);
}
template <class T, class pS, class I, class F>
typename std::enable_if<!types::is_iterable<I>::value &&
types::is_iterable<F>::value,
types::ndarray<T, types::pshape<long>>>::type
insert(types::ndarray<T, pS> in, I const &indices, F const &data,
types::none_type axis)
{
return insert(in, types::list<I>({indices}), {data}, axis);
}
template <class T, class pS, class I, class F>
typename std::enable_if<!types::is_iterable<I>::value &&
!types::is_iterable<F>::value,
types::ndarray<T, types::pshape<long>>>::type
insert(types::ndarray<T, pS> in, I const &indices, F const &data,
types::none_type axis)
{
return insert(in, types::list<I>({indices}), types::list<F>({data}), axis);
}
template <class E, class... Args>
E insert(E, Args const &...)
{
throw std::runtime_error("insert only partially supported");
}
}
PYTHONIC_NS_END
#endif