Skip to main content

Generating Realistic Tabular Data using Large Language Models

Project description

PyPI version Downloads

Generation of Realistic Tabular data
with pretrained Transformer-based language models

     

Our GReaT framework leverages the power of advanced pretrained Transformer language models to produce high-quality synthetic tabular data. Generate new data samples effortlessly with our user-friendly API in just a few lines of code. Please see our publication for more details.

GReaT Installation

The GReaT framework can be easily installed using with pip - requires a Python version >= 3.9:

pip install be-great

GReaT Quickstart

In the example below, we show how the GReaT approach is used to generate synthetic tabular data for the California Housing dataset.

from be_great import GReaT
from sklearn.datasets import fetch_california_housing

data = fetch_california_housing(as_frame=True).frame

model = GReaT(llm='distilgpt2', batch_size=32,  epochs=50,
              fp16=True, dataloader_num_workers=4, report_to=[])
model.fit(data)
synthetic_data = model.sample(n_samples=100)

Open In Colab

Imputing a sample

GReaT also features an interface to impute, i.e., fill in, missing values in arbitrary combinations. This requires a trained model, for instance one obtained using the code snippet above, and a pd.DataFrame where missing values are set to NaN. A minimal example is provided below:

# test_data: pd.DataFrame with samples from the distribution
# model: GReaT trained on the data distribution that should be imputed

# Drop values randomly from test_data
import numpy as np
for clm in test_data.columns:
    test_data[clm]=test_data[clm].apply(lambda x: (x if np.random.rand() > 0.5 else np.nan))

imputed_data = model.impute(test_data, max_length=200)

Saving and Loading

GReaT provides methods for saving a model checkpoint (besides the checkpoints stored by the huggingface transformers Trainer) and loading the checkpoint again.

model = GReaT(llm='distilgpt2', batch_size=32,  epochs=50, fp16=True)
model.fit(data)
model.save("my_directory")  # saves a "model.pt" and a "config.json" file
model = GReaT.load_from_dir("my_directory")  # loads the model again

# supports remote file systems via fsspec
model.save("s3://my_bucket")
model = GReaT.load_from_dir("s3://my_bucket")

GReaT Citation

If you use GReaT, please link or cite our work:

@inproceedings{borisov2023language,
  title={Language Models are Realistic Tabular Data Generators},
  author={Vadim Borisov and Kathrin Sessler and Tobias Leemann and Martin Pawelczyk and Gjergji Kasneci},
  booktitle={The Eleventh International Conference on Learning Representations },
  year={2023},
  url={https://openreview.net/forum?id=cEygmQNOeI}
}

Custom Synthetic Data

Need synthetic data for your business? We can help! Contact us at info@tabularis.ai for custom data generation services.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

be_great-0.0.9.tar.gz (19.7 kB view details)

Uploaded Source

Built Distribution

be_great-0.0.9-py3-none-any.whl (19.5 kB view details)

Uploaded Python 3

File details

Details for the file be_great-0.0.9.tar.gz.

File metadata

  • Download URL: be_great-0.0.9.tar.gz
  • Upload date:
  • Size: 19.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for be_great-0.0.9.tar.gz
Algorithm Hash digest
SHA256 78cf67a19bf015ddee5786ddd2e781d2dfac6a91c2a1f5f2c27466126ec78aed
MD5 bd3540a79325da4c5b1e9023daff00d5
BLAKE2b-256 97f6a82feb024cfd19fa97ca841281b7a3f5657ce0d074cc0814896d9db77262

See more details on using hashes here.

File details

Details for the file be_great-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: be_great-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 19.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for be_great-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 27eb324b489eb780c2a35b1c5a6a9c977eb92683c5c84642703eb85c6dcd0968
MD5 03ff5c91e6fc9bc502a51498b0b1cda1
BLAKE2b-256 a7f8644d2194cc66c89758c2d1e873d4213c85ecc3512ed44c9647c3d9206214

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page