Change the frame rate of an MP4 video with ffmpeg
Solution 1
I know this is an old question but none of the current answers are the recommended way anymore.
Lossless (video) remuxing
As noted in the comments there is a way to do this where the video does not have to be re-encoded. It requires remuxing the file to a different containter format MKV and then remuxing it back into an MP4. Here is an example that changes a video to 12 frames/second:
mkvmerge --default-duration 0:12fps --fix-bitstream-timing-information 0 original-video.mp4 -o temp-video.mkv
ffmpeg -i temp-video.mkv -c:v copy slow-video.mp4
If the video contains audio you can also slow that down without changing the pitch, but it is not a lossless conversion. The example below assumes the source video was 24 frames/second so that audio needed to be slowed to half (0.5) speed using ffmpeg's atempo filter.
mkvmerge --default-duration 0:12fps --fix-bitstream-timing-information 0 original-video.mp4 -o temp-video.mkv
ffmpeg -i temp-video.mkv -c:v copy -c:a aac -filter:a "atempo=0.5" slow-video-with-audio.mp4
FFMPEG Wiki Guidance
This is the guidance from the ffmpeg wiki. Note that all of these options do require re-encoding the video.
Speeding up/slowing down video
You can change the speed of a video stream using the setpts video filter. Note that in the following examples, the audio stream is not changed, so it should ideally be disabled with -an.
To double the speed of the video, you can use:
ffmpeg -i input.mkv -filter:v "setpts=0.5*PTS" output.mkv
The filter works by changing the presentation timestamp (PTS) of each video frame. For example, if there are two succesive frames shown at timestamps 1 and 2, and you want to speed up the video, those timestamps need to become 0.5 and 1, respectively. Thus, we have to multiply them by 0.5.
Note that this method will drop frames to achieve the desired speed. You can avoid dropped frames by specifying a higher output frame rate than the input. For example, to go from an input of 4 FPS to one that is sped up to 4x that (16 FPS):
ffmpeg -i input.mkv -r 16 -filter:v "setpts=0.25*PTS" output.mkv
To slow down your video, you have to use a multiplier greater than 1:
ffmpeg -i input.mkv -filter:v "setpts=2.0*PTS" output.mkv
Smooth
You can smooth out slow/fast video with the minterpolate video filter. This is also known as "motion interpolation" or "optical flow".
ffmpeg -i input.mkv -filter "minterpolate='mi_mode=mci:mc_mode=aobmc:vsbmc=1:fps=120'" output.mkv
Other options include slowmoVideo and Butterflow. Speeding up/slowing down audio
You can speed up or slow down audio with the atempo audio filter. To double the speed of audio:
ffmpeg -i input.mkv -filter:a "atempo=2.0" -vn output.mkv
The atempo filter is limited to using values between 0.5 and 2.0 (so it can slow it down to no less than half the original speed, and speed up to no more than double the input). If you need to, you can get around this limitation by stringing multiple atempo filters together. The following with quadruple the audio speed:
ffmpeg -i input.mkv -filter:a "atempo=2.0,atempo=2.0" -vn output.mkv
Using a complex filtergraph, you can speed up video and audio at the same time:
ffmpeg -i input.mkv -filter_complex "[0:v]setpts=0.5*PTS[v];[0:a]atempo=2.0[a]" -map "[v]" -map "[a]" output.mkv
Solution 2
If the input file doesn't have a valid frame rate you might have to set it explicitly
ffmpeg -r 1 -i input.mp4 -r 24 output.mp4
Solution 3
I could only get the changed framerate to take effect if the input file was classed as a "raw" file:
ffmpeg -r 5 -f h264 -i input.h264 -vcodec copy -an output.mkv
Without specifying -f h264
it would default to 25 fps and it could not be changed. Apparently this was because the stream lacked any framerate information at all and this is ffmpeg's default framerate.
Apparently when you use -r
as an output option it duplicates or drops frames so the video plays at the same speed - in this case, not what you want! But changing the input framerate as above will cause the video to speed up or slow down, with no frames lost or duplicated.
Solution 4
Such a feature - of changing framerate - is called "conforming" and is often used to produce slow-motion or fast-forward like showing a plant's growth in minutes insted of days. ffmpeg do not allow overwriting/changing framerate without re-encoding. If it does so, duration will change and audio would be out of sync unless separately mended. But I'm afraid audio is not of interest in your case with framerate of .33
You want conforming because you just want to change framerate, but ffmpeg ignores -r
silently if framerate is specified in the input file. Since your input file is in .mp4 format, its own framerate take precedence of when re-encode isn't needed. For this you need a different tool: mencoder.-r
Assuming your input file contains no sound - likely true for any video with .33 framerate - what you need is:
$ mencoder -fps 5 -o <output> -ovc copy -nosound <input.mp4>
Notice that mencoder by default produce output in AVI format.
Solution 5
The quickest way is to create a BAT-file in the directory with the following rows:
@ECHO OFF
for %%f in (*.mp4) do (
echo “fullname: %%f”
del temp.mkv
mkvmerge --default-duration 0:18fps --fix-bitstream-timing-information 0 %%f -o temp.mkv
del %%f
ffmpeg -i temp.mkv -c:v copy %%f
del temp.mkv
)
You need to have mkvmerge and ffmpeg in the same directory. It changes every mp4-file in seconds automatically with no loss of quality.
Related videos on Youtube

Admin
Updated on September 18, 2022Comments
-
Admin 3 months
I have a video in mp4 format with a frame rate of
.33
(1 frame for 3 seconds). I want to increase the frame rate to 5 frames/sec. I have tried the below command but it does not do any thing:ffmpeg -i <input.mp4> -r 5 <output.mp4>
Any idea why ffmpeg is ignoring
-r
option? -
Gyan almost 7 yearsThis is wrong. If
r
is specified as an output switch, ffmpeg will produce an output at that specified framerate, irrespective of the input's framerate. Ifr
is specified as an input switch, ffmpeg will duplicate or drop frames as necessary to feed the specified number of frames per second of input to the filter/encoder. -
Tankman六四 almost 7 yearsThe behaviour you describe when
r
is an input switch contradicts with my earlier experiment on .mp4 format, Malvineous' note (on this page) and bug description 403 trac.ffmpeg.org/ticket/403 ; your description whenr
is used on output happens when re-encoding, while the scenario of OP seems to be a conforming case (fix framerate without re-encoding) by the fact that he had .33 framerate. -
Gyan almost 7 yearsCheck report pasted here. Note the command line at the top, the input and output metadata and finally the no. of frames encoded.
-
Gyan almost 7 yearsAgreed that the OP wants to just conform file but their given command is re-encoding since copy switch(es) isn't specified. In that scenario, ffmpeg should be generating new stream at
r
fps. -
Tankman六四 almost 7 yearsThank you Mulvya for the convincing sample output. Yes, you are right on the usage of
-r
. That usage couldn't affect my earlier experiments in response to OP because, thinking a conforming case, I never dropped copy parameter from ffmpeg, and-r
is thus ignored. I wrote a feature request: trac.ffmpeg.org/ticket/5170 -
Gyan almost 7 yearsThanks. You should change the priority to wish as it's not a bug.
-
yota about 4 yearsMy useful answer. No re-encoding here
-
Peter Cordes over 3 yearsThis transcodes when you really only need to remux. (Unless you actually want to duplicate / drop frames instead of slowing down / speeding up the video.)
-
Peter Cordes over 3 yearsIt's possible to speed/slow by just remuxing, but FFmpeg doesn't know how to do it. e.g. for mkv, mkvtoolnix can do it. e.g.
mkvmerge --default-duration 0:24000/1001fps --fix-bitstream-timing-information 0 in.mkv -o out.mkv
Change framerate on MKV container. You could remux to MKV and back to MP4, or find a tool that does it for MP4 directly. xcoding the video is very CPU-intensive and lossy, so it's a horrible option. -
pseudosavant over 3 yearsTotally agreed that remuxing to a lower framerate is preferred as it is a lossless approach that is much less resource intensive. In practice I haven't found good tooling for doing that with MP4s though. I haven't tried really recently, but back when I first wrote this answer I had doing MP4->MKV->MP4 remuxing and I couldn't get it to work using mkvtoolnix, ffmpeg, and/or mp4box. I'll have to try with the parameters you suggest.
-
Paul 9 monthsThis didn't work: "Unknown input format: 'Audio Story.mp4'"
-
Malvineous 9 months@Paul: Your
.mp4
file is probably not raw H264 then, you'll have to use a different-f
value to match the internal file format inside the file.