According to the following papers – HEVC is better than VP9 in coding efficiency:
- “Coding Efficiency Comparison of AV1/VP9, H.265/MPEG-HEVC,and H.264/MPEG-AVC Encoders“, by Detlev Marpe et al, HHI
- “PERFORMANCE EVALUATION OF H.265/MPEG-HEVC, VP9 AND H.264/MPEGAVC VIDEO CODING“, by Ahmad A. Mazhar, 2016
- “Contemporary Video Compression Standards H.265/HEVC, VP9, VP10, Daala“, by M.P. Sharabayko et al., 2016 . Tomsk University
- “Comparison of compression efficiency between HEVC/H.265 and VP9 based on subjective assessments“, Martin Rerabek and Touradj Ebrahimi.
- White paper Choosing the Right Codec: Comparing HEVC & VP9
It’s always unclear what the authors of the above papers actually compare – video compression standards or specific codecs on specific platforms (e.g. x265 vs. vpx).
In my opinion to compare video compression standards one need analyze features list and estimates how each feature would impact on bitrate/coding efficiency and encoding time.
Let’s take for example the following feature – the number of intra prediction modes. In HEVC there are 35 intra modes while in VP9 only 10 intra modes are available. Hence, HEVC tends to exploit better spatial redundancy and consequently bitrate/coding efficiency is improved. On the other hand, the encoding time of HEVC is reduced since the search of best mode among 35 intra modes would take more cycles than that among 10 intra modes of VP9.
In comparison of HEVC vs. VP9 we can assign a pair (impact on coding efficiency, impact on complexity) to each feature. For instance for intra modes feature the pair is ( + , – ) meaning coding efficiency of HEVC improved against VP9, but the complexity of VP9 is reduced against HEVC.
At the end we can sum up pluses and minuses and derive a conclusion, e.g. HEVC is expected to provides better coding efficiency against VP9 while VP9 is expected to reduce encoding time against HEVC.
HEVC Error Resilience is better than that of VP9
i see three flaws in VP9 which deteriorate error resilience: lack of start-codes, lack of slices and non-adaptivity of probabilities within a frame.
When arithmetic coding is used the error-detection lag is expected to be long (the error detection lag is a distance in MBs/CTUs/Superblocks between a place where a bitstream error occurs and the place where it’s detected). For example, a bit-flip can occur at the start of a frame but detected at the end of this frame, as a result the error-detection lag is the whole frame. If the error is detected at the middle of the frame then the second half of the frame can be filled by co-located MBs/CUTs/Superblocks (error concealment).
In the figure below error-detection latency is 2 MBs (usually the latency is much higher):
In HEVC/AVC (as well as in H264/AVC)), a bitstream error is necessarily detected either at the end of a frame when the next start code is sensed but not all blocks have been decoded or when the number of CTUs/MBs exceeding the expected amount (according to resolution), i.e. there are non-decoded blocks but the start-code already have been sensed.
In VP9 (due to lack of start codes) a bitstream error can be detected at the middle of the next frame or at the middle of next-next-frame and in such case two or more frames are corrupted (it’s worth mentioning that in HEVC in worst case a single frame is corrupted). It’s useful to provide a sort of CRC at the start of each frame to detect bit flips.
Division into slices is extremely useful to enhance the error resilience, since corruption area is limited to the corrupted slice area (notice that a bitstream error is inevitable detected prior to start-code of the next slice). Consequently in worst case a single slice is corrupted and not the whole frame.
VP9 has a special error-resilience mode, in this mode each frame is coded with a default set of fixed probabilities (or context models in HEVC/AVC’s jargon), VP9 encoder can’t utilize probabilities from the previous frame, otherwise if the previous frame gets corrupted then the current frame is also corrupted. Consequently all frames in error-resilience VP9 mode are coded with fixed probabilities. There is a problem with fixed context models (or probabilities), if the actual context models are close to the fixed ones then arithmetic coding is effective. If no then tons of penalty bits are produced (the penalty can be assessed via Kullback–Leibler divergence). Consequently, VP9 entropy coding is non-effective due to lack of adaptivity.
In HEVC/AVC, even if start probabilities strongly differ from the actual ones, CABAC quickly adapt itself to the actual and coding gets optimal.
Feature Analysis/Comparison – Advantages of HEVC against VP9:
1) VP9 does not support slices while HEVC (and other standards like AVC/H.264) does support. Therefore MTU-matching, ultra low-delay modes, parallelization and error resilience in VP9 is challenging.
2) Tiles in VP9 are not self-contained since prediction is not broken across vertical boundaries while it’s broken across horizontal boundaries (actually a rows of tiles is self-contained but tiles in the row are not independent). In HEVC each tile is self-contained since the prediction is completely broken across all tile boundaries (excepting deblocking but the deblocking filter can be optionally switched off across tile boundaries). Consequently the parallization in HEVC can be exploited better than in VP9.
3) In VP9 tiles are uniformly divided (tiling grid is uniform) while in HEVC the tile grid can be divided in a custom manner. Hence HEVC encoder can adapt the tiling grid such that workload balancing is exploited better (most of scenes consist of complex and easy areas)
4) Number of intra prediction modes is 10 while in HEVC the amount of intra prediction is 35.
5) In HEVC an adaptive smoothing filter is applied on neighboring samples of an intra-prediction block (excepting 4×4 blocks). The intention of this filtering is to avoid steps in the values of reference samples that could potentially generate unwanted directional edges in the prediction block and consequently deteriorate coding efficiency and visual perception. In VP9 no filtering on neighboring samples exist.
6) In HEVC a custom quantization matrix can be applied in quantization process, where each DCT coefficient is quantized with its own step. However, in VP9, the custom quantization is almost absent (you can specify different quantization steps for DC and AC). It is well known that the human visual system is less sensitive to distortion of high-frequency components than that of low-frequency components. This property has been utilized in almost all standards (e.g. in HEVC and in AVC) by means of the custom quantization matrix.
7) Assymetric Inter Prediction is absent in VP9
8) Weighted Prediction is absent in VP9
9) SAO is absent in VP9
10) In HEVC probabilities are updated within frame to approach to optimal probabilities. However, in VP9 the probabilities are fixed within a frame and can be changed only at frame level.This is a real flaw of VP9. Indeed, in VP9 at random access frame (key frame) a default context is chosen (otherwise this frame can’t be the random access point since its probabilities are dependent on previous frames) if the context (the probabilities) is close to the actual probabilities then the entropy coder is near-optimal. However, in most cases the default context is pretty far to the actual probabilities. In such case VP9 entropy coder is sub-optimal within the whole frame and would produce tons of penalty bits.
Feature Analysis/Comparision – Advantages of VP9 against HEVC:
Segmentation – this is a strong tool to exploit super-block header redundancy especially on scenes with still background.
Appendix: Running VP9 with ffmpeg
vp9 encoder is activated via ‘-c:v libvpx-vp9’
Running with constant-quality mode (CRF), frame rate 50, (CRF is activated with ‘-b:v 0’ and ‘-crf x’), in CRF mode instant video bitrate is unlimited and depends on complexity of the scene:
ffmpeg -r 50 -s 1920×1080 -i crowdrun1080p50fps.yuv -c:v libvpx-vp9 -b:v 0 -crf 15 -y crowd.webm
Running with constrained constant-quality mode, say you wish to deliver video with near constant quality -crf 15 but not crossing 10Mbps (-b:v 10M), quality can be worse than crf=15:
ffmpeg -r 50 -s 1920×1080 -i crowdrun1080p50fps.yuv -c:v libvpx-vp9 -b:v 10M -crf 15 -y crowd.webm
23+ years’ programming and theoretical experience in the computer science fields such as video compression, media streaming and artificial intelligence (co-author of several papers and patents).
the author is looking for new job, my resume
you have a great blog here! would you like to make some invite posts on my blog?
I know this if off topic but I’m looking into starting my own blog and was wondering what all is needed to get setup? I’m assuming having a blog like yours would cost a pretty penny? I’m not very web smart so I’m not 100 certain. Any tips or advice would be greatly appreciated. Appreciate it
Your place is valueble for me. Thanks!…
I have been absent for a while, but now I remember why I used to love this web site. Thanks , I’ll try and check back more often. How frequently you update your site?
Thank you a lot for sharing this with all folks you really know what you are talking about! Bookmarked. Please also consult with my site =). We will have a link exchange arrangement between us!
I love your blog.. very nice colors & theme. Did you create this website yourself? Plz reply back as I’m looking to create my own blog and would like to know wheere u got this from. thanks
you are welcome to connect to the site’s designer Ivan Lukin, i am responsible only for the content, he is responsible for the form:
Telephone +7 (978) 858 11 48
e-mail: vanyalukin007@gmail.com
Pretty nice post. I just stumbled upon your weblog and wished to say that I have really enjoyed surfing around your blog posts. In any case I will be subscribing to your feed and I hope you write again very soon!
Hey there just wanted to give you a quick heads up. The words in your content seem to be running off the screen in Firefox. I’m not sure if this is a formatting issue or something to do with web browser compatibility but I figured I’d post to let you know. The layout look great though! Hope you get the problem resolved soon. Cheers
I have been exploring for a little bit for any high-quality articles or blog posts on this sort of area . Exploring in Yahoo I at last stumbled upon this site. Reading this info So i’m happy to convey that I have a very good uncanny feeling I discovered exactly what I needed. I most certainly will make sure to do not forget this website and give it a glance regularly.
After all, what a great site and informative posts, I will upload inbound link – bookmark this web site? Regards, Reader.
hello!,I like your writing so much! share we communicate more about your post on AOL? I need a specialist on this area to solve my problem. Maybe that’s you! Looking forward to see you.
I am glad to be a visitor of this double dyed web site! , thankyou for this rare info ! .
It’s exhausting to find knowledgeable people on this subject, however you sound like you realize what you’re speaking about! Thanks
I’ve been surfing online more than three hours today, yet I never found any interesting article like yours. It is pretty worth enough for me. Personally, if all website owners and bloggers made good content as you did, the internet will be a lot more useful than ever before.
Hi! This post couldn’t be written any better! Reading through this post reminds me of my previous room mate! He always kept chatting about this. I will forward this page to him. Pretty sure he will have a good read. Thank you for sharing!
I am no longer positive where you’re getting your information, however great topic. I needs to spend some time studying much more or working out more. Thanks for great info I used to be searching for this info for my mission.
I like this post, enjoyed this one thankyou for posting.
I am impressed with this site, rattling I am a big fan .
I must convey my affection for your generosity supporting people that need assistance with this one area. Your special commitment to passing the message throughout was amazingly effective and have constantly made people just like me to get to their goals. Your own interesting useful information entails a whole lot a person like me and extremely more to my office workers. Thank you; from all of us.
Good info. Lucky me I reach on your website by accident, I bookmarked it.
I have been exploring for a bit for any high-quality articles or blog posts on this kind of area . Exploring in Yahoo I at last stumbled upon this web site. Reading this info So i’m happy to convey that I’ve a very good uncanny feeling I discovered just what I needed. I most certainly will make sure to do not forget this site and give it a glance on a constant basis.