🚀 CVLFace预训练模型 (ADAFACE VIT BASE KPRPE WEBFACE12M)
CVLFace预训练模型基于ADAFACE VIT BASE KPRPE架构,在WEBFACE12M数据集上训练,可用于人脸识别任务,为相关研究和应用提供有力支持。
🚀 快速开始
from transformers import AutoModel
from huggingface_hub import hf_hub_download
import shutil
import os
import torch
import sys
def download(repo_id, path, HF_TOKEN=None):
os.makedirs(path, exist_ok=True)
files_path = os.path.join(path, 'files.txt')
if not os.path.exists(files_path):
hf_hub_download(repo_id, 'files.txt', token=HF_TOKEN, local_dir=path, local_dir_use_symlinks=False)
with open(os.path.join(path, 'files.txt'), 'r') as f:
files = f.read().split('\n')
for file in [f for f in files if f] + ['config.json', 'wrapper.py', 'model.safetensors']:
full_path = os.path.join(path, file)
if not os.path.exists(full_path):
hf_hub_download(repo_id, file, token=HF_TOKEN, local_dir=path, local_dir_use_symlinks=False)
def load_model_from_local_path(path, HF_TOKEN=None):
cwd = os.getcwd()
os.chdir(path)
sys.path.insert(0, path)
model = AutoModel.from_pretrained(path, trust_remote_code=True, token=HF_TOKEN)
os.chdir(cwd)
sys.path.pop(0)
return model
def load_model_by_repo_id(repo_id, save_path, HF_TOKEN=None, force_download=False):
if force_download:
if os.path.exists(save_path):
shutil.rmtree(save_path)
download(repo_id, save_path, HF_TOKEN)
return load_model_from_local_path(save_path, HF_TOKEN)
if __name__ == '__main__':
HF_TOKEN = 'YOUR_HUGGINGFACE_TOKEN'
path = os.path.expanduser('~/.cvlface_cache/minchul/cvlface_adaface_vit_base_kprpe_webface12m')
repo_id = 'minchul/cvlface_adaface_vit_base_kprpe_webface12m'
model = load_model_by_repo_id(repo_id, path, HF_TOKEN)
from torchvision.transforms import Compose, ToTensor, Normalize
from PIL import Image
img = Image.open('path/to/image.jpg')
trans = Compose([ToTensor(), Normalize(mean=[0.5, 0.5, 0.5], std=[0.5, 0.5, 0.5])])
input = trans(img).unsqueeze(0)
aligner = load_model_by_repo_id('minchul/cvlface_DFA_mobilenet', path, HF_TOKEN)
aligned_x, orig_ldmks, aligned_ldmks, score, thetas, bbox = aligner(input)
keypoints = orig_ldmks
out = model(input, keypoints)
📚 详细文档
模型信息
属性 |
详情 |
模型名称 |
ADAFACE VIT BASE KPRPE WEBFACE12M |
相关论文 |
KeyPoint Relative Position Encoding for Face Recognition (https://arxiv.org/abs/2403.14852) |
引用说明
请引用原论文并遵循训练数据集的许可协议。
📄 许可证
本项目采用MIT许可证。
🌐 GitHub • 🤗 Hugging Face