java 一元线性回归_一元线性回归的java实现

我们有两组数据,比如连续5年的pv与uv。

我们想预测一下,uv达到500k那么pv会是多少。当然更有意思可能是,如果销售额是500w的话,pv会是多少。

机器学习里的一元线性回归方法是比较简单的方法,就是我们猜是满足y=wx+b的。

那么,按求均方误差的偏导后,可得到如下两公式:

749c8ac84b24e6eb8f9b305cbcdc2724.png

下面是求b的公式,要用到w:

14853182f000eb8ece5b641afa234d6e.png

用java代码来实现一下这两公式:

package net.highersoft.svm;

import java.text.DecimalFormat;

import java.util.Arrays;

import java.util.List;

public class TestLineXY {

public static void main(String[] args) {

DecimalFormat df=new DecimalFormat("0.##");

//x pv

//y uv

List x=Arrays.asList(5,9,15,19,19,45);

List y=Arrays.asList(4,6,12,15,15,37);

/*

List x=Arrays.asList(4,6,8,10,12);

List y=Arrays.asList(7.8d,9.3d,9.9d,11.2d,11.9d);

*/

System.out.println(x+""+y);

if(x.size()!=y.size()) {

System.out.println("分子分母数量不一致。");

return;

}

long sum=0;

for(Integer xi:x) {

sum+=xi;

}

double avgx=sum*1.0/y.size();

System.out.println("avg_x:"+avgx);

//w的分子

double w_molecule=0;

for(int i=0;i

w_molecule+=y.get(i)*(x.get(i)-avgx);

//System.out.print(y.get(i)+"*("+x.get(i)+"-"+avgx+") +");

}

System.out.println();

//System.out.println("w_molecule:"+w_molecule);

//w的分母

double w_denominator=0;

int w_denominator_xi=0;

for(int i=0;i

w_denominator+=Math.pow(x.get(i),2);

w_denominator_xi+=x.get(i);

}

w_denominator=w_denominator-(1.0/x.size())*(Math.pow(w_denominator_xi,2));

//System.out.println("w_denominator:"+w_denominator+" w_denominator_xi:"+w_denominator_xi);

double w=w_molecule/w_denominator;

System.out.println("w:"+w);

double b=1.0/x.size();

double sum_y_wx=0;

for(int i=0;i

sum_y_wx+=(y.get(i)-w*x.get(i));

}

b=b*sum_y_wx;

System.out.println("b:"+b);

String symbol="+";

if(b<0) {

symbol="";

}

System.out.println("y="+df.format(w)+"x"+symbol+df.format(b));

System.out.println(w*15+b);

}

}

评论:

95578fe301251f2f2bbda78bf1fd727c.png

提交

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

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

相关文章

【转】ELK是什么能做什么怎么做

作者&#xff1a;蛙课网 链接&#xff1a;https://www.zhihu.com/question/338932215/answer/777380560 来源&#xff1a;知乎 著作权归作者所有。商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处。 为什么用到ELK&#xff1a; 一般我们需要进行日志分析场景&…

java中的并发类_java中并发常用工具类

前言:在你无聊的时候,想想比你优秀还努力的人,也许就不觉的无聊了今天下午没事干把买的java并发编程艺术这本书拿出来看了看,看了下也记不住,还是好记性不如烂笔头,今天讲四个并发中可能会用到的工具类,分别是&#xff1a;CountDownLatchCyclicBarrierSemaphoreExchangerCountD…

github迁移到gitee相关问题

为什么要从github迁移到gitee&#xff08;国内github版&#xff09;&#xff1f; 1. github对于国人来讲&#xff0c;速度较慢。例如&#xff1a; 浏览个技术文档点击个链接半天跳不过去pull、push、clone个代码太慢个人版&#xff08;免费版&#xff09;没有私人仓库&#xf…

【转】abp vNext微服务框架分析

abp vNext新框架的热度一直都很高&#xff0c;于是最近上手将vNext的微服务Demo做了一番研究。我的体验是&#xff0c;vNext的微服务架构确实比较成熟&#xff0c;但是十分难以上手&#xff0c;对于没有微服务开发经验的.net人员来说几乎是看不懂的&#xff0c;所以研究一番后再…

SQL SERVER data tier application 的作用及如何使用SSDT进行SQL数据库的自动化部署到生产环境和版本控制

这个是管理员用来发布数据库所有的脚本用的&#xff0c;自SQL2008以后&#xff0c;微软开始将数据库的开发整合到VS2010上&#xff0c;用户可以将数据所有的相关对象打包成一个DAC包&#xff0c;让管理通过extract data-tier application发布到服务器上。就好像你把代码变成dll…

bitcount java_Java.math.BigInteger.bitCount()方法实例

全屏Java.math.BigInteger.bitCount()方法实例java.math.BigInteger.bitCount()返回此BigInteger的二进制补码表示的位&#xff0c;从它的符号位不同的数字。实现位向量样式集上BigIntegers的时候&#xff0c;此方法很有用。声明以下是java.math.BigInteger.bitCount()方法的声…

php 和jsp,jsp和php哪个好?jsp和php的简单比较

jsp和php这两个Web开发技术哪个好&#xff1f;这个问题应该会有很多人问&#xff0c;但是每种开发技术都有各自的优缺点&#xff0c;所谓的哪个好&#xff0c;不过是看你更擅长使用哪一种技术&#xff0c;所以今天我们来对比一下jsp和php&#xff0c;介绍jsp和php之间有什么区别…

【转】SharePoint 2010 Search Service -- 管理中心配置

今天配置了一下SharePoint Search&#xff0c;怕忘&#xff0c;赶紧记下来。 我参考了国外的一篇文章&#xff1a;Search Configuration in SharePoint 2010 首先&#xff0c;要查看以下User Profile Service, User Profile Synchronization Service是否运行正常&#xff0c;然…

【转】SharePoint 2013中修改windows 活动目录(AD)域用户密码的WebPart(免费下载)

前段时间工作很忙&#xff0c;好久没更新博客了&#xff0c;趁国庆休假期间&#xff0c;整理了两个之前积累很实用的企业集成组件&#xff0c;并在真正的大型项目中经受住了考验&#xff1a;.Net版SAP RFC适配器组件和SharePoint 2013修改AD域用户密码的WebPart。目前无法在网上…

php base64尺寸,PHP base64编码的图像显示不正确

我试图使用base64编码将图像(任何大小)发送到我创建的API。编码后的字符串会作为URL中的参数访问我的API。使用PHP构建的API。PHP base64编码的图像显示不正确一旦请求命中我的API&#xff0c;我想将图像存储到我的服务器上&#xff0c;并将文件名保存在数据库中。这是工作&…

Windows电脑SMB共享设置方法

SMB简介&#xff1a; SMB&#xff08;Server Message Block&#xff09;(*nix平台和Win NT4.0又称CIFS)协议是Windows平台标准文件共享协议&#xff0c;Linux平台通过samba来支持。SMB最新版本v3.0&#xff0c;在v2.0基础上针对WAN和分布式有改进。 建议使用原版wind…

php个人扫码支付,PHP个人发卡网源码,支持MA支付对接,扫码自动发货

PHP个人发卡网源码&#xff0c;支持MA支付对接&#xff0c;扫码自动发货。源码介绍个人发卡网源码&#xff0c;支持码支付对接&#xff0c;扫码自动发货.自适应网页&#xff0c;可为商品设置优惠套餐&#xff0c;后台管理功能丰富。前台发卡页面有点粗糙&#xff0c;已开源的可…

php网页表格样式,HTML5制作表格样式

废话不多说了&#xff0c;具体代码如下所示&#xff1a;表格*{margin: 0;padding: 0;}body{font: italic 20px Georgia, serif;letter-spacing: normal;background-color: #f0f0f0;}#content{width: 750px;padding: 40px;margin: 0 auto;background-color: #fff;border-left: 3…

SharePoint 开发TimerJob 介绍

项目需要写TimerJob&#xff0c;以前也大概知道原理&#xff0c;不过&#xff0c;开发过程中&#xff0c;还是遇到一些问题&#xff0c;网上看了好多博客&#xff0c;也有写的灰常好的&#xff0c;不过&#xff0c;自己还是想再写一下&#xff0c;也算是给自己一个总结&#xf…

linux php环境搭建 图文教程,linux php环境搭建教程

1) 安装依赖包yum -y install wget vim pcre pcre-devel openssl openssl-devel \libicu-devel gcc gcc-c autoconf libjpeg libjpeg-devel libpng \libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib \zlib-devel glibc glibc-devel glib2 glib2-devel ncurse…

【转】The password supplied with the username Domain\UserName was not correct. AD密码定期更换

起因 今天想进入SharePoint 2013 Central Administration创建一个WebApplication&#xff0c;尽然发生了错误&#xff1a; The password supplied with the username Domain\UserName was not correct. Verify that it was entered correctly and try again 具体如下图&#x…

第一节: Timer的定时任务的复习、Quartz.Net的入门使用、Aop思想的体现

一. 前奏-Timer类实现定时任务 在没有引入第三方开源的定时调度框架之前&#xff0c;我们处理一些简单的定时任务同时都是使用Timer类&#xff0c; DotNet中的Timer类有三个&#xff0c;分别位于不同的命名空间下&#xff0c;分别是&#xff1a; ①.位于System.Windows.Forms里…

php 自动验证类,Thinkphp实现自动验证和自动完成

这篇文章主要介绍了Thinkphp实现自动验证和自动完成的相关资料,需要的朋友可以参考下Thinkphp的自动验证和自动完成都是根所表单提交的内容来的&#xff0c;对部分数据进行规则验证和处理后插入到数据库。1、自动验证格式&#xff1a;array(array(验证字段1,验证规则,错误提示,…

第二节:比较DateTime和DateTimeOffset两种时间类型并介绍Quartz.Net中用到的几类时间形式(定点、四舍五入、倍数、递增)

一. 时间的类型 1. 背景 这里为什么要介绍时间类型呢&#xff0c;明明是定时调度篇&#xff0c;原因是在定时任务中&#xff0c;任务什么时间开始执行&#xff0c;什么时间结束执行&#xff0c;要用到各种各样的时间模式&#xff0c;虽然这不能算是一个复杂的问题&#xff0c;但…