oCPC实践录 | 目标ROI的出价与转化回传调控算法

2024-01-01 14:28

本文主要是介绍oCPC实践录 | 目标ROI的出价与转化回传调控算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这篇文章我们聊聊广告主在oCPC下,怎么调控自己的出价或者回传转化优化自己的ROI。

ROI是广告主最关心的指标了,根据oCPC出价的基本原理ocpc_bid = pcvr * given_cpa * k, 广告主在整个出价中有两个可以控制的变量来影响出价,一个是直接的given_cpa,另一个是通过回传转化进而影响pcvr。

在oCPC实践录 | oCPC转化的设计、选择、归因与成本设置(4)中我们聊过,调整出价和调整回传是不等价的,不在这里赘述了。

ROI我们先定义一下:ROI=变现收入/广告花费,当ROI>1时毛利是正的,赚钱;当ROI<1时毛利是负的,亏钱。现在广告主有一个目标ROI,我们定义为target_ROI。

广告主可以通过调整出价或者转化影响出价,进而决定最终的ROI。做这个控制有个非常重要前提假设:调高出价(或转化率)ROI下降,调低出价(或转化率)ROI上升。这个假设往往是不能够严格保证的,因为调高出价有可能会买到高价值的流量,ROI不一定会下降,反之调低出价有可能会失去高价值流量,ROI不一定会上升。类似的逻辑我们在大厂广告算法专家:oCPC产品策略设计与投放实践(下)中也提到过。

现在正常的平台都会开放一个marketing API接口,供广告主自动化操作广告账户,包含广告的出价。因此,借助于这个工具,广告主可以做实时的ROI控制。

我们可以实时预估或者计算广告的真实ROI数据real_ROI,又有一个目标ROI即target_ROI,那一个很简单的思路就是无模型控制算法PID了,这里的无模型是指不去探究系统运行的机理,直接根据real_ROI和target_ROI的偏差调整出价,使得real_ROI=target_ROI,具体的算法逻辑在oCPC实践录 | 随你千变万化,oCPC PID控制(1),oCPC实践录 | 随你千变万化,oCPC PID控制(2),oCPC实践录 | 随你千变万化,oCPC PID控制(3)中有介绍过,不再赘述。

有聪明的小伙伴就发现一个问题,平台侧不是有个k值吗?他们也在控制出价,也会影响到ROI,那怎么办呢?有两个方法:

第一个方法是广告主侧的ROI控制与平台侧的成本控制,都把对方看成是一种系统干扰。直白说就是:不考虑对方的作用。

第二个方法是广告主侧的ROI控制与平台侧的成本控制分离解耦,这就需要探究系统的运行机理,使用基于模型的控制算法。系统的运行机理是一个转化的真实变现价值我们是知道的,除以target_ROI就应该是转化出价了,因此广告主直接计算平均每个转化的变现价值/除以target_ROI,将其设置为given_CPA即可,剩下的事情就是平台侧的成本控制保证real_cpa=given_cpa, 两者是解耦的。这就非常依赖平台侧的成本控制了。

(二)

有一些广告主是通过代理投放广告的,出价是通过代理控制的。所以可以通过调整转化回传来影响成本控制和ROI了。

第一个思路仍然是无模型的控制算法(PID),直接根据real_ROI和target_ROI的偏差调整回传,使得real_ROI=target_ROI,同样,会面临预估与调整出价一样的问题,不再赘述。

另一个思路是有模型的控制算法。从回传侧看系统的运行机理时,ROI等于一个转化的变现价值除以given_cpa,因此说只有转化价值累积超过given_cpa * target_ROI时才应该回传一个转化,点到为止了哈。

(三)

之前笔者做ROI产品时发现存在严重掉量的问题,当时没有分析到原因,直到看到有做目标ROI的回传时,才意识到平台侧ROI产品的一些隐忧。之前ROI产品的设计都是针对每个流量下的用户价值进行调价,但有些广告主是将多个用户累积的价值当成一个转化回传的。如果按照原来的思路将每个用户(或者转化用户的价值)的价值都进行回传,这个值会很小,会严重影响用户LTV的建模,进而影响出价和量级。

这篇关于oCPC实践录 | 目标ROI的出价与转化回传调控算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/559529

相关文章

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板

mac安装nvm(node.js)多版本管理实践步骤

《mac安装nvm(node.js)多版本管理实践步骤》:本文主要介绍mac安装nvm(node.js)多版本管理的相关资料,NVM是一个用于管理多个Node.js版本的命令行工具,它允许开发者在... 目录NVM功能简介MAC安装实践一、下载nvm二、安装nvm三、安装node.js总结NVM功能简介N

Spring Boot 3 整合 Spring Cloud Gateway实践过程

《SpringBoot3整合SpringCloudGateway实践过程》本文介绍了如何使用SpringCloudAlibaba2023.0.0.0版本构建一个微服务网关,包括统一路由、限... 目录引子为什么需要微服务网关实践1.统一路由2.限流防刷3.登录鉴权小结引子当前微服务架构已成为中大型系统的标

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

Java文件与Base64之间的转化方式

《Java文件与Base64之间的转化方式》这篇文章介绍了如何使用Java将文件(如图片、视频)转换为Base64编码,以及如何将Base64编码转换回文件,通过提供具体的工具类实现,作者希望帮助读者... 目录Java文件与Base64之间的转化1、文件转Base64工具类2、Base64转文件工具类3、

如何将二进制文件流转化为MockMultipartFile文件

《如何将二进制文件流转化为MockMultipartFile文件》文章主要介绍了如何使用Spring框架中的MockMultipartFile类来模拟文件上传,并处理上传逻辑,包括获取二进制文件流、创... 目录一、名词解释及业务解释1.具体业务流程2.转换对象解释1. MockMultipartFile2

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表