婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于PHP實現的多元線性回歸模擬曲線算法

基于PHP實現的多元線性回歸模擬曲線算法

熱門標簽:400電話申請方法收費 電話機器人危險嗎 400電話辦理福州市 江蘇外呼電銷機器人報價 離石地圖標注 深圳外呼系統收費 南寧高頻外呼回撥系統哪家好 專業電話機器人批發商 長沙crm外呼系統業務

本文實例講述了基于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.jb51.net/jisuanqi/create_fun

在線繪制多項式/函數曲線圖形工具:
http://tools.jb51.net/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,實現,的,多元,線性,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于PHP實現的多元線性回歸模擬曲線算法》相關的同類信息!
  • 本頁收集關于基于PHP實現的多元線性回歸模擬曲線算法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 泰宁县| 澄迈县| 台北县| 辽宁省| 清流县| 永泰县| 普兰县| 江源县| 方正县| 新疆| 招远市| 博野县| 南通市| 伽师县| 高雄市| 民县| 遵义市| 藁城市| 岐山县| 富民县| 台中县| 茶陵县| 电白县| 伊吾县| 金乡县| 崇文区| 始兴县| 宣化县| 绥芬河市| 沙湾县| 沙河市| 新绛县| 浮山县| 常州市| 黄浦区| 平潭县| 永丰县| 资兴市| 灯塔市| 昔阳县| 开江县|