FaceSwap+CUDA10.0使用笔记

本来想直接使用已有的换脸软件,但各个换脸程序都要求VS2015和CUDA9.0,自己的电脑显卡驱动最低支持CUDA9.1(怀疑是电脑的问题,显卡驱动只能安装更高版本的)。经过一天的挣扎后,最终放弃了给自己的电脑安装CUDA9.0的努力,转而看能不能直接在CUDA10.0运行。事实证明,CUDA10也是可以的。
第一步,从github把源代码克隆到本地,但通过git克隆速度才10k/s,最终是从deepfakes 中文站下载到的源代码。
第二步,根据说明配置环境
官方推荐VS2015+CUDA9.0的配置,事实上,只要能配置好正确的python环境,理论上都是可以运行的。运行中缺少哪个模块安装哪个,模块版本不对的话,就卸掉重新安装对应版本的模块。

  1. 安装合适的VS和CUDA,cuDNN,我的是VS2017(也安装了VS2015且没有卸载,这里并不确定只有VS2017的话能否正确运行),CUDA10.0,以及对应的cuDNN。
  2. 安装模块,下面是官方要求的环境
pathlib==1.0.1
scandir==1.6
h5py==2.7.1
Keras==2.1.2
opencv-python==3.3.0.10
tensorflow-gpu==1.5.0
scikit-image
dlib
face_recognition
tqdm
matplotlib

其中tensorflow-gpu模块需要换成对应CUDA10.0的版本,我的是tensorflow-gpu 1.12.0。在安装dlib的时候卡了良久,需要安装CMake和boost,参考的这个网站解决的问题:https://my.oschina.net/quicker/blog/2876068
接下来就可以愉快的在cmd或者PowShell中运行程序了。

第三步,运行程序

  1. 视频转图片

    .\ffmpeg -i workspace1/data_dst.mp4 workspace1/_01photo/dst/%5d.png
    .\ffmpeg -i workspace1/data_src.mp4 workspace1/_01photo/src/%5d.png

  2. 提取大头照
    python faceswap.py extract -i workspace1/_01photo/dst -o workspace1/_02data/dst
    python faceswap.py extract -i workspace1/_01photo/src -o workspace1/_02data/src

  3. 训练模型
    python faceswap.py train -A workspace1/_02data/dst -B workspace1/_02data/src -m workspace1/_03models/ -p

  4. 换脸
    python faceswap.py convert -i workspace1/_01photo/dst -o workspace1/_04output/ -m workspace1/_03models/

  5. 图片合成视频
    .\ffmpeg -i workspace1/_04output/%5d.png -c:v libx264 -vf “fps=25,format=yuv420p” workspace1/out.mp4

在训练模型那里是最花费时间的,跑了12个小时后:
saved model weights loss_A: 0.01127, loss_B: 0.01857
最后的结果还算差强人意。接下来试试能不能给程序加个皮,每次手动敲命令行太难受了,然后跑些有意思的视频。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: OpenCV是一个开源的计算机视觉和机器学习库,可以方便地处理图像和视频。而CUDA(Compute Unified Device Architecture)是由NVIDIA开发的一种并行计算架构,可以加速图形处理器(GPU)上的计算任务。 OpenCV 4.5.1是OpenCV的一个版本,它提供了丰富的功能和算法,用于图像和视频处理、特征提取、目标检测等任务。这个版本可以在Windows 10操作系统上使用,并且可以与Visual Studio 2017集成,提供开发环境和调试工具。 CUDA 10.0是NVIDIA的一个版本,它支持NVIDIA GPU上的并行计算任务。它允许开发人员使用C语言、C++或CUDA自己的扩展语言编写并行计算代码,以加速计算密集型任务。例如,在图像处理中,可以使用CUDA加速OpenCV算法,从而提高计算性能。 而cuDNN(CUDA Deep Neural Network library)是NVIDIA专门为深度学习任务开发的一个库。它提供了一组高性能的深度神经网络的基本操作和优化算法,可以与CUDA和OpenCV结合使用。 综上所述,OpenCV 4.5.1可以与CUDA 10.0和cuDNN 7.6.0集成使用。开发者可以在Visual Studio 2017中使用这些工具和库进行图像处理和机器学习任务的开发和优化。通过使用CUDA加速,可以提高计算性能,而cuDNN可以提供深度学习任务所需的算法和操作。 ### 回答2: OpenCV 4.5.1是一个计算机视觉库,用于在计算机视觉和机器学习项目中进行图像和视频处理。VS2017是一个集成开发环境(IDE),用于Windows操作系统上的软件开发。CUDA(Compute Unified Device Architecture)是一个用于GPU计算的并行计算平台和API模型。CUDNN是NVIDIA深度神经网络库,用于在GPU上加速深度学习任务。 在Windows 10上使用VS2017来编译OpenCV 4.5.1,并在CUDA 10.0和CUDNN 7.6.0的支持下进行构建可以提供更好的计算性能和加速。CUDA 10.0提供了与CUDA架构和驱动程序的兼容性,并支持许多NVIDIA GPU。CUDNN 7.6.0是基于CUDA的深度神经网络库,可以加速深度学习任务的训练和推理。 使用VS2017编译OpenCV可以让开发者方便地在Windows平台上进行开发和调试。VS2017提供了强大的集成开发环境,它可以帮助开发者编写、调试和测试程序。通过配置CUDA 10.0和CUDNN 7.6.0来支持OpenCV的GPU加速,可以进一步提高图像和视频处理的速度和效率。 总结来说,使用OpenCV 4.5.1、VS2017、Windows 10、CUDA 10.0和CUDNN 7.6.0可以实现在Windows平台上的高效计算机视觉和机器学习开发。这种配置可以提供更好的性能和加速,特别是在需要处理大量图像和视频、进行深度学习任务的情况下。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值