多项式拟合lm_R语言多项式回归

含有x和y这两个变量的线性回归是所有回归分析中最常见的一种;而且,在描述它们关系的时候,也是最有效、最容易假设的一种模型。然而,有些时候,它的实际情况下某些潜在的关系是非常复杂的,不是二元分析所能解决的,而这时,我们需要多项式回归分析来找到这种隐藏的关系。

让我们看一下经济学里的一个例子:假设你要买一个具体的产品,而你要买的个数是q。如果产品的单价是p,然后,你要给y元。其实,这就是一个很典型的线性关系。而总价和产品数量呈正比例关系。下面,根据这个实例,我们敲击行代码来作它们的线性关系图:

p

q

y

plot(q,y,type='l',col='red',main='Linear relationship')

下面是它的线性关系图:

57446ab60a739.png

现在,我们看到这确实是一个不错的估计,这个图很好的模拟成q和y的线性关系。然而,当我们在做买卖要考虑别的因素的时候,诸如这种商品要买多少,很有可能,我们可以通过询问和讨价赚得折扣,或者,当我们越来越多的买一种具体的商品的时候,我们也可能让这种商品升价了。

这样,我们根据上面的条件,我们在写脚本的时候,我们要注意,总价与产品的数量不再具有线性关系了:

y

plot(q,y,type='l',col='navy',main='Nonlinear relationship',lwd=3)

57446ac13c9fe.png

利用多项式回归,我们可以拟合n>1张订单所产生的数据的模型,并且能试着建一个非线性模型。

怎样拟合一个多项式回归

首先,当我们要创建一串虚拟随机数的时候,我们必须总要记得写set.seed(n)。这样做,随机数生成器总能产生同等数目的数据。

set.seed(20)

预测变量q:使用seq来快速产生等间距的序列:

q

预测y值:

y

我们现在产生一些噪音并把它添加到模型中:

noise

noisy.y

对噪声数据进行画图:

plot(q,noisy.y,col='deepskyblue4',xlab='q',main='Observed data')

lines(q,y,col='firebrick1',lwd=3)

下面的这个图根据观测数据进行模拟。其中,模拟的图的散点是蓝色的,而红色线则是信号(信号是一种术语,它通常用于表示我们感兴趣的东西的通常变化趋势)。

57446adaccbfe.png

我们得出的模型应当是 y = aq + bq2 + c*q3 + cost。

现在,我们用R对此进行模拟。要拟合一个多项式模型,你也可以这样用:

model

或者:

model

然而,我们要知道q,I(q^2),I(q^3)存在相关的关系,而这些相关变量很有可能引起某些问题的产生。这时,使用poly()可以避免这个问题,因为它是创建一个垂直的多项式。因此,我喜欢第一种方法:

summary(model)

Call:

lm(formula =noisy.y ~poly(q,3))

Residuals:

Min1QMedian3QMax

-212.326-51.1864.27661.485165.960

Coefficients:

EstimateStd.Errort value Pr(>|t|)

(Intercept)513.6155.60291.69<2e-16***

poly(q,3)12075.89979.42226.14<2e-16***

poly(q,3)2-108.00479.422-1.360.175

poly(q,3)3864.02579.42210.88<2e-16***

---

Signif.codes:0‘***’0.001‘**’0.01‘*’0.05‘.’0.1‘’1

Residualstandard error:79.42on 197degrees of freedom

MultipleR-squared:0.8031,AdjustedR-squared:0.8001

F-statistic:267.8on 3and197DF,p-value:0

我们可以使用confint()来获得一个模型的参数的置信区间。

一下是模型参数的置信区间:

confint(model,level=0.95)

2.5%97.5%

(Intercept)502.5676524.66261

poly(q,3)11919.27392232.52494

poly(q,3)2-264.629248.62188

poly(q,3)3707.39991020.65097

现在,我们要作一个拟合VS残差图。如果这是一个拟合效果比较不错的模型,我们应该看不到任何一种模型的模式特征:

plot(fitted(model),residuals(model))

57446b235efdd.png

整体来说,这个模型的拟合效果还是不错的,毕竟残差为0.8。第一和第三个订单序列的系数,在统计学当中,是相当这样的,这样在我们的意料之中。现在,我们可以使用predict()函数来获得拟合数据以及置信区间,这样,我们可以不按照数据来作图。

下面是预测值和预测置信区间:

predicted.intervals

在已有的图像中添加拟合线:

lines(q,predicted.intervals[,1],col='green',lwd=3)

lines(q,predicted.intervals[,2],col='black',lwd=1)

lines(q,predicted.intervals[,3],col='black',lwd=1)

添加图例:

legend("bottomright",c("Observ.","Signal","Predicted"),

col=c("deepskyblue4","red","green"),lwd=3)

下面是它的拟合图像:

57446b102f063.png

我们可以看到我们的模型在数据的拟合方面做的不错,我们也因此感到非常满意。

注意:多项式回归是一种更能强大的工具。可是,我们也可能得到事与愿违的结果:在这个例子中,我们知道我们的信号是使用三次多项式而产生的,然而,当我们在分析实际数据的时候,我们通常对此不知情,因此,正因为多项式次数n大于4的时候会产生过度拟合的情况,我们要在这里注意一下。但你的模型取了噪音而不是信号的时候会产生过拟合的情况;甚至,当你在现有的数据进行模型优化的时候,当你要尝试预测新的数据的时候就不好了,它会导致缺失值的产生。

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

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

相关文章

AI和大数据下,前端技术将如何发展?

简介&#xff1a; 2010年前后&#xff0c;各种大数据应用进入爆发期。如果说之前的Web应用更多地是在“产生”数据&#xff0c;那在2010年之后&#xff0c;如何更好地“展现”数据则被提上了新的高度&#xff0c;很多前端技术也随之打开了新的篇章。本文作者结合自己的实践&…

漫话云计算,这次加了点儿剧情

“云计算”这个词相信大家都非常熟悉作为目前最热门的科技概念之一它频繁地出现媒体的报道中专家们也经常将它挂在嘴边为它摇旗呐喊那么&#xff0c;究竟什么是云计算呢&#xff1f;它到底有什么用&#xff1f;相比传统计算&#xff0c;它有什么特别之处&#xff1f;今天这篇漫…

阿里云数据湖解决方案全面满足数据需求,帮助企业释放数据价值

简介&#xff1a; 基于阿里云对象存储OSS构建的数据湖解决方案&#xff0c;可以全面满足数据的存储、离线分析、交互查询等各种业务诉求&#xff0c;帮助企业释放数据的价值 1、行业综述 游戏市场需求旺盛&#xff0c;行业景气度持续提升 2020年突如其来的疫情&#xff0c;使…

微服务学习专栏

文章目录一、 Springboot 开源项目推荐1. SmartAdmin2. SPTools3. el-admin4. RuoYi-Vue5. mall6. OA系统开源一、 Springboot 开源项目推荐 1. SmartAdmin 项目地址&#xff1a;https://gitee.com/lab1024/smart-admin 2. SPTools 项目地址&#xff1a;https://gitee.com/52…

云原生时代,应用架构将如何演进?

简介&#xff1a; 如何借助云原生技术来提升交付速度&#xff1f;云原生时代背景下&#xff0c;研发的关注点又会有哪些转变&#xff1f;阿里云高级技术专家许晓斌通过本文分享从 IaaS 上云时代到 PaaS 上云时代的应用架构演进方向&#xff0c;以及云原生技术与应用架构演进的关…

Serverless 对研发效能的变革和创新

简介&#xff1a; 对企业而言&#xff0c;Serverless 架构有着巨大的应用潜力。随着云产品的完善&#xff0c;产品的集成和被集成能力的加强&#xff0c;软件交付流程自动化能力的提高&#xff0c;我们相信在 Serverless 架构下&#xff0c;企业的敏捷性有 10 倍提升的潜力。 作…

查看mysql服务的可视化_Prometheus 监控Mysql服务器及Grafana可视化

Prometheus 监控Mysql服务器及Grafana可视化、mysql_exporter&#xff1a;用于收集MySQL性能信息。使用版本mysqld_exporter 0.11.0官方地址使用文档&#xff1a;https://github.com/prometheus/mysqld_exporter图标模板&#xff1a;https://grafana.com/dashboards/7362下载地…

SprinBoot 集成 Flowable/Activiti工作流引擎

文章目录一、 Flowable工作流引擎1. flow2. flowable3. cims4. RuoYi-flowable5. springboot-flowable-modeler6. flowable-diagram二、Activiti 工作流引擎2.1. RuoYi-Vue-Process2.2. RuoYi-Process2.3. ruoyi-vue-activiti2.4. activiti7-workflow2.5. JeeSite4 JFlow2.6. a…

持续定义Saas模式云数据仓库+实时分析

简介&#xff1a; 从实时分析的价值、场景和数据流程&#xff0c;以及用户对平台能力要求展开&#xff0c;讲述云数据仓库MaxCompute的产品能力优势 &#xff0c;面对实时分析场景的能力演进要求。进而以实时分析典型场景的全数据流程处理、建模和分析的最佳实践&#xff0c;讲…

超 8 成软件存已知高危开源漏洞,奇安信发布《2021 中国软件供应链安全分析报告》

编辑 | 宋 慧 出品 | CSDN云计算 头图 | 付费下载于东方IC 2020年底&#xff0c;SolarWinds 遭受的大规模网络攻击&#xff0c;使得美国和多国政府在内的 18000 机构被影响。几乎每个月&#xff0c;软件供应链都在遭受黑客攻击。 而从软件端看&#xff0c;“检测发现&#xf…

前后端分离 常用工具汇总

文章目录一、数据框架1. vue2. react二、UI框架2.1. element2.2. element-plus2.3. Ant Design Vue2.4. Ant Design of React2.5. Bootstrap三、工具3.1. Fast Mock3.2. Easy Mock3.3. Mock语法/案例一、数据框架 1. vue https://cn.vuejs.org/ 2. react https://react.do…

Fluid 0.3 新版本正式发布:实现云原生场景通用化数据加速

简介&#xff1a; 为了解决大数据、AI 等数据密集型应用在云原生计算存储分离场景下&#xff0c;存在的数据**访问延时高、联合分析难、多维管理杂**等痛点问题&#xff0c;南京大学 PASALab、阿里巴巴、Alluxio 在 2020 年 9 月份联合发起了开源项目 Fluid。近期我们更新了0.3…

mysql 主从 跳过_mysql主从同步如何跳过错误

mysql主从同步跳过错误的方法&#xff1a;1、跳过指定数量的事务&#xff0c;代码为【mysql>SET GLOBAL SQL_SLAVE_SKIP..】&#xff1b;2、修改mysql的配置文件&#xff0c;通过【slave_skip_errors】参数来跳所有错误。本教程操作环境&#xff1a;windows7系统、mysql 5.6…

模拟驾驶能力输出,赋能客户提升稳定性信心

简介&#xff1a; 模拟驾驶能力输出&#xff0c;赋能客户提升稳定性信心 1.背景 我们技术服务团队经常会遇到这样的状况&#xff0c;随时随地收到紧急电话&#xff0c;开始紧张地排查问题&#xff0c;处理故障以及恢复服务。硬盘故障、网络不通、大量不到终态、水位高、流量激…

微服务如何拆分,能解决哪些问题?

作者 | 修冶来源 | 阿里巴巴中间件头图 | 下载于ICphoto微服务在最近几年大受欢迎&#xff0c;很多公司的研发人员都在考虑微服务架构&#xff0c;同时&#xff0c;随着 Docker 容器技术和自动化运维等相关技术发展&#xff0c;微服务变得更容易管理&#xff0c;这给了微服务架…

Tair持久存储系列技术解读

简介&#xff1a; 阿里云数据库重磅发布自研Tair持久存储系列的产品打破了传统Redis中的数据只能在易失性存储上进行读写的刻板印象&#xff0c;针对客户不同业务阶段的数据存储要求与服务成本考量&#xff0c;全新实现了持久性更强、成本更低的KV数据库。 Redis做为当今主流的…

Serverless X OpenKruise 部署效率优化之道

简介&#xff1a; 相信在不久的将来&#xff0c;SAE 的极致弹性&#xff0c;无论在弹性效率&#xff0c;弹性规模&#xff0c;还是智能精准等方面都会大放异彩。 作者 | 许成铭&#xff08;竞霄&#xff09; Serverless 作为云计算的最佳实践、云原生发展的方向和未来演进趋势…

重磅来袭 | 移动云城市峰会分论坛暨移动云TeaTalk青岛站 即将开启

随着大数据技术不断演进和应用持续深化&#xff0c;以数据为核心的大数据产业生态正在加速构建。6月10日&#xff0c;移动云城市峰会将在青岛举办。届时&#xff0c;“云数融通&#xff0c;驱动未来”分论坛暨移动云TeaTalk青岛站 也将同步重磅开启。分论坛将围绕移动云核心数据…

2020阿里云双11--0.73折起,爆款提前抢大促全攻略

2020阿里云双11大促活动于10月24日正式开启&#xff0c;此次双11阿里云将有哪些亮点活动&#xff0c;此篇文章将一网打尽。大家一定要关注&#xff0c;此文会一直更新到活动结束。 从活动页面来看&#xff0c;阿里云双11上云狂欢节活动分为三个阶段&#xff1a; 10月24日-10月…

linux共享软件_为什么 linux 要用 tar.gz,很少用 7z 或 zip?

因为 7z 和 zip 压缩格式都不能保留 unix 风格的文件权限&#xff0c;比如解压出个可执行文件要重新 chmod chown 才能恢复正常。而 tar 格式可以。而 tar 本身不提供压缩&#xff0c;无非就是把包括所有文件的內容和权限拼成一个文件而己&#xff0c;所以用另外如 gzip 格式压…