# PLOT: Pseudo-Labeling via Video Object Tracking


## Installation
<!-- We recommand to follow the installation instruction in [GroundingDINO](https://github.com/IDEA-Research/GroundingDINO), first. -->

Create a conda environment:

```bash
conda create -n plot python=3.10
conda activate plot

pip install torch==2.4.0 torchvision==0.19.0 xformers --index-url https://download.pytorch.org/whl/cu121

pip install -e .
```

> Notes: If you have an error using numba, please install numba according to this [official instructions](https://github.com/numba/numba#custom-python-environments) to setup llvm and cuda for numba.

## Dataset Preparation

### KITTI

```bash
|__ KITTI_Det
    |__ ImageSets
        |__ *.txt
    |__ training
        |__ calib
            |__ *.txt
        |__ image_2
            |__ *.png
        |__ label_2
            |__ *.txt

|__ KITTI_Raw
    |__ 2011_09_26
        |__ 2011_09_26_drive_0001_sync
            |__ image_02
                |__ data
                    |__ *.png
    |__ ...

```

Generate Temporal Frames

```bash
python preprocess/kitti/create_temporal_frames.py
```

Frames will be in the following format:

```txt
past_frames <- target_frame -> future_frames
0, ..., 19 <- 20 -> 21, ..., 40
```

> Notes: Some scenes may not have the full 41 frames but 20th frame will be the target frame no matter what.


## Pseudo-Labeling

For all submodules, install necessary requirements separately following the original implementation.


### Generate Detections and Masks
with GroundedSAM:

```bash 
python pseudo_labels/genreate_masks_groundedsam.py
```

### Generate Tracklets
with AllTracker:

```bash 
python pseudo_labels/generate_tracks_alltracker.py
```

Output will a numpy `.npy` pickle-like file with keys: 'tracks', 'visibility', 'confs'.



### Generate Depths

```bash 
python pseudo_labels/generate_depths.py
```

Output will be a numpy `.npz` file with keys: 'depth', 'conf', 'intrinsics'.


### Pseudo-LiDAR Completion and Attributes Estimation

KITTI
```bash 
python plot/datasets/kitti.py
```