# RadAgents (Basic Implementation)

This repo is a **basic and anonymized** implementation of RadAgents: a multi-agent system for chest X-ray interpretation. It orchestrates modular tools (classification, segmentation, grounding, DICOM processing, etc) and includes example scripts for visual question answering (VQA) and current-vs-prior comparisons.

- Status: basic research implementation
- Privacy: anonymized; no personal or institutional identifiers

## Installation

Prerequisites:
- Python >= 3.10
- macOS/Linux
- Optional GPU for heavy models

Setup:
```bash
python3 -m venv .venv
source .venv/bin/activate
pip install --upgrade pip
pip install -e .
```

Notes:
- Large model weights are not included; set `--model-dir` to your local weights directory if needed.
- CUDA is recommended but optional.

## 🔧 API Setup

This project uses the **Azure OpenAI API** for model access.  

### 1. Create a `.env` file
In the root directory of the project, create a file named `.env` and add the following environment variables:

```bash
AZURE_OPENAI_API_KEY=<your-azure-api-key>
AZURE_OPENAI_ENDPOINT=<your-azure-endpoint>
AZURE_OPENAI_API_VERSION=<your-api-version>
AZURE_OPENAI_DEPLOYMENT_NAME=<your-deployment-name>
```

## Usage Examples

Single-image VQA:
```bash
python run_exp_vqa.py \
  --image data/cardic_example/mild_enlarge_cardi.png \
  --query "Describe any cardiac findings on this CXR." \
  --model gpt-4o \
  --model-dir ./models
```

Current vs. prior comparison:
```bash
python run_exp_comparison.py \
  --current data/cardic_example/mild_enlarge_cardi.png \
  --prior data/cardic_example/normal_cxr.jpeg \
  --query "Has the heart size changed?" \
  --model gpt-4o \
  --model-dir ./models
```

See script help for full options:
```bash
python run_exp_vqa.py -h
python run_exp_comparison.py -h
```

## Programmatic API

```python
from radagents.multi_agent import (
    initialize_multi_agent_system,
    run_multi_agent_analysis,
    analyze_chest_xray,
)
```

- initialize_multi_agent_system(...) creates the orchestrator and loads tools/agents
- run_multi_agent_analysis(...) runs the analysis for a query and image path
- analyze_chest_xray(...) is a convenience wrapper for one-shot analysis

## Configuration

Common options:
- --model: LLM to use (e.g., gpt-4o)
- --temperature: LLM temperature
- --model-dir: directory for local model caches/weights (default ./models)
- --device: cuda or cpu
- --execution-mode: parallel or sequential
- --agents: specify a subset of agents (e.g., "cardiac airway synthesis")
- --no-smart-loading: load all tools instead of inferred subset

Azure OpenAI env vars are supported if set (AZURE_OPENAI_*).

## Anonymization Notes

- Import path is `radagents` (a shim re-exports public APIs from the internal modules).
- Personal paths removed; defaults use `./models`.
- UI branding uses generic text and no logos.
- `pyproject.toml` uses anonymous author metadata.

If you notice any remaining identifiers (names, institutions, logos), please remove them before release.

## Data

Demo images are under `data/cardic_example/` for testing only.

## License

See `LICENSE`.
