Instant-ngp linux训练数据集

2022-06-19  本文已影响0人  artCoding

本教程使用的环境及版本

Instant-ngp linux环境部署

参考地址:https://www.jianshu.com/p/02c3d3cce99b

Instant-ngp官方文档地址

https://github.com/NVlabs/instant-ngp/blob/master/docs/nerf_dataset_tips.md

目的

问题说明

./build/testbed --no-gui --scene data/nerf/fox

自有图片数据集训练思路

安装python运行环境

conda create -n ngp python=3.9
conda activate ngp
pip install -r requirements.txt

COLMAP稀疏重建生成transform.json

📂instant-ngp/ # this is root
├── 📂data/
│   ├── 📂toy_truck/
│   │   ├── 📜toy_truck_001.jpg
│   │   ├── 📜toy_truck_002.jpg
│   │   │...
│   │...
│...
# --images <image/path> 替换为自己的数据集目录
python scripts/colmap2nerf.py --colmap_matcher exhaustive --run_colmap --aabb_scale 16 --images data/toy_truck
📂instant-ngp/ # this is root
├── 📂data/
│   ├── 📂toy_truck/
│   │   ├── 📜transforms.json/
│   │   ├── 📂data/
│   │   │   ├── 📂toy_truck/
│   │   │   │   ├── 📜toy_truck_001.jpg
│   │   │   │   ├── 📜toy_truck_002.jpg
│   │   │   │   │...
│   │   │   │...
│   │   │...
│   │...
│...

导出模型文件(obj、ply)

mkdir saved
python ./scripts/run.py --mode nerf --scene ./data/toy_truck --save_snapshot saved/toy_truck.msgpack --save_mesh saved/toy_truck.ply --gui --train

脚本 scripts/run.py 中有一个 save_mesh 参数,它支持 OBJ 和 PLY 格式。
注意:非GUI模式需要删除 --gui 参数

导出图片

–scene 场景的路径
–mode 模式,选nerf即可
–load_snapshot 保存的训练好的模型
–screenshot_transforms 需要渲染的角度,数据结构和nerf的json格式一样
–screenshot_frames 渲染哪一帧,如果想全部渲染就不要这个参数,会默认渲染全部
–screenshot_dir 渲染好的图片存储的位置
–width 图片宽度
–height 图片高度

python scripts/run.py --scene data/toy_truck/ --mode nerf --load_snapshot saved/toy_truck.msgpack --screenshot_transforms data/toy_truck/transforms.json --screenshot_dir data/toy_truck/screenshot --width 2048 --height 2048 --n_steps 0

导出视频

python scripts/rendervideo.py --scene data/toy_truck/ --n_seconds 10 --fps 60 --render_name toy_truck_video --width 1920 --height 1080 --msgpack_path /root/code/instant-ngp/saved/toy_truck.msgpack --transform_path /root/code/instant-ngp/data/toy_truck/transforms.json

视频数据集训练方式(一)

sudo apt update
sudo apt install ffmpeg
ffmpeg -version
####安装ffmpeg(数据集为视频时需要安装)
sudo apt update
sudo apt install ffmpeg

生成清晰无压缩的图片方式:

ffmpeg -i  test.mp4 -r 10 -f image2 %05d.jpg

-i : 指定输入文件
-r : 帧数 10
-f : 指定格式化的格式为image2
image2后面跟着的是文件名
%5d:以为5位数按正序编号

视频数据集训练方式(二)框架脚本

python scripts/colmap2nerf.py --video_in data/model1/model1.MOV --video_fps 2 --run_colmap --aabb_scale 16

colmap2nerf.py实现的效果是自动将视频分割成图片,然后调用colmap稀疏重建生成transform.json文件,最后执行即可

文献参考

https://github.com/NVlabs/instant-ngp/blob/master/docs/nerf_dataset_tips.md
https://github.com/bycloudai/instant-ngp-Windows
https://github.com/NVlabs/instant-ngp/discussions/412
https://blog.csdn.net/YuhsiHu/article/details/124891710
https://asea.fun/articles/74

上一篇 下一篇

猜你喜欢

热点阅读