John Koleszar
dc1c3f9024
Merge remote branch 'internal/upstream' into HEAD
2011-07-16 00:05:05 -04:00
Scott LaVarnway
e68894fa03
Merge "Tokenize MB optimized"
2011-07-15 07:54:14 -07:00
Tero Rintaluoma
4e82f01547
Tokenize MB optimized
...
Optimized C-code of the following functions:
- vp8_tokenize_mb
- tokenize1st_order_b
- tokenize2nd_order_b
Gives ~1-5% speed-up for RT encoding on Cortex-A8/A9
depending on encoding parameters.
Change-Id: I6be86104a589a06dcbc9ed3318e8bf264ef4176c
2011-07-15 11:26:54 +03:00
John Koleszar
f1fcd74e3e
Merge remote branch 'origin/master' into experimental
...
Change-Id: Icbeb14d64ed3d9337606b591dde4e0669540a10d
2011-07-15 00:05:06 -04:00
John Koleszar
087b338d9e
Merge remote branch 'internal/upstream' into HEAD
2011-07-15 00:05:04 -04:00
James Berry
6b6f367c3d
bug fix vpx_copy_and_extend_frame size issue
...
vpx_copy_and_extend_frame could incorrectly
resize uv frames which could result in a crash.
Change-Id: Ie96f7078b1e328b3907a06eebeee44ca39a2e898
2011-07-14 15:58:15 -04:00
John Koleszar
04dce631a2
Remove unused speed features
...
min_fs_radius, max_fs_radius, full_freq were set but never read.
Change-Id: I82657f4e7f2ba2acc3cbc3faa5ec0de5b9c6ec74
2011-07-14 14:20:25 -04:00
John Koleszar
86edcb0cc7
Merge remote branch 'origin/master' into experimental
...
Change-Id: I3f64e220b78738e5261a9fda3c270d51613f4faa
2011-07-14 00:05:12 -04:00
John Koleszar
6901105e99
Merge remote branch 'internal/upstream' into HEAD
2011-07-14 00:05:04 -04:00
Yunqing Wang
f1f28535c3
Merge "Fix unnecessary casting of B_PREDICTION_MODE (issue 349)"
2011-07-13 13:32:57 -07:00
Yunqing Wang
139577f937
Fix unnecessary casting of B_PREDICTION_MODE (issue 349)
...
Minor fix.
Change-Id: Iaf93f6e47e882a33c479e57c7a0d0bf321e291c0
2011-07-13 15:52:07 -04:00
Yunqing Wang
0e9a6ed72a
Add improvements made in good-quality mode to real-time mode
...
Several improvements we made in good-quality mode can be added
into real-time mode to speed up encoding in speed 1, 2, and 3
with small quality loss. Tests using tulip clip showed:
--rt --cpu-used=-1
(before change)
PSNR: 38.028
time: 1m33.195s
(after change)
PSNR: 38.014
time: 1m20.851s
--rt --cpu-used=-2
(before change)
PSNR: 37.773
time: 0m57.650s
(after change)
PSNR: 37.759
time: 0m54.594s
--rt --cpu-used=-3
(before change)
PSNR: 37.392
time: 0m42.865s
(after change)
PSNR: 37.375
time: 0m41.949s
Change-Id: I76ab2a38d72bc5efc91f6fe20d332c472f6510c9
2011-07-13 14:51:02 -04:00
Fritz Koenig
84c3cd79d1
Merge "Reduce motion vector search on alt-ref frame."
2011-07-13 10:07:30 -07:00
Johann
211694f67e
Merge "update x86 asm for loopfilter"
2011-07-13 04:10:03 -07:00
Johann
8f910594bd
Merge "Update armv6 loopfilter to new interface"
2011-07-13 04:09:55 -07:00
Johann
1a219c22b1
Merge "Update armv7 loopfilter to new interface"
2011-07-13 04:09:42 -07:00
Johann
d9b825cff2
Merge "New loop filter interface"
2011-07-13 04:09:26 -07:00
John Koleszar
ffc4587a47
Merge remote branch 'origin/master' into experimental
...
Change-Id: I9dab62c24d71f71cdc36732ed8ed469bee67d7e1
2011-07-13 00:05:04 -04:00
John Koleszar
791ad1bb37
Merge remote branch 'internal/upstream' into HEAD
2011-07-13 00:05:03 -04:00
Attila Nagy
c231b0175d
Update armv6 loopfilter to new interface
...
Change-Id: I5fe581d797571a7a9432fbd17fc557591d0c1afa
2011-07-12 12:14:51 +03:00
Attila Nagy
283b0e25ac
Update armv7 loopfilter to new interface
...
Change-Id: I65105a9c63832669237e6a6a7fcb4ea3ea683346
2011-07-12 12:12:25 +03:00
Fritz Koenig
ede0b15c9d
Reduce motion vector search on alt-ref frame.
...
Clamp mv search to accomodate subpixel filtering
of UV mv.
Change-Id: Iab3ed405993ef6bf779ad7cf60863153068fb7d1
2011-07-11 09:05:43 -07:00
John Koleszar
6058c9ce0c
Merge remote branch 'origin/master' into experimental
...
Change-Id: Ica63d16cb39e2d65a3414f0b9f86c8a64112dfa3
2011-07-09 00:05:09 -04:00
John Koleszar
c24479e870
Merge remote branch 'internal/upstream' into HEAD
2011-07-09 00:05:04 -04:00
Yunqing Wang
587ca06da9
Minor change in pick_inter_mode()
...
Scott suggested to move vp8_mv_pred() under "case NEWMV" to save
extra checks.
Change-Id: I09e69892f34a08dd425a4d81cfcc83674e344a20
2011-07-08 14:08:45 -04:00
Yunqing Wang
e83d36c053
Merge "Adjust full-pixel clamping and motion vector limit calculation"
2011-07-08 08:39:32 -07:00
Yunqing Wang
40991faeae
Adjust full-pixel clamping and motion vector limit calculation
...
Do mvp clamping in full-pixel precision instead of 1/8-pixel
precision to avoid error caused by right shifting operation.
Also, further fixed the motion vector limit calculation in change:
b7480454706a6b15bf091e659cd6227ab373c1a6
Change-Id: Ied88a4f7ddfb0476eb9f7afc6ceeddbf209fffd7
2011-07-08 11:34:28 -04:00
Johann
01433c5043
update x86 asm for loopfilter
...
Change-Id: I1ed739522db7c00c189851c7095c1b64ef6412ce
2011-07-08 09:23:38 -04:00
John Koleszar
ef7f489dc3
Merge remote branch 'internal/upstream-experimental' into HEAD
2011-07-08 08:57:03 -04:00
Johann
6ae12c415e
Merge "clean up warnings when building arm with rtcd"
2011-07-08 05:16:09 -07:00
Attila Nagy
622958449b
New loop filter interface
...
Separate simple filter with reduced no. of parameters.
MB filter level picking based on precalculated table. Level table updated for
each frame. Inside and edge limits precalculated and updated just when
sharpness changes. HEV threshhold is constant.
ARM targets use scalars and others vectors.
Change works only with --target=generic-gnu
All other targets have to be updated!
Change-Id: I6b73aca6b525075b20129a371699b2561bd4d51c
2011-07-08 09:31:41 +03:00
John Koleszar
2c3c54f747
Merge remote branch 'origin/master' into experimental
...
Change-Id: I9cead934ebea85d81aceaaec4674efc74367f984
2011-07-08 00:05:05 -04:00
John Koleszar
973a9c075d
Merge "Set VPX_FRAME_IS_DROPPABLE"
2011-07-07 08:11:05 -07:00
John Koleszar
37de0b8bdf
Set VPX_FRAME_IS_DROPPABLE
...
Allow the encoder to inform the application that the encoded frame will not
be used as a reference.
Change-Id: I90e41962325ef73d44da03327deb340d6f7f4860
2011-07-07 10:38:45 -04:00
John Koleszar
61d9d595d5
Merge remote branch 'origin/master' into experimental
...
Change-Id: I009c7e3043ad1eb1ce95c69132a4727073b86757
2011-07-02 00:05:12 -04:00
John Koleszar
5380a2215e
Merge remote branch 'internal/upstream' into HEAD
2011-07-02 00:05:10 -04:00
John Koleszar
b4f70084cc
Merge "Properly use GET_GOT/RESTORE_GOT when using GLOBAL()."
2011-07-01 07:14:34 -07:00
John Koleszar
54c3637828
Merge remote branch 'origin/master' into experimental
...
Change-Id: Iaf6e9e14d0cfe5cef3895cfb68524d51139a6d23
2011-07-01 00:05:12 -04:00
John Koleszar
766fce16c4
Merge remote branch 'internal/upstream' into HEAD
2011-07-01 00:05:11 -04:00
Ronald S. Bultje
c8a23ad3f4
Properly use GET_GOT/RESTORE_GOT when using GLOBAL().
...
This should fix binaries using PIC on x86-32. Also should
fix issue 343.
Change-Id: I591de3ad68c8a8bb16054bd8f987a75b4e2bad02
2011-06-30 14:04:27 -07:00
Yunqing Wang
ae8aa836d5
Merge "Copy macroblock data to a buffer before encoding it"
2011-06-30 11:14:24 -07:00
Yunqing Wang
80c3bbf657
Merge "Bug fix in motion vector limit calculation"
2011-06-30 09:52:03 -07:00
Yunqing Wang
b748045470
Bug fix in motion vector limit calculation
...
Motion vector limits are calculated using right shifts, which
could give wrong results for negative numbers. James Berry's
test on one clip showed encoder produced some artifacts. This
change fixed that.
Change-Id: I035fc02280b10455b7f6eb388f7c2e33b796b018
2011-06-30 11:20:13 -04:00
Johann
3e4a80cc35
Merge "remove incorrect initialization"
2011-06-30 07:59:08 -07:00
John Koleszar
9dfd006017
Merge remote branch 'internal/upstream-experimental' into HEAD
...
Conflicts:
vp8/encoder/bitstream.c
Change-Id: I44c00f98dcb99eb728ce4f5256aefb135a711a74
2011-06-30 08:46:49 -04:00
John Koleszar
6251e9e5ce
Merge remote branch 'origin/master' into experimental
...
Change-Id: I35c9ca116aecd0d03e762942d9cf1289edb4f23d
2011-06-30 00:05:10 -04:00
Paul Wilkins
eacaabc592
Merge "Change to arf boost calculation."
2011-06-29 10:03:57 -07:00
Paul Wilkins
11694aab66
Change to arf boost calculation.
...
In this commit I have added an experimental function
that tests prediction quality either side of a central position
to calculate a suggested boost number for an ARF frame.
The function is passed an offset from the current position and
a number of frames to search forwards and backwards.
It returns a forward, backward and compound boost number.
The new code can be deactivated using #define NEW_BOOST 0
In its current default state the code searches forwards and backwards
from the proposed position of the next alt ref.
The the old code used a boost number calculated by scanning forward
from the previous GF up to the proposed alt ref frame position.
I have also added some code to try and prevent placement of a gf/arf
where there is a brief flash.
Change-Id: I98af789a5181148659f10dd5dd2ff2d4250cd51c
2011-06-29 18:01:25 +01:00
Johann
fe53107fda
remove incorrect initialization
...
Values were set, then reset. Only set them once.
Change-Id: Iaf43c8467129f2f261f04fa9188b603aa46216b5
2011-06-29 11:54:27 -04:00
Johann
6611f66978
clean up warnings when building arm with rtcd
...
Change-Id: I3683cb87e9cb7c36fc22c1d70f0799c7c46a21df
2011-06-29 10:51:41 -04:00