# This repository contains the official PyTorch implementation and supplementary material for the conference review.

## Introduction

3D hierarchical semantic segmentation is a crucial task for various applications, but it faces challenges like multi-hierarchy conflicts and class imbalance. To address these issues, we propose a novel framework, which features a late-decoupled architecture and an auxiliary SSL discrimination branch. This design mitigates conflicts between different hierarchy levels and alleviates the class imbalance problem. Our approach achieves state-of-the-art performance on challenging 3D semantic segmentation benchmarks.

## Installation

1.  **Clone the repository:**

    ```bash
    # The code is provided in the supplementary material.
    # Anonymized for blind review.
    ```

2.  **Create a Conda environment:**

    We recommend using Conda to manage the dependencies. The following commands will create a new environment with the specified versions of Python, CUDA, and PyTorch, and then install other necessary packages.

    ```bash
    # Create a new conda environment
    conda create -n ld3dhs python=3.8 -y
    conda activate ld3dhs

    # Install PyTorch with CUDA 11.8
    conda install pytorch==2.0.0 torchvision torchaudio pytorch-cuda=11.8 -c pytorch -c nvidia

    # Install other Python dependencies
    pip install -r requirements.txt

    # Compile custom CUDA operators
    # The original install.sh script compiles several custom operators.
    # Please run the following commands to compile them manually.
    cd openpoints/cpp/pointnet2_batch && python setup.py install && cd ../../../
    cd openpoints/cpp/subsampling && python setup.py build_ext --inplace && cd ../../../
    cd openpoints/cpp/pointops && python setup.py install && cd ../../../
    ```

    *Note: The provided `install.sh` script is configured for a different environment (Python 3.7, PyTorch 1.10.1). The instructions above have been updated to match your requirements. Please use these manual commands instead of the original script.* 

## Data Preparation

Please follow the instructions in the `preprocess/` directory to prepare the datasets (S3DIS, ScanNet, SensatUrban). You will need to download the raw data and then run the provided scripts to generate the pre-processed files.

## Training

To train the model, you can use the `main/main.py` script. The training configurations are defined in the `cfgs/` directory. For example, to train the model on the S3DIS dataset, you can run:

```bash
python main/main.py --cfg cfgs/3dhs/pointnet++.yaml
```

You can modify the `.yaml` files to change the training parameters, such as the learning rate, batch size, and number of epochs.

## Testing

To evaluate a trained model, you can use the `main/main.py` script with the `--test` flag. You also need to provide the path to the pre-trained model weights using the `--pretrained` argument.

```bash
python main/main.py --cfg cfgs/3dhs/pointnet++.yaml --test --pretrained /path/to/your/model.pth
```

## Configuration

The configuration files in the `cfgs/` directory are in YAML format. The `base.yaml` file contains the default settings, and the other files inherit from it and override specific parameters for different models and datasets.

Key configuration parameters include:

*   `dataset`: Dataset-specific settings, such as the data root, test area, and voxel size.
*   `model`: Model architecture and hyperparameters.
*   `optimizer`: Optimizer settings, such as the learning rate and weight decay.
*   `scheduler`: Learning rate scheduler settings.
*   `criterion`: Loss function settings.
