回归模型可解决的决策问题-DeepSeek分析第二篇
itomcoil 2025-05-08 18:58 4 浏览
在数据分析和决策支持领域,回归模型是解决复杂业务问题的强大工具。本文通过深入探讨回归模型在预测和解释变量关系中的应用,展示了如何利用多元线性回归和逻辑回归模型解决实际业务中的决策问题
在上一篇deepseek生成时间预测模型分析之后,继续探索deepseek结合分析的可能性,让它用于解决业务中常见的决策问题。
常见决策问题
预测问题:已知一部分变量,想要预测另一变量。
- 比较常见的,比如在知道二手房房屋面积、房龄、地段、房屋新旧程度等因素,想要知道它的售卖价格应该定在多少;
- 又或者知道一个人的收入水平、年龄、性别、历史信用卡还款及时情况、近期消费金额,想要知道这个人对一笔大额借款的借款概率和违约概率是多少,是借款优质用户,还是违约高危用户?
解释:在众多变量中,想要知道这些变量对目标变量的影响程度是多大。
- 比如在房屋面积、房龄、地段、房屋新旧程度,哪个是对房屋价格影响最大的因素,在重点获得房源时,应该着重关注哪个?
- 又或者收入水平、年龄、性别、历史信用卡还款及时情况、近期消费金额等对判断优质/高危的人群,哪个是更重要的因素,在扩展用户中应该重点关注哪部分用户?
回归模型简介
以上两个问题,使用多元线性模型和逻辑回归模型可简单解决。
简单看一下两个模型的数学表达式:
- 线性回归:Y=β0+β1X1+β2X2+β3X3+···+βkXk
- 逻辑回归:ln(P/(1-P))=β0+β1X1+β2X2+β3X3+···+βkXk ,进行指数转化即可得到概率公式
其中X为变量,β为参数,以示意图来理解的话(非数学表达式对应图形)
简单解释上图:多元线性回归,就是找到一条线,使得每组x对应的预测值y都与真实y距离和最短(垂直距离);逻辑回归,是找到一条线,可以将两个不同的类别,准确分到这条线的两边,与实际类别相比预测对的个数越多越好。
逻辑回归其实是一种特殊的多元线性回归,它进行了一次指数转化,把线性回归结果值映射到(0,1]上并保持单调,表达的含义为是y的概率,如以会流失的用户为目标群体,所计算的概率就为用户流失率。
回归模型案例实操
举个例子做个实操,假如在二手车交易平台,新上架一辆二手车,现在需要填写参考价格,希望它既能很快卖掉,又可以尽量多赚到钱。
先梳理一下报价的参考信息,车辆的参数很多如发动机相关的排量、智能系统是否有中控屏、车辆辅助配置是否有雷达等,这些同新车参数一样,也有一些二手车特有比如行驶里程、上牌年份等。重点挑一下对购买具有决策价值的字段,假如筛了如下这些:
对于二手车预计价格可以用多元线性回归模型处理,对于未来3年是否保值这类是否问题,可以使用逻辑回归预测未来3年可保值(p>0.5)的概率。模型选择之后,可能还需要解决一些疑问:
1. 自变量的处理
- 年份,它本身是个数值,但该数值并没有任何物理含义,需要加工一下让它变成距离今天的时间间隔,年份越小,车子越新。
- 排量,它是能衡量发动机性能具有物理含义的指标,但多数情况下车的排量只有几档,数值本身作用不大,需要对它进行效应编码,提取它的序1、2、3、4。
- 车级别、是否有中控屏或是否BBA等,甚至连数字都不是,很难放到线性模型里,这时就需要对类别做处理生成虚拟变量,比如以车辆类别的“轿车”作为参考组,SUV和MPV表示如下
2. 参数估计
- 线性回归,通过计算预估值和真实值最小均方误差,MSE = (1/n) * Σ(y_i – ^y_i)^2,其中n是样本数量,y_i是真实值,^y_i是预测值,数值越小误差越小。
- 逻辑回归,通过最小化对数损失 Log Loss = – (1/N) * Σ [y_i * log(p_i) + (1 – y_i) * log(1 – p_i)],log loss越小表示损失越小。
3. 模型评估指标
- 线性回归,R2、MSE、调整R2 ,R2越高越好,MSE越低越好。
- 逻辑回归,准确率、AUC-ROC、混淆矩阵、F1分数,AUC越高越好。
4. 模型结果
【二手车价格预测模型】
价格预测模型公式 Y1 = 22.636+0.069×行驶里程(万km)-1.8737×上牌距今年间隔+0.3383×新车指导价(万元)-3.6993×中控屏-4.3435×排量+2.3033×BBA品牌-3.3105×SUV车型+3.5228×MPV车型
假如新上架一辆二手车,对应的变量如下,求Y1
- X1 行驶里程数:12
- X2 距今上牌年份间隔:6
- X3 新车指导价:29.75
- X4 是否有中控屏:1
- X5 排量:2
- X6 是否BBA及以上:0
- X7 SUV车型:0
- X8 MPV车型:0
预测:可通过变量进行二手车售卖价格为9.89万元
模型解释:
- 回看公式,以X2和X3 这两个系数较为显著的变量来看,X2距今上牌间隔车龄每增加一年,价格就会下降1.87万;而X3新车指导价每增加1万元,对于二手车价格就会增加0.3万元(其他变量是均值的情况下)
- 而对于X7和X8来说,是在车级别为轿车的基础上判断对二手车价格的影响,即相对于轿车而言,如果是SUV则二手车价格会降3万元,如果是MPV则会增加3.5万元(当然这里的P值不显著即该变量其实对结果影响并没有那么大)
- 还要注意的是,这里通过VIF分析和经验判断,也会发现一点问题,即行驶里程和上牌距今年间隔具有很强的相关性,且X2 VIF=16.69,需要做特征选择或变换。
【二手车是否保值模型】
是否保值预测公式Y2= ln(p/(1-p)) = -3.4375 + (-0.0293)*行驶里程(万km) + (0.4238)*上牌距今年间隔 + (0.0200)*新车指导价(万元) + (1.5857)*中控屏 + (-0.4167)*排量 + (-0.3276)*BBA品牌+ (0.5123)*SUV车型+ (1.6684)*MPV车型
假如新上架一辆二手车,对应的变量如下,求Y2
预测:未来保值的概率为0.52
模型解释
- X2上牌距今年间隔增加1年,其Odds Ratio=e0.4238≈1.528,即距今车龄增加1年保值的的概率增加52.8% ,当然该指标也没有那么显著地影响到是否保值(Odds Ratio= P/(1-P),优势比),车龄越长反而越保值有点反常识的,但仔细思考,新车转手卖成二手车会大幅贬值,时间越长它的贬值幅度反而变缓。由此,也说明该变量更做时间衰减处理,这里就先不展开了。
以上,利用回归模型进行预测和变量解释。方法比较简单,不管是预测还是变量解释性还有一些调优的空间,在后边的文章中会再详细介绍。
但是,可定量衡量自变量对因变量的影响,对一些因素的重要程度进行判断,已经可以帮助我们在纷繁的因素中,找到方向和重点。
作者:小王子和小企鹅,公众号:小王子和小企鹅
本文由@小王子和小企鹅 原创发布于人人都是产品经理。未经作者许可,禁止转载。
该文观点仅代表作者本人,人人都是产品经理平台仅提供信息存储空间服务。
相关推荐
- Excel新函数TEXTSPLIT太强大了,轻松搞定数据拆分!
-
我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!最近我把WPS软件升级到了版本号:12.1.0.15990的最新版本,最版本已经支持文本拆分函数TEXTSPLIT了,并...
- Excel超强数据拆分函数TEXTSPLIT,从入门到精通!
-
我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!今天跟大家分享的是Excel超强数据拆分函数TEXTSPLIT,带你从入门到精通!TEXTSPLIT函数真是太强大了,轻松...
- 看完就会用的C++17特性总结(c++11常用新特性)
-
作者:taoklin,腾讯WXG后台开发一、简单特性1.namespace嵌套C++17使我们可以更加简洁使用命名空间:2.std::variant升级版的C语言Union在C++17之前,通...
- plsql字符串分割浅谈(plsql字符集设置)
-
工作之中遇到的小问题,在此抛出问题,并给出解决方法。一方面是为了给自己留下深刻印象,另一方面给遇到相似问题的同学一个解决思路。如若其中有写的不好或者不对的地方也请不加不吝赐教,集思广益,共同进步。遇到...
- javascript如何分割字符串(javascript切割字符串)
-
javascript如何分割字符串在JavaScript中,您可以使用字符串的`split()`方法来将一个字符串分割成一个数组。`split()`方法接收一个参数,这个参数指定了分割字符串的方式。如...
- TextSplit函数的使用方法(入门+进阶+高级共八种用法10个公式)
-
在Excel和WPS新增的几十个函数中,如果按实用性+功能性排名,textsplit排第二,无函数敢排第一。因为它不仅使用简单,而且解决了以前用超复杂公式才能搞定的难题。今天小编用10个公式,让你彻底...
- Python字符串split()方法使用技巧
-
在Python中,字符串操作可谓是基础且关键的技能,而今天咱们要重点攻克的“堡垒”——split()方法,它能将看似浑然一体的字符串,按照我们的需求进行拆分,极大地便利了数据处理与文本解析工作。基本语...
- go语言中字符串常用的系统函数(golang 字符串)
-
最近由于工作比较忙,视频有段时间没有更新了,在这里跟大家说声抱歉了,我尽快抽些时间整理下视频今天就发一篇关于go语言的基础知识吧!我这我工作中用到的一些常用函数,汇总出来分享给大家,希望对...
- 无规律文本拆分,这些函数你得会(没有分隔符没规律数据拆分)
-
今天文章来源于表格学员训练营群内答疑,混合文本拆分。其实拆分不难,只要规则明确就好办。就怕规则不清晰,或者规则太多。那真是,Oh,mygod.如上图所示进行拆分,文字表达实在是有点难,所以小熊变身灵...
- Python之文本解析:字符串格式化的逆操作?
-
引言前面的文章中,提到了关于Python中字符串中的相关操作,更多地涉及到了字符串的格式化,有些地方也称为字符串插值操作,本质上,就是把多个字符串拼接在一起,以固定的格式呈现。关于字符串的操作,其实还...
- 忘记【分列】吧,TEXTSPLIT拆分文本好用100倍
-
函数TEXTSPLIT的作用是:按分隔符将字符串拆分为行或列。仅ExcelM365版本可用。基本应用将A2单元格内容按逗号拆分。=TEXTSPLIT(A2,",")第二参数设置为逗号...
- Excel365版本新函数TEXTSPLIT,专攻文本拆分
-
Excel中字符串的处理,拆分和合并是比较常见的需求。合并,当前最好用的函数非TEXTJOIN不可。拆分,Office365于2022年3月更新了一个专业函数:TEXTSPLIT语法参数:【...
- 站长在线Python精讲使用正则表达式的split()方法分割字符串详解
-
欢迎你来到站长在线的站长学堂学习Python知识,本文学习的是《在Python中使用正则表达式的split()方法分割字符串详解》。使用正则表达式分割字符串在Python中使用正则表达式的split(...
- Java中字符串分割的方法(java字符串切割方法)
-
技术背景在Java编程中,经常需要对字符串进行分割操作,例如将一个包含多个信息的字符串按照特定的分隔符拆分成多个子字符串。常见的应用场景包括解析CSV文件、处理网络请求参数等。实现步骤1.使用Str...
- 因为一个函数strtok踩坑,我被老工程师无情嘲笑了
-
在用C/C++实现字符串切割中,strtok函数经常用到,其主要作用是按照给定的字符集分隔字符串,并返回各子字符串。但是实际上,可不止有strtok(),还有strtok、strtok_s、strto...
- 一周热门
- 最近发表
- 标签列表
-
- ps像素和厘米换算 (32)
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)