# Supplementary Material

This repository contains the necessary scripts, configurations, and example data structures for Orion main experiments, LLM intelligent retrieval, and DREAM3. Please execute all commands strictly within this directory.

- **Working Directory**: Please first enter Supplementary_Material

## Directory Structure Overview

- **DREAM3_configs/**: DREAM3-specific configurations (Example: Ecoli1_config.conf)
- **DREAM3_Orion/**: DREAM3 data and examples (partial file examples provided under Ecoli1/)
- **Fine_tuning/**: Fine-tuning scripts and data processing examples
- **Orion/**: Orion models, training/testing scripts, general configuration files and data directories
- **Others/**: Storage for final fine-tuned models (too large in size, currently empty placeholder)

## Environment

- Python 3.11.10
- PyTorch 2.4.0
- CUDA 12.1.1
- Other dependencies: Please install based on error messages or file documentation

## Data Placement

1. Download required data before running scripts.
2. Place Orion general data in: `./Orion/data/` (placeholder instructions already in folder).
3. Place final fine-tuned model (final_model) in `Others/`. Currently not provided, will be made public after paper acceptance. Fine-tuning data and code are provided for self-training.

## Important Conventions

- DREAM3 configuration: `./DREAM3_configs/Ecoli1_config.conf`
- LLM experiments (Orion) configuration: Configuration files under corresponding dataset in `./Orion/data/subset/`

---

## Quick Start

### Main Experiment Workflow

1. **Data Preprocessing**
   ```bash
   python ./Orion/prepareData.py --config ./Orion/configurations/Orion_dataset_name_config.conf
   ```

2. **Training**
   ```bash
   python ./Orion/train_Orion.py --config ./Orion/configurations/Orion_dataset_name_config.conf --seed 42
   ```

3. **Testing**
   ```bash
   python ./Orion/test_Orion.py --config ./Orion/configurations/Orion_dataset_name_config.conf
   ```

### LLM Experiment Full Workflow

1. **Data Preprocessing**
   ```bash
   python ./Orion/prepareData.py --config ./Orion/configurations/Orion_dataset_name_config.conf
   ```

2. **Training**
   ```bash
   python ./Orion/train_Orion.py --config ./Orion/data/subset/Orion_dataset_name_config.conf --seed 42
   ```

3. **Testing**
   ```bash
   python ./Orion/test_Orion.py --config ./Orion/data/subset/Orion_dataset_name_config.conf
   ```

**Notes:**
- Replace `<dataset>` with the subdataset directory name you use in `./Orion/data/subset/`.
- If using general configuration (not through subset), you can also use example configurations provided in `./Orion/configurations/`.

### DREAM3 Full Workflow

1. **Data Processing**
   ```bash
   python ./Orion/prepareData.py --config ./DREAM3_configs/Ecoli1_config.conf
   ```

2. **Training**
   ```bash
   python ./Orion/train_Orion.py --config ./DREAM3_configs/Ecoli1_config.conf --seed 42
   ```

3. **Testing (AUC)**
   ```bash
   python ./Orion/test_dream3_auc.py --config ./DREAM3_configs/Ecoli1_config.conf
   ```