Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Bug]: OpenRV 2.1.0 getting wrong framerate for movie files #600

Closed
1 task done
mircotornow opened this issue Oct 1, 2024 · 10 comments · Fixed by #662
Closed
1 task done

[Bug]: OpenRV 2.1.0 getting wrong framerate for movie files #600

mircotornow opened this issue Oct 1, 2024 · 10 comments · Fixed by #662
Labels
bug Something isn't working

Comments

@mircotornow
Copy link
Contributor

What happened?

Hi all.

We noticed a very strange behaviour with our newest rv build (2.1.0 Head: f9e45c7)

When opening movie files (.mov, codec doesn't seem to matter, happens in prores, h264, dnxhd) rv is somehow getting a wrong framerate. (2 instead of 24)

It's also printing following to the console:
WARNING: Using non-standard frame rate 2400/1000

It was working fine in previous versions (openrv1.0 and openrv2.0 (our latest working head: f3066e7)

Here openrv2.0 on the left and 2.1.0 on the right
image

The FPS is set to 24 for both.

The different framerate results in wrong frame numbers, which is very annoying and makes it unusable in production.

Can anyone confirm that this is happening for them too?

Cheers

List all the operating systems versions where this is happening

CentOS7, Windows10

On what computer hardware is this happening?

any

Relevant console log output

WARNING: Using non-standard frame rate 2400/1000
WARNING: Using non-standard frame rate 2400/1000
WARNING: Using non-standard frame rate 2400/1000
...

..[when playing]..
ALSA lib pcm.c:8424:(snd_pcm_recover) underrun occurred
ALSA lib pcm.c:8424:(snd_pcm_recover) underrun occurred
ALSA lib pcm.c:8424:(snd_pcm_recover) underrun occurred
...

Environment variables

No response

Extra information

No response

Code of Conduct

  • I agree to follow this project's Code of Conduct
@mircotornow mircotornow added the bug Something isn't working label Oct 1, 2024
@markreidvfx
Copy link
Contributor

markreidvfx commented Oct 1, 2024

I have a fix for this issue, I just haven't had time to report or submit a PR. The issue is due to ffmpeg version update. For mov containers, using the streams time_base as the frame rate for timecode is not correct.

AVRational tcRate = {tsStream->time_base.den,

Using AVStream.avg_frame_rate should be the correct thing to use as that is what ffmpeg is using to encode the timecode for mov container files.

https://github.com/FFmpeg/FFmpeg/blob/2a6f84718b172cd0858316281cbbd967f35767f0/libavformat/mov.c#L9503

This issue can be easily replicated using the Alab trailer media. The start frames are incorrect for the mov media in OpenRV.

https://dpel.aswf.io/alab-trailer/

@mircotornow
Copy link
Contributor Author

mircotornow commented Oct 2, 2024

Hey @markreidvfx

Thanks for the pointer in the right direction!
putting:

AVRational tcRate = tsStream->avg_frame_rate;

did the trick and OpenRV now is getting the correct framerate for mov containers.

However we still get the console log:
WARNING: Using non-standard frame rate 2400/1000 (When initially loading a file)

this is coming from ffmpeg:
https://github.com/FFmpeg/FFmpeg/blob/7151081e33425010a53c7573e84b274c68ad8087/libavutil/timecode.c#L204

which is called here in openrv:

av_timecode_init_from_string(&avTimecode, tcRate, tcEntry->value,

and
ALSA lib pcm.c:8424:(snd_pcm_recover) underrun occurred (when playing a .mov source)

So it seems it's calculating the framerate wrong somewhere else too.

@markreidvfx
Copy link
Contributor

markreidvfx commented Oct 2, 2024

I believe it needs to be fixed in two spots.
here too.

AVRational rate = {tsStream->time_base.den,

Maybe that will fix your audio issue.

I also removed those weird hack about wrong framerates here

if ( rate.num > 1000 && rate.den == 1)

I'm not really sure what that is all about, it seems very incorrect to me.

I also only limited using avg_frame_rate to mov container files by checking file format in the AVFormatContext. Using avg_frame_rate will lead to incorrect start frames mxf files, this again can be verified with the Alab trailer mxf media.

@mircotornow
Copy link
Contributor Author

for mxf you are right, but I think mp4 needs the same adjustment as mov

have you tested with mp4 files?

@markreidvfx
Copy link
Contributor

markreidvfx commented Oct 2, 2024

MOV and MP4 are essentially the same format, they use the same demuxer in ffmpeg. It's used for all these formats.
mov,mp4,m4a,3gp,3g2,mj2,psp,m4b,ism,ismv,isma,f4v,avif,heic,heif

(It's also used for cr3 raw files)

https://github.com/FFmpeg/FFmpeg/blob/a7449e4cbb36a65b0d3084a4d0ee66c880a4b4e1/libavformat/mov.c#L11018

AVFormatContext->iformat contains a list, so I'm currently just checking if the list contains mov and it should work for all of them. I could also be using the iformat class_name, I'd need to check

@markreidvfx
Copy link
Contributor

markreidvfx commented Oct 2, 2024

MKV and other containers are another issue entirely... If there is no metadata telling us what the timecode rate its impossible to know the start_frame exactly. moov Atom (mov) and MXF formats actually store the timecode as the number of frames, not a string, it would be nicer if ffmpeg exposed that, or the tc rate.

@mircotornow
Copy link
Contributor Author

mircotornow commented Oct 10, 2024

how are you exactly checking if the list contains mov?

Before I was thinking about checking it like isMP4format() and adapted it from there but I'm pretty sure this would only work for .mov ? (untested so far)

mircotornow@cb27612#diff-f87f8f114f0b9c97fdc4c1c6b87698cf860d0e01d0ae5bafdd55bfa24dffcfc7R706

@markreidvfx
Copy link
Contributor

I'm currently doing the same thing. strstr(avFormatContext->iformat->name, "mov")

@bernie-laberge
Copy link
Contributor

We would very much like to merge your fix into the main branch @mircotornow and @markreidvfx.
@mircotornow, do you think you could create a PR with this fix above @mircotornow ?
Alternatively, I could create the PR but it would be nice if it was coming from the true author.
Thank you guys !

@markreidvfx
Copy link
Contributor

// Correct wrong frame rates that seem to be generated by some codecs
if ( tcRate.num > 1000 && tcRate.den == 1)
{
   tcRate.den = 1000;
 }

I also removed this code, looks very questionable, it doesn't look correct to me. The comment is vague, are there really lots of files in the wild doing this?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants