-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathComboTrimean.php
51 lines (42 loc) · 1.41 KB
/
ComboTrimean.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<?php
/**
* JBZoo Toolbox - Csv-Blueprint.
*
* This file is part of the JBZoo Toolbox project.
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*
* @license MIT
* @copyright Copyright (C) JBZoo.com, All rights reserved.
* @see https://github.com/JBZoo/Csv-Blueprint
*/
declare(strict_types=1);
namespace JBZoo\CsvBlueprint\Rules\Aggregate;
use JBZoo\CsvBlueprint\Rules\AbstractRule;
use JBZoo\CsvBlueprint\Utils;
use MathPHP\Statistics\Average;
final class ComboTrimean extends AbstractAggregateRuleCombo
{
public const INPUT_TYPE = AbstractRule::INPUT_TYPE_FLOATS;
protected const NAME = 'trimean';
public function getHelpMeta(): array
{
return [
[
"Trimean (TM, or Tukey's trimean).",
"A measure of a probability distribution's location defined as a weighted average of" .
" the distribution's median and its two quartiles.",
'See: https://en.wikipedia.org/wiki/Trimean',
],
[],
];
}
protected static function calcValue(array $columnValues, ?array $options = null): null|float|int
{
$columnValues = Utils::analyzeGuard($columnValues, self::INPUT_TYPE);
if ($columnValues === null) {
return null;
}
return Average::trimean($columnValues);
}
}