2015-10-28 23:01:23 +03:00
|
|
|
/*
|
2016-11-29 02:26:06 +03:00
|
|
|
* Copyright (c) 2016, Alliance for Open Media. All rights reserved
|
2015-10-28 23:01:23 +03:00
|
|
|
*
|
2016-11-29 02:26:06 +03:00
|
|
|
* This source code is subject to the terms of the BSD 2 Clause License and
|
|
|
|
* the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
|
|
|
|
* was not distributed with this source code in the LICENSE file, you can
|
|
|
|
* obtain it at www.aomedia.org/license/software. If the Alliance for Open
|
|
|
|
* Media Patent License 1.0 was not distributed with this source code in the
|
|
|
|
* PATENTS file, you can obtain it at www.aomedia.org/license/patent.
|
2015-10-28 23:01:23 +03:00
|
|
|
*/
|
|
|
|
|
2016-08-31 00:01:10 +03:00
|
|
|
#ifndef AV1_FWD_TXFM2D_CFG_H_
|
|
|
|
#define AV1_FWD_TXFM2D_CFG_H_
|
2016-08-23 02:08:15 +03:00
|
|
|
#include "av1/common/enums.h"
|
2016-08-31 00:01:10 +03:00
|
|
|
#include "av1/common/av1_fwd_txfm1d.h"
|
2015-10-28 23:01:23 +03:00
|
|
|
// ---------------- config fwd_dct_dct_4 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_dct_4[3] = { 2, 0, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_dct_4[4] = { 15, 16, 17, 17 };
|
|
|
|
static const int8_t fwd_stage_range_row_dct_dct_4[4] = { 17, 18, 18, 18 };
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_dct_4[4] = { 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_dct_4[4] = { 13, 13, 13, 13 };
|
2015-10-28 23:01:23 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_dct_4 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
4, // .txfm_size
|
|
|
|
4, // .stage_num_col
|
|
|
|
4, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_dct_dct_4, // .shift
|
|
|
|
fwd_stage_range_col_dct_dct_4, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_dct_4, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_dct_4, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_dct_4, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT4, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT4
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:01:23 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_dct_dct_8 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_dct_8[3] = { 2, -1, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_dct_8[6] = {
|
|
|
|
15, 16, 17, 18, 18, 18
|
|
|
|
};
|
|
|
|
static const int8_t fwd_stage_range_row_dct_dct_8[6] = {
|
|
|
|
17, 18, 19, 19, 19, 19
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_dct_8[6] = { 13, 13, 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_dct_8[6] = { 13, 13, 13, 13, 13, 13 };
|
2015-10-28 23:01:23 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_dct_8 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
8, // .txfm_size
|
|
|
|
6, // .stage_num_col
|
|
|
|
6, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_dct_dct_8, // .shift
|
|
|
|
fwd_stage_range_col_dct_dct_8, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_dct_8, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_dct_8, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_dct_8, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT8, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT8
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:01:23 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_dct_dct_16 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_dct_16[3] = { 2, -2, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_dct_16[8] = { 15, 16, 17, 18,
|
|
|
|
19, 19, 19, 19 };
|
|
|
|
static const int8_t fwd_stage_range_row_dct_dct_16[8] = { 17, 18, 19, 20,
|
|
|
|
20, 20, 20, 20 };
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_dct_16[8] = { 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_dct_16[8] = { 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12 };
|
2015-10-28 23:01:23 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_dct_16 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
16, // .txfm_size
|
|
|
|
8, // .stage_num_col
|
|
|
|
8, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_dct_dct_16, // .shift
|
|
|
|
fwd_stage_range_col_dct_dct_16, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_dct_16, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_dct_16, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_dct_16, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT16, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT16
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:01:23 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_dct_dct_32 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_dct_32[3] = { 2, -4, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_dct_32[10] = { 15, 16, 17, 18, 19,
|
|
|
|
20, 20, 20, 20, 20 };
|
|
|
|
static const int8_t fwd_stage_range_row_dct_dct_32[10] = { 16, 17, 18, 19, 20,
|
|
|
|
20, 20, 20, 20, 20 };
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_dct_32[10] = { 12, 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12, 12 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_dct_32[10] = { 12, 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12, 12 };
|
2015-10-28 23:01:23 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_dct_32 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
32, // .txfm_size
|
|
|
|
10, // .stage_num_col
|
|
|
|
10, // .stage_num_row
|
|
|
|
// 1, // .log_scale
|
|
|
|
fwd_shift_dct_dct_32, // .shift
|
|
|
|
fwd_stage_range_col_dct_dct_32, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_dct_32, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_dct_32, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_dct_32, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT32, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT32
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:01:23 +03:00
|
|
|
|
2016-03-14 22:02:27 +03:00
|
|
|
// ---------------- config fwd_dct_dct_64 ----------------
|
2016-11-02 00:37:39 +03:00
|
|
|
static const int8_t fwd_shift_dct_dct_64[3] = { 0, -2, -2 };
|
2016-03-17 03:15:27 +03:00
|
|
|
static const int8_t fwd_stage_range_col_dct_dct_64[12] = {
|
2016-08-12 04:55:00 +03:00
|
|
|
13, 14, 15, 16, 17, 18, 19, 19, 19, 19, 19, 19
|
|
|
|
};
|
2016-03-17 03:15:27 +03:00
|
|
|
static const int8_t fwd_stage_range_row_dct_dct_64[12] = {
|
2016-08-12 04:55:00 +03:00
|
|
|
17, 18, 19, 20, 21, 22, 22, 22, 22, 22, 22, 22
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_dct_64[12] = { 15, 15, 15, 15, 15, 14,
|
|
|
|
13, 13, 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_dct_64[12] = { 15, 14, 13, 12, 11, 10,
|
|
|
|
10, 10, 10, 10, 10, 10 };
|
2016-03-14 22:02:27 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_dct_64 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
64, // .txfm_size
|
|
|
|
12, // .stage_num_col
|
|
|
|
12, // .stage_num_row
|
|
|
|
fwd_shift_dct_dct_64, // .shift
|
|
|
|
fwd_stage_range_col_dct_dct_64, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_dct_64, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_dct_64, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_dct_64, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT64, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT64
|
|
|
|
}; // .txfm_type_row
|
2016-03-14 22:02:27 +03:00
|
|
|
|
2015-10-28 23:02:16 +03:00
|
|
|
// ---------------- config fwd_dct_adst_4 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_adst_4[3] = { 2, 0, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_adst_4[4] = { 15, 16, 17, 17 };
|
|
|
|
static const int8_t fwd_stage_range_row_dct_adst_4[6] = {
|
|
|
|
17, 17, 17, 18, 18, 18
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_adst_4[4] = { 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_adst_4[6] = { 13, 13, 13, 13, 13, 13 };
|
2015-10-28 23:02:16 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_adst_4 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
4, // .txfm_size
|
|
|
|
4, // .stage_num_col
|
|
|
|
6, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_dct_adst_4, // .shift
|
|
|
|
fwd_stage_range_col_dct_adst_4, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_adst_4, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_adst_4, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_adst_4, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT4, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST4
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:16 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_dct_adst_8 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_adst_8[3] = { 2, -1, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_adst_8[6] = {
|
|
|
|
15, 16, 17, 18, 18, 18
|
|
|
|
};
|
|
|
|
static const int8_t fwd_stage_range_row_dct_adst_8[8] = { 17, 17, 17, 18,
|
|
|
|
18, 19, 19, 19 };
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_adst_8[6] = { 13, 13, 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_adst_8[8] = { 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13 };
|
2015-10-28 23:02:16 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_adst_8 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
8, // .txfm_size
|
|
|
|
6, // .stage_num_col
|
|
|
|
8, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_dct_adst_8, // .shift
|
|
|
|
fwd_stage_range_col_dct_adst_8, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_adst_8, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_adst_8, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_adst_8, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT8, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST8
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:16 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_dct_adst_16 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_adst_16[3] = { 2, -2, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_adst_16[8] = { 15, 16, 17, 18,
|
|
|
|
19, 19, 19, 19 };
|
|
|
|
static const int8_t fwd_stage_range_row_dct_adst_16[10] = {
|
|
|
|
17, 17, 17, 18, 18, 19, 19, 20, 20, 20
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_adst_16[8] = { 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_adst_16[10] = { 12, 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12, 12 };
|
2015-10-28 23:02:16 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_adst_16 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
16, // .txfm_size
|
|
|
|
8, // .stage_num_col
|
|
|
|
10, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_dct_adst_16, // .shift
|
|
|
|
fwd_stage_range_col_dct_adst_16, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_adst_16, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_adst_16, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_adst_16, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT16, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST16
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:16 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_dct_adst_32 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_dct_adst_32[3] = { 2, -4, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_dct_adst_32[10] = {
|
|
|
|
15, 16, 17, 18, 19, 20, 20, 20, 20, 20
|
|
|
|
};
|
2016-02-10 02:38:27 +03:00
|
|
|
static const int8_t fwd_stage_range_row_dct_adst_32[12] = {
|
2016-08-12 04:55:00 +03:00
|
|
|
16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 20
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_dct_adst_32[10] = { 12, 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12, 12 };
|
|
|
|
static const int8_t fwd_cos_bit_row_dct_adst_32[12] = {
|
|
|
|
12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12
|
|
|
|
};
|
2015-10-28 23:02:16 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_dct_adst_32 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
32, // .txfm_size
|
|
|
|
10, // .stage_num_col
|
|
|
|
12, // .stage_num_row
|
|
|
|
// 1, // .log_scale
|
|
|
|
fwd_shift_dct_adst_32, // .shift
|
|
|
|
fwd_stage_range_col_dct_adst_32, // .stage_range_col
|
|
|
|
fwd_stage_range_row_dct_adst_32, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_dct_adst_32, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_dct_adst_32, // .cos_bit_row
|
|
|
|
TXFM_TYPE_DCT32, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST32
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:39 +03:00
|
|
|
// ---------------- config fwd_adst_adst_4 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_adst_4[3] = { 2, 0, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_adst_adst_4[6] = { 15, 15, 16,
|
|
|
|
17, 17, 17 };
|
|
|
|
static const int8_t fwd_stage_range_row_adst_adst_4[6] = { 17, 17, 17,
|
|
|
|
18, 18, 18 };
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_adst_4[6] = { 13, 13, 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_adst_4[6] = { 13, 13, 13, 13, 13, 13 };
|
2015-10-28 23:02:39 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_adst_4 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
4, // .txfm_size
|
|
|
|
6, // .stage_num_col
|
|
|
|
6, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_adst_adst_4, // .shift
|
|
|
|
fwd_stage_range_col_adst_adst_4, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_adst_4, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_adst_4, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_adst_4, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST4, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST4
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:39 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_adst_adst_8 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_adst_8[3] = { 2, -1, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_adst_adst_8[8] = { 15, 15, 16, 17,
|
|
|
|
17, 18, 18, 18 };
|
|
|
|
static const int8_t fwd_stage_range_row_adst_adst_8[8] = { 17, 17, 17, 18,
|
|
|
|
18, 19, 19, 19 };
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_adst_8[8] = { 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_adst_8[8] = { 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13 };
|
2015-10-28 23:02:39 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_adst_8 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
8, // .txfm_size
|
|
|
|
8, // .stage_num_col
|
|
|
|
8, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_adst_adst_8, // .shift
|
|
|
|
fwd_stage_range_col_adst_adst_8, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_adst_8, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_adst_8, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_adst_8, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST8, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST8
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:39 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_adst_adst_16 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_adst_16[3] = { 2, -2, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_adst_adst_16[10] = {
|
|
|
|
15, 15, 16, 17, 17, 18, 18, 19, 19, 19
|
|
|
|
};
|
|
|
|
static const int8_t fwd_stage_range_row_adst_adst_16[10] = {
|
|
|
|
17, 17, 17, 18, 18, 19, 19, 20, 20, 20
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_adst_16[10] = { 13, 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_adst_16[10] = { 12, 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12, 12 };
|
2015-10-28 23:02:39 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_adst_16 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
16, // .txfm_size
|
|
|
|
10, // .stage_num_col
|
|
|
|
10, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_adst_adst_16, // .shift
|
|
|
|
fwd_stage_range_col_adst_adst_16, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_adst_16, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_adst_16, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_adst_16, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST16, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST16
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:39 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_adst_adst_32 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_adst_32[3] = { 2, -4, 0 };
|
2016-02-10 02:38:27 +03:00
|
|
|
static const int8_t fwd_stage_range_col_adst_adst_32[12] = {
|
2016-08-12 04:55:00 +03:00
|
|
|
15, 15, 16, 17, 17, 18, 18, 19, 19, 20, 20, 20
|
|
|
|
};
|
2016-02-10 02:38:27 +03:00
|
|
|
static const int8_t fwd_stage_range_row_adst_adst_32[12] = {
|
2016-08-12 04:55:00 +03:00
|
|
|
16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 20
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_adst_32[12] = {
|
|
|
|
12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_adst_32[12] = {
|
|
|
|
12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12
|
|
|
|
};
|
2015-10-28 23:02:39 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_adst_32 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
32, // .txfm_size
|
|
|
|
12, // .stage_num_col
|
|
|
|
12, // .stage_num_row
|
|
|
|
// 1, // .log_scale
|
|
|
|
fwd_shift_adst_adst_32, // .shift
|
|
|
|
fwd_stage_range_col_adst_adst_32, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_adst_32, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_adst_32, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_adst_32, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST32, // .txfm_type_col
|
|
|
|
TXFM_TYPE_ADST32
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:02:39 +03:00
|
|
|
|
2015-10-28 23:57:48 +03:00
|
|
|
// ---------------- config fwd_adst_dct_4 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_dct_4[3] = { 2, 0, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_adst_dct_4[6] = {
|
|
|
|
15, 15, 16, 17, 17, 17
|
|
|
|
};
|
|
|
|
static const int8_t fwd_stage_range_row_adst_dct_4[4] = { 17, 18, 18, 18 };
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_dct_4[6] = { 13, 13, 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_dct_4[4] = { 13, 13, 13, 13 };
|
2015-10-28 23:57:48 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_dct_4 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
4, // .txfm_size
|
|
|
|
6, // .stage_num_col
|
|
|
|
4, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_adst_dct_4, // .shift
|
|
|
|
fwd_stage_range_col_adst_dct_4, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_dct_4, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_dct_4, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_dct_4, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST4, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT4
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:57:48 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_adst_dct_8 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_dct_8[3] = { 2, -1, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_adst_dct_8[8] = { 15, 15, 16, 17,
|
|
|
|
17, 18, 18, 18 };
|
|
|
|
static const int8_t fwd_stage_range_row_adst_dct_8[6] = {
|
|
|
|
17, 18, 19, 19, 19, 19
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_dct_8[8] = { 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_dct_8[6] = { 13, 13, 13, 13, 13, 13 };
|
2015-10-28 23:57:48 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_dct_8 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
8, // .txfm_size
|
|
|
|
8, // .stage_num_col
|
|
|
|
6, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_adst_dct_8, // .shift
|
|
|
|
fwd_stage_range_col_adst_dct_8, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_dct_8, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_dct_8, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_dct_8, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST8, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT8
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:57:48 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_adst_dct_16 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_dct_16[3] = { 2, -2, 0 };
|
|
|
|
static const int8_t fwd_stage_range_col_adst_dct_16[10] = {
|
|
|
|
15, 15, 16, 17, 17, 18, 18, 19, 19, 19
|
|
|
|
};
|
|
|
|
static const int8_t fwd_stage_range_row_adst_dct_16[8] = { 17, 18, 19, 20,
|
|
|
|
20, 20, 20, 20 };
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_dct_16[10] = { 13, 13, 13, 13, 13,
|
|
|
|
13, 13, 13, 13, 13 };
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_dct_16[8] = { 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12 };
|
2015-10-28 23:57:48 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_dct_16 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
16, // .txfm_size
|
|
|
|
10, // .stage_num_col
|
|
|
|
8, // .stage_num_row
|
|
|
|
// 0, // .log_scale
|
|
|
|
fwd_shift_adst_dct_16, // .shift
|
|
|
|
fwd_stage_range_col_adst_dct_16, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_dct_16, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_dct_16, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_dct_16, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST16, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT16
|
|
|
|
}; // .txfm_type_row
|
2015-10-28 23:57:48 +03:00
|
|
|
|
|
|
|
// ---------------- config fwd_adst_dct_32 ----------------
|
2016-08-12 04:55:00 +03:00
|
|
|
static const int8_t fwd_shift_adst_dct_32[3] = { 2, -4, 0 };
|
2016-02-10 02:38:27 +03:00
|
|
|
static const int8_t fwd_stage_range_col_adst_dct_32[12] = {
|
2016-08-12 04:55:00 +03:00
|
|
|
15, 15, 16, 17, 17, 18, 18, 19, 19, 20, 20, 20
|
|
|
|
};
|
|
|
|
static const int8_t fwd_stage_range_row_adst_dct_32[10] = {
|
|
|
|
16, 17, 18, 19, 20, 20, 20, 20, 20, 20
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_col_adst_dct_32[12] = {
|
|
|
|
12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12
|
|
|
|
};
|
|
|
|
static const int8_t fwd_cos_bit_row_adst_dct_32[10] = { 12, 12, 12, 12, 12,
|
|
|
|
12, 12, 12, 12, 12 };
|
2015-10-28 23:57:48 +03:00
|
|
|
|
|
|
|
static const TXFM_2D_CFG fwd_txfm_2d_cfg_adst_dct_32 = {
|
2016-08-12 04:55:00 +03:00
|
|
|
32, // .txfm_size
|
|
|
|
12, // .stage_num_col
|
|
|
|
10, // .stage_num_row
|
|
|
|
// 1, // .log_scale
|
|
|
|
fwd_shift_adst_dct_32, // .shift
|
|
|
|
fwd_stage_range_col_adst_dct_32, // .stage_range_col
|
|
|
|
fwd_stage_range_row_adst_dct_32, // .stage_range_row
|
|
|
|
fwd_cos_bit_col_adst_dct_32, // .cos_bit_col
|
|
|
|
fwd_cos_bit_row_adst_dct_32, // .cos_bit_row
|
|
|
|
TXFM_TYPE_ADST32, // .txfm_type_col
|
|
|
|
TXFM_TYPE_DCT32
|
|
|
|
}; // .txfm_type_row
|
2016-08-31 00:01:10 +03:00
|
|
|
#endif // AV1_FWD_TXFM2D_CFG_H_
|