爱奇艺 Opal 机器学习平台:特征中心建设实践

 01 

综述

Opal 是爱奇艺大数据团队研发的一站式机器学习平台,旨在提升特征迭代、模型训练效率,帮助业务提高收益。整个平台覆盖了机器学习生命周期中特征生产、样本构建、模型探索、模型训练、模型部署等在内的多个关键环节。其中特征作为模型训练的基石,其重要性不言而喻,如何让用户借助平台的能力,提升其业务侧特征迭代效率,从而达到预期的目标,是作为平台方需要思考的关键问题之一。在 Opal 中,特征生产、存储、访问等共同组成了特征中心的核心功能。本文将重点介绍特征中心相关工作。关于 Opal 的更多介绍,详见:Opal 机器学习平台:爱奇艺数智一体化实践

 02

特征中心是什么

简单来说,特征中心是用来生产、共享、管理机器学习模型特征的工具平台。算法工程师或数据分析人员可以在平台上方便的创建及分享特征,而平台侧协助解决特征生产和使用过程中碰到的各类问题,提高特征的迭代效率。

特征中心基本适用于所有需要特征的场景,典型的如推荐、广告、风控等场景。特征表注册在特征中心中,特征中心可以自动完成在线和离线表的构建,保证在线和离线的一致性,同时保证特征表只存一份的情况下,能够向多人共享特征,减少资源成本。另外特征中心还可以节省时间成本,原来需要复杂的 SQL 操作,比如导出训练表、数据导表等操作,现在在特征中心中都可以通过 Web UI 进行简单的拖拽式配置完成。

 03

特征中心解决的问题

算法模型本质上是一个映射函数,输入数值型的向量,输出是基于某个目标对候选集的排序。在爱奇艺场景中,离线训练时,算法工程师需要先从原始日志抽取出特征,并基于此构建训练样本;在线服务时,要根据端侧用户的用户 ID 和 视频 ID 查询出对应的原始特征,并根据 DSL 配置将原始特征转换为训练特征,最后调用预测服务得到预测值。

一般来说,想提高模型效果只能从以下两方面着手:

  1. 模型侧优化:  这是一种以优化模型结构、调优模型超参数为主的系统调优策略,通过调整参数不断优化模型的效果指标,我们将对应的优化称为模型侧优化;

  2. 数据侧优化:与模型侧优化相对应,这是一种以调整数据集质量为主的系统调优策略,通过改进数据质量来提升模型效果,在做数据侧优化时,可以认为模型是固定的。但实际业务中,人们往往很容易认为模型效果不好,是因为模型不好,但却忽略了数据集本身对模型效果的巨大影响。

业内有共识:"数据(特征)决定模型上限,模型结构及调参只是逼近这个上限",数据侧优化对整体效果提升的重要性不言而喻。那么如何让工程师高效地基于数据侧进行优化?答案是特征中心。平台需要能够解决数据侧优化过程中遇到的各类挑战:

  1. 如何应对海量的用户请求?爱奇艺拥有海量观影用户,对特征的访问又是极高频的操作,如何应对高 QPS 的请求是特征中心面临的挑战之一;

  2. 如何满足对特征的实时化要求?在广告、推荐、风控场景下,为保证算法模型的输出效果,对特征的实时性要求水涨船高;

  3. 如何提高特征的扩展性和灵活性?业务场景日益复杂,特征需求灵活多变。从基础特征到统计序列特征组的生产,从离线特征的简单统计到实时特征的窗口计算、交叉特征等,业务方需要特征中台能够支持逐渐衍生而来的新特征类型和需求;

  4. 如何满足快速迭代的业务诉求?特征中台提供的面向业务的 DSL 需要足够场景,特征生产链路尽量让业务少写代码,底层的计算引擎、存储引擎对业务完全透明,彻底释放业务计算、存储选型、调优的负担,彻底实现实时基础特征的规模化生产,不断提升特征生产力。

具体来说,特征中心的功能需要至少覆盖如下几个方面:

  1. 特征输入:如何管理业务线的数据源,包括各类文本文件、Parquet 文件、Hive 表等;

  2. 特征计算:如何表达特征计算逻辑,从原始日志中高效的抽取出需要的特征;

  3. 特征存储:计算出来的特征存放在什么类型的系统中,这里涉及到存储成本和访问效率的权衡;

  4. 特征转换:从原始特征到模型特征的转换,包含各类 DSL 的解析及转换。

 04

特征中心整体架构图

2b91cfb7363f7b025f8983dc355b152d.png

根据特征在整个链路中的角色不同,可以将特征分为特征生产和特征使用两大类:

  1. 特征生产:解决了如何从各种类型的大数据源中进行特征计算、得到的结果如何存储的问题,平台设计了一套高效的特征计算算子,配合拖拽式的 Web 页面,托管运维用户的特征生产任务,协助用户高效地管理其特征;

  2. 特征使用:解决了如何实现特征的线上访问,特征中心通过引入特征视图的概念,实现从特征复用,自定义转换等功能,并提供 Opal Feat View SDK 实现特征的动态序列化,多机房自动感知,就近访问等功能,为业务方屏蔽底层的存储细节,让其专注于业务逻辑上。

 05

特征中心功能介绍

由上一小节可知,特征中心从功能上可分为特征的生产和特征的使用。进一步,根据目标特征的生产时延,可以将特征生产划分为离线特征组和实时特征组。下面将分别介绍其功能。


离线特征组


通常来讲,当需要训练一个机器学习模型时,我们通常会预处理一组数据,将原始数据转化为一个特征向量或者特征集,这个特征向量可以被模型更好的理解和使用。比如,统计一个用户过去一周的购买行为,将这个统计结果作为一个特征。在一些情况下,为了提高处理速度和效率,我们会提前计算这些特征,并将它们存储起来,以备后续使用。我们将这种提前计算并储存的特征集称为离线特征组。

00a032a466b2a5e858bae9fd82d93108.png

如下图所示,Opal 离线特征组基于用户通过拖拽构建的 DAG 图,从 Source 节点读取数据,数据可以是 Hive  表、Iceberg 表或 TFRecord 和 Parquet 文件,经过中间的由 Opal 抽象出来的计算节点进行数据转换,最终将产出的特征写入在 Target 节点所描述的存储系统中。如图所示,Opal 目前支持各类常见的特征存储格式。

特征元数据管理、特征生产 DAG 配置

3871a08fa5b7466992d5516635f339f7.jpeg

通过在平台上拖动左侧的算子进行组合后得到一个 DAG 的生产任务配置,围绕 DAG,平台支持对特征元数据及特征 Schema 等进行管理。


SQL 语法解析及 Schema 推断

925a4a8c2cbdb1766c036264f4fe1162.jpeg

平台提供语法解析及校验功能,用户在配置期间即可实时观察到每个算子输出的字段详情,无需到提交任务阶段才发现错误,可降低用户调试时间。


特征质量校验及预警

be08a82627b0f795646c668551d3bfcc.jpeg

平台支持对已产出的特征进行各种检查,例如:特征的零值率、空值率、分位数、最大最小值等,并提供可视化的页面,方便用户查看特征质量。


任务重跑及异常告警

2532626f5983d62cf3d96924bd1d428b.jpeg

目前已有推荐中台、广告算法、业务风控等多个团队接入离线特征生产模块,基于平台产出三百余个特征组,基于 Opal 平台托管式的特征生产模式一方面大幅度的简化了业务方对特征生产上的投入时间,因此可以把更多时间投入到其它链路中,提高迭代效率。

实时特征组


实时特征组不同于离线特征组。离线特征组通常包括可以预先计算和存储的特征,而实时特征组包含的是实时或近实时生成的特征。实时特征的获取和计算通常需要强大的数据基础设施和实时数据处理能力。

b8cc0242501a02680541859541644776.png

实时特征组在许多实时决策和预测系统中是很重要的,例如推荐系统,欺诈检测,金融交易等等。管理好实时特征组,确保实时特征值的准确和及时获取,对于这些系统的性能和实用性起着重要的作用。

与离线特征组类似,Opal 提供了基于 DAG 的实时特征加工流图,实现从 Kafka / Iceberg / MySQL 摄入数据,利用平台集成的算子进行计算,后输出到 Kafka 及其它数据存储介质中。

其它在离线特征组模块提供的功能在实时模块也正逐步增加中。


实时特征生产 DAG 配置

e539407c2070f9a8e19fefc92aad28c5.jpeg

平台提供特征元数据及 Schema 管理,通过各类算子的组合即可完成一个实时特征的配置。


滑动窗口算子示例

823cc1092f71157afc4094f4c372f3c6.png

通过简单的配置,即可实现窗口转换,用户无需编写复杂的 SQL 语句,大大降低了业务团队的开发成本。


窗口特征合并及状态复用

1fd3b2abb5ebbed7741e0e63de1cf080.png

对于不同窗口周期但滑动步长一样的特征计算任务,Opal 支持对其进行合并,将计算整合在同一个窗口中进行,这样可大幅度节省状态空间,减少任务资源占用。

特征视图


统一离在线特征组端侧访问

离线特征组、实时特征组解决了特征的配置、加工、存储等问题,而特征视图解决了特征的读取问题。如下所示,离线特征组、实时特征组产出特征后,存储在各种不同的离线存储介质中,无法被业务方线上引擎服务直接使用,需要一个灌库服务将特征组从离线存储导入到在线缓存(Couchbase、Redis、HBase等)中,Opal 通过特征视图实现特征的灌库,并提供统一客户端实现特征的读取,用户无需关注特征灌库的细节。

1ab933b240532b11ad4b88cf373645ac.png


特征转换及特征衍生

在某些情况下,用户需要对已有特征进行转换,例如对原始特征取对数或四则运算后再返给下游。为了支持上述功能,Opal 提供了一套灵活高效的 DSL 特征转换表达式。其基本格式如下:

语法解释:

  • 函数名为平台预定义的关键字

  • 参数可以是 特征变量 或各种类型的 字面值常量

    • 数值集合常量,如:[1, 2, 4]

    • 字符串集合常量,如:['aaa', 'bbb']

    • 特征变量,视图内任意合法的特征名称,由反引号标识,例如:`city`

    • 数字常量,任意合法的数字,例如:123

    • 字符串常量,由单引号标识,例如:'hello world'

    • 集合常量,由中括号标识

转换示例:


Java 客户端接入,简化特征获取流程

eba142750e59696373e5c09d2a2b6037.png

平台提供了 Java SDK 以实现对线上特征的访问,如图所示,SDK 屏蔽了底层存储资源,用户无需对接各类复杂的缓存,通过引入 SDK 即可实现对特征的访问。

运维监控大盘

接入客户端后,SDK 会自动向指标服务侧投递指标,用户可以基于 Grafana 大盘监控观察服务是否运行正常。

c4aa0c63b775fb7fe02f5da0558dac90.png

 06

业务接入

目前分别有广告、推荐、风控业务不同程度的接入了Opal 平台的特征中心,并进行了一系列相应升级改造,接入后各业务的特征迭代效率提升 0.4 倍到 3 倍不等,业务引擎侧获取特征时延降低约 50%,特征侧需求堆积实现零积压。具体业务接入前后架构变迁细节以及给业务带来的收益,可参考文章 Opal 机器学习平台:爱奇艺数智一体化实践 中业务实践小结。我们也将在后续的系列文章中推出,由业务同学撰写的基于 Opal 的特征评估架构改造的经验分享。

07

未来规划


未来,Opal 平台上的特征中心将从以下几方面增强功能,助力业务取得更好的效果:

  1. 特征共享:随着平台中管理的特征越来越多,不可避免的会出现特征重复计算问题,平台有必要实现特征的分享,避免用户重复生产;

  2. 实时特征的质量校验:对于离线特征,平台已有相对完善的特征校验模块,可以保证产出特征的质量,对实时特征也需要有一个相应的质量监测服务;

  3. 特征热度计算:根据特征被线上访问的情况,推算出每个特征的热度,该热度可以后续协助业务方进行特征的重要性评估。

3f84932aceea3c7e504f6ca3f23a22c7.jpeg

也许你还想看

数据湖在爱奇艺数据中台的应用

爱奇艺数据湖实战 - Hive数仓平滑入湖

爱奇艺数据湖实战 - 基于数据湖的日志平台架构演进

爱奇艺数据湖实战

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/863373.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于星火大模型的群聊对话分角色要素提取挑战赛-Lora微调与prompt构造

赛题连接 https://challenge.xfyun.cn/topic/info?typerole-element-extraction&optionphb 数据集预处理 由于赛题官方限定使用了星火大模型,所以只能调用星火大模型的API或者使用零代码微调 首先训练数据很少是有129条,其中只有chat_text和info…

【Mac】Listen 1 for Mac(最强的音乐搜索工具)软件介绍

软件介绍 Listen 1 for Mac 是一款非常方便的音乐播放软件,主要功能是集成多个音乐平台,让用户可以方便地搜索、播放和管理音乐。它是一个用 Python 语言开发的免费开源综合音乐搜索工具项目,最大的亮点在于可以搜索和播放来自网易云音乐&am…

实用的vueuseHooks,提高编码效率

文章目录 写在前面vueuse 官网安装HooksuseStorage [地址](https://vueuse.org/core/useStorage/)传统方法数据持久化 举例子传统持久化的弊端useStorage 数据持久化 举例子使用useStorage 更改存储数据使用useStorage 删除存储数据 useScriptTag [地址](https://vueuse.org/co…

matlab中simulink仿真软件的基础操作

(本内容源自《详解MATLAB/SIMULINK 通信系统建模与仿真》 刘学勇编著的第二章内容,有兴趣的可以阅读该书) 例:简单系统输入为两个不同频率的正弦、余弦信号,输出为两信号之和,建立模型。 在…

论文阅读_OpenAI嵌入+Lucene

英文名称: Vector Search with OpenAI Embeddings: Lucene Is All You Need 中文名称: 使用OpenAI嵌入进行向量搜索:只需Lucene 链接: http://arxiv.org/abs/2308.14963v1 作者: Jimmy Lin, Ronak Pradeep, Tommaso Teofili, Jasper Xian 机构: 滑铁卢大学戴维切里顿…

锁机制 -- 概述篇

锁机制 1、概述 ​  加锁是为了解决并发场景下,多个线程对同一资源同时进行操作,而导致同一线程多次操作出现结果不唯一的情况(一次操作包含多条指令)。结果不唯一发生的原因在于指令的错乱,前提条件是多线程环境及…

双指针算法第一弹(移动零 复写零 快乐数)

目录 前言 1. 移动零 (1)题目及示例 (2)一般思路 (3)双指针解法 2. 复写零 (1)题目及示例 (2)一般解法 (3)双指针解法 3. 快…

Hadoop 安装与伪分布的搭建

目录 1 SSH免密登录 1.1 修改主机名称 1.2 修改hosts文件 1.3 创建hadoop用户 1.4 生成密钥对免密登录 2 搭建hadoop环境与jdk环境 2.1 将下载好的压缩包进行解压 2.2 编写hadoop环境变量脚本文件 2.3 修改hadoop配置文件,指定jdk路径 2.4 查看环境是否搭建完成 3 …

基于Spring Boot的药房信息管理系统

1 项目介绍 1.1 研究的背景及意义 随着社会的飞速进步和药房行业竞争的白热化,传统的手工管理模式已难以适应药房信息管理的现代化需求。在计算机科学技术日臻完善的背景下,药房信息管理者们日益认识到运用计算机技术进行信息管理的迫切性和重要性。计…

快手正式推出Vision Pro版本,引领虚拟现实社交新潮流

6月28日,快手正式推出其专为Apple Vision Pro打造的版本——快手vp版app,成为国内首批登陆Apple Vision Pro的短视频平台。 借助先进的虚拟现实技术,用户可以在快手上体验更真实生动的视频内容,无论是观看趣味短视频内容&#xf…

产品是应该有生命力的

产品是应该有生命力的 在日新月异的商业环境中,产品被寄予厚望,不仅仅满足基本功能需求,而是要能够自我革新,适应市场和技术的快速变化,以及持续吸引并留住用户。 这种生命力体现在产品的迭代升级能力、对用户需求的精…

[鹏城杯 2022]babybit

发现一个压缩包提取出来提取出来两个压缩包里面是注册表使用MiTeC Windows Registry Recovery 恢复注册表 flag在ROOT\ControlSet001\Control\FVEStats里的OsvEncryptInit和OsvEncryptComplete中 NSSCTF{2022/6/13_15:17:39_2022/6/13_15:23:46}

互联网信任危机:Perplexity搜索引擎如何破坏内容创作者的权益

前段时间,Perplexity搜索引擎还是一颗冉冉升起的明日之星,手握巨额投资,有很美好的未来前景,这时,如果不出意外的话,要出意外。 喜好儿网 Perplexity这家公司,它正试图通过创建一个新型的“答…

LoRaWAN网关源码分析(基础概念篇)

目录 一、简介 1、lora_gateway 2、packet_forwarder 二、目录结构 1、lora_gateway 2、packet_forwarder 一、简介 LoRaWAN网关的实现主要依赖两个源代码:lora_gateway和packet_forwarder。接下来,我们将从分析源代码入手,移植LoRaWAN源…

Android Focused Window的更新

启动App时更新inputInfo/请求焦点窗口流程: App主线程调ViewRootImpl.java的relayoutWindow();然后调用到Wms的relayoutWindow(),窗口布局流程。焦点窗口的更新,通过WMS#updateFocusedWindowLocked()方法开始,下面从这…

MIX OTP——监督树和应用

在上一章关于 GenServer 的内容中,我们实现了 KV.Registry 来管理存储容器。在某个时候,我们开始监控存储容器,这样每当 KV.Bucket 崩溃时,我们就能采取行动。虽然变化相对较小,但它提出了一个 Elixir 开发人员经常问的…

独家原创 | Matlab实现CNN-Transformer多变量时间序列预测

SCI一区级 | Matlab实现BO-Transformer-GRU多变量时间序列预测 目录 SCI一区级 | Matlab实现BO-Transformer-GRU多变量时间序列预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实现CNN-Transformer多变量时间序列预测; 2.运行环境为Matlab2023b…

【JavaScript】JavaScript简介

希望文章能给到你启发和灵感~ 如果觉得文章对你有帮助的话,点赞 关注 收藏 支持一下博主吧~ 阅读指南 JavaScript入门(1)————JavaScript简介开篇说明一、什么是JavaScript二、JavaScript的使用2.1 开发工具的选择…

fiddler抓包工具

概念 概念: Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯。 http:不加密,端口为80 https:加密,端口为443 原理: 其实就在访问服务器时&#xff0…

如何在写代码中找到乐趣

平时我们写代码呢,多数情况都是流水线式写代码,基本就可以实现业务逻辑了。 如何在写代码中找到乐趣呢,我觉得,最好的方式就是:使用设计模式优化自己的业务代码。 参考资料: 实战!工作中常用到…