mirror of
https://github.com/furyfire/trueskill.git
synced 2025-01-27 05:50:40 +00:00
First Matrix unit test
This commit is contained in:
@ -9,34 +9,13 @@ class Matrix
|
|||||||
private $_rowCount;
|
private $_rowCount;
|
||||||
private $_columnCount;
|
private $_columnCount;
|
||||||
|
|
||||||
public function __construct($rows = 0, $columns = 0, $allRowValues = null)
|
public function __construct($rows = 0, $columns = 0, $matrixData = null)
|
||||||
{
|
{
|
||||||
$this->_rowCount = $rows;
|
$this->_rowCount = $rows;
|
||||||
$this->_columnCount = $columns;
|
$this->_columnCount = $columns;
|
||||||
|
$this->_matrixRowData = $matrixData;
|
||||||
$currentIndex = 0;
|
|
||||||
$this->_matrixRowData = array();
|
|
||||||
|
|
||||||
for($currentRow; $currentRow < $rows; $currentRow++)
|
|
||||||
{
|
|
||||||
$currentRowData = array();
|
|
||||||
$this->_matrixRowData[] = $currentRowData;
|
|
||||||
|
|
||||||
for($currentCol = 0; $currentCol < $columns; $currentCol++)
|
|
||||||
{
|
|
||||||
$currentRowData[] = ($allRowValues != null) ? $allRowValues[$currentIndex++] : 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function fromRowValues(&$rowValues)
|
|
||||||
{
|
|
||||||
$result = new Matrix();
|
|
||||||
$result->_matrixRowData = $rowValues;
|
|
||||||
$result->_rowCount = count($rowValues);
|
|
||||||
$result->_columnCount = count($rowValues[0]);
|
|
||||||
return $result;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getRowCount()
|
public function getRowCount()
|
||||||
{
|
{
|
||||||
@ -74,7 +53,7 @@ class Matrix
|
|||||||
$currentColumnTransposeMatrix < $this->_rowCount;
|
$currentColumnTransposeMatrix < $this->_rowCount;
|
||||||
$currentColumnTransposeMatrix++)
|
$currentColumnTransposeMatrix++)
|
||||||
{
|
{
|
||||||
$transposeMatrixCurrentRowColumnValues[$currentColumnTransposeMatrix] =
|
$transposeMatrix[$currentRowTransposeMatrix][$currentColumnTransposeMatrix] =
|
||||||
$this->_matrixRowData[$currentColumnTransposeMatrix][$currentRowTransposeMatrix];
|
$this->_matrixRowData[$currentColumnTransposeMatrix][$currentRowTransposeMatrix];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -84,7 +63,7 @@ class Matrix
|
|||||||
|
|
||||||
private function isSquare()
|
private function isSquare()
|
||||||
{
|
{
|
||||||
return ($this->_rowCount == $this->_column) && ($this->_rowCount > 0);
|
return ($this->_rowCount == $this->_columnCount) && ($this->_rowCount > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDeterminant()
|
public function getDeterminant()
|
||||||
@ -167,12 +146,9 @@ class Matrix
|
|||||||
|
|
||||||
for ($currentColumn = 0; $currentColumn < $this->_columns; $currentColumn++)
|
for ($currentColumn = 0; $currentColumn < $this->_columns; $currentColumn++)
|
||||||
{
|
{
|
||||||
$currentColumnData = array();
|
|
||||||
$result[] = $currentColumnData;
|
|
||||||
|
|
||||||
for ($currentRow = 0; $currentRow < $this->_rowCount; $currentRow++)
|
for ($currentRow = 0; $currentRow < $this->_rowCount; $currentRow++)
|
||||||
{
|
{
|
||||||
$currentColumnData[$currentRow] = $this->getCofactor($currentRow, $currentColumn);
|
$result[$currentColumn][$currentRow] = $this->getCofactor($currentRow, $currentColumn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,12 +178,9 @@ class Matrix
|
|||||||
|
|
||||||
for ($currentRow = 0; $currentRow < $rows; $currentRow++)
|
for ($currentRow = 0; $currentRow < $rows; $currentRow++)
|
||||||
{
|
{
|
||||||
$newRowColumnValues = array();
|
|
||||||
$newValues[$currentRow] = $newRowColumnValues;
|
|
||||||
|
|
||||||
for ($currentColumn = 0; $currentColumn < $columns; $currentColumn++)
|
for ($currentColumn = 0; $currentColumn < $columns; $currentColumn++)
|
||||||
{
|
{
|
||||||
$newRowColumnValues[$currentColumn] = $scalarValue*$matrix->getValue(currentRow, currentColumn);
|
$newValues[$currentRow][$currentColumn] = $scalarValue*$matrix->getValue($currentRow, $currentColumn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -231,11 +204,10 @@ class Matrix
|
|||||||
|
|
||||||
for ($currentRow = 0; $currentRow < $left->getRowCount(); $currentRow++)
|
for ($currentRow = 0; $currentRow < $left->getRowCount(); $currentRow++)
|
||||||
{
|
{
|
||||||
$rowColumnValues = array();
|
|
||||||
$resultMatrix[$currentRow] = $rowColumnValues;
|
|
||||||
for ($currentColumn = 0; $currentColumn < $right->getColumnCount(); $currentColumn++)
|
for ($currentColumn = 0; $currentColumn < $right->getColumnCount(); $currentColumn++)
|
||||||
{
|
{
|
||||||
$rowColumnValues[$currentColumn] = $left->getValue($currentRow, $currentColumn)
|
$resultMatrix[$currentRow][$currentColumn] =
|
||||||
|
$left->getValue($currentRow, $currentColumn)
|
||||||
+
|
+
|
||||||
$right->getValue($currentRow, $currentColumn);
|
$right->getValue($currentRow, $currentColumn);
|
||||||
}
|
}
|
||||||
@ -261,9 +233,6 @@ class Matrix
|
|||||||
|
|
||||||
for ($currentRow = 0; $currentRow < $resultRows; $currentRow++)
|
for ($currentRow = 0; $currentRow < $resultRows; $currentRow++)
|
||||||
{
|
{
|
||||||
$currentRowValues = array();
|
|
||||||
$resultMatrix[$currentRow] = $currentRowValues;
|
|
||||||
|
|
||||||
for ($currentColumn = 0; $currentColumn < $resultColumns; $currentColumn++)
|
for ($currentColumn = 0; $currentColumn < $resultColumns; $currentColumn++)
|
||||||
{
|
{
|
||||||
$productValue = 0;
|
$productValue = 0;
|
||||||
@ -276,7 +245,7 @@ class Matrix
|
|||||||
$productValue = $productValue + $vectorIndexProduct;
|
$productValue = $productValue + $vectorIndexProduct;
|
||||||
}
|
}
|
||||||
|
|
||||||
$resultMatrix[] = $productValue;
|
$resultMatrix[$currentRow][$currentColumn] = $productValue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -290,6 +259,8 @@ class Matrix
|
|||||||
// I'm going to use a horribly naïve algorithm... because I can :)
|
// I'm going to use a horribly naïve algorithm... because I can :)
|
||||||
$result = array();
|
$result = array();
|
||||||
|
|
||||||
|
$actualRow = 0;
|
||||||
|
|
||||||
for ($currentRow = 0; $currentRow < $this->_rowCount; $currentRow++)
|
for ($currentRow = 0; $currentRow < $this->_rowCount; $currentRow++)
|
||||||
{
|
{
|
||||||
if ($currentRow == $rowToRemove)
|
if ($currentRow == $rowToRemove)
|
||||||
@ -297,8 +268,7 @@ class Matrix
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$columnData = array();
|
$actualCol = 0;
|
||||||
$result[] = $columnData;
|
|
||||||
|
|
||||||
for ($currentColumn = 0; $currentColumn < $this->_columnCount; $currentColumn++)
|
for ($currentColumn = 0; $currentColumn < $this->_columnCount; $currentColumn++)
|
||||||
{
|
{
|
||||||
@ -307,8 +277,12 @@ class Matrix
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
$columnData[] = $this->_matrixRowData[$currentRow][$currentColumn];
|
$result[$currentRow][$currentColumn] = $this->_matrixRowData[$currentRow][$currentColumn];
|
||||||
|
|
||||||
|
$actualCol++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$actualRow++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Matrix($this->_rowCount - 1, $this->_columnCount - 1, $result);
|
return new Matrix($this->_rowCount - 1, $this->_columnCount - 1, $result);
|
||||||
@ -342,21 +316,20 @@ class Vector extends Matrix
|
|||||||
|
|
||||||
class SquareMatrix extends Matrix
|
class SquareMatrix extends Matrix
|
||||||
{
|
{
|
||||||
public function __construct(array $allValues)
|
public function __construct()
|
||||||
{
|
{
|
||||||
|
$allValues = \func_get_args();
|
||||||
$rows = (int) sqrt(count($allValues));
|
$rows = (int) sqrt(count($allValues));
|
||||||
$cols = $rows;
|
$cols = $rows;
|
||||||
|
|
||||||
$matrixData = array();
|
$matrixData = array();
|
||||||
|
$allValuesIndex = 0;
|
||||||
|
|
||||||
for ($currentRow = 0; $currentRow < $rows; $currentRow++)
|
for ($currentRow = 0; $currentRow < $rows; $currentRow++)
|
||||||
{
|
{
|
||||||
$currentRowValues = array();
|
|
||||||
$matrixData[] = currentRowValues;
|
|
||||||
|
|
||||||
for ($currentColumn = 0; $currentColumn < $cols; $currentColumn++)
|
for ($currentColumn = 0; $currentColumn < $cols; $currentColumn++)
|
||||||
{
|
{
|
||||||
$currentRowValues[] = $allValues[$allValuesIndex++];
|
$matrixData[$currentRow][$currentColumn] = $allValues[$allValuesIndex++];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user