Skip to content

automl/LCBench

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LCBench

A learning curve benchmark on openml data.

Dataset overview

LCBench provides extensive training data for different architectures and hyperparameters evaluated on OpenML datasets. The current version provides 2000 configurations, each evaluated on 35 datasets over 50 epochs. Logs include for each epoch:

  • Training, test and validation losses
  • Training, test and validation accuracy
  • Training, test and validation balanced accuracy
  • Global gradient statistics (max, mean, median, norm, std, q10, q25, q75, q90)
  • Layer-wise gradient statistics (max, mean, median, norm, std, q10, q25, q75, q90)
  • Learning rate
  • Runtime

And additionally:

  • Configuration (architecture, hyperparameters)
  • Number of model parameters
  • Dataset statistics (number of classes, instances and features)

The data was created using Auto-PyTorch. All runs feature funnel-shaped MLP nets and use SGD with cosine annealing without restarts. Overall, 7 parameters were sampled at random (4 float, 3 integer). These are:

  • Batch size: [16, 512], on log-scale
  • Learning rate: [1e-4, 1e-1], on log-scale
  • Momentum: [0.1, 0.99]
  • Weight decay: [1e-5, 1e-1]
  • Number of layers: [1, 4]
  • Maximum number of units per layer: [64, 1024], on log-scale
  • Dropout: [0.0, 1.0]

Setup

Clone the git repository:

$ cd install/path
$ git clone ...
$ cd LCBench

Install requirements:

$ cat requirements.txt | xargs -n 1 -L 1 pip install

Downloading the data

You can download the data on figshare. Lightweight versions are indicated by 'lw'. Futhermore, you can find the meta-features for all datasets in the same project.

Quickstart

Loading the data:

from LCBench import Benchmark

bench = Benchmark(data_dir="path/to/data.json")

Querying:

bench.query(dataset_name="credit-g", tag="Train/loss", config_id=0)

Listing available tags:

bench.get_queriable_tags()

Note: Tags starting with "Train/" indicate metrics that are logged every epoch.

Examples

An extended introduction is given in the jupyter notebook example in API Example. For documentation you can also call help on the API methods or check the source.

Tasks for the DL lecture 19/20

For the final project of the DL lecture, default tasks are defined in notebooks. Each notebook contains a short description of the task and a very basic example.

Leaderboard for Default Project

https://docs.google.com/spreadsheets/d/1igH18oFYT5yMNhbqJSVOiG-7SjZ0owvEn5sFJ-nxHDE/edit#gid=0

Citation

@article { ZimLin2021a,
  author = {Lucas Zimmer and Marius Lindauer and Frank Hutter},
  title = {Auto-PyTorch Tabular: Multi-Fidelity MetaLearning for Efficient and Robust AutoDL},
  journal = {IEEE Transactions on Pattern Analysis and Machine Intelligence},
  year = {2021},
  volume = {43},
  number = {9},
  pages = {3079 - 3090}
}