C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 팁&트릭
C++Builder Programming Tip&Tricks
[979] 실수(float)처리를 하는데 EPSILON이라는 것의 잘못 사용하는 예제
이경문 [gilgil] 12220 읽음    2010-04-05 23:40
실수를 처리하면서 EPSILON을 고정시키게 되는 경우 잘못된 예제입니다.
#include 

const float EPSILON = 0.000001f;

int main()
{
  float f = 1.0;
  int count = 0; // 나누기 2를 한 횟수

  // f가 EPSILON 값보다 작을 때까지 계속 줄여 본다.
  while (f < EPSILON)
  {
    f /= 2;
    count++;
  }

  // f를 더욱더 작게 한다.
  f /= 2; count++; 
  f /= 2; count++;
  f /= 2; count++;
  f /= 2; count++;
  f /= 2; count++;
  f /= 2; count++;
  f /= 2; count++;
  f /= 2; count++;
  f /= 2; count++;

  float f1 = f + EPSILON;
  float f2 = f - EPSILON;

  // 나눈 숫자만큼 다시 곱해 준다.
  for (int i = 0; i < count; i++)
  {
    f *= 2;
    f1 *= 2;
    f2 *= 2;
  }

  // 화면에 출력해 본다. 전부다 1.0을 출력하게 될까?
  printf("%f %f %f\n", f, f1, f2);
}


결과
1.000000 1.000512 0.999488


결론 EPSILON을 고정시켜서 실수 처리를 하면 안된다.
째즈토끼 [jazz16]   2010-06-07 18:53 X
while (f > EPSILON) 로 테스트 하셔야할듯..

+ -

관련 글 리스트
979 실수(float)처리를 하는데 EPSILON이라는 것의 잘못 사용하는 예제 이경문 12220 2010/04/05
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.