Skip to content

tamu-edu-students/SLTRLProject

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This codebase was created as a submission for CSCE-642 at Texas A&M University by Dineth Gunawardena and Wahib Kapdi.

DISLCLAIMER : This code base is based off of Kim Minji's Github repository Here for SLTTracking. This repository provide a perfect framework to further improve the performance for TransT tracker by using different RL techniques. We have created our implementation of A2C based SLT in this repository after stripping the repository down to only the necessary files.

Introduction

Traditional visual object trackers often rely on frame-level tracking, which struggles with challenges like occlusion, motion blur, or ambient conditions. This project addresses these issues by treating tracking as a sequential decision problem. By incorporating past frames and bounding boxes as inputs to a reinforcement learning (RL) network, we aim to reduce random perturbations and improve tracking robustness for difficult scenarios.

Improving Object Tracking Networks using Deep Reinforcement Learning

This project seeks to enhance visual object tracking performance by integrating RL algorithms with existing tracking frameworks. Specifically, we use Transformer Tracking (TransT) with sequence-level reinforcement learning. We trained and tested our models on the GOT10K dataset, drawing on the implementation from Kim et al. (2022).

Getting Started

Setup

We tested the codes in the following environments but other versions may also be compatible.

  • CUDA 11.3
  • Python 3.9
  • PyTorch 1.10.1
  • Torchvision 0.11.2
# Create and activate a conda environment
conda create -y --name slt python=3.9
conda activate slt

# Install PyTorch
conda install pytorch==1.10.1 torchvision==0.11.2 cudatoolkit=11.3 -c pytorch -c conda-forge

# Install requirements
pip install -r requirements.txt
sudo apt-get install libturbojpeg

Add the your workspace_path and your local GOT10k dataset path to local.py and local.py

Testing SLT

  1. Store one of the two models on your local system.
  2. Add the path to this file to slt_transt.py
  3. Then run
python pytracking/run_tracker.py slt_transt slt_transt --dataset_name got10k_test
  1. Then run and submit the generated .zip to the GOT10K Evaluation.
python pytracking/util_scripts/pack_got10k_results.py slt_transt slt_transt

Training SLT

  1. Store the baseline model above in yout local system.
  2. Add the path to this file to as a pretrained model slt_transt.py
  3. Then run
python ltr/run_training.py slt_transt slt_transt

Testing A2C SLT

  1. Store this model on your local system.
  2. Add the path to this file to ac_slt_transt.py
  3. Then run
python pytracking/run_tracker.py ac_slt_transt ac_slt_transt --dataset_name got10k_test
  1. Then run and submit the generated .zip to the GOT10K Evaluation.
python pytracking/util_scripts/pack_got10k_results.py ac_slt_transt ac_slt_transt

Training A2C SLT

  1. Store the baseline model above in yout local system.
  2. Add the path to this file to as a pretrained model ac_slt_transt.py
  3. Then run
python ltr/run_training.py ac_slt_transt ac_slt_transt

Results

Model Data Used AO SR50 SR75
TransT (Baseline)** [1] Multiple 66.2 75.5 58.5
SLT + TransT ([1]) Multiple 72.0 81.6 68.3
SLT + TransT (Ours) GOT-10K 72.5 82.2 68.8
A2C SLT + TransT GOT-10K 70.5 79.9 66.3

Notes:

  • Multiple Dataset represents a superset of the following publicly available datasets: TrackingNet, GOT-10k, LaSOT, ImageNet-VID, DAVIS, YouTube-VOS, MS-COCO, SBD, LVIS, ECSSD, MSRA10k, and HKU-IS.
  • ** Data that we did not verify, but taken directly from Kim et al. (2022) (See Acknowledgments).

image

Description: A screenshot of performance comparison of various models on the GOT-10k dataset. The table highlights the Average Overlap (AO), Success Rate at 50% (SR50), and Success Rate at 75% (SR75) metrics for the SLT-enhanced versions (as per the referenced paper and the current work), and the proposed A2C SLT + TransT method.

In the results, it is evident that SLT improves on the Baseline. In case of our A2C SLT, we failed to train it for long enough, but it still surpasses the Baseline on all measures and reaches pretty close to the SCST based SLT Tracker.

Work Yet to be done and further research

  • Explore other base trackers (e.g., Siamese trackers, TransDiMP).
  • Compare performance with different RL techniques (e.g., PPO, DDPG).
  • Add attention mechanisms for smoother tracking.
  • Implement real-time tracking capabilities.
  • Generate more visual results and user-friendly frontends.

Acknowledgments

SLTTracking was not developed by us, it is taken from the 2022 ECCV paper by Kim, Minji et al.

@inproceedings{SLTtrack,
  title={Towards Sequence-Level Training for Visual Tracking},
  author={Kim, Minji and Lee, Seungkwan and Ok, Jungseul and Han, Bohyung and Cho, Minsu},
  booktitle={ECCV},
  year={2022}
}

We have used it's code base here as our starting point. Here is link to it's github Github. SLTtrack is developed upon PyTracking library, also borrowing from TransT. We would like to thank the authors for providing great frameworks and toolkits.

Contact

Dineth Gunawardena: [email protected]
Wahib Kapdi: [email protected]

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published