class org.graalvm.polybench.PeakTimeMetric implements org.graalvm.polybench.Metric
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.graalvm.polybench.PeakTimeMetric
  super_class: java.lang.Object
{
  long startTime;
    descriptor: J
    flags: (0x0000) 

  long endTime;
    descriptor: J
    flags: (0x0000) 

  long totalTime;
    descriptor: J
    flags: (0x0000) 

  int totalIterations;
    descriptor: I
    flags: (0x0000) 

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
         0: .line 35
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 36
            aload 0 /* this */
            lconst_0
            putfield org.graalvm.polybench.PeakTimeMetric.totalTime:J
         2: .line 37
            return
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/graalvm/polybench/PeakTimeMetric;

  public void beforeIteration(boolean, int, org.graalvm.polybench.Config);
    descriptor: (ZILorg/graalvm/polybench/Config;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
        start local 1 // boolean warmup
        start local 2 // int iteration
        start local 3 // org.graalvm.polybench.Config config
         0: .line 41
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.graalvm.polybench.PeakTimeMetric.startTime:J
         1: .line 42
            return
        end local 3 // org.graalvm.polybench.Config config
        end local 2 // int iteration
        end local 1 // boolean warmup
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lorg/graalvm/polybench/PeakTimeMetric;
            0    2     1     warmup  Z
            0    2     2  iteration  I
            0    2     3     config  Lorg/graalvm/polybench/Config;
    MethodParameters:
           Name  Flags
      warmup     
      iteration  
      config     

  public void afterIteration(boolean, int, org.graalvm.polybench.Config);
    descriptor: (ZILorg/graalvm/polybench/Config;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=4
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
        start local 1 // boolean warmup
        start local 2 // int iteration
        start local 3 // org.graalvm.polybench.Config config
         0: .line 46
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.graalvm.polybench.PeakTimeMetric.endTime:J
         1: .line 48
            aload 0 /* this */
            dup
            getfield org.graalvm.polybench.PeakTimeMetric.totalTime:J
            aload 0 /* this */
            getfield org.graalvm.polybench.PeakTimeMetric.endTime:J
            aload 0 /* this */
            getfield org.graalvm.polybench.PeakTimeMetric.startTime:J
            lsub
            ladd
            putfield org.graalvm.polybench.PeakTimeMetric.totalTime:J
         2: .line 49
            aload 0 /* this */
            dup
            getfield org.graalvm.polybench.PeakTimeMetric.totalIterations:I
            iconst_1
            iadd
            putfield org.graalvm.polybench.PeakTimeMetric.totalIterations:I
         3: .line 50
            return
        end local 3 // org.graalvm.polybench.Config config
        end local 2 // int iteration
        end local 1 // boolean warmup
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lorg/graalvm/polybench/PeakTimeMetric;
            0    4     1     warmup  Z
            0    4     2  iteration  I
            0    4     3     config  Lorg/graalvm/polybench/Config;
    MethodParameters:
           Name  Flags
      warmup     
      iteration  
      config     

  public void reset();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
         0: .line 54
            aload 0 /* this */
            lconst_0
            putfield org.graalvm.polybench.PeakTimeMetric.startTime:J
         1: .line 55
            aload 0 /* this */
            lconst_0
            putfield org.graalvm.polybench.PeakTimeMetric.endTime:J
         2: .line 56
            aload 0 /* this */
            lconst_0
            putfield org.graalvm.polybench.PeakTimeMetric.totalTime:J
         3: .line 57
            aload 0 /* this */
            iconst_0
            putfield org.graalvm.polybench.PeakTimeMetric.totalIterations:I
         4: .line 58
            return
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/graalvm/polybench/PeakTimeMetric;

  public java.util.Optional<java.lang.Double> reportAfterIteration(org.graalvm.polybench.Config);
    descriptor: (Lorg/graalvm/polybench/Config;)Ljava/util/Optional;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
        start local 1 // org.graalvm.polybench.Config config
         0: .line 62
            aload 0 /* this */
            getfield org.graalvm.polybench.PeakTimeMetric.endTime:J
            aload 0 /* this */
            getfield org.graalvm.polybench.PeakTimeMetric.startTime:J
            lsub
            l2d
            ldc 1000000.0
            ddiv
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            invokestatic java.util.Optional.of:(Ljava/lang/Object;)Ljava/util/Optional;
            areturn
        end local 1 // org.graalvm.polybench.Config config
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lorg/graalvm/polybench/PeakTimeMetric;
            0    1     1  config  Lorg/graalvm/polybench/Config;
    Signature: (Lorg/graalvm/polybench/Config;)Ljava/util/Optional<Ljava/lang/Double;>;
    MethodParameters:
        Name  Flags
      config  

  public java.util.Optional<java.lang.Double> reportAfterAll();
    descriptor: ()Ljava/util/Optional;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
         0: .line 67
            dconst_1
            aload 0 /* this */
            getfield org.graalvm.polybench.PeakTimeMetric.totalTime:J
            l2d
            dmul
            aload 0 /* this */
            getfield org.graalvm.polybench.PeakTimeMetric.totalIterations:I
            i2d
            ddiv
            ldc 1000000.0
            ddiv
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            invokestatic java.util.Optional.of:(Ljava/lang/Object;)Ljava/util/Optional;
            areturn
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/polybench/PeakTimeMetric;
    Signature: ()Ljava/util/Optional<Ljava/lang/Double;>;

  public java.lang.String unit();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
         0: .line 72
            ldc "ms"
            areturn
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/polybench/PeakTimeMetric;

  public java.lang.String name();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.polybench.PeakTimeMetric this
         0: .line 77
            ldc "peak time"
            areturn
        end local 0 // org.graalvm.polybench.PeakTimeMetric this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/polybench/PeakTimeMetric;
}
SourceFile: "PeakTimeMetric.java"