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

The Future of MoviePy project #1874

Closed
B3QL opened this issue Dec 5, 2022 · 130 comments
Closed

The Future of MoviePy project #1874

B3QL opened this issue Dec 5, 2022 · 130 comments
Labels
project-admin Anything to do with the administration & organisation of moviepy. I.e. project "meta". question Questions regarding functionality, usage

Comments

@B3QL
Copy link
Contributor

B3QL commented Dec 5, 2022

I'm opening the issue in an attempt to provide a platform for discussion on the project's future.

The project is unmaintained and it looks like the original contributors lost interest in it.
Currently, few fellows giving their best and taking care of reviewing PRs
and fixing the issues related to their projects but it's not enough to keep the project healthy.
The library is obsolete to the point that 3rd party open source software
that depends on it is having problems with being included in the next Debian release.

If we want to save the project we need to build a community around it
and/or seek some financial help from OSS foundations.

Nevertheless, we need YOUR help.
If you have an idea of how to help the MoviePy project survive, please contribute in the comment.

@B3QL B3QL added the question Questions regarding functionality, usage label Dec 5, 2022
@davidbernat
Copy link

I second this nomination. Very important. Few to no alternatives.

@AndersonBY
Copy link

Support! I used to teach some lessons about how to use moviepy to automate the work of video making. Clearly people are interested in this since we are flooded by short videos today and Python is the easiest way many people can learn to automate video processing.

I think one problem now is that moviepy itself is good but the community and other projects that build on it is not famous enough. Therefore not much sponsor would be interested in moviepy.

My rough thoughts about the future of this project:

  1. Make a systematic series of teaching videos and promote so more people can know how to use it.
  2. Maybe build a saas platform that use moviepy with paid features and feed back the project? I can see many successful open source projects are running like this. This can be the self-sufficent way to run this project.
  3. Moviepy itself is just a tool. A tool itself usually is hard to have the wide spread ability. So use moviepy to build some projects which have a more wide spread ability. Topics like AI generated, trolling for content.

Just some random thoughs. Looking forward to your comments.

@B3QL
Copy link
Contributor Author

B3QL commented Dec 11, 2022

Support! I used to teach some lessons about how to use moviepy to automate the work of video making. Clearly people are interested in this since we are flooded by short videos today and Python is the easiest way many people can learn to automate video processing.

Great to hear that, no doubt that moviepy is a great choice for automating video processing, however, it looks like not many hobbyists contributing back to the project.

I think one problem now is that moviepy itself is good but the community and other projects that build on it is not famous enough. Therefore not much sponsor would be interested in moviepy.

My rough thoughts about the future of this project:

1. Make a systematic series of teaching videos and promote so more people can know how to use it.

IMHO the usage of the project is not a problem per se, it's more about how to convert more users to contributors.

2. Maybe build a saas platform that use moviepy with paid features and feed back the project? I can see many successful open source projects are running like this. This can be the self-sufficent way to run this project.

That is an interesting idea but I don't see a clear way how to monetize the project eg. what are the "premium" features?

3. Moviepy itself is just a tool. A tool itself usually is hard to have the wide spread ability. So use moviepy to build some projects  which have a more wide spread ability. Topics like AI generated, trolling for content.

At the current state of the project and its trajectory, I think that people should not build upon an unmaintained library to avoid problems such as #1798 (comment)

@AndersonBY
Copy link

@B3QL Came across this project Remotion. Kind of similar to moviepy but more active. It offers a membership subscription.
image

As for moviepy, I think cloud rendering and effects templates can be the premium features.

When using moviepy to do some automated editing, I need to spend a lot of times to get the correct effects. Would be great if there is a "template market" to preview and get some effects template code.

@tburrows13
Copy link
Collaborator

Hey, just checking in to say that I’m reading this discussion :) In the past I’ve found that when one or two enthusiastic people get involved in a project, that really helps me rejuvenate interest in it as well.

@B3QL
Copy link
Contributor Author

B3QL commented Dec 11, 2022

@AndersonBY thanks for the inspiration :)

@tburrows13 thanks for all your contributions so far and the will to participate further with additional help. Maybe you have any idea how to organize/improve collaboration to get the project back on track?

@komjum6
Copy link

komjum6 commented Dec 11, 2022

Maybe it needs an overhaul like from TKinter to Kivy

@korantu
Copy link

korantu commented Dec 12, 2022

Is there a specific next step wanna-be contributor with a bit of python experience could have a look at? To add momentum?

@xonoma
Copy link

xonoma commented Dec 12, 2022

The one thing that's really held MoviePy back IMHO is the documentation.

When I first started I had to go everywhere to look for basic MoviePy-related tutorials and steps. Not everyone's as motivated; a centralized documentation would create interest in users, and help to retain them.

@B3QL
Copy link
Contributor Author

B3QL commented Dec 13, 2022

Is there a specific next step wanna-be contributor with a bit of python experience could have a look at? To add momentum?

@korantu AFAIK there are no extra steps to contribute, just familiarize yourself with https://github.com/Zulko/moviepy/blob/master/CONTRIBUTING.md and that's it :)

I don't know for sure what is the most urgent problem to work on but I try to sort it out and bring some more clarity.
For now, I believe that the most benefit we can get from finishing #1089 and releasing 2.0

@tburrows13 correct me if I'm wrong here ☝️
@keikoro maybe you can help me with the priorities?

The one thing that's really held MoviePy back IMHO is the documentation.

@xonoma the documentation looks decent to me.
Do you miss something in particular or have an idea how to improve further? Feel free to give it a shot!

@Zulko
Copy link
Owner

Zulko commented Dec 16, 2022

Hi all! Very sorry for this situation. I've been spread thin for years now, and MoviePy has only been held together thanks to the efforts of @keikoro @tomburrows @mondeja and others. Here are my two cents:

Regarding @AndersonBY's comments: I agree that we could have more docs and "official" collections of plugins and effects. But these require a significant time investment, and could also be developed by users independently. Anyone can write a tutorial, release a library of moviepy filters/utilities on Github or PyPI, or build a web service around MoviePy - and a few have. So I would classify that as important, but not blocked by this repo.

The more problematic bottleneck is developer time on this repo (features, installation, test suite). Few users have contributed back to these areas, and occasionally when some attempted to contribute they were left hanging by lack of available reviewers.

I agree that releasing @tomburrows's 2.0 version would be the best move - and the most significant project improvement in years. It would resolve some of the confusion caused by the current API, and so should reduce the number of issues. It would also put the project in phase with its README (which is using the 2.0 API now). Realistically, going to 2.0 would also mean quickly dropping support from pre-2.0 MoviePy, as supporting two APIs would spread developer time even thinner. A bit of an unpopular opinion but a new API also means a smaller userbase, which could make mistakes more forgiving, and MR review less stressfull.

The 2.0 release in itself may not solve a harder problem the project is facing, which is managing dependencies like ffmpeg or ImageMagick, and their subtle differences between versions and OSes causing a lot of our open issues. These are generally difficult and joyless to solve, as they require setting up a specific environment to troubleshoot the issue, and because preventing regressions accross many OSes and several ffmpeg versions requires a large test suite tht could slow down some operations. For a long time, MoviePy was piggybacking on imageio (and its integrated ffmpeg installer) so that that most of the ffmpeg features and issues (such as the one now affecting the Debian release) were ultimately solved on the imageio side. But even coordinating with imageio takes time and we can't expect them to solve all our problems (meaning, even if the fix is pushed on the imageio side, someone has to do the work).

Summarizing:

  • We'd need a small team (could be 2 people so there's at least one main dev and one reviewer) for the last push on 2.0.
  • We'd need a very involved developer to fix the binary management problem, ideally by having moviepy come with reliable ffmpeg/Imagemagick versions when pip-installed, and/or by expanding tests for different OSes (this might already be largely in place) and ffmpeg releases. Not sure how we'd find that person - could be either someone who really needs it fixed, or looking for a student project. In that last case we'd still need someone from the project available to provide context and reviews.
  • We'd need more core developers to review and merge the regular MRs, Issues, improve docs, etc. I believe making an announcement in various places (e.g. Reddit) might help. Again we'd need to make sure there is bandwidth to welcome new devs.

Did that make sense? Did I miss anything?

@tburrows13
Copy link
Collaborator

Just a quick note to say that part of the plan for 2.0 was to not need ImageMagick at all. I think currently it is only used for making GIFs and drawing text. IIRC there are 3 options currently for making GIFs so losing IM would be fine there. There were a couple of explorations for alternatives for text drawing which looked promising, but I think that was one of the main outstanding tasks to complete before 2.0.

@B3QL
Copy link
Contributor Author

B3QL commented Dec 19, 2022

@Zulko thanks for the in-depth insights, it's great to hear back from you!
@tburrows13 thanks for clarification with the ImageMagick

We'd need a small team (could be 2 people so there's at least one main dev and one reviewer) for the last push on 2.0.

@tburrows13 would you take responsibility for the coordination of the 2.0 release with the help of current contributors?
@korantu are you still willing to help with the release?

We'd need a very involved developer to fix the binary management problem, ideally by having moviepy come with reliable ffmpeg/Imagemagick versions when pip-installed, and/or by expanding tests for different OSes (this might already be largely in place) and ffmpeg releases. Not sure how we'd find that person - could be either someone who really needs it fixed, or looking for a student project. In that last case we'd still need someone from the project available to provide context and reviews.

IMHO the simplest way would be to make the ffmpeg a static dependency and ship it along and support one version at a time, but I may not be aware of all the potential consequences. For now, would be great if we can manage to make some decisions and based on that create smaller tasks for implementation.

We'd need more core developers to review and merge the regular MRs, Issues, improve docs, etc. I believe making an announcement in various places (e.g. Reddit) might help. Again we'd need to make sure there is bandwidth to welcome new devs.

I announced it on Reddit [0][1] & HN [3][4] already, but we can repeat it from time to time.
[0] https://www.reddit.com/r/coolgithubprojects/comments/zin6na/the_future_of_moviepy_project/
[1] https://www.reddit.com/r/moviepy/comments/zin2ez/the_future_of_moviepy_project/
[3] https://news.ycombinator.com/item?id=33864865
[4] https://news.ycombinator.com/item?id=33953142

@keikoro
Copy link
Collaborator

keikoro commented Dec 19, 2022

Hi, thanks for starting this issue! I just wanted to comment that I (too) have been reading along but haven't yet had the time/energy to add to the discussion (or get my thoughts on this in order in the first place, ha).

@keikoro
Copy link
Collaborator

keikoro commented Dec 19, 2022

(A bunch of which revolve around communication/project management, a point which hasn't been raised yet.)

@B3QL
Copy link
Contributor Author

B3QL commented Dec 20, 2022

(A bunch of which revolve around communication/project management, a point which hasn't been raised yet.)

I believe that that is the main pain point here, so that's why I decided to open the issue and try to coordinate ongoing efforts.
I would love to hear your thought about it and the potential ideas, on how to arrange some kind of structure for the future.

BTW can we pin the issue for better visibility?

@rolandmas
Copy link

Hi all, I'm the maintainer of the Debian package of moviepy, which is currently not on track to be included in the upcoming Debian 12 "bookworm". I just wanted to mention in this discussion that I'll be glad to provide any help I can related to packaging or testing with Debian. Feel free to poke me either here or on https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=1004642 :-)

@tburrows13 tburrows13 pinned this issue Dec 20, 2022
@B3QL
Copy link
Contributor Author

B3QL commented Jan 30, 2023

Hi everyone in 2023!
@korantu have you had a chance to contribute so far?
@tburrows13 is the 2.0 release on track? Do you need help with it?

@korantu
Copy link

korantu commented Jan 31, 2023

I did not get to try my idea yet 😒.

@ShakedDovrat
Copy link

What is the status on multi-core CPU processing AND/OR GPU processing? Is anyone working on it?
I want to contribute.

@B3QL
Copy link
Contributor Author

B3QL commented Feb 9, 2023

Hey @ShakedDovrat, it's great to hear that :)
AFAIK all of the potential acceleration should be available on the FFMPEG level, but in order to unleash it we need to resolve 2 issues:

  • First one mentioned by @Zulko

We'd need a very involved developer to fix the binary management problem, ideally by having moviepy come with reliable ffmpeg/Imagemagick versions when pip-installed, and/or by expanding tests for different OSes (this might already be largely in place) and ffmpeg releases. Not sure how we'd find that person - could be either someone who really needs it fixed, or looking for a student project. In that last case we'd still need someone from the project available to provide context and reviews.

  • The second is to migrate the project to FFMPEG 5.0.

I know that it might not be the thing that you looking for but I'll be helpful if you give it a try :)

Btw @keikoro you seem to be one of the most active contributors around here. Can you help me with creating the proper structure for the project to enable more people?

@ShakedDovrat
Copy link

ShakedDovrat commented Feb 12, 2023

Thanks @B3QL. I must say that what you are describing is far from my field of expertise. But I see why this might be the most efficient approach.

I was thinking about something easier, which is to separate frames processing/rendering from the video writing, which will enable usage of Python's multiprocessing on each frame (i.e. call get_frame concurrently), while still writing the video frames to file serially. This by itself should accelerate the processing a few times fold, from my understanding. It will not require any change to the relationship between moviepy and ffmpeg.

Given that "a very involved developer" is hard to find for the kind of work @Zulko is talking about, Do you think a change such as what I propose can be accepted?

@B3QL
Copy link
Contributor Author

B3QL commented Feb 13, 2023

@ShakedDovrat unfortunately in the current situation there is no guarantee that the proposed feature will make it to the master.
I don't know for sure but it might be problematic due to ongoing work in API 2.0 #1089

IMHO you can open a separate issue for the acceleration, describe the approach, and ask for feedback :)

@keikoro keikoro added the project-admin Anything to do with the administration & organisation of moviepy. I.e. project "meta". label Jun 21, 2023
@B3QL
Copy link
Contributor Author

B3QL commented Jun 22, 2023

Hi all,
since I failed with constructing the team and oversee the project
the momentum is lost.

I opened the PR to let know the broader audience about the project's state, please review it.
#1998

Thanks for all the contributions to the project and overall support so far.

@davidbernat
Copy link

Let me throw a wild pitch into this mix, @B3QL. My experience using MoviePy for one year is that there is something fundamentally lacking in its design, despite being invaluable to the Python language and open source. It does not compete with heavier editing tools (some of which may have open source APIs) nor does it compete with heavier production or render tools (an API into Blender can do a lot, for instance). And the opening and closing and clipping and cropping of movie files would be a far more constrained, though truly essential, smaller package, which MoviePy does not want to be. If I were to "take over" the construction (team) of "Movies in Python 2024", I would argue, and organize the team around (our) committee, to first-and-foremost refactor MoviePy to be "native Cloud Function" in design, and operate a pay-for service (via my LLC, or our open source) to execute those services in the cloud IaaS environment. I believe we would all see the growth and sustenance of such a model (and microservices architecture) (think RedHat Linux model) and the natural "room to grow" "Movies in Python 2024" into AI and APIs outbound. I would be delighted to "man" that team were the commitment small (a few hours per month) and objectives slow and time bound by external factors determined by (our) "construction team". What do we think? Form a quorum? 🙋‍♂️⭐

My LLC is Starlight, by the way. You are all welcome to email me in my email address provided in my GitHub bio.

@davidbernat
Copy link

Looking good so far, @OsaAjani. Are you ready for me to provide input with the Examples page? cc: @alexdobrenko There are a few of us that will be peer reviewing the updates to the documentation so tagging you in this post as well.

@OsaAjani
Copy link
Collaborator

OsaAjani commented Aug 8, 2023

IMO in order to help "MoviePy project survive" I think type hints should be championed. I use this package occasionally and never remember the syntax.

I very much agree, I just didn't have to time to add proper typing, but it would be a very nice touch for some v2.1.

Looking good so far, @OsaAjani. Are you ready for me to provide input with the Examples page? cc: @alexdobrenko There are a few of us that will be peer reviewing the updates to the documentation so tagging you in this post as well.

As I didn't received responses to my last post on how to organize things, and because I really wont have time for a few weeks, I have just opened the PR with my final shot at the v2.0. I will add everyone involved to my repo so people can fix what need to be fixed and push to keep the PR up to date.

PS: If anyone want to participate and didn't received an invitation to become collaborator on my repo, do not hesitate to tag me and ask me to add you

@davidbernat
Copy link

@OsaAjani The invitation to the new repository you issued me has expired. Can you re-send please?

@HasseM
Copy link

HasseM commented Oct 11, 2023

Hope you guys also think about moviepy's performance. I'm currently looking at alternatives for moviepy just because the waiting times are really frustrating. A 11 seconds clip with some text and a moving image takes 581 seconds to render. Then I look at it, consider moving the text up/down a bit and wait another 591 seconds. Takes me a week to build a script for a video of 2 minutes! My PC is an 12900KS (i9) with RTX3090 and 128GB DDR5. So really no problems there. (yes, Im using nvidia ffmeg settings).

To get script generated video's right, people need to be able to run short & fast iterations just to look at it for the next iteration.

When people actually save time, it is easier for them to contribute as well.....

@davidbernat
Copy link

I agree. @HasseM. Ping me with an email if you want to chat (you can find this online). We had discussed this but the community here wanted to focus their energy elsewhere. I am working on a roadmap for a cloud-based python production facility for the end of 2024. The community here will eventually come around to my build. ;-) In the spirit of friendly competition.

@HasseM
Copy link

HasseM commented Oct 11, 2023

@davidbernat , yes I read your plans above. I'm an entrepeneur myself and I would for sure follow your route from a business perspective. And money coming in, means more project support! But as a user I won't follow that route. I'm working on some automated video pipelines that I want to run on my local machine. So it interacts with locally running stable diffusion models and Llama LLM model, TTS models and such. Reasons is simple: I don't want to be dependend on external parties changing stuff. So as long as I can run it locally, it's fine. When I can run it locally, I would be happy to move it over to a machine in the cloud that does run the automated tasks 24/7 (not just the video generation, also my other python scripts). But I can simply put it on a vps for that.

I'm not sure why moviepy is so extremely slow. For sure you need to fix that if you want your plans to succeed. Just putting it on a cloud does not solve that problem. I would love to try it if you have something to try.

@davidbernat
Copy link

Haven't read your details. In my experience, MoviePy does not respect the optimization need to only re-encode when necessary. It essentially is a cache of the most recently re-encoded frames; but then most operations launch re-encoding, which is slow. If that is not your problem then I am not helpful and I will revisit your problem when I cross that bridge. It is great that you respect the open source community and respect to building it up. The MoviePy team did great work.

@HasseM
Copy link

HasseM commented Oct 11, 2023

@davidbernat Yes, MoviePy is great in it's basis. Especially in these times. The whole point of script based video generation is to replay your script with different inputs and get a new video out. Combine it with all the AI stuff thats popping up and you can immediately see the value of MoviePy. New businesses can be build with it!

My point is that time is also value. So the process of creating a script should be effective as well. It currently definitely is not. And I see many other people complain on the slowness without real solutions.

So for a project like this to attract more users and get more support, it needs to add more value. Once the process of writing MoviePy scripts becomes effective, this whole project will likely take-off. There is currently an opportunity to become the No #1 video generation tool.

@davidbernat
Copy link

...Yes. Nobody ever asked me what I was actually building. They just shot it down as outside the community.
There is a hang-up in the entrepreneurial community currently how they drive customer innovation on the product side.
My company is very fortunate in that we get to have customers reach out to us. Otherwise our build will not work.

@OsaAjani
Copy link
Collaborator

Hope you guys also think about moviepy's performance. I'm currently looking at alternatives for moviepy just because the waiting times are really frustrating. A 11 seconds clip with some text and a moving image takes 581 seconds to render. Then I look at it, consider moving the text up/down a bit and wait another 591 seconds. Takes me a week to build a script for a video of 2 minutes! My PC is an 12900KS (i9) with RTX3090 and 128GB DDR5. So really no problems there. (yes, Im using nvidia ffmeg settings).

To get script generated video's right, people need to be able to run short & fast iterations just to look at it for the next iteration.

When people actually save time, it is easier for them to contribute as well.....

I wan say that for me performances are absolutely the next thing to work on, but to do so we needed the new API to be released first, and the documentation to be updated in order to keep moviepy usable in the meantime.

@Zulko any news on the review process ? I will have some free time in November if you need help.

@Zulko
Copy link
Owner

Zulko commented Oct 31, 2023

Sorry for the radio silence. I should have time this weekend. I also had to use Moviepy recently that will help me re-contextualize.

@davidbernat
Copy link

@Zulko my statements stand. Please cc me. Thank you for re-engaging @Zulko @OsaAjani

@OsaAjani
Copy link
Collaborator

OsaAjani commented Oct 31, 2023 via email

@Dotrar
Copy link

Dotrar commented Jan 12, 2024

Just adding to this (as my fledgeling startup uses moviepy, we need to both succeed :) )

Have you thought about adding to tidelift? imageio is on tidelift.

Alternatively, one can just use https://opencollective.com/

@anoncodemonkey
Copy link

Hello guys,

My startup is using moviepy as a tool(AI agent) to generate videos. We would love to help and participate in making moviepy better so that it can compete with davinci or premier pro, but run programmatically. We can have moviepy templates, akin to premier pro templates and that can be a revenue source for the project.

I would love to contribute more, whom shall I talk to?

@davidbernat
Copy link

Hi @afeezaziz. Happy to discuss. I have moved away from moviepy to direct ffmpeg because of speed improvements.
Find my email address and send me an email please.

@keikoro
Copy link
Collaborator

keikoro commented May 27, 2024

General question: should it be possible to set up MoviePy with Poetry in future?

I shot my last dev environment and currently seem unable to get it working again with the old instructions – not sure if they are outdated (will check @OsaAjani's work next) but I find them hard to debug either way because I hardly ever use pip anymore these days, much less install projects with setup.py.

@keikoro keikoro mentioned this issue Jun 7, 2024
2 tasks
@steinathan
Copy link

@keikoro I use moviepy with poetry

image

@aperture147
Copy link

Hello guys,

My startup is using moviepy as a tool(AI agent) to generate videos. We would love to help and participate in making moviepy better so that it can compete with davinci or premier pro, but run programmatically. We can have moviepy templates, akin to premier pro templates and that can be a revenue source for the project.

I would love to contribute more, whom shall I talk to?

What about libopenshot? I'm using their Python wrapper with a decent performance.

@keikoro keikoro mentioned this issue Dec 4, 2024
@OsaAjani
Copy link
Collaborator

Thank you for your contributions and for reporting issues in this repository. With the release of v2, which introduces significant changes to the codebase and API, we’ve reviewed the backlog of open PRs and issues. Due to the length of the backlog and the likelihood that many of these are either fixed or no longer applicable, we’ve made the decision to close all previous PRs and issues.

If you believe that any of these are still relevant to the current version or if you'd like to reopen a related discussion, please feel free to create a new issue or pull request, referencing the old one.

Thank you for your understanding and continued support!

@davidbernat
Copy link

We have migrated to our own private alternative to MoviePy with future revisions being published into the open source as demand and opportunity arises. Situations are difficult these days with GitHub bots modulating the comment threads of other open source programs and the unresolved issues regarding secure email and secure cloud provider. Not a fan of lots of the utilities and personnel out there in the front two waves of open source in the AI spectra these days. Please note that we no longer subscribe to these threads owned here and have not followed along with their posted information for nearly two years now for our own security. If you wish to know what we do with this project please star this repository FFMPEG.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
project-admin Anything to do with the administration & organisation of moviepy. I.e. project "meta". question Questions regarding functionality, usage
Projects
None yet
Development

No branches or pull requests