Skip to content

Latest commit

 

History

History
429 lines (338 loc) · 16.7 KB

INSTALL.md

File metadata and controls

429 lines (338 loc) · 16.7 KB

Installing faceswap

Prerequisites

Machine learning essentially involves a ton of trial and error. You're letting a program try millions of different settings to land on an algorithm that sort of does what you want it to do. This process is really really slow unless you have the hardware required to speed this up.

The type of computations that the process does are well suited for graphics cards, rather than regular processors. It is pretty much required that you run the training process on a desktop or server capable GPU. Running this on your CPU means it can take weeks to train your model, compared to several hours on a GPU.

Hardware Requirements

TL;DR: you need at least one of the following:

  • A powerful CPU
    • Laptop CPUs can often run the software, but will not be fast enough to train at reasonable speeds
  • A powerful GPU
    • Currently, Nvidia GPUs are fully supported
    • DirectX 12 AMD GPUs are supported on Windows through DirectML.
    • More modern AMD GPUs are supported on Linux through ROCm.
    • M-series Macs are supported through Tensorflow-Metal
    • OpenCL 1.2 support through PlaidML is deprecated and will be removed in a future update
    • If using an Nvidia GPU, then it needs to support at least CUDA Compute Capability 3.5. (Release 1.0 will work on Compute Capability 3.0) To see which version your GPU supports, consult this list: https://developer.nvidia.com/cuda-gpus Desktop cards later than the 7xx series are most likely supported.
  • A lot of patience

Supported operating systems

  • Windows 10/11 Windows 7 and 8 might work for Nvidia. Your mileage may vary. DirectML support is only available in Windows 10 onwards. Windows has an installer which will set up everything you need. See: https://github.com/deepfakes/faceswap/releases
  • Linux Most Ubuntu/Debian or CentOS based Linux distributions will work. There is a Linux install script that will install and set up everything you need. See: https://github.com/deepfakes/faceswap/releases
  • macOS Experimental support for GPU-accelerated, native Apple Silicon processing (e.g. Apple M1 chips). Installation instructions can be found further down this page. Intel based macOS systems should work, but you will need to follow the Manual Install instructions.
  • All operating systems must be 64-bit for Tensorflow to run.

Alternatively, there is a docker image that is based on Debian.

Important before you proceed

In its current iteration, the project relies heavily on the use of the command line, although a gui is available. if you are unfamiliar with command line tools, you may have difficulty setting up the environment and should perhaps not attempt any of the steps described in this guide. This guide assumes you have intermediate knowledge of the command line.

The developers are also not responsible for any damage you might cause to your own computer.

Linux and Windows Install Guide

Installer

Windows and Linux now both have an installer which installs everything for you and creates a desktop shortcut to launch straight into the GUI. You can download the installer from https://github.com/deepfakes/faceswap/releases.

If you have issues with the installer then read on for the more manual way to install faceswap on Windows.

Manual Install

Setting up faceswap can seem a little intimidating to new users, but it isn't that complicated, although a little time consuming. It is recommended to use Linux where possible as Windows will hog about 20% of your GPU Memory, making faceswap run a little slower, however using Windows is perfectly fine and 100% supported.

Prerequisites

Anaconda

Download and install the latest Python 3 Anaconda from: https://www.anaconda.com/download/. Unless you know what you are doing, you can leave all the options at default.

Git

Download and install Git for Windows: https://git-scm.com/download/win. Unless you know what you are doing, you can leave all the options at default.

Setup

Reboot your PC, so that everything you have just installed gets registered.

Anaconda

Set up a virtual environment

  • Open up Anaconda Navigator
  • Select "Environments" on the left hand side
  • Select "Create" at the bottom
  • In the pop up:
    • Give it the name: faceswap
    • IMPORTANT: Select python version 3.8
    • Hit "Create" (NB: This may take a while as it will need to download Python) Anaconda virtual env setup

Entering your virtual environment

To enter the virtual environment:

  • Open up Anaconda Navigator
  • Select "Environments" on the left hand side
  • Hit the ">" arrow next to your faceswap environment and select "Open Terminal" Anaconda enter virtual env

faceswap

  • If you are not already in your virtual environment follow these steps
  • Get the faceswap repo by typing: git clone --depth 1 https://github.com/deepfakes/faceswap.git
  • Enter the faceswap folder: cd faceswap

Easy install

  • Enter the command python setup.py and follow the prompts:
  • If you have issues/errors follow the Manual install steps below.

Manual install

Do not follow these steps if the Easy Install above completed succesfully. If you are using an Nvidia card make sure you have the correct versions of Cuda/cuDNN installed for the required version of Tensorflow

  • Install tkinter (required for the GUI) by typing: conda install tk
  • Install requirements:
    • For Nvidia GPU users: pip install -r ./requirements/requirements_nvidia.txt
    • For AMD GPU users: pip install -r ./requirements/requirements_amd.txt
    • For CPU users: pip install -r ./requirements/requirements_cpu.txt

Running faceswap

  • If you are not already in your virtual environment follow these steps
  • Enter the faceswap folder: cd faceswap
  • Enter the following to see the list of commands: python faceswap.py -h or enter python faceswap.py gui to launch the GUI

Create a desktop shortcut

A desktop shortcut can be added to easily launch straight into the faceswap GUI:

  • Open Notepad
  • Paste the following:
%USERPROFILE%\Anaconda3\envs\faceswap\python.exe %USERPROFILE%/faceswap/faceswap.py gui
  • Save the file to your desktop as "faceswap.bat"

Updating faceswap

It's good to keep faceswap up to date as new features are added and bugs are fixed. To do so:

  • If using the GUI you can go to the Help menu and select "Check for Updates...". If updates are available go to the Help menu and select "Update Faceswap". Restart Faceswap to complete the update.
  • If you are not already in your virtual environment follow these steps
  • Enter the faceswap folder: cd faceswap
  • Enter the following git pull --all
  • Once the latest version has downloaded, make sure your dependencies are up to date. There is a script to help with this: python update_deps.py

macOS (Apple Silicon) Install Guide

Prerequisites

OS

macOS 12.0+

XCode Tools

xcode-select --install

XQuartz

Download and install from:

Conda

Download and install the latest Conda env from:

Install Conda:

$ chmod +x ~/Downloads/Miniforge3-MacOSX-arm64.sh
$ sh ~/Downloads/Miniforge3-MacOSX-arm64.sh
$ source ~/miniforge3/bin/activate

Setup

Create and Activate the Environment

$ conda create --name faceswap python=3.9
$ conda activate faceswap

faceswap

  • Download the faceswap repo and enter the faceswap folder:
$ git clone --depth 1 https://github.com/deepfakes/faceswap.git
$ cd faceswap

Easy install

$ python setup.py
  • If you have issues/errors follow the Manual install steps below.

General Install Guide

Installing dependencies

Git

Git is required for obtaining the code and keeping your codebase up to date. Obtain git for your distribution from the git website.

Python

The recommended install method is to use a Conda3 Environment as this will handle the installation of Nvidia's CUDA and cuDNN straight into your Conda Environment. This is by far the easiest and most reliable way to setup the project.

Alternatively you can install Python (>= 3.7-3.9 64-bit) for your distribution (links below.) If you go down this route and are using an Nvidia GPU you should install CUDA (https://developer.nvidia.com/cuda-zone) and cuDNN (https://developer.nvidia.com/cudnn). for your system. If you do not plan to build Tensorflow yourself, make sure you install the correct Cuda and cuDNN package for the currently installed version of Tensorflow (Current release: Tensorflow 2.9. Release v1.0: Tensorflow 1.15). You can check for the compatible versions here: (https://www.tensorflow.org/install/source#gpu).

  • Python distributions:
    • apt/yum install python3 (Linux)
    • Installer (Windows)
    • brew install python3 (macOS)

Virtual Environment

It is highly recommended that you setup faceswap inside a virtual environment. In fact we will not generally support installations that are not within a virtual environment as troubleshooting package conflicts can be next to impossible.

If using Conda3 then setting up virtual environments is relatively straight forward. More information can be found at Conda Docs

If using a default Python distribution then virtualenv and virtualenvwrapper may help when you are not using docker.

Getting the faceswap code

It is recommended to clone the repo with git instead of downloading the code from http://github.com/deepfakes/faceswap and extracting it as this will make it far easier to get the latest code (which can be done from the GUI). To clone a repo you can either use the Git GUI for your distribution or open up a command prompt, enter the folder where you want to store faceswap and enter:

git clone https://github.com/deepfakes/faceswap.git

Setup

Enter your virtual environment and then enter the folder that faceswap has been downloaded to and run:

python setup.py

If setup fails for any reason you can still manually install the packages listed within the files in the requirements folder.

About some of the options

  • CUDA: For acceleration. Requires a good nVidia Graphics Card (which supports CUDA inside)
  • Docker: Provide a ready-made image. Hide trivial details. Get you straight to the project.
  • nVidia-Docker: Access to the nVidia GPU on host machine from inside container.

Docker Install Guide

Docker General

Click to expand!

CUDA with Docker in 20 minutes.

  1. Install Docker https://www.docker.com/community-edition

  2. Install Nvidia-Docker & Restart Docker Service https://github.com/NVIDIA/nvidia-docker

  3. Build Docker Image For faceswap

docker build -t deepfakes-gpu -f Dockerfile.gpu . 
  1. Mount faceswap volume and Run it a). without gui.tools.py gui not working.
nvidia-docker run --rm -it -p 8888:8888 \
    --hostname faceswap-gpu --name faceswap-gpu \
    -v /opt/faceswap:/srv \
    deepfakes-gpu
b). with gui. tools.py gui working.

Enable local access to X11 server

xhost +local:

Enable nvidia device if working under bumblebee

echo ON > /proc/acpi/bbswitch

Create container

nvidia-docker run -p 8888:8888 \
   --hostname faceswap-gpu --name faceswap-gpu \
   -v /opt/faceswap:/srv \
   -v /tmp/.X11-unix:/tmp/.X11-unix \
   -e DISPLAY=unix$DISPLAY \
   -e AUDIO_GID=`getent group audio | cut -d: -f3` \
   -e VIDEO_GID=`getent group video | cut -d: -f3` \
   -e GID=`id -g` \
   -e UID=`id -u` \
   deepfakes-gpu

Open a new terminal to interact with the project

docker exec -it deepfakes-gpu /bin/bash

Launch deepfakes gui (Answer 3 for NVIDIA at the prompt)

python3.8 /srv/faceswap.py gui

CUDA with Docker on Arch Linux

Click to expand!

Install docker

sudo pacman -S docker

The steps are same but Arch linux doesn't use nvidia-docker

create container

docker run -p 8888:8888 --gpus all --privileged -v /dev:/dev \  
            --hostname faceswap-gpu --name faceswap-gpu \
            -v /mnt/hdd2/faceswap:/srv \
            -v /tmp/.X11-unix:/tmp/.X11-unix \
            -e DISPLAY=unix$DISPLAY \
            -e AUDIO_GID=`getent group audio | cut -d: -f3` \
            -e VIDEO_GID=`getent group video | cut -d: -f3` \
            -e GID=`id -g` \
            -e UID=`id -u` \
            deepfakes-gpu

Open a new terminal to interact with the project

docker exec -it deepfakes-gpu /bin/bash

Launch deepfakes gui (Answer 3 for NVIDIA at the prompt)

With gui.tools.py gui working. Enable local access to X11 server

xhost +local:
python3.8 /srv/faceswap.py gui

A successful setup log, without docker.

INFO    The tool provides tips for installation
        and installs required python packages
INFO    Setup in Linux 4.14.39-1-MANJARO
INFO    Installed Python: 3.7.5 64bit
INFO    Installed PIP: 10.0.1
Enable  Docker? [Y/n] n
INFO    Docker Disabled
Enable  CUDA? [Y/n]
INFO    CUDA Enabled
INFO    CUDA version: 9.1
INFO    cuDNN version: 7
WARNING Tensorflow has no official prebuild for CUDA 9.1 currently.
        To continue, You have to build your own tensorflow-gpu.
        Help: https://www.tensorflow.org/install/install_sources
Are System Dependencies met? [y/N] y
INFO    Installing Missing Python Packages...
INFO    Installing tensorflow-gpu
......
INFO    Installing tqdm
INFO    Installing matplotlib
INFO    All python3 dependencies are met.
        You are good to go.

Run the project

Once all these requirements are installed, you can attempt to run the faceswap tools. Use the -h or --help options for a list of options.

python faceswap.py -h

or run with gui to launch the GUI

python faceswap.py gui

Proceed to ../blob/master/USAGE.md

Notes

This guide is far from complete. Functionality may change over time, and new dependencies are added and removed as time goes on.

If you are experiencing issues, please raise them in the faceswap Forum instead of the main repo. Usage questions raised in the issues within this repo are liable to be closed without response.