# EnerGS: Energy-Based Gaussian Splatting under Partial Geometric Observability

We reformulate partial geometric supervision in 3D Gaussian Splatting as a continuous energy field that provides soft geometric guidance during optimization, improving photometric quality and geometric stability under sparse and incomplete geometry.

## Features

- **Geometric Energy Field**: `E_geom = E_occ + E_unk + λ·E_free` guides Gaussians toward occupied regions
- **Relax Step**: Position update via `Δμ = -η∇E_geom`
- **Coverage Modulation**: Prevents Gaussian clustering
- **FREE Pruning**: Removes Gaussians in free space

## Installation

### 1. Clone Repository

```bash
git clone --recursive https://github.com/tbd/EnerGS.git
cd EnerGS
```

### 2. Create Conda Environment

**Option A: Using provided environment file (CUDA 12.1)**
```bash
conda env create -f gs_cuda12.yaml
conda activate gs_cuda12
```

**Option B: Manual setup**
```bash
conda create -n energs python=3.10
conda activate energs

# PyTorch with CUDA 12.1
pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu121

# Dependencies
pip install plyfile tqdm scipy numpy pillow lpips
```

### 3. Build CUDA Extensions

```bash
# Differential Gaussian Rasterization
pip install submodules/diff-gaussian-rasterization

# Simple KNN
pip install submodules/simple-knn

# Fused SSIM (optional, for faster training)
pip install submodules/fused-ssim
```

## Data Preparation

EnerGS requires:
1. **COLMAP data**: Standard 3DGS input format
2. **Field cache**: Pre-computed geometric field (`field_cache.npz`)

Expected structure:
```
<scene>/
├── images/
├── sparse/0/
│   ├── cameras.bin
│   ├── images.bin
│   └── points3D.bin
└── field_cache.npz  # Geometric field
```

## Training

```bash
python train_energs.py \
    -s <path/to/scene> \
    -m <output/path> \
    --field_npz <path/to/field_cache.npz> \
    --iterations 30000 \
    --eval
```

### Key Parameters

| Parameter | Default | Description |
|-----------|---------|-------------|
| `--energs_w_occ` | 1.0 | OCC attraction weight |
| `--energs_sigma_occ` | 1.0 | OCC attraction range (m) |
| `--energs_w_unk` | 0.25 | UNK attraction weight |
| `--energs_barrier_lambda` | 2.0 | FREE barrier strength |
| `--energs_relax_lr` | 0.005 | Relax step size η |
| `--energs_prune_free` | False | Enable FREE pruning |

## Rendering & Evaluation

```bash
# Render
python render.py -m <output/path>

# Evaluate
python metrics.py -m <output/path>
```

## Project Structure

```
EnerGS/
├── train_energs.py      # Training script
├── render.py            # Rendering
├── metrics.py           # Evaluation
├── energs/              # EnerGS core module
│   ├── geometric_energy.py   # E_geom computation
│   ├── gaussian_model.py     # GaussianModelEnerGS
│   └── coverage.py           # Coverage tracking
├── scene/               # Scene handling
├── gaussian_renderer/   # Rasterization
└── submodules/          # CUDA extensions
```

## Acknowledgments

Based on [3D Gaussian Splatting](https://github.com/graphdeco-inria/gaussian-splatting) by Kerbl et al.
