<div align="center">
  <h1> Consistency and Unified Semantic Regularization for Generalized Category Discovery </h1>
</div>

<div align="center">
  <h3>Paper ID 10706 </h3>
</div>

<!-- <p align="center">
  <img src="assets/framework.png" alt="result" width="60%" align="right"/>
</p> -->

## Environmnet installation
This project is built upon the following environment:
* [Python 3.7](https://pytorch.org)
* [PyTorch 1.13.1 + cu117](https://pytorch.org)

The package requirements can be installed via `requirements.txt`, 
```bash
pip install -r requirements.txt
```

## Datasets
We use fine-grained benchmarks in this paper, including:
* [The Semantic Shift Benchmark (SSB)](https://github.com/sgvaze/osr_closed_set_all_you_need#ssb) and [Herbarium19](https://www.kaggle.com/c/herbarium-2019-fgvc6)

We also use generic object recognition datasets, including:
* [CIFAR10](https://pytorch.org/vision/stable/datasets.html), [CIFAR100](https://pytorch.org/vision/stable/datasets.html) and [ImageNet-100](https://image-net.org/download.php)

Please follow [this repo](https://github.com/sgvaze/generalized-category-discovery) to set up the data.

Download the datasets, and pretrained model by following the file structure below and set `DATASET_ROOT={YOUR DIRECTORY}` in `config.py`.

## Training
the backbone obtained from SimGCD
```bash
bash scripts/run_{DATASET}.sh
```
or
```bash
python train.py --dataset_name 'cub' 
```

### Experimental results on GCD task.

<table>
  <tr>
    <td> </td>
    <td>All</td>
    <td>Old</td>
    <td>Novel</td>
  </tr>
  <tr>
    <td>CIFAR10</td>
    <td align="center">97.5</td>
    <td align="center">97.9</td>
    <td align="center">97.3</td>
</tr>
  <tr>
    <td>CIFAR100</td>
    <td align="center">85.7</td>
    <td align="center">85.3</td>
    <td align="center">86.6</td>
</tr>
  <tr>
    <td>ImageNet100</td>
    <td align="center">87.0</td>
    <td align="center">95.3</td>
    <td align="center">82.9</td>
 </tr>
  <tr>
    <td>CUB</td>
    <td align="center">75.2</td>
    <td align="center">75.5</td>
    <td align="center">75.1</td>
 </tr>
  <tr>
    <td>Stanford Cars</td>
    <td align="center">68.7</td>
    <td align="center">80.8</td>
    <td align="center">63.0</td>
 </tr>

  <tr>
    <td>Herbarium19</td>
    <td align="center">48.1</td>
    <td align="center">53.1</td>
    <td align="center">45.4</td>
</tr>

 <tr>
    <td>Aircraft</td>
    <td align="center">61.7</td>
    <td align="center">69.4</td>
    <td align="center">57.8</td>
</tr>
</table>
