3v4l.org

run code in 300+ PHP versions simultaneously
<?php $timings = [ 109719.80500221252, 55000.132545, 800.15347683, ]; foreach($timings as $time) { echo 'Original time: ', $time, PHP_EOL; if ($time > 60000) { $mins = floor($time / 60000); $secs = round((fmod($time, 60000) / 1000), 2); $time = $mins.' mins'; if ($secs !== 0) { $time .= ", $secs secs"; } } else if ($time > 1000) { $time = round(($time / 1000), 2).' secs'; } else { $time = round($time).'ms'; } echo 'Human readable time: ', $time, PHP_EOL, PHP_EOL; }
Finding entry points
Branch analysis from position: 0
2 jumps found. (Code = 77) Position 1 = 2, Position 2 = 52
Branch analysis from position: 2
2 jumps found. (Code = 78) Position 1 = 3, Position 2 = 52
Branch analysis from position: 3
2 jumps found. (Code = 43) Position 1 = 8, Position 2 = 32
Branch analysis from position: 8
2 jumps found. (Code = 43) Position 1 = 27, Position 2 = 31
Branch analysis from position: 27
1 jumps found. (Code = 42) Position 1 = 47
Branch analysis from position: 47
1 jumps found. (Code = 42) Position 1 = 2
Branch analysis from position: 2
Branch analysis from position: 31
Branch analysis from position: 32
2 jumps found. (Code = 43) Position 1 = 34, Position 2 = 42
Branch analysis from position: 34
1 jumps found. (Code = 42) Position 1 = 47
Branch analysis from position: 47
Branch analysis from position: 42
1 jumps found. (Code = 42) Position 1 = 2
Branch analysis from position: 2
Branch analysis from position: 52
1 jumps found. (Code = 62) Position 1 = -2
Branch analysis from position: 52
filename:       /in/9FelR
function name:  (null)
number of ops:  54
compiled vars:  !0 = $timings, !1 = $time, !2 = $mins, !3 = $secs
line      #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
    3     0  E >   ASSIGN                                                   !0, <array>
    9     1      > FE_RESET_R                                       $5      !0, ->52
          2    > > FE_FETCH_R                                               $5, !1, ->52
   10     3    >   ECHO                                                     'Original+time%3A+'
          4        ECHO                                                     !1
          5        ECHO                                                     '%0A'
   11     6        IS_SMALLER                                               60000, !1
          7      > JMPZ                                                     ~6, ->32
   12     8    >   INIT_FCALL                                               'floor'
          9        DIV                                              ~7      !1, 60000
         10        SEND_VAL                                                 ~7
         11        DO_ICALL                                         $8      
         12        ASSIGN                                                   !2, $8
   13    13        INIT_FCALL                                               'round'
         14        INIT_FCALL                                               'fmod'
         15        SEND_VAR                                                 !1
         16        SEND_VAL                                                 60000
         17        DO_ICALL                                         $10     
         18        DIV                                              ~11     $10, 1000
         19        SEND_VAL                                                 ~11
         20        SEND_VAL                                                 2
         21        DO_ICALL                                         $12     
         22        ASSIGN                                                   !3, $12
   14    23        CONCAT                                           ~14     !2, '+mins'
         24        ASSIGN                                                   !1, ~14
   15    25        IS_NOT_IDENTICAL                                         !3, 0
         26      > JMPZ                                                     ~16, ->31
   16    27    >   ROPE_INIT                                     3  ~18     '%2C+'
         28        ROPE_ADD                                      1  ~18     ~18, !3
         29        ROPE_END                                      2  ~17     ~18, '+secs'
         30        ASSIGN_OP                                     8          !1, ~17
   11    31    > > JMP                                                      ->47
   18    32    >   IS_SMALLER                                               1000, !1
         33      > JMPZ                                                     ~21, ->42
   19    34    >   INIT_FCALL                                               'round'
         35        DIV                                              ~22     !1, 1000
         36        SEND_VAL                                                 ~22
         37        SEND_VAL                                                 2
         38        DO_ICALL                                         $23     
         39        CONCAT                                           ~24     $23, '+secs'
         40        ASSIGN                                                   !1, ~24
   18    41      > JMP                                                      ->47
   21    42    >   INIT_FCALL                                               'round'
         43        SEND_VAR                                                 !1
         44        DO_ICALL                                         $26     
         45        CONCAT                                           ~27     $26, 'ms'
         46        ASSIGN                                                   !1, ~27
   24    47    >   ECHO                                                     'Human+readable+time%3A+'
         48        ECHO                                                     !1
         49        ECHO                                                     '%0A'
         50        ECHO                                                     '%0A'
    9    51      > JMP                                                      ->2
         52    >   FE_FREE                                                  $5
   25    53      > RETURN                                                   1

Generated using Vulcan Logic Dumper, using php 8.0.0


preferences:
156.62 ms | 1009 KiB | 16 Q