Skip to content

AFNI/NIfTI Server

Sections
Personal tools
You are here: Home » AFNI » Documentation

Doxygen Source Code Documentation


Main Page   Alphabetical List   Data Structures   File List   Data Fields   Globals   Search  

motion_comp.c

Go to the documentation of this file.
00001 /*
00002  * motion_comp.c
00003  * Copyright (C) 2000-2002 Michel Lespinasse <walken@zoy.org>
00004  * Copyright (C) 1999-2000 Aaron Holtzman <aholtzma@ess.engr.uvic.ca>
00005  *
00006  * This file is part of mpeg2dec, a free MPEG-2 video stream decoder.
00007  * See http://libmpeg2.sourceforge.net/ for updates.
00008  *
00009  * mpeg2dec is free software; you can redistribute it and/or modify
00010  * it under the terms of the GNU General Public License as published by
00011  * the Free Software Foundation; either version 2 of the License, or
00012  * (at your option) any later version.
00013  *
00014  * mpeg2dec is distributed in the hope that it will be useful,
00015  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00016  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00017  * GNU General Public License for more details.
00018  *
00019  * You should have received a copy of the GNU General Public License
00020  * along with this program; if not, write to the Free Software
00021  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00022  */
00023 
00024 #include "config.h"
00025 
00026 #include <inttypes.h>
00027 
00028 #include "mpeg2.h"
00029 #include "mpeg2_internal.h"
00030 
00031 mpeg2_mc_t mpeg2_mc;
00032 
00033 void mpeg2_mc_init (uint32_t accel)
00034 {
00035 #ifdef ARCH_X86
00036     if (accel & MPEG2_ACCEL_X86_MMXEXT)
00037         mpeg2_mc = mpeg2_mc_mmxext;
00038     else if (accel & MPEG2_ACCEL_X86_3DNOW)
00039         mpeg2_mc = mpeg2_mc_3dnow;
00040     else if (accel & MPEG2_ACCEL_X86_MMX)
00041         mpeg2_mc = mpeg2_mc_mmx;
00042     else
00043 #endif
00044 #ifdef ARCH_PPC
00045     if (accel & MPEG2_ACCEL_PPC_ALTIVEC)
00046         mpeg2_mc = mpeg2_mc_altivec;
00047     else
00048 #endif
00049 #ifdef ARCH_ALPHA
00050     if (accel & MPEG2_ACCEL_ALPHA)
00051         mpeg2_mc = mpeg2_mc_alpha;
00052     else
00053 #endif
00054 #ifdef LIBMPEG2_MLIB
00055     if (accel & MPEG2_ACCEL_MLIB)
00056         mpeg2_mc = mpeg2_mc_mlib;
00057     else
00058 #endif
00059         mpeg2_mc = mpeg2_mc_c;
00060 }
00061 
00062 #define avg2(a,b) ((a+b+1)>>1)
00063 #define avg4(a,b,c,d) ((a+b+c+d+2)>>2)
00064 
00065 #define predict_o(i) (ref[i])
00066 #define predict_x(i) (avg2 (ref[i], ref[i+1]))
00067 #define predict_y(i) (avg2 (ref[i], (ref+stride)[i]))
00068 #define predict_xy(i) (avg4 (ref[i], ref[i+1], \
00069                              (ref+stride)[i], (ref+stride)[i+1]))
00070 
00071 #define put(predictor,i) dest[i] = predictor (i)
00072 #define avg(predictor,i) dest[i] = avg2 (predictor (i), dest[i])
00073 
00074 /* mc function template */
00075 
00076 #define MC_FUNC(op,xy)                                                  \
00077 static void MC_##op##_##xy##_16_c (uint8_t * dest, const uint8_t * ref, \
00078                                    const int stride, int height)        \
00079 {                                                                       \
00080     do {                                                                \
00081         op (predict_##xy, 0);                                           \
00082         op (predict_##xy, 1);                                           \
00083         op (predict_##xy, 2);                                           \
00084         op (predict_##xy, 3);                                           \
00085         op (predict_##xy, 4);                                           \
00086         op (predict_##xy, 5);                                           \
00087         op (predict_##xy, 6);                                           \
00088         op (predict_##xy, 7);                                           \
00089         op (predict_##xy, 8);                                           \
00090         op (predict_##xy, 9);                                           \
00091         op (predict_##xy, 10);                                          \
00092         op (predict_##xy, 11);                                          \
00093         op (predict_##xy, 12);                                          \
00094         op (predict_##xy, 13);                                          \
00095         op (predict_##xy, 14);                                          \
00096         op (predict_##xy, 15);                                          \
00097         ref += stride;                                                  \
00098         dest += stride;                                                 \
00099     } while (--height);                                                 \
00100 }                                                                       \
00101 static void MC_##op##_##xy##_8_c (uint8_t * dest, const uint8_t * ref,  \
00102                                   const int stride, int height)         \
00103 {                                                                       \
00104     do {                                                                \
00105         op (predict_##xy, 0);                                           \
00106         op (predict_##xy, 1);                                           \
00107         op (predict_##xy, 2);                                           \
00108         op (predict_##xy, 3);                                           \
00109         op (predict_##xy, 4);                                           \
00110         op (predict_##xy, 5);                                           \
00111         op (predict_##xy, 6);                                           \
00112         op (predict_##xy, 7);                                           \
00113         ref += stride;                                                  \
00114         dest += stride;                                                 \
00115     } while (--height);                                                 \
00116 }
00117 
00118 /* definitions of the actual mc functions */
00119 
00120 MC_FUNC (put,o)
00121 MC_FUNC (avg,o)
00122 MC_FUNC (put,x)
00123 MC_FUNC (avg,x)
00124 MC_FUNC (put,y)
00125 MC_FUNC (avg,y)
00126 MC_FUNC (put,xy)
00127 MC_FUNC (avg,xy)
00128 
00129 MPEG2_MC_EXTERN (c)
 

Powered by Plone

This site conforms to the following standards: