⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 count.h

📁 最新的ITU-T的宽带语音编解码标准G.729.1,是对原先的G.729的最好的调整.码流输出速率可以进行自适应调整.满足未来通信要求.希望对大家有所帮助.
💻 H
字号:
/*  ===========================================================================   File: COUNT.H                                         v.2.0 - 15.Nov.2004  ===========================================================================            ITU-T         STL         BASIC       OPERATORS            PROTOTYPES & DEFINITION FOR COUNTING OPERATIONS   History   09.Aug.1999 V1.0.0   Input to UGST from ETSI AMR (count.h);    26.Jan.2000 V1.1.0   Added counter entries for G.723.1's                         L_mls(), div_l(), i_mult() [from basop32.c]   05.Jul.2000 V1.2.0   Added counter entries for 32bit shiftless                         operators L_mult0(), L_mac0(), L_msu0()   03 Nov 04   v2.0     Incorporation of new 32-bit / 40-bit / control                        operators for the ITU-T Standard Tool Library as                         described in Geneva, 20-30 January 2004 WP 3/16 Q10/16                        TD 11 document and subsequent discussions on the                        wp3audio@yahoogroups.com email reflector.  ============================================================================*//****************************************************************************** * Functions for counting operations. * * These functions make it possible to measure the wMOPS of a codec. * * All functions in this file, and in other *.h files, update a structure so * that it will be possible to track how many calls to add(), sub(), L_mult() * ... was made by the code and to estimate the wMOPS (and MIPS) for a certain * part of the 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 seperate 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 piece of code illustrating how the * functions can be used. *******************************************************************************/#ifndef _COUNT_H#define _COUNT_H "$Id$"#define WMOPS 1		    // enable WMOPS profiling features//#undef WMOPS				// disable WMOPS profiling features#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. */int readCounterId();/* * Returns the current CounterId. */void setCounter( int counterId);/* * Defines which counter group to use, default is zero. */char *readCounterIdName();/* * Returns the current CounterId name. */void incrementNbTimeObjectIsCalled( int counterId);/* * This function enables to increment by 1 a counter * tracking the number of times the application enters a groups of functions. * If the counterId is not refering to a defined function counter group, then it is * the default function group (0) which is impacted. * */void ClearNbTimeObjectsAreCalled();/* * This function enables to clear to 0 all the counters enabling to * track the number of times the application enters any groups of functions. */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 is 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. */#define WMOPS_DATA_FILENAME	"wmops_data.txt"/* * WMOPS_DATA_FILENAME is the macro defining the name of the file * where the Weighted Million of Operations per Second (wMOPS) * are appended, function group by function group.*/#define CODE_PROFILE_FILENAME	"code_profile.txt"/* * CODE_PROFILE_FILENAME is the macro defining the name of the file * where the Weighted Million of Operations per Second (WMOPS) * are appended, basic operation by basic operation.*/#define WMOPS_TOTAL_FILENAME	"wmops_total.txt"/* * WMOPS_TOTAL_FILENAME is the macro defining the name of the file * where the Weighted Million of Operations per Second (WMOPS) * are printed, globally for the application.*//* #define FRAME_RATE	(0.000025) */ /* FRAME_RATE of 0.000025 is corresponding to 40ms frame.*/#define FRAME_RATE			(0.00005F)/* * FRAME_RATE is the macro defining the calling rate of the * application to benchmark.*//* Global counter variable for calculation of complexity weight */typedef struct{    UWord32 add;             /* Complexity Weight of 1 */    UWord32 sub;             /* Complexity Weight of 1 */    UWord32 abs_s;           /* Complexity Weight of 1 */    UWord32 shl;             /* Complexity Weight of 1 */    UWord32 shr;             /* Complexity Weight of 1 */    UWord32 extract_h;       /* Complexity Weight of 1 */    UWord32 extract_l;       /* Complexity Weight of 1 */    UWord32 mult;            /* Complexity Weight of 1 */    UWord32 L_mult;          /* Complexity Weight of 1 */    UWord32 negate;          /* Complexity Weight of 1 */    UWord32 round;           /* Complexity Weight of 1 */    UWord32 L_mac;           /* Complexity Weight of 1 */    UWord32 L_msu;           /* Complexity Weight of 1 */    UWord32 L_macNs;         /* Complexity Weight of 1 */    UWord32 L_msuNs;         /* Complexity Weight of 1 */    UWord32 L_add;           /* Complexity Weight of 1 */    UWord32 L_sub;           /* Complexity Weight of 1 */    UWord32 L_add_c;         /* Complexity Weight of 2 */    UWord32 L_sub_c;         /* Complexity Weight of 2 */    UWord32 L_negate;        /* Complexity Weight of 1 */    UWord32 L_shl;           /* Complexity Weight of 1 */    UWord32 L_shr;           /* Complexity Weight of 1 */    UWord32 mult_r;          /* Complexity Weight of 1 */    UWord32 shr_r;           /* Complexity Weight of 3 */    UWord32 mac_r;           /* Complexity Weight of 1 */    UWord32 msu_r;           /* Complexity Weight of 1 */    UWord32 L_deposit_h;     /* Complexity Weight of 1 */    UWord32 L_deposit_l;     /* Complexity Weight of 1 */    UWord32 L_shr_r;         /* Complexity Weight of 3 */    UWord32 L_abs;           /* Complexity Weight of 1 */    UWord32 L_sat;           /* Complexity Weight of 4 */    UWord32 norm_s;          /* Complexity Weight of 1 */    UWord32 div_s;           /* Complexity Weight of 18 */    UWord32 norm_l;          /* Complexity Weight of 1 */    UWord32 move16;          /* Complexity Weight of 1 */    UWord32 move32;          /* Complexity Weight of 2 */    UWord32 Logic16;         /* Complexity Weight of 1 */    UWord32 Logic32;         /* Complexity Weight of 2 */    UWord32 Test;            /* Complexity Weight of 2 */    UWord32 s_max;           /* Complexity Weight of 1 */    UWord32 s_min;           /* Complexity Weight of 1 */    UWord32 L_max;           /* Complexity Weight of 1 */    UWord32 L_min;           /* Complexity Weight of 1 */    UWord32 L40_max;         /* Complexity Weight of 1 */    UWord32 L40_min;         /* Complexity Weight of 1 */    UWord32 shl_r;           /* Complexity Weight of 3 */    UWord32 L_shl_r;         /* Complexity Weight of 3 */    UWord32 L40_shr_r;       /* Complexity Weight of 3 */    UWord32 L40_shl_r;       /* Complexity Weight of 3 */    UWord32 norm_L40;        /* Complexity Weight of 1 */    UWord32 L40_shl;         /* Complexity Weight of 1 */    UWord32 L40_shr;         /* Complexity Weight of 1 */    UWord32 L40_negate;      /* Complexity Weight of 1 */    UWord32 L40_add;         /* Complexity Weight of 1 */    UWord32 L40_sub;         /* Complexity Weight of 1 */    UWord32 L40_abs;         /* Complexity Weight of 1 */    UWord32 L40_mult;        /* Complexity Weight of 1 */    UWord32 L40_mac;         /* Complexity Weight of 1 */    UWord32 mac_r40;         /* Complexity Weight of 2 */    UWord32 L40_msu;         /* Complexity Weight of 1 */    UWord32 msu_r40;         /* Complexity Weight of 2 */    UWord32 Mpy_32_16_ss;    /* Complexity Weight of 2 */    UWord32 Mpy_32_32_ss;    /* Complexity Weight of 4 */    UWord32 L_mult0;         /* Complexity Weight of 1 */    UWord32 L_mac0;          /* Complexity Weight of 1 */    UWord32 L_msu0;          /* Complexity Weight of 1 */    UWord32 lshl;            /* Complexity Weight of 1 */     UWord32 lshr;            /* Complexity Weight of 1 */    UWord32 L_lshl;          /* Complexity Weight of 1 */     UWord32 L_lshr;          /* Complexity Weight of 1 */    UWord32 L40_lshl;        /* Complexity Weight of 1 */    UWord32 L40_lshr;        /* Complexity Weight of 1 */    UWord32 s_and;           /* Complexity Weight of 1 */    UWord32 s_or;            /* Complexity Weight of 1 */    UWord32 s_xor;           /* Complexity Weight of 1 */    UWord32 L_and;           /* Complexity Weight of 1 */    UWord32 L_or;            /* Complexity Weight of 1 */    UWord32 L_xor;           /* Complexity Weight of 1 */    UWord32 rotl;            /* Complexity Weight of 3 */    UWord32 rotr;            /* Complexity Weight of 3 */    UWord32 L_rotl;          /* Complexity Weight of 3 */    UWord32 L_rotr;          /* Complexity Weight of 3 */    UWord32 L40_set;         /* Complexity Weight of 3 */    UWord32 L40_deposit_h;   /* Complexity Weight of 1 */    UWord32 L40_deposit_l;   /* Complexity Weight of 1 */    UWord32 L40_deposit32;   /* Complexity Weight of 1 */    UWord32 Extract40_H;     /* Complexity Weight of 1 */    UWord32 Extract40_L;     /* Complexity Weight of 1 */    UWord32 L_Extract40;     /* Complexity Weight of 1 */    UWord32 L40_round;       /* Complexity Weight of 1 */    UWord32 L_saturate40;    /* Complexity Weight of 1 */    UWord32 round40;         /* Complexity Weight of 1 */    UWord32 If;              /* Complexity Weight of 4 */    UWord32 Goto;            /* Complexity Weight of 4 */    UWord32 Break;           /* Complexity Weight of 4 */    UWord32 Switch;          /* Complexity Weight of 8 */    UWord32 For;             /* Complexity Weight of 3 */    UWord32 While;           /* Complexity Weight of 4 */    UWord32 Continue;        /* Complexity Weight of 4 */    UWord32 L_mls;           /* Complexity Weight of 6 */    UWord32 div_l;           /* Complexity Weight of 1 */    UWord32 i_mult;          /* Complexity Weight of 1 */}BASIC_OP;Word32 TotalWeightedOperation( void);Word32 DeltaWeightedOperation( void);void generic_WMOPS_output ( Word16 notPrintWorstWorstCase, char *test_file_name);/* * This function enable to append : * - to WMOPS_DATA_FILENAME file, the WMOPS information related *   to the execution of the application, function group by function *   group. * - to CODE_PROFILE_FILENAME file, the WMOPS information related *   to the execution of the application, basic operation by basic *   operation. * - to WMOPS_TOTAL_FILENAME file, the total WMOPS information related *   to the execution of the application. * * Note that : * if the files exists, the data will be written at the end of file. * * test_file_name : Is a character string referencing each calls to *                  generic_WMOPS_output(). Usually, it is the name of a test *                  sequence file. * * notPrintWorstWorstCase : Same usage as in WMOPS_output(). */#if 0/* * 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 /* #if 0*/#endif /* _COUNT_H *//* end of file */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -