:: 게시판
:: 이전 게시판
|
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다. 통합 규정을 준수해 주십시오. (2015.12.25.)
통합규정 1.3 이용안내 인용"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
17/05/09 11:37
printf 계열에서 float를 출력하는 형식 지정자는 없습니다.
printf 내부에서는 %e, %f를 double 자료형으로 처리합니다. 실수 underflow를 확인하고 싶으시면, double num1 = DLB_MIN / 2; printf("%en", num1); 하시면 될거에요 본문의 코드를 통해 해당 값이 왜 나왔는지 이해하고 싶으시면, IEEE 754 관련 정보를 찾아 보시면 될겁니다.
17/05/09 12:09
한화이글스님이 printf로 float이 double로 넘어가서 생기는 문제때문에 생길 수 있는 문제에 대해 답을 주셨으니
코드에서 사용하신 float 형과 사용한 macro 에 대해 조금 더 설명하면 FLT_MIN 값은 minimum normalized positive floating-point number 값으로 float로 표현 가능한 범위의 값의 범위 중에서 nomalize 해서 표현할때 갖을 수 있는 최솟값입니다. 실수형의 normalized 표현등은 책이나 관련된 키워드로 검색해 보시면 될 것 같습니다. 실제 float값의 최소값은 FLT_MIN(1.175494351e-38F) 보다 더 작은 FLT_TRUE_MIN(1.401298464e-45F)값입니다. 이 값을 기준으로 10.f로 나누시면 기대하시는 값 0.000..를 얻으실 수 있습니다.
|