| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| #ifdef HAVE_CONFIG_H |
| #include <config.h> |
| #endif |
|
|
| #include <stdio.h> |
| #include <stdlib.h> |
| #include <string.h> |
|
|
| #if defined(_WIN32) && !defined(__SYMBIAN32__) |
| # include <windows.h> |
| # ifndef _WIN32_WCE |
| # include <time.h> |
| # endif |
| #elif defined(HAVE_UNISTD_H) |
| # include <unistd.h> |
| # include <sys/time.h> |
| # include <sys/resource.h> |
| #endif |
|
|
| #ifdef _MSC_VER |
| #pragma warning (disable: 4996) |
| #endif |
|
|
| #include <pocketsphinx/err.h> |
|
|
| #include "util/profile.h" |
| #include "util/ckd_alloc.h" |
|
|
| #if defined(_WIN32_WCE) || defined(_WIN32_WP) |
| DWORD unlink(const char *filename) |
| { |
| WCHAR *wfilename; |
| DWORD rv; |
| size_t len; |
|
|
| len = mbstowcs(NULL, filename, 0); |
| wfilename = ckd_calloc(len+1, sizeof(*wfilename)); |
| mbstowcs(wfilename, filename, len); |
| rv = DeleteFileW(wfilename); |
| ckd_free(wfilename); |
|
|
| return rv; |
| } |
| #endif |
|
|
| pctr_t * |
| pctr_new(char *nm) |
| { |
| pctr_t *pc; |
|
|
| pc = ckd_calloc(1, sizeof(pctr_t)); |
| pc->name = ckd_salloc(nm); |
| pc->count = 0; |
|
|
| return pc; |
| } |
|
|
| void |
| pctr_reset(pctr_t * ctr) |
| { |
| ctr->count = 0; |
| } |
|
|
|
|
| void |
| pctr_increment(pctr_t * ctr, int32 inc) |
| { |
| ctr->count += inc; |
| |
| } |
|
|
| void |
| pctr_print(FILE * fp, pctr_t * ctr) |
| { |
| fprintf(fp, "CTR:"); |
| fprintf(fp, "[%d %s]", ctr->count, ctr->name); |
| } |
|
|
| void |
| pctr_free(pctr_t * pc) |
| { |
| if (pc) { |
| if (pc->name) |
| ckd_free(pc->name); |
| } |
| ckd_free(pc); |
| } |
|
|
|
|
| #if defined(_WIN32) && !defined(GNUWINCE) && !defined(__SYMBIAN32__) |
|
|
| #define TM_LOWSCALE 1e-7 |
| #define TM_HIGHSCALE (4294967296.0 * TM_LOWSCALE); |
|
|
| static float64 |
| make_sec(FILETIME * tm) |
| { |
| float64 dt; |
|
|
| dt = tm->dwLowDateTime * TM_LOWSCALE; |
| dt += tm->dwHighDateTime * TM_HIGHSCALE; |
|
|
| return (dt); |
| } |
|
|
| #else |
|
|
| static float64 |
| make_sec(struct timeval *s) |
| { |
| return (s->tv_sec + s->tv_usec * 0.000001); |
| } |
|
|
| #endif |
|
|
|
|
| void |
| ptmr_start(ptmr_t * tm) |
| { |
| #if (! defined(_WIN32)) || defined(GNUWINCE) || defined(__SYMBIAN32__) |
| struct timeval e_start; |
|
|
| #if (! defined(_HPUX_SOURCE)) && (! defined(__SYMBIAN32__)) |
| struct rusage start; |
|
|
| |
| getrusage(RUSAGE_SELF, &start); |
| tm->start_cpu = make_sec(&start.ru_utime) + make_sec(&start.ru_stime); |
| #endif |
| |
| gettimeofday(&e_start, 0); |
| tm->start_elapsed = make_sec(&e_start); |
| #elif defined(_WIN32_WP) |
| tm->start_cpu = GetTickCount64() / 1000; |
| tm->start_elapsed = GetTickCount64() / 1000; |
| #elif defined(_WIN32_WCE) |
| |
| tm->start_cpu = GetTickCount() / 1000; |
| tm->start_elapsed = GetTickCount() / 1000; |
| #else |
| HANDLE pid; |
| FILETIME t_create, t_exit, kst, ust; |
|
|
| |
| pid = GetCurrentProcess(); |
| GetProcessTimes(pid, &t_create, &t_exit, &kst, &ust); |
| tm->start_cpu = make_sec(&ust) + make_sec(&kst); |
|
|
| tm->start_elapsed = (float64) clock() / CLOCKS_PER_SEC; |
| #endif |
| } |
|
|
|
|
| void |
| ptmr_stop(ptmr_t * tm) |
| { |
| float64 dt_cpu, dt_elapsed; |
|
|
| #if (! defined(_WIN32)) || defined(GNUWINCE) || defined(__SYMBIAN32__) |
| struct timeval e_stop; |
|
|
| #if (! defined(_HPUX_SOURCE)) && (! defined(__SYMBIAN32__)) |
| struct rusage stop; |
|
|
| |
| getrusage(RUSAGE_SELF, &stop); |
| dt_cpu = |
| make_sec(&stop.ru_utime) + make_sec(&stop.ru_stime) - |
| tm->start_cpu; |
| #else |
| dt_cpu = 0.0; |
| #endif |
| |
| gettimeofday(&e_stop, 0); |
| dt_elapsed = (make_sec(&e_stop) - tm->start_elapsed); |
| #elif defined(_WIN32_WP) |
| dt_cpu = GetTickCount64() / 1000 - tm->start_cpu; |
| dt_elapsed = GetTickCount64() / 1000 - tm->start_elapsed; |
| #elif defined(_WIN32_WCE) |
| |
| dt_cpu = GetTickCount() / 1000 - tm->start_cpu; |
| dt_elapsed = GetTickCount() / 1000 - tm->start_elapsed; |
| #else |
| HANDLE pid; |
| FILETIME t_create, t_exit, kst, ust; |
|
|
| |
| pid = GetCurrentProcess(); |
| GetProcessTimes(pid, &t_create, &t_exit, &kst, &ust); |
| dt_cpu = make_sec(&ust) + make_sec(&kst) - tm->start_cpu; |
| dt_elapsed = ((float64) clock() / CLOCKS_PER_SEC) - tm->start_elapsed; |
| #endif |
|
|
| tm->t_cpu += dt_cpu; |
| tm->t_elapsed += dt_elapsed; |
|
|
| tm->t_tot_cpu += dt_cpu; |
| tm->t_tot_elapsed += dt_elapsed; |
| } |
|
|
|
|
| void |
| ptmr_reset(ptmr_t * tm) |
| { |
| tm->t_cpu = 0.0; |
| tm->t_elapsed = 0.0; |
| } |
|
|
|
|
| void |
| ptmr_init(ptmr_t * tm) |
| { |
| tm->t_cpu = 0.0; |
| tm->t_elapsed = 0.0; |
| tm->t_tot_cpu = 0.0; |
| tm->t_tot_elapsed = 0.0; |
| } |
|
|
|
|
| void |
| ptmr_reset_all(ptmr_t * tm) |
| { |
| for (; tm->name; tm++) |
| ptmr_reset(tm); |
| } |
|
|
|
|
| void |
| ptmr_print_all(FILE * fp, ptmr_t * tm, float64 norm) |
| { |
| if (norm != 0.0) { |
| norm = 1.0 / norm; |
| for (; tm->name; tm++) |
| fprintf(fp, " %6.2fx %s", tm->t_cpu * norm, tm->name); |
| } |
| } |
|
|
|
|
| int32 |
| host_endian(void) |
| { |
| FILE *fp; |
| int32 BYTE_ORDER_MAGIC; |
| char *file; |
| char buf[8]; |
| int32 k, endian; |
|
|
| file = "/tmp/__EnDiAn_TeSt__"; |
|
|
| if ((fp = fopen(file, "wb")) == NULL) { |
| E_ERROR("Failed to open file '%s' for writing", file); |
| return -1; |
| } |
|
|
| BYTE_ORDER_MAGIC = (int32) 0x11223344; |
|
|
| k = (int32) BYTE_ORDER_MAGIC; |
| if (fwrite(&k, sizeof(int32), 1, fp) != 1) { |
| E_ERROR("Failed to write to file '%s'\n", file); |
| fclose(fp); |
| unlink(file); |
| return -1; |
| } |
|
|
| fclose(fp); |
| if ((fp = fopen(file, "rb")) == NULL) { |
| E_ERROR_SYSTEM("Failed to open file '%s' for reading", file); |
| unlink(file); |
| return -1; |
| } |
| if (fread(buf, 1, sizeof(int32), fp) != sizeof(int32)) { |
| E_ERROR("Failed to read from file '%s'\n", file); |
| fclose(fp); |
| unlink(file); |
| return -1; |
| } |
| fclose(fp); |
| unlink(file); |
|
|
| |
| endian = (buf[0] == (BYTE_ORDER_MAGIC & 0x000000ff)) ? 1 : 0; |
|
|
| return (endian); |
| } |
|
|