158 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			PHP
		
	
	
| <?php
 | |
| 
 | |
| namespace Matrix;
 | |
| 
 | |
| use Matrix\Operators\Addition;
 | |
| use Matrix\Operators\DirectSum;
 | |
| use Matrix\Operators\Division;
 | |
| use Matrix\Operators\Multiplication;
 | |
| use Matrix\Operators\Subtraction;
 | |
| 
 | |
| class Operations
 | |
| {
 | |
|     public static function add(...$matrixValues): Matrix
 | |
|     {
 | |
|         if (count($matrixValues) < 2) {
 | |
|             throw new Exception('Addition operation requires at least 2 arguments');
 | |
|         }
 | |
| 
 | |
|         $matrix = array_shift($matrixValues);
 | |
| 
 | |
|         if (is_array($matrix)) {
 | |
|             $matrix = new Matrix($matrix);
 | |
|         }
 | |
|         if (!$matrix instanceof Matrix) {
 | |
|             throw new Exception('Addition arguments must be Matrix or array');
 | |
|         }
 | |
| 
 | |
|         $result = new Addition($matrix);
 | |
| 
 | |
|         foreach ($matrixValues as $matrix) {
 | |
|             $result->execute($matrix);
 | |
|         }
 | |
| 
 | |
|         return $result->result();
 | |
|     }
 | |
| 
 | |
|     public static function directsum(...$matrixValues): Matrix
 | |
|     {
 | |
|         if (count($matrixValues) < 2) {
 | |
|             throw new Exception('DirectSum operation requires at least 2 arguments');
 | |
|         }
 | |
| 
 | |
|         $matrix = array_shift($matrixValues);
 | |
| 
 | |
|         if (is_array($matrix)) {
 | |
|             $matrix = new Matrix($matrix);
 | |
|         }
 | |
|         if (!$matrix instanceof Matrix) {
 | |
|             throw new Exception('DirectSum arguments must be Matrix or array');
 | |
|         }
 | |
| 
 | |
|         $result = new DirectSum($matrix);
 | |
| 
 | |
|         foreach ($matrixValues as $matrix) {
 | |
|             $result->execute($matrix);
 | |
|         }
 | |
| 
 | |
|         return $result->result();
 | |
|     }
 | |
| 
 | |
|     public static function divideby(...$matrixValues): Matrix
 | |
|     {
 | |
|         if (count($matrixValues) < 2) {
 | |
|             throw new Exception('Division operation requires at least 2 arguments');
 | |
|         }
 | |
| 
 | |
|         $matrix = array_shift($matrixValues);
 | |
| 
 | |
|         if (is_array($matrix)) {
 | |
|             $matrix = new Matrix($matrix);
 | |
|         }
 | |
|         if (!$matrix instanceof Matrix) {
 | |
|             throw new Exception('Division arguments must be Matrix or array');
 | |
|         }
 | |
| 
 | |
|         $result = new Division($matrix);
 | |
| 
 | |
|         foreach ($matrixValues as $matrix) {
 | |
|             $result->execute($matrix);
 | |
|         }
 | |
| 
 | |
|         return $result->result();
 | |
|     }
 | |
| 
 | |
|     public static function divideinto(...$matrixValues): Matrix
 | |
|     {
 | |
|         if (count($matrixValues) < 2) {
 | |
|             throw new Exception('Division operation requires at least 2 arguments');
 | |
|         }
 | |
| 
 | |
|         $matrix = array_pop($matrixValues);
 | |
|         $matrixValues = array_reverse($matrixValues);
 | |
| 
 | |
|         if (is_array($matrix)) {
 | |
|             $matrix = new Matrix($matrix);
 | |
|         }
 | |
|         if (!$matrix instanceof Matrix) {
 | |
|             throw new Exception('Division arguments must be Matrix or array');
 | |
|         }
 | |
| 
 | |
|         $result = new Division($matrix);
 | |
| 
 | |
|         foreach ($matrixValues as $matrix) {
 | |
|             $result->execute($matrix);
 | |
|         }
 | |
| 
 | |
|         return $result->result();
 | |
|     }
 | |
| 
 | |
|     public static function multiply(...$matrixValues): Matrix
 | |
|     {
 | |
|         if (count($matrixValues) < 2) {
 | |
|             throw new Exception('Multiplication operation requires at least 2 arguments');
 | |
|         }
 | |
| 
 | |
|         $matrix = array_shift($matrixValues);
 | |
| 
 | |
|         if (is_array($matrix)) {
 | |
|             $matrix = new Matrix($matrix);
 | |
|         }
 | |
|         if (!$matrix instanceof Matrix) {
 | |
|             throw new Exception('Multiplication arguments must be Matrix or array');
 | |
|         }
 | |
| 
 | |
|         $result = new Multiplication($matrix);
 | |
| 
 | |
|         foreach ($matrixValues as $matrix) {
 | |
|             $result->execute($matrix);
 | |
|         }
 | |
| 
 | |
|         return $result->result();
 | |
|     }
 | |
| 
 | |
|     public static function subtract(...$matrixValues): Matrix
 | |
|     {
 | |
|         if (count($matrixValues) < 2) {
 | |
|             throw new Exception('Subtraction operation requires at least 2 arguments');
 | |
|         }
 | |
| 
 | |
|         $matrix = array_shift($matrixValues);
 | |
| 
 | |
|         if (is_array($matrix)) {
 | |
|             $matrix = new Matrix($matrix);
 | |
|         }
 | |
|         if (!$matrix instanceof Matrix) {
 | |
|             throw new Exception('Subtraction arguments must be Matrix or array');
 | |
|         }
 | |
| 
 | |
|         $result = new Subtraction($matrix);
 | |
| 
 | |
|         foreach ($matrixValues as $matrix) {
 | |
|             $result->execute($matrix);
 | |
|         }
 | |
| 
 | |
|         return $result->result();
 | |
|     }
 | |
| }
 |