# Code Availability.
To facilitate reproducibility, we provide an anonymized code repository containing the implementation of nD-RoPE and all experiments reported in this paper:

https://anonymous.4open.science/r/nD-RoPE-26B9

The repository will remain unchanged during the review period.

A zipped snapshot of the same repository is also provided in the supplementary materials for convenience.

# nD-RoPE: Core Implementation Across Multiple Architectures

This repository contains the core implementation of nD-RoPE evaluated across four representative architectures and tasks, covering point clouds, images, and videos:

- **Point Cloud Transformer (PCT v1)**  
  Based on: https://github.com/qq456cvb/Point-Transformers
- **Point Transformer v2 (Pointcept)**  
  Based on: https://github.com/Pointcept/Pointcept
- **Image Classification (RoPE-ViT / DeiT)**  
  Based on: https://github.com/facebookresearch/deit
- **Video Recognition (TimeSformer)**  
  Based on: https://github.com/facebookresearch/TimeSformer

Each experiment includes **nD-RoPE / other RoPE baselines**, along with training and evaluation scripts.

---
## 0. Dataset Preparation

1. **ImageNet-1K (ILSVRC 2012)**  
   Download from: https://image-net.org/challenges/LSVRC/2012/index.php

2. **Kinetics-400**  
   Download from: https://github.com/cvdfoundation/kinetics-dataset

3. **ModelNet40**  
   Download from: https://modelnet.cs.princeton.edu/

4. **SemanticKITTI**  
   Download from: https://semantic-kitti.org/dataset.html

After downloading the datasets, update the dataset paths in the corresponding configuration files:
- For **Pointcept** and **TimeSformer**, modify the dataset paths in the relevant config files.
- For **RoPE-ViT**, update the paths in the corresponding training or evaluation bash scripts.
- For **PCT**, you may alternatively place the datasets directly under the `data/` directory.


## 1. PCT v1 (Point-Transformers)

### Directory Structure
```
PCT/
├─ Point-Transformers-ndrope
└─ Point-Transformers-ndrope-vector
```

### Implementation
- Core implementation (vector attention and dot-product variants):
```
models/PT_ndrope/transformer.py
```

- Configuration:
```
config/partseg_ndrope.yaml
```

### Training
```bash
python train_partseg_ndrope.py
```

### Testing (Density Extrapolation)
```bash
bash test_partseg.bash
```

---

## 2. Point Transformer v2 (Pointcept)

### Implementation
```
pointcept/models/point_transformer_v2/
```
- Includes implementations of nD-RoPE vector attention, dot-product attention, and other RoPE variants.

### Configuration
```
configs/semantic_kitti/
```

### Training
```bash
bash train.bash
```

### Testing
```bash
bash base_test.bash
```

---

## 3. Image Classification (RoPE-ViT / DeiT)

### Implementation
```
models_v2_ndrope.py
```
- Includes nD-RoPE and other RoPE variants.

### Training
```bash
bash run_ndrope.bash
```

### Evaluation
To evaluate nD-RoPE without extrapolation techniques:
```bash
bash evaluate_ndrope.bash
```
To evaluate nD-RoPE with YaRN for resolution extrapolation:
```bash
bash evaluate_ndrope-yarn.bash
```

- Training recipes:
```
deit/
```

---

## 4. Video Recognition (TimeSformer)

### Implementation
```
timesformer/models/vit_ndrope.py
```

### Configuration
```
configs/Kinetics/Timesformer_divST_8x32_224-ndrope.yaml
```
- Other RoPE / nD-RoPE variants follow the same naming pattern.

### Training
```bash
bash train_baseline.bash
```

### Testing
Use the corresponding _test.yaml configuration:
```bash
bash train_baseline.bash --cfg Timesformer_divST_8x32_224_TEST-ndrope.yaml
```

---