# TabPack

The implementation of TabPack.

## Setup

First, install [uv](https://github.com/astral-sh/uv).
Then, run the following command from the root of this repository:

```bash
uv sync
```

Download and unpack the data (the `data/` directory should appear as a result):

```bash
wget https://zenodo.org/records/18411966/files/tabpack-data.tar.gz?download=1 -o data.tar
tar -xvf data.tar
```

## Running experiments

### TabPack

To run TabPack on the `california` dataset, create a copy of an existing experiment and run `bin/tabpack.py` with the `--force` flag:

```bash
cp -r exp/tabpack/california exp/tabpack/california-copy
uv run bin/tabpack.py exp/tabpack/california-copy --force
```

### TabPack with feature embeddings

Similarly to the above:

```bash
cp -r exp/tabpack-emb/california exp/tabpack-emb/california-copy
uv run bin/tabpack.py exp/tabpack-emb/california-copy --force
```

## Experiment configs and results

All results are in the `report.json` files next to the corresponding configs.

- `exp/tabpack/`: Base TabPack model
- `exp/tabpack-emb/`: TabPack with periodic embeddings

The above experiments represent the main runs of TabPack used in the paper.
