阿里云「飞天发布时刻」2024来啦!新产品、新特性、新能力、新方案,等你来探~ 了解详情
写点什么

你的 AI 有训练样本吗?从 0 到 1 教你解决 AI 数据短缺问题

  • 2019-09-06
  • 本文字数:2307 字

    阅读完需:约 8 分钟

你的AI有训练样本吗?从0到1教你解决AI数据短缺问题

六年前,IBM Watson 进军智能医疗领域,欲通过 AI 解决人类医生都难以解决的医疗问题,一度成为 AI 界的“绝对明星”。但随后,Watson 被爆出无法在现实中胜任医生的工作,给出了一大堆不可靠的医疗建议。最终,Watson 被重磅合作伙伴弃用,其研发团队在经过数次裁员后,也所剩无几。


其实,IBM Watson 的设计思想不但没有错,可能还堪称 AI 医疗“方法论”的缔造者之一。但为什么 IBM Watson 就这样陨落了呢?罪魁祸首其实是数据。


AI 模型的训练需要大量的优质数据。在所有 IBM Watson 可以诊断的单病种中,数据样本量最大的是肺癌,可关于肺癌的数据样本竟然只有 635 例,其中一部分还是人工设计的案例,并非真实的案例。


想以这样的数据量训练出一个可以实际投入生产的 AI 模型无异于痴人说梦。并非 IBM 不想获取更多数据,实是无法获取更多数据。由于隐私保护相关法案的限制,加上一些行业数据离散分布的特性,一个 AI 模型想要获取充足的训练数据是非常困难的。


AI 的现实远比理想要骨感的多。


正是在这种情况下,联邦学习走入了大众眼中。联邦学习本质上是一种加密的分布式机器学习技术,可以在不披露底层数据和加密形态的前提下共建模型。


2016 年,谷歌提出“联邦学习”的概念,为解决此类数据问题提供了新的思路。2018 年,微众银行向 IEEE 标准协会提交关于建立联邦学习标准的提案获批,这也是国际上首个针对人工智能协同技术框架订立标准的项目。2019 年 1 月,微众 AI 团队将工业级联邦学习平台 FATE 开源,终于为数据的联合应用问题夯实了基础。

一、纵、横向联邦学习,保护隐私的同时联合建模

为了在保护数据隐私的情况下实现模型共建,微众银行将联邦学习的应用范畴进行业务扩展,形成了三类体系:纵向联邦学习、横向联邦学习和联邦迁移学习,大赛主要聚焦纵向和横向联邦学习。


纵向和横向联邦学习主要参照用户和用户特征两个维度进行划分。其中,用户维度是指用户 ID,此 ID 一般为一个数据集合,可能包括电话号码、身份证号码等一系列数据,用以区分不同的用户;用户特征维度是指用户财务数据、出行数据、爱好数据等与用户画像有关的特征数据。



接下来,我们分别了解纵向和横向联邦学习的概念,以及其是如何按照用户和用户特征维度进行划分的。

纵向联邦学习

纵向联邦学习是指,在两个数据集的用户重叠较多而用户特征重叠较少的情况下,我们把数据集按照纵向(即特征维度)切分,并取出双方用户相同而用户特征不完全相同的那部分数据进行训练。


比如说,拥有用户财务数据的银行和拥有用户画像的社交媒体公司,在法律层面上是不允许共享数据建立模型的。在这种情况下,纵向联邦学习就派上了用场,先进行样本对齐,继而进行算法拆解,最终在保证数据隐私的情况下建立联合模型,双方皆大欢喜。

横向联邦学习

横向联邦学习是指,在两个数据集的用户特征重叠较多,而用户重叠较少的情况下,我们把数据集按照横向(即用户维度)切分,并取出双方用户特征相同而用户不完全相同的那部分数据进行训练。


最典型的例子是银行间共建反洗钱模型。虽然用户特征重叠很多,但各自样本数量非常单薄。最终的诉求还是在保证各自数据隐私的情况下,共建联合的反洗钱模型,且模型效果超过单边数据建模。


两种联邦学习最终都在不共享数据的情况下,实现了模型的共建,解决了 AI 的数据问题,但业界仍然需要一个工业级的开源平台作为探索联邦学习的基础。


运气不错,微众银行 AI 团队完成了FATE平台 的建设并于 2019 年 1 月宣布开源,3 月诞生第一位外部代码贡献者。一个开源的、工业级联邦学习应用构建平台终于到来了。

二、认识 FATE,构建联邦学习应用

FATE 平台通过一站式联合建模帮助开发者快速构建联邦学习应用。



联邦统计主要是对数据进行预处理,比如进行样本对齐、求系数之间的相关性和 IV 值等等;联邦特征工程环节主要是进行数据的特征分箱和特征选择,特征分箱是指将数据进行离散化处理,特征选择主要是指选择部分适合建模的样本特征;在模型训练环节,FATE 已经提供了多种算法给用户进行模型训练,如 Secureboost 等;联邦在线推理则将训练完的模型部署到生产环境,做在线推理。


通过这样的 workflow 就可以非常方便的训练并部署一个联邦学习模型。


而从架构上看,FATE 的核心功能主要分为四层:


  • FATE Workflow:通过 DAG 图定义联邦学习算法工作流。

  • FATE FederatedML Functions:包含联邦学习算法各个功能组件。

  • EggRoll:分布式计算和存储抽象。

  • Federated Network:跨站点网络通信抽象。



其中最核心的部分是 FederatedML Function,分为五层结构:



在部署方式上,FATE 支持单机版部署和集群版部署,集群版部署相对复杂一些,需要大家参考文档进行。


单机 Docker 版安装部署命令如下:


git clone https://github.com/WeBankFinTech/FATE.gitFATE $ sh build_standalone_docker.shFATE $ CONTAINER_ID='docker run -t -d fate/standalone'FATE $ docker exec -t -i ${CONTAINER_ID} bash
复制代码


部署完成后通过三步即可验证是否成功:


  • 单机版单元测试验证:


sh ./federatedml/test/run_test.sh
复制代码


  • Toy-example 测试:用于测试 eggroll 的接口是否完整可用

  • 最小化测试:测试一个最小的建模任务是否能完成


在项目的 example 文件夹下,也实现了很多例子可以作为参考,比如hetero_feature_binning


这个例子可以方便的让你测试 Feature binning 算法,即一种特征构造方法,测试命令为:


sh run_feature_binning_standalone.sh 
复制代码


运行后的日志存放在:


your_install_path / logs / feature_binning_ {timestamp}
复制代码


也可以点击这里访问直播录像教学。


一旦你开始从代码入手,踏上了学习 FATE 及联邦学习的旅途,人工智能就不再是一个空有模型、没有数据的高新概念,而是一个你真正可以触达,可以解决的技术问题。


公众号推荐:

跳进 AI 的奇妙世界,一起探索未来工作的新风貌!想要深入了解 AI 如何成为产业创新的新引擎?好奇哪些城市正成为 AI 人才的新磁场?《中国生成式 AI 开发者洞察 2024》由 InfoQ 研究中心精心打造,为你深度解锁生成式 AI 领域的最新开发者动态。无论你是资深研发者,还是对生成式 AI 充满好奇的新手,这份报告都是你不可错过的知识宝典。欢迎大家扫码关注「AI前线」公众号,回复「开发者洞察」领取。

2019-09-06 18:216869
用户头像
王一鹏 前 InfoQ 总编辑

发布了 151 篇内容, 共 88.4 次阅读, 收获喜欢 458 次。

关注

评论

发布
暂无评论
发现更多内容

【指针内功修炼】深度剖析指针笔试题(三)

Albert Edison

C语言 9月月更 指针数组 数组指针

DPDK源码分析之网络基础知识

于顾而言

网络协议 DPDK

【云原生 | 从零开始学Docker】七丶实战提交自己的镜像以及docker网络

泡泡

Docker 云计算 容器 云原生 9月月更

DPDK源码分析之rte_eal_init(二)

于顾而言

DPDK

新书上市 | Vue 3.0 核心源码解析,这本书给 Vue 学习提供新方法

图灵社区

前端 代码 VUE 3.0 源码

新书上市 | Vue 3.0 核心源码解析,这本书给Vue学习提供新方法

图灵教育

前端 代码 VUE 3.0 源码

NFTScan 正式发布 PlatON 网络 NFT 浏览器

NFT Research

NFT platon

流计算中的Windows计算

孤衫

大数据 流计算 9月月更

双活数据建设方案

阿泽🧸

双活 9月月更

【云原生 | 从零开始学Docker】六、如何写出自己的镜像——Docker file

泡泡

Docker 云计算 容器 云原生 9月月更

DAYU200升级最新的OpenHarmony系统,一起来玩开源鸿蒙呀!

坚果

鸿蒙 OpenHarmony 9月月更

TO B的本质是“定制化”不变,“定制化”实现方式求变

B Impact

TO B

DPDK源码分析之rte_eal_init(一)

于顾而言

DPDK

【Meetup预告】OpenMLDB+37手游:一键查收实时特征计算场景案例及进阶使用攻略

第四范式开发者社区

机器学习 数据库 实时计算 特征平台 特征工程

jquery入门到实战

楠羽

笔记 JQuery框架 9月月更

计算机网络——奈式准则

StackOverflow

编程 计算机网络 9月月更

DPDK源码分析之DPDK技术简介

于顾而言

DPDK DPDK开发

每日算法刷题Day12-跳台阶、排列、替换空格、求n累加

timerring

算法题 9月月更

网络入侵检测系统之Snort(一)--snort概览

于顾而言

网络安全 ips

网络入侵检测系统之Suricata(一)--概览

于顾而言

网络安全 suricata

DPDK源码分析之DPDK基础概览

于顾而言

DPDK DPDK开发

《新神榜:杨戬》亮点抢先看!追光新神话宇宙再添超燃国风巨作

Renderbus瑞云渲染农场

云渲染 云渲染农场 渲染农场 3D电影制作 CG动画电影

图解Kafka Producer中的消息缓存模型

石臻臻的杂货铺

Kakfa 9月月更

网络入侵检测系统之Snort(三)--优劣势与性能指标

于顾而言

网络安全

二叉树的概念及三种遍历方法(C语言)

孤衫

后端 C语言 9月月更

DPDK源码分析之l2fwd

于顾而言

DPDK

图库

武师叔

企业容器云建设及推广的一点Tips

穿过生命散发芬芳

容器云 9月月更

网络入侵检测系统之Snort(二)--数据流图与环境搭建

于顾而言

网络安全 ips

架构师的十八般武艺:一致性

agnostic

CAP 一致性

资本“呼唤”:走产品化路线,找得到PMF的云安全创业项目

B Impact

To B业务

你的AI有训练样本吗?从0到1教你解决AI数据短缺问题_AI&大模型_王一鹏_InfoQ精选文章