-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
Error: wrong indices in video buffer. Maybe buffer too small. #38
Comments
I am on 0.2.1.7.21. |
Any update on this? |
Really busy, give me some time. But thanks for the bug report. That is a strange bug, I don't know exactly what causes it. What is the length of the words for which your fix doesn't work ? Could you upload the files somewhere ? |
Code:
word.aif: |
Seems like a similar error message is thrown here. I have to ship my code into production this week, a fix would be greatly appreciated. |
Ok, I'll look into it tonight (in 10h) if I have time. should be fixed by tomorrow. |
Thank you. You are awesome! |
Ok, so it seems that the error is what I thought it was: the buffer for reading audio from video/audio files expects these to be longer, which causes the bug. To be precise, the default buffer is 200000 bytes of 2-channel 44100Hz 16-bit sound, which can only be found in clips that are more than 200000/(2_44100_2) = 1.13 seconds long. So you need to change the buffer size; your example works if I replace the line
by
Don't make that buffer too small (<20000) though, or the video-writer on the other end will scream that it cannot write enough bytes at once. As an alternative, you can also try the version I fixed on Github, in which the default buffersize is adapted to the file if the file is short. |
Can you push fixed version to pip or easy_install? |
Nevermind, I figured out pip can install from github. The problem doesn't seem to be fixed tho:
|
The |
It's not the same bug, this time it is the writer which screams at you. Can you give me a script/audio file for which it crashes ? |
Yes, the error is:
Code:
If I set buffersize something bigger (eg 50,000), or smaller (30,000) it goes away. |
I just double checked that the only version of moviepy installed on my machine is the commit b64cf4c. So with:
Crashes still occur (on different files). With manual buffersize settings crashes occur too. |
Another observation:
This only happens on some videos. Rendering code: |
I got the crash rate down a bit by this line:
in audio/io/readers.py line 60. I don't know why, but it reduces crashes a bit. It is not a fix by any means. Are you interested in fixing this bug, or not really? |
Yes I am interested in fixing this bug (it must be one of the most visible bugs left in moviepy). However I have other emergencies, so your feedbacks are greatly appreciated. I'll give it a look tomorrow. A few days ago I have changed something in the computation of "which clip is playing when". This little change fixes a bug that happened because at the end of a video file moviepy asked for a last video frame which was outside the range of the videofile. |
Hi, I'm sorry for late reply (was travelling to Europe). I've upgraded my local branch to the latest commit, but the issue still exists:
Could it be the case that the audio files have incorrect metadata or something of that nature? It only happens on 5% of files, and the same files consistently fail. |
Interesting... Could you upload one of these files somewhere (or does it fail with the last file that you already uploaded ?) |
Yup, just run this: The audio files are generated by |
Also, I've a quick question. Is it possible to have 2 audio tracks playing at same time? So the image/text clips get 1 and than the entire video gets 1 audio track as well? |
First, an update on your bugs. At least on my computer, it seems that the main problem is that you ask the same clip to play three times, which forces the ffmpeg-reader to "rewind" or re-initialize, and that's where the bug happens.
I will try to see what causes this bug. In the meantime, the most reliable solution is to create different entry points into the file:
Since you need to process these clips afterwards, the best thing to do is to make a loop or a function, like this:
|
While I am at it: your code is not optimized. The way you wrote it, for each frame of the video MoviePy will regenerate the slide (by blitting the text on the background). It is better to tell MoviePy that your slides are clips made of a single frame. To do so, you just change this code:
by adding this line:
Applying this to all your slides made the video generation 10x faster (it will also greatly improve your previews). |
Note that if your backgrounds are simply colors, you don't need to use CompositeVideoClip, you can use Also I would suggest you use a variable |
Now to answer your question on adding an audio background. I will certainly add a function to do this. Right now the way to do it is as follows:
|
Thank you! You are absolutely awesome. I've applied the to_image optimization, and that has reduced render time from 45 to 14 seconds. Awesome! As for crashes, I just upgraded to the latest commit, and almost every rendering crashes.
My +1 hack in audio/io/readers.py line 60 seems to reduce these crashes significantly. |
I don't get it. Is it due to the concatenation or is it a problem with the files themselves ?
and tell me if you get a bug, and if you get one for a given file, send me the file ? I believe there might be a problem with metadatas, I will try to implement a robust solution. Have you tried the trick in which I create 3 different clips from the same file. |
Yes, I no longer reuse clips in concatenation. That was probably not the issue anyway. I think its metadata problem with files. It seems to be just slightly off at times. |
Hi, I tried converting
It all goes back to audio/io/readers.py. I don't know what the problem is. Furthermore, on same files, here is the output of:
|
I believe there are different issues here, but the error you get is not really a bug, it's just that to_audiofile also requires you to provide the codec, given that it cannot guess the codec from the extension. Here are some examples of codecs:
So this will work:
I will look into the rest. |
With codec parameter, it works fine. Conversion work, but rendering crashes. |
Ok, but then I will need you to provide the script that crashes. The script you gave me last time works fine, even on the new files you sent me. |
Thats weird. It crashed for me on all of my machines. I've just stumbled upon something. If I do convert every .aif to .mp3 with And than use mp3's for rendering, the crash is gone. Testing a sample of 100 vids, will know in a bit if its for sure. |
Nevermind, it still crashes. |
Here is the the latest example: Run it with:
On latest version of moviepy:
|
Ok, I can reproduce the bug, I will see what is going wrong. |
Ok, I removed a "+1" (not where you had changed it) and now it seems to work. I hope I didn't break anything (my other projects still compile, that's a good sign). If that was it, thagt was a silly error, and it means that it wasn't the metadata's fault. Could you try reinstalling (either from PyPI or github) and send me files for which it still wouldn't work ? Thanks for your help in debugging this, that might be one of the most annoying bugs in the library ! |
I have ran a couple hundred renderings, and I can confirm the bug is definitely fixed. Thank you very much! You're awesome. |
The following code:
Produces:
A little hack that kinda makes it go away is to do:
Although this doesn't fix anything. It just happens to work in this case, but not for other clips. Why is it crashing?
The wordAudio.duration is 1.04s in this case. On some audio files it crashes, on some it doesn't. Is this the accuracy problem with generating number of frames based on audio length?
The text was updated successfully, but these errors were encountered: