[질문] 아주 긴 시간을 제려면 어떻게 하지요? time 함수 관련...

sDH8988L의 이미지

제가 좀 오래 걸리는 Program의 실행 시간을 제려고 합니다...

Matrix Multiplication의 실행 시간을 제려고 하는 건데요... Matrix의 크기가 좀 큽니다... 16K X 16K 정도의 큰 거라서 시간이 엄청 걸리는 군요...

그래서 알아봣더니 clock_t 같은 경우는 각 Machine에 따라 다르기는 하지만 거의 unsigned long이라서 저 시간을 젤 수가 없습니다... 계속 reset을 반복하죠...

물론, 중간중간에 Context Switch 되는 시간은 계산하지 말아야 합니다... 저만 쓰는 Machine이 아니라서요...

어떤 방법을 쓰는 게 좋을까요?

언듯 생각해 볼 수 있는게 clock_t의 범위를 넘지 않는 loop 내에서 clock() 함수를 실행하여 long long type에 계속 합해 가는 방법이 있기는 한데, 웬지 깔끔하지가 않아서요...

nike984의 이미지

스톱 워치를 쓰셈 -_-

cinsk의 이미지

time(1) 명령을 쓰면 될 것 같은데요.

--
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://www.cinsk.org/cfaqs/

mach의 이미지

1. clock()을 사용하는 방법
- 이미 사용해보신
2. time을 사용하는 방법
shell에서 실행파일명이 test라고 가정할때
- $ time ./test
3. time()을 이용하는 방법
- 선언 : time_t time0, time1;
- 시작점에서 time()호출 - time0를 파라메터로
...
- 종료점에서 time()호출 - time1을 파라메터로
- difftime()호출하여 시간차를 구함 - time0, time1을 파라메터로
* 그러나, 자신의 프로세스 만이 사용자 모드에서사용한 시간을 구할 수 없음
* 비슷하게 gettimeofday()를 사용할 수 있으나, 마찬가지
4. 알람이용법
- setitimer() 와 gettimer()를 이용해서 프로파일 시간을 측정할 수 있습니다.
5. getrusage()를 사용하는 방법
- 시스템자원을 사용한 다양한 상황에 대해 알 수 있음
- getrusage() ... getrusage()를 호출해서 (2번) 그 차이를 구해서 원하는 결과를 측정할 수 있음

그외 프로파일링 도구사용등 다양한 방법이 있지만, 간편하게 사용해 보세요.

전체수행시간이라면 2번을, 일부분의 수행시간이라면, 5번을 한번 사용해 보시지요.

------------------ P.S. --------------
지식은 오픈해서 검증받아야 산지식이된다고 동네 아저씨가 그러더라.

------------------ P.S. --------------
지식은 오픈해서 검증받아야 산지식이된다고 동네 아저씨가 그러더라.

sDH8988L의 이미지


답변 감사드립니다...

time(1)을 사용하는 방법이 가장 편리할 거 같습니다...

time이 return하는 real, user, sys 중에 저는 user를 그냥 가져다 쓰면 되겠군요...

이거 참... C Program 안에서 해결하려는 생각 밖에 못했군요... 이렇게 버젓이 명령어를 지원하지도 모르고...

좀 더 공부를 해야겠습니다...

다시 한 번 답변에 감사드립니다...

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.