Skip to content

Latest commit

 

History

History
70 lines (56 loc) · 1.58 KB

fegetround.md

File metadata and controls

70 lines (56 loc) · 1.58 KB

fegetround

  • cfenv[meta header]
  • std[meta namespace]
  • function[meta id-type]
  • cpp11[meta cpp]
namespace std {
  int fegetround();
}

概要

浮動小数点数の現在の丸め方式を取得する。

戻り値

現在設定されている浮動小数点数の丸め方式を返す。

#include <iostream>
#include <cfenv>

void print_round_mode(int round_mode)
{
  switch (round_mode) {
    case FE_DOWNWARD: std::cout << "downward" << std::endl; break;
    case FE_TONEAREST: std::cout << "to nearest" << std::endl; break;
    case FE_TOWARDZERO: std::cout << "toward zero" << std::endl; break;
    case FE_UPWARD: std::cout << "upward" << std::endl; break;
  }
}

int main()
{
  // デフォルト (FE_TONEAREST)
  print_round_mode(std::fegetround());

  // 切り下げに設定する
  std::fesetround(FE_DOWNWARD);
  print_round_mode(std::fegetround());
}
  • std::fegetround[color ff0000]
  • std::fesetround[link fesetround.md]
  • FE_DOWNWARD[link fe_downward.md]
  • FE_TONEAREST[link fe_tonearest.md]
  • FE_TOWARDZERO[link fe_towardzero.md]
  • FE_UPWARD[link fe_upward.md]

出力

to nearest
downward

バージョン

言語

  • C++11

処理系

  • Clang: 3.0 [mark verified]
  • GCC: 4.3.0 [mark verified]
  • ICC: ??
  • Visual C++: 2013 [mark verified], 2015 [mark verified]
    • コンパイルオプション/fp:strictまたは#pragma fenv_access (on)が必要。さもなくば、正しく動作しないおそれがある。