# ACDC: Adaptive Cloud-Device Collaboration for Efficient and Accurate Semantic Segmentation

## Overview

This repository provides the core implementation of the **Adaptive Cloud-Device Collaboration (ACDC)** framework. ACDC is designed to tackle challenges in semantic segmentation by combining efficient device-side processing with robust cloud-side computation. Built on the **mmsegmentation** framework, it achieves precise segmentation while minimizing data transmission.

### Key Features of ACDC Framework

1. **Device-Aware Adaptive Segmentor (DAS):** Utilizes a two-stage Uncertainty Decoupler for coarse segmentation and uncertainty detection.
2. **Dynamic Cloud Augmentation Module (DCAM):** Processes challenging samples in the cloud with adaptive updates.
3. **Collaborative Fusion Engine (CFE):** Merges device-side contour information with cloud-side predictions for enhanced segmentation accuracy.

Extensive experiments demonstrate that ACDC improves segmentation performance while adapting to dynamic environments with minimal data transfer.

## Directory Structure

The project is organized as follows:

```
configs
├── _base_
│   ├── datasets          # Dataset configuration files
│   ├── default_runtime.py  # Default runtime configuration
│   ├── models            # Base model configuration files
│   ├── schedules         # Training schedule configuration files
├── acdc
│   ├── acdc_hrnet48_segformerb5_minku_480x480_80k_pascal-context.py
│   ├── acdc_hrnet48_segformerb5_minku_512x512_80k_ade20k.py
│   ├── acdc_hrnet48_segformerb5_minku_512x1024_80k_cityscapes.py
│   ├── acdc_hrnet48_segformerb5_minku_512x1024_80k_pascal_voc12.py

mmseg
├── models
│   ├── backbones
│   ├── data_preprocessor.py
│   ├── decode_heads
│   ├── segmentors       # Contains ACDC framework code
│   ├── UncerDetector.py # Custom uncertainty detection module

tools
├── dist_test.sh         # Script for distributed testing
├── dist_train.sh        # Script for distributed training
├── test.py              # Testing script
├── train.py             # Training script
```

## Prerequisites

### 1. Environment Setup

This project is based on Python and PyTorch. To set up the environment, follow the [mmsegmentation installation guide](https://github.com/open-mmlab/mmsegmentation#installation).

### 2. Code Integration

The repository includes essential components of the ACDC framework. To use the code:

1. Copy custom files (e.g. `acdc.py`) to the corresponding directories in your mmsegmentation environment.
2. Add the provided configuration files to the `configs` directory of mmsegmentation.

## Usage

### Training

To train a model with the ACDC framework, use the following command:

```
bash tools/dist_train.sh <CONFIG_FILE> <NUM_GPUS>
```

Example:

```
bash tools/dist_train.sh configs/acdc/acdc_hrnet48_segformerb5_minku_512x1024_80k_cityscapes.py 4
```

### Testing

To test a model:

```
bash tools/dist_test.sh <CONFIG_FILE> <CHECKPOINT_FILE> <NUM_GPUS>
```

Example:

```
bash tools/dist_test.sh configs/acdc/acdc_hrnet48_segformerb5_minku_512x1024_80k_cityscapes.py work_dirs/checkpoint.pth 4
```

## Components

### Configuration Files

- **Base Configurations (base):** Include datasets, runtime, models, and training schedules.
- **ACDC Configurations:** Framework-specific configurations for various datasets:
  - Pascal Context
  - ADE20K
  - Cityscapes
  - Pascal VOC

### Custom Modules

The `mmseg/models` directory contains the implemented framework code, including ACDC-specific modules.

### Scripts

- **train.py:** Script for training models.
- **test.py:** Script for evaluating models.
- **dist_train.sh** and **dist_test.sh:** Scripts for distributed training and testing.