Install
openclaw skills install 3dgs-engineering-guideGuide for deploying 3DGS from research to production: 10 industry verticals, engineering stack, GIS toolchain solutions, cross-platform deployment, and common pitfalls
openclaw skills install 3dgs-engineering-guideBridging the gap from academic research to production deployment for 3D Gaussian Splatting.
When invoked, follow this workflow:
references/3dgs-methods-overview.md and references/methods-systems-apps.mdMaturity: Engineering | Players: aiSim, Li Auto mindVLA, NVIDIA DRIVE Sim
Pipeline: Real-world scan (LiDAR + multi-camera) → 3DGS reconstruction → Sensor simulation → HIL/SIL testing
Key papers: GSDrive, GS-Playground (10^4 FPS, RSS 2026), GS-Surrogate, FieryGS, Nighttime AD GS, Real2Sim (4DGS + differentiable MPM), GS-SCNet, Ground4D, ULF-Loc (CVPR 2026 highlight)
Quality bar: Sensor sim error < 0.02, LiDAR > 30 FPS, LPIPS < 0.1, Radar ±3 dB
Notes: LiDAR sim requires opaque surface Gaussians; OpenDRIVE co-registration mandatory; nighttime needs separate IR-adjacent training
Maturity: Commercial | Players: SuperMap, FantoVision, LCC
Pipeline: Aerial + streetview → Large-scale 3DGS → S3M conversion → GIS integration → IoT fusion
Key papers: DiffSoup, Street Gaussians, GlobalSplat, Large-Scale HQ Head
Standards: S3M (Chinese GIS), OGC 3D Tiles, glTF/glb, CityGML
Notes: City-level = 10^9–10^10 Gaussians; WGS84→ENU→3DGS alignment critical; streaming LOD mandatory; S3M needs custom exporter
Maturity: Commercial
Pipeline: Controlled-lighting photography → High-fidelity 3DGS → Color calibration → Digital archive → VR/AR exhibition
Quality: Sub-mm geometry, ΔE < 2 (CIE76), 2048×2048+ texture, lossless compression
Notes: Dome/array lighting > flash; attach DOI/catalog metadata; store raw images + COLMAP + checkpoint + compressed .ply
Maturity: Exploration | Players: Volcengine, UE team, Tencent
Pipeline: Multi-camera capture → 3DGS → Mesh extraction (SuGaR/2DGS) → UE5 import → Virtual production
Notes: 3DGS→mesh needed for DCC; SuGaR (TSDF) > naive marching cubes; material separation (GOR-IS/SSD-GS) for relighting; 4DGS (GauFRe/DeformGS) for temporal consistency; UE5 Nanite+Lumen experimental
Maturity: Commercial
Pipeline: Turntable photography → 3DGS → Compression (MobileGS/GETA-3DGS) → Web AR preview
Requirements: < 50 MB, browser-renderable (WebGPU/WebGL2 via gsplat.js), < 5s load on 4G
Notes: 50x+ compression needed for web; mesh fallback for low-end; AR needs mesh (Quick Look/Scene Viewer)
Maturity: Engineering
Pipeline: Drone capture → 3DGS → AI defect detection → Measurement → Report
Key papers: EnerGS (LiDAR-3DGS fusion), RGS (CBCT inspection), E2EGS (end-to-end field)
Notes: GPS geotagging for defect correlation; EnerGS for LiDAR+cam fusion; detect ≥ 5mm at 10m; CAAC/FAA compliance
Maturity: Exploration
Pipeline: Real-time headset scan → 3DGS → 6DoF tracking + low-latency render → MR overlay
Key papers: Mobile Avatar, GS-Playground, CoherentRaster (subpixel rasterization for light field)
Notes: < 20ms motion-to-photon; VkSplat for cross-VR; hybrid 3DGS+mesh for occlusion physics; Vision Pro = ARKit+Metal, Quest = OpenXR+Vulkan
Maturity: Engineering | Players: LumenBIM × LCC
Pipeline: TLS + drone → 3DGS → IFC alignment → As-built verification → LCC delivery
Key papers: BrepGaussian (B-rep aware), CADFS (CAD feature saliency)
Notes: ICP registration before overlay; IFC coordinate mapping; LCC proprietary streaming format
Maturity: Early
Pipeline: 3DGS environment → Physics sim (GS-Playground) → Policy learning (sim-to-real) → Deployment
Key papers: GS-Playground (RSS 2026), FieryGS, MAGICIAN
Notes: 10^4 FPS sim transforms sample efficiency; ROS2 as point cloud/depth topics; debias with real-world fine-tuning
Maturity: Early, classified | Security: GuardMarkGS (unified watermarking + edit deterrence for 3DGS assets)
Requirements: Air-gapped deployment, indigenous tools, > 60 FPS, sub-meter terrain, multi-spectral (visible+IR+SAR)
Notes: No foreign cloud/API; DEM/DSM fusion; no sensitive data in checkpoints
| Device Type | Use Case | Key Requirements |
|---|---|---|
| DSLR/Mirrorless | High-fidelity capture | Manual exposure, fixed focal length |
| Drone (RTK) | Aerial survey | > 80% forward, > 60% side overlap |
| LiDAR | AD simulation, inspection | Time-synced with cameras |
| Mobile (LiDAR) | Quick indoor scan | iPad Pro/iPhone for rapid scouting |
| TLS | Architectural, industrial | Sub-mm accuracy for as-built |
Software: COLMAP (SfM+MVS standard), ORB-SLAM3/BLEPS (visual SLAM), LIO-SAM/FAST-LIO2 (LiDAR SLAM), FreeMoCap (AGPL-3.0, markerless MoCap from webcams, outputs .trc/.c3d/.fbx, pip install freemocap)
Key considerations: Camera calibration consistency, manual/HDR exposure, > 60% image overlap, GCPs for georeferencing, overcast preferred
| Framework | Language | Best For |
|---|---|---|
| original 3DGS | CUDA/Python | Research, benchmarking |
| gsplat | PyTorch/CUDA | Custom training, differentiable |
| 2DGS | CUDA/Python | Mesh-extraction pipelines |
| Scaffold-GS | CUDA/Python | Large-scale scenes |
| OpenGaussian | OpenGL | Non-CUDA rendering |
| Scale | Gaussians | Training | GPU |
|---|---|---|---|
| Object/room | 100K–1M | 10–30 min | RTX 4070 |
| Building | 1M–10M | 1–3 h | RTX 4090 |
| City block | 10M–100M | 3–7 h | A100 80GB |
| City district | 100M–1B | 12–24 h | A100/H100 cluster |
Compression: HAC (100x), MobileGS (CPU-runnable), GETA-3DGS (5x), MesonGS++ (34x, SOTA rate-distortion), AdaGScale (adaptive)
Rule: No compression for prototyping → add when deployment demands; validate compressed vs original.
Mesh extraction: SuGaR (TSDF, clean meshes), 2DGS+Poisson, Marching Cubes (baseline, blobby), NeuS2-GS (hybrid SDF+Gaussian)
Material separation: GOR-IS (albedo/shading/normals), SSD-GS (scatter+shadow) — enables relighting
Relighting: GS³ (SH-based), GaRe, LumiMotion — critical for virtual production and e-commerce
Editing: GaussianEditor, ObjectMorpher, TransSplat, SuperSplat (PlayCanvas, MIT, browser-based: inspect/edit/compress/publish PLY & SOG; https://superspl.at/editor)
Toolchain: splat-transform (PlayCanvas, MIT, CLI) — PLY→SOG (~20x), PLY→streamed SOG (LOD), -K collision mesh (.collision.glb); npm install -g @playcanvas/splat-transform
MoCap input: FreeMoCap (AGPL-3.0) — webcam MoCap → SMPL/FLAME → drive GaussianAvatar/EmoTaG; same rig for MoCap + 3DGS training images; note: AGPL-3.0 not MIT-compatible for commercial use
| Engine | Backend | Platform | 3DGS Native? |
|---|---|---|---|
| original 3DGS | CUDA | NVIDIA GPU | Yes |
| VkSplat | Vulkan | Cross-platform | Yes |
| GSeurat | Vulkan C++23 | Cross-platform | Yes |
| BlitzGS | Multi-GPU (parity sharding) | Distributed | Yes |
| msplat | Metal | macOS/iOS | Yes |
| tortuise | CPU (Rust) | Any CPU | Yes |
| PlayCanvas Engine | WebGL2/WebGPU | Web | Yes (first-class) |
| gsplat.js | WebGPU/WebGL2 | Web | Yes |
| @playcanvas/react | WebGL2/WebGPU | Web | Yes (Splats component) |
| UE5 plugin | DX12 | Desktop/Console | Plugin |
| Unity renderer | Vulkan/DX12 | Multi-platform | Plugin |
Streaming: CAGS (VQ + LoD, ~7x, chunked with global codebook), AV1-3DGS (AV1 motion vectors for SfM, 63% training reduction), PD-4DGS (progressive 4D streaming, DASH/HLS-compatible), progressive loading (coarse→fine), view-dependent prioritization, 20–50 Mbps for 1080p
Formats: .ply (uncompressed), .splat (compact binary, web-friendly), .sog (PlayCanvas, ~20x, streaming LOD, chunked with manifest), .spz (Niantic, ~10x, mobile/AR), custom (HAC/MesonGS++), future: 3D Tiles + Gaussian extension
GIS: SuperMap S3M extension, Cesium ion, ArcGIS (experimental)
BIM: IFC/STEP via BrepGaussian, Navisworks federated review, Revit as-built comparison
AD: OpenDRIVE + 3DGS co-registration, aiSim 6, ROS2 sensor topics
Game engines: UE5 (experimental Nanite-compatible), Unity (gsplat package), Godot (community, early), PlayCanvas (MIT, first-class 3DGS + collision + navmesh + physics + WebXR, @playcanvas/react)
Robotics: ROS2 scene server, MuJoCo/Isaac Sim, GS-Playground
The #1 pain point blocking 3DGS from production use (based on industry practitioner analysis, particularly WebGIS engineer xjjdjj).
After expensive drone surveys and 3DGS reconstruction, the resulting PLY file cannot: measure distances, cut cross-sections, calculate volumes, compute surface areas, query semantics, or overlay real-time video.
5 Root Causes:
6 Solution Categories:
PlayCanvas Pipeline (3 CLI commands — first end-to-end open-source making 3DGS scenes interactable in browser; source: PlayCanvas Blog 2026-04):
splat-transform scene.ply --seed-pos 0,1,0 --voxel-params 0.05,0.1 \
--voxel-carve 1.6,0.2 -K scene.sog
npx glb-to-navmesh scene.collision.glb navmesh.bin
# Step 3: Bake lightness probes (in-engine, ~15s, ~40KB JSON)
| Component | Tool | Output | Size |
|---|---|---|---|
| Collision mesh | splat-transform -K (voxelization + flood-fill) | .collision.glb | ~1 MB |
| Nav mesh | recast-navigation | navmesh.bin | ~100 KB |
| Lightness grid | Probe script (cubemap luminance, Rec.601) | lightness.json | ~40 KB |
| Streamed SOG | splat-transform (LOD partitioning) | Multi-chunk .sog/ + manifest | ~5% of PLY |
Key insights: Voxelization + flood-fill = sealed collision meshes (no manual cleanup); lightness probes as JSON (no runtime raytracing, mobile-friendly); SOG streaming enables mobile deployment of million-Gaussian scenes.
GIS Toolchain Solutions:
| Task | Tool | Notes |
|---|---|---|
| PLY → 3D Tiles | libTileSplat, supermap-3dtiles | Cesium-compatible |
| PLY → collision mesh | splat-transform -K | Voxelization + flood-fill |
| PLY → nav mesh | splat-transform + recast-navigation | Collision GLB → Recast |
| PLY → compressed SOG | splat-transform | 20x, streaming LOD |
| Web 3DGS editor | SuperSplat | Browser-based, PWA |
| Spatial analysis | Custom Python (NumPy + plyfile) | Build custom GIS layer |
| Semantic labeling | SAGA | SAM → 3D projection |
| Lightness baking | PlayCanvas probe script | ~15s bake, ~40KB |
| Volume calculation | Custom voxelizer + PLY parser | Not yet standard |
| Cesium rendering | gsplat.js, cesium-3dgs-plugin | Three.js limited native support |
Standards progress: CSM group standard for 3DGS modeling initiated (2026-04); S3M extended for 3DGS; 3D Tiles extension proposals
Geometric: Chamfer Distance, F-Score (τ ∈ {1mm, 5mm, 10mm}), normal consistency
Visual: PSNR/SSIM/LPIPS — WARNING: insufficient for engineering use; human evaluation required for sign-off
Engineering metrics: sensor sim fidelity vs real data, real-time FPS (30/60/90+ by domain), memory footprint, time-to-first-render, rate-distortion curves
| Scenario | Compression | Ratio | Quality |
|---|---|---|---|
| Prototyping | None | 1x | None |
| Desktop | GETA-3DGS | 5x | Minimal |
| Mobile | MobileGS / CAGS | 10–50x | Moderate |
| Web | MesonGS++ + .splat/SPZ | 30–50x | Acceptable |
| Large-scale | HAC + progressive / CAGS | 50–100x | Significant |
| Platform | Backend | Fallback | Max Scene | Real-time? |
|---|---|---|---|---|
| Desktop (NVIDIA) | CUDA | Vulkan | 10M+ | 60 FPS |
| Desktop (AMD/Intel) | VkSplat | GSeurat | 5M+ | 30 FPS |
| Desktop (CPU) | tortuise (Rust) | — | 500K | No |
| macOS (Apple) | msplat (Metal) | — | 3M | 20 FPS |
| iOS | Metal | — | 1M | 15 FPS |
| Android | Vulkan | WebGPU | 1M | 15 FPS |
| Web | WebGPU | WebGL2 | 500K–2M | Varies |
| VR (Quest 3) | Vulkan (OpenXR) | — | 2M | 72 Hz |
| VR (Vision Pro) | Metal | — | 3M | 90 Hz |
Checklist: target GPU family, VRAM fallback to lower LOD, color space (sRGB/linear/HDR), min-spec hardware, memory leak testing over extended sessions
CI/CD: Data validation → COLMAP SfM+MVS → 3DGS training → quality gate (PSNR/F-Score) → compression → deploy to CDN → alert on regression
Quality gates: PSNR < 28 dB = flag; geometric drift > 5mm = flag; coverage gaps; floater/needle artifacts
Versioning: Raw images + COLMAP in git; checkpoints (.ply) in git LFS/DVC; semantic versioning; changelog per version
Monitoring: FPS P50/P95/P99, Gaussian count, file size, data freshness, user engagement metrics
| Domain | Methods |
|---|---|
| AD Simulation | GSDrive, GS-Playground (RSS 2026), GS-Surrogate, FieryGS, GS-SCNet, Ground4D, ULF-Loc (CVPR 2026), Nighttime AD, Real2Sim |
| Digital Twin | DiffSoup, Street Gaussians, GlobalSplat, Large-Scale HQ Head |
| Inspection | EnerGS, RGS, E2EGS |
| Physics | PhysGaussian, Gaussian Splashing, GS-Playground |
| Relighting | GS³, GaRe, SSD-GS, LumiMotion, GOR-IS |
| Cross-platform | VkSplat, GSeurat (Vulkan C++23), msplat (Metal), tortuise (Rust CPU), brush (Rust/WebGPU, 4.3k stars), AdaGScale, BlitzGS (distributed) |
| BIM/CAD | BrepGaussian, CADFS |
| Editing | GaussianEditor, ObjectMorpher, TransSplat |
| Security | GuardMarkGS (watermarking + edit deterrence) |
| Rendering | CoherentRaster (subpixel, light field), 3DGEER (exact ray, ICLR 2026), SparseOIT (order-independent transparency) |
| Streaming | CAGS (~7x VQ+LoD), AV1-3DGS (63% training reduction), PD-4DGS (progressive 4D streaming) |
| Compression | HAC (100x), MobileGS (CPU), GETA-3DGS (5x), MesonGS++ (34x), AdaGScale |
See knowledge base: references/3dgs-methods-overview.md, references/methods-core.md, references/methods-semantic-editing.md, references/methods-systems-apps.md
Part of Awesome-Gaussian-Skills