当前位置: 首页 > news >正文

解决 3D Gaussian Splatting 中 SIBR 可视化组件报错 uv_mesh.vert 缺失问题【2025最新版!】

一、📌 引言

在使用 3D Gaussian Splatting(3DGS)进行三维重建和可视化的过程,SIBR_gaussianViewer_app 是一款官方推荐的本地可视化工具,允许我们在 GPU 上实时浏览重建结果。然而,许多用户在启动该工具时,会遇到如下报错:
在这里插入图片描述
而且可视化界面会闪退,该错误虽简单,却阻碍了整个可视化流程的展开。本文将基于实际案例,详细解析错误成因,并提供一个无需改代码即可成功运行的实战级解决方案

二、🧠 报错溯源分析

运行如下命令:

./SIBR_gaussianViewer_app -m /home/sunshine/Project/darkgs/output/7a0f12c0-7

出现日志信息:

[SIBR] ##  ERROR  ##:   FILE .../Utils.cppLINE 82, FUNC loadFileFile not found: uv_mesh.vert
terminate called after throwing an instance of 'std::runtime_error'

这表明程序在尝试加载 GLSL 着色器 uv_mesh.vert 文件时失败,触发异常崩溃。
在日志中,我们可以看到以下关键线索:
正确加载了 COLMAP 的 SfM 数据(例如 points3D.bin);
成功读取了高斯点(193073 个);
初始化 OpenGL 过程也未报错;
最后失败点为:尝试加载 uv_mesh.vert 着色器失败,触发 C++ 层的异常,导致程序崩溃。
这一错误本质上是 SIBR 框架依赖某些 GLSL 着色器文件未找到,其核心由如下函数触发:

std::string loadFile(const std::string &filename) {std::ifstream file(filename);if (!file.is_open())throw std::runtime_error("File not found: " + filename);...
}

三、🎯根本原因分析

SIBR 使用 OpenGL 渲染高斯点云时,需要加载多个着色器文件(例如 .vert, .frag 等),但程序使用的是 相对路径加载资源文件,默认在可执行文件当前路径下寻找 shaders/core/uv_mesh.vert。

因此,如果你直接在 install/bin/ 下运行程序,而当前路径下没有 shaders/ 文件夹或着色器文件,就会导致加载失败。

四、✅解决方案

SIBR_gaussianViewer_app 在加载 shader 时 直接从“当前工作目录”拿裸文件名,不会去读 SIBR_PATH。
所以只要执行时所在的目录里没有 uv_mesh.vert 就会崩溃 —— 环境变量已经对,但程序根本没去用它。
官方 issue #508 给的办法:
让 工作目录 指向 shader 文件夹,或把 shader 扔到可执行旁边。

# 进入 shader 目录当工作目录
cd ~/Project/darkgs/SIBR_viewers/install/shaders/core# 从这里启动 Viewer(相对路径回到 bin)
../../../bin/SIBR_gaussianViewer_app \-m /home/sunshine/Project/darkgs/output/RNN-0.1路径解释:
../../../ = 从 shaders/core → shaders → install → bin。

在这里插入图片描述
执行完毕就可以正常可视化了!

五、✅ 方案 A:建立软链接其他方案可选(便于后续使用)

方案 A:建立软链接

ln -s ~/Project/darkgs/SIBR_viewers/install/shaders ~/Project/darkgs/SIBR_viewers/install/bin/shaders
cd ~/Project/darkgs/SIBR_viewers/install/bin
./SIBR_gaussianViewer_app -m ...

方案 B:设置环境变量(部分版本支持)

export SIBR_RESOURCE_PATH=~/Project/darkgs/SIBR_viewers/install/shaders
./SIBR_gaussianViewer_app -m ...

SIBR 在某些版本中支持通过该变量设置资源路径,适用于自动化脚本运行场景。

六、总结与建议

一句话总结: 该报错并非缺少文件,而是路径未对齐,调整运行目录即可解决。

📌 核心结论:

报错 uv_mesh.vert 缺失源于路径问题;
推荐在包含 shaders/core/ 的目录中运行程序;
也可通过软链接或环境变量方式规避路径问题。

🛠 建议:

可写入一个运行脚本 run_viewer.sh,自动设置路径;
若部署跨设备使用,务必将 shaders/ 文件夹随模型一同打包。

http://www.xdnf.cn/news/251389.html

相关文章:

  • 基于深度学习的毒蘑菇检测
  • 大学生入学审核系统设计与实现【基于SpringBoot + Vue 前后端分离技术】
  • 精益数据分析(38/126):SaaS模式的流失率计算优化与定价策略案例
  • ubuntu22.04安装显卡驱动与cuda+cuDNN
  • IntelliJ IDEA 使用教程
  • Linux:信号(一)
  • 八闽十三张模块部署测试记录:源码结构拆解与本地运行验证(含常见问题与修复指南)
  • c/c++开发调试工具之gdb
  • 每天学一个 Linux 命令(34):wc
  • DeepSeek R1:强化学习范式的推理强化模型
  • 华为OD机试真题 Java 实现【水库蓄水问题】
  • 【Linux深入浅出】之全连接队列及抓包介绍
  • 供应链算法整理(一)--- 销量预估
  • 云计算-容器云-服务网格Bookinfo
  • 大模型的第一天学习-LM studio的安装和本地大模型搭建
  • 从0开始建立Github个人博客(hugoPaperMod)
  • 见多识广4:Buffer与Cache,神经网络加速器的Buffer
  • A2A Python 教程 - 综合指南
  • 体系结构论文(八十二):A Comprehensive Analysis of Transient Errors on Systolic Arrays
  • 目标检测中的损失函数(三) | SIoU WIoUv1 WIoUv2 WIoUv3
  • 【计算机视觉】三维视觉:Open3D:现代三维数据处理的全栈解决方案
  • [Verilog]跨时钟域数据传输解决方案
  • 【Linux】Petalinux U-Boot
  • 普通IT的股票交易成长史--20250502 突破(1)
  • 虚拟局域网(VLAN)实验(Cisco Packet Tracer)-路由器、交换机的基本配置
  • 2000-2022年上市公司数字经济专利申请数据
  • 使用Vite创建vue3项目
  • linux下抓包工具--tcpdump介绍
  • 2025年- H20-Lc128-240. 搜索二维矩阵 II(矩阵)---java版
  • C++ 动态内存管理