view solvers/SMALL_ompGabor/ompprof.h @ 157:00a8473e4b85 danieleb

Added tag danieleb for changeset a4d0977d4595
author danieleb@code.soundsoftware.ac.uk
date Tue, 30 Aug 2011 11:18:34 +0100
parents 31d2864dfdd4
children
line wrap: on
line source
/**************************************************************************
 *
 * File name: ompprof.h
 *
 * Ron Rubinstein
 * Computer Science Department
 * Technion, Haifa 32000 Israel
 * ronrubin@cs
 *
 * Last Updated: 18.8.2009
 *
 * Collection of definitions and functions for profiling the OMP method.
 *
 *************************************************************************/


#ifndef __OMP_PROF_H__
#define __OMP_PROF_H__

#include "mex.h"
#include <time.h>



/**************************************************************************
 *
 * Constants and data types.
 *
 **************************************************************************/


/* constants denoting the various parts of the algorithm */

enum { DtX_TIME, XtX_TIME, DtR_TIME, MAXABS_TIME, DtD_TIME, LCHOL_TIME, COMPCOEF_TIME, 
       UPDATE_DtR_TIME, UPDATE_RESNORM_TIME, COMPRES_TIME, INDEXSORT_TIME };

       
       
/* profiling data container with counters for each part of the algorithm */
       
typedef struct profdata 
{
  clock_t prevtime;  /* the time when last initialization/call to addproftime() was performed */
  
  clock_t DtX_time;
  clock_t XtX_time;
  clock_t DtR_time;
  clock_t maxabs_time;
  clock_t DtD_time;
  clock_t Lchol_time;
  clock_t compcoef_time;
  clock_t update_DtR_time;
  clock_t update_resnorm_time;
  clock_t compres_time;
  clock_t indexsort_time;
  
  /* flags indicating whether profiling data was gathered */
  int DtX_time_counted;
  int XtX_time_counted;
  int DtR_time_counted;
  int DtD_time_counted;
  int update_DtR_time_counted;
  int resnorm_time_counted;
  int compres_time_counted;
  int indexsort_time_counted;
  
} profdata;



/**************************************************************************
 *
 * Initialize a profdata structure, zero all counters, and start its timer.
 *
 **************************************************************************/
void initprofdata(profdata *pd);


/**************************************************************************
 *
 * Add elapsed time from last call to addproftime(), or from initialization
 * of profdata, to the counter specified by comptype. comptype must be one
 * of the constants in the enumeration above.
 *
 **************************************************************************/
void addproftime(profdata *pd, int comptype);


/**************************************************************************
 *
 * Print the current contents of the counters in profdata.
 *
 * Parameters:
 *   pd - the profdata to print
 *   erroromp - indicates whether error-based (nonzero) or sparsity-based (zero)
 *              omp was performed.
 *   batchomp - indicates whether batch-omp (nonzero) or omp-cholesky (zero)
 *              omp was performed.
 *   signum   - number of signals processed by omp
 *
 **************************************************************************/
void printprofinfo(profdata *pd, int erroromp, int batchomp, int signum);


#endif