# T-3DGS: Removing Transient Objects for 3D Scene Reconstruction

## Abstract
Transient objects in video sequences can significantly degrade the quality of 3D scene reconstructions. To address this challenge, we propose T-3DGS, a novel framework that robustly filters out transient distractors during 3D reconstruction using Gaussian Splatting. Our framework consists of two steps. First, we employ an unsupervised classification network that distinguishes transient objects from static scene elements by leveraging their distinct training dynamics within the reconstruction process. Second, we refine these initial detections by integrating an off-the-shelf segmentation method with a bidirectional tracking module, which together enhance boundary accuracy and temporal coherence. Evaluations on both sparsely and densely captured video datasets demonstrate that T-3DGS significantly outperforms state-of-the-art approaches, enabling high-fidelity 3D reconstructions in challenging, real-world scenarios.

## Overview
This repository implements Reconstruction Uncertainty Predictor (RUP), a solution for handling transient objects in 3D scene reconstruction. For mask refinement functionality (TMR), please refer to our companion repository - AutoVidSeg.


## Key Features
- **Automatic Detection of Transient Objects:** Integrate transient object removal seamlessly into the 3D reconstruction pipeline.
- **Two-Stage Pipeline:** Combines RUP and TMR for enhanced mask prediction and refinement.
- **Docker Support:** Simplifies deployment and setup across different environments.


## Installation

The installation process aligns with the original [Gaussian Splatting](https://github.com/graphdeco-inria/gaussian-splatting) project, with additional dependencies specified in `environment.yml`. We also provide a `Dockerfile` for containerized setups.

## Run Experiments

By default, the following features are enabled:

- **Reconstruction Uncertainty Predictor (RUP)**
- **Mask Dilation**
- **Depth Regularization**

### Training the Model

To start training with default settings:

```bash
python train.py -s [path to dataset]
```

### Customizing Training Options
To disable specific features, use the following flags:
- **Disable Reconstruction Uncertainty Predictor (RUP):**

```bash
python train.py -s [path to dataset] --disable_transient
```

- **Disable Mask Dilation:**

```bash
python train.py -s [path to dataset] --disable_dilate
```

- **Disable Depth Regularization:**

```bash
python train.py -s [path to dataset] --lambda_tv 0
```
### Training With Precomputed Masks

```bash
python train.py -s [path to dataset] --masks [path to masks] --disable_transient
```
- Masks should be in `.png` format.
- Masks can have any naming format.
- Images and masks are matched based on their positions in the [nasorted](https://www.geeksforgeeks.org/python-natsorted-function/) lists of image filenames and mask filenames.
- It is recommended to slightly dilate your masks to account for potential inaccuracies. Use the `--mask_dilate` flag (default is 5).

### Bechmarking

#### Running TMP Benchmark
To run all experiments without TMR:

```bash
bash examples/tmp_benchmark.sh
```
This script will initiate the training and evaluation processes for the TMP without mask refinement.

#### Mask Refinement with TMR
To refine transient masks using TMR, follow these steps:

1. **Prepare TMR input**

Run the preparation script:
```bash
bash examples/prepare_tmr_input.sh
```
This script performs the following actions:

- **Reformats Images**: Converts images to the format required by SAM2.

- **Extracts Transient Masks and Differences**: Retrieves transient masks and difference images from your T-3DGS checkpoint (default iteration is 7000).


2. **Run TMR**

- **Follow Instructions:** Visit the TMR Repository for detailed instructions.

- **Execute Refinement Script:** Use the provided script - tmr_benchmark.sh in the TMR repository to perform mask refinement.

3. **Final Training with Refined Masks**
After obtaining refined masks from TMR, run the following script to train the model with these masks:

```bash
bash examples/tmr_benchmark.sh
```

## Acknowledgments
Our code is based on the official [implementation](https://github.com/graphdeco-inria/gaussian-splatting) of 3D Gaussian Splatting (3DGS).