]> granicus.if.org Git - libvpx/log
libvpx
11 years agoMerge "Always extend macroblock edges in the decoder." into experimental
Debargha Mukherjee [Thu, 25 Oct 2012 20:52:29 +0000 (13:52 -0700)]
Merge "Always extend macroblock edges in the decoder." into experimental

11 years agoAlways extend macroblock edges in the decoder.
Ronald S. Bultje [Thu, 25 Oct 2012 19:46:26 +0000 (12:46 -0700)]
Always extend macroblock edges in the decoder.

This fixes edge extension if SB [0,1] doesn't use B_PRED but [1,1] does.

Change-Id: I48354a9dba0de16472938824f5e6db87ce61979f

11 years agoAdded sse2 instrinsic version of vp8_sad3x16
Scott LaVarnway [Mon, 22 Oct 2012 23:38:58 +0000 (16:38 -0700)]
Added sse2 instrinsic version of vp8_sad3x16

1.6% boost in decoder performance for the clip used.

Change-Id: I91f3c4573fd3d10afbf18930f279af7ae2223e3a

11 years agoMerge "Added sse2 instrinsic version of vp8_sad16x3" into experimental
Scott LaVarnway [Thu, 25 Oct 2012 19:19:26 +0000 (12:19 -0700)]
Merge "Added sse2 instrinsic version of vp8_sad16x3" into experimental

11 years agoAdded sse2 instrinsic version of vp8_sad16x3
Scott LaVarnway [Mon, 22 Oct 2012 23:16:04 +0000 (16:16 -0700)]
Added sse2 instrinsic version of vp8_sad16x3

3.7% boost in decoder performance for the clip used.

Change-Id: I74f28486a9352b472b36e21b5eaf30eff35e9199

11 years agoFix 4x4 intra prediction on the edge of SB rows.
Ronald S. Bultje [Thu, 25 Oct 2012 19:05:37 +0000 (12:05 -0700)]
Fix 4x4 intra prediction on the edge of SB rows.

Change-Id: I87d571008c73f0a8514e0a864405aadb82fd1bc0

11 years agoFix yet another typo in splitmv/tx_select code.
Ronald S. Bultje [Thu, 25 Oct 2012 16:17:47 +0000 (09:17 -0700)]
Fix yet another typo in splitmv/tx_select code.

Change-Id: I6a28cc87af275fc267b3cc8d90d642dcc870c249

11 years agoGeneralize coefficient tokenizing.
Ronald S. Bultje [Thu, 25 Oct 2012 16:14:21 +0000 (09:14 -0700)]
Generalize coefficient tokenizing.

Change-Id: Ie33f7d0f90d0e5862be975d676a700d06f79eec6

11 years agoGeneralize EOB token stuffing.
Ronald S. Bultje [Wed, 24 Oct 2012 23:59:00 +0000 (16:59 -0700)]
Generalize EOB token stuffing.

Change-Id: Ibb51f3f8c3575d4621890220b20887a13a46a04e

11 years agoMerge "Fix typo in splitmv/tx_select code." into experimental
Ronald S. Bultje [Wed, 24 Oct 2012 22:21:05 +0000 (15:21 -0700)]
Merge "Fix typo in splitmv/tx_select code." into experimental

11 years agoFix typo in splitmv/tx_select code.
Ronald S. Bultje [Wed, 24 Oct 2012 20:03:51 +0000 (13:03 -0700)]
Fix typo in splitmv/tx_select code.

Change-Id: I2823043634b0fa617c2715d63ff18595b7209287

11 years agoFix bad merge of coef_probs update
John Koleszar [Wed, 24 Oct 2012 19:59:22 +0000 (12:59 -0700)]
Fix bad merge of coef_probs update

Stray CONFIG_HYBRIDTRANSFORM caused decode mismatch.

Change-Id: I1d77bad9b366f7a6ceb3cb45269ed5badb5c4c53

11 years agocoef_probs: remove duplicate read/update code
John Koleszar [Fri, 19 Oct 2012 22:35:36 +0000 (15:35 -0700)]
coef_probs: remove duplicate read/update code

Refactor per-transform copy & paste into a common function
update_coef_probs_common() and read_coef_probs_common(). The dry-run and
bit-writing loops in the encoder are still obvious candidates to be made
common, but they start to diverge a bit in the next commit, so are left
as-is for now.

Change-Id: I896bd3f4a073a6296eab7e92463fef79d8c6c08c

11 years agoMerge "Fix "_FORTIFY_SOURCE" redefined warning" into experimental
John Koleszar [Wed, 24 Oct 2012 16:36:40 +0000 (09:36 -0700)]
Merge "Fix "_FORTIFY_SOURCE" redefined warning" into experimental

11 years agoFix "_FORTIFY_SOURCE" redefined warning
Yunqing Wang [Wed, 24 Oct 2012 16:14:36 +0000 (09:14 -0700)]
Fix "_FORTIFY_SOURCE" redefined warning

On Ubuntu 12.04, we got the following warning message:
<command-line>:0:0: warning: "_FORTIFY_SOURCE" redefined
 [enabled by default]
<built-in>:0:0: note: this is the location of the previous definition

This was already fixed in VP8 configure file. Did the same change in
experimental branch to stop this warning.

Change-Id: Id162e5fd8841585ae806df6560b2f7536ea307c0

11 years agoMerge "Fixed the MSVC compiling error with correct cast" into experimental
Yaowu Xu [Tue, 23 Oct 2012 21:31:38 +0000 (14:31 -0700)]
Merge "Fixed the MSVC compiling error with correct cast" into experimental

11 years agoFixed the MSVC compiling error with correct cast
Scott LaVarnway [Tue, 23 Oct 2012 20:35:13 +0000 (13:35 -0700)]
Fixed the MSVC compiling error with correct cast

Change-Id: Ia904f4ec72500d29f1361ce305d8f3231e592f47

11 years agoMerge "Change eob[] array type in splitmv RD loop to a regular integer." into experim...
pascal massimino [Tue, 23 Oct 2012 21:00:01 +0000 (14:00 -0700)]
Merge "Change eob[] array type in splitmv RD loop to a regular integer." into experimental

11 years agoRevert "make the instrinsic code build with MS compilers"
Yaowu Xu [Tue, 23 Oct 2012 20:00:23 +0000 (13:00 -0700)]
Revert "make the instrinsic code build with MS compilers"

This reverts commit b0e3ca126189123ddec27ebba6aa62290e64adb6.

Change-Id: I9c5aa463461b187160ad01fbc1795ae4f5263b2c

11 years agoMerge "changed to avoid code confusion" into experimental
Yaowu Xu [Tue, 23 Oct 2012 18:54:25 +0000 (11:54 -0700)]
Merge "changed to avoid code confusion" into experimental

11 years agoMerge "make the instrinsic code build with MS compilers" into experimental
Yaowu Xu [Tue, 23 Oct 2012 18:54:07 +0000 (11:54 -0700)]
Merge "make the instrinsic code build with MS compilers" into experimental

11 years agomake the instrinsic code build with MS compilers
Scott LaVarnway [Tue, 23 Oct 2012 16:39:22 +0000 (09:39 -0700)]
make the instrinsic code build with MS compilers

to enable build under windows/MSVC

Change-Id: Ida41cc5b3c8d0fec9512c2f5c5feb64e07b44805

11 years agoChange eob[] array type in splitmv RD loop to a regular integer.
Ronald S. Bultje [Tue, 23 Oct 2012 16:23:23 +0000 (09:23 -0700)]
Change eob[] array type in splitmv RD loop to a regular integer.

Change-Id: I240d6b50069fd3f35cc4fed2f4507796f0ef25e9

11 years agoMerging in the Switchable interp experiment
Deb Mukherjee [Mon, 22 Oct 2012 21:43:01 +0000 (14:43 -0700)]
Merging in the Switchable interp experiment

There is a macro DEFAULT_INTERP_FILTER defined in encoder/onyx_if.c that
is set as EIGHTTAP for now - so SWITCHABLE is not really used. Ideally,
this should be SWITCHABLE but that would make the encoder quite a bit slower.
We will change the default filter to SWITCHABLE once we find a faster way to
search for switchable filters.

Change-Id: Iee91832cdc07e6e14108d9b543130fdd12fc9874

11 years agoMerge "Change entropy context assignment style from *(x + y) = z to x[y] = z." into...
Ronald S. Bultje [Tue, 23 Oct 2012 05:04:28 +0000 (22:04 -0700)]
Merge "Change entropy context assignment style from *(x + y) = z to x[y] = z." into experimental

11 years agoMerging in the TX_SELECT experiment
Deb Mukherjee [Mon, 22 Oct 2012 23:52:28 +0000 (16:52 -0700)]
Merging in the TX_SELECT experiment

Change-Id: I0d306b0062be59bc785b65882691c956c8b5e7c8

11 years agoMerge of the newmventropy experiment
Deb Mukherjee [Mon, 22 Oct 2012 19:19:00 +0000 (12:19 -0700)]
Merge of the newmventropy experiment

Removes the old mv encoding code.

Change-Id: I1026d48cc5ac15ccb776f98463e929254c3dc7da

11 years agoChange entropy context assignment style from *(x + y) = z to x[y] = z.
Ronald S. Bultje [Mon, 22 Oct 2012 21:06:52 +0000 (14:06 -0700)]
Change entropy context assignment style from *(x + y) = z to x[y] = z.

Change-Id: Ibc4425bb6e01606751021e57c93106c365a2da21

11 years agochanged to avoid code confusion
Yaowu Xu [Mon, 22 Oct 2012 20:58:26 +0000 (13:58 -0700)]
changed to avoid code confusion

The previous double if and else code snippets were rather confusing.

Change-Id: Id1b6152fa0e471beb9b20407aa406e109c1471e3

11 years agoMerge "Added rtcd support vp8_sad16x3 and vp8_sad3x16" into experimental
Scott LaVarnway [Mon, 22 Oct 2012 20:57:03 +0000 (13:57 -0700)]
Merge "Added rtcd support vp8_sad16x3 and vp8_sad3x16" into experimental

11 years agoAdded rtcd support vp8_sad16x3 and vp8_sad3x16
Scott LaVarnway [Mon, 22 Oct 2012 20:45:42 +0000 (13:45 -0700)]
Added rtcd support vp8_sad16x3 and vp8_sad3x16

Change-Id: I5bca7b7a4b230082d36ac6fb84db84137ad177d7

11 years agoMerge changes I02e7f64a,Ide954b00,Idc8b5977 into experimental
Ronald S. Bultje [Mon, 22 Oct 2012 19:54:39 +0000 (12:54 -0700)]
Merge changes I02e7f64a,Ide954b00,Idc8b5977 into experimental

* changes:
  Fix another typo in 4x4-transform-for-i8x8-intra-pred coeff contexts.
  8x8 transform support in splitmv.
  Use SPLITMV_PARTITIONING instead of a plain integer type.

11 years agoMerge "Merging the hybrid transform experiments" into experimental
Deb Mukherjee [Mon, 22 Oct 2012 19:18:46 +0000 (12:18 -0700)]
Merge "Merging the hybrid transform experiments" into experimental

11 years agoMerging the hybrid transform experiments
Deb Mukherjee [Mon, 22 Oct 2012 18:55:29 +0000 (11:55 -0700)]
Merging the hybrid transform experiments

Change-Id: I99f1982b30a630a9a070a8326d83b34a33cba14c

11 years agoFix another typo in 4x4-transform-for-i8x8-intra-pred coeff contexts.
Ronald S. Bultje [Mon, 22 Oct 2012 18:55:06 +0000 (11:55 -0700)]
Fix another typo in 4x4-transform-for-i8x8-intra-pred coeff contexts.

Change-Id: I02e7f64a7c99f6c222b9ef21341b0e801d646810

11 years ago8x8 transform support in splitmv.
Ronald S. Bultje [Mon, 22 Oct 2012 18:49:00 +0000 (11:49 -0700)]
8x8 transform support in splitmv.

For splitmv, where partitioning is 8x16, 16x8 or 8x8, this patch
uses the 8x8 transform (instead of the 4x4) if txfm_mode is
ALLOW_8X8 or ALLOW_16X16. For TX_MODE_SELECT, splitmv can indicate
which of the 2 transform sizes (4x4 or 8x8) it wants to use.

Gains (with hybridtx4x4/8x8/16x16 and tx_select experiments
enabled) on derf: +0.9%, HD: +0.4%, STD/HD: +0.8% (SSIM or overall
PSNR, both metrics show similar improvements).

Change-Id: Ide954b000b415548ed92a7ac78e24f36e60fcf06

11 years agoMerge "Re-enable specialized sse2 block loop filter functions" into experimental
Scott LaVarnway [Mon, 22 Oct 2012 18:39:08 +0000 (11:39 -0700)]
Merge "Re-enable specialized sse2 block loop filter functions" into experimental

11 years agoMerge "sse2 intrinsic version of vp8_mbloop_filter_vertical_edge()" into experimental
Scott LaVarnway [Mon, 22 Oct 2012 18:38:37 +0000 (11:38 -0700)]
Merge "sse2 intrinsic version of vp8_mbloop_filter_vertical_edge()" into experimental

11 years agoMerge "sse2 intrinsic version of vp8_mbloop_filter_horizontal_edge()" into experimental
Scott LaVarnway [Mon, 22 Oct 2012 18:38:21 +0000 (11:38 -0700)]
Merge "sse2 intrinsic version of vp8_mbloop_filter_horizontal_edge()" into experimental

11 years agoUse SPLITMV_PARTITIONING instead of a plain integer type.
Ronald S. Bultje [Mon, 22 Oct 2012 18:25:48 +0000 (11:25 -0700)]
Use SPLITMV_PARTITIONING instead of a plain integer type.

This can be used to distinguish between 16x8, 8x16, 8x8 and 4x4
partitioning modes when choosing splitmv as a MB mode.

Change-Id: Idc8b59772e1a80ccc4ad44d63c5c2ec3fc061a3c

11 years agoMerge "Invert SB probability." into experimental
Ronald S. Bultje [Mon, 22 Oct 2012 18:18:01 +0000 (11:18 -0700)]
Merge "Invert SB probability." into experimental

11 years agoMerge "Remove variance vtable from rtcd" into experimental
Jim Bankoski [Mon, 22 Oct 2012 18:12:07 +0000 (11:12 -0700)]
Merge "Remove variance vtable from rtcd" into experimental

11 years agoInvert SB probability.
Ronald S. Bultje [Mon, 22 Oct 2012 18:05:56 +0000 (11:05 -0700)]
Invert SB probability.

It currently counts the probability that the branch is true, but it
should count the probability that the branch is false.

Change-Id: I963825da2e7a7ed3a613eb23ffd085e427dc36e5

11 years agoMerge "Fix use of wrong context in i8x8 coefficient cost calculation." into experimental
Ronald S. Bultje [Mon, 22 Oct 2012 18:03:25 +0000 (11:03 -0700)]
Merge "Fix use of wrong context in i8x8 coefficient cost calculation." into experimental

11 years agoRemove variance vtable from rtcd
Jim Bankoski [Mon, 22 Oct 2012 03:47:57 +0000 (20:47 -0700)]
Remove variance vtable from rtcd

Change-Id: Idd2722a538423b451e1e3495f89a7141480493d6

11 years agoMerge "Allow B_VL_PRED & B_LD_PRED modes with Superblocks" into experimental
Deb Mukherjee [Sun, 21 Oct 2012 22:35:24 +0000 (15:35 -0700)]
Merge "Allow B_VL_PRED & B_LD_PRED modes with Superblocks" into experimental

11 years agoAllow B_VL_PRED & B_LD_PRED modes with Superblocks
Deb Mukherjee [Fri, 19 Oct 2012 22:12:12 +0000 (15:12 -0700)]
Allow B_VL_PRED & B_LD_PRED modes with Superblocks

Allows B_VL_PRED & B_LD_PRED modes to be used for all blocks
within a MB in B_PRED mode. These modes were temporarily
disabled with super-block coding.

Change-Id: I973b9bdb82c3da5f12d7cc963162a28805f25303

11 years agoFix use of wrong context in i8x8 coefficient cost calculation.
Ronald S. Bultje [Sat, 20 Oct 2012 05:05:50 +0000 (22:05 -0700)]
Fix use of wrong context in i8x8 coefficient cost calculation.

Change-Id: Ica58d0c7d8addb5ddd5d6e1fdea8f0f96e110862

11 years agoRe-enable specialized sse2 block loop filter functions
Scott LaVarnway [Fri, 19 Oct 2012 23:02:50 +0000 (16:02 -0700)]
Re-enable specialized sse2 block loop filter functions

vp8_loop_filter_bh and vp8_loop_filter_bv

Change-Id: I0a77d38c701a6cce96cb8371c7f3ab7e2e7f878c

11 years agosse2 intrinsic version of vp8_mbloop_filter_vertical_edge()
Scott LaVarnway [Fri, 19 Oct 2012 22:52:12 +0000 (15:52 -0700)]
sse2 intrinsic version of vp8_mbloop_filter_vertical_edge()

First sse2 version of vp8_mbloop_filter_vertical_edge().  For now,
intrinsics are being used until the bitstream is finalized.  This function
will be revisited later for further performance improvements.

For the test clip used, a 34+% decoder performance improvement
was seen.  This will vary depending on material.

Change-Id: I455b438bc8d8af76cf7533ac42eda5f689b21f7c

11 years agocalculate probs consistently
John Koleszar [Thu, 18 Oct 2012 23:27:30 +0000 (16:27 -0700)]
calculate probs consistently

There were several different methods for calculating bitstream
probabilities in use. Consolodate these into a pair of functions,
get_prob() and get_binary_prob().

Change-Id: I5534f517f74027fee16d89c9baefaafea8156b2f

11 years agolint-hunks: better support for working tree
John Koleszar [Thu, 18 Oct 2012 21:34:53 +0000 (14:34 -0700)]
lint-hunks: better support for working tree

When run with no arguments, report warnings in the diff between the
working tree and HEAD. With arguments, report warnings in the diff
between the named commit and its parents.

Change-Id: Ie10dcdecb303edf8af51bad645cc11206a1fc26b

11 years agoRemove bc, bc2 from pbi,cpi,xd
John Koleszar [Wed, 17 Oct 2012 23:47:38 +0000 (16:47 -0700)]
Remove bc, bc2 from pbi,cpi,xd

Pass the bool coder to be used explicitly. This avoids cases where two
different bool coders can be addressed from the same function. Also be
more consistent with bool coder variable naming, start to standardize
on 'bc'.

Change-Id: I1c95e2fdbe24ebe8c0f84924daa1728e3b054a31

11 years agoSome cleanups and fixes.
Deb Mukherjee [Mon, 15 Oct 2012 23:41:41 +0000 (16:41 -0700)]
Some cleanups and fixes.

Separates the logic on transform type selection previously spread out
over a number of files into a separate function. Currently the tx_type
field in b_mode_info is not used, but still left in there to eventually
use for signaling the transform type in the bitstream.

Also, now for tx_type = DCT_DCT, the regular integer DCT is used, as
opposed to the floating point DCT used in conjuction with hybrid
transform.

Results change somewhat due to the transform change, but are within
reasonable limits. The hd/std-hd sets are slightly up, while derf/yt
are slightly down.

Change-Id: I5776840c2239ca2da31ca6cfd7fd1148dc5f9e0f

11 years agoMerge "Fix encode breakout skip handling." into experimental
Ronald S. Bultje [Thu, 18 Oct 2012 22:21:30 +0000 (15:21 -0700)]
Merge "Fix encode breakout skip handling." into experimental

11 years agoMerge "Detect skippable blocks in splitmv RD loop case." into experimental
Ronald S. Bultje [Thu, 18 Oct 2012 22:21:14 +0000 (15:21 -0700)]
Merge "Detect skippable blocks in splitmv RD loop case." into experimental

11 years agosse2 intrinsic version of vp8_mbloop_filter_horizontal_edge()
Scott LaVarnway [Thu, 18 Oct 2012 21:29:26 +0000 (14:29 -0700)]
sse2 intrinsic version of vp8_mbloop_filter_horizontal_edge()

First sse2 version of vp8_mbloop_filter_horizontal_edge().  For now,
intrinsics are being used until the bitstream is finalized.  This function
will be revisited later for further performance improvements.
For the test clip used, a 31+% decoder performance improvement
was seen.  This will vary depending on material.

Change-Id: I03ed3a7182478bdd1f094644ff3e0442625600e7

11 years agoMerge "Use correct context for optimize_b() in vp8_optimize_mby_8x8()." into experimental
Ronald S. Bultje [Thu, 18 Oct 2012 19:39:10 +0000 (12:39 -0700)]
Merge "Use correct context for optimize_b() in vp8_optimize_mby_8x8()." into experimental

11 years agoA fix for crashes when #macroblock rows is odd.
Deb Mukherjee [Thu, 18 Oct 2012 19:00:23 +0000 (12:00 -0700)]
A fix for crashes when #macroblock rows is odd.

Change-Id: If9fc2df4051ccfb8d804dae9d1be08d12d0f81ce

11 years agolint-hunks: exit status for only affected lines
John Koleszar [Thu, 18 Oct 2012 04:43:18 +0000 (21:43 -0700)]
lint-hunks: exit status for only affected lines

Prior to this patch, if there were any lint errors, this script would
exit with an error, even if those errors were not in the hunks being
tested by this script. This change makes it so that if any lint lines
are printed, an error is returned.

Change-Id: I69c8bef4367ccf25d287508f29e587b1f4426143

11 years agoFix encode breakout skip handling.
Ronald S. Bultje [Thu, 18 Oct 2012 01:00:56 +0000 (18:00 -0700)]
Fix encode breakout skip handling.

Change-Id: Ib42a5dbded27abf2a01fd656a47a1e96b1fe2912

11 years agoMerge "lint-hunks: support operating on arbirary revs" into experimental
John Koleszar [Wed, 17 Oct 2012 23:44:46 +0000 (16:44 -0700)]
Merge "lint-hunks: support operating on arbirary revs" into experimental

11 years agoDetect skippable blocks in splitmv RD loop case.
Ronald S. Bultje [Wed, 17 Oct 2012 21:32:17 +0000 (14:32 -0700)]
Detect skippable blocks in splitmv RD loop case.

Change-Id: Id8a7265dc721e5cdcaa144e0041beeb32a98f51c

11 years agoMerge "cosmetic: fix '= & ' construct" into experimental
pascal massimino [Wed, 17 Oct 2012 22:17:21 +0000 (15:17 -0700)]
Merge "cosmetic: fix '= & ' construct" into experimental

11 years agoMerge "rtcd: merge rtcd.c from master" into experimental
John Koleszar [Wed, 17 Oct 2012 22:16:20 +0000 (15:16 -0700)]
Merge "rtcd: merge rtcd.c from master" into experimental

11 years agoMerge "consolidate update_mb_segmentation_map data" into experimental
John Koleszar [Wed, 17 Oct 2012 22:15:59 +0000 (15:15 -0700)]
Merge "consolidate update_mb_segmentation_map data" into experimental

11 years agoMerge changes Ic711a378,I43a46c36,If19ee74a into experimental
John Koleszar [Wed, 17 Oct 2012 22:15:10 +0000 (15:15 -0700)]
Merge changes Ic711a378,I43a46c36,If19ee74a into experimental

* changes:
  Move remaining per-frame data into partition 0
  Interleave modes/residual per macroblock
  Force interleaved decoding

11 years agocosmetic: fix '= & ' construct
John Koleszar [Wed, 17 Oct 2012 21:51:27 +0000 (14:51 -0700)]
cosmetic: fix '= & ' construct

remove useless space after address-of operator.

Change-Id: I1fb9e82e8d6cf87558fbd454fb5c0f87599ca2ab

11 years agoMove remaining per-frame data into partition 0
John Koleszar [Wed, 17 Oct 2012 16:38:13 +0000 (09:38 -0700)]
Move remaining per-frame data into partition 0

This commit moves a bit of data that ended up packed with the
modes/mv/residual partition during the change to interleaved encoding
into partition 0 where it belongs.

Change-Id: Ic711a378c58d9d6a17254384f492c213a15bad92

11 years agolint-hunks: support operating on arbirary revs
John Koleszar [Wed, 17 Oct 2012 21:23:08 +0000 (14:23 -0700)]
lint-hunks: support operating on arbirary revs

Rather than diffing only the index, support checking arbitrary commits.

Change-Id: Ia135a487990d8293d1e0799dc062b9f49e020b25

11 years agoUse correct context for optimize_b() in vp8_optimize_mby_8x8().
Ronald S. Bultje [Wed, 17 Oct 2012 20:14:56 +0000 (13:14 -0700)]
Use correct context for optimize_b() in vp8_optimize_mby_8x8().

Change-Id: Ic975ab85a9924adc7b3d421f64155cc79f40ffd0

11 years agoInterleave modes/residual per macroblock
John Koleszar [Tue, 16 Oct 2012 20:52:39 +0000 (13:52 -0700)]
Interleave modes/residual per macroblock

Packs the bitstream with each mb's residual following its mode/mv
information.

TODO: There are still a few fields that should be packed into partition
0 but are included in partition 1, due to them being serialized from
write_kfmodes/pack_inter_mode_mvs, which execute after the first
partition is finalized. These need to be separated out into a separate
function, similar to mb_mode_mv_init() in decodemv.c.

Change-Id: I43a46c363601ab36954d07ebe498760e1e2e3af4

11 years agoUse 8x8 block bases for non-4x4 splitmv RD.
Ronald S. Bultje [Wed, 17 Oct 2012 18:40:00 +0000 (11:40 -0700)]
Use 8x8 block bases for non-4x4 splitmv RD.

Change-Id: I76095d5a02edcc5d404ea830157780b24fd509d7

11 years agoMerge "Removed the loopfilter rtcd invoke macro code" into experimental
Scott LaVarnway [Wed, 17 Oct 2012 16:57:23 +0000 (09:57 -0700)]
Merge "Removed the loopfilter rtcd invoke macro code" into experimental

11 years agoremoved obselete build dependency
Jim Bankoski [Wed, 17 Oct 2012 16:18:54 +0000 (09:18 -0700)]
removed obselete build dependency

this commit fixes the build on windows with visual studio 2008.

Change-Id: I0baa4044e9e54237da29f2e17332ea6f766dbbec

11 years agoRemoved the loopfilter rtcd invoke macro code
Scott LaVarnway [Tue, 16 Oct 2012 23:19:35 +0000 (16:19 -0700)]
Removed the loopfilter rtcd invoke macro code

Change-Id: I446b2ffcbe732ffb112dbd97a4799272d4c01a84

11 years agoForce interleaved decoding
John Koleszar [Tue, 16 Oct 2012 21:08:40 +0000 (14:08 -0700)]
Force interleaved decoding

Rather than decoding all modes/mvs separately, decode them per MB. This
forces the mode which was already used form the CONFIG_NEWBESTREFMV and
CONFIG_SUPERBLOCKS experiments, and is a precursor to changing to
interleaved encoding.

Change-Id: If19ee74ac8a987846d1cd0cf2b2e02a82f1a43ad

11 years agoMerge "removed the recon rtcd invoke macro code (unrevert)" into experimental
Jim Bankoski [Tue, 16 Oct 2012 20:49:22 +0000 (13:49 -0700)]
Merge "removed the recon rtcd invoke macro code (unrevert)" into experimental

11 years agoFix a mismatch if a keyframe contains skip-blocks.
Ronald S. Bultje [Tue, 16 Oct 2012 19:41:56 +0000 (12:41 -0700)]
Fix a mismatch if a keyframe contains skip-blocks.

Change-Id: I0681d3183f51627be8c2bb76f343b7270f9116d8

11 years agoremoved the recon rtcd invoke macro code (unrevert)
Jim Bankoski [Sun, 14 Oct 2012 01:49:44 +0000 (18:49 -0700)]
removed the recon rtcd invoke macro code (unrevert)

This reinstates reverted commit 2113a831575d81faeadd9966e256d58b6b2b1633

Change-Id: I9a9af13497d1e58d4f467e3e083fddf06b1b786c

11 years agoMerge "Remove test from B_MODE_INFO." into experimental
Ronald S. Bultje [Tue, 16 Oct 2012 02:50:20 +0000 (19:50 -0700)]
Merge "Remove test from B_MODE_INFO." into experimental

11 years agoMerge "Remove mode_rdopt from MB_MODE_INFO." into experimental
Ronald S. Bultje [Tue, 16 Oct 2012 02:50:06 +0000 (19:50 -0700)]
Merge "Remove mode_rdopt from MB_MODE_INFO." into experimental

11 years agoMerge "Properly use chroma block object for chroma coefficient costing." into experim...
Ronald S. Bultje [Tue, 16 Oct 2012 02:49:37 +0000 (19:49 -0700)]
Merge "Properly use chroma block object for chroma coefficient costing." into experimental

11 years agoMerge "Changed to use real pixels only for evaluating MVs" into experimental
Yaowu Xu [Mon, 15 Oct 2012 22:02:36 +0000 (15:02 -0700)]
Merge "Changed to use real pixels only for evaluating MVs" into experimental

11 years agoChanged to use real pixels only for evaluating MVs
Yaowu Xu [Mon, 15 Oct 2012 21:30:15 +0000 (14:30 -0700)]
Changed to use real pixels only for evaluating MVs

The commit changed to avoid using pixels from extended border in
in evaluating and select best reference motion vector.

Change-Id: I39b758889373e42ed2889d59744388e5b9c1a20a

11 years agoRemove test from B_MODE_INFO.
Ronald S. Bultje [Mon, 15 Oct 2012 20:54:05 +0000 (13:54 -0700)]
Remove test from B_MODE_INFO.

It is essentially a duplicate of mode for RD-only purposes. Removing it
saves us 4 bytes per B_MODE_INFO, or ~0.5MB for a 1080p video encode.

Change-Id: I0a54db5f51658b3946d7efb1ca6e8cfbda0cdf88

11 years agoRemove mode_rdopt from MB_MODE_INFO.
Ronald S. Bultje [Mon, 15 Oct 2012 20:49:45 +0000 (13:49 -0700)]
Remove mode_rdopt from MB_MODE_INFO.

The variable is essentially a duplicate of mode for RD-only purposes.
Removing it gives identical results, and saves 4 bytes per macroblock
(i.e. 32.5kB for a 1080p HD video encode).

Change-Id: I22d5058fdb80ab0b69862caee825e9d86bb148b3

11 years agoProperly use chroma block object for chroma coefficient costing.
Ronald S. Bultje [Mon, 15 Oct 2012 20:36:00 +0000 (13:36 -0700)]
Properly use chroma block object for chroma coefficient costing.

Change-Id: Ieb38c7aae91dbaca4a8add204fa84e1cfc459933

11 years agoAdd a new token stuffing function vp8_stuff_mb().
Ronald S. Bultje [Mon, 15 Oct 2012 17:52:13 +0000 (10:52 -0700)]
Add a new token stuffing function vp8_stuff_mb().

This way a caller doesn't need to implement the logic for which (and how
many) tokens to write out to stuff one macroblock worth of EOBs. Make
the actual function implementations static, since they are now only used
in tokenize.c; also do some minor stylistic changes so it follows the
style guide a little more closely; use PLANE_TYPE where appropriate,
remove old (stale) frame_type function arguments; hardcode plane type
where only a single one is possible (2nd order DC or U/V EOB stuffing);
support stuffing 8x8/4x4 transform EOBs with no 2nd order DC.

Change-Id: Ia448e251d19a4e3182eddeb9edd034bd7dc16fa3

11 years agoAdd and consistently use PLANE_TYPE.
Ronald S. Bultje [Sun, 14 Oct 2012 22:29:56 +0000 (15:29 -0700)]
Add and consistently use PLANE_TYPE.

Change the macros PLANE_TYPE_{Y_NO_DC,Y2,UV,Y_WITH_DC} to a typed enum,
and use this typed enum consistently across all places where relevant.
In places where the type is implied (e.g. in functions that only handle
second order planes or chroma planes), remove it as a function argument
and instead hardcode the proper enum in the code directly.

Change-Id: I93652b4a36aa43163d49c732b0bf5c4442738c47

11 years agoMerge duplicate loops in tokenization code.
Ronald S. Bultje [Sat, 13 Oct 2012 18:46:21 +0000 (11:46 -0700)]
Merge duplicate loops in tokenization code.

Also merge the three occurrences of 4x4 chroma block writing into a
single function, and call that function instead of duplicating the
4x4 chroma tokenization code in 3 places.

Change-Id: I7913538d1029f709b0e3ae49fff1148d3be9eeb9

11 years agoMinor refactoring in encodeintra.c.
Ronald S. Bultje [Sat, 13 Oct 2012 16:27:54 +0000 (09:27 -0700)]
Minor refactoring in encodeintra.c.

Merge code blocks for different transform sizes; use MACROBLOCKD as a
temp variable where that leads to smaller overall source code; remove
duplicate code under #if CONFIG_HYBRIDTRANSFORM/#else blocks. Some style
changes to make it follow the style guide a little better.

Change-Id: I1870a06dae298243db46e14c6729c96c66196525

11 years agoMake optimize_mb_16x16() static.
Ronald S. Bultje [Sat, 13 Oct 2012 15:31:02 +0000 (08:31 -0700)]
Make optimize_mb_16x16() static.

It is not used outside this file.

Change-Id: Id0947180edab4c5f1f50589863350b21e97c25f1

11 years agoRemove assignment in vp8_optimize_mby_16x16().
Ronald S. Bultje [Sat, 13 Oct 2012 15:29:59 +0000 (08:29 -0700)]
Remove assignment in vp8_optimize_mby_16x16().

The result of the assignment is unused.

Change-Id: Id94b790baa6451f24e9aeda6f036390388d93921

11 years agoRemove duplicate code in optimize_mb_NxN vs. vp8_optimize_mby/uv_NxN().
Ronald S. Bultje [Sat, 13 Oct 2012 15:26:05 +0000 (08:26 -0700)]
Remove duplicate code in optimize_mb_NxN vs. vp8_optimize_mby/uv_NxN().

Instead, just call vp8_optimize_mby/uv_NxN() inside optimize_mb_NxN().

Change-Id: Ief941064d86db4277ba02e990a26819144b55f7c

11 years agoRemove duplicate or unused code in encoder/encodemb.c.
Ronald S. Bultje [Sat, 13 Oct 2012 15:15:51 +0000 (08:15 -0700)]
Remove duplicate or unused code in encoder/encodemb.c.

Also make some minor stylistic changes to bring the code closer to
the style guide. Remove distinction between inter and intra transform
functions, since both do exactly the same thing except for the check
against SPLITMV for the second-order transform. Remove some commented
out debug code. Remove 8x8/16x16 transform code in encode_inter16x16y(),
since the first-pass only uses 4x4 anyway.

Change-Id: Ife54816ff759825b9141f95dc2ba43c253c14dba

11 years agoRemove duplicate or unused code in encoder/quantize.c.
Ronald S. Bultje [Sat, 13 Oct 2012 05:42:06 +0000 (22:42 -0700)]
Remove duplicate or unused code in encoder/quantize.c.

Also make some minor stylistic changes to bring the code closer to
the style guide. Remove checks against i8x8/bpred in the mb-codepath,
since these do individual block reconstruction and thus don't go through
this codepath.

Change-Id: I4dfcf8f78746f4647a206475acf731837aa4fd47

11 years agoRemove duplicate or unused code in common/invtrans.c.
Ronald S. Bultje [Sat, 13 Oct 2012 04:59:50 +0000 (21:59 -0700)]
Remove duplicate or unused code in common/invtrans.c.

Also make some minor stylistic changes to bring the code closer to
the style guide.

Change-Id: Idafa280724f49868ed6b7d65b7fd9227d781994b

11 years agoAdd a _4x4 sufix to all 4x4-transform-related functions.
Ronald S. Bultje [Sat, 13 Oct 2012 04:41:58 +0000 (21:41 -0700)]
Add a _4x4 sufix to all 4x4-transform-related functions.

This includes trellis optimization, forward/inverse transform,
quantization, tokenization and stuffing functions.

Change-Id: Ibd34132e1bf0cd667671a57b3f25b3d361b9bf8a

11 years agoReplace vp8_inverse_htransform_b() by direct call to vp8_ihtllm_c().
Ronald S. Bultje [Sat, 13 Oct 2012 04:08:03 +0000 (21:08 -0700)]
Replace vp8_inverse_htransform_b() by direct call to vp8_ihtllm_c().

Change-Id: I55ee7566341b04d7e7340fdab95189f82231a792