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