位置: IT常识 - 正文

Nerf_studio 使用记录(nerf 入门)

编辑:rootadmin
Nerf_studio 使用记录 这里写自定义目录标题Nerfstudio 安装和使用记录安装训练出现 Address already in use 的错误的时候,原因是因为Port已经被占据,执行以下命令。添加Camera 之后的 Render 命令Nerfstudio 代码笔记大致梳理具体如何从DataManger 中进行Random Sample pixel 来生成 pixel_batch?render 代码阅读和梳理修改了nerfstudio 的sprial_marching 的代码Nerfstudio 安装和使用记录

推荐整理分享Nerf_studio 使用记录(nerf 入门),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nerf 入门,nerfstf,nerf worker,nerf入门推荐,nerf 入门,nerf怎么样,nerf csdn,nerf 入门,内容如对您有帮助,希望把文章链接给更多的朋友!

参考网站:https://docs.nerf.studio/en/latest/quickstart/installation.html

安装

因为服务器无法联网,采用本地安装的方法进行安装:

conda create --name nerfstudio -y python=3.8conda activate nerfstudiopython -m pip install --upgrade pippip install torch==1.12.1+cu113 torchvision==0.13.1+cu113 -f https://download.pytorch.org/whl/torch_stable.html

这个链接无法在服务器联网安装,服务器一般不连外网

pip install git+https://github.com/NVlabs/tiny-cuda-nn/#subdirectory=bindings/torch

可以去官网github下载

https://github.com/NVlabs/tiny-cuda-nn/

另外fmt 和 cutlass github 是给的超链接,因此上面的链接并没有下载 这两个包,需要手动下载和安装。

如果报错 ld: cannot find -lcudaexport LIBRARY_PATH="/usr/local/cuda-11.3/lib64/stubs:$LIBRARY_PATH"cd bindings/torchpython setup.py install

安装nerfstudio:

git clone git@github.com:nerfstudio-project/nerfstudio.gitcd nerfstudiopip install --upgrade pip setuptoolspip install -e .训练

下面这些配置是有顺序,更改顺序可能会报错。比如把 --viewer.skip-openrelay True 加在命令行的最后,会报错。应该跟在–viewer 的后面 在之前的权重上继续进行训练,加上 --load_dir 参数指定 ckpt 权重的 路径

ns-train nerfacto --data posters_v3/ --vis viewer --viewer.skip-openrelay True --viewer.websocket-port 7008ns-train nerfacto --data kitti360/ --load_dir ckpt_path --vis viewer --viewer.skip-openrelay True --viewer.websocket-port 7008

打开电脑浏览器的 localhost:7008,可以查看viewer中的训练过程。

ns-train nerfacto --data posters_v3/ --vis viewer --viewer.skip-openrelay True --viewer.websocket-port 7008 --load-dir ./nerfstudio-main/outputs/posters_v3/nerfacto/2022-12-29_142632/nerfstudio_models/

加上==–logdir== 参数可以从预加载模型开始训练

出现 Address already in use 的错误的时候,原因是因为Port已经被占据,执行以下命令。netstat -tunlpkill -9 pid_number

运行原始的nerf (vanilla-nerf):

## Viewerns-train vanilla-nerf --data nerf_synthetic/kitti360 --vis viewer --viewer.skip-openrelay True --viewer.websocket-port 7007## Tensorboadns-train vanilla-nerf --data nerf_synthetic/kitti360 --vis tensorboard

导出TSDF的Geometry

ns-export tsdf --load-config CONFIG.yml --output-dir OUTPUT_DIRns-extract-mesh --load-config outputs/../config.yml --output-path meshes/xxx.ply添加Camera 之后的 Render 命令Nerf_studio 使用记录(nerf 入门)

这里采用 nohup 的后端执行命令,即使关闭 Terminal 也照样执行程序代码。

nohup ns-render --load-config outputs/datasets-kitti360_mono_priors/monosdf/2023-02-06_125735/config.yml --traj filename --camera-path-filename outputs/datasets-kitti360_mono_priors/monosdf/2023-02-06_125735/camera_path.json --output-path renders/monosdf_output.mp4 &Nerfstudio 代码笔记大致梳理

Pipeline 如下:

DataParser 是什么?

DataParser 将各种形式的数据集作为输入,并且读取各个数据类别的Meta数据,返回的参数是DataparserOutputs

DataManager 是什么?

DataManger 返回的是RayBundle 和 RayGT 。对于大多数的NerfPaper ,NerfStudio 设立了 VanillaDataManger. 其随机在DataManger中随机采样了一些像素点。生成了Training Ray 的颜色和Gt 的颜色

每一次采样的 光线数量 由参数 --pipeline.datamanager.train-num-rays-per-batch 来指定,默认数值是1024

Code:

ray_bundle, batch = self.datamanager.next_train(step) Ray_bundle (1024)

具体如何从DataManger 中进行Random Sample pixel 来生成 pixel_batch?

在Sample 函数中,输入的是img_batch 参数,是一个Dict,包含image_idx 列表和 image (batch,H,W,C)的Tensor。

在 pixel_sampler.py 代码中,调用sample_method 均匀采样pixel。具体算法是生成均匀采样的随机数t(batch,3) 和 tensor([num_images, image_height, image_width]) 进行相乘,返回一个Tensor.

indices = torch.floor( torch.rand((batch_size, 3), device=device) * torch.tensor([num_images, image_height, image_width], device=device) ).long()Model是什么?

Model 是实际执行的 Nerf-based 算法。Model读取RayBundle 对象返回的是每一条Ray对应的 rendered color

一般包含的模块有:

# Fields # Ray Samplers # Colliders # Renderers # Losses # MetricsField 是什么?

Field 是 Model 模块中的一个重要的Component 。在大多数经典的应用当中,输入是3D 的Location 和 View direction 输出是 density 和 color 数值。

Pipeline 是什么?

在Nerfstudio 的代码中,Pipeline 包含Nerf方法所有的代码。在代码中有一个 Vanilla Implementation 类,负责从DataManger 中读取数据然后feed到Model当中。

render 代码阅读和梳理

对于在nerfstudio 的 Viewer 中会生成 camera.json 文件,解析这个json 文件,从其中读出 需要渲染的 相机的信息,包括 相机的 c2w 矩阵, 相机的内参数cx,cy 等。

elif self.traj == "filename": with open(self.camera_path_filename, "r", encoding="utf-8") as f: camera_path = json.load(f) seconds = camera_path["seconds"] camera_path = get_path_from_json(camera_path)

came_path 包含的信息如下所示: 得到了相机的参数,主要通过 _render_trajectory_video 进行渲染:

def _render_trajectory_video( pipeline: Pipeline, cameras: Cameras, output_filename: Path, rendered_output_names: List[str], rendered_resolution_scaling_factor: float = 1.0, seconds: float = 5.0, output_format: Literal["images", "video"] = "video",) -> None: """Helper function to create a video of the spiral trajectory. Args: pipeline: Pipeline to evaluate with. cameras: Cameras to render. output_filename: Name of the output file. rendered_output_names: List of outputs to visualise. rendered_resolution_scaling_factor: Scaling factor to apply to the camera image resolution. seconds: Length of output video. output_format: How to save output data. """修改了nerfstudio 的sprial_marching 的代码

可以按照相机的位姿 进行螺旋前景跑完整个场景

python scripts/render.py --load-config outputs/data_leader-train_00/nerfacto/2023-03-17_223503/config.yml --traj spiral --output-path trai00.mp4
本文链接地址:https://www.jiuchutong.com/zhishi/297382.html 转载请保留说明!

上一篇:无需公网IP,远程连接SQL Server数据库【内网穿透】(没有公网ip如何实现外网访问路由器)

下一篇:web前端开发期末大作业 ——个人主页(可自取源码)(web前端开发学什么)

  • 微信怎么设置未成年模式(微信怎么设置未成年)

    微信怎么设置未成年模式(微信怎么设置未成年)

  • 淘宝怎么收藏店铺(淘宝怎么收藏店铺订阅是收藏吗)

    淘宝怎么收藏店铺(淘宝怎么收藏店铺订阅是收藏吗)

  • 为什么微信的聊天记录自动没了(为什么微信的聊天背景图片会很模糊)

    为什么微信的聊天记录自动没了(为什么微信的聊天背景图片会很模糊)

  • word和excel统称(word,excel的区别)

    word和excel统称(word,excel的区别)

  • iphone自带的ar在哪(苹果手机里的ar系统怎么打开)

    iphone自带的ar在哪(苹果手机里的ar系统怎么打开)

  • 苹果手机收藏的文件在哪里可以找到(苹果手机收藏的照片在哪里可以找到)

    苹果手机收藏的文件在哪里可以找到(苹果手机收藏的照片在哪里可以找到)

  • 多媒体网络应用包括(多媒体网络应用领域有哪些)

    多媒体网络应用包括(多媒体网络应用领域有哪些)

  • 电脑更新系统会不会丢失文件(电脑更新系统会怎么样)

    电脑更新系统会不会丢失文件(电脑更新系统会怎么样)

  • vivoy83的隐藏界面在哪(vivoy83隐藏图标)

    vivoy83的隐藏界面在哪(vivoy83隐藏图标)

  • 华为荣耀20Pro手机如何自制图标(华为荣耀20PRO手机充电器原配)

    华为荣耀20Pro手机如何自制图标(华为荣耀20PRO手机充电器原配)

  • 华为手机密码最多输错几次(华为手机密码最多可以试多少次)

    华为手机密码最多输错几次(华为手机密码最多可以试多少次)

  • 回放生成要多久(回放正在生成中什么原因)

    回放生成要多久(回放正在生成中什么原因)

  • 苹果qq不能录屏直播(苹果手机qq不能录屏直播吗)

    苹果qq不能录屏直播(苹果手机qq不能录屏直播吗)

  • 苹果siri认主人吗(苹果siri怎么设置主人的声音)

    苹果siri认主人吗(苹果siri怎么设置主人的声音)

  • 流量充不进去老退款(流量充不上去怎么回事)

    流量充不进去老退款(流量充不上去怎么回事)

  • 手机加载不出来图片怎么回事(手机加载不出来图片)

    手机加载不出来图片怎么回事(手机加载不出来图片)

  • 手机里的同步是什么意思(手机同步的东西都存哪里了)

    手机里的同步是什么意思(手机同步的东西都存哪里了)

  • 手机滑动解锁忘了怎么办(手机滑动解锁忘记了)

    手机滑动解锁忘了怎么办(手机滑动解锁忘记了)

  • 魅族16sPro怎么设置呼吸灯(魅族16th设置)

    魅族16sPro怎么设置呼吸灯(魅族16th设置)

  • 为什么来电秀只有铃声没有视频(为什么来电秀只有视频没有声音)

    为什么来电秀只有铃声没有视频(为什么来电秀只有视频没有声音)

  • 三星s10 防水吗(三星s10防水级别是多少)

    三星s10 防水吗(三星s10防水级别是多少)

  • 华为p30怎么分辨真假(华为p30分辨率)

    华为p30怎么分辨真假(华为p30分辨率)

  • apple watch 安卓手机能用吗(apple watch 安卓手表)

    apple watch 安卓手机能用吗(apple watch 安卓手表)

  • 有什么办法可以看电脑系统?电脑系统怎么看?(有什么办法可以快速减肥)

    有什么办法可以看电脑系统?电脑系统怎么看?(有什么办法可以快速减肥)

  • 阿里云版GPT官宣,我们问了它10个问题(阿里云 gtm)

    阿里云版GPT官宣,我们问了它10个问题(阿里云 gtm)

  • 税收指的是什么
  • 发票领购簿长什么样
  • 无形资产开发阶段
  • 融资租出的设备计入什么科目
  • 开发票利润
  • 注销税务注意事项
  • 企业持有到期债券的风险
  • 企业可以不弥补以前年度亏损吗
  • 出口样品账务处理
  • 委托加工设备
  • 固定资产如何抵扣企业所得税
  • 收到上个月支付的短信
  • 公司长期应付账款怎么算
  • 生产用水的会计分录
  • 办税员身份怎么办理
  • 企业年金个税如何计提
  • 原材料意外损失会计分录
  • 一台设备发票开来0.5台怎么做账?
  • 以自有资金进行股权投资
  • 信托保证本金吗
  • Mac怎么禁用icloud
  • 行政单位年底结账怎么算
  • 预付维修费计入入账价值吗
  • 钉钉h5微应用
  • 现金解款单的使用范围
  • 企业购入固定资产一次性税前扣除
  • mac怎么删除应用程序中没有的软件
  • messenger 是什么意思
  • 瑞芯微 8nm
  • php io操作
  • php追加写入
  • flex的几个常用布局
  • 售后回租融资租赁案例
  • 净资产收益率的概念
  • 车辆购置税发票在哪里打印
  • 蓝桥杯大赛官网试题
  • rust 入门教程
  • 微信实现刮刮卡抽奖效果
  • java桥接模式的应用场景
  • 转让旧机器的会计分录
  • 出售自建不动产怎么交税
  • phpcms默认密码
  • 个人税收收入退税政策
  • 移动平均法适用范围
  • 发票抬头为个人的纳税人识别号
  • 资产负债表日后事项是指资产负债表日之后至审计报告
  • 财务会计制度及核算软件备案有效期
  • 项目支出可以列办公费吗
  • 盈余公积转增资本所有者权益会变吗
  • 其他债权投资的汇兑差额计入什么科目
  • 在MysQL数据库中,数据库文件的扩展包括
  • 2019年印花税减半征收条件
  • 社保金的滞纳金个人承担吗?
  • 社保基数在哪里申报
  • 一般纳税人抵扣进项税流程
  • 存货与总账对账
  • Linq to SQL 插入数据时的一个问题
  • 多种工具安装系统怎么用
  • 怎样设置禁
  • xp系统如何加速
  • xp系统远程桌面怎么设置
  • mac睡眠设置方法
  • win10 1511(win10 TH2)如何调整开始屏幕磁贴大小?
  • linux各种重定向及其含义
  • 怎么关闭win10升级
  • Android Chronometer(定时器)
  • 教你学python
  • nginx日志切割原理
  • dos命令怎么输入命令
  • 批处理重启后继续运行
  • 梦见擦窗户框
  • 用jquery实现全选
  • Unity3D实现Billboard效果
  • jquery .find()
  • JavaScript Length 属性的总结
  • 方块大作战百科
  • 江苏税务社保缴纳查询缴费记录
  • 临沂学生医疗保险多少钱
  • 地方公安局归谁管
  • 小微企业所得税优惠政策最新2023
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设