# FT-Agent

LLM Fine-tuning Agent - An automated fine-tuning framework powered by LLM.

## Installation

```bash
pip install -e .
```

## Quick Start

### 1. Configure Environment Variables

Copy the example environment file and configure the necessary variables:

```bash
cp .env.example .env
# Edit .env with your configuration
```

### 2. Run Fine-tuning Task

```bash
# Basic usage
python ftagent/app/finetune/llm/loop.py --base-model <model_path>

# Example: using Qwen3-8B model
python ftagent/app/finetune/llm/loop.py --base-model Qwen/Qwen3-8B

# Specify GPUs
CUDA_VISIBLE_DEVICES=0,1 python ftagent/app/finetune/llm/loop.py --base-model Qwen/Qwen3-8B

# Set timeout
python ftagent/app/finetune/llm/loop.py --base-model Qwen/Qwen3-8B --timeout 12h
```

### 3. Launch Web UI

```bash
streamlit run ftagent/app/finetune/llm/ui/app.py
```

## Main Parameters

| Parameter | Description | Example |
|-----------|-------------|---------|
| `--base-model` | HuggingFace model path | `Qwen/Qwen3-8B` |
| `--timeout` | Run timeout | `12h`, `30m` |

## Environment Variables

| Variable | Description |
|----------|-------------|
| `CUDA_VISIBLE_DEVICES` | GPU device IDs to use |
| `LOG_TRACE_PATH` | Log output path |
| `WORKSPACE_PATH` | Workspace path |
| `FT_TARGET_BENCHMARK` | Target evaluation benchmark |
| `FT_BENCHMARK_DESCRIPTION` | Benchmark description |

## Project Structure

```
FT-Agent/
├── ftagent/                    # Source code
│   ├── app/                    # Application entry points
│   │   ├── finetune/          # Fine-tuning scenario
│   │   │   └── llm/           # LLM fine-tuning
│   │   │       ├── loop.py    # Main entry
│   │   │       └── ui/        # Web UI
│   │   └── utils/             # Utility functions
│   ├── components/            # Core components
│   │   ├── coder/            # Code generation
│   │   └── workflow/         # Workflow
│   ├── core/                  # Core abstractions
│   ├── scenarios/            # Scenario definitions
│   └── utils/                # Common utilities
├── eval_patches/              # Evaluation framework patches
│   ├── opencompass.patch     # OpenCompass modifications
│   └── README.md             # Patch instructions
├── pyproject.toml
├── requirements.txt
└── README.md
```

## Evaluation Setup

FT-Agent uses a customized version of OpenCompass for evaluation. To set up:

```bash
# Clone OpenCompass
git clone https://github.com/open-compass/opencompass.git
cd opencompass

# Apply our customizations
git apply /path/to/FT-Agent/eval_patches/opencompass.patch

# Install
pip install -e .
```

See `eval_patches/README.md` for details on the added benchmarks.

## Requirements

- Python >= 3.10
- PyTorch
- Transformers
- LlamaFactory (for fine-tuning)
- OpenCompass (for evaluation)
