Johann [Wed, 28 Oct 2015 23:03:55 +0000 (16:03 -0700)]
Release v1.5.0
Javan Whistling Duck release.
Change-Id: If44c9ca16a8188b68759325fbacc771365cb4af8
James Zern [Thu, 29 Oct 2015 23:42:26 +0000 (16:42 -0700)]
vp9_dx_iface: move struct defs to separate header
this avoids redefining vpx_codec_vp9_dx, vpx_codec_vp9_dx_algo in
vp9_encoder_parms_get_to_decoder.cc
Change-Id: I3b89e7a62497227ee32419f1a7d30e4c10a13c05
(cherry picked from commit
ca163b85bb13fc07df3e1be60d4e4b71c8e83090)
James Zern [Thu, 29 Oct 2015 23:41:25 +0000 (16:41 -0700)]
vp9_decodeframe.h: add missing include
Change-Id: I8ef772a016a79cab88bee8e9739530aa030baaa9
(cherry picked from commit
68ecfc1e62408800611ed96c37949d65b7f25cf7)
Marco Paniconi [Mon, 26 Oct 2015 20:52:16 +0000 (20:52 +0000)]
Merge "Code cleanup for vp9-denoiser."
Paul Wilkins [Mon, 26 Oct 2015 19:12:34 +0000 (19:12 +0000)]
Merge "Incorrect frame used in KF boost loop."
Paul Wilkins [Mon, 26 Oct 2015 19:12:08 +0000 (19:12 +0000)]
Merge "Bug in clamping of base_frame_target."
Marco [Mon, 26 Oct 2015 19:01:52 +0000 (12:01 -0700)]
Code cleanup for vp9-denoiser.
Change-Id: Ibb573f50c4bf2cfb382b589803f3363db0ac1285
Debargha Mukherjee [Mon, 26 Oct 2015 18:04:49 +0000 (18:04 +0000)]
Merge "Optimize vpx_quantize_{b,b_32x32} assembler."
Debargha Mukherjee [Mon, 26 Oct 2015 18:03:46 +0000 (18:03 +0000)]
Merge "Optimize vp9_highbd_block_error_8bit assembly."
Alex Converse [Mon, 26 Oct 2015 17:05:00 +0000 (17:05 +0000)]
Merge "palette: Replace rand() call with custom LCG."
Jingning Han [Mon, 26 Oct 2015 16:25:56 +0000 (16:25 +0000)]
Merge "Use explicit block position in foreach_transformed_block"
Alex Converse [Wed, 14 Oct 2015 18:03:14 +0000 (11:03 -0700)]
palette: Replace rand() call with custom LCG.
The custom LCG is based on the POSIX recommend constants for a 16-bit
rand(). This implementation uses less computation than typical standard
library procedures which have been extended for 32-bit support, is
guaranteed to be reentrant, and identical everywhere.
Change-Id: I3140bbd566f44ab820d131c584a5d4ec6134c5a0
Ref: http://pubs.opengroup.org/onlinepubs/
9699919799/functions/rand.html
Paul Wilkins [Wed, 21 Oct 2015 16:20:13 +0000 (17:20 +0100)]
Bug in clamping of base_frame_target.
Bug relating to issue:- http://b/
25090786
base_frame_target is supposed to track the idealized bit
allocation based on error score and not the actual bits
allocated to each frame.
The clamping of this value based on the VBR min and max pct values
was causing a bug where in some cases the loop that adjusts the
active max quantizer for each GF group was running out of bits at
the end of a KF group. This caused a spike in Q and some ugly artifacts.
A second change makes sure that the calculation of the active
Q range for a group DOES, however, take account of clamping.
Change-Id: I31035e97d18853530b0874b433c1da7703f607d1
Marco [Fri, 16 Oct 2015 23:14:22 +0000 (16:14 -0700)]
VP9: Estimate noise level for denoiser.
Periodically estiamte noise level in source, and only denoise
if estimated noise level is above threshold.
Change-Id: I54f967b3003b0c14d0b1d3dc83cb82ce8cc2d381
Jingning Han [Fri, 23 Oct 2015 00:25:00 +0000 (17:25 -0700)]
Use explicit block position in foreach_transformed_block
Add the row and column index to the argument list of unit functions
called by foreach_transformed_block wrapper. This avoids the
repeated internal parsing according to the block index.
Change-Id: Ie7508acdac0b498487564639bc5cc6378a8a0df7
Ronald S. Bultje [Thu, 22 Oct 2015 21:14:20 +0000 (21:14 +0000)]
Merge "vp10: merge ext_ipred_bltr experiment into misc_fixes."
Ronald S. Bultje [Thu, 22 Oct 2015 21:14:13 +0000 (21:14 +0000)]
Merge "vp10: merge universal_hp experiment into misc_fixes."
Ronald S. Bultje [Thu, 22 Oct 2015 21:14:06 +0000 (21:14 +0000)]
Merge "Adjust superframe-is-optional unit test for vp10 superframe syntax."
Ronald S. Bultje [Thu, 22 Oct 2015 21:14:00 +0000 (21:14 +0000)]
Merge "vp10: don't allow comp_inter_inter on keyframes."
Ronald S. Bultje [Thu, 22 Oct 2015 21:12:44 +0000 (21:12 +0000)]
Merge "vp10: fix tile size in remuxing step."
Ronald S. Bultje [Thu, 22 Oct 2015 21:12:35 +0000 (21:12 +0000)]
Merge "vp10: use correct constant for bw adaptation of seg pred probs."
Ronald S. Bultje [Thu, 22 Oct 2015 21:12:25 +0000 (21:12 +0000)]
Merge "vp10: don't make right edge available across tile boundaries."
Ronald S. Bultje [Thu, 22 Oct 2015 21:12:09 +0000 (21:12 +0000)]
Merge "vp10: clip MVs before adding to find_ref_mvs() list."
Ronald S. Bultje [Wed, 21 Oct 2015 19:23:16 +0000 (15:23 -0400)]
vp10: merge ext_ipred_bltr experiment into misc_fixes.
Change-Id: I2f2deb700748408b8278b7f5c29ee1f2e39785ec
Ronald S. Bultje [Wed, 21 Oct 2015 19:20:22 +0000 (15:20 -0400)]
vp10: merge universal_hp experiment into misc_fixes.
Change-Id: I79fc3c0594535adc0056339c929cff69b8188760
Ronald S. Bultje [Wed, 21 Oct 2015 14:24:49 +0000 (10:24 -0400)]
Adjust superframe-is-optional unit test for vp10 superframe syntax.
Change-Id: Ic64b6928af7ae8ecc987f845b0bf0faecdacb072
Paul Wilkins [Wed, 21 Oct 2015 17:48:15 +0000 (18:48 +0100)]
Incorrect frame used in KF boost loop.
Fixes a bug in the calculation of the boost for key frames.
Change-Id: I75e9c96a9e86379239fbbbecb56ccd529783dc7c
Ronald S. Bultje [Wed, 21 Oct 2015 13:13:59 +0000 (09:13 -0400)]
vp10: don't allow comp_inter_inter on keyframes.
Change-Id: Ibd0e13721a2bb71c532d20b36c42f4cccf5c5de2
Ronald S. Bultje [Tue, 20 Oct 2015 23:40:36 +0000 (19:40 -0400)]
vp10: fix tile size in remuxing step.
Change-Id: Id48fb193bbdb3afed1d0db26c4ddded65a293b1b
Ronald S. Bultje [Tue, 20 Oct 2015 23:40:14 +0000 (19:40 -0400)]
vp10: use correct constant for bw adaptation of seg pred probs.
Change-Id: Idb869a77a126982814b8e7e288f952a65340e6be
Ronald S. Bultje [Tue, 20 Oct 2015 23:13:10 +0000 (19:13 -0400)]
vp10: don't make right edge available across tile boundaries.
Change-Id: Ia81cf3858ef6c8d1fd4b1fb2dd9627906081129d
Geza Lore [Thu, 15 Oct 2015 17:28:31 +0000 (18:28 +0100)]
Optimize vp9_highbd_block_error_8bit assembly.
A new version of vp9_highbd_error_8bit is now available which is
optimized with AVX assembly. AVX itself does not buy us too much, but
the non-destructive 3 operand format encoding of the 128bit SSEn integer
instructions helps to eliminate move instructions. The Sandy Bridge
micro-architecture cannot eliminate move instructions in the processor
front end, so AVX will help on these machines.
Further 2 optimizations are applied:
1. The common case of computing block error on 4x4 blocks is optimized
as a special case.
2. All arithmetic is speculatively done on 32 bits only. At the end of
the loop, the code detects if overflow might have happened and if so,
the whole computation is re-executed using higher precision arithmetic.
This case however is extremely rare in real use, so we can achieve a
large net gain here.
The optimizations rely on the fact that the coefficients are in the
range [-(2^15-1), 2^15-1], and that the quantized coefficients always
have the same sign as the input coefficients (in the worst case they are
0). These are the same assumptions that the old SSE2 assembly code for
the non high bitdepth configuration relied on. The unit tests have been
updated to take this constraint into consideration when generating test
input data.
Change-Id: I57d9888a74715e7145a5d9987d67891ef68f39b7
Ronald S. Bultje [Tue, 20 Oct 2015 19:58:00 +0000 (19:58 +0000)]
Merge "vp10: disallow coding zero-sized tiles-in-frame/frames-in-superframe."
Ronald S. Bultje [Tue, 20 Oct 2015 17:31:40 +0000 (13:31 -0400)]
vp10: clip MVs before adding to find_ref_mvs() list.
This causes the output of find_ref_mvs() to always be unique or zero.
A nice side-effect of this is that it also causes the output of
find_ref_mvs_sub8x8() to be unique-or-zero, and it will not ignore
available candidate MVs under certain conditions.
See issue 1012.
Change-Id: If4792789cb7885dbc9db420001d95f9b91b63bfa
Ronald S. Bultje [Tue, 20 Oct 2015 16:13:03 +0000 (12:13 -0400)]
vp10: disallow coding zero-sized tiles-in-frame/frames-in-superframe.
See issue 1088.
Change-Id: Icb15d33b4e316add848f210b50cbccd7c7847207
Marco [Tue, 20 Oct 2015 17:38:09 +0000 (10:38 -0700)]
Setting change in sample encoder: vpx_temporal_svc_encoder.c
Change-Id: Ifb384fa571eb08b516ed08fe05b8bca0c94b1edf
Hui Su [Tue, 20 Oct 2015 16:37:31 +0000 (16:37 +0000)]
Merge "VP10: some changes to palette mode"
Ronald S. Bultje [Tue, 20 Oct 2015 15:57:21 +0000 (15:57 +0000)]
Merge "vp10: write colorspace info for profile 0 intraonly frames."
Ronald S. Bultje [Tue, 20 Oct 2015 15:57:12 +0000 (15:57 +0000)]
Merge "vp10: per-segment lossless coding."
Ronald S. Bultje [Tue, 20 Oct 2015 15:57:05 +0000 (15:57 +0000)]
Merge "vp10: add extended-intra prediction edges experiment."
Ronald S. Bultje [Tue, 20 Oct 2015 15:56:56 +0000 (15:56 +0000)]
Merge "vp10: allow MV refs to point outside visible image."
Ronald S. Bultje [Tue, 20 Oct 2015 15:56:49 +0000 (15:56 +0000)]
Merge "vp10: allow forward updates for keyframe y intra mode probabilities."
Ronald S. Bultje [Tue, 20 Oct 2015 15:56:42 +0000 (15:56 +0000)]
Merge "vp10: merge keyframe/interframe uvintramode/partition probabilities."
Ronald S. Bultje [Tue, 20 Oct 2015 15:56:34 +0000 (15:56 +0000)]
Merge "vp10: make segmentation probs use generic probability model."
Geza Lore [Mon, 19 Oct 2015 13:05:35 +0000 (14:05 +0100)]
Optimize vpx_quantize_{b,b_32x32} assembler.
Added optimization of the 8 bit assembly quantizer routines. This makes
these functions up to 100% faster, depending on encoding parameters.
This patch maskes the encoder faster in both the high bitdepth and 8bit
configurations. In the high bitdepth configuration, it effects profile 0
only.
Based on my profiling using 1080p input the net gain is between 1-3% for
the 8 bit config, and around 2.5-4.5% for the high bitdepth config,
depending on target bitrate. The difference between the 8 bit and high
bitdepth configurations for the same encoder run is reduced by 1% in all
cases I have profiled.
Change-Id: I86714a6b7364da20cd468cd784247009663a5140
James Zern [Tue, 20 Oct 2015 02:46:36 +0000 (02:46 +0000)]
Merge "vp8cx: remove deprecated reference/entropy controls"
Ronald S. Bultje [Mon, 19 Oct 2015 16:18:57 +0000 (12:18 -0400)]
vp10: write colorspace info for profile 0 intraonly frames.
See issue 1087.
Change-Id: I231f6f12f870d0a56391daf1673536048418b207
James Zern [Fri, 16 Oct 2015 23:47:38 +0000 (16:47 -0700)]
vp8cx: remove deprecated reference/entropy controls
VP8E_UPD_ENTROPY, VP8E_UPD_REFERENCE and VP8E_USE_REFERENCE have been
deprecated since the initial public release
Change-Id: Ied16b441eec13434d85f1ab115d49ccaf5f2f7b0
Ronald S. Bultje [Mon, 12 Oct 2015 21:54:25 +0000 (17:54 -0400)]
vp10: per-segment lossless coding.
Some more testing of this patch would probably be useful, but I
think the basics of it should work fine now.
See issue 1035.
Change-Id: I4a36d58f671c5391cb09d564581784a00ed26245
Ronald S. Bultje [Mon, 12 Oct 2015 14:35:46 +0000 (10:35 -0400)]
vp10: add extended-intra prediction edges experiment.
This experiment allows using full above/right edges for all transform
sizes whenever available (for d45/d63), and adds bottom/left edges for
d207.
See issue 1043.
Change-Id: I5cf7f345e783e8539bb6b6d2c9972fb1d6d0a78b
Ronald S. Bultje [Fri, 2 Oct 2015 16:09:24 +0000 (12:09 -0400)]
vp10: allow MV refs to point outside visible image.
In VP9, the ref MV had to point to a block that itself fully resided
within the visible image, i.e. all borders of the image had to be
within the visible borders of the coded frame. This is somewhat
illogical, and had obscure side effects, e.g. clamping of fairly
reasonable motion vectors such as 0,0 were clipped to negative values
if the block was overhanging on frame edges (such as the last rows
on 1080p content), which makes no sense whatsoever.
Instead, relax clamping constraints such that the ref MVs are allowed
to point to blocks exactly outside the visible edges in both Y as well
as UV planes, including the 8tap filter edges (that's why the offset is
8 pixels + block size).
See issue 1037.
Change-Id: I2683eb2a18b24955e4dcce36c2940aa2ba3a1061
Ronald S. Bultje [Tue, 13 Oct 2015 18:08:24 +0000 (14:08 -0400)]
vp10: allow forward updates for keyframe y intra mode probabilities.
See issue 1040 point 5.
Change-Id: I51a70b9eade39efba392a1457bd70a3c515525cb
Ronald S. Bultje [Tue, 13 Oct 2015 18:07:47 +0000 (14:07 -0400)]
vp10: merge keyframe/interframe uvintramode/partition probabilities.
This has various benefits:
- simplify implementations because we don't have to switch between
multiple probability tables depending on frametype
- allows fw subexp and bw adaptivity for partitions/uvmode in keyframes
See issue 1040 point 5.
Change-Id: Ia566aa2863252d130cee9deedcf123bb2a0d3765
Ronald S. Bultje [Tue, 13 Oct 2015 18:06:28 +0000 (14:06 -0400)]
vp10: make segmentation probs use generic probability model.
Locate them (code-wise) in frame_context, and have them be updated
as any other probability using the subexp forward and adaptive bw
updates.
See issue 1040 point 1.
TODOs:
- real-world default probabilities
- why is counts sometimes NULL in the decoder? Does that mean bw
adaptivity updates only work on some frames? (I haven't looked
very closely yet, maybe this is a red herring.)
Change-Id: I23b57b4e5e7574b75f16eb64823b29c22fbab42e
Yaowu Xu [Fri, 16 Oct 2015 23:25:08 +0000 (16:25 -0700)]
Add a new enum type vpx_color_range_t
to make meaning of color_range obvious.
Change-Id: I303582e448b82b3203b497e27b22601cc718dfff
James Zern [Fri, 9 Oct 2015 23:31:17 +0000 (16:31 -0700)]
vpx/*.h: add VPX_CTRL_* preproc defines
allows controls to be tested for at compile-time
Change-Id: I1cd01287dc144392956c82e6dbac003f37703039
James Zern [Fri, 16 Oct 2015 18:47:08 +0000 (18:47 +0000)]
Merge "vpx/*.h, cosmetics: fix some typos"
hui su [Fri, 16 Oct 2015 01:04:50 +0000 (18:04 -0700)]
VP10: some changes to palette mode
Account for rounding in distortion calculation in k-means;
carry out rounding before duplicates removal of base colors;
replace numbers with macros;
use prefix increment.
Slight coding gain (<0.1%) on screen_content testset.
Change-Id: Ie8bd241266da6b82c7b2874befc3a0c72b4fcd8c
Marco [Tue, 29 Sep 2015 22:38:49 +0000 (15:38 -0700)]
Adjustment on limiting cyclic refresh on steady blocks.
Adjust the qp threshold and consec_zeromv threshold for
limiting cyclic refresh. Also increase the refresh period
when the limit amount is significant, and some code-cleanup.
Small gain in PSNR/SSIM metrics: ~0.25/0.3 gain on RTC set, speed 7.
Change only affects non-screen content.
Change-Id: I1ced87a89a132684c071e722616e445b2d18236a
Yaowu Xu [Thu, 15 Oct 2015 18:33:41 +0000 (11:33 -0700)]
Restore partial changes from previous commit
This portion was tested to have no effect on asan test failures.
Change-Id: I3de1dab7479148bdffc24c4568cb2e7e9963f099
hui su [Thu, 15 Oct 2015 03:18:18 +0000 (20:18 -0700)]
Fix palette mode in multi-thread encoding setting
Fix a couple of memory related errors. Also fix thread test failures.
Change-Id: I0103995f832cecf1dd2380000321ac7204f0cfc0
Jacky Chen [Thu, 15 Oct 2015 21:35:02 +0000 (21:35 +0000)]
Merge "VP9_resizing: adjust the threshold and another improvement."
Marco Paniconi [Thu, 15 Oct 2015 21:09:06 +0000 (21:09 +0000)]
Merge "Fix resetting of cyclic refresh on dynamic resize change."
JackyChen [Thu, 15 Oct 2015 06:04:01 +0000 (23:04 -0700)]
VP9_resizing: adjust the threshold and another improvement.
Adjust the qp threshold based on the denoising setting; not allow
to scale directly from original resolution to one half and vise versa.
Change-Id: I032a9b22f8e1c88de6bb81cf8351367223a3e40d
Marco [Thu, 15 Oct 2015 16:01:47 +0000 (09:01 -0700)]
Fix resetting of cyclic refresh on dynamic resize change.
Put the reset at the right place, during the setup and prior
to updating the map.
Change-Id: I75e550ae9d8cc15081330b8857edc04c23947875
Marco [Tue, 13 Oct 2015 02:17:44 +0000 (19:17 -0700)]
VP9: Rate control update for re-encode screen-content.
For the re-encoding (at max-qp) on the detected high-content change:
update rate correction factor, reset rate over/under-shoot flags,
and update/reset the rate control for layered coding.
Change-Id: I5dc72bb235427344dc87b5235f2b0f31704a034a
Yaowu Xu [Thu, 15 Oct 2015 14:39:01 +0000 (14:39 +0000)]
Merge "fix a msvc compiler warning"
Yaowu Xu [Thu, 15 Oct 2015 14:38:05 +0000 (14:38 +0000)]
Merge "Fix two asan failures"
Yaowu Xu [Wed, 14 Oct 2015 15:10:05 +0000 (08:10 -0700)]
fix a msvc compiler warning
Change-Id: Ifd6581c1bdb8d8f4b2ecf676c1a3d385dc129abf
Yaowu Xu [Wed, 14 Oct 2015 15:37:15 +0000 (08:37 -0700)]
Fix two asan failures
Change-Id: I57865e9604ac162ef0d97deb16e81ca436a98428
Johann [Wed, 14 Oct 2015 17:42:41 +0000 (10:42 -0700)]
Check for bswap* builtins before using
Canonical builtin checks for clang are to use
__has_builtin. Much less fragile than version checks.
https://code.google.com/p/webm/issues/detail?id=1082
Change-Id: I8151fb75899acdf1a935c23aad9441da99a9abcd
Johann [Tue, 13 Oct 2015 17:36:16 +0000 (10:36 -0700)]
Upstream Mozilla fix for older Apple clang builds
Also use the _mm_broadcastsi128_si256 intrisic for
Apple clang versions 4.[012]
https://bugzilla.mozilla.org/show_bug.cgi?id=1085607
https://code.google.com/p/webm/issues/detail?id=1082
Change-Id: I6bc821d8163387194ef663e94bfed91fa7281d88
Yaowu Xu [Tue, 13 Oct 2015 22:31:56 +0000 (22:31 +0000)]
Merge "Changes to partition breakout rules."
paulwilkins [Wed, 23 Sep 2015 10:13:52 +0000 (11:13 +0100)]
Changes to partition breakout rules.
Changes to the breakout behavior for partition selection.
The biggest impact is on speed 0 where encode speed in
some cases more than doubles with typically less than 1%
impact on quality.
Speed 0 encode speed impact examples
Animation test clip: +128%
Park Joy: +59%
Old town Cross: + 109%
Change-Id: I222720657e56cede1b2a5539096f788ffb2df3a1
Marco Paniconi [Tue, 13 Oct 2015 21:09:10 +0000 (21:09 +0000)]
Merge "VP9-SVC: Bugfix to allow skipping lower layer(s) encoding."
Ronald S. Bultje [Tue, 13 Oct 2015 19:33:05 +0000 (19:33 +0000)]
Merge "vp10: fix compiler warning with --enable-universal_hp."
Hui Su [Tue, 13 Oct 2015 19:30:33 +0000 (19:30 +0000)]
Merge "Fix compiler warnings"
Ronald S. Bultje [Mon, 12 Oct 2015 21:57:43 +0000 (17:57 -0400)]
vp10: fix compiler warning with --enable-universal_hp.
Change-Id: I0d7ca20bdd0fc868b28b0755e3114a4499056f45
Hui Su [Tue, 13 Oct 2015 17:34:27 +0000 (17:34 +0000)]
Merge "VP10: Add palette mode part 1"
hui su [Tue, 13 Oct 2015 17:16:51 +0000 (10:16 -0700)]
Fix compiler warnings
Change-Id: I761256a8100d83abf1b937f3739580237e3fad2a
Marco [Mon, 12 Oct 2015 23:05:27 +0000 (16:05 -0700)]
VP9-SVC: Bugfix to allow skipping lower layer(s) encoding.
The setting of svc->spatial_layer_to_encode was missing
in VP9E_SET_SVC_LAYER_ID.
Change-Id: I015b1a64adb9ef2644d6477a02d9d9364c8462b9
Ronald S. Bultje [Thu, 1 Oct 2015 14:45:46 +0000 (10:45 -0400)]
vp10: allow forward updates for uv_mode probabilities.
See issue 1040 point 4.
Change-Id: I79e06bd71a27f45770c760c47dc71bc3767a77a0
Ronald S. Bultje [Thu, 1 Oct 2015 14:32:57 +0000 (10:32 -0400)]
vp10: allow bw adaptivity for skip/tx probabilities in keyframes.
See issue 1040 point 3.
Change-Id: Ieef6d326b7fb50ceca5936525b7c688225a11fd1
Ronald S. Bultje [Mon, 12 Oct 2015 20:35:32 +0000 (16:35 -0400)]
vp10: don't write tile size marker bit if CONFIG_MISC_FIXES=0.
Change-Id: I41b13b8767e30da391c2c4da9a729ca7292b16b9
Ronald S. Bultje [Fri, 2 Oct 2015 19:07:04 +0000 (15:07 -0400)]
vp10: remove ref-MV-dependent use of HP.
This change (in a new config experiment: universal_hp) removes the
bitstream parsing dependency of the HP MV bit on the ref MV to be
coded. It also cleans up clearing of the HP bit in near/nearestMV,
since HP is always on if it's set in the frame header.
This admittedly doesn't clean up the crap that could be cleaned up,
but that's mostly because I think this needs some careful review;
not so much for coding style, but more from hardware people and from
the codec team on what we/you want. It would also be nice to get some
actual numbers on the real quality impact of this change. If, for
example, hardware people come up and tell us they don't actually care
anymore, we should probably just this code as-is and do nothing (i.e.
discard this patch).
See issue 1036.
Change-Id: Ic9b106f34422aa0f79de0c28125b72d566bd511a
Ronald S. Bultje [Fri, 2 Oct 2015 15:51:54 +0000 (11:51 -0400)]
vp10: remove clamp_mv2() call from vp10_find_best_ref_mvs().
This actually has no effect whatsoever, since the input MVs themselves
are clamped by clamp_mv_ref() already, which is significantly more
restrictive in its bounds.
Change-Id: I4a3a7b2b121ee422c56428c2a12d930c3813c06e
Ronald S. Bultje [Mon, 12 Oct 2015 18:45:04 +0000 (14:45 -0400)]
vp10: update assertion/allocation for tokens.
We only write EOSB tokens if we write tokens (i.e. not for skip blocks),
and we write EOSB tokens per-plane instead of per block.
Change-Id: I8d7ee99f8ec50eb7ae809f9f9282c1c91dbf6537
hui su [Tue, 15 Sep 2015 19:44:13 +0000 (12:44 -0700)]
VP10: Add palette mode part 1
Add palette mode for keyframe luma channel. Palette mode is enabled
when using "--tune-content=screen" in encoding config parameters.
on screen_content testset: +6.89%
on derlr : +0.00%
Design doc (WIP):
https://goo.gl/lD4yJw
Change-Id: Ib368b216bfd3ea21c6c27436934ad87afdaa6f88
James Zern [Sat, 10 Oct 2015 18:16:20 +0000 (11:16 -0700)]
tile_worker_hook: fix -Wclobbered warning
*tile should be marked volatile like the others due to the use of
setjmp()
Change-Id: I5dbf8e6792e4c0f34a683434b4fd06e3b4c75c4b
James Zern [Fri, 9 Oct 2015 05:43:45 +0000 (22:43 -0700)]
vpx/*.h, cosmetics: fix some typos
Change-Id: Ie9ead2c665c6c065a6b922ab66bae9be63483272
Alex Converse [Tue, 6 Oct 2015 22:59:03 +0000 (15:59 -0700)]
Add vpx_highbd_convolve_{copy,avg}_sse2
single-threaded:
swanky (silvermont): ~1% faster overall
peppy (celeron,haswell): ~1.5% faster overall
Change-Id: Ib74f014374c63c9eaf2d38191cbd8e2edcc52073
Alex Converse [Fri, 9 Oct 2015 18:42:05 +0000 (11:42 -0700)]
Generate convolve_test wrapper functions with a macro
Change-Id: Iccb4cdc23c1845cf9cb7d69101c9f4f43675d368
James Zern [Fri, 9 Oct 2015 17:52:34 +0000 (17:52 +0000)]
Merge "vp9/decode_tiles_mt: remove unnecessary local"
Geza Lore [Thu, 8 Oct 2015 17:33:32 +0000 (18:33 +0100)]
Remove 4 mova insts from quantize_ssse3_x86_64.asm
Change-Id: If3cb9345b44162e600e6c74873e0cb4c207fc7fb
Debargha Mukherjee [Fri, 9 Oct 2015 13:36:47 +0000 (13:36 +0000)]
Merge "Optimization of 8bit block error for high bitdepth"
Geza Lore [Thu, 8 Oct 2015 14:44:49 +0000 (15:44 +0100)]
Optimization of 8bit block error for high bitdepth
If high bit depth configuration is enabled, but encoding in profile 0,
the code now falls back on optimized SSE2 assembler to compute the
block errors, similar to when high bit depth is not enabled.
Change-Id: I471d1494e541de61a4008f852dbc0d548856484f
Jacky Chen [Thu, 8 Oct 2015 21:02:46 +0000 (21:02 +0000)]
Merge "VP9 denoiser: use skin map to improve denoising."
jackychen [Wed, 7 Oct 2015 22:08:20 +0000 (15:08 -0700)]
VP9 denoiser: use skin map to improve denoising.
Only denoise at small motion if it's a skin block.
Change-Id: I6235cad9dd7f76ab40e7d9cdfe6180e619c20c6e
Ronald S. Bultje [Thu, 8 Oct 2015 18:50:50 +0000 (18:50 +0000)]
Merge "vp10: use subexp probability updates for MV probs."
Ronald S. Bultje [Thu, 8 Oct 2015 18:50:39 +0000 (18:50 +0000)]
Merge "vp10: skip unreachable cat6 token extrabits."