摘要:本文将介绍如何借力一站式 AI 开发平台,“傻瓜式”操作实现生成“蚂蚁牙黑“小视频。

作者:华为云EI专家胡琦

一夜之间,朋友圈都在“蚂蚁牙黑”!网友却担心......"Baby, don't worry, we have ModelArts!",是的,咱用 ModelArts 来制作,无需担心“有人模仿我的脸?”,也不用担心偌大的水印。不过,使用别人的脸可能真的有法律风险!本文将介绍如何借力一站式 AI 开发平台,“傻瓜式”操作实现生成“蚂蚁牙黑“小视频。

环境准备

ModelArts 和她的最佳搭档--对象存储服务 OBS ,您可以理解为是“网盘”,主要要来存放数据集、模型或其他文件。

ModelArts: https://www.huaweicloud.com/product/modelarts.html AI开发平台ModelArts是面向开发者的一站式AI开发平台,为机器学习与深度学习提供海量数据预处理及半自动化标注、大规模分布式Training、自动化模型生成,及端-边-云模型按需部署能力,帮助用户快速创建和部署模型,管理全周期AI工作流。

OBS: https://www.huaweicloud.com/product/obs.html
对象存储服务(Object Storage Service,OBS)提供海量、安全、高可靠、低成本的数据存储能力,可供用户存储任意类型和大小的数据。适合企业备份/归档、视频点播、视频监控等多种数据存储场景。

使用以上服务会有一定费用产生,或者您可以尝试认证为开发者会有一定代金券赠送,当然关注 ModelArts 和加入 ModelArts 开发者社区也会有机会获得大额代金券。

模型、素材准备

本次实现使用的是用于图像动画的一阶运动模型,这是一种基于关键点和局部仿射变换的图像动画方法,
论文地址:https://arxiv.org/abs/2003.00196

下载预训练模型及素材

最近手头紧,非常抱歉不能为大家提供 OBS 路径直接下载,我已将预训练模型及素材上传到 AI Gallery 数据集,请自行下载到您的 OBS 中。当然如果您有可快速下载的地址,欢迎分享!

源文件地址:https://drive.google.com/drive/folders/1kZ1gCnpfU0BnpdU47pLM_TQ6RypDDqgw?usp=sharing 或者https://drive.google.com/drive/folders/16inDpBRPT1UC0YMGMX3dKvRnOUsf5Dhn?usp=sharing 因为是源文件,因此不包含”蚂蚁牙黑“原视频素材,但我已添加至AI Gallery 数据集。如仍有需求,可以直接找我要,公众号:胡琦,WeChat:Hugi66;欢迎加入 ModelArts 开发者社区,广州地区的小伙伴可以加入我们共创 MDG 广州站哦!

AI Gallery 是在 ModelArts 的基础上构建的开发者生态社区,提供模型、算法、HiLens技能、数据集等内容的共享和交易。因此您可以下载分发的数据集或文件到您的 OBS ,使用时请遵守相应的政策和规则!打开 https://marketplace.huaweicloud.com/markets/aihub/datasets/detail/?content_id=00bc20c3-2a00-4231-bdfd-dfa3eb62a46d 点击下载按钮进入下载详情,设置 OBS 路径,确定下载即可将模型和素材下载到自己的 OBS 中,比如我路径是/modelarts-lab/first-order-motion-model。下载进度可以在 AI Gallery 个人中心-我的下载查看。

JUST DO IT -- ModelArts 我的笔记本

接下来开始使用 ModelArts--我的笔记本 ,即开即用的在线集成开发环境,可以轻松的构建、训练、调试、部署机器学习算法与模型。当前使用免费规格用于体验, 值得留意的是 72 小时内没有使用,会释放资源,因此需要注意文件备份。当然还可以使用 Notebook 免费算力,记得选择 GPU 环境哦!

当我们使用我的笔记本时默认开启的是 CPU 环境,因此我们需要切换到 GPU 环境。目前 ModelArts-我的笔记本 支持8 vCPU + 64 GiB + 1 x Tesla V100-PCIE-32GB。

新建Pytorch 1.0的.ipynb文件,开始我们的“蚂蚁呀嘿”体验之旅。

下载代码

!git clone https://github.com/AliaksandrSiarohin/first-order-model
# or
!git clone https://codehub.devcloud.cn-north-4.huaweicloud.com/ai-pome-free00001/first-order-model.git

github 速度慢,建议转存到华为云代码托管平台再拉取。

此处提供我已经缓存好的代码仓库地址,因此不再演示如何将 github 代码迁移到 codehub。(不保证我的账号欠费而无法访问,因此建议大家以自己的方式上传代码到 Notebook !)

利用 Moxing 拷贝文件到 JupyterLab,将之前下载到 OBS 中的模型和素材通过 Moxing 拷贝过来,此处注意替换为您的 OBS 路径。02.mp4是“蚂蚁呀嘿”的模版视频,

# 此处牛刀小试--用 Moxing 下载文件
import moxing as mox
# 此处需要替换您的 OBS 地址
mox.file.copy_parallel('obs://modelarts-lab/first-order-motion-model/first-order-motion-model-20210226T075740Z-001.zip' , 'first-order-motion-model.zip')
mox.file.copy_parallel('obs://modelarts-lab/first-order-motion-model/02.mp4' , '02.mp4')
# 解压
!unzip first-order-motion-model.zip
# 模版视频
!mv 02.mp4 first-order-motion-model/

  • JUST DO IT

准备工作完成之后,撸起袖子就是干!切换到first-order-model目录,然后将 source_image_path中的路径替换为”您的脸”所在的路径,脸的照片可以直接通过 Notebook 的文件上传功能上传。当然您还可以将默认的“蚂蚁牙黑”视频替换为您自定义的视频,格式为 mp4。一路执行可以查看到合成前的预览。

cd first-order-model
import imageio
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.animation as animation
from skimage.transform import resize
from IPython.display import HTML
import warnings
warnings.filterwarnings("ignore")# 此处替换为您的图片路径,图片最好为 256*256,这里默认为普京大帝
source_image_path = '/home/ma-user/work/first-order-motion-model/02.png'
source_image = imageio.imread(source_image_path)# 此处可替换为您的视频路径,这里默认为“蚂蚁牙黑”
reader_path = '/home/ma-user/work/first-order-motion-model/02.mp4'
reader = imageio.get_reader(reader_path)
# 调整图片和视频大小为 256x256source_image = resize(source_image, (256, 256))[..., :3]fps = reader.get_meta_data()['fps']
driving_video = []
try:for im in reader:driving_video.append(im)
except RuntimeError:pass
reader.close()driving_video = [resize(frame, (256, 256))[..., :3] for frame in driving_video]def display(source, driving, generated=None):fig = plt.figure(figsize=(8 + 4 * (generated is not None), 6))ims = []for i in range(len(driving)):cols = [source]cols.append(driving[i])if generated is not None:cols.append(generated[i])im = plt.imshow(np.concatenate(cols, axis=1), animated=True)plt.axis('off')ims.append([im])ani = animation.ArtistAnimation(fig, ims, interval=50, repeat_delay=1000)plt.close()return ani
HTML(display(source_image, driving_video).to_html5_video())
  • 创建模型并加载 checkpoints

这一步完成之后,我们便得到了“蚂蚁呀嘿”的视频了--“generated.mp4”,这就结束了?不过,问题来了……

from demo import load_checkpoints
generator, kp_detector = load_checkpoints(config_path='config/vox-256.yaml', checkpoint_path='/home/ma-user/work/first-order-motion-model/vox-cpk.pth.tar')
from demo import make_animation
from skimage import img_as_ubytepredictions = make_animation(source_image, driving_video, generator, kp_detector, relative=True)# 保存结果视频
imageio.mimsave('../generated.mp4', [img_as_ubyte(frame) for frame in predictions], fps=fps)
# 在 Notebook 根目录能找,/home/ma-user/work/HTML(display(source_image, driving_video, predictions).to_html5_video())

  • 后续操作

如果您和我一样直接下载并打开上面操作的产物--generated.mp4,您一定会和我一样困惑:声音呢?是的,声音丢失了,因为核心代码只处理图像,声音需要我们自行找回,因为我们使用moviepy。不仅如此,我们还可以为视频加水印。

  • 安装 moviepy 为视频剪辑做准备

# 安装视频剪辑神器 moviepy
!pip install moviepy

  • 为视频添加背景音乐

# 为生成的视频加上源视频声音
from moviepy.editor import *videoclip_1 = VideoFileClip(reader_path)
videoclip_2 = VideoFileClip("../generated.mp4")audio_1 = videoclip_1.audiovideoclip_3 = videoclip_2.set_audio(audio_1)videoclip_3.write_videofile("../result.mp4", audio_codec="aac")

  • 别人花钱去水印,而我还要加水印,欢迎加入MDG!

# 还可以给视频加水印
video = VideoFileClip("../result.mp4")
# 水印图片请自行上传
logo = (ImageClip("/home/ma-user/work/first-order-motion-model/water.png").set_duration(video.duration) # 水印持续时间.resize(height=50) # 水印的高度,会等比缩放.margin(right=0, top=0, opacity=1) # 水印边距和透明度.set_pos(("left","top"))) # 水印的位置final = CompositeVideoClip([video, logo])
final.write_videofile("../result_water.mp4", audio_codec="aac")final_reader = imageio.get_reader("../result_water.mp4")fps = final_reader.get_meta_data()['fps']
result_water_video = []
try:for im in final_reader:result_water_video.append(im)
except RuntimeError:pass
reader.close()
result_water_video = [resize(frame, (256, 256))[..., :3] for frame in result_water_video]
HTML(display(source_image, driving_video, result_water_video).to_html5_video())

至此,本次实现先告一段落,关于“多人运动”--合照的解决办法还没来得及探索,欢迎您在评论区分享指导,感谢!

本文分享自华为云社区《"蚂蚁牙黑",快用 ModelArts 自己实现一个!》,原文作者:胡琦 。

点击关注,第一时间了解华为云新鲜技术~

“蚂蚁牙黑”太火,想玩就用ModelArts做一个!相关推荐

  1. “蚂蚁牙黑,蚂蚁呀吼”一夜间火遍全网?别忽略了潜在风险

    "蚂蚁牙黑,蚂蚁呀吼" 这两天 一种魔性音乐短视频风靡网络 你有没有被洗脑? 其实这个视频的原理很简单 就是把一张静态照片 ↓↓↓ 通过软件制作成一个动态小视频 ↓↓↓ 魔性的表情 ...

  2. Avatarify 爆火不到 7 天下架,抖音、快手接棒 “蚂蚁牙黑”刷屏特效制作

    3 月 3 日消息,"蚂蚁牙是什么颜色的?" 如果你不是秒回 "黑",那就代表你 out 了. 这是 Avatarify"蚂蚁牙黑"视频特效 ...

  3. 2021年更新:火爆全网的抖音“蚂蚁牙黑”视频制作实战,附软件

    近日,在抖音关于"蚂蚁牙黑"的魔性音乐超过了10亿次播放,相信大家都有被这首神曲洗过脑吧,说实话,还真是挺上头的,本来之前就想给大家出一期教程,不过当时使用的工具以及过程太过繁琐, ...

  4. 火爆全网的 “蚂蚁牙黑” 特效 今天你也可以做。

    不仅仅是 "蚂蚁牙黑" 特效,还有比如 "让老照片动起来",都可以做. 我不生产代码,我只是 GitHub 的搬运工.

  5. 开源项目推荐:“蚂蚁呀嘿/蚂蚁牙黑”AI社交软件

    网络神曲:Dragostea din tei AI制作:https://github.com/alievk/avatarify

  6. 想在公众号上做一个测试软件,公众号测试新功能想要扭转乾坤?

    近期,公众号测试了新功能,文章数据将直接以小字形式展示文章标题下方,根据图文排序的不同,显示的数据也不一样. 排在第一和第二的两篇文章底部可以看到文章的阅读量.点赞数.分享这三项数据,往下是阅读量.点 ...

  7. 怎样才能让学生用计算机玩游戏,让孩子通过游戏就能了解电脑的计算原理!大人看了都想玩...

    原标题:让孩子通过游戏就能了解电脑的计算原理!大人看了都想玩 "它看起来是一个超级有趣的教育游戏,也许有一天当所有电脑都关闭时,你也可以用它来管理图书,这很可能会发生.. 众所周知,让儿童过 ...

  8. Vision Transformer太火!这门开源课也火了!十小时现场coding带你玩转ViT 爆款SOTA算法!...

    关注公众号,发现CV技术之美 Transformer自2017年被提出后,从横扫NLP领域的风光无二,到陷入一片对其在CV任务有效性的质疑声中,再到不久前在多项图像任务中显示出直逼CNN的优异性能 以 ...

  9. 想玩IEO又怕跑得慢?LBank的“锁仓释放”了解下

    IEO 不会消亡,升级玩法已经到来. 文 | 黄雪姣  运营 | 盖遥  编辑 | 郝方舟 出品 | Odaily星球日报(ID:o-daily) 比特币价格先于区块奖励"减半". ...

最新文章

  1. 打开快手,体验流畅的单目三维手势技术
  2. pip ValueError: check_hostname requires server_hostname
  3. LUA面向对象编程技巧
  4. css 宽高最大值最小值 0303
  5. 清华 | 量化卷积神经网络加速芯片
  6. 谷歌为什登不上去github_8个月,从中年Web前端到亚马逊百万年薪软件工程师:GitHub最励志计算机自学教程!...
  7. python教程视频下载-python怎么下载视频
  8. oracle不能插入,oracle – 在过程中截断和插入不能一起工作
  9. 供应XBF-01型多功存储介质粉碎机
  10. 第二季-专题12-通过按键玩中断
  11. greensock下载_面向初学者的GreenSock(第2部分):GSAP的时间表
  12. Hadoop 3.x 的组成 完整使用 (月薪过万 第三章)
  13. 【2023王道数据结构】【树与二叉树】通过C++实现中序遍历的非递归算法(手动入出栈)C、C++完整实现(可直接运行
  14. 英文科技论文写作与学术报告Lecture 4习题答案
  15. LeetCode 2300. 咒语和药水的成功对数
  16. 惠普笔记本重装系统 BIOS设置
  17. 企业号、企业微信、企业邮箱三者融合,IBOS微信生态掘金之路
  18. centos7安装dos2unix
  19. ggplot2——图例篇
  20. 你否有遇到Spring事务失效,花费太多时间找bug

热门文章

  1. 实战 | Element UI 父子组件传值与事件绑定(逆向)
  2. Bootstrap3 Font Awesome 字体图标的堆叠
  3. Bootstrap下拉菜单分隔线
  4. 关于总结记录的一点体会
  5. 视觉SLAM笔记(60) 建图
  6. 视觉SLAM笔记(4) SLAM的数学表述
  7. java 执行 cd_java执行cd命令
  8. ac ap原理、_AP面板是什么?家庭AC+AP的组网方式,真的适合所有人吗?
  9. c语言如何删除数组中的某一个元素_数据结构之线性表高效删除重复元素
  10. dev用不了_惊艳!小姐姐用动画图解 Git 的 10 大命令,这也太秀了吧!