Граф коммитов

1652 Коммитов

Автор SHA1 Сообщение Дата
Joe Young e7a9133c74 palette: fix bug in float_comparer()
This function is used by av1_remove_duplicates() to remove
duplicate palette colors.

Change-Id: Ia9943bffa2032bcae92f4a6da86477a8135613f2
2017-02-01 15:55:04 -08:00
Debargha Mukherjee d978cd5e74 Misc global motion changes.
A few encoder global-motion estimation parameter changes.
lowres: -0.844% (up by 0.08%)

Change-Id: Ib080125803cf56a91ce7d482d6d1445160105010
2017-02-01 22:27:39 +00:00
Sebastien Alaiwan d0e23b4061 Merge dct_const_round_shift functions.
Change-Id: I73e3eec0b8fd17c3f9b9f52afc9fac43f3043028
2017-02-01 16:35:09 +00:00
David Barker 3aec8d6cd5 Fix encode/decode mismatches for supertx + delta-q
This fixes the following mismatch bugs:
* At the bitstream level, the decoder would not read the delta_qindex
  information for supertx blocks, but the encoder always sent it,
  leading to the encoder and decoder becoming misaligned.
  The delta_qindex information is still required for supertx blocks,
  so change the decoder to read it.
* In addition, the quantizer was not properly adjusted for supertx
  blocks at the decoder. We copy the quantizer setup code from
  non-supertx blocks.

Since this does not change the encoder, it should not have any
quality impact.

Change-Id: I9a0f79c3aa66f2a5a353821e2a6f3b526636e7b4
2017-02-01 14:47:43 +00:00
Alex Converse 8aca36d36c ans: Remove some out of date ifdefs
Change-Id: Ibd4bbceca8218eb94ed0af3c980f8e829a1896de
2017-01-31 23:27:49 +00:00
Urvang Joshi 451e0f22c0 Bugfix: Fix an assert being triggered because of palette.
rd_pick_palette_intra_sby() was being passed a dummy 'best_mbmi' in
one case, and later that dummy value could be assigned to 'mbmi'
causing invalid values in 'mbmi'.

This bug was introduced by:
de0c70a2: Refactor rd_pick_intra_sby_mode()

See the referenced bug for a repro case.

BUG=aomedia:337

Change-Id: If6b0aa329f4e4902cd4de8a5e09bc5d9196492a1
2017-01-31 22:05:22 +00:00
Yue Chen 4415b6ccd9 Offset probabilities of compound types for cb4x4
BUG=aomedia:313

Change-Id: Ic1a9e20e5fd3f645d3be851d7be759cf4caf7c02
2017-01-31 22:02:16 +00:00
David Barker 426a997e63 Fix ext-inter + compound-segment + supertx
Allow the above combination of experiments to work together
correctly, fixing an encode/decode mismatch bug when they
were all enabled.

This change causes build_masked_compound(_highbd) to only
ever be called if CONFIG_SUPERTX is off, so wrap these functions
in an '#if !CONFIG_SUPERTX' block.

BUG=aomedia:313

Change-Id: Ic3886bc69ba9624b8fcb0a4c2d71fc64d2c0f22c
2017-01-31 12:59:50 -08:00
Urvang Joshi d803cb96d9 Fix segmentation fault when encoding all keyframes (kf-max-dist=0).
The issue was that:
- We call av1_setup_pre_planes() when this is not an intra-only frame,
but,
- But, we do motion vector search for any frame other than first frame
Doing both of these only when this is not an intra-only frames makes
logical sense and fixes the crash too.

This also avoids doing motion search for intra-only frames in the first
pass.

Verified that there is no change in compression performance for video,
as well as when forcing all keyframes.

BUG=aomedia:133

Change-Id: I7b18c0568eaa29c6c97f31f226243e5a9dbaecf1
2017-01-31 18:39:55 +00:00
Sarah Parker c2d3871501 Make global_motion work with ext_inter
Change-Id: I2a490e144099d7692296992528192c1f11d2c06f
2017-01-31 17:59:51 +00:00
Thomas Davies c6733fb7f0 EC_MULTISYMBOL: Separate out tokenization loop.
This will make merging EOB_TOKEN easier.

Change-Id: I1789344e9c3bbb329c30287a00aeee3c8a9d60c4
2017-01-31 11:16:24 +00:00
Thomas Davies f63903219f EC_MULTISYMBOL: split off token packing.
This will make refactoring to support EOB_TOKEN easier.

Change-Id: I8c7e37d090fd142f6b95d997116b84e6e10f3db5
2017-01-31 11:16:04 +00:00
Thomas Davies 0583c9849f EC_MULTISYMBOL: reconfigure coefficient decoding loop.
Preparation for merging EOB into multi-symbol encoding.
The more_data flag for the first position is moved
out of the loop, and for remaining positions is
moved in with the previous coefficient. This way it
can always be associated with the previous non-zero
coefficient.

Change-Id: Idfb38058f4c415127b4d9a9beeb8ea2d3a2ec1a2
2017-01-31 11:15:52 +00:00
Thomas Davies 0ccefe21af EC_MULTISYMBOL: merge ZERO_TOKEN into coding scheme.
Zero, one, and two or more coded as one symbol (head).
Remaining tokens coded as a tail symbol.

The pareto CDF distribution is adjusted to cover tokens from
two onwards.

Change-Id: I98b33fab6b9f52690f6ad618ac55e725a97be056
2017-01-31 11:13:04 +00:00
Urvang Joshi 23a611173b Palette code: add comments and rename some variables.
- Added comments for some tables and #defines for clarity.
- Renamed some variables to ensure we use "color_index" instead of
"color" for palette color index related variables.

Change-Id: Ica95a26e0f171a41a3259c8e6b3b891b8cd10151
2017-01-30 15:09:57 -08:00
Yue Chen d0d3bccf14 Fix conflicts between cb4x4 and warped_motion
Set mi_size properly in findSample()

Change-Id: I26bae25bf6300a107108dc5c2b7098e7d7dfa750
2017-01-30 22:04:02 +00:00
Jingning Han 1992af1b98 Make cb4x4 work with daala-ec
This commit makes the daala-ec work in the cb4x4 mode. As compared
to --enable-experimental, --enable-experimental --enable-cb4x4
improves the coding performance by:

lowres 2.6%
midres 1.2%

Change-Id: Ifee6f011c80364492c4a547513d24eb2958b5a56
2017-01-30 19:39:11 +00:00
Urvang Joshi cdbe708581 Palette Optimization: O(1) context lookup.
Now that we have small number of contexts (5), use hash multipliers
(instead of base 11), so that color context hash is within a small
range. This allows us to use a lookup table to get color context
instead of a for loop.

Output bitstreams are bit-exact, so no change in compression.

Change-Id: I8cd8c893048c2fc6b22ccbd56f652d11486e2ee9
2017-01-30 17:48:46 +00:00
Urvang Joshi 199a2f4052 Palette: Don't use top-right pixel for context of color indices.
This reduces the complexity in a number of ways:
- We need just 3 neighbors instead of 4.
- Possible contexts reduce from 16 to 5.
- On hardware side, getting the contexts for a whole block will be more
parallelizable.

At the same time, compression performance improves very slightly:
- Screen-content set (videos) (Google): BDRate improved by 0.32
- screenshots set (images) (AWCY): PSNR improved by 0.62:
https://arewecompressedyet.com/?job=palette_withTR2%402017-01-27T21%3A30%3A28.890Z&job=palette_noTR2%402017-01-27T21%3A41%3A34.312Z

Change-Id: Ie84ca32f05d55ad481a51c2d3abc579468597189
2017-01-30 17:48:46 +00:00
Jean-Marc Valin 79c0f32c58 Remove DCT from od_compute_dist_8x8
Cherry-pick Daala e248823a
 Getting rid of the DCT in od_compute_dist_8x8()
Replacing the DCT and frequency weighting by a filter

Change-Id: Icc3a46e5dbb561e4e3b00fa6c2290d54299c05cb
2017-01-30 09:46:15 +00:00
Jingning Han 86e277911a Fix ext-partition/type in cb4x4 mode
This commit fixes the encoding/decoding mismatch issue when
ext-partition and ext-partition-type are both turned on in cb4x4
mode.

BUG=aomedia:336

Change-Id: I4d6ad5863c9d3bc8e3a41c259b8b39f130164790
2017-01-27 13:58:08 -08:00
Debargha Mukherjee 4bab6e4f58 Adjust WIENER_FILT_TAP2_MIDV value to fix convolve
Adjusts the value by 1 to make sure that the center tap
if the Wiener filter does not drop below 0.

BUG=aomedia:315

Change-Id: I41c3a2eb3f36dd49072a4873a995003d18f94ece
2017-01-27 17:56:17 +00:00
Jonathan Matthews 6d69ba0c74 Bugfix: decode_palette_tokens inverting stride and width.
Introduced in I745ca032f313c5041aacc98c03ae4bfc33d840de.
Stride should be plane_block_width and width should be cols,
 sanity check: cols <= plane_block_width.

Change-Id: Ic5128e94a909e498010c92fef2013da8df6d6d85
2017-01-27 17:26:15 +00:00
Thomas Davies dbfc4f9cc0 TILE_GROUPS: code a single tile group more efficiently.
Change-Id: If6efdb754558e3f237aa2d56c0eae4590fb021a4
2017-01-27 15:18:06 +00:00
Debargha Mukherjee 1a0ae84dab Fix OneByOneVideoTest for loop-restoration
Fixes and turns on the test.

BUG=aomedia:312

Change-Id: I6c7d1970e743ec2b025a798070761d22624e796a
2017-01-27 06:06:04 +00:00
Debargha Mukherjee 9868c7479a Fix crash with cb4x4 and warped-motion
BUG=aomedia:314

Change-Id: I66af7f69ca0b97b9d840918a6b9ec34708a7f4e5
2017-01-27 00:54:05 +00:00
hui su 83c2663677 Refactor rd_pick_intra_sbuv_mode()
Change-Id: Id86b48ad34059668beb9464200dd9e03fc1b8a48
2017-01-27 00:42:44 +00:00
Yaowu Xu 006ff4be43 Change to initialize correct thread_data
BUG=aomedia:307

Change-Id: Ia1d39916b3e856acd33f4e199321395455151fb6
2017-01-26 23:05:35 +00:00
Debargha Mukherjee ff59b6acb1 Fix mismtach with ref-mv and ext-partition-types
Change the list of search offsets searched when ext-partition-types
is on for square block_sizes. This is because the VERTICAL_A and
HORIZONTAL_A partitions are incompatible with the default list.

BUG=AOMEDIA:141

Change-Id: I884c45c3d11039b7dcb72336a928362f926473ed
2017-01-26 20:48:18 +00:00
Urvang Joshi 56ba91bbe4 Palette: Don't store tokens for pixels outside image boundary.
If part of a block falls outside right and/or bottom image boundary,
then only store tokens for the part of it within the boundary.

Also, consider only the part of the block within the boundary when
calculating the number of colors in the image, deciding the base
colors for palette, RD calculation etc.

The part of color map corresponding to pixels outside the image
boundary is padded with color indices copied from same row/column.
This behavior is similar to how pixels outside the boundary are padded.

For screen_content set, this is improves compression performance by
0.038 overall. One clip, in particular, has a significant gain of 0.8.

Change-Id: I745ca032f313c5041aacc98c03ae4bfc33d840de
2017-01-26 18:03:33 +00:00
ltrudeau e1c0929f51 Convert PVQ skip variable to enum
Creates the PVQ_SKIP_TYPE enum to encapsulate the different types of
skipping that can be signaled by PVQ (i.e. skip: AC, DC or both).

There is no impact on the bitstream. However, the decoder will now emit
an internal error if the decoded skip flag is out of range. The
block_skip variable is also renamed to ac_dc_coded as it stores the same
information.

Change-Id: Ib2aadaf99dc1736ea392ae5ed8948c3cdc12da9b
2017-01-26 17:36:04 +00:00
Debargha Mukherjee 8b61321690 Fix mismatch w/ ext-inter/warped-motion/motion-var
Fixes a mismatch issue with ext-inter+motion-var+warped-motion
due to unset num_proj_ref values.

BUG=aomedia:311

Change-Id: I042551f6c53e8cc005f2133704a03b243c98c12a
2017-01-26 02:05:45 +00:00
hui su 78c611ab7f Speed up palette keyframe encoding with model RD
On keyframe, 18% speedup, 0.02% compression loss.

Change-Id: I29085ec23dd145effbea58852a46cd7f4dea8a46
2017-01-25 23:47:03 +00:00
hui su 8f4cc0a351 Speed up filter-intra keyframe encoding with model RD
On keyframe, 22% speedup, 0.04% compression loss.

Change-Id: I70d387cc9de86c0c0c8b0037d35cff141409d59b
2017-01-25 23:38:57 +00:00
hui su 0161a93266 Cleanup for the entropy experiment
Minor performance changes
0.03% better on lowres
0.01% better on midres

Change-Id: I7a7168f3a2a4d17a03353841a416eff6edf1e241
2017-01-25 22:45:22 +00:00
hui su 9a416f5721 Speed up ext-intra keyframe encoding with model RD
On keyframe, 18% speedup, 0.07% compression loss.

Change-Id: I98323db23251c70958a314f16fd6d789579017ec
2017-01-25 22:44:20 +00:00
Tristan Matthews 54e197749d pvq: skip gshift calculation in float pvq case
Cherry-picked from daala commit 28de40bfcd84e7df3fbd64de7b89dd7fd889bb27

Change-Id: I31af05f07514c023c5be84f7e2ae353ab7d276f0
2017-01-25 21:18:14 +00:00
James Zern e2a703e340 av1_dct_test: fix duplicate symbol link error
only expose the static functions needed in the test file to avoid link
errors for e.g., av1_fht4x4_c

Change-Id: I35111d322f30bc2bfc57b32c11f691f0717cfaba
2017-01-25 19:43:06 +00:00
Debargha Mukherjee 63131ea6e3 Silence a compiler warning
Change-Id: I130f748c076a1642f12b95051dab19bfdac5b855
2017-01-25 05:10:06 +00:00
David Barker 839467f42c Make ext-inter use new rectangular intra predictor
Now that https://aomedia-review.googlesource.com/#/c/6729/
has been merged, build_intra_predictors_for_interintra() is
now redundant, so replace it by a direct call to
av1_predict_intra_block() and remove the old function.

Reset rect_interintra back to 1.

To do this, we need to make the intra predictor take a
BLOCK_SIZE instead of a TX_SIZE. This is because we need to
be able to predict 32x64 and 64x32 blocks, but there is no
TX_32X64 or TX_64X32.

No effect on output or performance.

Change-Id: I8c185a211c97a85012cc54ec293c785a693608ed
2017-01-24 21:37:24 +00:00
Yaowu Xu a93e65e5c6 Fix a couple of typos
Change-Id: Ibec40c3cd8e14343b096e406ba233cf4f131e7b9
2017-01-24 20:35:31 +00:00
Angie Chiang c71d613097 Fix bitstream error when entropy and adapt_scan on
BUG=aomedia:310

Change-Id: I8e1a1c6d59e3d14ba132d2bbf4e203da26538bde
2017-01-24 20:06:31 +00:00
Jingning Han 61418bbd1f Fix conflicts between ext-inter and cb4x4 modes
Resolve the broken coding pipeline in ext-inter experiment when
cb4x4 mode is enabled. Turn off rectangular inter-intra mode.
This needs some more work to hook up. Given that it gives fairly
limited coding performance gains, disable it for the moment.

BUG=aomedia:309

Change-Id: I9b406df6183f75697bfd4eed5125a6e9436d84b0
2017-01-24 18:18:19 +00:00
Fangwen Fu 8d164de25c enable explicit temp mv prediction signaling
Change-Id: Ieb2922c3df4ef4f8514b8a6df6f9a8fc45ef3cf4
2017-01-23 14:22:45 -08:00
Yaowu Xu 6b763c9c9e Fix issues in --enable-entropy and --enable-cb4x4
Change-Id: I148d60d56599a238c60c429572a25cbddbe5191d
2017-01-23 21:50:06 +00:00
Emil Keyder 01770b3e20 Rename NONE to NONE_FRAME.
This follows the naming for the other frame types, and allows libaom
to be compiled against other libraries that also #define NONE.

Change-Id: Ic2e2814587bbc5ea67385a9af775396d29b7dde0
2017-01-23 21:12:35 +00:00
David Barker 13797462df Warp filter improvements
* The restriction on the parameter 'delta' was too strict, so we
  loosen it (delta only ever gets multiplied by -4, ... , 4,
  whereas beta gets multiplied by -7, ..., 7)
* Correct a comment about the border clamping
* Fix an issue with the test case

Change-Id: I30e55203455ba6e419b5a8b646151a6d1fd5cc3b
2017-01-23 20:46:22 +00:00
Yushin Cho 7a428ba243 Add a new experiment, DAALA_DIST
This commit adds a new experiment, Daala's distortion function,
which is designed to better approximate perceptual distortion
in 8x8 pixel blocks.

This experiment is expected to work best with PVQ.

It measures the variance of overlapped 4x4 regions in the 8x8 area,
then uses these variances to scale the MSE of weighted frequency domain
distortion of 8x8 block.

Since AV1 calculates distortion in blocks as small as 4x4, it is not possible to
directly replace the existing distortion functions of AV1,
such as dist_block() and block_rd_txf().
Hence, there has been substantial changes in order to apply
Daala's 8x8 distortion function.
The daala distortion function is applied
after all 4x4 tx blocks in a 8x8 block are encoded (during RDO),
as in below two cases:
1) intra/inter sub8x8 predictions and
2) 4x4 transform with prediction size >= 8.

To enable this experiment, add '--enable-daala-dist' with configure.

TODO: Significant tuning of parameters is required since the function has
originally came from Daala thus most parameters would not work
correctly outside Daala.
The fact that chroma distortion is added to the distortion of AV1's RDO is
also critical since Daala's distortion function is applied to luma only
and chroma continues to use MSE.

Change-Id: If35fdd3aec7efe401f351ba1c99891ad57a3d957
2017-01-23 20:24:57 +00:00
Jingning Han 48b1cb35bb Support filter-intra in cb4x4 mode
This commit resolves an enc/dec mismatch issue when both filter-intra
and cb4x4 modes are enabled.

BUG=aomedia:253

Change-Id: I4026d93c00a819f2ce69aedba9d34a774319acbf
2017-01-23 20:20:30 +00:00
Angie Chiang 54294194c5 Fix segmentation fault of dual_filter in hbd mode
BUG=aomedia:142

Change-Id: Id21dd2d19e1e46a9225cd5f8f8b0705ae178118c
2017-01-23 16:10:28 +00:00