php实现矩阵
PHP 实现矩阵操作
在 PHP 中,矩阵可以通过多维数组来表示。以下是常见的矩阵操作实现方法:
矩阵初始化
$matrix = [
[1, 2, 3],
[4, 5, 6],
[7, 8, 9]
];
矩阵转置
function matrixTranspose($matrix) {
$transposed = [];
foreach ($matrix as $row => $columns) {
foreach ($columns as $col => $value) {
$transposed[$col][$row] = $value;
}
}
return $transposed;
}
矩阵相加
function matrixAdd($matrix1, $matrix2) {
$result = [];
for ($i = 0; $i < count($matrix1); $i++) {
for ($j = 0; $j < count($matrix1[0]); $j++) {
$result[$i][$j] = $matrix1[$i][$j] + $matrix2[$i][$j];
}
}
return $result;
}
矩阵相乘
function matrixMultiply($matrix1, $matrix2) {
$result = [];
$rows1 = count($matrix1);
$cols1 = count($matrix1[0]);
$cols2 = count($matrix2[0]);
for ($i = 0; $i < $rows1; $i++) {
for ($j = 0; $j < $cols2; $j++) {
$result[$i][$j] = 0;
for ($k = 0; $k < $cols1; $k++) {
$result[$i][$j] += $matrix1[$i][$k] * $matrix2[$k][$j];
}
}
}
return $result;
}
矩阵行列式
function matrixDeterminant($matrix) {
$size = count($matrix);
if ($size == 1) {
return $matrix[0][0];
}
if ($size == 2) {
return $matrix[0][0] * $matrix[1][1] - $matrix[0][1] * $matrix[1][0];
}
$det = 0;
for ($i = 0; $i < $size; $i++) {
$minor = [];
for ($j = 1; $j < $size; $j++) {
$row = [];
for ($k = 0; $k < $size; $k++) {
if ($k != $i) {
$row[] = $matrix[$j][$k];
}
}
$minor[] = $row;
}
$det += $matrix[0][$i] * pow(-1, $i) * matrixDeterminant($minor);
}
return $det;
}
矩阵输出
function printMatrix($matrix) {
foreach ($matrix as $row) {
echo implode("\t", $row) . PHP_EOL;
}
}
使用示例
$m1 = [
[1, 2],
[3, 4]
];
$m2 = [
[5, 6],
[7, 8]
];
$sum = matrixAdd($m1, $m2);
$product = matrixMultiply($m1, $m2);
$transposed = matrixTranspose($m1);
echo "Matrix Addition:\n";
printMatrix($sum);
echo "\nMatrix Multiplication:\n";
printMatrix($product);
echo "\nTransposed Matrix:\n";
printMatrix($transposed);
这些函数提供了基础的矩阵操作功能,可以根据需要进一步扩展。对于更复杂的矩阵运算,可以考虑使用专门的数学库如 PHP-ML 或 MathPHP。







