# QIVPT Project

## Overview
QIVPT is a quantum-inspired visual prompt tuning framework designed for fine-tuning and evaluating visual features across various datasets and configurations. It supports multiple training strategies, including fine-tuning, linear evaluation, and prompt-based tuning.

## Features
- Fine-tuning visual features with configurable settings.
- Support for VTAB datasets and other custom datasets.
- Prompt-based tuning with attention mechanisms.
- Reproducible training and evaluation workflows.

## Directory Structure
- `configs/`: Contains YAML configuration files for different training strategies and datasets.
- `src/`: Source code for data loading, model building, training, and evaluation.
- `train.py`: Main script for training and evaluation.
- `requirement.txt`: Lists Python dependencies.
- `env_setup.sh`: Environment setup script.

## Environment Setup
To set up the environment, install the dependencies listed in `requirement.txt`:

```bash
bash env_setup.sh
pip install -r requirement.txt
```

## Data Preparation
Ensure your datasets are organized according to the expected structure defined in the configuration files. VTAB datasets and other custom datasets are supported.

## Quick Start
Run the training script with a specified configuration file:

```bash
bash train_vfpt.sh
```

## Configuration
The project uses YAML configuration files to define training settings. Key parameters include:
- `DATA.NAME`: Dataset name.
- `SOLVER.BASE_LR`: Learning rate.
- `SOLVER.WEIGHT_DECAY`: Weight decay.
- `MODEL.SAVE_CKPT`: Whether to save model checkpoints.

## Outputs
Training outputs are saved in structured directories under `OUTPUT_DIR`, including logs, checkpoints, and evaluation results.

## Notes
- Ensure reproducibility by setting the `SEED` parameter in the configuration.
- Use `train.py` for fine-tuning and evaluation workflows.

