[svn] / trunk / xvidcore / src / bitstream / cbp.c Repository:
ViewVC logotype

View of /trunk/xvidcore/src/bitstream/cbp.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 911 - (download) (annotate)
Sun Mar 9 11:30:24 2003 UTC (21 years, 1 month ago) by chl
File size: 1556 byte(s)
Speedup for calc_cbp_c(), loop unrolling / 64bit integers
#include "../portab.h"
#include "cbp.h"

cbpFuncPtr calc_cbp;

/*
 * Returns a field of bits that indicates non zero ac blocks
 * for this macro block
 */

/* naive C */
uint32_t
calc_cbp_plain(const int16_t codes[6 * 64])
{
	int i, j;
	uint32_t cbp = 0;

	for (i = 0; i < 6; i++) {
		for (j=1; j<64;j++) {
			if (codes[64*i+j]) {
            	cbp |= 1 << (5-i);
				break;
			}
		}
	}
	return cbp;
}

/* optimized C */
uint32_t
calc_cbp_c(const int16_t codes[6 * 64])
{
	int i, j;
	uint32_t cbp = 0;
/* if definition is changed (e.g. from int16_t to something like int) this routine 
   is not possible anymore! */

   for (i = 5; i >= 0; i--, codes += 64) {

		uint64_t *codes64 = (uint64_t*)codes;
		cbp += cbp; 
        if (codes[1] || codes[2] || codes[3]) {
			cbp++;
			continue;
		}
        if (codes64[1] | codes64[2] | codes64[3]) {
			cbp++;
			continue;
		}
        if (codes64[4] | codes64[5] | codes64[6] | codes64[7]) {
			cbp++;
			continue;
		}
        if (codes64[8] | codes64[9] | codes64[10] | codes64[11]) {
			cbp++;
			continue;
		}
        if (codes64[12] | codes64[13] | codes64[14] | codes64[15]) {
			cbp++;
			continue;
		}
    }

	return cbp;
}




/* older code maybe better on some plattforms? */
#if (0==1)
	for (i = 5; i >= 0; i--) {
		if (codes[1] | codes[2] | codes[3])
                        cbp |= 1 << i;
		else {
			for (j = 4; j <= 56; j+=4) 	/* [60],[61],[62],[63] are last */
				if (codes[j] | codes[j+1] | codes[j+2] | codes[j+3]) {
				cbp |= 1 << i;
				break;
			}
		}
		codes += 64;
	}

	return cbp;
#endif

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4