Spaces:
Sleeping
Sleeping
File size: 3,873 Bytes
78d2329 15400ef 78d2329 15400ef 78d2329 15400ef 78d2329 15400ef 78d2329 6da57aa 78d2329 6da57aa 78d2329 6da57aa 78d2329 f1fab86 15400ef 78d2329 15400ef 78d2329 15400ef 78d2329 8407819 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 | # Learn2Splat β interactive demo for a Hugging Face Space (Docker SDK, GPU).
#
# Installs the optgs package + prebuilt CUDA-extension wheels, then runs
# demo.py's viser GUI: SfM-initialize a COLMAP scene and refine the Gaussians
# with the learned optimizer live in the browser.
#
# The CUDA extensions are NOT compiled here β the HF Docker builder runs out of
# RAM doing it. They are prebuilt into wheels/ on a machine matching this image
# (Python 3.12, torch 2.7.1+cu128, glibc 2.35); see huggingface_space/DEPLOY.md.
#
# Build context = the Space repo root (optgs source + wheels/, see DEPLOY.md).
# Hardware: pick a GPU in the Space settings β A10G (24 GB) recommended; the
# GUI holds the dense and sparse checkpoints in VRAM at once.
# CUDA 12.8 + Ubuntu 22.04 β matches the wheels' build environment.
FROM nvidia/cuda:12.8.0-devel-ubuntu22.04
ENV DEBIAN_FRONTEND=noninteractive \
PYTHONUNBUFFERED=1 \
PIP_NO_CACHE_DIR=1
# Python 3.12 (via deadsnakes) β optgs uses PEP 695 generic syntax that
# Ubuntu 22.04's stock Python 3.10 cannot parse. Also: build tools, extension
# headers (libglm-dev), and the OpenCV runtime libs (libgl1, libglib2.0-0 β
# optgs's COLMAP loader imports cv2).
RUN apt-get update && apt-get install -y --no-install-recommends \
software-properties-common \
&& add-apt-repository -y ppa:deadsnakes/ppa \
&& apt-get update && apt-get install -y --no-install-recommends \
python3.12 python3.12-dev python3.12-venv \
git build-essential ninja-build libglm-dev \
libgl1 libglib2.0-0 ca-certificates \
&& rm -rf /var/lib/apt/lists/*
# HF Spaces convention: run as a non-root user (UID 1000).
RUN useradd -m -u 1000 user
USER user
ENV HOME=/home/user \
HF_HOME=/home/user/.cache/huggingface \
TORCH_HOME=/home/user/.cache/torch
WORKDIR /home/user/app
# All Python work happens in a venv on PATH (no system-Python writes).
RUN python3.12 -m venv /home/user/venv
ENV PATH=/home/user/venv/bin:$PATH
RUN pip install --upgrade pip setuptools wheel
# PyTorch (CUDA 12.8) β pinned to setup.sh.
RUN pip install torch==2.7.1 torchvision==0.22.1 torchaudio==2.7.1 \
--index-url https://download.pytorch.org/whl/cu128
# Python requirements (copied first so this layer caches across code edits).
COPY --chown=user:user requirements.txt .
RUN pip install -r requirements.txt
# HF serves the Space over HTTP/2, and the WebSocket subprotocol viser uses to
# announce its client version doesn't survive the proxy β so viser's server
# reads the client version as "unknown" and rejects the connection (the GUI
# then hangs on "connecting"). Client and server are the same viser build
# here, so treat an undeterminable client version as a match, not a reject.
RUN VISER_INFRA="$(python -c 'import viser.infra._infra as m; print(m.__file__)')" \
&& sed -i 's/client_version_str = "unknown"/client_version_str = viser.__version__/' "$VISER_INFRA" \
&& grep -q 'client_version_str = viser.__version__' "$VISER_INFRA"
# Prebuilt CUDA-extension wheels β gsplat, nerfacc, pycolmap, fused-ssim,
# simple-knn, pointops, fused_knn_attn. Built on a matching machine (see
# DEPLOY.md) so the HF builder never compiles CUDA and never OOMs.
COPY --chown=user:user wheels/ ./wheels/
RUN pip install --no-deps ./wheels/*.whl
# The optgs repo, then optgs itself (pure Python β editable install).
COPY --chown=user:user . .
RUN pip install --no-build-isolation --no-deps -e .
# viser serves the GUI here β must equal app_port in README.md.
EXPOSE 7860
# server mode: the optgs decoder renders frames on the GPU and viser streams
# them as images β no multi-MB splat-geometry transfer to the browser and no
# client-side WebGL, which is far more robust behind HF's HTTP/2 proxy.
# viser binds 0.0.0.0 by default.
CMD ["python", "demo.py", "--with-gui", "server", "--gui-port", "7860"]
|