首页 >>  正文

long+double

来源:baiyundou.net   日期:2024-08-05

风控策略、风控运营等业务人员时常会用到一类系统,即风控决策引擎。那么,什么是风控决策引擎?风控决策引擎有哪些具体的功能模块,其对应的设计又是怎么样的?一起来看看作者的解读。

一、前言

信贷管理中的贷前管理、贷中管理、贷后管理这三篇介绍了信贷管理业务中的主要业务及系统是如何设计的,但是从内容来说,我自我感觉还是稍微比较乱的,后续的工作中如果有了新的理解,可能出再出对应的文章去做补充说明。

信贷管理部分就此告一段落,接下去就介绍下之前一直留下来的一个大坑——风控篇,也就是风控决策引擎部分。

二、什么是风控决策引擎?

「风控决策引擎」目前在市场上没有统一的官方定义,但是从用途来说主要是通过可视化的操作,提供规则、评分卡、决策流等工具,管理和评估风险的系统。主要在金融、电商、保险等各领域被使用。

为什么要设计成的系统?

本质上还是与业务流程的结耦,因为风控规则是高度灵活变动的,在业务的不同阶段和时期,或者说不同领导人的要求下,都是变动的。

如果配置灵活度不高,后期重新设计开发的可能性比较高。

风控决策引擎主要的使用对象是风控策略、风控运营等业务人员,主要工具包含规则、评分卡、决策流。

三、什么是特征?

在说具体工具之前,我们先来聊一聊特征,什么是特征?

特征可以说是风控系统中的最小单元,是风控工具的重要组成部分,我们也可以理解成变量。不过叫什么问题不大,团队内有相同的共识就行。

那么特征有哪些呢?

我们来稍微举几个例子,年龄、性别、年收入这些都属于特征,而这些特征我们需要给予他们对应的类型。从变量分类的角度来分类,可以有int、long、double、string、boolean等类型。但我是设计成了数值型(普通数值型/汇总数值型)、字符串型和枚举型这三种,做了一层归集和删减。

但是,无论采取哪种分类方式,后续的设计能够闭环即可。

四、什么是规则?

一个规则包含特征、逻辑运算符、比较运算符、阈值和触发结果。其中,特征、比较运算符和阈值构成条件表达式,规则由一个或多个条件表达式和触发结果构成,具体关系如下图:

看不懂?

没关系,我们就来举个简单的例子,就以进入网吧的准入规则为例:

  1. 若对象年龄大于等于18岁,则可进入
  2. 若对象年龄小于18岁,则不可进入

这就是一个简单的规则,也是一个条件表达式,其中特征=年龄、比较运算符=大于等于、阈值=18,若满足条件,则触发结果=True,则可进入网吧;否则触发结果=False,不可进入。

那如果增加一个准入条件“是否有钱呢”,那么准入规则就变成为:

  1. 若对象年龄大于等于18岁,且有钱,则可进入
  2. 若对象年龄大于等于18岁,且没钱,则不可进入
  3. 若对象年龄小于18岁,且有钱,则不可进入
  4. 若对象年龄小于18岁,且没钱,则不可进入

在满足年龄大于等于18岁的条件下,还增加了一个条件是否有钱,其中“年龄大于等于18岁”和“是否有钱”这两个条件的逻辑运算符=且,表示两个条件均需满足。

实际的计算过程中,第3、4两种条件下,对象年龄小于18岁的时候,就会造成短路运算,不会再去判断是否有钱。

所以,由上面这个例子可以得出,规则的本质其实就是在处理条件语句。理解了这个大前提之后,风控决策引擎设计上就已经了解了一大半了。

五、功能模块

了解完规则之后,我们来聊下有哪些具体的功能模块以及对应的设计。

风控决策引擎主要由特征管理、规则管理、规则集管理、评分卡管理、决策流管理和历史决策管理组成,在此之上可能迭代出其他模块,但是我是觉得这几个模块是从0开始必须的。

1. 特征管理

系统中的所有基础特征都是需要进行定义的,因此再提交开发之前需要将特征的取值和计算逻辑和开发沟通清楚。在基础特征之外,系统可设计对应衍生特征的简单配置,比如加减乘除、最大、最小值之类的,可以在前端提供给也业务方使用,减少开发的工作量。

在特征管理中着重说明下特征类型和特征来源这两个字段。

a)特征类型

在上文中也说明了每个特征都是有具体的类型的,我在处理的时候做了一层归集,减少了类型数,分为了数值型、枚举型和字符串型。

其中数值型又拆分成普通数值型和汇总数值型,二者主要区别是不同时间维度下的是否存在不同的统计值,最终体现在前端的是是否有时间维度的选择 。

例如“年龄”,年龄的具体数字根据规则执行节点的年月日和出生日期的差值计算得出,在不同的时间维度下年龄是不会有区别的(比如近3个月),所以年龄属于普通数值型;而“月均收入”是根据计算月份的总收入/计算总月份计算得出,所以不同时间维度下是有区别的(比如近3个月和近6个月)。

另外不同类型的特征也绑定了特定的运算符,这样在规则配置的时候也会更简洁点。

  • 数值型:绑定了大于、大于等于、小于、小于等于、等于等运算符,阈值需要是数值。
  • 枚举型:绑定了在集合内、不再集合内的运算符,阈值需要是一个集合。
  • 字符串型:绑定了等于、不等于、在集合内、不在集合内等运算符,阈值需要是一个字符串。

具体的比较运算符的绑定,可以采取先配置基础的运算符,然后根据实际的业务需求再做加法。

b)特征来源

同一个特征,可能会对接不同数据供应商(成本考虑)。比如企业法人信息变更,就可能来自两个不同的供应商,那么,就需要根据特征来源对供应商进行判断。

2. 规则管理

了解规则是由特征、逻辑运算符、比较运算符、阈值和触发结果组成,以及规则其实是在处理条件语句的本质之后,那么前端设计就万变不离其宗了。

上图就是规则管理的部分页面内容,其中比较重要的功能是规则测试。规则测试主要面向对象是业务和测试人员。

  • 业务人员:能够就配置的规则,立马知道规则执行是否有问题。
  • 测试人员:上文说过特征来源可能是自有数据,也有可能是供应商的数据。规则的测试分为取值正确性和规则逻辑性验证。规则测试主要解决规则逻辑性验证,确定好这部分正确后,就可着重对取值进行验证,在规则的验证过程中有的放矢。

另外在触发结果上,一般是有“通过”、“拒绝”、“记录”、“转人工”等选择。因为规则设计都是顺序执行,所以在遇到“拒绝”结果上,整条规则就会中断执行并输出结果;“记录”结果可以认为是一个中性结果,用作规则调试;“转人工”结果就会将案件转人工,由人工介入二次审批。

触发结果除了上述的结果,还有可能输出某一变量的值。比如输出的是“会员等级”这一变量值,根据具体的规则输出金牌、银牌、铜牌这个变量值。

触发结果有哪些、形式是怎样以及对应的逻辑处理,读者可根据实际的业务背景进行定义。

3. 规则集管理

规则集是将多条规则组合成一条规则集合,其本质上还是在执行规则。下图是规则集配置的部分前端页面:

因为规则集也是顺序执行,并且包含了多条规则,在设计上可以加上一些快速变更执行规则顺序的操作。

另外,类似的还有规则表和规则树。

a)规则表

规则表由条件列和结果列构成,上图中的贷款主体变更次数和欠缴费总金额为条件列,最右侧的触发结果为结果列,总共规则数为两个条件列的乘积。

b)规则树

规则树的设计上是按照横向的树叶分支结构。

所以,从上面的额介绍可以得出规则集、规则表和规则树都是规则的聚合,本质上都是在执行规则。

但是在使用体验上还是有差异的:

  • 规则集:规则复用性高,可以复用已经配置好的规则;
  • 规则表:可以额外增加一些表格导入规则的操作;
  • 规则树:树状结构使用上我觉得是最直观的。
4. 评分卡管理

评分卡本质上也是一种规则的变体,在规则中输出的是一个是否通过的结果,而评分卡输出的是一个分数结果。例如针对“年收入”这个特征,可能设置的评分卡如下:

  • 年收入小于5万,得10分
  • 年收入大于等于5万,小于20万,得20分
  • 年收入大于等于20万,得30分

这个例子就是一个评分卡,理解了这个例子就理解了评分卡。

上图是评分卡管理部分的前端页面,其中不同的特征维度之间可能还会有「权重」的设置,比如年收入相较于年龄,设置的权重要更高点,在这样的业务背景下,前端就需要有配置的权重的功能。点击「设置权重」,展示对应权重列,可对某一特征进行设置权重值。那么,最终的评分=特征评分1*权重值1+特征评分2*权重值2+…

在设计评分卡的过程中,要着重注意缺失值 的处理,也就是要有个兜底的区间,保证对应的条件都能取到分值。

5. 决策流管理

决策流类似工作流,能将规则、规则集、评分卡编排,实现一个较大的业务决策流程。

决策流由开始、规则节点、决策和结束构成。规则节点包含规则、规则集和评分卡等工具。

决策就是拿着上一个规则节点的结果进行判断,是选择结束,还是去往下一个规则节点。

上图就是决策流的前端界面,通过规则节点和决策之间的连线,可以清晰的看出决策的处理逻辑。

6. 历史决策管理

历史决策管理中主要管理决策引擎中的历史决策,可查看历史决策的执行路径、明细和结果。

上图是历史决策详情的部分前端页面,针对历史决策,还需要有重新执行、决策回溯之类的操作,以满足业务需要。

  • 重新执行:在进行决策时,会调用大量的内外部接口进行计算,计算的过程中可能会接口错误导致决策停止,针对异常情况,需要有对应的重新执行的操作。
  • 决策回溯:业务是动态变化的,因此针对历史的决策,能回溯重测。

六、补充

功能模块也聊好了,那我们来两个补充的内容吧,分别是贷前的决策模型及规则介绍、数据使用原则。

a)决策模型及规则介绍

贷前模型:

预授信:常使用模型或者评分卡。通常用于白名单营销,在我对接的资金方中,网商和京东有采取预授信,通过主体的基础信息和经营信息,可以预授信出对应的额度,可用于白名单营销。正式进件之后,会再执行准入、反欺诈之类的策略。

准入:常使用规则。一般使用平台自有数据、工商数据、司法数据、纳税数据、发票数据、多头借贷数据。

  • 平台自有数据:年龄、加盟商状态、加盟时长、发货数量、充值金额…
  • 工商数据:成立年限、经营状态、法人变更、股东变更…
  • 司法数据:被列入失信被执行人、限高、被执行案件数量…
  • 纳税数据:纳税年限、纳税登记水平、欠缴税金额….
  • 发票数据:开票月份数、最近一次开票月份距今、开票金额…
  • 多头借贷数据:不同时间纬度下的平台申请数、非银机构逾期记录、非银机构申请数…

反欺诈:常使用规则和评分卡。一般使用平台自有数据、运营商数据。

  • 平台自有数据:三要素/四要素、在网异常、入网时间…
  • 运营商数据:提交时间异常、MAC值变化情况…

授信评级:常使用评分卡。

定额定价:常使用评分卡。

模型的使用不同机构间可能不同,以实际业务为准。

b)数据使用原则(主打一个降本~)

  • 优先使用自有数据源:对于同一个特征可能自有和外部供应商都能提供接口查询,应该优先使用自有数据源。
  • 优先使用低成本数据源:对于同一个特征,可能有多个外部供应商提供接口查询,在选择时应该选择费用较低的数据源。
  • 外部数据及时入库:外部供应商的数据接口查询一般分为查询和查得两种,针对请求回来的供应商的数据要及时入库,在一定周期内是可以重复使用的,避免重复调用供应商接口产生不必要的费用。

七、总结

作为金融风控小学生,在设计风控决策引擎的时候,我觉得最难的不是功能设计,在吃透业务之后,了解了网上相关的材料也能完成设计。在接触的过程中,最难的还是对于规则的设置,在顶层战略规划下,你要怎么去设计你的规则去满足业务规模需要,又能保证风险可控,当然这也可能是对规则背后含义的理解不透彻。

还有个我觉得最繁琐的事,那就是设计特征。文中也说到很多特征是来源于第三方供应商,在设计特征的过程中,看了几十篇接口文档,成百上千个字段,现在回想起来都有一种恶寒,不知道你有没有这样的感受…

那么,风控篇也告一段落了,后续也会继续输出总结相关的内容,让我们一起期待下吧。

希望这篇文章对你有用~

本文由@没汤圆啦 原创发布于人人都是产品经理。未经许可,禁止转载。

题图来自 Unsplash,基于 CC0 协议

该文观点仅代表作者本人,人人都是产品经理平台仅提供信息存储空间服务。提供信息存储空间服务。

","gnid":"99189dc053e25d15e","img_data":[{"flag":2,"img":[{"desc":"","height":"420","title":"","url":"https://p0.ssl.img.360kuai.com/t01b415c63989d88cb9.jpg","width":"900"},{"desc":"","height":"1299","title":"","url":"https://p0.ssl.img.360kuai.com/t012b1c999bb4f03997.jpg","width":"2000"},{"desc":"","height":"1145","title":"","url":"https://p0.ssl.img.360kuai.com/t01afaae00e5375002b.jpg","width":"2000"},{"desc":"","height":"612","title":"","url":"https://p0.ssl.img.360kuai.com/t01b5e3d633b2dd556b.jpg","width":"2000"},{"desc":"","height":"477","title":"","url":"https://p0.ssl.img.360kuai.com/t01ab11a2d62ef801cd.jpg","width":"2000"},{"desc":"","height":"610","title":"","url":"https://p0.ssl.img.360kuai.com/t0128bb850fa1cb6dd6.jpg","width":"2000"},{"desc":"","height":"679","title":"","url":"https://p0.ssl.img.360kuai.com/t01ffb03bab8aed453d.jpg","width":"2000"},{"desc":"","height":"687","title":"","url":"https://p0.ssl.img.360kuai.com/t016c565e468c3cde86.jpg","width":"2000"},{"desc":"","height":"1425","title":"","url":"https://p0.ssl.img.360kuai.com/t01f67c066b5c956907.jpg","width":"2000"},{"desc":"","height":"1346","title":"","url":"https://p0.ssl.img.360kuai.com/t0105b813f564fc9cc1.jpg","width":"2000"}]}],"original":0,"pat":"art_src_3,fts0,sts0","powerby":"pika","pub_time":1694054760000,"pure":"","rawurl":"http://zm.news.so.com/59382d92ed9a49d2d2b8deac1aa491c1","redirect":0,"rptid":"50d7edb79922c8fb","rss_ext":[],"s":"t","src":"人人都是产品经理","tag":[{"clk":"ktechnology_1:风控","k":"风控","u":""}],"title":"从0到1设计金融系统——风控篇

崔善雷5047double 和 long double 有哪些区别 -
尹琦史15015247995 ______ 区别大了 从数学上说,double是实数(有范围限制),long是整数(有范围限制) 实数包含整数 从系统分配字节来说,double变量占8个字节,long占4个字节 从计算机的存储形式来说,区别就更大了,当然,楼主初学,不必了解那么详细 ,只要记住前两点就行

崔善雷5047c语言中 long long ;long double 占用多少内存空间?用什么控制字符? -
尹琦史15015247995 ______ 不同的编译器 long long ;long double 占用多少内存空间可能会有所不同. 你可以用下面的程序得到: #include <stdio.h> #include <limits.h> #include <float.h> int main(void) { printf("long long int 的范围从%lld到%lld, 占用空间为%d个字节\n",...

崔善雷5047double与long double 有何差别 -
尹琦史15015247995 ______ double 长度 8字节.long double 长度 16字节.表示的数的数值范围大小不同,数的精度不同.见 float.h 中的规定.VC++ 6.0:LDBL_MAX 1.189731495357231765e+4932L LDBL_EPSILON 1.08420217248550443412e-019L DBL_MAX 1.7976931348623158e+308 DBL_EPSILON 2.2204460492503131e-016

崔善雷5047C语言long double,超过有效位数之后怎么办 -
尹琦史15015247995 ______ 1. long double,C 提供 long double 类型,目的是提供一种比 double 更加精确的类型.然而,C 标准仅仅规定 long double 至少要和 double 一样精确.对于大多数编译器,long double等于double.2. C语言中,双精度浮点(double)型,占8 个字...

崔善雷5047tc 中怎么输出long double 类型 -
尹琦史15015247995 ______ 可以用以下语句将变量强制转化为long double 类型: (long double )a; 可以用以下语句输出long double 类型 printf("%ld",a);

崔善雷5047Java初学:long类型能转换为double类型吗?它们都是8字节的内存长度 -
尹琦史15015247995 ______ 是有区别的 double a = (double) b/1000;强制转化成double 输出结果:12.345 double c = b/1000;这里的类型是long 输出结果12.0

崔善雷5047long数据类型转换为double会出现数据丢失吗 -
尹琦史15015247995 ______ 会啊 double要大

崔善雷5047怎么把Long或Double类型的数字转换成字节数组 -
尹琦史15015247995 ______ 以下是Int转byte数组,以及byte数组转Int的方法: int对应4个字节分别为:byte[] intBytes = new byte[4]; intBytes[0] = (byte) (x >> 24); intBytes[1] = (byte) (x >> 16); intBytes[2] = (byte) (x >> 8); intBytes[3] = (byte) (x >> 0); 而对应从字节到int,b3对应...

崔善雷5047C语言中long double在什么编译器里是128位? -
尹琦史15015247995 ______ long double什么时候都是80位 另外谭浩强的书有很多致命的错误#include <stdlib.h>#include <stdio.h> int main() { if(((sizeof(long double)*8)==128) printf("long double is %d bytes\1\n",128); else printf("long double is not %d bytes\1\n",128); return 0; }

崔善雷5047请问long double 与double之间为什么字节不是倍数关系? 8 16 32 64 -
尹琦史15015247995 ______ 1.这个和倍数没有直接联系,这个是程序设计语言中的数据类型,是根据计算机语言标准由语言开发商规定的,你要使用这门语言比如说JAVA就得采用JAVA规定的数据类型.而C系列语言也有对应的类型,申明不一定相同,但是可以表示的数字差不多!2.另外这个是由计算机硬件,主要是CPU能处理的字长也有关系!

(编辑:自媒体)
关于我们 | 客户服务 | 服务条款 | 联系我们 | 免责声明 | 网站地图 @ 白云都 2024