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