Deep-Live-Cam/README.md

383 lines
15 KiB
Markdown
Raw Normal View History

2024-10-21 16:14:39 +08:00
<h1 align="center">Deep-Live-Cam</h1>
2024-09-28 23:23:29 +08:00
<p align="center">
Real-time face swap and video deepfake with a single click and only a single image.
</p>
2024-09-25 20:12:09 +08:00
2024-11-14 19:47:35 +08:00
<p align="center">
<a href="https://trendshift.io/repositories/11395" target="_blank"><img src="https://trendshift.io/api/badge/repositories/11395" alt="hacksider%2FDeep-Live-Cam | Trendshift" style="width: 250px; height: 55px;" width="250" height="55"/></a>
</p>
2024-09-28 23:23:29 +08:00
<p align="center">
2025-01-11 23:33:26 +08:00
<img src="media/demo.gif" alt="Demo GIF" width="800">
2024-09-28 23:23:29 +08:00
</p>
2024-01-27 22:20:15 +08:00
2025-01-18 22:23:08 +08:00
## Disclaimer
2025-01-18 22:27:46 +08:00
2025-01-29 14:00:41 +08:00
This deepfake software is designed to be a productive tool for the AI-generated media industry. It can assist artists in animating custom characters, creating engaging content, and even using models for clothing design.
We are aware of the potential for unethical applications and are committed to preventative measures. A built-in check prevents the program from processing inappropriate media (nudity, graphic content, sensitive material like war footage, etc.). We will continue to develop this project responsibly, adhering to the law and ethics. We may shut down the project or add watermarks if legally required.
2025-01-29 14:02:07 +08:00
- Ethical Use: Users are expected to use this software responsibly and legally. If using a real person's face, obtain their consent and clearly label any output as a deepfake when sharing online.
2025-01-29 14:00:41 +08:00
2025-01-29 14:02:07 +08:00
- Content Restrictions: The software includes built-in checks to prevent processing inappropriate media, such as nudity, graphic content, or sensitive material.
2025-01-29 14:00:41 +08:00
2025-01-29 14:02:07 +08:00
- Legal Compliance: We adhere to all relevant laws and ethical guidelines. If legally required, we may shut down the project or add watermarks to the output.
2025-01-29 14:00:41 +08:00
2025-01-29 14:02:07 +08:00
- User Responsibility: We are not responsible for end-user actions. Users must ensure their use of the software aligns with ethical standards and legal requirements.
2025-01-29 14:00:41 +08:00
By using this software, you agree to these terms and commit to using it in a manner that respects the rights and dignity of others.
Users are expected to use this software responsibly and legally. If using a real person's face, obtain their consent and clearly label any output as a deepfake when sharing online. We are not responsible for end-user actions.
2025-01-18 22:23:08 +08:00
2025-06-16 00:49:49 +08:00
## Exclusive v2.1 Quick Start - Pre-built (Windows/Mac Silicon)
2025-04-17 12:04:10 +08:00
2025-05-05 08:30:44 +08:00
<a href="https://deeplivecam.net/index.php/quickstart"> <img src="media/Download.png" width="285" height="77" />
2025-04-17 12:04:10 +08:00
2025-06-16 00:49:49 +08:00
##### This is the fastest build you can get if you have a discrete NVIDIA or AMD GPU or Mac Silicon, And you'll receive special priority support.
2025-04-17 12:04:10 +08:00
2025-06-23 17:06:34 +08:00
###### These Pre-builts are perfect for non-technical users or those who don't have time to, or can't manually install all the requirements. Just a heads-up: this is an open-source project, so you can also install it manually.
2025-01-18 22:23:08 +08:00
2025-01-11 23:33:26 +08:00
## TLDR; Live Deepfake in just 3 Clicks
![easysteps](https://github.com/user-attachments/assets/af825228-852c-411b-b787-ffd9aac72fc6)
1. Select a face
2. Select which camera to use
3. Press live!
2025-01-07 18:48:03 +08:00
2025-02-04 23:50:54 +08:00
## Features & Uses - Everything is in real-time
### Mouth Mask
2025-01-16 01:15:23 +08:00
**Retain your original mouth for accurate movement using Mouth Mask**
2025-01-16 01:15:23 +08:00
<p align="center">
<img src="media/ludwig.gif" alt="resizable-gif">
</p>
### Face Mapping
2025-01-16 01:15:23 +08:00
**Use different faces on multiple subjects simultaneously**
2025-01-16 01:15:23 +08:00
<p align="center">
<img src="media/streamers.gif" alt="face_mapping_source">
</p>
### Your Movie, Your Face
**Watch movies with any face in real-time**
2025-01-16 01:15:23 +08:00
<p align="center">
<img src="media/movie.gif" alt="movie">
</p>
2025-01-15 03:03:02 +08:00
### Live Show
2025-01-16 01:15:23 +08:00
**Run Live shows and performances**
2025-01-15 03:03:02 +08:00
2025-01-16 01:15:23 +08:00
<p align="center">
<img src="media/live_show.gif" alt="show">
</p>
### Memes
2025-02-04 23:38:36 +08:00
**Create Your Most Viral Meme Yet**
2025-01-16 01:15:23 +08:00
<p align="center">
2025-01-16 01:18:21 +08:00
<img src="media/meme.gif" alt="show" width="450">
2025-01-16 01:15:23 +08:00
<br>
<sub>Created using Many Faces feature in Deep-Live-Cam</sub>
</p>
2025-01-15 03:03:02 +08:00
2025-02-04 23:38:36 +08:00
### Omegle
**Surprise people on Omegle**
<p align="center">
2025-02-06 13:10:32 +08:00
<video src="https://github.com/user-attachments/assets/2e9b9b82-fa04-4b70-9f56-b1f68e7672d0" width="450" controls></video>
2025-02-04 23:38:36 +08:00
</p>
2024-09-25 20:12:09 +08:00
## Installation (Manual)
2025-01-06 20:21:00 +08:00
2025-06-29 14:58:13 +08:00
**Please be aware that the installation requires technical skills and is not for beginners. Consider downloading the quickstart version.**
2024-12-01 02:07:38 +08:00
<details>
<summary>Click to see the process</summary>
### Installation
2024-09-25 20:12:09 +08:00
This is more likely to work on your computer but will be slower as it utilizes the CPU.
2025-01-06 20:21:00 +08:00
**1. Set up Your Platform**
2025-06-29 14:58:13 +08:00
- Python (3.11 recommended)
2025-01-06 20:21:00 +08:00
- pip
- git
- [ffmpeg](https://www.youtube.com/watch?v=OlNWCpFdVMA) - ```iex (irm ffmpeg.tc.ht)```
2025-01-06 20:21:00 +08:00
- [Visual Studio 2022 Runtimes (Windows)](https://visualstudio.microsoft.com/visual-cpp-build-tools/)
2025-01-06 20:21:00 +08:00
**2. Clone the Repository**
2024-09-25 20:12:09 +08:00
```bash
git clone https://github.com/hacksider/Deep-Live-Cam.git
cd Deep-Live-Cam
```
2024-09-25 20:12:09 +08:00
2025-01-06 20:21:00 +08:00
**3. Download the Models**
2024-09-25 20:12:09 +08:00
1. [GFPGANv1.4](https://huggingface.co/hacksider/deep-live-cam/resolve/main/GFPGANv1.4.pth)
2025-01-14 02:56:03 +08:00
2. [inswapper\_128\_fp16.onnx](https://huggingface.co/hacksider/deep-live-cam/resolve/main/inswapper_128_fp16.onnx)
2024-09-25 20:12:09 +08:00
Place these files in the "**models**" folder.
**4. Install Dependencies**
We highly recommend using a `venv` to avoid issues.
2025-05-01 05:09:12 +08:00
For Windows:
2024-09-25 20:12:09 +08:00
```bash
python -m venv venv
2025-06-28 01:09:00 +08:00
source ./venv/bin/activate
2023-09-24 21:36:57 +08:00
pip install -r requirements.txt
```
2025-05-01 05:09:12 +08:00
For Linux:
```bash
# Ensure you use the installed Python 3.10
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
```
2024-09-25 20:12:09 +08:00
**For macOS:**
Apple Silicon (M1/M2/M3) requires specific setup:
2024-09-25 20:12:09 +08:00
```bash
2025-06-29 14:58:13 +08:00
# Install Python 3.11 (specific version is important)
brew install python@3.11
# Install tkinter package (required for the GUI)
2024-08-15 03:22:06 +08:00
brew install python-tk@3.10
2025-06-29 14:58:13 +08:00
# Create and activate virtual environment with Python 3.11
python3.11 -m venv venv
source venv/bin/activate
# Install dependencies
pip install -r requirements.txt
2024-08-15 03:22:06 +08:00
```
** In case something goes wrong and you need to reinstall the virtual environment **
```bash
# Deactivate the virtual environment
rm -rf venv
# Reinstall the virtual environment
python -m venv venv
source venv/bin/activate
# install the dependencies again
pip install -r requirements.txt
2024-08-15 03:22:06 +08:00
```
2024-09-25 20:12:09 +08:00
**Run:** If you don't have a GPU, you can run Deep-Live-Cam using `python run.py`. Note that initial execution will download models (~300MB).
2025-01-06 20:21:00 +08:00
### GPU Acceleration
2023-09-24 21:36:57 +08:00
2024-09-25 20:12:09 +08:00
**CUDA Execution Provider (Nvidia)**
2023-09-24 21:36:57 +08:00
2025-06-09 00:34:26 +08:00
1. Install [CUDA Toolkit 12.8.0](https://developer.nvidia.com/cuda-12-8-0-download-archive)
2. Install [cuDNN v8.9.7 for CUDA 12.x](https://developer.nvidia.com/rdp/cudnn-archive) (required for onnxruntime-gpu):
- Download cuDNN v8.9.7 for CUDA 12.x
- Make sure the cuDNN bin directory is in your system PATH
3. Install dependencies:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2025-06-09 00:34:26 +08:00
pip install -U torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu128
2023-09-24 21:36:57 +08:00
pip uninstall onnxruntime onnxruntime-gpu
2025-06-15 02:22:00 +08:00
pip install onnxruntime-gpu==1.21.0
2023-09-24 21:36:57 +08:00
```
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
3. Usage:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
python run.py --execution-provider cuda
```
2024-09-25 20:12:09 +08:00
**CoreML Execution Provider (Apple Silicon)**
2023-09-24 21:36:57 +08:00
Apple Silicon (M1/M2/M3) specific installation:
1. Make sure you've completed the macOS setup above using Python 3.10.
2. Install dependencies:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
pip uninstall onnxruntime onnxruntime-silicon
pip install onnxruntime-silicon==1.13.1
```
2025-01-06 20:21:00 +08:00
3. Usage (important: specify Python 3.10):
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
python3.10 run.py --execution-provider coreml
2023-09-24 21:36:57 +08:00
```
**Important Notes for macOS:**
- You **must** use Python 3.10, not newer versions like 3.11 or 3.13
- Always run with `python3.10` command not just `python` if you have multiple Python versions installed
- If you get error about `_tkinter` missing, reinstall the tkinter package: `brew reinstall python-tk@3.10`
- If you get model loading errors, check that your models are in the correct folder
- If you encounter conflicts with other Python versions, consider uninstalling them:
```bash
# List all installed Python versions
brew list | grep python
# Uninstall conflicting versions if needed
brew uninstall --ignore-dependencies python@3.11 python@3.13
2025-06-29 14:58:13 +08:00
# Keep only Python 3.11
brew cleanup
```
2024-09-25 20:12:09 +08:00
**CoreML Execution Provider (Apple Legacy)**
2023-09-24 21:36:57 +08:00
2024-09-25 20:12:09 +08:00
1. Install dependencies:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
pip uninstall onnxruntime onnxruntime-coreml
2025-06-29 14:58:13 +08:00
pip install onnxruntime-coreml==1.21.0
2023-09-24 21:36:57 +08:00
```
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
2. Usage:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
python run.py --execution-provider coreml
```
2024-09-25 20:12:09 +08:00
**DirectML Execution Provider (Windows)**
2023-09-24 21:36:57 +08:00
2024-09-25 20:12:09 +08:00
1. Install dependencies:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
pip uninstall onnxruntime onnxruntime-directml
2025-06-29 14:58:13 +08:00
pip install onnxruntime-directml==1.21.0
2023-09-24 21:36:57 +08:00
```
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
2. Usage:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
python run.py --execution-provider directml
```
2024-09-25 20:12:09 +08:00
**OpenVINO™ Execution Provider (Intel)**
2023-09-24 21:36:57 +08:00
2024-09-25 20:12:09 +08:00
1. Install dependencies:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
pip uninstall onnxruntime onnxruntime-openvino
2025-06-29 14:58:13 +08:00
pip install onnxruntime-openvino==1.21.0
2023-09-24 21:36:57 +08:00
```
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
2. Usage:
2025-01-06 20:21:00 +08:00
2024-09-25 20:12:09 +08:00
```bash
2023-09-24 21:36:57 +08:00
python run.py --execution-provider openvino
```
</details>
2023-09-24 21:36:57 +08:00
2024-09-25 20:12:09 +08:00
## Usage
2023-09-24 21:36:57 +08:00
2024-09-25 20:12:09 +08:00
**1. Image/Video Mode**
2023-09-24 21:36:57 +08:00
2025-01-06 20:21:00 +08:00
- Execute `python run.py`.
- Choose a source face image and a target image/video.
- Click "Start".
- The output will be saved in a directory named after the target video.
2023-09-24 21:36:57 +08:00
2024-09-25 20:12:09 +08:00
**2. Webcam Mode**
2023-09-24 21:36:57 +08:00
2025-01-06 20:21:00 +08:00
- Execute `python run.py`.
- Select a source face image.
- Click "Live".
- Wait for the preview to appear (10-30 seconds).
- Use a screen capture tool like OBS to stream.
- To change the face, select a new source image.
2023-09-24 21:36:57 +08:00
2024-12-01 02:07:38 +08:00
## Command Line Arguments (Unmaintained)
2023-09-24 21:36:57 +08:00
```
options:
-h, --help show this help message and exit
-s SOURCE_PATH, --source SOURCE_PATH select a source image
-t TARGET_PATH, --target TARGET_PATH select a target image or video
2023-09-24 21:36:57 +08:00
-o OUTPUT_PATH, --output OUTPUT_PATH select output file or directory
--frame-processor FRAME_PROCESSOR [FRAME_PROCESSOR ...] frame processors (choices: face_swapper, face_enhancer, ...)
--keep-fps keep original fps
--keep-audio keep original audio
--keep-frames keep temporary frames
--many-faces process every face
--map-faces map source target faces
2024-12-24 14:21:32 +08:00
--mouth-mask mask the mouth region
2023-09-24 21:36:57 +08:00
--video-encoder {libx264,libx265,libvpx-vp9} adjust output video encoder
--video-quality [0-51] adjust output video quality
--live-mirror the live camera display as you see it in the front-facing camera frame
--live-resizable the live camera frame is resizable
2023-09-24 21:36:57 +08:00
--max-memory MAX_MEMORY maximum amount of RAM in GB
--execution-provider {cpu} [{cpu} ...] available execution provider (choices: cpu, ...)
--execution-threads EXECUTION_THREADS number of execution threads
-v, --version show program's version number and exit
```
Looking for a CLI mode? Using the -s/--source argument will make the run program in cli mode.
2024-12-29 05:32:54 +08:00
## Press
2025-01-06 20:21:00 +08:00
**We are always open to criticism and are ready to improve, that's why we didn't cherry-pick anything.**
- [*"Deep-Live-Cam goes viral, allowing anyone to become a digital doppelganger"*](https://arstechnica.com/information-technology/2024/08/new-ai-tool-enables-real-time-face-swapping-on-webcams-raising-fraud-concerns/) - Ars Technica
- [*"Thanks Deep Live Cam, shapeshifters are among us now"*](https://dataconomy.com/2024/08/15/what-is-deep-live-cam-github-deepfake/) - Dataconomy
- [*"This free AI tool lets you become anyone during video-calls"*](https://www.newsbytesapp.com/news/science/deep-live-cam-ai-impersonation-tool-goes-viral/story) - NewsBytes
- [*"OK, this viral AI live stream software is truly terrifying"*](https://www.creativebloq.com/ai/ok-this-viral-ai-live-stream-software-is-truly-terrifying) - Creative Bloq
- [*"Deepfake AI Tool Lets You Become Anyone in a Video Call With Single Photo"*](https://petapixel.com/2024/08/14/deep-live-cam-deepfake-ai-tool-lets-you-become-anyone-in-a-video-call-with-single-photo-mark-zuckerberg-jd-vance-elon-musk/) - PetaPixel
- [*"Deep-Live-Cam Uses AI to Transform Your Face in Real-Time, Celebrities Included"*](https://www.techeblog.com/deep-live-cam-ai-transform-face/) - TechEBlog
- [*"An AI tool that "makes you look like anyone" during a video call is going viral online"*](https://telegrafi.com/en/a-tool-that-makes-you-look-like-anyone-during-a-video-call-is-going-viral-on-the-Internet/) - Telegrafi
- [*"This Deepfake Tool Turning Images Into Livestreams is Topping the GitHub Charts"*](https://decrypt.co/244565/this-deepfake-tool-turning-images-into-livestreams-is-topping-the-github-charts) - Emerge
- [*"New Real-Time Face-Swapping AI Allows Anyone to Mimic Famous Faces"*](https://www.digitalmusicnews.com/2024/08/15/face-swapping-ai-real-time-mimic/) - Digital Music News
- [*"This real-time webcam deepfake tool raises alarms about the future of identity theft"*](https://www.diyphotography.net/this-real-time-webcam-deepfake-tool-raises-alarms-about-the-future-of-identity-theft/) - DIYPhotography
- [*"That's Crazy, Oh God. That's Fucking Freaky Dude... That's So Wild Dude"*](https://www.youtube.com/watch?time_continue=1074&v=py4Tc-Y8BcY) - SomeOrdinaryGamers
- [*"Alright look look look, now look chat, we can do any face we want to look like chat"*](https://www.youtube.com/live/mFsCe7AIxq8?feature=shared&t=2686) - IShowSpeed
2025-06-17 21:12:36 +08:00
- [*"They do a pretty good job matching poses, expression and even the lighting"*](https://www.youtube.com/watch?v=wnCghLjqv3s&t=551s) - TechLinked (LTT)
- [*"Als Sean Connery an der Redaktionskonferenz teilnahm"*](https://www.golem.de/news/deepfakes-als-sean-connery-an-der-redaktionskonferenz-teilnahm-2408-188172.html) - Golem.de (German)
2025-06-17 21:12:10 +08:00
2024-08-24 01:45:14 +08:00
2023-09-24 21:36:57 +08:00
## Credits
2025-01-06 20:21:00 +08:00
- [ffmpeg](https://ffmpeg.org/): for making video-related operations easy
- [deepinsight](https://github.com/deepinsight): for their [insightface](https://github.com/deepinsight/insightface) project which provided a well-made library and models. Please be reminded that the [use of the model is for non-commercial research purposes only](https://github.com/deepinsight/insightface?tab=readme-ov-file#license).
- [havok2-htwo](https://github.com/havok2-htwo): for sharing the code for webcam
- [GosuDRM](https://github.com/GosuDRM): for the open version of roop
- [pereiraroland26](https://github.com/pereiraroland26): Multiple faces support
- [vic4key](https://github.com/vic4key): For supporting/contributing to this project
- [kier007](https://github.com/kier007): for improving the user experience
- [qitianai](https://github.com/qitianai): for multi-lingual support
2025-01-06 20:21:00 +08:00
- and [all developers](https://github.com/hacksider/Deep-Live-Cam/graphs/contributors) behind libraries used in this project.
- Footnote: Please be informed that the base author of the code is [s0md3v](https://github.com/s0md3v/roop)
- All the wonderful users who helped make this project go viral by starring the repo ❤️
2024-12-29 05:32:54 +08:00
[![Stargazers](https://reporoster.com/stars/hacksider/Deep-Live-Cam)](https://github.com/hacksider/Deep-Live-Cam/stargazers)
2024-09-25 20:12:09 +08:00
2024-10-10 00:16:59 +08:00
## Contributions
2025-01-06 20:21:00 +08:00
2024-09-28 19:52:21 +08:00
![Alt](https://repobeats.axiom.co/api/embed/fec8e29c45dfdb9c5916f3a7830e1249308d20e1.svg "Repobeats analytics image")
2025-01-06 20:21:00 +08:00
2024-12-29 05:32:54 +08:00
## Stars to the Moon 🚀
2024-10-10 00:16:59 +08:00
<a href="https://star-history.com/#hacksider/deep-live-cam&Date">
<picture>
<source media="(prefers-color-scheme: dark)" srcset="https://api.star-history.com/svg?repos=hacksider/deep-live-cam&type=Date&theme=dark" />
<source media="(prefers-color-scheme: light)" srcset="https://api.star-history.com/svg?repos=hacksider/deep-live-cam&type=Date" />
<img alt="Star History Chart" src="https://api.star-history.com/svg?repos=hacksider/deep-live-cam&type=Date" />
</picture>
2025-03-29 03:23:49 +08:00
</a>