• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

php 搞代码 4年前 (2022-01-22) 39次浏览 已收录 0个评论

这篇文章主要介绍了基于PHP实现的多元线性回归模拟曲线算法,结合具体实例形式分析了多元线性回归模拟曲线算法的原理与相关php实现技巧,需要的朋友可以参考下

本文实例讲述了基于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 < $<b>%本文@来源gao@!dai!ma.com搞$$代^@码!网</b><strong>搞代gaodaima码</strong>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;}

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:基于PHP实现的多元线性回归模拟曲线算法php技巧

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址