mirror of
https://github.com/ultravideo/uvg266.git
synced 2024-11-23 18:14:06 +00:00
Move basic SAD functions to picture-module.
This commit is contained in:
parent
0e078b2d18
commit
4e36992752
|
@ -559,6 +559,52 @@ uint32_t sad4x4(int16_t *block1, uint32_t stride1,
|
|||
return sum;
|
||||
}
|
||||
|
||||
unsigned cor_sad(unsigned char* pic_data, unsigned char* ref_data,
|
||||
unsigned block_width, unsigned block_height, unsigned width)
|
||||
{
|
||||
unsigned char ref = *ref_data;
|
||||
unsigned x, y;
|
||||
unsigned sad = 0;
|
||||
|
||||
for (y = 0; y < block_height; ++y) {
|
||||
for (x = 0; x < block_width; ++x) {
|
||||
sad += abs(pic_data[y * width + x] - ref);
|
||||
}
|
||||
}
|
||||
|
||||
return sad;
|
||||
}
|
||||
|
||||
unsigned ver_sad(unsigned char* pic_data, unsigned char* ref_data,
|
||||
unsigned block_width, unsigned block_height, unsigned width)
|
||||
{
|
||||
unsigned x, y;
|
||||
unsigned sad = 0;
|
||||
|
||||
for (y = 0; y < block_height; ++y) {
|
||||
for (x = 0; x < block_width; ++x) {
|
||||
sad += abs(pic_data[y * width + x] - ref_data[x]);
|
||||
}
|
||||
}
|
||||
|
||||
return sad;
|
||||
}
|
||||
|
||||
unsigned hor_sad(unsigned char* pic_data, unsigned char* ref_data,
|
||||
unsigned block_width, unsigned block_height, unsigned width)
|
||||
{
|
||||
unsigned x, y;
|
||||
unsigned sad = 0;
|
||||
|
||||
for (y = 0; y < block_height; ++y) {
|
||||
for (x = 0; x < block_width; ++x) {
|
||||
sad += abs(pic_data[y * width + x] - ref_data[y * width]);
|
||||
}
|
||||
}
|
||||
|
||||
return sad;
|
||||
}
|
||||
|
||||
/**
|
||||
* \brief Calculate Sum of Absolute Differences (SAD)
|
||||
*
|
||||
|
@ -573,7 +619,7 @@ uint32_t sad4x4(int16_t *block1, uint32_t stride1,
|
|||
*
|
||||
* \returns Sum of Absolute Differences
|
||||
*/
|
||||
uint32_t sad(uint8_t *data1, uint8_t *data2,
|
||||
uint32_t reg_sad(uint8_t *data1, uint8_t *data2,
|
||||
unsigned width, unsigned height, unsigned stride)
|
||||
{
|
||||
unsigned y, x;
|
||||
|
|
|
@ -120,8 +120,15 @@ uint32_t sad8x8(int16_t *block1, uint32_t stride1,
|
|||
int16_t* block2, uint32_t stride2);
|
||||
uint32_t sad4x4(int16_t *block1, uint32_t stride1,
|
||||
int16_t* block2, uint32_t stride2);
|
||||
uint32_t sad(uint8_t *data1, uint8_t *data2,
|
||||
unsigned width, unsigned height, unsigned stride);
|
||||
|
||||
uint32_t cor_sad(uint8_t *data1, uint8_t *data2,
|
||||
unsigned width, unsigned height, unsigned stride);
|
||||
uint32_t ver_sad(uint8_t *data1, uint8_t *data2,
|
||||
unsigned width, unsigned height, unsigned stride);
|
||||
uint32_t hor_sad(uint8_t *data1, uint8_t *data2,
|
||||
unsigned width, unsigned height, unsigned stride);
|
||||
uint32_t reg_sad(uint8_t *data1, uint8_t *data2,
|
||||
unsigned width, unsigned height, unsigned stride);
|
||||
|
||||
double image_psnr(uint8_t *frame1, uint8_t *frame2, int32_t x, int32_t y);
|
||||
|
||||
|
|
52
src/search.c
52
src/search.c
|
@ -36,52 +36,6 @@
|
|||
&& (x) + (block_width) <= (width) \
|
||||
&& (y) + (block_height) <= (height))
|
||||
|
||||
unsigned cor_sad(unsigned char* pic_data, unsigned char* ref_data,
|
||||
unsigned block_width, unsigned block_height, unsigned width)
|
||||
{
|
||||
unsigned char ref = *ref_data;
|
||||
unsigned x, y;
|
||||
unsigned sad = 0;
|
||||
|
||||
for (y = 0; y < block_height; ++y) {
|
||||
for (x = 0; x < block_width; ++x) {
|
||||
sad += abs(pic_data[y * width + x] - ref);
|
||||
}
|
||||
}
|
||||
|
||||
return sad;
|
||||
}
|
||||
|
||||
unsigned ver_sad(unsigned char* pic_data, unsigned char* ref_data,
|
||||
unsigned block_width, unsigned block_height, unsigned width)
|
||||
{
|
||||
unsigned x, y;
|
||||
unsigned sad = 0;
|
||||
|
||||
for (y = 0; y < block_height; ++y) {
|
||||
for (x = 0; x < block_width; ++x) {
|
||||
sad += abs(pic_data[y * width + x] - ref_data[x]);
|
||||
}
|
||||
}
|
||||
|
||||
return sad;
|
||||
}
|
||||
|
||||
unsigned hor_sad(unsigned char* pic_data, unsigned char* ref_data,
|
||||
unsigned block_width, unsigned block_height, unsigned width)
|
||||
{
|
||||
unsigned x, y;
|
||||
unsigned sad = 0;
|
||||
|
||||
for (y = 0; y < block_height; ++y) {
|
||||
for (x = 0; x < block_width; ++x) {
|
||||
sad += abs(pic_data[y * width + x] - ref_data[y * width]);
|
||||
}
|
||||
}
|
||||
|
||||
return sad;
|
||||
}
|
||||
|
||||
/**
|
||||
* \brief Get Sum of Absolute Differences (SAD) between two blocks in two
|
||||
* different frames.
|
||||
|
@ -149,7 +103,7 @@ unsigned get_block_sad(picture *pic, picture *ref,
|
|||
} else if (bottom) {
|
||||
|
||||
} else {
|
||||
result += sad(pic_data, ref_data, block_width, block_height, width);
|
||||
result += reg_sad(pic_data, ref_data, block_width, block_height, width);
|
||||
}
|
||||
|
||||
return result;
|
||||
|
@ -406,8 +360,8 @@ void search_mv_full(picture *pic, uint8_t *pic_data, uint8_t *ref_data,
|
|||
if (orig_x + x < 0 || orig_y + y < 0 || orig_x + x > pic->width - block_width
|
||||
|| orig_y + y > pic->height - block_height) return;
|
||||
|
||||
cost = sad(pic_data, &ref_data[(orig_y + y) * pic->width + (orig_x + x)],
|
||||
block_width, block_height, pic->width) + 1;
|
||||
cost = reg_sad(pic_data, &ref_data[(orig_y + y) * pic->width + (orig_x + x)],
|
||||
block_width, block_height, pic->width) + 1;
|
||||
if (cost < cur_cu->inter.cost) {
|
||||
cur_cu->inter.cost = cost;
|
||||
cur_cu->inter.mv[0] = x << 2;
|
||||
|
|
Loading…
Reference in a new issue