Skip to main content

A privacy-preserving data publishing tool with parameter optimization

Project description

Privacy Tuner

Privacy Tuner 是一个通用的隐私保护数据发布工具。它通过智能参数搜索,在用户指定的隐私预算和效用目标约束下,自动寻找最优的数据扰动参数(如噪声尺度、泛化粒度、采样比例等),从而在保护隐私的同时最大化数据的实用性。最终输出净化后的数据集、最优参数组合以及可视化报告。

特性

  • 模块化设计:支持可插拔的隐私机制、风险度量、效用评估和优化器,方便扩展与定制。
  • 多种隐私模型:内置差分隐私(拉普拉斯、高斯)、经验风险(KNN 成员推断攻击)等,并预留接口支持 k-匿名等传统方法。
  • 多种数据类型:表格数据原生支持,并预留文本、图像数据加载接口。
  • 自动参数搜索:提供网格搜索、贝叶斯优化、遗传算法等多种优化器,自动探索参数空间。
  • 可解释性:生成风险-效用曲线和自然语言报告,帮助理解参数选择的理由。
  • 结果可复现:支持保存最优参数、扰动数据和报告,便于审计和二次使用。

安装

通过 PyPI 安装(推荐)

pip install privacy-tuner

从源码安装

如果你已经获取了项目源码(例如从本地目录或压缩包),可以在项目根目录下执行以下命令进行安装:

cd privacy_tuner   # 进入项目根目录
pip install -e .

注:-e 选项表示以可编辑模式安装,方便修改代码后立即生效。如果不需要修改源码,也可以去掉 -e 进行普通安装。

快速开始

Python API

from privacy_tuner import protect
import numpy as np

# 假设你有一个数据数组,最后一列是标签
data = np.random.randn(100, 5)  # 100个样本,5个特征
labels = (data[:, 0] > 0).astype(int)
data = np.column_stack([data, labels])

# 一键保护数据
result = protect(data, epsilon=1.0, output_dir='output')

print(f"最优参数: {result['best_params']}")
print(f"效用 (准确率): {result['best_utility']:.4f}")
print(f"风险: {result['best_risk']:.4f}")

命令行工具(安装后使用)

privacy-tuner your_data.csv --epsilon 1.0 --output results

更多示例请参考项目中的 examples 目录。

核心模块

模块 描述 内置实现
输入层 数据加载与特征分析 CSVLoader, FeatureAnalyzer
隐私机制 数据扰动算法 CopulaMechanism, LaplaceMechanism, GaussianMechanism
风险度量 隐私风险评估 EmpiricalRiskMeter, DPRisk
效用评估 数据实用性评估 TSTRClassifier, QueryError, ClusteringSilhouette
优化器 参数自动搜索 GridSearchOptimizer, BayesianOptimizer, GeneticOptimizer
输出层 结果导出与报告 CSVExporter, HTMLReporter
可视化 图表绘制 Visualizer

目录结构

privacy_tuner/
├── privacy_tuner/               # 主代码包
│   ├── input/                   # 数据加载与特征分析
│   ├── core/                    # 核心模块(机制、风险、效用、优化器)
│   ├── output/                  # 数据导出与报告生成
│   ├── visualization/           # 可视化工具
│   ├── validation/              # 验证与案例库
│   └── examples/                # 使用示例
├── tests/                       # 单元测试
├── docs/                        # 文档
├── README.md
├── LICENSE
├── CONTRIBUTING.md
├── MANIFEST.in
├── setup.py
└── requirements.txt

开发与贡献

欢迎参与开发!请阅读 CONTRIBUTING.md 了解环境搭建、代码风格和测试流程。

本地开发环境

# 进入项目根目录
cd privacy_tuner

# 创建虚拟环境(可选)
python -m venv venv
source venv/bin/activate   # Linux/Mac
venv\Scripts\activate      # Windows

# 安装开发依赖
pip install -e .
pip install pytest flake8 black

运行测试

pytest tests/

许可证

本项目采用 MIT 许可证

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

privacy_tuner-1.1.0.tar.gz (41.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

privacy_tuner-1.1.0-py3-none-any.whl (63.4 kB view details)

Uploaded Python 3

File details

Details for the file privacy_tuner-1.1.0.tar.gz.

File metadata

  • Download URL: privacy_tuner-1.1.0.tar.gz
  • Upload date:
  • Size: 41.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.11

File hashes

Hashes for privacy_tuner-1.1.0.tar.gz
Algorithm Hash digest
SHA256 a362c571ca5e5c150821c94ff560c046086f0ee5a34b93be45eaa4d9f791e90d
MD5 7676000cadc2af495aa95479928d88a9
BLAKE2b-256 98bc496593ed9cf7d5145a6666ca00396ffea796e8cd108cd431468ec4ce1a4c

See more details on using hashes here.

File details

Details for the file privacy_tuner-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: privacy_tuner-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 63.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.11

File hashes

Hashes for privacy_tuner-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 266abcd888419ac9d50c3b715634133d7a6e5e5435f43f0f72e65da8a395e5c0
MD5 0f8660a7b4d8e92d6299fdf99e2472c8
BLAKE2b-256 9a2547fbeeed2afc42508f9468a450a27a55be221ab0b21b901353aad7721f41

See more details on using hashes here.

Supported by

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