侯体宗的博客
  • 首页
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

基于PHP实现的多元线性回归模拟曲线算法

php  /  管理员 发布于 7年前   141

本文实例讲述了基于PHP实现的多元线性回归模拟曲线算法。分享给大家供大家参考,具体如下:

多元线性回归模型: y = b1x1 + b2x2 + b3x3 +...... +bnxn;

我们根据一组数据: 类似 arr_x = [[1, 2, 3, 4, 5], [6, 7, 8, 9, 10], [11, 12, 13, 14, 15]]; arr_y = [5, 10, 15]; 我们最后要求出的是一个数组,包含了从b1 到bn;

方法:利用最小二乘法

公式:我们只用公式的前半部分,也就是用矩阵来计算

式中的X就是arr_x,二维数组我们可以把它看成是一个矩阵,式中的y就是arr_y,也把它看成一个矩阵(5, 10, 15) ,不过应该是竖着写的。

然后可以根据公式我们会发现要用到矩阵的相乘,转置,求逆;所以下面的代码一一给出:

public function get_complement($data, $i, $j) {  /* x和y为矩阵data的行数和列数 */  $x = count($data);  $y = count($data[0]);  /* data2为所求剩余矩阵 */  $data2 =[];  for ($k = 0; $k < $x -1; $k++) {    if ($k < $i) {      for ($kk = 0; $kk < $y -1; $kk++) {        if ($kk < $j) {          $data2[$k][$kk] = $data[$k][$kk];        } else {          $data2[$k][$kk] = $data[$k][$kk +1];        }      }    } else {      for ($kk = 0; $kk < $y -1; $kk++) {        if ($kk < $j) {          $data2[$k][$kk] = $data[$k +1][$kk];        } else {          $data2[$k][$kk] = $data[$k +1][$kk +1];        }      }    }  }  return $data2;}/* 计算矩阵行列式 */public function cal_det($data) {  $ans = 0;  if (count($data[0]) === 2) {    $ans = $data[0][0] * $data[1][1] - $data[0][1] * $data[1][0];  } else {    for ($i = 0; $i < count($data[0]); $i++) {      $data_temp = $this->get_complement($data, 0, $i);      if ($i % 2 === 0) {        $ans = $ans + $data[0][$i] * ($this->cal_det($data_temp));      } else {        $ans = $ans - $data[0][$i] * ($this->cal_det($data_temp));      }    }  }  return $ans;}/*计算矩阵的伴随矩阵*/public function ajoint($data) {  $m = count($data);  $n = count($data[0]);  $data2 =[];  for ($i = 0; $i < $m; $i++) {    for ($j = 0; $j < $n; $j++) {      if (($i + $j) % 2 === 0) {        $data2[$i][$j] = $this->cal_det($this->get_complement($data, $i, $j));      } else {        $data2[$i][$j] = - $this->cal_det($this->get_complement($data, $i, $j));      }    }  }  return $this->trans($data2);}/*转置矩阵*/public function trans($data) {  $i = count($data);  $j = count($data[0]);  $data2 =[];  for ($k2 = 0; $k2 < $j; $k2++) {    for ($k1 = 0; $k1 < $i; $k1++) {      $data2[$k2][$k1] = $data[$k1][$k2];    }  }  /*将矩阵转置便可得到伴随矩阵*/  return $data2;}/*求矩阵的逆,输入参数为原矩阵*/public function inv($data) {  $m = count($data);  $n = count($data[0]);  $data2 =[];  $det_val = $this->cal_det($data);  $data2 = $this->ajoint($data);  for ($i = 0; $i < $m; $i++) {    for ($j = 0; $j < $n; $j++) {      $data2[$i][$j] = $data2[$i][$j] / $det_val;    }  }  return $data2;}/*求两矩阵的乘积*/public function getProduct($data1, $data2) {  /*$data1 为左乘矩阵*/  $m1 = count($data1);  $n1 = count($data1[0]);  $m2 = count($data2);  $n2 = count($data2[0]);  $data_new =[];  if ($n1 !== $m2) {    return false;  } else {    for ($i = 0; $i <= $m1 -1; $i++) {      for ($k = 0; $k <= $n2 -1; $k++) {        $data_new[$i][$k] = 0;        for ($j = 0; $j <= $n1 -1; $j++) {          $data_new[$i][$k] += $data1[$i][$j] * $data2[$j][$k];        }      }    }  }  return $data_new;}/*多元线性方程*/public function getParams($arr_x, $arr_y) {  $final =[];  $arr_x_t = $this->trans($arr_x);  $result = $this->getProduct($this->getProduct($this->inv($this->getProduct($arr_x_t, $arr_x)), $arr_x_t), $arr_y);  foreach ($result as $key => $val) {    foreach ($val as $_k => $_v) {      $final[] = $_v;    }  }  return $final;}

最后的getParams()方法就是最后求b参数数组的方法,传入一个二维数组arr_x, 和一个一维数组arr_y就可以了。

这一般用于大数据分析,根据大数据来模拟和预测下面的发展和走势。

PS:这里为大家推荐两款相关模拟曲线工具供大家参考:

在线多项式曲线及曲线函数拟合工具:
http://tools..net.cn/jisuanqi/create_fun

在线绘制多项式/函数曲线图形工具:
http://tools..net.cn/jisuanqi/fun_draw

更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP数据结构与算法教程》、《php程序设计算法总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP常用遍历算法与技巧总结》及《PHP数学运算技巧总结》

希望本文所述对大家PHP程序设计有所帮助。

您可能感兴趣的文章:

  • php 大数据量及海量数据处理算法总结
  • php中最简单的字符串匹配算法
  • PHP经典算法集锦【经典收藏】
  • 关于PHP递归算法和应用方法介绍
  • PHP面试常用算法(推荐)
  • php经典算法集锦
  • PHP常用算法和数据结构示例(必看篇)
  • php使用高斯算法实现图片的模糊处理功能示例
  • php实现的常见排序算法汇总
  • PHP实现深度优先搜索算法(DFS,Depth First Search)详解
  • PHP实现广度优先搜索算法(BFS,Broad First Search)详解


  • 上一条:
    PHP双向链表定义与用法示例
    下一条:
    PHP 记录访客的浏览信息方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(95个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客