/*===========================================================================*
* search.h *
* *
* stuff dealing with the motion search *
* *
*===========================================================================*/
/*
* Copyright (c) 1995 The Regents of the University of California.
* All rights reserved.
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose, without fee, and without written agreement is
* hereby granted, provided that the above copyright notice and the following
* two paragraphs appear in all copies of this software.
*
* IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT
* OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF
* CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
* AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
*/
/*
* $Header: /share/cvs/AFNI/src/mpeg_encodedir/headers/search.h,v 1.4 2004/04/02 15:12:42 rwcox Exp $
* $Log: search.h,v $
* Revision 1.4 2004/04/02 15:12:42 rwcox
* Cput
*
* Revision 1.3 2003/12/23 13:50:09 rwcox
* Cput
*
* Revision 1.2 2003/12/03 14:46:15 rwcox
* Cput
*
* Revision 1.1 2001/12/17 18:25:45 rwcox
* Cadd
*
* Revision 1.6 1995/08/15 23:43:36 smoot
* *** empty log message ***
*
* Revision 1.5 1995/01/19 23:55:20 eyhung
* Changed copyrights
*
* Revision 1.4 1994/12/07 00:42:01 smoot
* Added seperate P and B search ranges
*
* Revision 1.3 1994/11/12 02:12:58 keving
* nothing
*
* Revision 1.2 1993/07/22 22:24:23 keving
* nothing
*
* Revision 1.1 1993/07/09 00:17:23 keving
* nothing
*
*/
/*==============*
* HEADER FILES *
*==============*/
#include "ansi.h"
/*===========*
* CONSTANTS *
*===========*/
#define PSEARCH_SUBSAMPLE 0
#define PSEARCH_EXHAUSTIVE 1
#define PSEARCH_LOGARITHMIC 2
#define PSEARCH_TWOLEVEL 3
#define BSEARCH_EXHAUSTIVE 0
#define BSEARCH_CROSS2 1
#define BSEARCH_SIMPLE 2
/*========*
* MACROS *
*========*/
#define COMPUTE_MOTION_BOUNDARY(by,bx,stepSize,leftMY,leftMX,rightMY,rightMX)\
leftMY = -2*DCTSIZE*by; /* these are valid motion vectors */ \
leftMX = -2*DCTSIZE*bx; \
/* these are invalid motion vectors */ \
rightMY = 2*(Fsize_y - (by+2)*DCTSIZE + 1) - 1; \
rightMX = 2*(Fsize_x - (bx+2)*DCTSIZE + 1) - 1; \
\
if ( stepSize == 2 ) { \
rightMY++; \
rightMX++; \
}
#define VALID_MOTION(y,x) \
(((y) >= leftMY) && ((y) < rightMY) && \
((x) >= leftMX) && ((x) < rightMX) )
/*===============================*
* EXTERNAL PROCEDURE prototypes *
*===============================*/
void SetPSearchAlg _ANSI_ARGS_((char *alg));
void SetBSearchAlg _ANSI_ARGS_((char *alg));
char *BSearchName _ANSI_ARGS_((void));
char *PSearchName _ANSI_ARGS_((void));
int32 PLogarithmicSearch _ANSI_ARGS_((LumBlock currentBlock,
MpegFrame *prev,
int by, int bx,
int *motionY, int *motionX, int searchRange));
int32 PSubSampleSearch _ANSI_ARGS_((LumBlock currentBlock,
MpegFrame *prev, int by, int bx,
int *motionY, int *motionX, int searchRange));
int32 PLocalSearch _ANSI_ARGS_((LumBlock currentBlock,
MpegFrame *prev, int by, int bx,
int *motionY, int *motionX,
int32 bestSoFar, int searchRange));
int32 PTwoLevelSearch _ANSI_ARGS_((LumBlock currentBlock,
MpegFrame *prev, int by, int bx,
int *motionY, int *motionX,
int32 bestSoFar, int searchRange));
boolean PMotionSearch _ANSI_ARGS_((LumBlock currentBlock,
MpegFrame *prev,
int by, int bx,
int *motionY, int *motionX));
/*==================*
* GLOBAL VARIABLES *
*==================*/
extern int psearchAlg;
syntax highlighted by Code2HTML, v. 0.9.1