!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:     Factorial.php (3.73 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace PhpOffice\PhpSpreadsheet\Calculation\MathTrig;

use 
PhpOffice\PhpSpreadsheet\Calculation\ArrayEnabled;
use 
PhpOffice\PhpSpreadsheet\Calculation\Exception;
use 
PhpOffice\PhpSpreadsheet\Calculation\Functions;
use 
PhpOffice\PhpSpreadsheet\Calculation\Information\ExcelError;
use 
PhpOffice\PhpSpreadsheet\Calculation\Statistical;

class 
Factorial
{
    use 
ArrayEnabled;

    
/**
     * FACT.
     *
     * Returns the factorial of a number.
     * The factorial of a number is equal to 1*2*3*...* number.
     *
     * Excel Function:
     *        FACT(factVal)
     *
     * @param array|float $factVal Factorial Value, or can be an array of numbers
     *
     * @return array|float|int|string Factorial, or a string containing an error
     *         If an array of numbers is passed as the argument, then the returned result will also be an array
     *            with the same dimensions
     */
    
public static function fact($factVal)
    {
        if (
is_array($factVal)) {
            return 
self::evaluateSingleArgumentArray([self::class, __FUNCTION__], $factVal);
        }

        try {
            
$factVal Helpers::validateNumericNullBool($factVal);
            
Helpers::validateNotNegative($factVal);
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }

        
$factLoop floor($factVal);
        if (
$factVal $factLoop) {
            if (
Functions::getCompatibilityMode() == Functions::COMPATIBILITY_GNUMERIC) {
                return 
Statistical\Distributions\Gamma::gammaValue($factVal 1);
            }
        }

        
$factorial 1;
        while (
$factLoop 1) {
            
$factorial *= $factLoop--;
        }

        return 
$factorial;
    }

    
/**
     * FACTDOUBLE.
     *
     * Returns the double factorial of a number.
     *
     * Excel Function:
     *        FACTDOUBLE(factVal)
     *
     * @param array|float $factVal Factorial Value, or can be an array of numbers
     *
     * @return array|float|int|string Double Factorial, or a string containing an error
     *         If an array of numbers is passed as the argument, then the returned result will also be an array
     *            with the same dimensions
     */
    
public static function factDouble($factVal)
    {
        if (
is_array($factVal)) {
            return 
self::evaluateSingleArgumentArray([self::class, __FUNCTION__], $factVal);
        }

        try {
            
$factVal Helpers::validateNumericNullSubstitution($factVal0);
            
Helpers::validateNotNegative($factVal);
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }

        
$factLoop floor($factVal);
        
$factorial 1;
        while (
$factLoop 1) {
            
$factorial *= $factLoop;
            
$factLoop -= 2;
        }

        return 
$factorial;
    }

    
/**
     * MULTINOMIAL.
     *
     * Returns the ratio of the factorial of a sum of values to the product of factorials.
     *
     * @param mixed[] $args An array of mixed values for the Data Series
     *
     * @return float|string The result, or a string containing an error
     */
    
public static function multinomial(...$args)
    {
        
$summer 0;
        
$divisor 1;

        try {
            
// Loop through arguments
            
foreach (Functions::flattenArray($args) as $argx) {
                
$arg Helpers::validateNumericNullSubstitution($argxnull);
                
Helpers::validateNotNegative($arg);
                
$arg = (int) $arg;
                
$summer += $arg;
                
$divisor *= self::fact($arg);
            }
        } catch (
Exception $e) {
            return 
$e->getMessage();
        }

        
$summer self::fact($summer);

        return 
is_numeric($summer) ? ($summer $divisor) : ExcelError::VALUE();
    }
}

:: 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.0048 ]--