121 |
uint32_t iEdgedWidth; |
uint32_t iEdgedWidth; |
122 |
uint32_t iFcode; |
uint32_t iFcode; |
123 |
int * temp; |
int * temp; |
124 |
|
int * dir; |
125 |
int qpel, qpel_precision; |
int qpel, qpel_precision; |
126 |
int chroma; |
int chroma; |
127 |
int rrv; |
int rrv; |
146 |
|
|
147 |
|
|
148 |
typedef void(CheckFunc)(const int x, const int y, |
typedef void(CheckFunc)(const int x, const int y, |
149 |
const int Direction, int * const dir, |
const SearchData * const Data, |
150 |
const SearchData * const Data); |
const int Direction); |
|
CheckFunc *CheckCandidate; |
|
151 |
|
|
152 |
/* |
/* |
153 |
* Calculate the min/max range |
* Calculate the min/max range |
179 |
} |
} |
180 |
|
|
181 |
k = (int)(width - (x<<block_sz))<<precision; |
k = (int)(width - (x<<block_sz))<<precision; |
182 |
*max_dx = min(high, k); |
*max_dx = MIN(high, k); |
183 |
k = (int)(height - (y<<block_sz))<<precision; |
k = (int)(height - (y<<block_sz))<<precision; |
184 |
*max_dy = min(high, k); |
*max_dy = MIN(high, k); |
185 |
|
|
186 |
k = (-(int)((x+1)<<block_sz))<<precision; |
k = (-(int)((x+1)<<block_sz))<<precision; |
187 |
*min_dx = max(low, k); |
*min_dx = MAX(low, k); |
188 |
k = (-(int)((y+1)<<block_sz))<<precision; |
k = (-(int)((y+1)<<block_sz))<<precision; |
189 |
*min_dy = max(low, k); |
*min_dy = MAX(low, k); |
190 |
} |
} |
191 |
|
|
192 |
typedef void MainSearchFunc(int x, int y, const SearchData * const Data, int bDirection); |
typedef void |
193 |
|
MainSearchFunc(int x, int y, const SearchData * const Data, |
194 |
|
int bDirection, CheckFunc * const CheckCandidate); |
195 |
|
|
196 |
static MainSearchFunc DiamondSearch, AdvDiamondSearch, SquareSearch; |
static MainSearchFunc DiamondSearch, AdvDiamondSearch, SquareSearch; |
197 |
|
|