| Conditions | 9 |
| Paths | 24 |
| Total Lines | 31 |
| Code Lines | 18 |
| Lines | 0 |
| Ratio | 0 % |
| Tests | 0 |
| CRAP Score | 90 |
| Changes | 0 | ||
| 1 | <?php |
||
| 28 | public function __invoke(Collection $ohlcv, int $period = 200): int |
||
| 29 | { |
||
| 30 | |||
| 31 | $data_close = []; |
||
| 32 | foreach ($ohlcv->get('close') as $point) { |
||
| 33 | $data_close[] = $point; |
||
| 34 | } |
||
| 35 | |||
| 36 | $nl = $nh = 0; |
||
| 37 | $len = count($data_close); |
||
| 38 | $median = (array_sum($data_close) / $len); |
||
| 39 | |||
| 40 | for ($a = 0; $a < $len; $a++) { |
||
| 41 | if ($data_close[$a] > $median && $data_close[$a] > @$data_close[$a - 1]) { |
||
| 42 | $nl++; |
||
| 43 | } elseif ($data_close[$a] < $median && $data_close[$a] < @$data_close[$a - 1]) { |
||
| 44 | $nh++; |
||
| 45 | } |
||
| 46 | } |
||
| 47 | |||
| 48 | $mmi = 100. * ($nl + $nh) / ($len - 1); |
||
| 49 | if ($mmi < 75) { |
||
| 50 | return static::BUY; |
||
| 51 | } |
||
| 52 | |||
| 53 | if ($mmi > 75) { |
||
| 54 | return static::SELL; |
||
| 55 | } |
||
| 56 | |||
| 57 | return static::HOLD; |
||
| 58 | } |
||
| 59 | } |
||
| 60 |