# DiP-G: Discrete Prompting for Graphs

This repository contains the official implementation of **DiP-G** (**Di**screte **P**rompting for **G**raphs).

## Abstract
DiP-G is a discrete graph prompting framework designed to bridge the "discretization gap" in few-shot graph adaptation. Unlike existing methods that optimize continuous weighted adjacency matrices, DiP-G learns task-specific graph structures directly in the combinatorial space. It features:
1.  **Parametric Local Prompting**: Scalable candidate scoring on local subgraphs.
2.  **Perturbed Discrete Solver**: Generates hard $k$-sparse prompts.
3.  **Adaptive Screening**: Accelerates I-MLE gradient estimation by restricting the search space.

## Requirements
* python >= 3.9
* torch >= 2.2.0
* torch-geometric >= 2.5.0
* numpy
* scikit-learn

## File Structure
* `run.py`: Entry point for training.
* `task.py`: Main training loop and evaluation logic.
* `dipg_solver.py`: Implementation of I-MLE with Adaptive Screening.
* `prompt.py`: Prompt generator network (MLP).
* `model.py`: Backbone GCN architecture.
* `load_data.py`: Data loading and candidate subgraph construction.
* `utils.py`: Argument parsing and helper functions.

## Usage

### 1. Prepare Data & Pre-trained Models
Ensure datasets are in `./data` and pre-trained GCN models are in `./pretrained_gnns`.

### 2. Run DiP-G
To reproduce the experiments on **PubMed** (5-shot) with default parameters ($k=8, m=128, r=4$):

```bash
python run.py \
  --dataset_name PubMed \
  --pretrain_task EdgePredGraphPrompt \
  --shots 5 \
  --k 8 \
  --m 128 \
  --r 4 \
  --gpu_id 0