MP4 File Format Part 2
ISO IEC 14496-12 defined the base media file format for MPEG file structure.
ISO IEC 14496-15 Information technology — Coding of audio-visual objects — Part 15: Advanced Video Coding (AVC) file format extends part 12 to provide specific atom/box type for AVC (H.264)
Mdat Atom
As mdat is about frame, I have to mention about AVC sample structure
ISO 14496-15 define AVC sample structure as externally framed sample and have a frame length supplied by external framing. Thus, AVC access unit means a set of NAL units where each NAL has
- a usually 4 bytes fields to denote the frame size
- followed by a NAL unit
With that in mind, the screenshot shows a the red box denote the frame size (4 bytes). The blue box is the start of the frame, in this case, it is H.264 Non-IDR frame. See 5.2.3 of that document.
AVC Decoder Configuration Record
H.264 require decoder configuration data to initialize the decoder prior to any decoding process. Thus, MP4 file must have this record in the Movie Box.
These decoder configuration record data are stored in STSD (sample decription box) - Visual Sample Entry. For H.264, this is stored in a avc1 atom.
Before going into that, I should provide some information regarding the AVC decoder configuration record. Below is the AVC decoder configuration record in a class structure.
configurationVersion - 8 bits int value that is always 1. If decoder see unrecognized version, the decoder should not decode the stream
AVCProfileIndication - 8 bits int value that contains profile code in ISO IEC 14496-10
profile_compatibility - 8 bits int value that exactly the same byte that occurs between profile_IDC and level_IDC in the SPS
AVCLevelIndication - 8 bits int value that define the level code
lengthSizeMinusOne - 2 bits int value that indicate the length in bytes of the NALUnitLength field in an AVC video sample
numOfSequenceParameterSets - 5 bits int value that indicate the number os SPSs that are used as the initial set of SPSs for decoding the AVC elementary stream
sequenceParameterSetLength - 16 bits int value that indicate the length in bytes of SPS
sequenceParameterSetNALUnit - the actual SPS. The length is defined by the preceding sequenceParameterSetLength field
numOfPictureParameterSets - 8 bits int value that indicate the number of PPS that are used as the initial set of PPSs for decoding the AVC elementary stream
pictureParameterSetLength - 16 bits int value that indicate the length in bytes of the PPS
pictureParameterSetNALUnit - the actual PPS. The length is defined by the preceding pictureParameterSetLength field
acv1 -Sample Description Name And Format
avc1 is an AVC visual sample entry. It has a avcC (AVC Configuration Box) atom. This atom contains an AVCDecoderConfigurationRecord as state above.
I have broker down and highlighted those value in acvC atom
Red - these 4 bytes in red denote the length of the atom, including the length and type field
Green - these 4 bytes in green denote the type field
Purple - those bytes surrounded by purple is the AVCDecoderConfigurationRecord. So, the length of AVCDecoderConfigurationRecord is length of atom - 8
By following AVCDecoderConfigurationRecord structure, you can parse the values easily.
For example,
0x01 - the first byte is configurationVersion = 1
0x42 - the second byte is AVCProfileIndication = 66
0xC0 - the third byte is profile_compatibility = 192
0x15 - the fourth byte is AVCLevelIndication = 21
Reference: ISO IEC 14496-12 and ISO IEC 14496-15
Thanks for these useful posts. Which software are you using to browse the file structure with shown in the screenshots?
ReplyDeleteIt is mp4parser.
ReplyDeletehttp://code.google.com/p/mp4parser/
Hello guys,
ReplyDeleteI have a question, please help me. Thanks a lot.
My question is that quicktime can not play the mp4 file which be produced by ffmpeg. I try to fill AVC Decoder Configuration Record to h264 extradata, it is same as before. qt can not play, it seems I lost something, do you have any ideal, please help me, thanks a lot.
Hi psychesnet,
ReplyDeleteI suggest you should localize the issue first.
Can you output mp4 file played by VLC? If no, you file structure or AVC configuration have some issue.
If VLC can play it, it means that it will be the fussy quicktime issue. What you can do is to change the profile or level to lower rate, remove B-Frame setting, etc..
Dear Thompson Ng,
ReplyDeleteIf I do not insert extradata for h264, the vlc can play it(mp4 file). But qt can not.
If I insert
0142001effe1001b6742001ee90283f7fe0000030001c48006ddd000cdfe600d88109401000468ce3152
(
SPS:6742001ee90283f7fe0000030001c48006ddd000cdfe600d881094
PPS:68ce3152
)
the vlc can not play it, even no video screen.
By the way, I do not have B-Frame and my video frame is coming driver(camera). So, I do not need encode and decode the frame, I just put it into the avpacket(ffmpeg).
Dear Thompson Ng, please help me, Thanks a lot.
Dear Thompson Ng,
ReplyDeleteMay I send email to you and attach my output file.
Thanks a lot.
Sure. Please send to tngcy@hotmail.com, some description on what you want to do and your error. I will get back to you asap
ReplyDeleteHow i can send AVC via RTP? Which headers contain NAL unit in first picture? rfc 3964 compatible? For example, what means 0x41 byte header? A single NAL unit?
ReplyDeletePS: i already can stream this video file via RTP, but player play it with some artifacts. I think, key frames (0x65 - IDR) have a wrong header.
You need to read the H.264 specification to really know what 41 means. Or, even on RFC3984.
ReplyDeleteIn actual fact, RFC3984 - 5.3. NAL Unit Octet Usage does give you a brief description on what is H.264 header. From there, you can see that 0x41 means P-Frame. And like you had said, 0x65 is a I-Frame.
As for artifacts, it could be due to many different reason from dropping of frames, incomplete frames, lack of SPS and PPS information, etc... The best tools to help you is wireshark where you really have to dig into network packet level to understand what is happening.
Hi Thompson,
ReplyDeleteYour site help me lot in understanding mp4 file format. I have one question what is nal size ? when i muxing h264 data in mp4 file and running that file in vlc its giving waring that
AVC: nal size -1683583999
no frame!
[0x981755c] avcodec decoder warning: cannot decode one frame (13258 bytes)
can you explain why that warning
thanks in advance
How did you mux the h264 frame? Did you mux 1 NAL at a time?
ReplyDeleteIf look at ffmpeg code, that error may occurs when you mux 2 or more NAL units in 1 mp4 mdat sample.
You can see the source code here http://ffmpeg.org/doxygen/trunk/h264_8c-source.html
Hi Thompson,
ReplyDeleteThanks for reply.I did not set proper sample size values. so that i got error.Now its working fine.
Your mp4 file format part1 helped lot to understand mp4 file.
Thanks,
Raghav
Really grad that your had fixed the issue ^^
ReplyDeletenice post about mp4 file format part 2, you gave me more known with mp4 format. thank you.
ReplyDeleteGood to know it benefit others ^^
ReplyDeleteHi Thompson,
ReplyDeleteMP4 blog 1 & 2 is absolutely brilliant stuff. Got very valuable insights. Thx a lot.
Abhishek
Hi Thompson,
ReplyDeleteIs there a way to generate a recommended or desired bitrate (bandwidth) to download avc content based on the setting in AVC Decoder Configuration Record?
Thanks a lot.
Weibing
Thanks for those posts about mp4 file structure. I'm using default components to play mp4 file (with progressive download) in Silverlight. It looks like I really need to write my own MediaStreamSource. How shoud I download and parse file to fulfill progressive download scenerio? Just looking for concept and some directions.
ReplyDeleteHi Thompson ,
ReplyDeleteis there way to decode mpeg-4 frame into I,P,B frames
Hi Thompson!
ReplyDeleteVery useful post.
Can MP4 be encrypted frame by frame so when the frame is written to the disc it is encrypted?
Where the encryption information is written?
Collection of my favorite ringtone in 2018
ReplyDeleteHi everybody
I will mention popular songs and interesting melodies. The most popular ringtones are edm phone ringtones, and Vinahouse, Hip Hop. You can refer to my ringtone collection and leave a comment. You can visit my homepage to find more types of attractive ringtones here: https://ringtonesmobile.net/
These are the favorite tunes in 2018, I want you to introduce and install:
- https://ringtonesmobile.net/bollywood
- https://ringtonesmobile.net/pop
- https://ringtonesmobile.net/iphone-ringtones
- https://ringtonesmobile.net/marimba
- https://ringtonesmobile.net/dance
Best quality ringtone 2018. What are you waiting for? Quickly install your favorite ringtone on your mobile phone. Thanks for care!
Hi all,
ReplyDeleteI have implemented a program that - using ffmpeg/libavformat - writes .mp4 files containing h.264 video from an IP camera.
I've implemented a file-switching logic so that a new .mp4 file is created (and the current one is closed) whenever a change is detected in SPS/PPS (this happens, for example, when one manually changes the video and/or encoder parameters on the camera).
My question: is this strategy correct, or I could keep recording on the same .mp4 file even when SPS/PPS changes? Recently I have found an IP camera whose SPS occasionally changes (within its VUI section) without any explicit change in its video and encoder settings..
Thanks in advance,
Massimo
Enthusiastic words written in this blog helped me to enhance my skills as well as helped me to know how I can help myself on my own. I am really glad to come at this platform. online zwangerschapscursus
ReplyDeleteMe and my team was in search of a rarely found platform which can help us for our new assignment. We are writers and its been a long time we are in this writing field. So we would appreciate help of this blog.online zwangerschapscursus
ReplyDeleteThis comment has been removed by the author.
ReplyDeletePolo studbook dot org is assisting students to get their essay mission written under the steering of professional specialists. Over this platform, you may entertain many service at the equal time that’s why it's far greater effective platform for students.zwangerschapscursus online
ReplyDelete