mirror of
https://github.com/zebrajr/faceswap.git
synced 2026-01-15 12:15:15 +00:00
* FaceSwap 3 (#1515) * Update extract pipeline * Update requirements + setup for nvidia * Remove allow-growth option * tf.keras to keras updates * lib.model.losses - Port + fix all loss functions for Keras3 * lib.model - port initializers, layers. normalization to Keras3 * lib.model.autoclip to Keras 3 * Update mixed precision layer storage * model file to .keras format * Restructure nn_blocks to initialize layers in __init__ * Tensorboard - Trainer: Add Torch compatible Tensorboard callbacks - GUI event reader remove TF dependency * Loss logging - Flush TB logs on save - Replace TB live iterator for GUI * Backup models on total loss drop rather than per side * Update all models to Keras3 Compat * Remove lib.model.session * Update clip ViT to Keras 3 * plugins.extract.mask.unet-dfl - Fix for Keras3/Torch backend * Port AdaBelief to Keras 3 * setup.py: - Add --dev flag for dev tool install * Fix Keras 3 syntax * Fix LR Finder for Keras 3 * Fix mixed precision switching for Keras 3 * Add more optimizers + open up config setting * train: Remove updating FS1 weights to FS2 models * Alignments: Remove support for legacy .json files * tools.model: - Remove TF Saved Format saving - Fix Backup/Restore + Nan-Scan * Fix inference model creation for Keras 3 * Preview tool: Fix for Keras3 * setup.py: Configure keras backend * train: Migration of FS2 models to FS3 * Training: Default coverage to 100% * Remove DirectML backend * Update setup for MacOS * GUI: Force line reading to UTF-8 * Remove redundant Tensorflow references * Remove redundant code * Legacy model loading: Fix TFLamdaOp scalar ops and DepthwiseConv2D * Add vertical offset option for training * Github actions: Add more python versions * Add python version to workflow names * Github workflow: Exclude Python 3.12 for macOS * Implement custom training loop * Fs3 - Add RTX5xxx and ROCm 6.1-6.4 support (#1511) * setup.py: Add Cuda/ROCm version select options * bump minimum python version to 3.11 * Switch from setup.cgf to pyproject.toml * Documentation: Update all docs to use automodapi * Allow sysinfo to run with missing packages + correctly install tk under Linux * Bugfix: dot naming convention in clip models * lib.config: Centralise globally rather than passing as object - Add torch DataParallel for multi-gpu training - GUI: Group switches together when generating cli args - CLI: Remove deprecated multi-character argparse args - Refactor: - Centralise tensorboard reading/writing + unit tests - Create trainer plugin interfaces + add original + distributed * Update installers
40 lines
1.3 KiB
Python
40 lines
1.3 KiB
Python
#!/usr/bin/env python3
|
|
""" Sanity checks for Faceswap. """
|
|
|
|
import inspect
|
|
import sys
|
|
|
|
import pytest
|
|
import keras
|
|
import torch
|
|
|
|
from lib.utils import get_backend
|
|
from lib.system.system import VALID_KERAS, VALID_PYTHON, VALID_TORCH
|
|
|
|
_BACKEND = get_backend().upper()
|
|
|
|
_LIBS = (VALID_KERAS + (keras.__version__, ),
|
|
VALID_PYTHON + (sys.version, ),
|
|
VALID_TORCH + (torch.__version__, ))
|
|
_IDS = [f"{x}[{_BACKEND}" for x in ("keras", "python", "torch")]
|
|
|
|
|
|
@pytest.mark.parametrize(["min_vers", "max_vers", "installed_vers"], _LIBS, ids=_IDS)
|
|
def test_libraries(min_vers: tuple[int, int],
|
|
max_vers: tuple[int, int],
|
|
installed_vers: str) -> None:
|
|
""" Sanity check to ensure that we are running on a valid libraries """
|
|
installed = tuple(int(x) for x in installed_vers.split(".")[:2])
|
|
assert min_vers <= installed <= max_vers
|
|
|
|
|
|
@pytest.mark.parametrize('dummy', [None], ids=[_BACKEND])
|
|
def test_backend(dummy): # pylint:disable=unused-argument
|
|
""" Sanity check to ensure that Keras backend is returning the correct object type. """
|
|
with keras.device("cpu"):
|
|
test_var = keras.Variable((1, 1, 4, 4), trainable=False)
|
|
mod = inspect.getmodule(test_var)
|
|
assert mod is not None
|
|
lib = mod.__name__.split(".")[0]
|
|
assert lib == "keras"
|