前端智能化在淘宝的2022实践总结

news2024/11/16 6:48:41

6699abb8bd699defa1bcc29e2bc1bed4.gif

过去十年是智能化蓬勃发展的十年,但未来十年会是智能化渗入各领域彻底改变我们生活和工作的十年。阿里前端智能化方向小组历经 4 年的实践和演变,在前端融入业务技术团队和终端融合的背景之下,前端智能化小组在2022年更多以优化拓展基础业务工具、落地服务业务为主。

74df68e89e1bb1ae689eb52565e974e1.png

本篇重点介绍业务工具的核心进展,以及在大促期间的应用落地。

11dd05af6f05ec47b62f7e1539173afd.png

D2C 核心进展

D2C(Design to Code) 对外的服务在 imgcook.com 上,2022 D2C的核心只聚焦在还原代码质量提升上。近期用户使用情况如下:

00b12a8ba5bb47a58f090ecb24aed91b.png

在产品能力不增加的情况下,D2C的自来水用户目前依旧保持活跃。核心策略是:

  1. 业务赋能:提供设计稿生成代码各种原子能力,无缝融入阿里研发流程形成各个业务自己的研发解决方案,帮助提高业务交付效率。

  2. 提升生成代码质量:聚焦视图代码生成可用性,对标内部专业前端对代码的可维护性要求,生成高可用代码。

阿里内部用户使用原子化开放能力,还原服务API 调用 227w 次左右。核心只基于问题驱动减少设计稿干预提升代码生成质量,其中问题大部分出现在布局算法层,同时由于D2C体系的复杂度,D2C本身的工程质量提升也是保持持续迭代的根基。接下来重点介绍下 D2C 布局算法和 D2C工程质量的核心进展:

  布局算法背景

对于 D2C 系统整体, 数据的来源是 Sketch 等原型图设计工具的设计稿, 根据设计稿上每一个元素在空间上的分布, 例如x坐标, y坐标, 图层(z坐标), 宽度与高度, 可以精确描述整张设计稿的内容, 例如图2.1的二维设计稿, 实际上能够转化为图1.2的三维分布描述:

09f4ac51bace1af526c6ac146f3cac00.jpeg

图2.1 设计稿在原型图设计工具上的展示

2c6cc47b087e1a4ce2fe7e0f5da23241.png

图2.2 展示的内容等效的三维分布

对于三维分布的结果, 向z的负方向进行投影, 则可以得到一颗初步成型的DOM树:

a52d560780e076d1d59c57610a699081.png

图2.3 向z的负方向投影后生成的树

这样的操作生成的DOM节点和设计稿中元素一一对应, 但是设计稿中主要进行的是视觉描述, 存在大量被省略的中间节点, 以及少量视觉表达正常而元素使用不合理的节点, 需要经过布局算法的预处理与成组划分, 转换或生成这些新的节点。

除此以外, 布局算法需要对各元素进行识别与定位, 尤其是绝对定位元素的识别, 在判断本应在文档流内的元素的分布时混入本应在文档流外的元素, 会产生严重的错误。

  布局算法优化进展

  • 预处理

文本合并策略


背景

设计稿中, 存在部分“通过多个单行文本节点表达多行文本”的操作(如图2.1), 同时存在“通过间断的单行文本片段表达连续的文本”的操作(如图2.2):

61abe42f46e05b234a76d4e0bf6bd7b3.jpeg

图2.1 多行文本被通过多个文本元素表达而实际需要合并

6faf4854a03eb9c8680b5bce48fc4a37.jpeg

图2.2 单行文本被通过多个文本元素表达而实际需要合并

基于以上问题, 需要一种文本合并的解决方案


问题定义

给定在三维空间下的单行文本元素集合, 通过一定的“搜索规则”, 找到需要合并的“单行文本节点簇”, 通过 “合并操作” 生成新的文本元素集合。
同时, “合并操作” 需要保证结果与原先的“单行文本节点簇”在二维空间投影下的显示尽可能相似。

解决方案
  1. 首先可以排除在二维投影中互相覆盖的元素, 因为除开“生成图片”这样的“合并操作”, 通过简单的“合并操作”不可能得到一个相似的结果, 重叠的文本无法在一个“DOM节点”中表达。

  2. 其二, 排除 font-size , color , font-weight 等文本样式属性不相同的合并目标, 因为生成的结果只能有同一的文本样式属性。

  3. 其三, “合并操作” 考虑通过 text-indent, line-height 及 "添加空格与空行" 对合并后的文本进行调整。

  4. 其四, 文本合并后, 如果有明显的对齐特征, 则考虑使用 text-align 进行对齐而非上述方案, 以增强文本的扩展性。

  5. 最后, “搜索规则” 根据经验, 定义为 “小于或等于 2 的曼哈顿距离”。

详细讨论 “合并操作”,显然,对于混合的 text-align , 处理会比较复杂, 基于此, “合并操作” 每次只处理 “两个来自设计稿的文本节点” 排除 “已处理的结果” , 这样的处理也可以避免 “无法表达的单行文本节点簇”。

4f33055e2a3f886ef4cefcc26f98308d.jpeg

图2.3 无法合并后由一个文本节点表达的单行文本节点簇 其不满足简单的行列分布

详细讨论 “两个不相交的单行文本节点的情况”,定义其中一个长节点为 “节点A” , 并据此进行分区, 有如下结果

6e09243b439b76dda6101eba91305cac.jpeg

图2.4 将一个节点的周围进行分区的结果

定义另一个短节点为 “节点B”,基于上文中提到的 font-size 相同的前提, 不妨假设 "节点A" 有 2 个字符长, “节点B” 有 1 个字符长,滑动 “节点B” 并记录左上角顶点和右下角顶点的边界情况。

d26f89dfb6a1062a21c57a938e90c113.jpeg

图2.5 从左向右滑动过程中的一类情况

枚举后, 可以得到共52种可能

e5d455b73ffe239e3066172c3be81f88.jpeg

图2.6 52种可能的分布中的部分情况

那么, 通过 “空格” 与 text-indent 可以调整x轴的起点与终点, 通过 “空行” 与 line-height 可以调整y轴的起点与终点, 两个维度的结合, 可以表达全部的52种可能,对于 text-align , 可以取52种可能中明显的对齐分布, 覆写上述策略。

角标的识别

背景

绝对定位的元素有两个来源, “几何” 与 “语义” , 其中 “几何” 的绝对定位 (或称被动的绝对定位) 在本层元素无法通过算法的布局策略定位(如元素相交) 时触发, 而 “语义” 的绝对定位 (或称主动的绝对定位) 来源于开发惯例(如 Tooltip )对于角标 (徽标 Badge) , 显然遵循 “语义的绝对定位”, 尤其是下图(图2.7)中的场景, 角标并没有和任何元素相交, “几何的绝对定位” 失效, 须提前识别到本角标元素。

fa468db07eb6d9dab2dec14d6df8db15.jpeg

图2.7 变异的角标没有与任何元素边缘相交


解决方案

显然, 如果需要解决此类问题, 最好应当采用目标检测方法, 但是基于时间与计算资源有限, 只能人工抽样并提取特征,那么, 需要多份不同来源的含角标实体图例。

总结后, 不难发现, 子元素的 border-radius 与对齐能够作为关键特征,那么, 便可以有如下定义:

定义: 对于两节点, 通过成树后为父子关系, 且子元素非文本节点并含有 border-radius, 子元素与父元素顶部对齐, 则称子元素为角标,后续将 角标 绝对定位即可。

第一步:用行投影预处理

首先我们通过 模糊投影操作(在行投影的基础上模糊边界) 找到符合以下特征的 连续行

  1. 每行元素通过 列投影 能相似等分

  2. 每行元素通过 列间隙投影 能相似等分

  3. 第二行开始每行与上一行 居中对齐 或者 左对齐

  4. 每行每区域可能不止一个节点

找到满足以上条件的连续行,为接下来的「行合并」作准备

1ba7b22e1488656bf18a13bfe6c672d7.png

图2.9 通过行投影判断行间元素是否规范

根据行投影,再行内进行一次列投影,就可以将临散的节点聚合在一起成组了。这个小步骤的目的是为了能忽略某个小网格的细节,将碎图也能成为一个整体。(图 2.10)

979ce7c230f2eb3b80770f50aee0911e.png4665c662706c63afea4dcc8f0ac28d97.png

图2.10  “更多”上方图形被视作整体

第二步 行合并

预处理完成之后,我们可以标记每个网格的元素类型。并且通过类型来判断每列节点的循环关系。

6a58bfbcceb9a921d7a06590aa50c32a.png

在此,我们综合了两种方案

方式一:直接统计每行元素类型,是否能满足固定重复的结构

例:[图文图文图文] => [[图文],[图文],[图文]]

例:[图文文图文文] => [[图文文],[图文文]] 

方式二: 当上述无法判断时,通过在循环成组中使用过的 HAC聚类的方式,同样也可以找出满足循环条件的结构。

第三步 样式生成

至此,整体成组结构已经完成。将循环的部分标记为 GridItem,整体标记Grid。在样式生成时可以针对此结构,计算出网格宽高间隙,用 display: grid 来实现。

骨架成组

背景

在布局算法中,「循环成组」中主要通过对「节点类型聚类」和「节点位置向量的聚类来识别循环」

「骨架结构相似判断」将更直接的通过重合相似度来判断成组,核心是找到更多相似的行结构成组。相比较于兜底行成组,骨架可以找到更多的行间关系。

0490ccf224334fde9fc766e172459985.png

解决方案

将区域划分成 N 多个 网格状区域,N 越大,精度越高,计算越准确。分别比较每个相同位置的内容,根据不同权重来计算是否相似。注意以下几个关键特征:

  1. 相交区域 重合面积(内容一致的格子数)

  2. 相交区域 空心面积(没有节点的格子数)

  3. 相交区域 实心面积(有节点格子数)

  4. 相交区域 实心比

  5. 相似区域 占 相交区域 比例

  6. 相似区域 占 整体有变化区域 比例

  7. 形状结构复杂度

a9f86e5245dde1d8b3f19e0d7c729c4c.png

当然也需要运用一些 人视觉判断时的心理活动 作为判断依据:

  1. 结构越复杂,越奇形怪状,相似度的阈值可以更低。

  2. 复杂度太低的节点,严格增加限制控制相似。比如节点数量等。

  3. 重合面积占据空间越满,则越不可信。

当然,布局算法在原有的基础上,也引入了一些别的成组方式来解决有明显业务含义的问题,比如直接为 图标按钮这类结构成组,顶部导航栏成组,有明显视觉分割特征的分割线成组,具有严格对齐特征的行列成组。

  • 样式

定宽高问题的优化

背景

大促产品化项目中,希望生成的代码后只要绑定数据源能达到直接可用的目的。其中就要求针对动态内容是否定宽要符合预期。如图,利益点“满200减30” 希望是动态宽度,而“定金100”希望是固定宽度。

ca859b54692e61c41214c9dd10a8836c.png


解决方案

经过总结,我们认为这类卡片中,也存在一些明显可总结的规则

  1. 多行文本定宽(如标题)

  2. 单行文本,价格默认不定宽

  3. 图片定宽

  4. 标签类文本不定宽(如上图满减)

  5. 按钮胶囊类按钮根据文本与容器的间隙来判断容器是否定宽。(如上图定金100)

  6. 循环容器定宽,防止被内部元素撑开

  7. 通过是否充实,防止塌陷

0e1806dd7543d50dc9048755ac54208f.png

  • 特征工程

背景

当前布局算法为预测分布状况, 采用人工构造的特征, 然而这些特征并未进行过优化, 部分特征可以合并降维, 而部分也可以拆解升维, 同时了解特征对分类的贡献, 也有利于后续新的特征的构造,基于以上等原因, 可以采用决策树对样本进行解释与分析。

解决方案

对此, 将数据通过决策树进行训练, 并绘制决策树模型

4c1182c80f1ce5e1dc688032e4cdbd2c.png

图2.11 决策树模型

基于本决策树使用“信息增益”生成, 可以合理推断出 feat_2 , feat_5 , feat_9 与 feat_10 有较高的贡献, 后续会对这四个特征进行进一步分析。

  工程质量进展

  • 单元测试

背景

布局算法的执行流程, 抽象来看属于Pipeline的执行流程, 下图中为布局算法的执行流程:

a4800d83d9e9447e89cb933c2849811c.png

图2. 布局算法的执行流程

对于每一个最小的执行单元, 布局算法中称其为 Transformation (转换) , 其输入一个节点 node ,处理后生成一个新的节点 transformedNode将树上的每一个节点进行转化, 即一轮 “转换” , 称为 Epoch (周期) , 其输入一颗由节点构成的树, 生成一个处理后的树,上图中的每一个功能, 都可以抽象的看作一个 Epoch , 在每个 Epoch 之间, 能够获得中间结果并进行可视化。

解决方案

基于部分 Transformation 并不是标准的纯函数, 其不止作用于输入的 node 节点, 还有可能作用其子节点, 故将 Epoch 作为一个单元, 并且 Epoch 本身只依赖初始的参数设置与输入的树对象,那么, 可以简单的在各 Epoch 之间截取每一个结果, 并将其作为输入的树与输出的结果快照。

db0716b7323beb0a6436f247e470292e.jpeg

图2.13 每个 Epoch 的输入和输出进行持久化以进行单元测试

利用 jest 库, 可以很方便的将输出转化为快照以进行持久化。

  双促落地-面向运营的无代码模式

  • 欢聚日模块示例

287e779e93b202b402f19c042d3bc3b5.png

聚划算欢聚日模块使用直接生成的方式完成了整个模块的开发。其中原本需要“人工干预”才能完成的部分,通过逻辑库来实现;部分样式通过大促产品化中元件的 UI可变性来实现。

  • 核心思路

  1. 规范视觉稿,将需求中需要作为背景图合并的内容,在图层上打#merge#标记

  2. 准备大促产品化中相关元件(1x3 布局,左下角的静态按钮元件,价格元件)

  3. 实现元件的识别逻辑,用于分析设计稿中的元件组成和关键样式

  4. 使用 imgcook 解析设计稿并还原之后得到 schema

  5. 使用逻辑库识别的方式分析结构,识别出 1x3 的一个布局

  6. 提取关键样式,比如左下角按钮槽位里左边的边距。

    fbc905ff816c0368b2633266d9373997.png

  7. 根据元件注册时内置的mock数据和schema信息,可直接拼接处该模块完整需要的schema和mock.json 无需额外写代码。

  D2C总结

在业务闭域场景-营销导购,面向运营的无代码模式正在大淘宝技术的营销场景的大促产品化模块工厂落地,其使用角色是运营,其中对D2C的还原能力要求接近100%,D2C的核心依旧是聚焦基于C端营销业务现实问题驱动提升视图代码生成质量。

defed778788a323b3229ab2421b8bfdb.png

智能UI 核心进展

智能UI一直致力于做UI的有效性表达,之前的技术重点主要投入在供给和投放两个方向上:在供给侧如何提升物料的生产效率,在投放侧如何改进UI样式的推荐算法。随着智能UI和业务的深入结合,我们发现原先基于“物料&分区”的智能UI协议无法支持更细粒度的UI调控诉求,同时,在UI展现上也没有针对不同类目的商品进行差异化的信息表达,一个页面几百种商品全部采用了统一的样式进行渲染。基于这些问题我们对鲸幂平台的产品能力进行了改造升级,以更好的支撑不同的业务需求。

  能力完善

  • 更细粒度的UI调控能力

智能UI将一个商品模块的设计数据进行了结构化的拆解,如下:

4b06bee4f6456cabd96df5e56e480640.png

我们分别对模块的「布局」、「字段」、「样式」三个层级的元素进行扩充就可以快速实现方案的 1 到 n。通过控制每个层级中的可选元素数量,来调整最终应用的总方案数;通过对每个层级中的元素进行针对性的设计,来满足业务目标和设计诉求。

65a711d3cd654dad9d9bcdd2a2acb3c2.png

所以原先智能 UI 的调控粒度是“物料&分区”,UI 的样式实际上耦合到了物料(字段)中,假设我们只想调控字体的颜色或者大小,每种样式的物料都需要单独开发。

为了满足运营同学对模块样式可配置的诉求(比如修改文字大小、颜色、背景等等),我们对智能 UI 的数据结构进行了升级,基于 DesignToken 的能力,将「样式」剥离开单独控制。整体链路如下,模块内在设置元件的可变性值时使用了一个由页面统一调控的新DesignToken 值,而该值将在页面级别下发生效。另外,当页面不需要进行 UI 统一调控时,该模块的展示仍不受影响。

ef4fd86f97772212d77dbce5a5421cab.jpeg

  • 更高效的模块研发能力

当一个智能UI模块进行前台渲染时,在工程链路上会分别请求ald数据接口,以及素材个性化tpp服务,假如我们要对主图的素材(场景图、白底图、长图)进行个性化展示,按原先的逻辑前端一方面要开发场景图、白底图、长图三种不同的组件,另一方面需要将从素材个性化服务中获取到的字段决策值,与阿拉丁的数据做校验,因为可能会存在推荐值不存在的情况,而行为埋点则直接取了素材个性化服务的埋点信息。

现在我们直接在阿拉丁侧实现了素材个性化的补全服务,在服务内部调用素材个性化tpp决策要使用的素材图片,前端直接请求阿拉丁的数据接口,不需要做额外的改造,在行为埋点时也直接取用阿拉丁返回值,使埋点信息更准确了。这样通过阿拉丁这样一个中心化的内容分发节点,智能素材可以以较低的研发成本接入多个业务场景。

bc051e2bf04a16d7618f416399ecec3c.jpeg

  • 可观测的 UI 定投实验能力 

基于人群差异、品类差异对 UI 进行精细化的调控,是提升消费者体验以及对产品“独有价值”感知度的一个技术手段。我们将人群定投,品类定投的技术能力产品化到鲸幂平台,形成一个可观测的实验系统,作为鲸幂产品能力的升级。

278a93c2e8f53a6c1cbe5e82c89c1b63.jpeg

支持以下四种投放类型:

  1. 变量A/B(general):单一变量的随机实验,用于不同UI策略的AB测试

  2. 人群定投(crowd):为指定的用户展示指定的UI策略

  3. 行业定投(cate):为指定的一级类目匹配指定的UI策略

  4. 个性化投放(algo):接入智能UI推荐算法模型,对于不同的用户,通过算法决策要展示的UI策略

产品化页面如下:

37309c1a608b622a801cce3a8ccec0dd.png

abff93a86d1ad833ab30d120d70ab513.png

  • 人群定投 - 基于人群的 UI 差异化表达

通过智能UI推荐算法可以实现对不同用户的UI个性化展现,但在新业务的探索阶段,往往需要更具解释性的技术工具,能够直接结合业务目标对用户进行分层。基于以往的实验和经验总结,UI要素在如下人群中的浏览和点击差异较为显著,是可运营的分类方法:

  1. 日常/大促:大促期间用户更注重浏览的效率,且会忽视掉其他内容字段的变化;日常期间用户开始关注商品内容,且对利益点、角标、牛皮癣等内容字段也比较敏感

  2. 女性/男性:女性的点击率显著高于男性

  3. 年龄:在一定程度上随着年龄增加,浏览深度降低,但点击行为也更聚集

  4. 用户活跃度:高、中、低活,新人

  5. 用户点击行为特征

智能UI通过接入奥格人群SDK实现人群投放服务,先在奥格平台进行人群圈选和投放服务化,然后在DSM平台进行UI方案的人群打标过程,在DSM进行实验创建时会自动同步一个鲸幂项目,便于后续在鲸幂平台进行方案的投放,在DSM上的基础操作流程如下,

7f1b58ac89b1685975ef628aa842bc9e.jpeg

人群和UI的绑定规则:

  1. 人群tag(crowd_id)和 UI方案 之间没有严格的映射要求, 可以是一对一、 一对多、或者多对一的关系,如果是一对多的关系,在投放时会给该人群随机分配一个方案;

  2. 由于人群是和UI方案绑定的,在同一个方案包集合中,人群tags要互斥,比如同一个user_id,不能既属于人群 1,又属于人群 2,否则在该方案包中,对于同一人群无法归类;

  3. 支持六种打标方案。

  • 类目定投 - 基于品类的 UI 差异化表达

由于商品卡片的空间固定,所承载信息量极其有限。除去图片所占空间与必要的留白面积,卡片内留给商品描述性文本的空间很少,因此针对用户偏好呈现商品重点信息十分重要。不同行业商品的信息表达示例如下:

3143d5cd64b50b746f9b0bbafb8bb4b6.png

要实现基于类目进行UI投放,是将原先以单页面返回UI的方式改为以单商品坑返回UI。tpp服务的入参需传递多个商品 id,服务端通过数组的顺序匹配对应scene,

[{
"scene":"122_4411",
"items":"618764511532,641571898810"
}]

返回的数据示例:

{
    "result": [
        //场景一的数据
        {
            "scene": "122_4411",
            "algoName": "RANDOM",
            "abType": "random",
            //每个 item 的数据
            "items":[
                {
                    "id":"1",
                    "key":"A^331|B^997|C^5124|D^5110|E^5125|F^988|G^980|H^2518",
                    "trackInfo": "/jingmi.module.exp-----lyg=122_4411.lyg_jmui_183458|random|RANDOM_null.A^331|B^997|C^5124|D^5110|E^5125|F^988|G^980|H^2518.null&item_id=1&scene=122_4411&pageId=null&bucket=183458&ui=A^331|B^997|C^5124|D^5110|E^5125|F^988|G^980|H^2518&score=1.0E-6-----GET",
                    "content": {},
                },
                {
                    "id":"2",
                    "key":"A^331|B^997|C^5124|D^5110|E^5125|F^988|G^980|H^2518",
                    "trackInfo": "/jingmi.module.exp-----lyg=122_4411.lyg_jmui_183458|random|RANDOM_null.A^331|B^997|C^5124|D^5110|E^5125|F^988|G^980|H^2518.null&item_id=2&scene=122_4411&pageId=null&bucket=183458&ui=A^331|B^997|C^5124|D^5110|E^5125|F^988|G^980|H^2518&score=1.0E-6-----GET",
                    "content": {}
                }
            ]
        }
    ]
}

同时,在算法侧也需要将欲打分的UI方案和商品做笛卡尔积处理,由多商品请求服务带来的性能开销通过算法和工程上的优化可以控制在50ms以内,在前台渲染侧是可接受的范围。

类目和UI方案的绑定同样有一个打标的操作过程,方法跟上面的人群定投类似,不同的是不需要去奥格平台圈人。

  落地使用

  • 运营减负 - 页面级 UI 样式调控在小二工作台的应用

在每次大促活动中,同一个会场页面经常会遇到样式风格不统一的问题,比如不同模块之间的上下边距、左右边距不统一,不同模块的标题字号、字重不统一,价格字号、主题色不统一等等。为了帮助运营减负,以一种低成本的方式既快又好地统一调控页面的 UI 风格,我们为方舟模块工坊的生产链路提供了对UI样式可变性进行调控的能力。

458b1099579ce09a979780416b2af4b8.png

上图是模块工坊的生产链路。可以看到,模块的生产角色转变成了运营,运营可以在模块编辑器中根据元件搭建出满足需求的模块,而前端开发只需按照设计师给的规范开发出相应的元件即可。

以点赞数的样式定义举例,首先,设计师会针对不同的业务场景抽象设计出对应的元件,并指定了这些元件的样式可变性范围。开发阶段我们定义了两个 Token: --dt-font-size 和 --dt-color。

.like-count-text {
  font-size: var(--dt-font-size, 20rpx);
  color: var(--dt-color, #333);
}

在元件发布时,我们会对代码进行扫描,从中提取出元件中定义的所有 DesignToken,并注册到元件中心,当运营同学在模块编辑器上使用该元件时,就能对其样式可变性进行修改。

7e809766d1ca1aac7a4b2b21723b5d9b.png

在完成模块的搭建之后,通过发布运营同学就能在方舟搭建页面上使用该模块了,而到了页面运行时,模块将根据 CSS 变量的方式使得可变样式生效。因此,对于页面级 UI 样式调控的诉求,运营只需统一配置页面级的 DesignToken 值即可,从而大大减轻了配置的工作量。

  • 研发提效 - 智能补全字段在聚划算频道场的应用

在聚划算大牌折扣页面,我们应用智能UI进行商品短标题和IC商品标题的个性化投放,只需要在阿拉丁侧和鲸幂侧分别进行配置,通过字段名进行关联。阿拉丁的字段补全服务会自动调用智能素材的tpp服务,前端只需要增加模块的曝光和点击埋点,不需要研发智能模块了,应用一次减少2人日的开发工作量,由3人日下降到1人日,研发效率提升约60%。

ca80a391aef58a5e5c46d792cac07e70.png

线上页面:

8ce7c6502c5bfb423c519be8252085b7.png

  • 人群的精细化运营 - 人群的UI差异化投放在天天特卖中的探索

天天特卖频道通过挖掘不同人群的行为特征数据,应用智能 UI 的人群定投功能,结合不同的交互和 UI 策略,在最佳前台表达方案的探索上进行了多角度尝试。可以看到通过对不同用户做精细化策略投放,提升目标初见成效,实验目前最高相对提升35.7%的目标用户转化。

  智能 UI 总结

鲸幂智能UI项目通过升级智能UI协议规范,支持物料(M)、布局(L),以及更细粒度的字段(F)、风格(S) 的调控,也为基于人群和品类的UI差异化运营提供了一个可干预的技术手段,将来会在探索UI有效性表达的方向上继续深耕,同时会更多的围绕业务需求组织技术迭代和升级鲸幂产品。

1de1e554cd93e9d2e7426beff2a7d4a3.png

聚划算前端端智能应用

03e70f4d8c49af30c183a166d3dcc79a.png

b69cd7bd7da6c0c1e1051a847485a56f.jpeg

天猫超市前端智能化应用

0fa6df0649f1ed598bf990e66365bd62.png

2f3190d7b2a7566c9ae985e83117cc8c.jpeg

天猫新品TMIC智能问卷质量评估

15ec33bcbd44e1f76dfe690cf9b43f9e.png

2576f1d22578886334f4eac4956fabab.jpeg

展望

前端智能化各子领域百花齐放,通过最近这 2 年的阿里业务应用发现,其中前端端智能、智能UI、D2C的使用较为高频,其中前端端智能是近期业务面对流量红利消失用增乏力背景下精细化用户运营的策略,是实现感知用户实时意图的重要能力;在精细化用户运营的背景下终端的交付物(UI交互)怎么进行千人千面的有效表达进而促进转化,未来甚至是短视频、AR/VR的有效表达。D2C还是问题驱动,坚定不移提升设计稿生成视图代码的还原度和可维护性的下限,并基于之上结合C端营销导购场景,探索无代码面向非编程人员的应用,这几乎对设计稿生成代码的还原能力需要接近 100%,继续加油,当 D2C 体验鸿沟真正跨越的时候,才能带来基于此的应用方式的大革新。

6821ef916ffdcd695ef8b91b9aaf0eb2.jpeg

团队介绍

我们是大淘宝技术营销前台技术团队。大淘宝技术,一支致力于成为全球最懂商业的技术创新团队,旗下包含淘宝技术、天猫技术等团队和业务,是一支是具有商业和技术双重基因的螺旋体。

我们在 「杭州阿里巴巴西溪园区」 办公,
我们的定位是「用诗人的浪漫和科学家的严谨打造的极致消费者体验」,
我们的使命是前端智能让业务创新更高效,从而实现让天下没有难做的生意。

¤ 拓展阅读 ¤

3DXR技术 | 终端技术 | 音视频技术

服务端技术 | 技术质量 | 数据算法

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

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

相关文章

【计算机网络】因特网概述

文章目录因特网概述网络、互联网和因特网互联网历史与ISP标准化与RFC因特网的组成三种交换方式电路交换分组交换和报文交换三种交换方式的对比与总结计算机网络的定义和分类计算机网络的定义计算机网络的分类计算机网络的性能指标速率带宽吞吐量时延时延带宽积往返时间利用率丢…

球员分析-前锋

1、球员位置 1.1柱式中锋 球员:吉鲁、奥斯梅恩、米特罗维奇 1.2防守型前锋 球员:劳塔罗、瓦尔迪、维尔纳 1.3抢点前锋 球员:伊卡尔迪、曼联c罗、因扎吉 1.4组织型前锋 球员:凯恩、本泽马、迪巴拉 2、战术职责 2.1柱式中锋&#xf…

设计模式-状态机模式

参考 什么是状态机? 设计模式-状态机模式 什么是状态机(有限状态自动机) 可以把状态机比作方程式, 你输入当前信息, 就能得到下一个信息 举个例子, 按钮门有两个状态, 关闭状态和打开状态, 如果按下开门按钮, 门的状态就从关闭到打开 状态机就是接受门当前状态…

极兔一面:10亿级ES海量搜索狂飙10倍,该怎么办?

背景说明: ES高性能全文索引,如果不会用,或者没有用过,在面试中,会非常吃亏。 所以ES的实操和底层原理,大家要好好准备。 另外,ES调优是一个非常、非常核心的面试知识点,大家要非…

就业大山之下的网络安全:安逸的安服仔

从去年开始,各个互联网大厂就接二连三的放出了裁员消息,整个互联网行业好像都处于寒冬状态。微博、小米、滴滴、知乎、拼多多等在内的一大批互联网知名企业,也相继传出“人员优化”的消息。 除了国内市场的萧条,国外市场也是不容…

kubernetes教程 --Pod调度

Pod调度 在默认情况下,一个Pod在哪个Node节点上运行,是由Scheduler组件采用相应的算法计算出来的,这个过程是不受人工控制的。但是在实际使用中,这并不满足的需求,因为很多情况下,我们想控制某些Pod到达某…

springboot simple (13) springboot Elasticsearch(Elasticsearch8.5.1)

这里首先简单的介绍了Elasticsearch,然后实现了springboot集成Elasticsearch。 版本: Elasticsearch:v8.5.1 Kibana:v8.5.1 springboot集成elasticsearch有两种方式。 1)rest客户端RestHingLevelClient; …

2.2 BeautifulSoup 装载HTML文档

HTML文档结点的查找工具很多,其中 BeautifulSoup 是功能强大且十分流行的查找工具之一。1. BeautifulSoup 的安装安装:pip install bs4导包:from bs4 import BeautifulSoup2. BeautifulSoup 装载HTML文档如果 doc 是一个 HTML 文档&#xff0…

fast planner总结

一、前端 kinodynamic A*算法动力学路径搜索 1.1 路径搜索的主要函数为kinodynamicAstar类的search函数 int KinodynamicAstar::search(Eigen::Vector3d start_pt, Eigen::Vector3d start_v, Eigen::Vector3d start_a,Eigen::Vector3d end_pt, Eigen::Vector3d end_v, bool ini…

DPDK — Userspace PMD 源码分析

目录 文章目录目录PMD driver 通过 IGB_UIO 与 UIO 进行交互注册一个 UIO 设备PMD 的应用层实现PMD 同样支持中断处理方式PMD driver 通过 IGB_UIO 与 UIO 进行交互 IGB_UIO 内核模块的另一个主要功能就是让用于态的 PMD 网卡驱动程序得以与 UIO 进行交互。对于 PMD 的实现来说…

松下PLC通过fpwin上传写入MRTC模块方法

目录 PLC程序上传方法 加密模块使用 PLC程序上传方法 手动将PLC模式设置为prog模式查看PLC是否设置为禁止上传查询指示灯是否变蓝,变蓝则需要将PLC禁止上传功能取消。 3.当上述动作操作完成后,将PLC程序导入到PLC中。为了配合加密程序使用,…

进程通信方式

无名管道( pipe ): 管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。进程的亲缘关系通常是指父子进程关系。高级管道(popen): 将另一个程序当做一个新的进程在当前程序进…

主成分分析(PCA)原理详解

1. 相关背景 在许多领域的研究与应用中,通常需要对含有多个变量的数据进行观测,收集大量数据后进行分析寻找规律。多变量大数据集无疑会为研究和应用提供丰富的信息,但是也在一定程度上增加了数据采集的工作量。更重要的是在很多情形下&…

Windows server——部署web服务

作者简介:一名云计算网络运维人员、每天分享网络与运维的技术与干货。 座右铭:低头赶路,敬事如仪 个人主页:网络豆的主页​​​​​​ 目录 前言 本章重点 一.web讲解 1.WWW概述 (1)WWW服务概述 &…

Linux应用编程下连接本地数据库进行增删改查系列操作

文章目录前言一、常用SQL操作语句二、相关函数解析三、连接本地数据库四、编译运行五、程序源码前言 本篇为C语言应用编程下连接Linux本地数据库进行增删改查系列操作。 在此之前,首先当然是你需要具备一定的数据库基础,所以下面我先列出部分常用的SQL…

如何利用文件上传漏洞-以及如何修复它们

目录什么是文件上传漏洞?文件上传请求如何工作为什么文件上传漏洞是个问题?漏洞 #1:通过文件内容远程代码执行(Web Shell 上传)绕过黑名单保护案例 1:案例 2:案例 3:案例 4&#xff…

【Spark分布式内存计算框架——Spark SQL】10. External DataSource(上)数据源与格式

第六章 External DataSource 在SparkSQL模块,提供一套完成API接口,用于方便读写外部数据源的的数据(从Spark 1.4版本提供),框架本身内置外部数据源: 在Spark 2.4版本中添加支持Image Source(图…

音频信号处理笔记(一)

相关课程:【音频信号处理及深度学习教程】 文章目录01 信号的时域分析1.1 分帧1.1.1 幅值包络1.1.2 均方根能量0 信号的叠加:https://teropa.info/harmonics-explorer/ 一个复杂信号分解成若干简单信号分量之和。不同个频率信号的叠加: 由于和差化积&a…

【Mysql基础 —— SQL语句(一)】

文章目录概述使用启动/停止mysql服务连接mysql客户端数据模型SQLSQL语句分类DDL数据库操作表操作查询创建数据类型修改删除DML添加数据修改数据删除数据DQL基础查询条件查询聚合函数分组查询排序查询分页查询执行顺序DCL管理用户权限控制概述 数据库(Database&#…

如何评价一个新技术——以 ChatGPT 为例

开源社KAIYUANSHE近期微信公众号订阅功能做调整啦!没有被星标的账号在信息流里可能不显示大图了!快星标⭐我们,就可以及时看到发布的文章啦!STEP01 点击右上角标志STEP02 点击【设为星标】缘起2015 年的时候,我写过一篇…