pip install tabganGANGenerator().generate_data_pipe:from tabgan.sampler import OriginalGenerator, GANGenerator, ForestDiffusionGenerator, LLMGenerator import pandas as pd import numpy as np # 随机输入数据 train = pd.DataFrame(np.random.randint(-10, 150, size=(150, 4)), columns=list("ABCD")) target = pd.DataFrame(np.random.randint(0, 2, size=(150, 1)), columns=list("Y")) test = pd.DataFrame(np.random.randint(0, 100, size=(100, 4)), columns=list("ABCD")) # 生成数据 new_train1, new_target1 = OriginalGenerator().generate_data_pipe(train, target, test, ) new_train2, new_target2 = GANGenerator(gen_params={"batch_size": 500, "epochs": 10, "patience": 5 }).generate_data_pipe(train, target, test, ) new_train3, new_target3 = ForestDiffusionGenerator().generate_data_pipe(train, target, test, ) new_train4, new_target4 = LLMGenerator(gen_params={"batch_size": 32, "epochs": 4, "llm": "distilgpt2", "max_length": 500}).generate_data_pipe(train, target, test, ) # 定义所有参数的示例 new_train4, new_target4 = GANGenerator(gen_x_times=1.1, cat_cols=None, bot_filter_quantile=0.001, top_filter_quantile=0.999, is_post_process=True, adversarial_model_params={ "metrics": "AUC", "max_depth": 2, "max_bin": 100, "learning_rate": 0.02, "random_state": 42, "n_estimators": 100, }, pregeneration_frac=2, only_generated_data=False, gen_params = {"batch_size": 500, "patience": 25, "epochs" : 500,}).generate_data_pipe(train, target, test, deep_copy=True, only_adversarial=False, use_adversarial=True)
所有采样器OriginalGenerator、ForestDiffusionGenerator、LLMGenerator和GANGenerator都具有相同的输入参数。
generate_data_pipe方法的参数:
因此,你可以使用这个库来提高你的数据集质量:
def fit_predict(clf, X_train, y_train, X_test, y_test): clf.fit(X_train, y_train) return sklearn.metrics.roc_auc_score(y_test, clf.predict_proba(X_test)[:, 1]) dataset = sklearn.datasets.load_breast_cancer() clf = sklearn.ensemble.RandomForestClassifier(n_estimators=25, max_depth=6) X_train, X_test, y_train, y_test = sklearn.model_selection.train_test_split( pd.DataFrame(dataset.data), pd.DataFrame(dataset.target, columns=["target"]), test_size=0.33, random_state=42) print("初始指标", fit_predict(clf, X_train, y_train, X_test, y_test)) new_train1, new_target1 = OriginalGenerator().generate_data_pipe(X_train, y_train, X_test, ) print("OriginalGenerator指标", fit_predict(clf, new_train1, new_target1, X_test, y_test)) new_train1, new_target1 = GANGenerator().generate_data_pipe(X_train, y_train, X_test, ) print("GANGenerator指标", fit_predict(clf, new_train1, new_target1, X_test, y_test))
你可以轻松调整代码以生成多维时间序列数据。 基本上它从_date_中提取天、月和年。以下示例演示如何使用:
import pandas as pd import numpy as np from tabgan.utils import get_year_mnth_dt_from_date,make_two_digit,collect_dates from tabgan.sampler import OriginalGenerator, GANGenerator train_size = 100 train = pd.DataFrame( np.random.randint(-10, 150, size=(train_size, 4)), columns=list("ABCD") ) min_date = pd.to_datetime('2019-01-01') max_date = pd.to_datetime('2021-12-31') d = (max_date - min_date).days + 1 train['Date'] = min_date + pd.to_timedelta(pd.np.random.randint(d, size=train_size), unit='d') train = get_year_mnth_dt_from_date(train, 'Date')
new_train, new_target = GANGenerator(gen_x_times=1.1, cat_cols=['year'], bot_filter_quantile=0.001,
top_filter_quantile=0.999,
is_post_process=True, pregeneration_frac=2, only_generated_data=False).
generate_data_pipe(train.drop('Date', axis=1), None,
train.drop('Date', axis=1)
)
new_train = collect_dates(new_train)
检查数据生成质量 只需使用内置函数
compare_dataframes(original_df, generated_df) # 返回0到1之间的值
运行实验
按照以下步骤运行实验:
./Research/data 文件夹中pip install -r requirements.txtpython ./Research/run_experiment.py。运行所有实验 python run_experiment.py。你可以添加更多数据集,调整验证类型和分类编码器。./Research/results/fit_predict_scores.txt 中查看所有实验的指标实验设计

图1.1 实验设计和工作流程
为确定最佳采样策略,对每个数据集的ROC AUC分数进行缩放(最小-最大缩放),然后在数据集间取平均值。
表1.2 不同数据集的采样结果,越高越好(100% - 每个数据集的最大ROC AUC)
| 数据集名称 | 无 | GAN | 原始采样 |
|---|---|---|---|
| credit | 0.997 | 0.998 | 0.997 |
| employee | 0.986 | 0.966 | 0.972 |
| mortgages | 0.984 | 0.964 | 0.988 |
| poverty_A | 0.937 | 0.950 | 0.933 |
| taxi | 0.966 | 0.938 | 0.987 |
| adult | 0.995 | 0.967 | 0.998 |
如果您在科学出版物中使用GAN-for-tabular-data,我们将感谢您引用以下BibTex条目: arxiv出版物:
@misc{ashrapov2020tabular, title={Tabular GANs for uneven distribution}, author={Insaf Ashrapov}, year={2020}, eprint={2010.00638}, archivePrefix={arXiv}, primaryClass={cs.LG} }
[1] Lei Xu LIDS, Kalyan Veeramachaneni. Synthesizing Tabular Data using Generative Adversarial Networks (2018). arXiv: 1811.11264v1 [cs.LG]
[2] Alexia Jolicoeur-Martineau and Kilian Fatras and Tal Kachman. Generating and Imputing Tabular Data via Diffusion and Flow-based Gradient-Boosted Trees ((2023) https://github.com/SamsungSAILMontreal/ForestDiffusion [cs.LG]
[3] Lei Xu, Maria Skoularidou, Alfredo Cuesta-Infante, Kalyan Veeramachaneni. Modeling Tabular data using Conditional GAN. NeurIPS, (2019)
[4] Vadim Borisov and Kathrin Sessler and Tobias Leemann and Martin Pawelczyk and Gjergji Kasneci. Language Models are Realistic Tabular Data Generators. ICLR, (2023)


企业专属的AI法律顾问
iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。


稳定高效的流量提升解决方案,助力品牌曝光
稳定高效的流量提升解决方案,助力品牌曝光


最新版Sora2模型免费使用,一键生成无水印视频
最新版Sora2模型免费使用,一键生成无水印视频


实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。


选题、配图、成文,一站式创作,让内容运营更高效
讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。


AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。


最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。


像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。


AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。


一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号