火山引擎DataTester:一个爆款游戏产品,是如何用A/B测试打磨出来的?

news2024/11/15 7:43:19

更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群

随着国内游戏用户数量趋于饱和,中国游戏产业也从高速成长期逐渐转型,市场成熟度提升,竞争趋于精细化。

随着游戏出海以及私域流量运营的挑战,游戏企业对数据分析的使用需求和依赖度进一步提高。而在游戏研发立项、验证、开发、测试、上线和运营等阶段 A/B 测试均能发挥重要作用。

本文讲述一个通过 A/B 测试获得“数据驱动增长”能力的游戏产品故事。并介绍在游戏的研发推广的全流程中,A/B 测试都能应用于哪些场景。

快速试错,A/B 测试打磨爆款游戏

游戏行业发展至今,先后经历了主机游戏时代、网页游戏时代、移动游戏时代等多个阶段,如今移动游戏收入占国内游戏收入的 7 成以上,许多传统游戏公司正面临着转型压力。而随着游戏技术的日趋成熟,大批新兴公司涌入该行业,进一步加剧了竞争压力。

游戏研发流程大致分为立项、验证、开发、测试、上线准备和运营六个阶段,每个阶段往往都伴随着许多修改。

修改的效果如何?对于核心指标是否会有负面的影响?传统的思路,是将新特性上线后验证效果,但这也往往存在上线周期长,过分依赖经验,影响面广等问题。

A/B 测试能够完美地解决上述痛点。它通过在线上流量中取出一小部分,完全随机地分给原策略 A(对照组)和新策略 B(实验组),再结合科学的统计方法 ,得到对于两种策略相对效果的准确估计。

A/B 测试使用线上小流量即可验证效果,并能够有效地衡量不同策略的收益。

"全民弹弹弹"的 A/B 测试故事

在发行时曾荣获“年度最佳休闲游戏”大奖的《全民弹弹弹》,是超休闲游戏类的爆款产品代表。它是一款操作简单、极易上手的球跳塔类休闲游戏,玩家既可以让弹球一层一层地击穿彩色砖块,享受纯粹的弹射快感,也可以解锁更多未知的球球,体验合成的养成乐趣。

在这款游戏研发和推广过程中,借鉴了字节跳动的增长经验,接入了字节自研出品的 A/B 测试产品——火山引擎 DataTester,对游戏的多个环节进行了 A/B 测试。

在《全民弹弹弹》的游戏运营环节,为验证游戏首页对玩家留存和广告数据的影响,设计了两款首页方案通过 A/B 测试进行玩家留存数据的对比:跳塔页(左图)、合成页面(右图)。

经过在 DataTester 中运行 2 周的实验测试,结果显示,首页为合成页(右图)的页面在用户 3 日留存、用户 7 日留存以及广告效果等核心指标中,均明显优于对照组跳塔页(左图)的方案。

在 A/B 测试的数据结果支撑下,《全民弹弹弹》最终全量上线了合成页面的方案,并取得了优异的效果。

一款游戏从研发到打磨,再到上线后的不断调优,全链路均可通过 A/B 测试提升效率和决策准确度。除上述场景外,DataTester 还能在游戏产品中,应用于以下场景:

1.验证新手引导改动,新手任务难度调整,初始资源调整等

2.验证关卡难度、装备爆率、宝箱中奖率调整等影响游戏体验的的改动

3.验证商城界面,积分系统,公告栏、banner、按钮、图标等功能性区域的改动

4.验证匹配系统、好友系统、聊天系统等社交性功能改动

5.验证游戏 IP、NPC、游戏场景、剧情的改动

实验分层,可无限拓展实验流量

在游戏内测阶段,常常会遇到需要多个 A/B 测试并行的场景:

小 A 要验证新的武器系统,需要 50%的流量验证;小 B 修改商城界面,也需要 50%的流量;小 C 对新手任务进行了完善,同样需要 50%的流量验证。此时同时进行 3 个实验,需要 150%的流量。

线上流量不够用,只能对实验进行优先级排序,让几个实验先后进行,但这会导致效率低下。

火山引擎 A/B 测试 DataTester 流量分层技术,将总体流量复制“无数遍”,形成”无数个”流量层。流量层两两之间相互正交,再加之运行在相同层的实验流量互斥,从而保证同时运行多个实验不会互相干扰。

 实验分层技术可以有效的解决线上流量不足的情况,尤其是在游戏内测阶段,这个阶段往往获取用户难度较大。需要通过发布内测任务,小规模买量等方式获得游戏玩家,流量获取成本高。

而这个阶段既需要验证游戏的性能、兼容性,又要对游戏的玩法、关卡设置、故事剧情、营收模型等进行调整。

如果内测时间过长,不仅需要持续的买量投入,也会导致游戏上线节奏被拖慢,甚至可能错过市场热点。通过 DataTester 实验流量分层技术,打破流量限制,大大缩短游戏验证时间,快速上线迭代。

3 大实验场景,提高游戏推广效率

除了传统的客户端、服务端 A/B 测试以外,火山引擎 DataTester 还设有 3 大针对特殊场景的 A/B 测试能力,可以大幅提升游戏在广告投放、信息推送等场景下的效率。

  • 推送实验:通过对推送通知的标题、内容、点击动作等进行测试,找出效果最优的方案。

DataTester 支持多种推送通道、设备类型;可应用于游戏的拉新、召回以及活动推广等场景,及时响应效果,避免负面影响。

  • 广告实验:提升广告投放 ROI,可对比不同的实验文案、不同的投放渠道的广告投放效果。

DataTester 可以通过转化增效度量的方式来控制“自然转化”对实验效果的影响,保证广告实验的科学性和严谨性。

 

  • 可视化实验:DataTester 可以达成所见即所得的 A/B 测试配置,新手小白也能直接上手使用。

通过所见即所得的在线编辑,降低在 Web/H5 页面优化的场景下,产品方和运营方使用 A/B 测试工具的成本。可用于游戏活动的推广页面,抽奖页面的效果对比,无需编程即可快速上线。

上述能力均来自于字节跳动在多年业务打磨中,完成过 150 万余次 A/B 测试的经验积累,因此产品在实用性和易用性方面能力极强。

出海游戏,DataTester 保驾护航

如今全球化运营已经成为新的趋势,海外游戏营收相较于国内有着更高的增长性。国内自研游戏纷纷出海,快速抢占重点地区份额。与此同时也带来了差异化运营、全球化发布、信息安全等全新的挑战。

  • 地区差异化运营

由于各国文化、宗教信仰、潮流趋势的差异,相同的游戏活动和修改,在海外不同的地区往往取得的收益各不相同。对于公司来说,海外不同地区的差异化运营,往往需要积累各地的运营经验,成本通常较高。

盲目的推行,又容易导致一些负面的影响。DataTester 的 A/B 测试支持圈选不同地区的游戏用户,可以针对不同地区的用户开展针对性的测试,能够快速的比较实验结果,确定该地区的最优方案。

  • 全球化发布

全球化发布也是公司在出海过程中所不得不面临的挑战。全球化发布意味着运维成本的提高,同时多版本的管理也增加了发行的复杂性。

DataTester 运行中的 A/B 实验,支持直接转换为特性进行发布。同时支持渐进式发布、定时发布,以及回滚操作等。通过使用特性发布功能,使发布流程更加简洁,减少发布风险。

产品介绍

DataTester 是火山引擎数智平台旗下产品,经过抖音、今日头条等字节业务多年验证,累计开设过 150 万次 A/B 测试,可基于先进的底层算法,提供科学分流能力和智能的统计引擎,支持多种复杂的 A/B 测试类型。

在应用和分析场景上,DataTester 深度耦合推荐、广告、搜索、UI、产品功能等多种业务场景需求,为业务增长、转化、产品迭代,策略优化,运营提效等各个环节提供科学的决策依据,让业务真正做到数据驱动。

目前,DataTester 已在外部多家企业上线应用,将成熟的“数据驱动增长”经验赋能给游戏、汽车、大消费、金融等多个领域。

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

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

相关文章

Java开发学习(二十六)----SpringMVC返回响应结果

SpringMVC接收到请求和数据后,进行了一些处理,当然这个处理可以是转发给Service,Service层再调用Dao层完成的,不管怎样,处理完以后,都需要将结果告知给用户。 比如:根据用户ID查询用户信息、查询用户列表、…

2022世界杯La‘eeb肖像,python海龟实现啦

努力是为了不平庸~ 学习的最大理由是想摆脱平庸,早一天就多一份人生的精彩;迟一天就多一天平庸的困扰。 目录 一、Laeeb的身世 二、开始作画 1、准备阶段 2、常用指令 3、开始做画 一、Laeeb的身世 2022年卡塔尔世界杯(英语&#xff1a…

华为机试 - 高效的任务规划

目录 题目描述 输入描述 输出描述 用例 题目解析 算法源码 题目描述 你有 n 台机器,编号为 1~n,每台都需要完成一项工作,机器经过配置后都能完成独立完成一项工作。假设第 i 台机器你需要花 B 分钟进行设置,然后开始运行&a…

[附源码]计算机毕业设计室内设计类网站Springboot程序

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

Azure考试认证经验

目录 一、概述 1、考试报名 2、考试经验 3、Azure居家考试 4、Azure证书 一、概述 人不管做什么事情,决心很重要。有了目标就要坚定不移的去执行,这是最基本的。如果没有一个正确的心态来学习,建议你放弃。 1、考试报名 Azure考试报名…

2022 年度优秀开源技术

2022 年,我们综合了 OSCHINA 平台上各大认证官方技术团队、开源社区帐号年度发表的内容频率及质量、开展各种活动运营积极性等多方面的表现 具体名单如下(按首字母顺序排名,不分先后): Alluxio 官方 …

osgEarth示例分析——osgearth_cluster

前言 osgearth_cluster示例,展示了绘制很多模型时,如何合适设置模型遮挡的混乱情况。 当模型过多时,可以创建 osgEarth::Util::ClusterNode 节点对象,然后创建 osg::NodeList,将需要绘制的节点 node 们,都…

[附源码]计算机毕业设计JAVA影院售票系统

[附源码]计算机毕业设计JAVA影院售票系统 项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis M…

Mockito verify Junit5集成 Mockito

Mockito 集成 Junit5 在学习Mockito 如何集成 Junit5 之前&#xff0c;先来学习下 Mockito 基础的verify功能。 Maven依赖 本篇博客代码的Maven依赖如下&#xff0c;源码地址 <dependencies><dependency><groupId>org.springframework</groupId>&l…

分享107个小清新ppt模板,总有一款适合您

PPT下载链接&#xff1a;https://pan.baidu.com/s/1WqaR_29avEgq46iTSLKfmw?pwd5r81 提取码&#xff1a;5r81 源码下载链接&#xff1a;ppt.rar - 蓝奏云 采集的参数 page_count 1 # 每个栏目开始业务content"text/html; charsetgb2312"base_url "https:…

大一学生《Web编程基础》期末网页制作 基于HTML+CSS+JavaScript响应式个人主页相册介绍模板

&#x1f389;精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

UNIX环境高级编程_文件IO_文件描述表

这篇文件记录文件描述表。 2 文件描述符表 2.1 什么是文件描述符表 当运行一个程序时&#xff0c;内核会创建进程表task_struct。当open 打开文件后&#xff0c;会在进程表中创建相应的结构体来记录打开的文件&#xff0c;这个结构体就是文件描述符表。 2.2 task_struct 与…

Apple M1 开启HiDPI的新方法,无需虚拟屏,无需SwitchResX

之前折腾2K屏开HiDPI时记录过三种方法&#xff1a; 2020年03月&#xff1a;SwitchResX 开启HiDPI时显示Not installed的解决办法 2020年11月&#xff1a;升级macOS Big Sur 后 HIDPI失效的解决办法 2021年12月&#xff1a; Apple M1 开启HiDPI的新方法&#xff0c;无需关闭SIP&…

MySQL学习笔记(十三)count(*),count(id),count(1),count(字段)区别

count count 是MySQL的一个查询数量统计的函数&#xff0c;我们在平常的工作中经常会用到&#xff0c;count(*),count(id),count(1),count(字段)这4种写法有什么区别呢&#xff1f; //星号 select count(*) from user; //常数 select count(1) from user; //id(主键) select …

片内总线在cpu扮演什么角色?他为什么能实现高效,不同的CPU为什么采用不同的总线协议?

文章目录各种新型片上总线维度&#xff08;Degree&#xff09;跳&#xff08;Hop&#xff09;和跳数&#xff08;Hop Count&#xff0c;HC&#xff09;直连拓扑和路由器Intel的Ring和Mesh总线双Ring结构Mesh Bus结论片上总线&#xff0c;也称作片上网络&#xff08;Network on …

毕业设计-基于机器视觉的火灾烟雾检测识别系统-yolo

目录 前言 课题背景和意义 实现技术思路 实现效果图样例 前言 &#x1f4c5;大四是整个大学期间最忙碌的时光,一边要忙着备考或实习为毕业后面临的就业升学做准备,一边要为毕业设计耗费大量精力。近几年各个学校要求的毕设项目越来越难,有不少课题是研究生级别难度的,对本科…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java基于网络安全维护的机房设备管理19rya

对于计算机专业的学生最头疼的就是临近毕业时的毕业设计,对于如何选题,技术选型等这些问题,难道了大部分人,确实,还没毕业的学生对于这些问题还比较陌生,只有学习的理论知识,没有实战经验怎么能独自完成毕业设计这一系列的流程,今天我们就聊聊如何快速应对这一难题. 比较容易的…

LSM Tree

LSM Tree 的存储模型&#xff0c;包括 Tidb&#xff0c;HBase等 特点 通过将大量的随机写转换为顺序写&#xff0c;从而极大地提升了数据写入的性能&#xff0c;虽然与此同时牺牲了部分读的性能。 只适合存储 key 值有序且写入大于读取的数据&#xff0c;或者读取操作通常是…

vueX持久化存储插件

场景&#xff1a;我们在做vue项目时&#xff0c;会遇到存储一些公共值&#xff0c;这样方便在不同的页面去调用这些值 vue中有个vuex&#xff0c;一般我们都存储在这里&#xff0c;这样在每个页面都能够调用 但是&#xff0c;当页面刷新了&#xff0c;这些值就被自动清理掉了 这…

第七届 Sky Hackathon 笔记集合贴

Alex_McAvoy--------NVIDIA 7th SkyHackathon&#xff08;二&#xff09;开发套件的安装与测试 Alex_McAvoy--------NVIDIA 7th SkyHackathon&#xff08;三&#xff09;语音数据集的制作 Alex_McAvoy--------NVIDIA 7th SkyHackathon&#xff08;四&#xff09;Nemo ASR 模型训…