mirror of https://github.com/FFmpeg/FFmpeg.git
Originally written by Ronald S. Bultje <rsbultje@gmail.com> and Clément Bœsch <u@pkh.me> Further contributions by: Anton Khirnov <anton@khirnov.net> Diego Biurrun <diego@biurrun.de> Luca Barbato <lu_zero@gentoo.org> Martin Storsjö <martin@martin.st> Signed-off-by: Luca Barbato <lu_zero@gentoo.org> Signed-off-by: Anton Khirnov <anton@khirnov.net>pull/48/head
parent
458446acfa
commit
72ca830f51
221 changed files with 10716 additions and 1 deletions
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,419 @@ |
||||
/*
|
||||
* VP9 compatible video decoder |
||||
* |
||||
* Copyright (C) 2013 Ronald S. Bultje <rsbultje gmail com> |
||||
* Copyright (C) 2013 Clément Bœsch <u pkh me> |
||||
* |
||||
* This file is part of Libav. |
||||
* |
||||
* Libav is free software; you can redistribute it and/or |
||||
* modify it under the terms of the GNU Lesser General Public |
||||
* License as published by the Free Software Foundation; either |
||||
* version 2.1 of the License, or (at your option) any later version. |
||||
* |
||||
* Libav 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 |
||||
* Lesser General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Lesser General Public |
||||
* License along with Libav; if not, write to the Free Software |
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
||||
*/ |
||||
|
||||
#ifndef AVCODEC_VP9_H |
||||
#define AVCODEC_VP9_H |
||||
|
||||
#include <stddef.h> |
||||
#include <stdint.h> |
||||
|
||||
#include "libavutil/internal.h" |
||||
|
||||
#include "avcodec.h" |
||||
#include "vp56.h" |
||||
|
||||
enum TxfmMode { |
||||
TX_4X4, |
||||
TX_8X8, |
||||
TX_16X16, |
||||
TX_32X32, |
||||
N_TXFM_SIZES, |
||||
TX_SWITCHABLE = N_TXFM_SIZES, |
||||
N_TXFM_MODES |
||||
}; |
||||
|
||||
enum TxfmType { |
||||
DCT_DCT, |
||||
DCT_ADST, |
||||
ADST_DCT, |
||||
ADST_ADST, |
||||
N_TXFM_TYPES |
||||
}; |
||||
|
||||
enum IntraPredMode { |
||||
VERT_PRED, |
||||
HOR_PRED, |
||||
DC_PRED, |
||||
DIAG_DOWN_LEFT_PRED, |
||||
DIAG_DOWN_RIGHT_PRED, |
||||
VERT_RIGHT_PRED, |
||||
HOR_DOWN_PRED, |
||||
VERT_LEFT_PRED, |
||||
HOR_UP_PRED, |
||||
TM_VP8_PRED, |
||||
LEFT_DC_PRED, |
||||
TOP_DC_PRED, |
||||
DC_128_PRED, |
||||
DC_127_PRED, |
||||
DC_129_PRED, |
||||
N_INTRA_PRED_MODES |
||||
}; |
||||
|
||||
enum FilterMode { |
||||
FILTER_8TAP_SMOOTH, |
||||
FILTER_8TAP_REGULAR, |
||||
FILTER_8TAP_SHARP, |
||||
FILTER_BILINEAR, |
||||
FILTER_SWITCHABLE, |
||||
}; |
||||
|
||||
enum BlockPartition { |
||||
PARTITION_NONE, // [ ] <-.
|
||||
PARTITION_H, // [-] |
|
||||
PARTITION_V, // [|] |
|
||||
PARTITION_SPLIT, // [+] --'
|
||||
}; |
||||
|
||||
enum InterPredMode { |
||||
NEARESTMV = 10, |
||||
NEARMV = 11, |
||||
ZEROMV = 12, |
||||
NEWMV = 13, |
||||
}; |
||||
|
||||
enum MVJoint { |
||||
MV_JOINT_ZERO, |
||||
MV_JOINT_H, |
||||
MV_JOINT_V, |
||||
MV_JOINT_HV, |
||||
}; |
||||
|
||||
typedef struct ProbContext { |
||||
uint8_t y_mode[4][9]; |
||||
uint8_t uv_mode[10][9]; |
||||
uint8_t filter[4][2]; |
||||
uint8_t mv_mode[7][3]; |
||||
uint8_t intra[4]; |
||||
uint8_t comp[5]; |
||||
uint8_t single_ref[5][2]; |
||||
uint8_t comp_ref[5]; |
||||
uint8_t tx32p[2][3]; |
||||
uint8_t tx16p[2][2]; |
||||
uint8_t tx8p[2]; |
||||
uint8_t skip[3]; |
||||
uint8_t mv_joint[3]; |
||||
struct { |
||||
uint8_t sign; |
||||
uint8_t classes[10]; |
||||
uint8_t class0; |
||||
uint8_t bits[10]; |
||||
uint8_t class0_fp[2][3]; |
||||
uint8_t fp[3]; |
||||
uint8_t class0_hp; |
||||
uint8_t hp; |
||||
} mv_comp[2]; |
||||
uint8_t partition[4][4][3]; |
||||
} ProbContext; |
||||
|
||||
typedef void (*vp9_mc_func)(uint8_t *dst, const uint8_t *ref, |
||||
ptrdiff_t dst_stride, |
||||
ptrdiff_t ref_stride, |
||||
int h, int mx, int my); |
||||
|
||||
typedef struct VP9DSPContext { |
||||
/*
|
||||
* dimension 1: 0=4x4, 1=8x8, 2=16x16, 3=32x32 |
||||
* dimension 2: intra prediction modes |
||||
* |
||||
* dst/left/top is aligned by transform-size (i.e. 4, 8, 16 or 32 pixels) |
||||
* stride is aligned by 16 pixels |
||||
* top[-1] is top/left; top[4,7] is top-right for 4x4 |
||||
*/ |
||||
// FIXME(rbultje) maybe replace left/top pointers with HAVE_TOP/
|
||||
// HAVE_LEFT/HAVE_TOPRIGHT flags instead, and then handle it in-place?
|
||||
// also needs to fit in with what h264/vp8/etc do
|
||||
void (*intra_pred[N_TXFM_SIZES][N_INTRA_PRED_MODES])(uint8_t *dst, |
||||
ptrdiff_t stride, |
||||
const uint8_t *left, |
||||
const uint8_t *top); |
||||
|
||||
/*
|
||||
* dimension 1: 0=4x4, 1=8x8, 2=16x16, 3=32x32, 4=lossless (3-4=dct only) |
||||
* dimension 2: 0=dct/dct, 1=dct/adst, 2=adst/dct, 3=adst/adst |
||||
* |
||||
* dst is aligned by transform-size (i.e. 4, 8, 16 or 32 pixels) |
||||
* stride is aligned by 16 pixels |
||||
* block is 16-byte aligned |
||||
* eob indicates the position (+1) of the last non-zero coefficient, |
||||
* in scan-order. This can be used to write faster versions, e.g. a |
||||
* dc-only 4x4/8x8/16x16/32x32, or a 4x4-only (eob<10) 8x8/16x16/32x32, |
||||
* etc. |
||||
*/ |
||||
// FIXME also write idct_add_block() versions for whole (inter) pred
|
||||
// blocks, so we can do 2 4x4s at once
|
||||
void (*itxfm_add[N_TXFM_SIZES + 1][N_TXFM_TYPES])(uint8_t *dst, |
||||
ptrdiff_t stride, |
||||
int16_t *block, int eob); |
||||
|
||||
/*
|
||||
* dimension 1: width of filter (0=4, 1=8, 2=16) |
||||
* dimension 2: 0=col-edge filter (h), 1=row-edge filter (v) |
||||
* |
||||
* dst/stride are aligned by 8 |
||||
*/ |
||||
void (*loop_filter_8[3][2])(uint8_t *dst, ptrdiff_t stride, |
||||
int mb_lim, int lim, int hev_thr); |
||||
|
||||
/*
|
||||
* dimension 1: 0=col-edge filter (h), 1=row-edge filter (v) |
||||
* |
||||
* The width of filter is assumed to be 16; dst/stride are aligned by 16 |
||||
*/ |
||||
void (*loop_filter_16[2])(uint8_t *dst, ptrdiff_t stride, |
||||
int mb_lim, int lim, int hev_thr); |
||||
|
||||
/*
|
||||
* dimension 1/2: width of filter (0=4, 1=8) for each filter half |
||||
* dimension 3: 0=col-edge filter (h), 1=row-edge filter (v) |
||||
* |
||||
* dst/stride are aligned by operation size |
||||
* this basically calls loop_filter[d1][d3][0](), followed by |
||||
* loop_filter[d2][d3][0]() on the next 8 pixels |
||||
* mb_lim/lim/hev_thr contain two values in the lowest two bytes of the |
||||
* integer. |
||||
*/ |
||||
// FIXME perhaps a mix4 that operates on 32px (for AVX2)
|
||||
void (*loop_filter_mix2[2][2][2])(uint8_t *dst, ptrdiff_t stride, |
||||
int mb_lim, int lim, int hev_thr); |
||||
|
||||
/*
|
||||
* dimension 1: hsize (0: 64, 1: 32, 2: 16, 3: 8, 4: 4) |
||||
* dimension 2: filter type (0: smooth, 1: regular, 2: sharp, 3: bilin) |
||||
* dimension 3: averaging type (0: put, 1: avg) |
||||
* dimension 4: x subpel interpolation (0: none, 1: 8tap/bilin) |
||||
* dimension 5: y subpel interpolation (1: none, 1: 8tap/bilin) |
||||
* |
||||
* dst/stride are aligned by hsize |
||||
*/ |
||||
vp9_mc_func mc[5][4][2][2][2]; |
||||
} VP9DSPContext; |
||||
|
||||
enum CompPredMode { |
||||
PRED_SINGLEREF, |
||||
PRED_COMPREF, |
||||
PRED_SWITCHABLE, |
||||
}; |
||||
|
||||
typedef struct VP9MVRefPair { |
||||
VP56mv mv[2]; |
||||
int8_t ref[2]; |
||||
} VP9MVRefPair; |
||||
|
||||
typedef struct VP9Filter { |
||||
uint8_t level[8 * 8]; |
||||
uint8_t /* bit=col */ mask[2 /* 0=y, 1=uv */][2 /* 0=col, 1=row */] |
||||
[8 /* rows */][4 /* 0=16, 1=8, 2=4, 3=inner4 */]; |
||||
} VP9Filter; |
||||
|
||||
enum BlockLevel { |
||||
BL_64X64, |
||||
BL_32X32, |
||||
BL_16X16, |
||||
BL_8X8, |
||||
}; |
||||
|
||||
enum BlockSize { |
||||
BS_64x64, |
||||
BS_64x32, |
||||
BS_32x64, |
||||
BS_32x32, |
||||
BS_32x16, |
||||
BS_16x32, |
||||
BS_16x16, |
||||
BS_16x8, |
||||
BS_8x16, |
||||
BS_8x8, |
||||
BS_8x4, |
||||
BS_4x8, |
||||
BS_4x4, |
||||
N_BS_SIZES, |
||||
}; |
||||
|
||||
typedef struct VP9Block { |
||||
uint8_t seg_id, intra, comp, ref[2], mode[4], uvmode, skip; |
||||
enum FilterMode filter; |
||||
VP56mv mv[4 /* b_idx */][2 /* ref */]; |
||||
enum BlockSize bs; |
||||
enum TxfmMode tx, uvtx; |
||||
|
||||
int row, row7, col, col7; |
||||
uint8_t *dst[3]; |
||||
ptrdiff_t y_stride, uv_stride; |
||||
} VP9Block; |
||||
|
||||
typedef struct VP9Context { |
||||
VP9DSPContext dsp; |
||||
VideoDSPContext vdsp; |
||||
GetBitContext gb; |
||||
VP56RangeCoder c; |
||||
VP56RangeCoder *c_b; |
||||
unsigned c_b_size; |
||||
VP9Block b; |
||||
|
||||
// bitstream header
|
||||
uint8_t profile; |
||||
uint8_t keyframe, last_keyframe; |
||||
uint8_t invisible; |
||||
uint8_t use_last_frame_mvs; |
||||
uint8_t errorres; |
||||
uint8_t colorspace; |
||||
uint8_t fullrange; |
||||
uint8_t intraonly; |
||||
uint8_t resetctx; |
||||
uint8_t refreshrefmask; |
||||
uint8_t highprecisionmvs; |
||||
enum FilterMode filtermode; |
||||
uint8_t allowcompinter; |
||||
uint8_t fixcompref; |
||||
uint8_t refreshctx; |
||||
uint8_t parallelmode; |
||||
uint8_t framectxid; |
||||
uint8_t refidx[3]; |
||||
uint8_t signbias[3]; |
||||
uint8_t varcompref[2]; |
||||
AVFrame *refs[8]; |
||||
AVFrame *cur_frame; |
||||
|
||||
struct { |
||||
uint8_t level; |
||||
int8_t sharpness; |
||||
uint8_t lim_lut[64]; |
||||
uint8_t mblim_lut[64]; |
||||
} filter; |
||||
struct { |
||||
uint8_t enabled; |
||||
int8_t mode[2]; |
||||
int8_t ref[4]; |
||||
} lf_delta; |
||||
uint8_t yac_qi; |
||||
int8_t ydc_qdelta, uvdc_qdelta, uvac_qdelta; |
||||
uint8_t lossless; |
||||
struct { |
||||
uint8_t enabled; |
||||
uint8_t temporal; |
||||
uint8_t absolute_vals; |
||||
uint8_t update_map; |
||||
struct { |
||||
uint8_t q_enabled; |
||||
uint8_t lf_enabled; |
||||
uint8_t ref_enabled; |
||||
uint8_t skip_enabled; |
||||
uint8_t ref_val; |
||||
int16_t q_val; |
||||
int8_t lf_val; |
||||
int16_t qmul[2][2]; |
||||
uint8_t lflvl[4][2]; |
||||
} feat[8]; |
||||
} segmentation; |
||||
struct { |
||||
unsigned log2_tile_cols, log2_tile_rows; |
||||
unsigned tile_cols, tile_rows; |
||||
unsigned tile_row_start, tile_row_end, tile_col_start, tile_col_end; |
||||
} tiling; |
||||
unsigned sb_cols, sb_rows, rows, cols; |
||||
struct { |
||||
ProbContext p; |
||||
uint8_t coef[4][2][2][6][6][3]; |
||||
} prob_ctx[4]; |
||||
struct { |
||||
ProbContext p; |
||||
uint8_t coef[4][2][2][6][6][11]; |
||||
uint8_t seg[7]; |
||||
uint8_t segpred[3]; |
||||
} prob; |
||||
struct { |
||||
unsigned y_mode[4][10]; |
||||
unsigned uv_mode[10][10]; |
||||
unsigned filter[4][3]; |
||||
unsigned mv_mode[7][4]; |
||||
unsigned intra[4][2]; |
||||
unsigned comp[5][2]; |
||||
unsigned single_ref[5][2][2]; |
||||
unsigned comp_ref[5][2]; |
||||
unsigned tx32p[2][4]; |
||||
unsigned tx16p[2][3]; |
||||
unsigned tx8p[2][2]; |
||||
unsigned skip[3][2]; |
||||
unsigned mv_joint[4]; |
||||
struct { |
||||
unsigned sign[2]; |
||||
unsigned classes[11]; |
||||
unsigned class0[2]; |
||||
unsigned bits[10][2]; |
||||
unsigned class0_fp[2][4]; |
||||
unsigned fp[4]; |
||||
unsigned class0_hp[2]; |
||||
unsigned hp[2]; |
||||
} mv_comp[2]; |
||||
unsigned partition[4][4][4]; |
||||
unsigned coef[4][2][2][6][6][3]; |
||||
unsigned eob[4][2][2][6][6][2]; |
||||
} counts; |
||||
enum TxfmMode txfmmode; |
||||
enum CompPredMode comppredmode; |
||||
|
||||
// contextual (left/above) cache
|
||||
uint8_t left_partition_ctx[8], *above_partition_ctx; |
||||
uint8_t left_mode_ctx[16], *above_mode_ctx; |
||||
// FIXME maybe merge some of the below in a flags field?
|
||||
uint8_t left_y_nnz_ctx[16], *above_y_nnz_ctx; |
||||
uint8_t left_uv_nnz_ctx[2][8], *above_uv_nnz_ctx[2]; |
||||
uint8_t left_skip_ctx[8], *above_skip_ctx; // 1bit
|
||||
uint8_t left_txfm_ctx[8], *above_txfm_ctx; // 2bit
|
||||
uint8_t left_segpred_ctx[8], *above_segpred_ctx; // 1bit
|
||||
uint8_t left_intra_ctx[8], *above_intra_ctx; // 1bit
|
||||
uint8_t left_comp_ctx[8], *above_comp_ctx; // 1bit
|
||||
uint8_t left_ref_ctx[8], *above_ref_ctx; // 2bit
|
||||
uint8_t left_filter_ctx[8], *above_filter_ctx; |
||||
VP56mv left_mv_ctx[16][2], (*above_mv_ctx)[2]; |
||||
|
||||
// whole-frame cache
|
||||
uint8_t *intra_pred_data[3]; |
||||
uint8_t *segmentation_map; |
||||
VP9MVRefPair *mv[2]; |
||||
VP9Filter *lflvl; |
||||
DECLARE_ALIGNED(32, uint8_t, edge_emu_buffer)[71 * 80]; |
||||
|
||||
// block reconstruction intermediates
|
||||
DECLARE_ALIGNED(32, int16_t, block)[4096]; |
||||
DECLARE_ALIGNED(32, int16_t, uvblock)[2][1024]; |
||||
uint8_t eob[256]; |
||||
uint8_t uveob[2][64]; |
||||
VP56mv min_mv, max_mv; |
||||
DECLARE_ALIGNED(32, uint8_t, tmp_y)[64 * 64]; |
||||
DECLARE_ALIGNED(32, uint8_t, tmp_uv)[2][32 * 32]; |
||||
} VP9Context; |
||||
|
||||
void ff_vp9dsp_init(VP9DSPContext *dsp); |
||||
|
||||
void ff_vp9dsp_init_x86(VP9DSPContext *dsp); |
||||
|
||||
void ff_vp9_fill_mv(VP9Context *s, VP56mv *mv, int mode, int sb); |
||||
|
||||
void ff_vp9_adapt_probs(VP9Context *s); |
||||
|
||||
int ff_vp9_decode_block(AVCodecContext *avctx, int row, int col, |
||||
VP9Filter *lflvl, ptrdiff_t yoff, ptrdiff_t uvoff, |
||||
enum BlockLevel bl, enum BlockPartition bp); |
||||
|
||||
#endif /* AVCODEC_VP9_H */ |
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,70 @@ |
||||
/*
|
||||
* Copyright (C) 2013 Ronald S. Bultje <rsbultje gmail com> |
||||
* Copyright (C) 2013 Clément Bœsch <u pkh me> |
||||
* |
||||
* This file is part of Libav. |
||||
* |
||||
* Libav is free software; you can redistribute it and/or |
||||
* modify it under the terms of the GNU Lesser General Public |
||||
* License as published by the Free Software Foundation; either |
||||
* version 2.1 of the License, or (at your option) any later version. |
||||
* |
||||
* Libav 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 |
||||
* Lesser General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Lesser General Public |
||||
* License along with Libav; if not, write to the Free Software |
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
||||
*/ |
||||
|
||||
#ifndef AVCODEC_VP9DATA_H |
||||
#define AVCODEC_VP9DATA_H |
||||
|
||||
#include <stdint.h> |
||||
|
||||
#include "vp9.h" |
||||
|
||||
extern const int8_t ff_vp9_partition_tree[3][2]; |
||||
extern const uint8_t ff_vp9_default_kf_partition_probs[4][4][3]; |
||||
extern const int8_t ff_vp9_segmentation_tree[7][2]; |
||||
extern const int8_t ff_vp9_intramode_tree[9][2]; |
||||
extern const uint8_t ff_vp9_default_kf_ymode_probs[10][10][9]; |
||||
extern const uint8_t ff_vp9_default_kf_uvmode_probs[10][9]; |
||||
extern const int8_t ff_vp9_inter_mode_tree[3][2]; |
||||
extern const int8_t ff_vp9_filter_tree[2][2]; |
||||
extern const enum FilterMode ff_vp9_filter_lut[3]; |
||||
extern const int16_t ff_vp9_dc_qlookup[256]; |
||||
extern const int16_t ff_vp9_ac_qlookup[256]; |
||||
extern const enum TxfmType ff_vp9_intra_txfm_type[14]; |
||||
extern const int16_t ff_vp9_default_scan_4x4[16]; |
||||
extern const int16_t ff_vp9_col_scan_4x4[16]; |
||||
extern const int16_t ff_vp9_row_scan_4x4[16]; |
||||
extern const int16_t ff_vp9_default_scan_8x8[64]; |
||||
extern const int16_t ff_vp9_col_scan_8x8[64]; |
||||
extern const int16_t ff_vp9_row_scan_8x8[64]; |
||||
extern const int16_t ff_vp9_default_scan_16x16[256]; |
||||
extern const int16_t ff_vp9_col_scan_16x16[256]; |
||||
extern const int16_t ff_vp9_row_scan_16x16[256]; |
||||
extern const int16_t ff_vp9_default_scan_32x32[1024]; |
||||
extern const int16_t *ff_vp9_scans[5][4]; |
||||
extern const int16_t ff_vp9_default_scan_4x4_nb[16][2]; |
||||
extern const int16_t ff_vp9_col_scan_4x4_nb[16][2]; |
||||
extern const int16_t ff_vp9_row_scan_4x4_nb[16][2]; |
||||
extern const int16_t ff_vp9_default_scan_8x8_nb[64][2]; |
||||
extern const int16_t ff_vp9_col_scan_8x8_nb[64][2]; |
||||
extern const int16_t ff_vp9_row_scan_8x8_nb[64][2]; |
||||
extern const int16_t ff_vp9_default_scan_16x16_nb[256][2]; |
||||
extern const int16_t ff_vp9_col_scan_16x16_nb[256][2]; |
||||
extern const int16_t ff_vp9_row_scan_16x16_nb[256][2]; |
||||
extern const int16_t ff_vp9_default_scan_32x32_nb[1024][2]; |
||||
extern const int16_t (*ff_vp9_scans_nb[5][4])[2]; |
||||
extern const uint8_t ff_vp9_model_pareto8[256][8]; |
||||
extern const ProbContext ff_vp9_default_probs; |
||||
extern const uint8_t ff_vp9_default_coef_probs[4][2][2][6][6][3]; |
||||
extern const int8_t ff_vp9_mv_joint_tree[3][2]; |
||||
extern const int8_t ff_vp9_mv_class_tree[10][2]; |
||||
extern const int8_t ff_vp9_mv_fp_tree[3][2]; |
||||
|
||||
#endif /* AVCODEC_VP9DATA_H */ |
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,344 @@ |
||||
/*
|
||||
* VP9 compatible video decoder |
||||
* |
||||
* Copyright (C) 2013 Ronald S. Bultje <rsbultje gmail com> |
||||
* Copyright (C) 2013 Clément Bœsch <u pkh me> |
||||
* |
||||
* This file is part of Libav. |
||||
* |
||||
* Libav is free software; you can redistribute it and/or |
||||
* modify it under the terms of the GNU Lesser General Public |
||||
* License as published by the Free Software Foundation; either |
||||
* version 2.1 of the License, or (at your option) any later version. |
||||
* |
||||
* Libav 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 |
||||
* Lesser General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Lesser General Public |
||||
* License along with Libav; if not, write to the Free Software |
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
||||
*/ |
||||
|
||||
#include "internal.h" |
||||
#include "vp56.h" |
||||
#include "vp9.h" |
||||
#include "vp9data.h" |
||||
|
||||
static av_always_inline void clamp_mv(VP56mv *dst, const VP56mv *src, |
||||
VP9Context *s) |
||||
{ |
||||
dst->x = av_clip(src->x, s->min_mv.x, s->max_mv.x); |
||||
dst->y = av_clip(src->y, s->min_mv.y, s->max_mv.y); |
||||
} |
||||
|
||||
static void find_ref_mvs(VP9Context *s, |
||||
VP56mv *pmv, int ref, int z, int idx, int sb) |
||||
{ |
||||
static const int8_t mv_ref_blk_off[N_BS_SIZES][8][2] = { |
||||
[BS_64x64] = { { 3, -1 }, { -1, 3 }, { 4, -1 }, { -1, 4 }, |
||||
{ -1, -1 }, { 0, -1 }, { -1, 0 }, { 6, -1 } }, |
||||
[BS_64x32] = { { 0, -1 }, { -1, 0 }, { 4, -1 }, { -1, 2 }, |
||||
{ -1, -1 }, { 0, -3 }, { -3, 0 }, { 2, -1 } }, |
||||
[BS_32x64] = { { -1, 0 }, { 0, -1 }, { -1, 4 }, { 2, -1 }, |
||||
{ -1, -1 }, { -3, 0 }, { 0, -3 }, { -1, 2 } }, |
||||
[BS_32x32] = { { 1, -1 }, { -1, 1 }, { 2, -1 }, { -1, 2 }, |
||||
{ -1, -1 }, { 0, -3 }, { -3, 0 }, { -3, -3 } }, |
||||
[BS_32x16] = { { 0, -1 }, { -1, 0 }, { 2, -1 }, { -1, -1 }, |
||||
{ -1, 1 }, { 0, -3 }, { -3, 0 }, { -3, -3 } }, |
||||
[BS_16x32] = { { -1, 0 }, { 0, -1 }, { -1, 2 }, { -1, -1 }, |
||||
{ 1, -1 }, { -3, 0 }, { 0, -3 }, { -3, -3 } }, |
||||
[BS_16x16] = { { 0, -1 }, { -1, 0 }, { 1, -1 }, { -1, 1 }, |
||||
{ -1, -1 }, { 0, -3 }, { -3, 0 }, { -3, -3 } }, |
||||
[BS_16x8] = { { 0, -1 }, { -1, 0 }, { 1, -1 }, { -1, -1 }, |
||||
{ 0, -2 }, { -2, 0 }, { -2, -1 }, { -1, -2 } }, |
||||
[BS_8x16] = { { -1, 0 }, { 0, -1 }, { -1, 1 }, { -1, -1 }, |
||||
{ -2, 0 }, { 0, -2 }, { -1, -2 }, { -2, -1 } }, |
||||
[BS_8x8] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 }, |
||||
{ -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } }, |
||||
[BS_8x4] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 }, |
||||
{ -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } }, |
||||
[BS_4x8] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 }, |
||||
{ -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } }, |
||||
[BS_4x4] = { { 0, -1 }, { -1, 0 }, { -1, -1 }, { 0, -2 }, |
||||
{ -2, 0 }, { -1, -2 }, { -2, -1 }, { -2, -2 } }, |
||||
}; |
||||
VP9Block *const b = &s->b; |
||||
int row = b->row, col = b->col, row7 = b->row7; |
||||
const int8_t (*p)[2] = mv_ref_blk_off[b->bs]; |
||||
#define INVALID_MV 0x80008000U |
||||
uint32_t mem = INVALID_MV; |
||||
int i; |
||||
|
||||
#define RETURN_DIRECT_MV(mv) \ |
||||
do { \
|
||||
uint32_t m = AV_RN32A(&mv); \
|
||||
if (!idx) { \
|
||||
AV_WN32A(pmv, m); \
|
||||
return; \
|
||||
} else if (mem == INVALID_MV) { \
|
||||
mem = m; \
|
||||
} else if (m != mem) { \
|
||||
AV_WN32A(pmv, m); \
|
||||
return; \
|
||||
} \
|
||||
} while (0) |
||||
|
||||
if (sb >= 0) { |
||||
if (sb == 2 || sb == 1) { |
||||
RETURN_DIRECT_MV(b->mv[0][z]); |
||||
} else if (sb == 3) { |
||||
RETURN_DIRECT_MV(b->mv[2][z]); |
||||
RETURN_DIRECT_MV(b->mv[1][z]); |
||||
RETURN_DIRECT_MV(b->mv[0][z]); |
||||
} |
||||
|
||||
#define RETURN_MV(mv) \ |
||||
do { \
|
||||
if (sb > 0) { \
|
||||
VP56mv tmp; \
|
||||
uint32_t m; \
|
||||
clamp_mv(&tmp, &mv, s); \
|
||||
m = AV_RN32A(&tmp); \
|
||||
if (!idx) { \
|
||||
AV_WN32A(pmv, m); \
|
||||
return; \
|
||||
} else if (mem == INVALID_MV) { \
|
||||
mem = m; \
|
||||
} else if (m != mem) { \
|
||||
AV_WN32A(pmv, m); \
|
||||
return; \
|
||||
} \
|
||||
} else { \
|
||||
uint32_t m = AV_RN32A(&mv); \
|
||||
if (!idx) { \
|
||||
clamp_mv(pmv, &mv, s); \
|
||||
return; \
|
||||
} else if (mem == INVALID_MV) { \
|
||||
mem = m; \
|
||||
} else if (m != mem) { \
|
||||
clamp_mv(pmv, &mv, s); \
|
||||
return; \
|
||||
} \
|
||||
} \
|
||||
} while (0) |
||||
|
||||
if (row > 0) { |
||||
VP9MVRefPair *mv = &s->mv[0][(row - 1) * s->sb_cols * 8 + col]; |
||||
|
||||
if (mv->ref[0] == ref) |
||||
RETURN_MV(s->above_mv_ctx[2 * col + (sb & 1)][0]); |
||||
else if (mv->ref[1] == ref) |
||||
RETURN_MV(s->above_mv_ctx[2 * col + (sb & 1)][1]); |
||||
} |
||||
if (col > s->tiling.tile_col_start) { |
||||
VP9MVRefPair *mv = &s->mv[0][row * s->sb_cols * 8 + col - 1]; |
||||
|
||||
if (mv->ref[0] == ref) |
||||
RETURN_MV(s->left_mv_ctx[2 * row7 + (sb >> 1)][0]); |
||||
else if (mv->ref[1] == ref) |
||||
RETURN_MV(s->left_mv_ctx[2 * row7 + (sb >> 1)][1]); |
||||
} |
||||
i = 2; |
||||
} else { |
||||
i = 0; |
||||
} |
||||
|
||||
// previously coded MVs in the neighborhood, using same reference frame
|
||||
for (; i < 8; i++) { |
||||
int c = p[i][0] + col, r = p[i][1] + row; |
||||
|
||||
if (c >= s->tiling.tile_col_start && c < s->cols && |
||||
r >= 0 && r < s->rows) { |
||||
VP9MVRefPair *mv = &s->mv[0][r * s->sb_cols * 8 + c]; |
||||
|
||||
if (mv->ref[0] == ref) |
||||
RETURN_MV(mv->mv[0]); |
||||
else if (mv->ref[1] == ref) |
||||
RETURN_MV(mv->mv[1]); |
||||
} |
||||
} |
||||
|
||||
// MV at this position in previous frame, using same reference frame
|
||||
if (s->use_last_frame_mvs) { |
||||
VP9MVRefPair *mv = &s->mv[1][row * s->sb_cols * 8 + col]; |
||||
|
||||
if (mv->ref[0] == ref) |
||||
RETURN_MV(mv->mv[0]); |
||||
else if (mv->ref[1] == ref) |
||||
RETURN_MV(mv->mv[1]); |
||||
} |
||||
|
||||
#define RETURN_SCALE_MV(mv, scale) \ |
||||
do { \
|
||||
if (scale) { \
|
||||
VP56mv mv_temp = { -mv.x, -mv.y }; \
|
||||
RETURN_MV(mv_temp); \
|
||||
} else { \
|
||||
RETURN_MV(mv); \
|
||||
} \
|
||||
} while (0) |
||||
|
||||
// previously coded MVs in the neighborhood, using different reference frame
|
||||
for (i = 0; i < 8; i++) { |
||||
int c = p[i][0] + col, r = p[i][1] + row; |
||||
|
||||
if (c >= s->tiling.tile_col_start && c < s->cols && |
||||
r >= 0 && r < s->rows) { |
||||
VP9MVRefPair *mv = &s->mv[0][r * s->sb_cols * 8 + c]; |
||||
|
||||
if (mv->ref[0] != ref && mv->ref[0] >= 0) |
||||
RETURN_SCALE_MV(mv->mv[0], |
||||
s->signbias[mv->ref[0]] != s->signbias[ref]); |
||||
if (mv->ref[1] != ref && mv->ref[1] >= 0) |
||||
RETURN_SCALE_MV(mv->mv[1], |
||||
s->signbias[mv->ref[1]] != s->signbias[ref]); |
||||
} |
||||
} |
||||
|
||||
// MV at this position in previous frame, using different reference frame
|
||||
if (s->use_last_frame_mvs) { |
||||
VP9MVRefPair *mv = &s->mv[1][row * s->sb_cols * 8 + col]; |
||||
|
||||
if (mv->ref[0] != ref && mv->ref[0] >= 0) |
||||
RETURN_SCALE_MV(mv->mv[0], |
||||
s->signbias[mv->ref[0]] != s->signbias[ref]); |
||||
if (mv->ref[1] != ref && mv->ref[1] >= 0) |
||||
RETURN_SCALE_MV(mv->mv[1], |
||||
s->signbias[mv->ref[1]] != s->signbias[ref]); |
||||
} |
||||
|
||||
AV_ZERO32(pmv); |
||||
#undef INVALID_MV |
||||
#undef RETURN_MV |
||||
#undef RETURN_SCALE_MV |
||||
} |
||||
|
||||
static av_always_inline int read_mv_component(VP9Context *s, int idx, int hp) |
||||
{ |
||||
int bit, sign = vp56_rac_get_prob(&s->c, s->prob.p.mv_comp[idx].sign); |
||||
int n, c = vp8_rac_get_tree(&s->c, ff_vp9_mv_class_tree, |
||||
s->prob.p.mv_comp[idx].classes); |
||||
|
||||
s->counts.mv_comp[idx].sign[sign]++; |
||||
s->counts.mv_comp[idx].classes[c]++; |
||||
if (c) { |
||||
int m; |
||||
|
||||
for (n = 0, m = 0; m < c; m++) { |
||||
bit = vp56_rac_get_prob(&s->c, s->prob.p.mv_comp[idx].bits[m]); |
||||
n |= bit << m; |
||||
s->counts.mv_comp[idx].bits[m][bit]++; |
||||
} |
||||
n <<= 3; |
||||
bit = vp8_rac_get_tree(&s->c, ff_vp9_mv_fp_tree, |
||||
s->prob.p.mv_comp[idx].fp); |
||||
n |= bit << 1; |
||||
s->counts.mv_comp[idx].fp[bit]++; |
||||
if (hp) { |
||||
bit = vp56_rac_get_prob(&s->c, s->prob.p.mv_comp[idx].hp); |
||||
s->counts.mv_comp[idx].hp[bit]++; |
||||
n |= bit; |
||||
} else { |
||||
n |= 1; |
||||
// bug in libvpx - we count for bw entropy purposes even if the
|
||||
// bit wasn't coded
|
||||
s->counts.mv_comp[idx].hp[1]++; |
||||
} |
||||
n += 8 << c; |
||||
} else { |
||||
n = vp56_rac_get_prob(&s->c, s->prob.p.mv_comp[idx].class0); |
||||
s->counts.mv_comp[idx].class0[n]++; |
||||
bit = vp8_rac_get_tree(&s->c, ff_vp9_mv_fp_tree, |
||||
s->prob.p.mv_comp[idx].class0_fp[n]); |
||||
s->counts.mv_comp[idx].class0_fp[n][bit]++; |
||||
n = (n << 3) | (bit << 1); |
||||
if (hp) { |
||||
bit = vp56_rac_get_prob(&s->c, s->prob.p.mv_comp[idx].class0_hp); |
||||
s->counts.mv_comp[idx].class0_hp[bit]++; |
||||
n |= bit; |
||||
} else { |
||||
n |= 1; |
||||
// bug in libvpx - we count for bw entropy purposes even if the
|
||||
// bit wasn't coded
|
||||
s->counts.mv_comp[idx].class0_hp[1]++; |
||||
} |
||||
} |
||||
|
||||
return sign ? -(n + 1) : (n + 1); |
||||
} |
||||
|
||||
void ff_vp9_fill_mv(VP9Context *s, VP56mv *mv, int mode, int sb) |
||||
{ |
||||
VP9Block *const b = &s->b; |
||||
|
||||
if (mode == ZEROMV) { |
||||
memset(mv, 0, sizeof(*mv) * 2); |
||||
} else { |
||||
int hp; |
||||
|
||||
// FIXME cache this value and reuse for other subblocks
|
||||
find_ref_mvs(s, &mv[0], b->ref[0], 0, mode == NEARMV, |
||||
mode == NEWMV ? -1 : sb); |
||||
// FIXME maybe move this code into find_ref_mvs()
|
||||
if ((mode == NEWMV || sb == -1) && |
||||
!(hp = s->highprecisionmvs && |
||||
abs(mv[0].x) < 64 && abs(mv[0].y) < 64)) { |
||||
if (mv[0].y & 1) { |
||||
if (mv[0].y < 0) |
||||
mv[0].y++; |
||||
else |
||||
mv[0].y--; |
||||
} |
||||
if (mv[0].x & 1) { |
||||
if (mv[0].x < 0) |
||||
mv[0].x++; |
||||
else |
||||
mv[0].x--; |
||||
} |
||||
} |
||||
if (mode == NEWMV) { |
||||
enum MVJoint j = vp8_rac_get_tree(&s->c, ff_vp9_mv_joint_tree, |
||||
s->prob.p.mv_joint); |
||||
|
||||
s->counts.mv_joint[j]++; |
||||
if (j >= MV_JOINT_V) |
||||
mv[0].y += read_mv_component(s, 0, hp); |
||||
if (j & 1) |
||||
mv[0].x += read_mv_component(s, 1, hp); |
||||
} |
||||
|
||||
if (b->comp) { |
||||
// FIXME cache this value and reuse for other subblocks
|
||||
find_ref_mvs(s, &mv[1], b->ref[1], 1, mode == NEARMV, |
||||
mode == NEWMV ? -1 : sb); |
||||
if ((mode == NEWMV || sb == -1) && |
||||
!(hp = s->highprecisionmvs && |
||||
abs(mv[1].x) < 64 && abs(mv[1].y) < 64)) { |
||||
if (mv[1].y & 1) { |
||||
if (mv[1].y < 0) |
||||
mv[1].y++; |
||||
else |
||||
mv[1].y--; |
||||
} |
||||
if (mv[1].x & 1) { |
||||
if (mv[1].x < 0) |
||||
mv[1].x++; |
||||
else |
||||
mv[1].x--; |
||||
} |
||||
} |
||||
if (mode == NEWMV) { |
||||
enum MVJoint j = vp8_rac_get_tree(&s->c, ff_vp9_mv_joint_tree, |
||||
s->prob.p.mv_joint); |
||||
|
||||
s->counts.mv_joint[j]++; |
||||
if (j >= MV_JOINT_V) |
||||
mv[1].y += read_mv_component(s, 0, hp); |
||||
if (j & 1) |
||||
mv[1].x += read_mv_component(s, 1, hp); |
||||
} |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,274 @@ |
||||
/*
|
||||
* VP9 compatible video decoder |
||||
* |
||||
* Copyright (C) 2013 Ronald S. Bultje <rsbultje gmail com> |
||||
* Copyright (C) 2013 Clément Bœsch <u pkh me> |
||||
* |
||||
* This file is part of Libav. |
||||
* |
||||
* Libav is free software; you can redistribute it and/or |
||||
* modify it under the terms of the GNU Lesser General Public |
||||
* License as published by the Free Software Foundation; either |
||||
* version 2.1 of the License, or (at your option) any later version. |
||||
* |
||||
* Libav 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 |
||||
* Lesser General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Lesser General Public |
||||
* License along with Libav; if not, write to the Free Software |
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
||||
*/ |
||||
|
||||
#include "vp56.h" |
||||
#include "vp9.h" |
||||
#include "vp9data.h" |
||||
|
||||
static av_always_inline void adapt_prob(uint8_t *p, unsigned ct0, unsigned ct1, |
||||
int max_count, int update_factor) |
||||
{ |
||||
unsigned ct = ct0 + ct1, p2, p1; |
||||
|
||||
if (!ct) |
||||
return; |
||||
|
||||
p1 = *p; |
||||
p2 = ((ct0 << 8) + (ct >> 1)) / ct; |
||||
p2 = av_clip(p2, 1, 255); |
||||
ct = FFMIN(ct, max_count); |
||||
update_factor = FASTDIV(update_factor * ct, max_count); |
||||
|
||||
// (p1 * (256 - update_factor) + p2 * update_factor + 128) >> 8
|
||||
*p = p1 + (((p2 - p1) * update_factor + 128) >> 8); |
||||
} |
||||
|
||||
void ff_vp9_adapt_probs(VP9Context *s) |
||||
{ |
||||
int i, j, k, l, m; |
||||
ProbContext *p = &s->prob_ctx[s->framectxid].p; |
||||
int uf = (s->keyframe || s->intraonly || !s->last_keyframe) ? 112 : 128; |
||||
|
||||
// coefficients
|
||||
for (i = 0; i < 4; i++) |
||||
for (j = 0; j < 2; j++) |
||||
for (k = 0; k < 2; k++) |
||||
for (l = 0; l < 6; l++) |
||||
for (m = 0; m < 6; m++) { |
||||
uint8_t *pp = s->prob_ctx[s->framectxid].coef[i][j][k][l][m]; |
||||
unsigned *e = s->counts.eob[i][j][k][l][m]; |
||||
unsigned *c = s->counts.coef[i][j][k][l][m]; |
||||
|
||||
if (l == 0 && m >= 3) // dc only has 3 pt
|
||||
break; |
||||
|
||||
adapt_prob(&pp[0], e[0], e[1], 24, uf); |
||||
adapt_prob(&pp[1], c[0], c[1] + c[2], 24, uf); |
||||
adapt_prob(&pp[2], c[1], c[2], 24, uf); |
||||
} |
||||
|
||||
if (s->keyframe || s->intraonly) { |
||||
memcpy(p->skip, s->prob.p.skip, sizeof(p->skip)); |
||||
memcpy(p->tx32p, s->prob.p.tx32p, sizeof(p->tx32p)); |
||||
memcpy(p->tx16p, s->prob.p.tx16p, sizeof(p->tx16p)); |
||||
memcpy(p->tx8p, s->prob.p.tx8p, sizeof(p->tx8p)); |
||||
return; |
||||
} |
||||
|
||||
// skip flag
|
||||
for (i = 0; i < 3; i++) |
||||
adapt_prob(&p->skip[i], s->counts.skip[i][0], |
||||
s->counts.skip[i][1], 20, 128); |
||||
|
||||
// intra/inter flag
|
||||
for (i = 0; i < 4; i++) |
||||
adapt_prob(&p->intra[i], s->counts.intra[i][0], |
||||
s->counts.intra[i][1], 20, 128); |
||||
|
||||
// comppred flag
|
||||
if (s->comppredmode == PRED_SWITCHABLE) { |
||||
for (i = 0; i < 5; i++) |
||||
adapt_prob(&p->comp[i], s->counts.comp[i][0], |
||||
s->counts.comp[i][1], 20, 128); |
||||
} |
||||
|
||||
// reference frames
|
||||
if (s->comppredmode != PRED_SINGLEREF) { |
||||
for (i = 0; i < 5; i++) |
||||
adapt_prob(&p->comp_ref[i], s->counts.comp_ref[i][0], |
||||
s->counts.comp_ref[i][1], 20, 128); |
||||
} |
||||
|
||||
if (s->comppredmode != PRED_COMPREF) { |
||||
for (i = 0; i < 5; i++) { |
||||
uint8_t *pp = p->single_ref[i]; |
||||
unsigned (*c)[2] = s->counts.single_ref[i]; |
||||
|
||||
adapt_prob(&pp[0], c[0][0], c[0][1], 20, 128); |
||||
adapt_prob(&pp[1], c[1][0], c[1][1], 20, 128); |
||||
} |
||||
} |
||||
|
||||
// block partitioning
|
||||
for (i = 0; i < 4; i++) |
||||
for (j = 0; j < 4; j++) { |
||||
uint8_t *pp = p->partition[i][j]; |
||||
unsigned *c = s->counts.partition[i][j]; |
||||
|
||||
adapt_prob(&pp[0], c[0], c[1] + c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[1], c[1], c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[2], c[2], c[3], 20, 128); |
||||
} |
||||
|
||||
// tx size
|
||||
if (s->txfmmode == TX_SWITCHABLE) { |
||||
for (i = 0; i < 2; i++) { |
||||
unsigned *c16 = s->counts.tx16p[i], *c32 = s->counts.tx32p[i]; |
||||
|
||||
adapt_prob(&p->tx8p[i], s->counts.tx8p[i][0], |
||||
s->counts.tx8p[i][1], 20, 128); |
||||
adapt_prob(&p->tx16p[i][0], c16[0], c16[1] + c16[2], 20, 128); |
||||
adapt_prob(&p->tx16p[i][1], c16[1], c16[2], 20, 128); |
||||
adapt_prob(&p->tx32p[i][0], c32[0], c32[1] + c32[2] + c32[3], 20, 128); |
||||
adapt_prob(&p->tx32p[i][1], c32[1], c32[2] + c32[3], 20, 128); |
||||
adapt_prob(&p->tx32p[i][2], c32[2], c32[3], 20, 128); |
||||
} |
||||
} |
||||
|
||||
// interpolation filter
|
||||
if (s->filtermode == FILTER_SWITCHABLE) { |
||||
for (i = 0; i < 4; i++) { |
||||
uint8_t *pp = p->filter[i]; |
||||
unsigned *c = s->counts.filter[i]; |
||||
|
||||
adapt_prob(&pp[0], c[0], c[1] + c[2], 20, 128); |
||||
adapt_prob(&pp[1], c[1], c[2], 20, 128); |
||||
} |
||||
} |
||||
|
||||
// inter modes
|
||||
for (i = 0; i < 7; i++) { |
||||
uint8_t *pp = p->mv_mode[i]; |
||||
unsigned *c = s->counts.mv_mode[i]; |
||||
|
||||
adapt_prob(&pp[0], c[2], c[1] + c[0] + c[3], 20, 128); |
||||
adapt_prob(&pp[1], c[0], c[1] + c[3], 20, 128); |
||||
adapt_prob(&pp[2], c[1], c[3], 20, 128); |
||||
} |
||||
|
||||
// mv joints
|
||||
{ |
||||
uint8_t *pp = p->mv_joint; |
||||
unsigned *c = s->counts.mv_joint; |
||||
|
||||
adapt_prob(&pp[0], c[0], c[1] + c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[1], c[1], c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[2], c[2], c[3], 20, 128); |
||||
} |
||||
|
||||
// mv components
|
||||
for (i = 0; i < 2; i++) { |
||||
uint8_t *pp; |
||||
unsigned *c, (*c2)[2], sum; |
||||
|
||||
adapt_prob(&p->mv_comp[i].sign, s->counts.mv_comp[i].sign[0], |
||||
s->counts.mv_comp[i].sign[1], 20, 128); |
||||
|
||||
pp = p->mv_comp[i].classes; |
||||
c = s->counts.mv_comp[i].classes; |
||||
sum = c[1] + c[2] + c[3] + c[4] + c[5] + |
||||
c[6] + c[7] + c[8] + c[9] + c[10]; |
||||
adapt_prob(&pp[0], c[0], sum, 20, 128); |
||||
sum -= c[1]; |
||||
adapt_prob(&pp[1], c[1], sum, 20, 128); |
||||
sum -= c[2] + c[3]; |
||||
adapt_prob(&pp[2], c[2] + c[3], sum, 20, 128); |
||||
adapt_prob(&pp[3], c[2], c[3], 20, 128); |
||||
sum -= c[4] + c[5]; |
||||
adapt_prob(&pp[4], c[4] + c[5], sum, 20, 128); |
||||
adapt_prob(&pp[5], c[4], c[5], 20, 128); |
||||
sum -= c[6]; |
||||
adapt_prob(&pp[6], c[6], sum, 20, 128); |
||||
adapt_prob(&pp[7], c[7] + c[8], c[9] + c[10], 20, 128); |
||||
adapt_prob(&pp[8], c[7], c[8], 20, 128); |
||||
adapt_prob(&pp[9], c[9], c[10], 20, 128); |
||||
|
||||
adapt_prob(&p->mv_comp[i].class0, s->counts.mv_comp[i].class0[0], |
||||
s->counts.mv_comp[i].class0[1], 20, 128); |
||||
pp = p->mv_comp[i].bits; |
||||
c2 = s->counts.mv_comp[i].bits; |
||||
for (j = 0; j < 10; j++) |
||||
adapt_prob(&pp[j], c2[j][0], c2[j][1], 20, 128); |
||||
|
||||
for (j = 0; j < 2; j++) { |
||||
pp = p->mv_comp[i].class0_fp[j]; |
||||
c = s->counts.mv_comp[i].class0_fp[j]; |
||||
adapt_prob(&pp[0], c[0], c[1] + c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[1], c[1], c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[2], c[2], c[3], 20, 128); |
||||
} |
||||
pp = p->mv_comp[i].fp; |
||||
c = s->counts.mv_comp[i].fp; |
||||
adapt_prob(&pp[0], c[0], c[1] + c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[1], c[1], c[2] + c[3], 20, 128); |
||||
adapt_prob(&pp[2], c[2], c[3], 20, 128); |
||||
|
||||
if (s->highprecisionmvs) { |
||||
adapt_prob(&p->mv_comp[i].class0_hp, |
||||
s->counts.mv_comp[i].class0_hp[0], |
||||
s->counts.mv_comp[i].class0_hp[1], 20, 128); |
||||
adapt_prob(&p->mv_comp[i].hp, s->counts.mv_comp[i].hp[0], |
||||
s->counts.mv_comp[i].hp[1], 20, 128); |
||||
} |
||||
} |
||||
|
||||
// y intra modes
|
||||
for (i = 0; i < 4; i++) { |
||||
uint8_t *pp = p->y_mode[i]; |
||||
unsigned *c = s->counts.y_mode[i], sum, s2; |
||||
|
||||
sum = c[0] + c[1] + c[3] + c[4] + c[5] + c[6] + c[7] + c[8] + c[9]; |
||||
adapt_prob(&pp[0], c[DC_PRED], sum, 20, 128); |
||||
sum -= c[TM_VP8_PRED]; |
||||
adapt_prob(&pp[1], c[TM_VP8_PRED], sum, 20, 128); |
||||
sum -= c[VERT_PRED]; |
||||
adapt_prob(&pp[2], c[VERT_PRED], sum, 20, 128); |
||||
s2 = c[HOR_PRED] + c[DIAG_DOWN_RIGHT_PRED] + c[VERT_RIGHT_PRED]; |
||||
sum -= s2; |
||||
adapt_prob(&pp[3], s2, sum, 20, 128); |
||||
s2 -= c[HOR_PRED]; |
||||
adapt_prob(&pp[4], c[HOR_PRED], s2, 20, 128); |
||||
adapt_prob(&pp[5], c[DIAG_DOWN_RIGHT_PRED], c[VERT_RIGHT_PRED], |
||||
20, 128); |
||||
sum -= c[DIAG_DOWN_LEFT_PRED]; |
||||
adapt_prob(&pp[6], c[DIAG_DOWN_LEFT_PRED], sum, 20, 128); |
||||
sum -= c[VERT_LEFT_PRED]; |
||||
adapt_prob(&pp[7], c[VERT_LEFT_PRED], sum, 20, 128); |
||||
adapt_prob(&pp[8], c[HOR_DOWN_PRED], c[HOR_UP_PRED], 20, 128); |
||||
} |
||||
|
||||
// uv intra modes
|
||||
for (i = 0; i < 10; i++) { |
||||
uint8_t *pp = p->uv_mode[i]; |
||||
unsigned *c = s->counts.uv_mode[i], sum, s2; |
||||
|
||||
sum = c[0] + c[1] + c[3] + c[4] + c[5] + c[6] + c[7] + c[8] + c[9]; |
||||
adapt_prob(&pp[0], c[DC_PRED], sum, 20, 128); |
||||
sum -= c[TM_VP8_PRED]; |
||||
adapt_prob(&pp[1], c[TM_VP8_PRED], sum, 20, 128); |
||||
sum -= c[VERT_PRED]; |
||||
adapt_prob(&pp[2], c[VERT_PRED], sum, 20, 128); |
||||
s2 = c[HOR_PRED] + c[DIAG_DOWN_RIGHT_PRED] + c[VERT_RIGHT_PRED]; |
||||
sum -= s2; |
||||
adapt_prob(&pp[3], s2, sum, 20, 128); |
||||
s2 -= c[HOR_PRED]; |
||||
adapt_prob(&pp[4], c[HOR_PRED], s2, 20, 128); |
||||
adapt_prob(&pp[5], c[DIAG_DOWN_RIGHT_PRED], c[VERT_RIGHT_PRED], |
||||
20, 128); |
||||
sum -= c[DIAG_DOWN_LEFT_PRED]; |
||||
adapt_prob(&pp[6], c[DIAG_DOWN_LEFT_PRED], sum, 20, 128); |
||||
sum -= c[VERT_LEFT_PRED]; |
||||
adapt_prob(&pp[7], c[VERT_LEFT_PRED], sum, 20, 128); |
||||
adapt_prob(&pp[8], c[HOR_DOWN_PRED], c[HOR_UP_PRED], 20, 128); |
||||
} |
||||
} |
@ -0,0 +1,277 @@ |
||||
;****************************************************************************** |
||||
;* VP9 SIMD optimizations |
||||
;* |
||||
;* Copyright (c) 2013 Ronald S. Bultje <rsbultje gmail com> |
||||
;* |
||||
;* This file is part of Libav. |
||||
;* |
||||
;* Libav is free software; you can redistribute it and/or |
||||
;* modify it under the terms of the GNU Lesser General Public |
||||
;* License as published by the Free Software Foundation; either |
||||
;* version 2.1 of the License, or (at your option) any later version. |
||||
;* |
||||
;* Libav 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 |
||||
;* Lesser General Public License for more details. |
||||
;* |
||||
;* You should have received a copy of the GNU Lesser General Public |
||||
;* License along with Libav; if not, write to the Free Software |
||||
;* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
||||
;****************************************************************************** |
||||
|
||||
%include "libavutil/x86/x86util.asm" |
||||
|
||||
SECTION_RODATA |
||||
|
||||
; FIXME share with vp8dsp.asm |
||||
pw_256: times 8 dw 256 |
||||
|
||||
%macro F8_TAPS 8 |
||||
times 8 db %1, %2 |
||||
times 8 db %3, %4 |
||||
times 8 db %5, %6 |
||||
times 8 db %7, %8 |
||||
%endmacro |
||||
; int8_t ff_filters_ssse3[3][15][4][16] |
||||
const filters_ssse3 ; smooth |
||||
F8_TAPS -3, -1, 32, 64, 38, 1, -3, 0 |
||||
F8_TAPS -2, -2, 29, 63, 41, 2, -3, 0 |
||||
F8_TAPS -2, -2, 26, 63, 43, 4, -4, 0 |
||||
F8_TAPS -2, -3, 24, 62, 46, 5, -4, 0 |
||||
F8_TAPS -2, -3, 21, 60, 49, 7, -4, 0 |
||||
F8_TAPS -1, -4, 18, 59, 51, 9, -4, 0 |
||||
F8_TAPS -1, -4, 16, 57, 53, 12, -4, -1 |
||||
F8_TAPS -1, -4, 14, 55, 55, 14, -4, -1 |
||||
F8_TAPS -1, -4, 12, 53, 57, 16, -4, -1 |
||||
F8_TAPS 0, -4, 9, 51, 59, 18, -4, -1 |
||||
F8_TAPS 0, -4, 7, 49, 60, 21, -3, -2 |
||||
F8_TAPS 0, -4, 5, 46, 62, 24, -3, -2 |
||||
F8_TAPS 0, -4, 4, 43, 63, 26, -2, -2 |
||||
F8_TAPS 0, -3, 2, 41, 63, 29, -2, -2 |
||||
F8_TAPS 0, -3, 1, 38, 64, 32, -1, -3 |
||||
; regular |
||||
F8_TAPS 0, 1, -5, 126, 8, -3, 1, 0 |
||||
F8_TAPS -1, 3, -10, 122, 18, -6, 2, 0 |
||||
F8_TAPS -1, 4, -13, 118, 27, -9, 3, -1 |
||||
F8_TAPS -1, 4, -16, 112, 37, -11, 4, -1 |
||||
F8_TAPS -1, 5, -18, 105, 48, -14, 4, -1 |
||||
F8_TAPS -1, 5, -19, 97, 58, -16, 5, -1 |
||||
F8_TAPS -1, 6, -19, 88, 68, -18, 5, -1 |
||||
F8_TAPS -1, 6, -19, 78, 78, -19, 6, -1 |
||||
F8_TAPS -1, 5, -18, 68, 88, -19, 6, -1 |
||||
F8_TAPS -1, 5, -16, 58, 97, -19, 5, -1 |
||||
F8_TAPS -1, 4, -14, 48, 105, -18, 5, -1 |
||||
F8_TAPS -1, 4, -11, 37, 112, -16, 4, -1 |
||||
F8_TAPS -1, 3, -9, 27, 118, -13, 4, -1 |
||||
F8_TAPS 0, 2, -6, 18, 122, -10, 3, -1 |
||||
F8_TAPS 0, 1, -3, 8, 126, -5, 1, 0 |
||||
; sharp |
||||
F8_TAPS -1, 3, -7, 127, 8, -3, 1, 0 |
||||
F8_TAPS -2, 5, -13, 125, 17, -6, 3, -1 |
||||
F8_TAPS -3, 7, -17, 121, 27, -10, 5, -2 |
||||
F8_TAPS -4, 9, -20, 115, 37, -13, 6, -2 |
||||
F8_TAPS -4, 10, -23, 108, 48, -16, 8, -3 |
||||
F8_TAPS -4, 10, -24, 100, 59, -19, 9, -3 |
||||
F8_TAPS -4, 11, -24, 90, 70, -21, 10, -4 |
||||
F8_TAPS -4, 11, -23, 80, 80, -23, 11, -4 |
||||
F8_TAPS -4, 10, -21, 70, 90, -24, 11, -4 |
||||
F8_TAPS -3, 9, -19, 59, 100, -24, 10, -4 |
||||
F8_TAPS -3, 8, -16, 48, 108, -23, 10, -4 |
||||
F8_TAPS -2, 6, -13, 37, 115, -20, 9, -4 |
||||
F8_TAPS -2, 5, -10, 27, 121, -17, 7, -3 |
||||
F8_TAPS -1, 3, -6, 17, 125, -13, 5, -2 |
||||
F8_TAPS 0, 1, -3, 8, 127, -7, 3, -1 |
||||
|
||||
SECTION .text |
||||
|
||||
%macro filter_h_fn 1 |
||||
%assign %%px mmsize/2 |
||||
cglobal %1_8tap_1d_h_ %+ %%px, 6, 6, 11, dst, src, dstride, sstride, h, filtery |
||||
mova m6, [pw_256] |
||||
mova m7, [filteryq+ 0] |
||||
%if ARCH_X86_64 && mmsize > 8 |
||||
mova m8, [filteryq+16] |
||||
mova m9, [filteryq+32] |
||||
mova m10, [filteryq+48] |
||||
%endif |
||||
.loop: |
||||
movh m0, [srcq-3] |
||||
movh m1, [srcq-2] |
||||
movh m2, [srcq-1] |
||||
movh m3, [srcq+0] |
||||
movh m4, [srcq+1] |
||||
movh m5, [srcq+2] |
||||
punpcklbw m0, m1 |
||||
punpcklbw m2, m3 |
||||
movh m1, [srcq+3] |
||||
movh m3, [srcq+4] |
||||
add srcq, sstrideq |
||||
punpcklbw m4, m5 |
||||
punpcklbw m1, m3 |
||||
pmaddubsw m0, m7 |
||||
%if ARCH_X86_64 && mmsize > 8 |
||||
pmaddubsw m2, m8 |
||||
pmaddubsw m4, m9 |
||||
pmaddubsw m1, m10 |
||||
%else |
||||
pmaddubsw m2, [filteryq+16] |
||||
pmaddubsw m4, [filteryq+32] |
||||
pmaddubsw m1, [filteryq+48] |
||||
%endif |
||||
paddw m0, m2 |
||||
paddw m4, m1 |
||||
paddsw m0, m4 |
||||
pmulhrsw m0, m6 |
||||
%ifidn %1, avg |
||||
movh m1, [dstq] |
||||
%endif |
||||
packuswb m0, m0 |
||||
%ifidn %1, avg |
||||
pavgb m0, m1 |
||||
%endif |
||||
movh [dstq], m0 |
||||
add dstq, dstrideq |
||||
dec hd |
||||
jg .loop |
||||
RET |
||||
%endmacro |
||||
|
||||
INIT_MMX ssse3 |
||||
filter_h_fn put |
||||
filter_h_fn avg |
||||
|
||||
INIT_XMM ssse3 |
||||
filter_h_fn put |
||||
filter_h_fn avg |
||||
|
||||
%macro filter_v_fn 1 |
||||
%assign %%px mmsize/2 |
||||
%if ARCH_X86_64 |
||||
cglobal %1_8tap_1d_v_ %+ %%px, 6, 8, 11, dst, src, dstride, sstride, h, filtery, src4, sstride3 |
||||
%else |
||||
cglobal %1_8tap_1d_v_ %+ %%px, 4, 7, 11, dst, src, dstride, sstride, filtery, src4, sstride3 |
||||
mov filteryq, r5mp |
||||
%define hd r4mp |
||||
%endif |
||||
sub srcq, sstrideq |
||||
lea sstride3q, [sstrideq*3] |
||||
sub srcq, sstrideq |
||||
mova m6, [pw_256] |
||||
sub srcq, sstrideq |
||||
mova m7, [filteryq+ 0] |
||||
lea src4q, [srcq+sstrideq*4] |
||||
%if ARCH_X86_64 && mmsize > 8 |
||||
mova m8, [filteryq+16] |
||||
mova m9, [filteryq+32] |
||||
mova m10, [filteryq+48] |
||||
%endif |
||||
.loop: |
||||
; FIXME maybe reuse loads from previous rows, or just more generally |
||||
; unroll this to prevent multiple loads of the same data? |
||||
movh m0, [srcq] |
||||
movh m1, [srcq+sstrideq] |
||||
movh m2, [srcq+sstrideq*2] |
||||
movh m3, [srcq+sstride3q] |
||||
movh m4, [src4q] |
||||
movh m5, [src4q+sstrideq] |
||||
punpcklbw m0, m1 |
||||
punpcklbw m2, m3 |
||||
movh m1, [src4q+sstrideq*2] |
||||
movh m3, [src4q+sstride3q] |
||||
add srcq, sstrideq |
||||
add src4q, sstrideq |
||||
punpcklbw m4, m5 |
||||
punpcklbw m1, m3 |
||||
pmaddubsw m0, m7 |
||||
%if ARCH_X86_64 && mmsize > 8 |
||||
pmaddubsw m2, m8 |
||||
pmaddubsw m4, m9 |
||||
pmaddubsw m1, m10 |
||||
%else |
||||
pmaddubsw m2, [filteryq+16] |
||||
pmaddubsw m4, [filteryq+32] |
||||
pmaddubsw m1, [filteryq+48] |
||||
%endif |
||||
paddw m0, m2 |
||||
paddw m4, m1 |
||||
paddsw m0, m4 |
||||
pmulhrsw m0, m6 |
||||
%ifidn %1, avg |
||||
movh m1, [dstq] |
||||
%endif |
||||
packuswb m0, m0 |
||||
%ifidn %1, avg |
||||
pavgb m0, m1 |
||||
%endif |
||||
movh [dstq], m0 |
||||
add dstq, dstrideq |
||||
dec hd |
||||
jg .loop |
||||
RET |
||||
%endmacro |
||||
|
||||
INIT_MMX ssse3 |
||||
filter_v_fn put |
||||
filter_v_fn avg |
||||
|
||||
INIT_XMM ssse3 |
||||
filter_v_fn put |
||||
filter_v_fn avg |
||||
|
||||
%macro fpel_fn 6 |
||||
%if %2 == 4 |
||||
%define %%srcfn movh |
||||
%define %%dstfn movh |
||||
%else |
||||
%define %%srcfn movu |
||||
%define %%dstfn mova |
||||
%endif |
||||
|
||||
%if %2 <= 16 |
||||
cglobal %1%2, 5, 7, 4, dst, src, dstride, sstride, h, dstride3, sstride3 |
||||
lea sstride3q, [sstrideq*3] |
||||
lea dstride3q, [dstrideq*3] |
||||
%else |
||||
cglobal %1%2, 5, 5, 4, dst, src, dstride, sstride, h |
||||
%endif |
||||
.loop: |
||||
%%srcfn m0, [srcq] |
||||
%%srcfn m1, [srcq+s%3] |
||||
%%srcfn m2, [srcq+s%4] |
||||
%%srcfn m3, [srcq+s%5] |
||||
lea srcq, [srcq+sstrideq*%6] |
||||
%ifidn %1, avg |
||||
pavgb m0, [dstq] |
||||
pavgb m1, [dstq+d%3] |
||||
pavgb m2, [dstq+d%4] |
||||
pavgb m3, [dstq+d%5] |
||||
%endif |
||||
%%dstfn [dstq], m0 |
||||
%%dstfn [dstq+d%3], m1 |
||||
%%dstfn [dstq+d%4], m2 |
||||
%%dstfn [dstq+d%5], m3 |
||||
lea dstq, [dstq+dstrideq*%6] |
||||
sub hd, %6 |
||||
jnz .loop |
||||
RET |
||||
%endmacro |
||||
|
||||
%define d16 16 |
||||
%define s16 16 |
||||
INIT_MMX mmx |
||||
fpel_fn put, 4, strideq, strideq*2, stride3q, 4 |
||||
fpel_fn put, 8, strideq, strideq*2, stride3q, 4 |
||||
INIT_MMX sse |
||||
fpel_fn avg, 4, strideq, strideq*2, stride3q, 4 |
||||
fpel_fn avg, 8, strideq, strideq*2, stride3q, 4 |
||||
INIT_XMM sse |
||||
fpel_fn put, 16, strideq, strideq*2, stride3q, 4 |
||||
fpel_fn put, 32, mmsize, strideq, strideq+mmsize, 2 |
||||
fpel_fn put, 64, mmsize, mmsize*2, mmsize*3, 1 |
||||
INIT_XMM sse2 |
||||
fpel_fn avg, 16, strideq, strideq*2, stride3q, 4 |
||||
fpel_fn avg, 32, mmsize, strideq, strideq+mmsize, 2 |
||||
fpel_fn avg, 64, mmsize, mmsize*2, mmsize*3, 1 |
||||
%undef s16 |
||||
%undef d16 |
@ -0,0 +1,245 @@ |
||||
/*
|
||||
* VP9 SIMD optimizations |
||||
* |
||||
* Copyright (c) 2013 Ronald S. Bultje <rsbultje@gmail.com> |
||||
* |
||||
* This file is part of Libav. |
||||
* |
||||
* Libav is free software; you can redistribute it and/or |
||||
* modify it under the terms of the GNU Lesser General Public |
||||
* License as published by the Free Software Foundation; either |
||||
* version 2.1 of the License, or (at your option) any later version. |
||||
* |
||||
* Libav 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 |
||||
* Lesser General Public License for more details. |
||||
* |
||||
* You should have received a copy of the GNU Lesser General Public |
||||
* License along with Libav; if not, write to the Free Software |
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
||||
*/ |
||||
|
||||
#include "libavutil/cpu.h" |
||||
#include "libavutil/internal.h" |
||||
#include "libavutil/mem.h" |
||||
#include "libavutil/x86/asm.h" |
||||
#include "libavutil/x86/cpu.h" |
||||
#include "libavcodec/vp9.h" |
||||
|
||||
#if HAVE_YASM |
||||
|
||||
#define fpel_func(avg, sz, opt) \ |
||||
void ff_ ## avg ## sz ## _ ## opt(uint8_t *dst, const uint8_t *src, \
|
||||
ptrdiff_t dst_stride, \
|
||||
ptrdiff_t src_stride, \
|
||||
int h, int mx, int my) |
||||
|
||||
fpel_func(put, 4, mmx); |
||||
fpel_func(put, 8, mmx); |
||||
fpel_func(put, 16, sse); |
||||
fpel_func(put, 32, sse); |
||||
fpel_func(put, 64, sse); |
||||
fpel_func(avg, 4, sse); |
||||
fpel_func(avg, 8, sse); |
||||
fpel_func(avg, 16, sse2); |
||||
fpel_func(avg, 32, sse2); |
||||
fpel_func(avg, 64, sse2); |
||||
#undef fpel_func |
||||
|
||||
#define mc_func(avg, sz, dir, opt) \ |
||||
void \
|
||||
ff_ ## avg ## _8tap_1d_ ## dir ## _ ## sz ## _ ## opt(uint8_t *dst, \
|
||||
const uint8_t *src, \
|
||||
ptrdiff_t dst_stride, \
|
||||
ptrdiff_t src_stride, \
|
||||
int h, \
|
||||
const int8_t (*filter)[16]) |
||||
|
||||
#define mc_funcs(sz) \ |
||||
mc_func(put, sz, h, ssse3); \
|
||||
mc_func(avg, sz, h, ssse3); \
|
||||
mc_func(put, sz, v, ssse3); \
|
||||
mc_func(avg, sz, v, ssse3) |
||||
|
||||
mc_funcs(4); |
||||
mc_funcs(8); |
||||
|
||||
#undef mc_funcs |
||||
#undef mc_func |
||||
|
||||
#define mc_rep_func(avg, sz, hsz, dir, opt) \ |
||||
static av_always_inline void \
|
||||
ff_ ## avg ## _8tap_1d_ ## dir ## _ ## sz ## _ ## opt(uint8_t *dst, \
|
||||
const uint8_t *src, \
|
||||
ptrdiff_t dst_stride, \
|
||||
ptrdiff_t src_stride, \
|
||||
int h, \
|
||||
const int8_t (*filter)[16]) \
|
||||
{ \
|
||||
ff_ ## avg ## _8tap_1d_ ## dir ## _ ## hsz ## _ ## opt(dst, src, \
|
||||
dst_stride, \
|
||||
src_stride, \
|
||||
h, \
|
||||
filter); \
|
||||
ff_ ## avg ## _8tap_1d_ ## dir ## _ ## hsz ## _ ## opt(dst + hsz, \
|
||||
src + hsz, \
|
||||
dst_stride, \
|
||||
src_stride, \
|
||||
h, filter); \
|
||||
} |
||||
|
||||
#define mc_rep_funcs(sz, hsz) \ |
||||
mc_rep_func(put, sz, hsz, h, ssse3); \
|
||||
mc_rep_func(avg, sz, hsz, h, ssse3); \
|
||||
mc_rep_func(put, sz, hsz, v, ssse3); \
|
||||
mc_rep_func(avg, sz, hsz, v, ssse3) |
||||
|
||||
mc_rep_funcs(16, 8); |
||||
mc_rep_funcs(32, 16); |
||||
mc_rep_funcs(64, 32); |
||||
|
||||
#undef mc_rep_funcs |
||||
#undef mc_rep_func |
||||
|
||||
extern const int8_t ff_filters_ssse3[3][15][4][16]; |
||||
|
||||
#define filter_8tap_2d_fn(op, sz, f, fname) \ |
||||
static void \
|
||||
op ## _8tap_ ## fname ## _ ## sz ## hv_ssse3(uint8_t *dst, \
|
||||
const uint8_t *src, \
|
||||
ptrdiff_t dst_stride, \
|
||||
ptrdiff_t src_stride, \
|
||||
int h, int mx, int my) \
|
||||
{ \
|
||||
LOCAL_ALIGNED_16(uint8_t, temp, [71 * 64]); \
|
||||
ff_put_8tap_1d_h_ ## sz ## _ssse3(temp, src - 3 * src_stride, \
|
||||
64, src_stride, \
|
||||
h + 7, \
|
||||
ff_filters_ssse3[f][mx - 1]); \
|
||||
ff_ ## op ## _8tap_1d_v_ ## sz ## _ssse3(dst, temp + 3 * 64, \
|
||||
dst_stride, 64, \
|
||||
h, \
|
||||
ff_filters_ssse3[f][my - 1]); \
|
||||
} |
||||
|
||||
#define filters_8tap_2d_fn(op, sz) \ |
||||
filter_8tap_2d_fn(op, sz, FILTER_8TAP_REGULAR, regular) \
|
||||
filter_8tap_2d_fn(op, sz, FILTER_8TAP_SHARP, sharp) \
|
||||
filter_8tap_2d_fn(op, sz, FILTER_8TAP_SMOOTH, smooth) |
||||
|
||||
#define filters_8tap_2d_fn2(op) \ |
||||
filters_8tap_2d_fn(op, 64) \
|
||||
filters_8tap_2d_fn(op, 32) \
|
||||
filters_8tap_2d_fn(op, 16) \
|
||||
filters_8tap_2d_fn(op, 8) \
|
||||
filters_8tap_2d_fn(op, 4) |
||||
|
||||
filters_8tap_2d_fn2(put) |
||||
filters_8tap_2d_fn2(avg) |
||||
|
||||
#undef filters_8tap_2d_fn2 |
||||
#undef filters_8tap_2d_fn |
||||
#undef filter_8tap_2d_fn |
||||
|
||||
#define filter_8tap_1d_fn(op, sz, f, fname, dir, dvar) \ |
||||
static void \
|
||||
op ## _8tap_ ## fname ## _ ## sz ## dir ## _ssse3(uint8_t *dst, \
|
||||
const uint8_t *src, \
|
||||
ptrdiff_t dst_stride, \
|
||||
ptrdiff_t src_stride, \
|
||||
int h, int mx, \
|
||||
int my) \
|
||||
{ \
|
||||
ff_ ## op ## _8tap_1d_ ## dir ## _ ## sz ## _ssse3(dst, src, \
|
||||
dst_stride, \
|
||||
src_stride, h, \
|
||||
ff_filters_ssse3[f][dvar - 1]); \
|
||||
} |
||||
|
||||
#define filters_8tap_1d_fn(op, sz, dir, dvar) \ |
||||
filter_8tap_1d_fn(op, sz, FILTER_8TAP_REGULAR, regular, dir, dvar) \
|
||||
filter_8tap_1d_fn(op, sz, FILTER_8TAP_SHARP, sharp, dir, dvar) \
|
||||
filter_8tap_1d_fn(op, sz, FILTER_8TAP_SMOOTH, smooth, dir, dvar) |
||||
|
||||
#define filters_8tap_1d_fn2(op, sz) \ |
||||
filters_8tap_1d_fn(op, sz, h, mx) \
|
||||
filters_8tap_1d_fn(op, sz, v, my) |
||||
|
||||
#define filters_8tap_1d_fn3(op) \ |
||||
filters_8tap_1d_fn2(op, 64) \
|
||||
filters_8tap_1d_fn2(op, 32) \
|
||||
filters_8tap_1d_fn2(op, 16) \
|
||||
filters_8tap_1d_fn2(op, 8) \
|
||||
filters_8tap_1d_fn2(op, 4) |
||||
|
||||
filters_8tap_1d_fn3(put) |
||||
filters_8tap_1d_fn3(avg) |
||||
|
||||
#undef filters_8tap_1d_fn |
||||
#undef filters_8tap_1d_fn2 |
||||
#undef filters_8tap_1d_fn3 |
||||
#undef filter_8tap_1d_fn |
||||
|
||||
#endif /* HAVE_YASM */ |
||||
|
||||
av_cold void ff_vp9dsp_init_x86(VP9DSPContext *dsp) |
||||
{ |
||||
#if HAVE_YASM |
||||
int cpu_flags = av_get_cpu_flags(); |
||||
|
||||
#define init_fpel(idx1, idx2, sz, type, opt) \ |
||||
dsp->mc[idx1][FILTER_8TAP_SMOOTH ][idx2][0][0] = \
|
||||
dsp->mc[idx1][FILTER_8TAP_REGULAR][idx2][0][0] = \
|
||||
dsp->mc[idx1][FILTER_8TAP_SHARP ][idx2][0][0] = \
|
||||
dsp->mc[idx1][FILTER_BILINEAR ][idx2][0][0] = ff_ ## type ## sz ## _ ## opt |
||||
|
||||
|
||||
#define init_subpel1(idx1, idx2, idxh, idxv, sz, dir, type, opt) \ |
||||
dsp->mc[idx1][FILTER_8TAP_SMOOTH][idx2][idxh][idxv] = type ## _8tap_smooth_ ## sz ## dir ## _ ## opt; \
|
||||
dsp->mc[idx1][FILTER_8TAP_REGULAR][idx2][idxh][idxv] = type ## _8tap_regular_ ## sz ## dir ## _ ## opt; \
|
||||
dsp->mc[idx1][FILTER_8TAP_SHARP][idx2][idxh][idxv] = type ## _8tap_sharp_ ## sz ## dir ## _ ## opt |
||||
|
||||
#define init_subpel2(idx, idxh, idxv, dir, type, opt) \ |
||||
init_subpel1(0, idx, idxh, idxv, 64, dir, type, opt); \
|
||||
init_subpel1(1, idx, idxh, idxv, 32, dir, type, opt); \
|
||||
init_subpel1(2, idx, idxh, idxv, 16, dir, type, opt); \
|
||||
init_subpel1(3, idx, idxh, idxv, 8, dir, type, opt); \
|
||||
init_subpel1(4, idx, idxh, idxv, 4, dir, type, opt) |
||||
|
||||
#define init_subpel3(idx, type, opt) \ |
||||
init_subpel2(idx, 1, 1, hv, type, opt); \
|
||||
init_subpel2(idx, 0, 1, v, type, opt); \
|
||||
init_subpel2(idx, 1, 0, h, type, opt) |
||||
|
||||
if (EXTERNAL_MMX(cpu_flags)) { |
||||
init_fpel(4, 0, 4, put, mmx); |
||||
init_fpel(3, 0, 8, put, mmx); |
||||
} |
||||
|
||||
if (EXTERNAL_SSE(cpu_flags)) { |
||||
init_fpel(2, 0, 16, put, sse); |
||||
init_fpel(1, 0, 32, put, sse); |
||||
init_fpel(0, 0, 64, put, sse); |
||||
init_fpel(4, 1, 4, avg, sse); |
||||
init_fpel(3, 1, 8, avg, sse); |
||||
} |
||||
|
||||
if (EXTERNAL_SSE2(cpu_flags)) { |
||||
init_fpel(2, 1, 16, avg, sse2); |
||||
init_fpel(1, 1, 32, avg, sse2); |
||||
init_fpel(0, 1, 64, avg, sse2); |
||||
} |
||||
|
||||
if (EXTERNAL_SSSE3(cpu_flags)) { |
||||
init_subpel3(0, put, ssse3); |
||||
init_subpel3(1, avg, ssse3); |
||||
} |
||||
|
||||
#undef init_fpel |
||||
#undef init_subpel1 |
||||
#undef init_subpel2 |
||||
#undef init_subpel3 |
||||
|
||||
#endif /* HAVE_YASM */ |
||||
} |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, c3fbb7abbdb5bd4ed4a7e34768c17df1 |
||||
0, 33, 33, 0, 152064, 08203c2595bdb2d58ead6f921345d699 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, f041b870cf9236d5f22e2b08a77d5958 |
||||
0, 33, 33, 0, 152064, cbdb7526986ae15592891488c9afc84c |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 98048cfdb4af5059f4085c5acc94ef8f |
||||
0, 33, 33, 0, 152064, 8160183e1eed1d0af4427be216b8b9f7 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 15c548208f5eda243a151a42f4d64855 |
||||
0, 33, 33, 0, 152064, e96d463dc8e9b27b1c2ec40f77eee6ef |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 928c64a0747ac57ab50c1520d694fea7 |
||||
0, 33, 33, 0, 152064, a6f6daa293231e95ef30ed168f582c84 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 082460718b7d7046c8fb23184b7f71ca |
||||
0, 33, 33, 0, 152064, 4a41aad51c40a92df72333e13f47d3fe |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, cfca1bed96ff62a69b2d841fda01c6b9 |
||||
0, 33, 33, 0, 152064, 9b4d61f1b998745c108f8eb67925e03d |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 6f5122064bead9d9882bec2698a6ed9c |
||||
0, 33, 33, 0, 152064, 50dae67d2f57a76eece210dee8b6df9e |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, eb3d6985fcda5d93dd62d53354e8a093 |
||||
0, 33, 33, 0, 152064, 5b1f5b7780b4cafe1f75e56a0b526643 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, d7ccaf28c59875fe91983def5490d2b1 |
||||
0, 33, 33, 0, 152064, bd98fe9492054826748de840b4495309 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 20dda6231f9801c9c237c6d09d9939b6 |
||||
0, 33, 33, 0, 152064, 23c91e93807fb9a4ed5bd5bdd449d99f |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 960833315ebcdee97f46c4d98d0f3fef |
||||
0, 33, 33, 0, 152064, eec40507d17b64b7895a61cb87b2096a |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 6533224d3b6ba1ec0dd973bbe56c6349 |
||||
0, 33, 33, 0, 152064, 12ceadc6d28327a24a75f8c40b6084d1 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 7268de6756014f79a56dcf010c52a97f |
||||
0, 33, 33, 0, 152064, 9e39e9b0e2295b8460dfa05f44762771 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 57e9e333c641fa952f7485b788df225a |
||||
0, 33, 33, 0, 152064, 551f0cea83dcdf4540c3983736757874 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 17a0a2842856b9e89aede237648d5dda |
||||
0, 33, 33, 0, 152064, c9fcade888a38621bebe3d4b41664245 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 6cc2089e9a3d352fe10b59ccd935c677 |
||||
0, 33, 33, 0, 152064, d165bf7b9cb901e121a65038758d8613 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, bc80511c83162c09661f155cd29f6dd8 |
||||
0, 33, 33, 0, 152064, a62f1cbdb3f86d2fb4c880cfd917def5 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, b2d350f6faa41cb50c2e8a9907d0f4a5 |
||||
0, 33, 33, 0, 152064, 39b4380d16bc8e093dd4dba475175fb3 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 441e09be3c15fcb240afd74bb7a10a72 |
||||
0, 33, 33, 0, 152064, 32ae5dac876ca5d5ae6ab7c74f4dc25d |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 7786eb9944dba0553e129133523a98c1 |
||||
0, 33, 33, 0, 152064, 206d888f8453427f10a40aa8bf5f6df0 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, aab95e195be71feca050a839d7b3154d |
||||
0, 33, 33, 0, 152064, 02a05d699bbbdc477e34bb0dad9f0391 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 41f853c3ee2d4611b645cc643d82e287 |
||||
0, 33, 33, 0, 152064, 1c240c653110ff8609ca0f0287a6496d |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, bc5b07369df50c8f97ce1a377fe513cf |
||||
0, 33, 33, 0, 152064, ce62ddb4f3e305d0f8587ae8bb44cc79 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 982d54041221c977b6f0e37a9236cc76 |
||||
0, 33, 33, 0, 152064, 57631e7f13f645c834e2944ebfd6d40e |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, b0fb55f3f2f56b3d27038e83c10123ce |
||||
0, 33, 33, 0, 152064, 9fcac3becdcc2d30d778a55eca4c2018 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 4f645e0f354da77b9e2f2a6753c361da |
||||
0, 33, 33, 0, 152064, b7542998ec298273ca662bc9b658d10e |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 6edc96a3747cad43828397045764206e |
||||
0, 33, 33, 0, 152064, 5fbc65d20fdca1abd69079851ce676d3 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 5db3e910e70da38bb91d01d73acc33dd |
||||
0, 33, 33, 0, 152064, b920ee7f7e61b7fdf9f44b1f738d0292 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 3cb3e310be5305077efa6216f6f10654 |
||||
0, 33, 33, 0, 152064, 692d3e098af5978fe1a898ebc1a66a7a |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, e3b3cea66ea38c5dfba1aa73bb4c611d |
||||
0, 33, 33, 0, 152064, 42bb3e54b19c3f4c4f7ee3a6ba012e19 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 2523e9ecfd3781eafcd7da192dc105e9 |
||||
0, 33, 33, 0, 152064, 6d5feea012b9a1f51fc643633e728764 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 0a0305eba36500ebf6cc6cc0f01f5a3b |
||||
0, 33, 33, 0, 152064, 2c76bcd6763467f9057a726fbcf50ab1 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, c68433e0e94047c220be9b629334f744 |
||||
0, 33, 33, 0, 152064, fcfa4dff7a39bc9c5e315849ecbb46ea |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, ad9dc2f912c137b014a33e2792c88a25 |
||||
0, 33, 33, 0, 152064, 11221ee4ea5c776f43af68756682cd5a |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 75031f898cccf303a64ab46b1f815389 |
||||
0, 33, 33, 0, 152064, a4fc864e7fbc470dfcab6207e0eea152 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, c7824af009fde6cafdd8d39fae6bb6cf |
||||
0, 33, 33, 0, 152064, 516a82d5fc4dfa3daf713ed2ec36041b |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, fb23e0bc64728a492a33d985032f21b8 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 8347bfb891317e89ef66781d6c28e24f |
||||
0, 33, 33, 0, 152064, a5722f824d32deac042513a1a7dcdcd0 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 018968f97fac3bdff146cf22c1da5ef0 |
||||
0, 33, 33, 0, 152064, ca8b09b01e5132183395e238f1c7901e |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 792660f6589ad5340be4bd0554435866 |
||||
0, 33, 33, 0, 152064, 68c84c8a15d679e0a73678b93215c62c |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a456bdfc6c1c07b4cb3a3848843743b9 |
||||
0, 33, 33, 0, 152064, fe41a12b8cb6bc5667ba2179e076f3b0 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, f016dd8431694d989700fb1ba71a5b2d |
||||
0, 33, 33, 0, 152064, e89c3c5b935157b40f2fb0ab92415828 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 7b8ab82625f3006bac89d4fb5197e71c |
||||
0, 33, 33, 0, 152064, 18bd3716045563dfba2c72b640b3274b |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 66fde04d8320c750e56406feefd29979 |
||||
0, 33, 33, 0, 152064, f9d01d8fc1722ec345e624e14b404215 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, cc97597b015896d73f3e60e7ae44c4da |
||||
0, 33, 33, 0, 152064, fea98bc508f92135641ab99762444b14 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 79ed95c741178bb3c0954f1f6f8e21a3 |
||||
0, 33, 33, 0, 152064, f02a06a5e2b5b7619c9a52c5bea0564d |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 9b98e948b8c2a822f21bd8419e6f4410 |
||||
0, 33, 33, 0, 152064, 491382d68c16c2a3c6f1746598bc4a97 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, f0f095b0edae7262f44d7ed7ef84ded4 |
||||
0, 33, 33, 0, 152064, 0e833889ccac81d60251007d1baf6500 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 6c1b7b7827617fb9b8417aca2cfdbcaa |
||||
0, 33, 33, 0, 152064, 4c1fc8a89297fdcf79f0faabd42b8684 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, ca6142db68463487bc28c888ab38476c |
||||
0, 33, 33, 0, 152064, 02a71153ec70f569524c3d814cb62f86 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, eece2627df1ddf0872256eb92352e179 |
||||
0, 33, 33, 0, 152064, 0ee9f221246ad747250e4b5e8ba586e2 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 7290039d974c4e50db9d69f9864bcdbe |
||||
0, 33, 33, 0, 152064, 264765de9d02503038a4da54133b9f85 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 917af24da66f143a56a01eb2c2254285 |
||||
0, 33, 33, 0, 152064, 45a05d3bc644420519619e4115662a70 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 6fea2820bb10a9dec9add4d2452b01f5 |
||||
0, 33, 33, 0, 152064, 74675169a4bfc2ff5463c4db5d85a79f |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 11e5d196f6537fb7d85988d90195e556 |
||||
0, 33, 33, 0, 152064, 8536106795f7c93c5a43a11493527469 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 40839b7a3a40ec10f96b8a75224f646d |
||||
0, 33, 33, 0, 152064, 11408dd73e8c45ddaab99f5c9650102b |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, d0e9fa03dd48da4592ebaadb4e3794e0 |
||||
0, 33, 33, 0, 152064, 5172e29b1e04cd543833d6a68aab297c |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, bef4a27d460e7697e038fe6f1c8bd597 |
||||
0, 33, 33, 0, 152064, 124674686cafc5f2ff5bc7ea412b8f3b |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, ae9d99e9d16ef20073300559566844ae |
||||
0, 33, 33, 0, 152064, da9405e5a6bfe4ed18d927ba2004008e |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 9e66bb8e1b5e206ea4afe4bf2d335ac5 |
||||
0, 33, 33, 0, 152064, 092b74c905c12c1e87e90f5a79857736 |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, d062dc6be246c8042744018765ef50a8 |
||||
0, 33, 33, 0, 152064, 45fd9cbacb6a91060a7e49a58a85869d |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 62f7e42fe653e81c5a65a25389e045b5 |
||||
0, 33, 33, 0, 152064, cb0cdd0b25689e0a43328550011d960d |
@ -0,0 +1,3 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, 8467643dceff827e04acd82eeff1d1b0 |
||||
0, 33, 33, 0, 152064, c786f49d66f4dfd685dea9605821a19f |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, aa20a75be3a316193496706c9f760d08 |
||||
0, 66, 66, 0, 152064, 95567be97a64d3c9efe45f2524116a2e |
||||
0, 100, 100, 0, 152064, 219e86cd6b3cca312856eead21776b1c |
||||
0, 133, 133, 0, 152064, 4a67fd359ca362398e97c15eb018a2bb |
||||
0, 166, 166, 0, 152064, 9916d4e359274d690827f0eb22547423 |
||||
0, 200, 200, 0, 152064, a07785b52561150c48f1a8eff89d5d75 |
||||
0, 233, 233, 0, 152064, a3382a92982953dfa20018e5ac975b51 |
||||
0, 266, 266, 0, 152064, 911836989ca7b148438aa3ec7fc7e303 |
||||
0, 300, 300, 0, 152064, 5627b981e3fc9e4401d35d3a5ab25917 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, cd94572239817ae7c9b07de739c3272b |
||||
0, 66, 66, 0, 152064, 383cf752d457e122b5ff49d08960208e |
||||
0, 100, 100, 0, 152064, 1c0a6ec9cd3ce29b8b004e7526f1b07e |
||||
0, 133, 133, 0, 152064, 91c42a8a108d67947cabfc2a5a80df66 |
||||
0, 166, 166, 0, 152064, 08c57fc1f3fec0305883315a66c714d1 |
||||
0, 200, 200, 0, 152064, 70cb8d8dc83eac82f2d3c4b0376bb1aa |
||||
0, 233, 233, 0, 152064, ffd62a9ef829ec81f0f74f740488a41f |
||||
0, 266, 266, 0, 152064, bab0aa23b5854e2a70926046e4618710 |
||||
0, 300, 300, 0, 152064, fec456f38f2a43661e786a8d5f67ed15 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, 0d487a146393a0b8b84b4be1b371b507 |
||||
0, 66, 66, 0, 152064, 68372e191eba620a431cfff226026ac3 |
||||
0, 100, 100, 0, 152064, de7fd274460e36b983fe93acc208d72f |
||||
0, 133, 133, 0, 152064, afbd36c61bab65b98ff9acf08e215721 |
||||
0, 166, 166, 0, 152064, e1e9fc2ab4e7a187a8d8d84aae48d6b9 |
||||
0, 200, 200, 0, 152064, 11d95de6a9cc5e00511e99534779faac |
||||
0, 233, 233, 0, 152064, cd2f5539fdfc2d8eefe6b6da28c13398 |
||||
0, 266, 266, 0, 152064, a8b3aeed41da7aeb8d5b962ee4a4af93 |
||||
0, 300, 300, 0, 152064, 4283670bd1c1c506ef18d3dafca22035 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, 8bad76c55b5149169d64ce6512521de6 |
||||
0, 66, 66, 0, 152064, c1d986e1f9bf46382e598ba289b9bd7c |
||||
0, 100, 100, 0, 152064, 86c097ac6069c786023d3561dae68bac |
||||
0, 133, 133, 0, 152064, 8c238a2831b8c7c49736b6de6ff76ed8 |
||||
0, 166, 166, 0, 152064, cb5a038ed0a74a317ee72dae93a7ee3e |
||||
0, 200, 200, 0, 152064, f8fe330a257e3e4e4c39c1c12820a654 |
||||
0, 233, 233, 0, 152064, a73e2fcdcbb9334c0c123f8276a2c881 |
||||
0, 266, 266, 0, 152064, 24fccece8ee639e4d0e00e4060e1db0c |
||||
0, 300, 300, 0, 152064, 46d6e9aad69a39c718c5fd1e41e86e6e |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, f1ce0a5d57a46c9ff1331804b7b03fdb |
||||
0, 66, 66, 0, 152064, 0364a085b06bee6b980189cf5378eda9 |
||||
0, 100, 100, 0, 152064, 4b5358698d734b0ae210909a913d4c1e |
||||
0, 133, 133, 0, 152064, dc22565aaceee77b15fd8ab3c84bd5e0 |
||||
0, 166, 166, 0, 152064, 5f6340b656536292b46ba9a647aeb6e4 |
||||
0, 200, 200, 0, 152064, b7d4bce9a04b2a6caa45801be15e331e |
||||
0, 233, 233, 0, 152064, 534c851cfe59ffc047815ece98d8cede |
||||
0, 266, 266, 0, 152064, 786b0e1564d5c71aabfc2dd528cff4e7 |
||||
0, 300, 300, 0, 152064, cac0366209cf471bb7cc3e64966cbbd4 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, 45d9ca07ed04210b1ebc743169bc8ec4 |
||||
0, 66, 66, 0, 152064, 5b646cc309a711f1d8814f925002d8c4 |
||||
0, 100, 100, 0, 152064, 34db8db727fa1ded0a55cc7cf85be249 |
||||
0, 133, 133, 0, 152064, 54173d08afe6369b16a9c0c9cc6ce04d |
||||
0, 166, 166, 0, 152064, 76275b0a478cdb3c1fb527ebbce023c3 |
||||
0, 200, 200, 0, 152064, e7643cdf0c42f2af700d8730bfc1a453 |
||||
0, 233, 233, 0, 152064, 6e53097e56f680cb658d63100e7736f7 |
||||
0, 266, 266, 0, 152064, 1a407c3c8ea1d5245ae68c5ce7de70e1 |
||||
0, 300, 300, 0, 152064, 6cbca24912cadf09b20be74f14e359c9 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 152064, a2e5c820fd9733e18f9349fb658ca281 |
||||
0, 33, 33, 0, 152064, f719d0be18d16a448b4e7da3e2d9bf28 |
||||
0, 66, 66, 0, 152064, 83ee8ebc0ca796782a2376a76f2ffc26 |
||||
0, 100, 100, 0, 152064, 7cf5afdbc229e1af50a5377cfc23d831 |
||||
0, 133, 133, 0, 152064, 44244e896e0362f6376ba5afa563ba8b |
||||
0, 166, 166, 0, 152064, df5f518d44eb6cb91b2df5a30d27ef82 |
||||
0, 200, 200, 0, 152064, 43cc3f151b8337aca7ee659c8abeb783 |
||||
0, 233, 233, 0, 152064, 4e89573470d9b97464e10806fc81aa8b |
||||
0, 266, 266, 0, 152064, 62e0ba70f07ece8d85372f0a42e83a9a |
||||
0, 300, 300, 0, 152064, 45ac2928acb11326f6c4a21401f3609c |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 96, 52def242c36123e5a8f5f53d6a971399 |
||||
0, 33, 33, 0, 96, 79c93360fbd47179400414bbfee0901c |
||||
0, 66, 66, 0, 96, c3b1947c79537baa7838905276276a91 |
||||
0, 100, 100, 0, 96, 20f35e501bdee0bc63e87b9240265c25 |
||||
0, 133, 133, 0, 96, 5e8f1c464bafd54833c51860906b5368 |
||||
0, 166, 166, 0, 96, f57b592600dfc99e634a083278af769a |
||||
0, 200, 200, 0, 96, 7b02191f85590cbad3f148c7b92d6436 |
||||
0, 233, 233, 0, 96, b0a1c9870447a1744f64cd4087ef55ee |
||||
0, 266, 266, 0, 96, c82712b1ba7a95efb67cbdde0ad708b6 |
||||
0, 300, 300, 0, 96, 89f4539f8d7a7b45a91fd2f46335988e |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 120, ea3e0f807304b0eb2d3e329b0124f75c |
||||
0, 33, 33, 0, 120, 8d13cf682d63e7eb13094f55d67fc458 |
||||
0, 66, 66, 0, 120, e729cc6c3684c94a8f6118c618efc3ea |
||||
0, 100, 100, 0, 120, ac43a0ace8e4112e877c2491ecc14fb5 |
||||
0, 133, 133, 0, 120, 53695f90b88d8e8cb838f0faec3238d3 |
||||
0, 166, 166, 0, 120, 40afd1c4dfd4a2e3b31631c46d252bcc |
||||
0, 200, 200, 0, 120, 2b656f76f2e84d2f82d9bda2b5be94d3 |
||||
0, 233, 233, 0, 120, b22f004d678d047bc401be5e040cf883 |
||||
0, 266, 266, 0, 120, 57c840319abfb9c31013fbde54de3fb0 |
||||
0, 300, 300, 0, 120, 0f3dfc156216d7cfb6fd1d8c77dadab9 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 192, 0553e56a9d89aea496421885aab491f5 |
||||
0, 33, 33, 0, 192, b2a14cf676f7ebf3c50450050f76ad16 |
||||
0, 66, 66, 0, 192, a308d981e09b50571fb0c8ebdcefe505 |
||||
0, 100, 100, 0, 192, d592ec625a0ac0373e82610c3eed9864 |
||||
0, 133, 133, 0, 192, acd19642455e643023b4fb882c3891ba |
||||
0, 166, 166, 0, 192, 5af5390fd8c29b795e0ddf83f3f34284 |
||||
0, 200, 200, 0, 192, 473505aa2a76231725cf2107d6c9dbef |
||||
0, 233, 233, 0, 192, 84860db6887e320f2d64f80cf0032e57 |
||||
0, 266, 266, 0, 192, 408e9cf60e99ae99d204ff08f3196d1a |
||||
0, 300, 300, 0, 192, d8af96b79258f9382e911ed38340bdf5 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 216, 4c41f93b1b280b37bc77d7047435eaa4 |
||||
0, 33, 33, 0, 216, c9c80fdba2ebc2b8c3490ae35e34f84f |
||||
0, 66, 66, 0, 216, 089d86acb3263fa5ef4f591a7f44556d |
||||
0, 100, 100, 0, 216, 938fca6d93b83484144f5054e4838a41 |
||||
0, 133, 133, 0, 216, e0592e2ac9f5e09525ce0d3904cadf47 |
||||
0, 166, 166, 0, 216, ea43ff5d1330986e60c08567262ea764 |
||||
0, 200, 200, 0, 216, 08b40fe109ee90188f1cba9bbb1b376e |
||||
0, 233, 233, 0, 216, b067068a2a7e36d5c5b5b405a1e73a18 |
||||
0, 266, 266, 0, 216, 9cf2d350296288803434b7451bd2be85 |
||||
0, 300, 300, 0, 216, 3c785e21dc228d6396738fbfcb470289 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 384, f92a7777fd69aa2f2914d9a41c4828ba |
||||
0, 33, 33, 0, 384, 62e1cc73487d2249a88a60e35a22d9c7 |
||||
0, 66, 66, 0, 384, aa2619b605cb65eda15fdd99d5775550 |
||||
0, 100, 100, 0, 384, e6f0a491c543b835d0cefe5ca62c3dbe |
||||
0, 133, 133, 0, 384, 361be1a06913c398f09494ca1b2d288f |
||||
0, 166, 166, 0, 384, 0497bf849a973357c0ccb8d43f5bd8b4 |
||||
0, 200, 200, 0, 384, 5ac6ac523147c409dd00820622161dd7 |
||||
0, 233, 233, 0, 384, 7d07245574a46c524360f09be29a5f19 |
||||
0, 266, 266, 0, 384, fcfa7fbcaf42f81e4e34a4ee5a029ca1 |
||||
0, 300, 300, 0, 384, 336e3fe4f15d3d6c82d82b1855dcfeb4 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 408, f3f2cd8f157466ff23dace85d77367ce |
||||
0, 33, 33, 0, 408, 639d9b70a14062e95559c12d2b597f91 |
||||
0, 66, 66, 0, 408, b2ee07a6656af583f19593229fa11848 |
||||
0, 100, 100, 0, 408, 74e3b5ab4c798a0afe745694e871bbd5 |
||||
0, 133, 133, 0, 408, 35f1c30d0f8678f319a392a6c53b5989 |
||||
0, 166, 166, 0, 408, 07e2b4c0b92a394bfb11124fe80476f0 |
||||
0, 200, 200, 0, 408, 7864bd20dfc5280e5f027d67ea22bf30 |
||||
0, 233, 233, 0, 408, 10a2925a7b91dfa9b82de76069388fd4 |
||||
0, 266, 266, 0, 408, 79cc7f7a149e8d6e04e065f75e63733c |
||||
0, 300, 300, 0, 408, 6453d10d97532d9bb03f7c06cba9fca0 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 768, 764bd02b781a38c621a109c12f3d9393 |
||||
0, 33, 33, 0, 768, 79496bd2b9212026af816b3b7a0587d5 |
||||
0, 66, 66, 0, 768, 2a3afd47ba3d075033fd94d5c3746c45 |
||||
0, 100, 100, 0, 768, fca00cad8d37a6646337baebadd0ca31 |
||||
0, 133, 133, 0, 768, aca376fb3f8a5ef670ecc2430037262a |
||||
0, 166, 166, 0, 768, 7e6c8d96d1e24855c3e380f1bf2ce02c |
||||
0, 200, 200, 0, 768, 09e051241972969d439f27f324d78490 |
||||
0, 233, 233, 0, 768, 2566b2a425caaba41305bf04ff10ea01 |
||||
0, 266, 266, 0, 768, db3995bedee42ada1b4ee63c339daf1b |
||||
0, 300, 300, 0, 768, b00b8f1bf4fd907f0487738f5b5442c6 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 792, df20e8df89449fe50bb610e95a449a95 |
||||
0, 33, 33, 0, 792, 18f1a66d463274d1b0489f3a50e86857 |
||||
0, 66, 66, 0, 792, b0cc102875a94c9a92e53826617adbe9 |
||||
0, 100, 100, 0, 792, dfece7c17b4b149283ef51bdc1bd440e |
||||
0, 133, 133, 0, 792, 6e346884f67be259fcabe493109cb63c |
||||
0, 166, 166, 0, 792, 6d282127311eb2d958377490d7cb77f0 |
||||
0, 200, 200, 0, 792, 637ac8b14ca5ddbaf7b8910406c3cd08 |
||||
0, 233, 233, 0, 792, e7980f3fcb36969da0d218c4389fa9e8 |
||||
0, 266, 266, 0, 792, 730a1c95b9fb165f6e1a2f33a0d25de0 |
||||
0, 300, 300, 0, 792, 7bd8424d0783b1c8ad617e17408371bb |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 120, e1e66a88615da98523ef887f1463fc42 |
||||
0, 33, 33, 0, 120, 549842fa98c8faf572882d38b0aae390 |
||||
0, 66, 66, 0, 120, 17ee85785517705fdc78c6122a4b2548 |
||||
0, 100, 100, 0, 120, 1143391d419dac30a6c11f366157c974 |
||||
0, 133, 133, 0, 120, b62d2a962c4c36809ef75a610106715c |
||||
0, 166, 166, 0, 120, e6f143ca33fbc0e776bb149950cdedff |
||||
0, 200, 200, 0, 120, 01716a1077ec66df00474fd4510d2789 |
||||
0, 233, 233, 0, 120, 8cb5b6a865fa2cbb15f0d7736fda88a6 |
||||
0, 266, 266, 0, 120, 0fb9fd883e895a540fe1704dddbbab04 |
||||
0, 300, 300, 0, 120, 150a3b99aa24ef102c92f87c8adb4386 |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 150, 083d638f2e147295d817bb14fff5e4f4 |
||||
0, 33, 33, 0, 150, 6dbdc445b6fd6bb99f2025cc2a40977e |
||||
0, 66, 66, 0, 150, 41714089383b181d64fbfa7de5904608 |
||||
0, 100, 100, 0, 150, 11fdb8465e1599f7a9227706646d2cba |
||||
0, 133, 133, 0, 150, 907876b3342a10040db0851a936af4e3 |
||||
0, 166, 166, 0, 150, e7b18d47d06b25de205d873d3d941640 |
||||
0, 200, 200, 0, 150, 523ce7413c8da7f6a657a9b661f36c44 |
||||
0, 233, 233, 0, 150, 23caff863af875c66c903662a3e1e6a1 |
||||
0, 266, 266, 0, 150, ed4cc5557203e5b7a119112ee9ceb00b |
||||
0, 300, 300, 0, 150, 4bb78a996be3188888d1c60e11a08e1b |
@ -0,0 +1,11 @@ |
||||
#tb 0: 1/1000 |
||||
0, 0, 0, 0, 240, fab07d6209d2413e0a434e1aaaa12154 |
||||
0, 33, 33, 0, 240, f9ffffdb96f98527ba2e553d1265edbb |
||||
0, 66, 66, 0, 240, 56a992264cf7da2b23dd97435e9d0365 |
||||
0, 100, 100, 0, 240, b1db980423d8004bd45a789b02b92a65 |
||||
0, 133, 133, 0, 240, b29496aedc7026566367b634f55ebb28 |
||||
0, 166, 166, 0, 240, 2bc9def672da4a2fc17cbd669e2b8081 |
||||
0, 200, 200, 0, 240, 8c54721514cdf577a52a8668b9135f13 |
||||
0, 233, 233, 0, 240, 2efab81d5e039d82b3bc7b0303b022c4 |
||||
0, 266, 266, 0, 240, bd0f42b91b5d126fd0baec765b1096ad |
||||
0, 300, 300, 0, 240, c6bfea2735a629167bc6a7a7c76eb7f3 |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue