久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

基于PHP實(shí)現(xiàn)的多元線性回歸模擬曲線算法

這篇文章主要介紹了基于PHP實(shí)現(xiàn)的多元線性回歸模擬曲線算法,結(jié)合具體實(shí)例形式分析了多元線性回歸模擬曲線算法的原理與相關(guān)php實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了基于PHP實(shí)現(xiàn)的多元線性回歸模擬曲線算法。分享給大家供大家參考,具體如下:

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

我們根據(jù)一組數(shù)據(jù): 類似 arr_x = [[1, 2, 3, 4, 5], [6, 7, 8, 9, 10], [11, 12, 13, 14, 15]]; arr_y = [5, 10, 15]; 我們最后要求出的是一個(gè)數(shù)組,包含了從b1 到bn;

方法:利用最小二乘法

公式:基于PHP實(shí)現(xiàn)的多元線性回歸模擬曲線算法我們只用公式的前半部分,也就是用矩陣來計(jì)算

式中的X就是arr_x,二維數(shù)組我們可以把它看成是一個(gè)矩陣,式中的y就是arr_y,也把它看成一個(gè)矩陣(5, 10, 15) ,不過應(yīng)該是豎著寫的。

然后可以根據(jù)公式我們會(huì)發(fā)現(xiàn)要用到矩陣的相乘,轉(zhuǎn)置,求逆;所以下面的代碼一一給出:

public function get_complement($data, $i, $j) {
  /* x和y為矩陣data的行數(shù)和列數(shù) */
  $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;
}
/* 計(jì)算矩陣行列式 */
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;
}
/*計(jì)算矩陣的伴隨矩陣*/
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);
}
/*轉(zhuǎn)置矩陣*/
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];
    }
  }
  /*將矩陣轉(zhuǎn)置便可得到伴隨矩陣*/
  return $data2;
}
/*求矩陣的逆,輸入?yún)?shù)為原矩陣*/
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參數(shù)數(shù)組的方法,傳入一個(gè)二維數(shù)組arr_x, 和一個(gè)一維數(shù)組arr_y就可以了。

這一般用于大數(shù)據(jù)分析,根據(jù)大數(shù)據(jù)來模擬和預(yù)測下面的發(fā)展和走勢。

PS:這里為大家推薦兩款相關(guān)模擬曲線工具供大家參考:

在線多項(xiàng)式曲線及曲線函數(shù)擬合工具:
http://tools.jb51.net/jisuanqi/create_fun

在線繪制多項(xiàng)式/函數(shù)曲線圖形工具:
http://tools.jb51.net/jisuanqi/fun_draw

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》

【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)針對有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實(shí)現(xiàn)服務(wù)端分頁的示例代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實(shí)現(xiàn)APP微信支付的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實(shí)現(xiàn)的多維數(shù)組排序算法,結(jié)合實(shí)例形式對比分析了php針對多維數(shù)組及帶有鍵名的多維數(shù)組進(jìn)行排序相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實(shí)現(xiàn)無刷新文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開發(fā)接口使用RSA進(jìn)行加密解密方法,對此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: 伊人久久综合 | 久久久久国产精品人 | 久久免费视频在线 | 国产黄色一级片 | 伊人爽| 狠狠干综合视频 | 日日摸日日爽 | 精品免费国产一区二区三区四区介绍 | 成人免费观看网站 | 天天草天天操 | 一区二区在线免费观看视频 | 午夜日韩视频 | 国产精品久久久久久吹潮 | 日韩视频专区 | 成人精品一区亚洲午夜久久久 | 国产精品完整版 | 亚洲一区二区三区桃乃木香奈 | 精品久久久久久久久久久久久久久久久 | 一区二区三区视频在线观看 | 一级欧美 | 精品国产免费人成在线观看 | 色悠悠久 | 亚洲国产精品激情在线观看 | 国产视频久久 | 日韩成人在线观看 | 久久久久久久久久久国产 | 欧美日韩在线视频一区 | aaa在线| 三级黄片毛片 | 欧美区在线| 一级做a爰片久久毛片 | 亚洲精品欧美一区二区三区 | 日本精品久久 | 国产成人短视频在线观看 | 亚洲综合小视频 | 欧美成人精品一区二区男人看 | 国内精品成人 | 一区二区三区高清不卡 | 女朋友的闺蜜3韩国三级 | 久久久久国产一级毛片高清网站 | 国产在线精品一区二区 |