## Setup

1) Download the two datasets from these links:
   - [agenttrek-with-importance-diversity-score.json](https://drive.google.com/file/d/1a-XnF2aitsXBQd5yf5ALlQvQP28pSrqJ/view?usp=sharing)
   - [full-agenttrek-dataset-pruned.json](https://drive.google.com/file/d/1SFaCCW-3NExYi6jb2EkFT9BpQhp9FZ7N/view?usp=sharing)

2) Put both datasets inside `weasel/`.

3) Run the greedy selection:
```bash
python greedy-algorithm.py
```
This generates and saves `full_selected_dataset_indices_T0_3_agenttrek.json` in the same folder.

4) Run post-processing:
```bash
python post-process-data.py
```
This generates `agenttrek_dataset_pruned_centered_w_threshold_sampled_10k_T0_3_agenttrek.json`.

5) Use the generated dataset to train the model with LLaMA-Factory:
`agenttrek_dataset_pruned_centered_w_threshold_sampled_10k_T0_3_agenttrek.json`
LLaMA-Factory: [link](https://github.com/hiyouga/LlamaFactory.git)

## Training config (LLaMA-Factory)

After installing LLaMA-Factory, create `qwen3-4b-it.yaml` inside `LLaMA-Factory/examples/train_lora` and paste:
```yaml
### model
model_name_or_path: google/gemma-3-4b-it
trust_remote_code: true

### method
stage: sft
do_train: true
finetuning_type: lora
lora_rank: 8
lora_target: all
deepspeed: examples/deepspeed/ds_z0_config.json 
enable_liger_kernel: true
flash_attn: fa2

### dataset
dataset: <Add the name of dataset template here>
# dataset: agenttrek_dataset_10k
template: gemma3
cutoff_len: 12000
overwrite_cache: true
preprocessing_num_workers: 16

### output
output_dir: saves/gemma3-4b/lora/
logging_steps: 100
save_steps: 1000
plot_loss: true
overwrite_output_dir: true
# save_only_model: false
report_to: wandb 

### train
per_device_train_batch_size: 2
gradient_accumulation_steps: 8
learning_rate: 2.0e-5
# learning_rate: 1.0e-4
num_train_epochs: 2.0
lr_scheduler_type: cosine
warmup_ratio: 0.1
bf16: true
ddp_timeout: 180000000
resume_from_checkpoint: null
# packing: true

### eval
val_size: 0.1
per_device_eval_batch_size: 1
eval_strategy: steps
eval_steps: 2500
```
Inside `LLaMA-Factory/data/dataset_info.json` add generated dataset template.

## Evaluation

For evaluation, use BrowserGym (repo): [link](https://github.com/ServiceNow/BrowserGym.git)
 
