1 /********************************************************************
3 * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE. *
4 * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
5 * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
6 * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
8 * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2007 *
9 * by the Xiph.Org Foundation http://www.xiph.org/ *
11 ********************************************************************
14 last mod: $Id: ocintrin.h 13884 2007-09-22 08:38:10Z giles $
16 ********************************************************************/
18 /*Some common macros for potential platform-specific optimization.*/
20 #if !defined(_ocintrin_H)
21 # define _ocintrin_H (1)
23 /*Some specific platforms may have optimized intrinsic or inline assembly
24 versions of these functions which can substantially improve performance.
25 We define macros for them to allow easy incorporation of these non-ANSI
28 /*Branchless, but not correct for differences larger than INT_MAX.
29 static int oc_mini(int _a,int _b){
31 ambsign=_a-_b>>sizeof(int)*8-1;
32 return (_a&~ambsign)+(_b&ambsign);
36 #define OC_MAXI(_a,_b) ((_a)<(_b)?(_b):(_a))
37 #define OC_MINI(_a,_b) ((_a)>(_b)?(_b):(_a))
38 /*Clamps an integer into the given range.
39 If _a>_c, then the lower bound _a is respected over the upper bound _c (this
40 behavior is required to meet our documented API behavior).
42 _b: The value to clamp.
44 #define OC_CLAMPI(_a,_b,_c) (OC_MAXI(_a,OC_MINI(_b,_c)))
45 #define OC_CLAMP255(_x) ((unsigned char)((((_x)<0)-1)&((_x)|-((_x)>255))))
46 /*Divides an integer by a power of two, truncating towards 0.
47 _dividend: The integer to divide.
48 _shift: The non-negative power of two to divide by.
49 _rmask: (1<<_shift)-1*/
50 #define OC_DIV_POW2(_dividend,_shift,_rmask)\
51 ((_dividend)+(((_dividend)>>sizeof(_dividend)*8-1)&(_rmask))>>(_shift))
52 /*Divides _x by 65536, truncating towards 0.*/
53 #define OC_DIV2_16(_x) OC_DIV_POW2(_x,16,0xFFFF)
54 /*Divides _x by 2, truncating towards 0.*/
55 #define OC_DIV2(_x) OC_DIV_POW2(_x,1,0x1)
56 /*Divides _x by 8, truncating towards 0.*/
57 #define OC_DIV8(_x) OC_DIV_POW2(_x,3,0x7)
58 /*Divides _x by 16, truncating towards 0.*/
59 #define OC_DIV16(_x) OC_DIV_POW2(_x,4,0xF)
60 /*Right shifts _dividend by _shift, adding _rval, and subtracting one for
61 negative dividends first..
62 When _rval is (1<<_shift-1), this is equivalent to division with rounding
63 ties towards positive infinity.*/
64 #define OC_DIV_ROUND_POW2(_dividend,_shift,_rval)\
65 ((_dividend)+((_dividend)>>sizeof(_dividend)*8-1)+(_rval)>>(_shift))
66 /*Swaps two integers _a and _b if _a>_b.*/
67 #define OC_SORT2I(_a,_b)\
77 /*All of these macros should expect floats as arguments.*/
78 #define OC_MAXF(_a,_b) ((_a)<(_b)?(_b):(_a))
79 #define OC_MINF(_a,_b) ((_a)>(_b)?(_b):(_a))
80 #define OC_CLAMPF(_a,_b,_c) (OC_MINF(_a,OC_MAXF(_b,_c)))
81 #define OC_FABSF(_f) ((float)fabs(_f))
82 #define OC_SQRTF(_f) ((float)sqrt(_f))
83 #define OC_POWF(_b,_e) ((float)pow(_b,_e))
84 #define OC_LOGF(_f) ((float)log(_f))
85 #define OC_IFLOORF(_f) ((int)floor(_f))
86 #define OC_ICEILF(_f) ((int)ceil(_f))