Blog coding and discussion of coding about JavaScript, PHP, CGI, general web building etc.

Monday, February 15, 2016

Suggested Compression Ratio with H.264?

Suggested Compression Ratio with H.264?


Note bene: I realize this is an immensely complicated question with about a million levels of nuance that I'm trying to reduce to a single number...

I'm about to undertake a large video encoding project using H.264 encoding. We are trying to create multiple bitrate profiles in order to accommodate streaming across internet connections, processors, devices, etc.

Generally speaking, what kind of compression ratio should I be expecting to see (while staying within a reasonable level of quality)?

For example, a 640x360 (16:9) pixel video file @ 24 frames per second and 16-bit color should yield an uncompressed file that is approximately 33 MB/s.

I've been told that, for that file, 500 Kbits/second (or 62 KB/s) is not an unreasonable video bitrate. That seems insane - more than 530:1 compression? That's 99.8% compression. Is my math wrong?

I'm just looking for a rough outer guide for quality, like "more than 500x compression is crazy" or "less than 400x is a waste of bandwidth". I've looked everywhere, and nothing gives me any kind of expected compression...

Answer by Stu Thompson for Suggested Compression Ratio with H.264?


It will vary dramatically depending on the content of the source videos. I'll get to that in a bit.

640x360 is not that large. 512kbps is very reasonable and arguably standard. Maybe 768kbps if you are really interested in quality.

How is this possible? A simplified answer: There are a couple of techniques and facts about video compression that make this possible:

  1. Not every video frame data structure in an common H.264 (or other CODECs for that matter) is a full image. Instead there are two types which are colloquially referred to as
    1. Key Frames: a full rendering of the entire video image
    2. Intra-frames: a description of changes to the previous frame. These frames generally make up the vast majority (80%-99%) of frames in a video.
  2. H.264 is "lossy", as are many other CODECs. They do not reproduce a pixel-by-pixel, frame-by-frame exact duplicate of the original source video. Example: Lossy blocks: If all but one pixel in an area is the same color, the CODEC 'loses' the one pixel. So, instead of having to store information about every single pixel in a frame, the CODEC just says "x1, y1 to x2, y2 are all color x". Very efficient.

It is all wildly more complex than that, with zillions of different approaches, techniques and algorithms within specific CODECs and between CODECs to make this happen.

So, back to the "It will vary dramatically depending on the content of the source videos" comment: The compression ratio you'll see, and the resulting quality, will depend significantly upon:

  • the contents of the video
  • your tolerance for artifacts (blocks, loss of color, loss of definition)
  • the CODEC parameters you set, and how you set them

Example: A video of a door in a room (like a security camera) with one key frame every ten minutes is going to have an amazingly high compression ratio. My back-of-the-napkin calculations put that scenario at 15,000:1 compression.

Since you are starting on a large video encoding project, I would recommend a couple of things to determine what your compression ratio is going to be:

  • take a sample of the source videos you are going to encode. 100 or more being statistically relevant.
  • encode them at various bit rates, with various parameters, to determine what resulting characteristics meets your needs

Changing the parameters of the encoder to make the videos smaller can have other impacts too:

  • higher play back CPU requirements
  • player CODEC expectations. Not all H.264 encoded videos can be played back by all players
  • longer encoding times
  • various degrading of quality

It's a big complicated subject. Good luck. My experienced "thumb-to-the-wind" test says you'll be more than happy with 512-768kbps for your project.

Answer by SirDarius for Suggested Compression Ratio with H.264?


In a quite interesting document called H.264 Primer, a simple formula is given as an hint to compute the `ideal' output file bitrate, based on the video's characteristics:

[image width] x [image height] x [framerate] x [motion rank] x 0.07 = [desired bitrate]

where the image width and height is expressed in pixels, and the motion rank is an integer between 1 and 4, 1 being low motion, 2 being medium motion, and 4 being high motion (motion being the amount of image data that is changing between frames, see the linked document for more information).

So for instance, if we take a 1280x720 video at 24 FPS, with medium motion (movie with slow camera movements, not many scene changes...), the expected ideal bitrate would be:

1280 x 720 x 24 x 2 x 0.07 = 3,096,576 bps => approximatively 3000 kbps

This is purely a hint, and in my opinion, the only way to accurately find the ideal bitrate is trial by error :)

Answer by Const for Suggested Compression Ratio with H.264?


  Compression Ratio Rules of Thumb  Compression ratios to maintain excellent quality:  ? 10:1 for general images using JPEG  ? 30:1 for general video using H.263 and MPEG-2  ? 50:1 for general video using H.264 / MPEG-4 AVC  

from http://www.kanecomputing.co.uk/pdfs/compression_ratio_rules_of_thumb.pdf

Answer by laruffii for Suggested Compression Ratio with H.264?


Just sharing my knowledge over encoding with H264 environment

As for the ratio 450-512 kbits/second is best if you use H264 with High 5.0 or High 7.0. Well i can suggest you that to get a good ratio in balance with the best quality , the key that really matters to it is to play with the Resolution size. Result of Video Resoltion = 3/4 * Native's / Raw Video's Resolution

H264 tends to loose details more if you don't compress the frame into a little bit of smaller resolution.

Answer by Wilson for Suggested Compression Ratio with H.264?


Don't forget normal playback MPEG will only use YUV 4:2:0. In 8-bit color depth each pixel only worth 16-bit(or 64bit each 4 pixels). Please, only RAW file from camera will use 16-bit depth, and it must worth millions USD!!Medium high Film DVR only can provide 12-14bit!!And nobody will use H.264 to store RAW. H.264 is deigned for end product.

In 640x360/24p YUV4:2:0 the bitrate will worth:

  640x360x24x(8+4+4)/8 = 10.5MB/s  

For 500Kbps the compression will be only 172:1. It's normal

For expatiation of YUV4:2:0, read:
http://en.wikipedia.org/wiki/Chroma_subsampling


Fatal error: Call to a member function getElementsByTagName() on a non-object in D:\XAMPP INSTALLASTION\xampp\htdocs\endunpratama9i\www-stackoverflow-info-proses.php on line 72

0 comments:

Post a Comment

Popular Posts

Powered by Blogger.