%PDF- %PDF-
Direktori : /lib/python3/dist-packages/pythran/pythonic/numpy/ |
Current File : //lib/python3/dist-packages/pythran/pythonic/numpy/average.hpp |
#ifndef PYTHONIC_NUMPY_AVERAGE_HPP #define PYTHONIC_NUMPY_AVERAGE_HPP #include "pythonic/include/numpy/average.hpp" #include "pythonic/numpy/asarray.hpp" #include "pythonic/numpy/sum.hpp" PYTHONIC_NS_BEGIN namespace numpy { template <class E> auto average(E const &expr, types::none_type const &axis) -> decltype(sum(expr, axis) / 1.) { return sum(expr, axis) / double(expr.flat_size()); } template <class E> auto average(E const &expr, long axis) -> decltype(sum(expr, axis) / 1.) { auto shape = sutils::getshape(expr); return sum(expr, axis) / double(shape[axis]); } template <class E, class W> auto average(E const &expr, types::none_type const &axis, W const &weights) -> decltype(average(expr *asarray(weights) / average(asarray(weights)))) { auto aweights = asarray(weights); auto weighted_expr = expr * aweights / average(aweights); return average(weighted_expr); } } PYTHONIC_NS_END #endif