C++에서 부동 소수점 숫자의 정밀도 설정

Jinku Hu 2023년10월12일
  1. std::setprecision을 사용하여 C++에서 부동 소수점 숫자의 정밀도 설정
  2. std::floorstd::ceil을 사용하여 부동 소수점 숫자의 정밀도 수정
  3. std::roundstd::lround를 사용하여 부동 소수점 숫자의 정밀도 수정
C++에서 부동 소수점 숫자의 정밀도 설정

이 기사에서는 C++에서 부동 소수점 숫자의 정밀도를 설정하는 방법에 대한 몇 가지 방법을 설명합니다.

std::setprecision을 사용하여 C++에서 부동 소수점 숫자의 정밀도 설정

std::setprecision은 입력 / 출력 스트림을 형식화하는 데 사용할 수있는 STL I/O 조작기 라이브러리의 일부입니다. setprecision은 부동 소수점 숫자의 정밀도를 변경하며 소수점 뒤에 표시 할 숫자 자릿수를 지정하는 정수 매개 변수 만 사용합니다. 즉, 부동 소수점 숫자에 대해 암시 적으로 가정되는 기본 정밀도는 쉼표 뒤의 6 자리입니다. 그럼에도 불구하고 숫자가 너무 적고 조작자가 사용되지 않은 경우 때때로 부동 소수점이 과학적 표기법으로 표시 될 수 있습니다. 다음 예제 코드에서와 같이 이러한 숫자는 모든 유효 자릿수를 잃고 0으로 나타날 수 있습니다.

#include <iomanip>
#include <iostream>
#include <vector>

using std::cout;
using std::endl;
using std::fixed;
using std::setprecision;
using std::vector;

int main() {
  vector<double> d_vec = {123.231,       2.2343, 0.012,
                          26.9491092019, 113,    0.000000234};

  for (auto &i : d_vec) {
    cout << i << " | ";
  }
  cout << endl;

  for (auto &i : d_vec) {
    cout << setprecision(3) << i << " | ";
  }
  cout << endl;

  return EXIT_SUCCESS;
}

출력:

123.231 | 2.2343 | 0.012 | 26.9491 | 113 | 2.34e-07 |
123.231 | 2.234 | 0.012 | 26.949 | 113.000 | 0.000 |

std::floorstd::ceil을 사용하여 부동 소수점 숫자의 정밀도 수정

std::floorstd::ceil 함수는 원래 C 표준 라이브러리에서 구현 된<cmath>헤더에서 제공됩니다. ceil함수는 유일한 인수로 전달 된 부동 소수점보다 크거나 같은 가장 작은 정수 값을 계산합니다. 반면 floor는 인수보다 작거나 같은 가장 큰 정수 값을 계산합니다. 이러한 함수는float,doublelong double 유형에 대해 정의됩니다.

#include <cmath>
#include <iomanip>
#include <iostream>
#include <vector>

using std::cout;
using std::endl;
using std::fixed;
using std::vector;

int main() {
  vector<double> d_vec = {123.231,       2.2343, 0.012,
                          26.9491092019, 113,    0.000000234};

  for (auto &i : d_vec) {
    cout << i << " | ";
  }
  cout << endl;

  for (auto &i : d_vec) {
    cout << fixed << std::ceil(i) << " | ";
  }
  cout << endl;

  for (auto &i : d_vec) {
    cout << fixed << std::floor(i) << " | ";
  }
  cout << endl;

  return EXIT_SUCCESS;
}

출력:

123.231 | 2.2343 | 0.012 | 26.9491 | 113 | 2.34e-07 |
124.000000 | 3.000000 | 1.000000 | 27.000000 | 113.000000 | 1.000000 |
123.000000 | 2.000000 | 0.000000 | 26.000000 | 113.000000 | 0.000000 |

std::roundstd::lround를 사용하여 부동 소수점 숫자의 정밀도 수정

또는std::roundstd::round를 사용하여 0에서 멀어지는 가장 가까운 정수 값을 계산할 수 있습니다. 이러한 함수는 페이지에서 자세히 설명하는 부동 소수점 산술 관련 오류를 발생시킬 수 있습니다.

#include <cmath>
#include <iomanip>
#include <iostream>
#include <vector>

using std::cout;
using std::endl;
using std::fixed;
using std::vector;

int main() {
  vector<double> d_vec = {123.231,       2.2343, 0.012,
                          26.9491092019, 113,    0.000000234};

  for (auto &i : d_vec) {
    cout << i << " | ";
  }
  cout << endl;

  for (auto &i : d_vec) {
    cout << fixed << std::round(i) << " | ";
  }
  cout << endl;

  for (auto &i : d_vec) {
    cout << fixed << std::lround(i) << " | ";
  }
  cout << endl;

  return EXIT_SUCCESS;
}

출력:

123.231 | 2.2343 | 0.012 | 26.9491 | 113 | 2.34e-07 |
123.000000 | 2.000000 | 0.000000 | 27.000000 | 113.000000 | 0.000000 |
123 | 2 | 0 | 27 | 113 | 0 |
작가: Jinku Hu
Jinku Hu avatar Jinku Hu avatar

Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.

LinkedIn Facebook

관련 문장 - C++ Float