Skip to content
DarkKaiser의 블로그
DarkKaiser의 블로그
  • 개발 관련 자료(노션)
  • Raspberry Pi(노션)
  • WD My Cloud(노션)
  • GitHub
DarkKaiser의 블로그

실수형에서 정수형 형변환 성능 높이기

DarkKaiser, 2007년 6월 12일2023년 9월 4일
일반적으로 실수형에서 정수형으로 형변환을 하는 경우가 종종 있다. 이때 보통 묵시적으로 컴파일러가 알아서 해 줄수 있지만 이렇게 할 경우에 속도가 상당히 느리다. 한두번은 빠르게 느껴져도 이게 백만번, 천만번일 경우 형변환 부분에서 전체 함수의 90%까지 잡아먹을 수도 있다. 이럴경우 아래의 코드를 이용하여 성능을 30% 정도 끌어올릴 수 있다.
이때, 주의할 점은 아래의 함수를 이용한 경우 실수형은 반올림을 행한다는 것이다. 이 점을 주의하자~

우선 아래의 매크로를 선언한다.

#ifdef __BIGENDIAN__ 
#   define FTOI_LONG reserved, l 
#else 
#   define FTOI_LONG l 
#endif
#define USE_FTOI union{ double r; struct { long FTOI_LONG; } l; } __ftoitmp;
#define OP_FTOI(val) (((__ftoitmp.r=(val)+((((65536.*65536.*16.)+(65536.*.5))*65536.)) ), __ftoitmp.l.l-0x80000000L))

위의 매크로를 선언하고 나서, 형변환을 하려는 함수의 처음에 아래의 코드를 집어넣는다.

register USE_FTOI

그리고 실제 형변환은 아래와 같이 한다. 아래 코드의 경우 반올림을 버리기 위해서 일부러 0.5를 빼고있는것을 볼 수 있다.

i_orgc = OP_FTOI(r_orgc - .5f);
C/C++/VC++ 형변환C++VC성능

글 내비게이션

Previous post
Next post

답글 남기기 응답 취소

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다

최신 글

  • AssertJ 소개testCompile ‘org.assertj:assertj-core:3.6.2’ 2017년 9월 14일
  • 자주 사용되는 Lombok 어노테이션 2017년 9월 14일
  • 유니코드 #3 2017년 9월 14일
  • 유니코드 #2 2017년 9월 14일
  • 유니코드 #1 2017년 9월 14일

최신 댓글

    카테고리

    • 개인 자료 (1)
      • 일기 (1)
    • 주절주절 (7)
    • 프로그래밍 갤러리 (16)
    • 프로그래밍 언어 (186)
      • Java (29)
      • C/C++/VC++ (114)
      • C# (11)
      • Visual Basic (6)
      • 안드로이드 (9)
      • Objective-C (5)
      • JavaScript (4)
      • JSP/Servlet (2)
      • Python (4)
      • 어셈블러 (1)
    • 개발++ (44)
      • Book (11)
        • Joel On Software (10)
      • 프로젝트 관리 (6)
      • Maven (1)
      • 디버깅 (1)
      • DirectX (1)
      • Silverlight (1)
      • RESTful (1)
      • Hacking (1)
      • WDM (4)
      • VoIP (5)
      • 기타 (1)
    • 개발 도구 (15)
      • eclipse (14)
      • Sublime Text (1)
    • 네트워크 (7)
    • 설치 및 배포 (7)
      • InstallShield (2)
      • NSIS (4)
    • 버전 관리 (9)
      • Git (2)
      • CVS (2)
      • Subversion (5)
    • 데이터베이스 (7)
      • Oracle (3)
      • Sybase (2)
      • MS-SQL (2)
    • 단위테스트 (3)
      • JUnit (1)
      • NUnit (2)
    • 버그추적시스템 (2)
      • mantis (2)
    • 운영체제 (7)
      • Windows (5)
      • 리눅스 (2)
    • WAS (3)
      • WebLogic (3)
    • 디자인패턴 (1)
    • 디지털 이미지 프로세싱 (16)

    태그

    ArrayList BMP CAB CAB 파일 CD-ROM COM DCOM Downcasting Encoding for each GetLastError() IHTMLDocument2 InstallShield Internet Explorer JDT LinkedList Lokbok netsh OCX Python SAX setup SVN toolbar TR1 unicows Upcasting VisualStudio WAVE XP 테마 내장 객체 다국어 레이아웃 로그 리소스 리팩토링 바이트 스트림 배열 버전관리 서브클래싱 스트림 시스템 에러메시지 유니코드 임시파일 입력 스트림

    메타

    • 로그인
    • 엔트리 피드
    • 댓글 피드
    • WordPress.org
    ©2025 DarkKaiser의 블로그 | WordPress Theme by SuperbThemes