성능을 측정하기위한 코드중 .. 머가 잘못되었을까요?

jinushun의 이미지

struct   timeval   tv1;
struct   timeval   tv2;

gettimeofday(&tv1, NULL);

/*수행 코드 등등등*/

gettimeofday(&tv2, NULL);

log(tv2.tv_user - tv1.tv_usec) / 1000);

이런식으로 해서 얼마나 걸리었나를 측정하곤합니다.
그런데 가끔가다 - 가 나올때도 있고.

쩝. 다른분들은 시간을 꼭 측정해야할때 어떻게 하시는 지 궁금하네요.

조언 바랍니다.

날씨가 춥습니다. 감기조심하세요

익명 사용자의 이미지

당연히도 음수가 나올수 있겠죠.
timeval의 tv_usec는 1000000 즉 1초보다 커질 수 없습니다.
음수가 나오는 경우는 tv1과 tv2사이에서 overflow가 발생해서 tv_sec값이 증가하고 tv_usec가 다시 0부터 다시 시작하는 경우가 일어난 때입니다.
이경우를 처리하던지 아님 tv_sec값을 포함하는 수식을 사용하던지 하시면됩니다.

jinushun의 이미지

헉 감사합니다 -_-;
기본에 충실하지 못했군요 ㅋㅋ
좋은하루되세요

----------------------------
www.nate.com
----------------------------

익명 사용자의 이미지

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)로 환산해서 시간을 계산했습니다.
물론, 정수연산만으로 시간을 계산할 수 있지만, 원리만을 말씀드리기 위함입니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.