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

#ifndef PYTHONIC_NUMPY_AROUND_HPP
#define PYTHONIC_NUMPY_AROUND_HPP

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

#include "pythonic/numpy/rint.hpp"
#include "pythonic/numpy/power.hpp"
#include "pythonic/numpy/asarray.hpp"
#include "pythonic/numpy/floor_divide.hpp"
#include "pythonic/numpy/float64.hpp"
#include "pythonic/numpy/multiply.hpp"

PYTHONIC_NS_BEGIN

namespace numpy
{
  // fast path
  template <class E>
  auto around(E &&a) -> decltype(functor::rint{}(std::forward<E>(a)))
  {
    return functor::rint{}(std::forward<E>(a));
  }

  // generic floating point version, pure numpy_expr
  template <class E>
  auto around(E &&a, long decimals) -> typename std::enable_if<
      !std::is_integral<
          typename types::dtype_of<typename std::decay<E>::type>::type>::value,
      decltype(functor::rint{}(functor::multiply{}(
                   std::forward<E>(a),
                   std::declval<typename types::dtype_of<
                       typename std::decay<E>::type>::type>())) /
               std::declval<typename types::dtype_of<
                   typename std::decay<E>::type>::type>())>::type
  {
    typename types::dtype_of<typename std::decay<E>::type>::type const fact =
        functor::power{}(10., decimals);
    return functor::rint{}(functor::multiply{}(std::forward<E>(a), fact)) /
           fact;
  }

  // the integer version is only relevant when decimals < 0
  template <class E>
  auto around(E &&a, long decimals) -> typename std::enable_if<
      std::is_integral<
          typename types::dtype_of<typename std::decay<E>::type>::type>::value,
      decltype(numpy::functor::floor_divide{}(
                   functor::float64{}(std::forward<E>(a)),
                   std::declval<typename types::dtype_of<
                       typename std::decay<E>::type>::type>()) *
               std::declval<typename types::dtype_of<
                   typename std::decay<E>::type>::type>())>::type
  {
    typename types::dtype_of<typename std::decay<E>::type>::type const fact =
        functor::power{}(10L, std::max(0L, -decimals));
    return pythonic::numpy::functor::floor_divide{}(
               functor::float64{}(std::forward<E>(a)), fact) *
           fact;
  }
}
PYTHONIC_NS_END

#endif

Zerion Mini Shell 1.0