My new favorite hobby is making trailers for films that don’t exist. In this blog post, I’ll walk you through how I make these AI movies, and how you can too.
Bugsy Shadows — A New York Mystery:
Vanderbilt Express by Wes Anderson:
Planet Zearth narrated by David Ai-ttenborough (skip to 1:40 for the fight scene):
Script
It all starts with the script. Like any good AI filmmaker, let’s ask ChatGPT for a rough draft. Here’s the conversation I had with GPT-4 to create the David Attenborough movie:
ChatGPT is a solid starting point, but I find the scripts need a bit of a human touch (I thought it would be funnier if the glow leopard encounters a penguin rather than a fungi).
GPT is really good at silly puns. or at least better than me. Here’s a chat I had to create a Barbie-Oppenheimer crossover:
Note that the AI is good at brainstorming a lot of ideas fast. But many of these scripts are missing something that’s hard to put a finger on. That’s where us humans come in :)
Narrator
Phase II — let’s bring in a narrator to our production. There are two ways you can do this: the break the terms of service way, and the this is what you’re supposed to do way. I shouldn’t talk much about the first way, but it may involve finding a YouTube clip of an speaker you like, downloading it as an mp3 using pytube, uploading it into audacity and trimming the best parts, and then uploading to ElevenLabs voice cloning feature.
The second way is to use a community generated voice, which are pretty good too. I use [Ixel] Male older American voice, fairly deep too as a narrator for a few of these videos — he makes a good trailer narrator.
Videos + Music + Editing (the fun part)
Now comes the fun part: making the videos and music, and stitching everything together. Open up iMovie and start a new movie project.
Open up a terminal and clone the ai-studio repo:
git clone https://github.com/cbh123/ai-studio
cd ai-studio
Install Replicate:
pip install replicate
export REPLICATE_API_TOKEN=<your-token>
If you don’t have an API token, you can create a Replicate account here.
Optionally, change the PROJECT_NAME
on line 7 in main.py
to a project name of your choice. This tells ai studio where to save your output.
Now, you can run the script with this command, and the prompts will save to the ai-studio/videos/<project-name>
directory:
python main.py "prompt for your content" <number-of-outputs> --type <video/music> --style <a-style-that-you-want-appended-to-all-videos> &
For example, here’s how to create 3 videos of a glowing leopard:
python main.py "bioluminescent leopards walking in the forest" 3 --type video --style "national geographic, 4k &"
I always add a
&
to the end of the command so that it runs in the background. This way you can send off a bunch of different requests to Replicate without having to open up new terminals or wait for the predictions to finish. To see progress, you can runtail -F studio.log
to tail the logs (quit withctrl+c
)
As for the kinds of prompts you should use to create videos with——you’re going to need a bit of trial and error. But to get started, let’s ask our AI friend. This GPT-4 prompt works decently well (in the same chat where you created the script):
I want to create a series of videos to make this trailer, and I'd like your help describing what the videos should look like for my text-to-video model. Can you describe all the videos I'll need to create as if you were sending it as a prompt to a text-to-video model?
Some rules:
- the text-to-video model only makes videos with no sound. so no need to describe the sound
- If the video features a character, can you describe them? instead of saying names, describe the character. Remember, this text-to-video model doesn't know who the characters are.
- NO NAMES! Just describe the character. Don't say "John", say "a man in a suit"
- Don't say action verbs. Just describe in plain detail what's in the video
This is a decent starting off point, but I’d encourage you to experiment with the prompts and styles. My friend fofrAI got my started with the following parameters for zeroscope, but feel free to play with these too.
{
num_frames: 24, # zeroscrope struggles with higher values here
fps: 12, # 2s videos
width: 576,
height: 320,
guidance_scale: 12.5,
num_inference_steps: 50,
model: '576w',
negative_prompt: 'noisy, washed out, ugly, distorted, low quality, garish',
prompt: '<your-prompt>'
}
So now my workflow looks like a lot of this:
“Hmmm, I want to see a shot of a family before we show individual characters”
Run:
python main.py "a family wearing fancy clothes in a palatial room" --style "wide angle, wes anderson, colorful" --type video 3 &
Then I decided that the “disillusioned inventor, Augustus” needed to be frustrated with his progress creating the worlds quietest blender:
python main.py "a man in a suit, frustrated, hands on head" --style "wes anderson, colorful" --type video 2 &
Creating the music is a similar process. Instead of --type video
, it’s --type music
. Also note that --style
doesn’t do anything for music generation.
Here’s the prompt I used for the Wes Anderson trailer:
python main.py "upbeat, classical music" --type music 2 &
Now that we have a nice selection of narration, video clips, and music, it’s a matter of dragging into iMovie and iterating from there. This process looks a lot like this. A lot of dragging, dropping, shuffling, and then creating new videos and repeating:
I like this trick that fades out the sound:
Can’t wait to see what you make!
Tips
-
The
--style
is helpful for keeping a consistent, um, style. I’d play with prompter to find some styles that might fit. Some styles I’ve had success with:- macro
- film noir
- black and white
- wes anderson
- national geographic
- deep ocean
- Generally I run 2-3 minimum videos per generation. The results can be off sometimes, so it’s nice to be able to pick the best ones to drag into iMovie.
-
Don’t forget the
&
at the end of the command! This makes the python script run in the background. - Within VSCode, the alt+cmd+R shortcut is really nice for opening up the content before pulling into iMovie. Example: