Linux/함수

함수의 실행 시간 구하기

khd0801 2022. 4. 21. 13:50
반응형

 1. struct timeval 사용

#include <stdio.h>
#include <sys/time.h>
#include <unistd.h>

void getElapsedTime(struct timeval Tstart, struct timeval Tend) {
    Tend.tv_usec = Tend.tv_usec - Tstart.tv_usec;
    Tend.tv_sec = Tend.tv_sec - Tstart.tv_sec;

    printf("timeval sub sec : %ld, usec : %ld \n",Tend.tv_sec, Tend.tv_usec);
    Tend.tv_usec += (Tend.tv_sec*1000000);

    printf("Elapsed timeval Time: %lf sec\n",Tend.tv_usec / 1000000.0);
}

struct timeval, struct timespec 구조체를 사용하기 위해서는 #include<sys/time.h>의 헤더가 필요하다.

 

 2. struct timespec 사용

#include <stdio.h>
#include <unistd.h>
#include <time.h>

void getElapsedTime(struct timeval Tstart, struct timeval Tend) {
    Tend.tv_usec = Tend.tv_usec - Tstart.tv_usec;
    Tend.tv_sec = Tend.tv_sec - Tstart.tv_sec;

    printf("timeval sub sec : %ld, usec : %ld \n",Tend.tv_sec, Tend.tv_usec);
    Tend.tv_usec += (Tend.tv_sec*1000000);

    printf("Elapsed timeval Time: %lf sec\n",Tend.tv_usec / 1000000.0);
}

void getElapsedTimeSpec(struct timespec Tstart, struct timespec Tend) {
    Tend.tv_nsec = Tend.tv_nsec - Tstart.tv_nsec;
    Tend.tv_sec = Tend.tv_sec - Tstart.tv_sec;

    printf("timespe sub sec : %ld, nsec : %ld \n",Tend.tv_sec, Tend.tv_nsec);
    Tend.tv_nsec += (Tend.tv_sec*1000000000);

    printf("Elapsed timespec Time: %lf sec\n",Tend.tv_nsec / 1000000000.0);
}

clock_gettime()함수의 입력 파라미터 "CLOCK_MONOTONIC"을 사용하기 위해서는 #include<time.h> 선인이 필요하다.

clock_gettime()함수의 아규먼트 종류는 아래와 같다.

아규먼트 종류 설명
CLOCK_REALTIME 설정 가능한 시스템 전역인 실제 시간.
CLOCK_REATIME_COARSE CLOCK_REALTIME 보다 빠르지만 정확하지 않다.
CLOCK_MONOTONIC 특정 시점(부팅 부터 시작)부터 흐른 시간을 나타낸다. 이 clock은 set 할 수 없다.
CLOCK_MONOTONIC_COARSE CLOCK_MONOTONIC과 비슷하지만 더 빠르고 정확하지 않다.
CLOCK_MONOTONIC_RAW CLOCK_MONOTONIC과 비슷하지만 NTP 조정이나 adjtime()에 대한 조정에 영향을 받지 않는 하드웨어 기반 시간에 대한 엑세스를 제공한다. 시스템 절전 대기 시간은 포함하지 않는다.
CLOCK_BOOTTIME CLOCK_MONOTONIC_RAW와 비슷하지만 시스템의 절전 대기 시간도 포함하는 시간이다.
CLOCK_PROCESS_CPUTIME_ID 프로세스별 CPU 시간 클럭. 프로세스냄 모든 쓰레드들이 소모한 CPU 시간을 나타낸다.
CLOCK_THREAD_CPUTIME_ID 특정 쓰레드 환경 CPU 사용 시간을 나타낸다.

 

 

 3. TEST 코드

#include <stdio.h>
#include <sys/time.h>
#include <unistd.h>
#include <time.h>

void getElapsedTime(struct timeval Tstart, struct timeval Tend) {
    Tend.tv_usec = Tend.tv_usec - Tstart.tv_usec;
    Tend.tv_sec = Tend.tv_sec - Tstart.tv_sec;

    printf("timeval sub sec : %ld, usec : %ld \n",Tend.tv_sec, Tend.tv_usec);
    Tend.tv_usec += (Tend.tv_sec*1000000);

    printf("Elapsed timeval Time: %lf sec\n",Tend.tv_usec / 1000000.0);
}

void getElapsedTimeSpec(struct timespec Tstart, struct timespec Tend) {
    Tend.tv_nsec = Tend.tv_nsec - Tstart.tv_nsec;
    Tend.tv_sec = Tend.tv_sec - Tstart.tv_sec;

    printf("timespe sub sec : %ld, nsec : %ld \n",Tend.tv_sec, Tend.tv_nsec);
    Tend.tv_nsec += (Tend.tv_sec*1000000000);

    printf("Elapsed timespec Time: %lf sec\n",Tend.tv_nsec / 1000000000.0);
}

void delayfor(void) {
    int i = 0;
    int cnt = 0;
    for(i=0; i<100000000; i++)
        cnt++;
}

int main(void) {
    int i = 0;
    int cnt = 0;
    struct timeval Tstart, Tend;
    struct timespec TSstart, TSend;

    gettimeofday(&Tstart, NULL);
    usleep(1000);
    //delayfor();
    gettimeofday(&Tend,NULL);
    getElapsedTime(Tstart, Tend);



    clock_gettime(CLOCK_MONOTONIC,&TSstart);
    usleep(1000); 
    //delayfor();
    clock_gettime(CLOCK_MONOTONIC,&TSend);
    
    getElapsedTimeSpec(TSstart, TSend);


    return 0;
}

 

간단한 테스트 프로그램으로 struct timeval와 struct timespec을 이용하여 정밀도를 측정해 보았다.

usleep을 이용하여 약 1msec sleep 구간을 만들어 timeval와 timespec 구조체를 이용하여 시간을 측정하여 보았다.

결과는 아래 로그와 같이 timespec이 조금더 정밀한 것 같다.

$ ./test.out 

timeval sub sec : 0, usec : 1126 

Elapsed timeval Time: 0.001126 sec

timespe sub sec : 0, nsec : 1147035 

Elapsed timespec Time: 0.001147 sec

$ ./test.out 

timeval sub sec : 0, usec : 1128 

Elapsed timeval Time: 0.001128 sec

timespe sub sec : 0, nsec : 1120208 

Elapsed timespec Time: 0.001120 sec

$ ./test.out 

timeval sub sec : 0, usec : 1106 

Elapsed timeval Time: 0.001106 sec

timespe sub sec : 0, nsec : 1119420 

Elapsed timespec Time: 0.001119 sec

$ ./test.out 

timeval sub sec : 0, usec : 1130 

Elapsed timeval Time: 0.001130 sec

timespe sub sec : 0, nsec : 1120662 

Elapsed timespec Time: 0.001121 sec

$ ./test.out 

timeval sub sec : 0, usec : 1136 

Elapsed timeval Time: 0.001136 sec

timespe sub sec : 0, nsec : 1110551 

Elapsed timespec Time: 0.001111 sec

$ ./test.out 

timeval sub sec : 0, usec : 1291 

Elapsed timeval Time: 0.001291 sec

timespe sub sec : 0, nsec : 1076578 

Elapsed timespec Time: 0.001077 sec

$ ./test.out 

timeval sub sec : 0, usec : 1374 

Elapsed timeval Time: 0.001374 sec

timespe sub sec : 0, nsec : 1082080 

Elapsed timespec Time: 0.001082 sec

$ ./test.out 

timeval sub sec : 0, usec : 1382 

Elapsed timeval Time: 0.001382 sec

timespe sub sec : 0, nsec : 1121709 

Elapsed timespec Time: 0.001122 sec

$ ./test.out 

timeval sub sec : 0, usec : 1138 

Elapsed timeval Time: 0.001138 sec

timespe sub sec : 0, nsec : 1124684 

Elapsed timespec Time: 0.001125 sec

$ ./test.out 

timeval sub sec : 0, usec : 1121 

Elapsed timeval Time: 0.001121 sec

timespe sub sec : 0, nsec : 1125626 

Elapsed timespec Time: 0.001126 sec

 

 

 

반응형