# pTNAS

![System Architecture](brand/sys.png)

## Overview

pTNAS is a neural architecture search approach for tabular data.

## Dataset

Download NAS-Bench-Tabular dataset from the following link and extract to `exp_data`:

https://drive.google.com/file/d/1fpKAqvvVooiJh2EIfz18UMsBE4demHL2/view?usp=drive_link

## Project Structure

- **`src/model/`** - Model base classes and implementations
- **`src/proxies/`** - Proxy metrics (pTProxy, etc.) for training-free architecture evaluation
- **`src/search_algorithm/`** - Search algorithms (Evolutionary Algorithm)
- **`src/search_space/`** - Search space definitions (MLP, ResNet)
- **`src/utils/`** - Utility functions (data loading, etc.)
- **`scripts/`** - Execution scripts
  - `ptnas.py` - Main program
  - `baselines/` - Baseline methods
- **`logs/`** - Logs and result files
- **`brand/`** - Project resource files

## Usage

### Basic Command

```bash
python scripts/ptnas.py \
    --data_dir <data_directory> \
    --space_name <mlp|resnet> \
    --output_csv <output_csv_path> \
    --device cuda:0 \
    --seed 42
```

### Arguments

- `--data_dir`: Data directory (required)
- `--space_name`: Search space, choose `mlp` or `resnet` (required)
- `--output_csv`: Output CSV file path (required)
- `--device`: Device, default `cuda:0`
- `--seed`: Random seed, default `42`

### Example

```bash
python scripts/ptnas.py \
    --data_dir /path/to/data \
    --space_name mlp \
    --output_csv logs/results.csv \
    --device cuda:0 \
    --seed 42
```
