정밀한 퍼포먼스 체크

조회 수 7184 추천 수 128 2002.10.19 04:02:23
예전에 하이텔 게제동 강좌게시판에 올렸던 글입니다.


제  목:[PROG] 정밀한 퍼포먼스 체크를 위한 짤막한 강좌   관련자료:없음  [502]
보낸이:유영천  (yuchi   )  2000-07-27 01:13  조회:1282
GetTickCoun()를 쓰면 밀리세컨드로 시간을 측정할 수 있습니다.
하지만 밀리세컨드는 컴퓨터한테는 엄청 긴 시간이죠.
이보다 정밀하게 시간을 측정할 수 있는 방법이 있습니다.
아시는 분들은 이미 아시겠지만...모르시는 분들을 위해 간단
하게 적어보도록 하겠습니다.

펜터임 이상의 cpu는 입력된 클럭을 카운트하고 있습니다.rdtsc란 명
령을 사용하면 클럭을 카운트 하는 time stamp counter의 내용을
edx:eax 레지스터로 저장해줍니다. time stamp counter는 64비트
로서 하위 dword는 eax에, 상위 dword는 edx에 저장됩니다.

설명 길게 할 것 없고 예제를 보도록 합시다.
우선 많이 쓰는 수학함수인 sin함수가 몇클럭 정도를 잡아먹는지
체크해보도록 하죠.

#include <math.h>
#include <stdio.h>
#include <windows.h>

int main()
{
   DWORD        dwhi;
   DWORD        dwlo;
        
   __asm
   {
        rdtsc                   ; 클럭카운트를 edx:eax레지스터에 저장
        mov     dwhi,edx        ;상위 dword 메모리에 백업
        mov     dwlo,eax        ;하위 dword 메모리에 백업      
   }
        
   sin(0.5f);                   // sin()함수 수행
        
   __asm
   {
        rdtsc                   ; 클럭카운트를 edx:eax레지스터에 저장
        sub     eax,dwlo        ; 현재 클럭카운트에서 sin()수행 전의
        sub     edx,dwhi        ; 카운트를 빼서 몇 클럭을 소모했는지체크

        mov     dwlo,eax        ; 하위 dword 값 저장
        mov     dwhi,edx        ; 상위 dword값 저장

        }
        printf( "%dn",dwlo);           // 결과 출력
        
        return 0;
   }

간단한 예제죠? 컴파일 해서 돌려보면 제 pc에선 1700-1900 사이가 나오는군요.
곧 평균 1800클럭 정도 소모한단 얘기죠.하위dword값만 놓고 계산했는데 만약
하위 dword에서 자리 올림으로 상위 dword값이 바뀌었다면 뺄샘은 다르게 해야할겁니다.귀찮아서 일단 skip했습니다.거의 대부분의 경우는 하위 32비트만 체크하면 됩니다.

또한 dwlo,dwhi로 mov할때의 클럭소모는 일단 무시했습니다.정확히 몇 클럭
나올진 모르겠습니다.했을 경우 cpu와 동일클럭 캐쉬를 가지고 있는 CPU에서 캐쉬히트했을 경우 1-2클럭 정도 소모되고 하프클럭 캐쉬의 cpu라면 좀 더 걸립니다.캐쉬 미스했을 경우는 수십에서 수백클럭 소모됩니다.

GetTickCount()가 너무 무디다고 생각하신 분들, rdtsc로 정밀하게 체크하세요.
그럼...

ps:dwLo,dwHi
파일 첨부

여기에 파일을 끌어 놓거나 파일 첨부 버튼을 클릭하세요.

파일 크기 제한 : 0MB (허용 확장자 : *.*)

0개 첨부 됨 ( / )
List of Articles
번호 제목 글쓴이 날짜 조회 수
43 [re] 오랜만에 질문 하나 드립니다~ [1] 여치 2003-08-08 7193
42 [질문] 게임 hongiro 2003-07-07 12297
41 [re] [질문] 게임 [1] 여치 2003-07-08 8310
40 [re] [질문] 게임 [2] hongiro 2003-07-08 6641
39 [퍼온글] 프로그래밍의 도 여치 2003-06-20 6141
38 NPC 길찾기 시스템과 맵구조에 대한 질문이에요 ^^ [2] 풍이 2003-06-03 7588
37 [펌] 어릴적 기억 [1] 청년 2003-03-18 6225
36 마소의 도전...X-box의 후기 베지타 2003-01-15 9120
35 swicth 문에 대한 질문 [2] hongiro 2002-11-14 6358
34 direct3d8.0 hongiro 2002-11-07 10214
33 [re] direct3d8.0 여치 2002-11-07 5533
32 [필독] 프로그래밍, 신이 내린 최고의 노가다 [1] 베지타 2002-10-21 7758
31 지금 게임학원에 hongiro 2002-10-20 6325
30 [re] 지금 게임학원에 [1] 여치 2002-10-20 6171
29 멀티스레드 프로그래밍에서 동기화는 왜 필요할까? [1] 여치 2002-10-19 5848
28 가상함수는 어떻게 호출되나? 여치 2002-10-19 6657
27 메모리카피는 어떻게 이루어지나? [3] 여치 2002-10-19 9538
» 정밀한 퍼포먼스 체크 여치 2002-10-19 7184
25 Overlapped I/O(중첩입출력)란 무엇인가? 여치 2002-10-19 31150
24 sse와 정수 레지스터의 연산속도 비교 여치 2002-10-19 5421



XE Login

天安門大屠殺 六四天安門事件 反右派鬥爭 大躍進政策 文化大革命 六四天安門事件 The Tiananmen Square protests of 1989 天安門大屠殺 The Tiananmen Square Massacre 反右派鬥爭 The Anti-Rightist Struggle 大躍進政策 The Great Leap Forward 文化大革命 The Great Proletarian Cultural Revolution 人權 Human Rights 民運 Democratization 自由 Freedom 獨立 Independence 多黨制 Multi-party system 民主 言論 思想 反共 反革命 抗議 運動 騷亂 暴亂 騷擾 擾亂 抗暴 平反 維權 示威游行 法輪功 Falun Dafa 李洪志 法輪大法 大法弟子 強制斷種 強制堕胎 民族淨化 人體實驗 胡耀邦 趙紫陽 魏京生 王丹 還政於民 和平演變 激流中國 北京之春 大紀元時報 九評論共産黨 獨裁 專制 壓制 統一 監視 鎮壓 迫害 侵略 掠奪 破壞 拷問 屠殺 肅清 活摘器官 障テ社會 誘拐 買賣人口 遊進 走私 毒品 賣淫 春畫 賭博 六合彩 台灣 臺灣 Taiwan Formosa 中華民國 Republic of China 西藏 土伯特 唐古特 Tibet 達償ワ喇嘛 Dalai Lama 新疆維吾爾自治區 The Xinjiang Uyghur Autonomous Region free tibet