>백엔드 개발 >PHP 튜토리얼 >PHP PHP 기술을 기반으로 한 다중 선형 회귀 시뮬레이션 곡선 알고리즘

PHP PHP 기술을 기반으로 한 다중 선형 회귀 시뮬레이션 곡선 알고리즘

jacklove
jacklove원래의
2018-06-28 17:45:401970검색

이 글은 주로 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는 행렬(5, 10, 15)로 간주되므로 2차원 배열을 사용할 수 있습니다. .

그런 다음 공식에 따라 행렬 곱셈, 전치 및 역산을 사용해야 하므로 다음 코드가 하나씩 제공됩니다.

#🎜 🎜#

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;
}

마지막

방법은 b 매개변수 배열을 찾는 마지막 방법입니다. 2차원 배열 arr_x와 1차원 배열 arr_y를 전달하면 됩니다.

이는 일반적으로 빅데이터를 기반으로 다음과 같은 전개 및 동향을 시뮬레이션하고 예측하는 빅데이터 분석에 사용됩니다. getParams()

PS: 참고용으로 권장되는 두 가지 관련 시뮬레이션 곡선 도구는 다음과 같습니다.

#🎜 🎜# 온라인 다항식 곡선 및 곡선 함수 피팅 도구:

http://tools.jb51.net/jisuanqi/create_fun
# 🎜🎜#
온라인 다항식/함수 곡선 그리기 도구:

http://tools.jb51.net/jisuanqi/fun_draw# 🎜🎜## 🎜🎜#당신이 관심을 가질 만한 기사:
PHP 이중 연결 목록 정의 및 사용 예 PHP 기술

#🎜🎜 ##🎜 🎜#PHP는 foreach를 사용하여 배열을 마술처럼 변환합니다(예제 설명)php example

PHP 큰따옴표에서 배열 요소에 액세스할 때 발생하는 오류에 대한 해결 방법 PHP 기술

위 내용은 PHP PHP 기술을 기반으로 한 다중 선형 회귀 시뮬레이션 곡선 알고리즘의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.