[질문] 아주 긴 시간을 제려면 어떻게 하지요? time 함수 관련...
글쓴이: sDH8988L / 작성시간: 목, 2006/04/20 - 12:16오전
제가 좀 오래 걸리는 Program의 실행 시간을 제려고 합니다...
Matrix Multiplication의 실행 시간을 제려고 하는 건데요... Matrix의 크기가 좀 큽니다... 16K X 16K 정도의 큰 거라서 시간이 엄청 걸리는 군요...
그래서 알아봣더니 clock_t 같은 경우는 각 Machine에 따라 다르기는 하지만 거의 unsigned long이라서 저 시간을 젤 수가 없습니다... 계속 reset을 반복하죠...
물론, 중간중간에 Context Switch 되는 시간은 계산하지 말아야 합니다... 저만 쓰는 Machine이 아니라서요...
어떤 방법을 쓰는 게 좋을까요?
언듯 생각해 볼 수 있는게 clock_t의 범위를 넘지 않는 loop 내에서 clock() 함수를 실행하여 long long type에 계속 합해 가는 방법이 있기는 한데, 웬지 깔끔하지가 않아서요...
Forums:
스톱 워치를 쓰셈 -_-
스톱 워치를 쓰셈 -_-
time(1) 명령을 쓰면 될
time(1) 명령을 쓰면 될 것 같은데요.
--
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://www.cinsk.org/cfaqs/
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://cinsk.github.io/cfaqs/
1. clock()을 사용하는
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. --------------
지식은 오픈해서 검증받아야 산지식이된다고 동네 아저씨가 그러더라.
답변
답변 감사드립니다...
time(1)을 사용하는 방법이 가장 편리할 거 같습니다...
time이 return하는 real, user, sys 중에 저는 user를 그냥 가져다 쓰면 되겠군요...
이거 참... C Program 안에서 해결하려는 생각 밖에 못했군요... 이렇게 버젓이 명령어를 지원하지도 모르고...
좀 더 공부를 해야겠습니다...
다시 한 번 답변에 감사드립니다...
댓글 달기