ref: c78ac707b07a3c8dea4685274cb6f1b3ba1ea93f
dir: /amr-wb/count.h/
/* * functions for counting operations * * These functions, and the ones in basic_op.h, makes it possible to measure * the wMOPS of a codec. * * All functions in this file, and in basic_op.h, uppdates a structure so that * it will be possible the see how many calls to add, mul mulAdd ... that the * code made, and estimate the wMOPS (and MIPS) for a sertain part of code * * It is also possible to measure the wMOPS separatly for different parts * of the codec. * * This is done by creating a counter group (getCounterId) for each part of the * code that one wants a separte measure for. Before a part of the code * is executed a call to the "setCounter" function is needed to identify * which counter group to use. * * Currently there is a limit of 255 different counter groups. * * In the end of this file there is a pice of code illustration how the * functions can be used. */ #ifndef count_h #define count_h "$Id: count.h,v 1.1 2007/02/15 23:22:35 robs Exp $" #define MAXCOUNTERS 256 int getCounterId(char *objectName); /* * Create a counter group, the "objectname" will be used when printing * statistics for this counter group. * * Returns 0 if no more counter groups are available. */ void setCounter(int counterId); /* * Defines which counter group to use, default is zero. */ void Init_WMOPS_counter (void); /* * Initiates the current counter group. */ void Reset_WMOPS_counter (void); /* * Resets the current counter group. */ void WMOPS_output (Word16 notPrintWorstWorstCase); /* * Prints the statistics to the screen, if the argument if non zero * the statistics for worst worst case will not be printed. This is typically * done for dtx frames. * */ Word32 fwc (void); /* * worst worst case counter. * * This function calculates the worst possible case that can be reached. * * This is done by calling this function for each subpart of the calculations * for a frame. This function then stores the maximum wMOPS for each part. * * The WMOPS_output function add together all parts and presents the sum. */ void move16 (void); void move32 (void); void logic16 (void); void logic32 (void); void test (void); /* * The functions above increases the corresponding operation counter for * the current counter group. */ typedef struct { Word32 add; /* Complexity Weight of 1 */ Word32 sub; Word32 abs_s; Word32 shl; Word32 shr; Word32 extract_h; Word32 extract_l; Word32 mult; Word32 L_mult; Word32 negate; Word32 round; Word32 L_mac; Word32 L_msu; Word32 L_macNs; Word32 L_msuNs; Word32 L_add; /* Complexity Weight of 2 */ Word32 L_sub; Word32 L_add_c; Word32 L_sub_c; Word32 L_negate; Word32 L_shl; Word32 L_shr; Word32 mult_r; Word32 shr_r; Word32 shift_r; Word32 mac_r; Word32 msu_r; Word32 L_deposit_h; Word32 L_deposit_l; Word32 L_shr_r; /* Complexity Weight of 3 */ Word32 L_shift_r; Word32 L_abs; Word32 L_sat; /* Complexity Weight of 4 */ Word32 norm_s; /* Complexity Weight of 15 */ Word32 div_s; /* Complexity Weight of 18 */ Word32 norm_l; /* Complexity Weight of 30 */ Word32 DataMove16; /* Complexity Weight of 1 */ Word32 DataMove32; /* Complexity Weight of 2 */ Word32 Logic16; /* Complexity Weight of 1 */ Word32 Logic32; /* Complexity Weight of 2 */ Word32 Test; /* Complexity Weight of 2 */ } BASIC_OP; /* * Example of how count.h could be used. * * In the example below it is assumed that the init_OBJECT functions * does not use any calls to counter.h or basic_op.h. If this is the case * a call to the function Reset_WMOPS_counter() must be done after each call * to init_OBJECT if these operations is not to be included in the statistics. int main(){ int spe1Id,spe2Id,cheId; // initiate counters and objects spe1Id=getCounterId("Spe 5k8"); setCounter(spe1Id); Init_WMOPS_counter (); init_spe1(...); spe2Id=getCounterId("Spe 12k2"); setCounter(spe2Id); Init_WMOPS_counter (); init_spe2(...); cheId=getCounterId("Channel encoder"); setCounter(cheId); Init_WMOPS_counter (); init_che(...); ... while(data){ test(); // Note this call to test(); if(useSpe1) setCounter(spe1Id); else setCounter(spe2Id); Reset_WMOPS_counter(); speEncode(...); WMOPS_output(0); // Normal routine for displaying WMOPS info setCounter(cheId); Reset_WMOPS_counter(); preChannelInter(...); fwc(); // Note the call to fwc() for each part convolve(...); fwc(); // of the channel encoder. interleave(...); fwc(); WMOPS_output(0); // Normal routine for displaying WMOPS info } */ #endif