# **GOOD: Geometry-guided Out-of-Distribution Modeling for Open-set Test-time Adaptation in Point Cloud Semantic Segmentation**


## Installation
The code has been tested with Docker (see Docker container below) with Python 3.8, CUDA 10.2/11.1, pytorch 1.8.0 and pytorch-lighting 1.4.1.
Any other version may requireq to update the code for compatibility.

### Pip/Venv/Conda
Following [MinkowskiEnginge](https://github.com/NVIDIA/MinkowskiEngine), this will install all the base packages.

Additionally, you need to install:
- [open3d 0.13.0](http://www.open3d.org)
- [KNN-CUDA](https://github.com/unlimblue/KNN_CUDA)
- [pytorch-lighting 1.4.1](https://www.pytorchlightning.ai)
- [wandb](https://docs.wandb.ai/quickstart)
- tqdm
- pickle
- pytorch3d

If you want to work on nuScenes you need to install
- [nuscenes-devkit](https://github.com/nutonomy/nuscenes-devkit)


## Pretrained models
```
sh train_source.sh
```
Please change the path root to your own path. You can change ```--ignore_class``` to ignore different classes in the training (Only for synlidar2kitti adaptation). 

## Preprocess superpoint cluster
```
python superpoint_gen_kitti.py
python superpoint_gen_nusc.py
```
You can change the ```eps``` and ```min_points``` in the code to get different superpoint clusters.

## Adaptation to target

```
sh train.sh
```
Please change the path root to your own path. You can change ```--ignore_class``` to ignore different classes in the training (Only for synlidar2kitti adaptation). You can also easily and freely delete our modules to obtain different results





