You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
145 lines
3.5 KiB
145 lines
3.5 KiB
2 years ago
|
/*
|
||
|
* H.265 video codec.
|
||
|
* Copyright (c) 2015 struktur AG, Dirk Farin <farin@struktur.de>
|
||
|
*
|
||
|
* This file is part of libde265.
|
||
|
*
|
||
|
* libde265 is free software: you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License as published by
|
||
|
* the Free Software Foundation, either version 3 of the License, or
|
||
|
* (at your option) any later version.
|
||
|
*
|
||
|
* libde265 is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
|
* along with libde265. If not, see <http://www.gnu.org/licenses/>.
|
||
|
*/
|
||
|
|
||
|
#include "dct.h"
|
||
|
|
||
|
|
||
|
// --- FDCT ---
|
||
|
|
||
|
void DSPFunc_FDCT_Base::dump(int x,int y)
|
||
|
{
|
||
|
printf("-> ");
|
||
|
for (int yy=0;yy<blkSize;yy++)
|
||
|
for (int xx=0;xx<blkSize;xx++)
|
||
|
printf("%d ", *(residuals+x+xx+(y+yy)*stride));
|
||
|
printf("\n");
|
||
|
|
||
|
printf(" ");
|
||
|
for (int x=0;x<blkSize*blkSize;x++)
|
||
|
printf("%d ", coeffs[x]);
|
||
|
printf("\n");
|
||
|
|
||
|
int32_t out[32*32];
|
||
|
transform_idct_8x8_fallback(out, coeffs, 20-8, 15);
|
||
|
|
||
|
printf(" ");
|
||
|
for (int x=0;x<blkSize*blkSize;x++)
|
||
|
printf("%d ", out[x]);
|
||
|
printf("\n");
|
||
|
}
|
||
|
|
||
|
|
||
|
bool DSPFunc_FDCT_Base::compareToReferenceImplementation()
|
||
|
{
|
||
|
DSPFunc_FDCT_Base* refImpl = dynamic_cast<DSPFunc_FDCT_Base*>(referenceImplementation());
|
||
|
|
||
|
for (int i=0;i<blkSize*blkSize;i++)
|
||
|
if (coeffs[i] != refImpl->coeffs[i])
|
||
|
return false;
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
|
||
|
bool DSPFunc_FDCT_Base::prepareNextImage(std::shared_ptr<const de265_image> img)
|
||
|
{
|
||
|
if (!curr_image) {
|
||
|
curr_image = img;
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
prev_image = curr_image;
|
||
|
curr_image = img;
|
||
|
|
||
|
int w = curr_image->get_width(0);
|
||
|
int h = curr_image->get_height(0);
|
||
|
|
||
|
if (residuals==NULL) {
|
||
|
int align=16;
|
||
|
stride = (w+align-1)/align*align;
|
||
|
residuals = new int16_t[stride*h];
|
||
|
}
|
||
|
|
||
|
int cstride = curr_image->get_luma_stride();
|
||
|
int pstride = prev_image->get_luma_stride();
|
||
|
const uint8_t* curr = curr_image->get_image_plane_at_pos(0,0,0);
|
||
|
const uint8_t* prev = prev_image->get_image_plane_at_pos(0,0,0);
|
||
|
|
||
|
for (int y=0;y<h;y++)
|
||
|
for (int x=0;x<w;x++) {
|
||
|
residuals[y*stride+x] = curr[y*cstride+x] - prev[y*pstride+x];
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
|
||
|
// --- IDCT ---
|
||
|
|
||
|
bool DSPFunc_IDCT_Base::compareToReferenceImplementation()
|
||
|
{
|
||
|
DSPFunc_IDCT_Base* refImpl = dynamic_cast<DSPFunc_IDCT_Base*>(referenceImplementation());
|
||
|
|
||
|
for (int i=0;i<blkSize*blkSize;i++)
|
||
|
if (out[i] != refImpl->out[i])
|
||
|
return false;
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
|
||
|
bool DSPFunc_IDCT_Base::prepareNextImage(std::shared_ptr<const de265_image> img)
|
||
|
{
|
||
|
// --- generate fake coefficients ---
|
||
|
// difference between two frames
|
||
|
|
||
|
if (!curr_image) {
|
||
|
curr_image = img;
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
prev_image = curr_image;
|
||
|
curr_image = img;
|
||
|
|
||
|
int w = curr_image->get_width(0);
|
||
|
int h = curr_image->get_height(0);
|
||
|
|
||
|
int align = blkSize;
|
||
|
width = (w+align-1) / align * align;
|
||
|
|
||
|
blksPerRow = w/blkSize;
|
||
|
|
||
|
if (coeffs==NULL) {
|
||
|
coeffs = new int16_t[width*h];
|
||
|
}
|
||
|
|
||
|
int cstride = curr_image->get_luma_stride();
|
||
|
int pstride = prev_image->get_luma_stride();
|
||
|
const uint8_t* curr = curr_image->get_image_plane_at_pos(0,0,0);
|
||
|
const uint8_t* prev = prev_image->get_image_plane_at_pos(0,0,0);
|
||
|
|
||
|
for (int y=0;y<h;y++)
|
||
|
for (int x=0;x<w;x++) {
|
||
|
coeffs[y*w+x] = curr[y*cstride+x] - prev[y*pstride+x];
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|