Learn more  » Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Bower components Debian packages RPM packages NuGet packages

neilisaac / torch   python

Repository URL to install this package:

Version: 1.8.0 

/ include / c10 / util / MathConstants.h

#pragma once

#include <c10/macros/Macros.h>
#include <c10/util/BFloat16.h>
#include <c10/util/Half.h>

namespace c10 {
// TODO: Replace me with inline constexpr variable when C++17 becomes available
namespace detail {
template <typename T>
C10_HOST_DEVICE inline constexpr T pi() {
   return static_cast<T>(3.14159265358979323846L);
}

template<>
C10_HOST_DEVICE inline constexpr BFloat16 pi<BFloat16>() {
  // According to https://en.wikipedia.org/wiki/Bfloat16_floating-point_format#Special_values pi is encoded as 4049
  return BFloat16(0x4049, BFloat16::from_bits());
}
template<>
C10_HOST_DEVICE inline constexpr Half pi<Half>() {
  return Half(0x4248, Half::from_bits());
}
} // namespace detail

// TODO: Replace me with std::numbers::pi when C++20 is there
template<typename T>
constexpr T pi = c10::detail::pi<T>();

} // namespace c10