Blame pph/fixed_generic.h

Packit 675970
/* Copyright (C) 2003 Jean-Marc Valin */
Packit 675970
/**
Packit 675970
   @file fixed_generic.h
Packit 675970
   @brief Generic fixed-point operations
Packit 675970
*/
Packit 675970
/*
Packit 675970
   Redistribution and use in source and binary forms, with or without
Packit 675970
   modification, are permitted provided that the following conditions
Packit 675970
   are met:
Packit 675970
   
Packit 675970
   - Redistributions of source code must retain the above copyright
Packit 675970
   notice, this list of conditions and the following disclaimer.
Packit 675970
   
Packit 675970
   - Redistributions in binary form must reproduce the above copyright
Packit 675970
   notice, this list of conditions and the following disclaimer in the
Packit 675970
   documentation and/or other materials provided with the distribution.
Packit 675970
   
Packit 675970
   - Neither the name of the Xiph.org Foundation nor the names of its
Packit 675970
   contributors may be used to endorse or promote products derived from
Packit 675970
   this software without specific prior written permission.
Packit 675970
   
Packit 675970
   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 675970
   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 675970
   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 675970
   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
Packit 675970
   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
Packit 675970
   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
Packit 675970
   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
Packit 675970
   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
Packit 675970
   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
Packit 675970
   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
Packit 675970
   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 675970
*/
Packit 675970
Packit 675970
#ifndef FIXED_GENERIC_H
Packit 675970
#define FIXED_GENERIC_H
Packit 675970
Packit 675970
#define QCONST16(x,bits) ((spx_word16_t)(.5+(x)*(((spx_word32_t)1)<<(bits))))
Packit 675970
#define QCONST32(x,bits) ((spx_word32_t)(.5+(x)*(((spx_word32_t)1)<<(bits))))
Packit 675970
Packit 675970
#define NEG16(x) (-(x))
Packit 675970
#define NEG32(x) (-(x))
Packit 675970
#define EXTRACT16(x) ((spx_word16_t)(x))
Packit 675970
#define EXTEND32(x) ((spx_word32_t)(x))
Packit 675970
#define SHR16(a,shift) ((a) >> (shift))
Packit 675970
#define SHL16(a,shift) ((a) << (shift))
Packit 675970
#define SHR32(a,shift) ((a) >> (shift))
Packit 675970
#define SHL32(a,shift) ((a) << (shift))
Packit 675970
#define PSHR16(a,shift) (SHR16((a)+((1<<((shift))>>1)),shift))
Packit 675970
#define PSHR32(a,shift) (SHR32((a)+((1<<((shift))>>1)),shift))
Packit 675970
#define VSHR32(a, shift) (((shift)>0) ? SHR32(a, shift) : SHL32(a, -(shift)))
Packit 675970
#define SATURATE16(x,a) (((x)>(a) ? (a) : (x)<-(a) ? -(a) : (x)))
Packit 675970
#define SATURATE32(x,a) (((x)>(a) ? (a) : (x)<-(a) ? -(a) : (x)))
Packit 675970
Packit 675970
#define SHR(a,shift) ((a) >> (shift))
Packit 675970
#define SHL(a,shift) ((spx_word32_t)(a) << (shift))
Packit 675970
#define PSHR(a,shift) (SHR((a)+((1<<((shift))>>1)),shift))
Packit 675970
#define SATURATE(x,a) (((x)>(a) ? (a) : (x)<-(a) ? -(a) : (x)))
Packit 675970
Packit 675970
Packit 675970
#define ADD16(a,b) ((spx_word16_t)((spx_word16_t)(a)+(spx_word16_t)(b)))
Packit 675970
#define SUB16(a,b) ((spx_word16_t)(a)-(spx_word16_t)(b))
Packit 675970
#define ADD32(a,b) ((spx_word32_t)(a)+(spx_word32_t)(b))
Packit 675970
#define SUB32(a,b) ((spx_word32_t)(a)-(spx_word32_t)(b))
Packit 675970
Packit 675970
Packit 675970
/* result fits in 16 bits */
Packit 675970
#define MULT16_16_16(a,b)     ((((spx_word16_t)(a))*((spx_word16_t)(b))))
Packit 675970
Packit 675970
/* (spx_word32_t)(spx_word16_t) gives TI compiler a hint that it's 16x16->32 multiply */
Packit 675970
#define MULT16_16(a,b)     (((spx_word32_t)(spx_word16_t)(a))*((spx_word32_t)(spx_word16_t)(b)))
Packit 675970
Packit 675970
#define MAC16_16(c,a,b) (ADD32((c),MULT16_16((a),(b))))
Packit 675970
#define MULT16_32_Q12(a,b) ADD32(MULT16_16((a),SHR((b),12)), SHR(MULT16_16((a),((b)&0x00000fff)),12))
Packit 675970
#define MULT16_32_Q13(a,b) ADD32(MULT16_16((a),SHR((b),13)), SHR(MULT16_16((a),((b)&0x00001fff)),13))
Packit 675970
#define MULT16_32_Q14(a,b) ADD32(MULT16_16((a),SHR((b),14)), SHR(MULT16_16((a),((b)&0x00003fff)),14))
Packit 675970
Packit 675970
#define MULT16_32_Q11(a,b) ADD32(MULT16_16((a),SHR((b),11)), SHR(MULT16_16((a),((b)&0x000007ff)),11))
Packit 675970
#define MAC16_32_Q11(c,a,b) ADD32(c,ADD32(MULT16_16((a),SHR((b),11)), SHR(MULT16_16((a),((b)&0x000007ff)),11)))
Packit 675970
Packit 675970
#define MULT16_32_P15(a,b) ADD32(MULT16_16((a),SHR((b),15)), PSHR(MULT16_16((a),((b)&0x00007fff)),15))
Packit 675970
#define MULT16_32_Q15(a,b) ADD32(MULT16_16((a),SHR((b),15)), SHR(MULT16_16((a),((b)&0x00007fff)),15))
Packit 675970
#define MAC16_32_Q15(c,a,b) ADD32(c,ADD32(MULT16_16((a),SHR((b),15)), SHR(MULT16_16((a),((b)&0x00007fff)),15)))
Packit 675970
Packit 675970
Packit 675970
#define MAC16_16_Q11(c,a,b)     (ADD32((c),SHR(MULT16_16((a),(b)),11)))
Packit 675970
#define MAC16_16_Q13(c,a,b)     (ADD32((c),SHR(MULT16_16((a),(b)),13)))
Packit 675970
#define MAC16_16_P13(c,a,b)     (ADD32((c),SHR(ADD32(4096,MULT16_16((a),(b))),13)))
Packit 675970
Packit 675970
#define MULT16_16_Q11_32(a,b) (SHR(MULT16_16((a),(b)),11))
Packit 675970
#define MULT16_16_Q13(a,b) (SHR(MULT16_16((a),(b)),13))
Packit 675970
#define MULT16_16_Q14(a,b) (SHR(MULT16_16((a),(b)),14))
Packit 675970
#define MULT16_16_Q15(a,b) (SHR(MULT16_16((a),(b)),15))
Packit 675970
Packit 675970
#define MULT16_16_P13(a,b) (SHR(ADD32(4096,MULT16_16((a),(b))),13))
Packit 675970
#define MULT16_16_P14(a,b) (SHR(ADD32(8192,MULT16_16((a),(b))),14))
Packit 675970
#define MULT16_16_P15(a,b) (SHR(ADD32(16384,MULT16_16((a),(b))),15))
Packit 675970
Packit 675970
#define MUL_16_32_R15(a,bh,bl) ADD32(MULT16_16((a),(bh)), SHR(MULT16_16((a),(bl)),15))
Packit 675970
Packit 675970
#define DIV32_16(a,b) ((spx_word16_t)(((spx_word32_t)(a))/((spx_word16_t)(b))))
Packit 675970
#define PDIV32_16(a,b) ((spx_word16_t)(((spx_word32_t)(a)+((spx_word16_t)(b)>>1))/((spx_word16_t)(b))))
Packit 675970
#define DIV32(a,b) (((spx_word32_t)(a))/((spx_word32_t)(b)))
Packit 675970
#define PDIV32(a,b) (((spx_word32_t)(a)+((spx_word16_t)(b)>>1))/((spx_word32_t)(b)))
Packit 675970
Packit 675970
#endif