성능을 측정하기위한 코드중 .. 머가 잘못되었을까요?
글쓴이: jinushun / 작성시간: 화, 2005/12/06 - 3:31오후
struct timeval tv1; struct timeval tv2; gettimeofday(&tv1, NULL); /*수행 코드 등등등*/ gettimeofday(&tv2, NULL); log(tv2.tv_user - tv1.tv_usec) / 1000);
이런식으로 해서 얼마나 걸리었나를 측정하곤합니다.
그런데 가끔가다 - 가 나올때도 있고.
쩝. 다른분들은 시간을 꼭 측정해야할때 어떻게 하시는 지 궁금하네요.
조언 바랍니다.
날씨가 춥습니다. 감기조심하세요
Forums:
당연히도 음수가 나올수 있겠죠.timeval의 tv_usec는 100
당연히도 음수가 나올수 있겠죠.
timeval의 tv_usec는 1000000 즉 1초보다 커질 수 없습니다.
음수가 나오는 경우는 tv1과 tv2사이에서 overflow가 발생해서 tv_sec값이 증가하고 tv_usec가 다시 0부터 다시 시작하는 경우가 일어난 때입니다.
이경우를 처리하던지 아님 tv_sec값을 포함하는 수식을 사용하던지 하시면됩니다.
헉 감사합니다 -_-;기본에 충실하지 못했군요 ㅋㅋ좋은하루되세요
헉 감사합니다 -_-;
기본에 충실하지 못했군요 ㅋㅋ
좋은하루되세요
----------------------------
www.nate.com
----------------------------
log(tv2.tv_usec - tv1.tv_usec) / 1000);
log(tv2.tv_usec - tv1.tv_usec) / 1000);
==>
(double)(tv2.tv_sec +tv2.tv_usec/1000000.0) - (double)(tv2.tv_sec +tv2.tv_usec/1000000.0)
tv_usec의 범위는 0~999,999 입니다. (정수로 u 즉 micro부분을 표현함에 유의)
(0.000000~0.999999초가 인간에게는 친근한 표현이지요)
질문자의 오류인 음수가 나오는 것은 다음과 같은 상황입니다.
측정 1 ) 현재 시각 123.000100 초로 가정
측정 2 ) 현재 시각 124.000001 초로 가정
gettimeofday로 시각을 가져오면 초 및 마이크로 초 부분이 정수로 나뉘어서 들어옵니다.
=> 측정 1)의 경우
tv_sec ==> 123
tv_usec => 100
=>측정 2)의 경우
tv_sec ==> 124
tv_usec => 1
이 경우 질문자의 코드로 계산하면
1 - 100 = -99 가 나오게 될것입니다.
즉, 초 부분을 고려하지 않고 계산해서 그렇습니다.
제대로 계산한다면,
124.000001 - 123.000100 = 0.999901 초가 나오게됩니다.
이를 위해 답변에서는 실수(double)로 환산해서 시간을 계산했습니다.
물론, 정수연산만으로 시간을 계산할 수 있지만, 원리만을 말씀드리기 위함입니다.
댓글 달기