public class org.graalvm.compiler.phases.common.ExpandLogicPhase extends org.graalvm.compiler.phases.Phase
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.phases.common.ExpandLogicPhase
  super_class: org.graalvm.compiler.phases.Phase
{
  private static final double EPSILON;
    descriptor: D
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1.0E-6

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 48
            ldc Lorg/graalvm/compiler/phases/common/ExpandLogicPhase;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.graalvm.compiler.phases.common.ExpandLogicPhase.$assertionsDisabled:Z
         3: .line 49
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.phases.common.ExpandLogicPhase this
         0: .line 48
            aload 0 /* this */
            invokespecial org.graalvm.compiler.phases.Phase.<init>:()V
            return
        end local 0 // org.graalvm.compiler.phases.common.ExpandLogicPhase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/phases/common/ExpandLogicPhase;

  protected void run(org.graalvm.compiler.nodes.StructuredGraph);
    descriptor: (Lorg/graalvm/compiler/nodes/StructuredGraph;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=7, args_size=2
        start local 0 // org.graalvm.compiler.phases.common.ExpandLogicPhase this
        start local 1 // org.graalvm.compiler.nodes.StructuredGraph graph
         0: .line 54
            aload 1 /* graph */
            getstatic org.graalvm.compiler.nodes.ShortCircuitOrNode.TYPE:Lorg/graalvm/compiler/graph/NodeClass;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getNodes:(Lorg/graalvm/compiler/graph/NodeClass;)Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 3
            goto 3
      StackMap locals: org.graalvm.compiler.phases.common.ExpandLogicPhase org.graalvm.compiler.nodes.StructuredGraph top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.ShortCircuitOrNode
            astore 2 /* logic */
        start local 2 // org.graalvm.compiler.nodes.ShortCircuitOrNode logic
         2: .line 55
            aload 2 /* logic */
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.processBinary:(Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;)V
        end local 2 // org.graalvm.compiler.nodes.ShortCircuitOrNode logic
         3: .line 54
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 57
            getstatic org.graalvm.compiler.phases.common.ExpandLogicPhase.$assertionsDisabled:Z
            ifne 5
            aload 1 /* graph */
            getstatic org.graalvm.compiler.nodes.ShortCircuitOrNode.TYPE:Lorg/graalvm/compiler/graph/NodeClass;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getNodes:(Lorg/graalvm/compiler/graph/NodeClass;)Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isEmpty:()Z
            ifne 5
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         5: .line 59
      StackMap locals: org.graalvm.compiler.phases.common.ExpandLogicPhase org.graalvm.compiler.nodes.StructuredGraph
      StackMap stack:
            aload 1 /* graph */
            getstatic org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode.TYPE:Lorg/graalvm/compiler/graph/NodeClass;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.getNodes:(Lorg/graalvm/compiler/graph/NodeClass;)Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.iterator:()Ljava/util/Iterator;
            astore 3
            goto 16
      StackMap locals: org.graalvm.compiler.phases.common.ExpandLogicPhase org.graalvm.compiler.nodes.StructuredGraph top java.util.Iterator
      StackMap stack:
         6: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode
            astore 2 /* logic */
        start local 2 // org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode logic
         7: .line 60
            aconst_null
            astore 4
            aconst_null
            astore 5
         8: aload 2 /* logic */
            invokevirtual org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode.withNodeSourcePosition:()Lorg/graalvm/compiler/debug/DebugCloseable;
            astore 6 /* context */
        start local 6 // org.graalvm.compiler.debug.DebugCloseable context
         9: .line 61
            aload 2 /* logic */
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.processNormalizeCompareNode:(Lorg/graalvm/compiler/nodes/calc/AbstractNormalizeCompareNode;)V
        10: .line 62
            aload 6 /* context */
            ifnull 16
            aload 6 /* context */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
            goto 16
      StackMap locals: org.graalvm.compiler.phases.common.ExpandLogicPhase org.graalvm.compiler.nodes.StructuredGraph org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode java.util.Iterator java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable
      StackMap stack: java.lang.Throwable
        11: astore 4
            aload 6 /* context */
            ifnull 12
            aload 6 /* context */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
        end local 6 // org.graalvm.compiler.debug.DebugCloseable context
      StackMap locals:
      StackMap stack:
        12: aload 4
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        13: astore 5
            aload 4
            ifnonnull 14
            aload 5
            astore 4
            goto 15
      StackMap locals:
      StackMap stack:
        14: aload 4
            aload 5
            if_acmpeq 15
            aload 4
            aload 5
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        15: aload 4
            athrow
        end local 2 // org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode logic
        16: .line 59
      StackMap locals: org.graalvm.compiler.phases.common.ExpandLogicPhase org.graalvm.compiler.nodes.StructuredGraph top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        17: .line 64
            aload 1 /* graph */
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.setAfterExpandLogic:()V
        18: .line 65
            return
        end local 1 // org.graalvm.compiler.nodes.StructuredGraph graph
        end local 0 // org.graalvm.compiler.phases.common.ExpandLogicPhase this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   19     0     this  Lorg/graalvm/compiler/phases/common/ExpandLogicPhase;
            0   19     1    graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
            2    3     2    logic  Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;
            7   16     2    logic  Lorg/graalvm/compiler/nodes/calc/AbstractNormalizeCompareNode;
            9   12     6  context  Lorg/graalvm/compiler/debug/DebugCloseable;
      Exception table:
        from    to  target  type
           9    10      11  any
           8    13      13  any
    MethodParameters:
       Name  Flags
      graph  

  private static void processNormalizeCompareNode(org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode);
    descriptor: (Lorg/graalvm/compiler/nodes/calc/AbstractNormalizeCompareNode;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=9, locals=7, args_size=1
        start local 0 // org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode normalize
         0: .line 68
            aload 0 /* normalize */
            invokevirtual org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            astore 1 /* graph */
        start local 1 // org.graalvm.compiler.nodes.StructuredGraph graph
         1: .line 69
            aload 1 /* graph */
            aload 0 /* normalize */
            invokevirtual org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode.createEqualComparison:()Lorg/graalvm/compiler/nodes/LogicNode;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addOrUniqueWithInputs:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            astore 2 /* equalComp */
        start local 2 // org.graalvm.compiler.nodes.LogicNode equalComp
         2: .line 70
            aload 1 /* graph */
            aload 0 /* normalize */
            invokevirtual org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode.createLowerComparison:()Lorg/graalvm/compiler/nodes/LogicNode;
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.addOrUniqueWithInputs:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.LogicNode
            astore 3 /* lessComp */
        start local 3 // org.graalvm.compiler.nodes.LogicNode lessComp
         3: .line 71
            aload 0 /* normalize */
            getstatic org.graalvm.compiler.nodes.NodeView.DEFAULT:Lorg/graalvm/compiler/nodes/NodeView;
            invokevirtual org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode.stamp:(Lorg/graalvm/compiler/nodes/NodeView;)Lorg/graalvm/compiler/core/common/type/Stamp;
            astore 4 /* stamp */
        start local 4 // org.graalvm.compiler.core.common.type.Stamp stamp
         4: .line 72
            aload 1 /* graph */
            new org.graalvm.compiler.nodes.calc.ConditionalNode
            dup
            aload 2 /* equalComp */
            aload 4 /* stamp */
            lconst_0
            aload 1 /* graph */
            invokestatic org.graalvm.compiler.nodes.ConstantNode.forIntegerStamp:(Lorg/graalvm/compiler/core/common/type/Stamp;JLorg/graalvm/compiler/nodes/StructuredGraph;)Lorg/graalvm/compiler/nodes/ConstantNode;
            aload 4 /* stamp */
            lconst_1
            aload 1 /* graph */
            invokestatic org.graalvm.compiler.nodes.ConstantNode.forIntegerStamp:(Lorg/graalvm/compiler/core/common/type/Stamp;JLorg/graalvm/compiler/nodes/StructuredGraph;)Lorg/graalvm/compiler/nodes/ConstantNode;
            invokespecial org.graalvm.compiler.nodes.calc.ConditionalNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 5 /* equalValue */
        start local 5 // org.graalvm.compiler.nodes.calc.ConditionalNode equalValue
         5: .line 73
            aload 1 /* graph */
            new org.graalvm.compiler.nodes.calc.ConditionalNode
            dup
            aload 3 /* lessComp */
            aload 4 /* stamp */
            ldc -1
            aload 1 /* graph */
            invokestatic org.graalvm.compiler.nodes.ConstantNode.forIntegerStamp:(Lorg/graalvm/compiler/core/common/type/Stamp;JLorg/graalvm/compiler/nodes/StructuredGraph;)Lorg/graalvm/compiler/nodes/ConstantNode;
            aload 5 /* equalValue */
            invokespecial org.graalvm.compiler.nodes.calc.ConditionalNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.nodes.StructuredGraph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 6 /* value */
        start local 6 // org.graalvm.compiler.nodes.calc.ConditionalNode value
         6: .line 74
            aload 0 /* normalize */
            aload 6 /* value */
            invokevirtual org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode.replaceAtUsagesAndDelete:(Lorg/graalvm/compiler/graph/Node;)V
         7: .line 75
            return
        end local 6 // org.graalvm.compiler.nodes.calc.ConditionalNode value
        end local 5 // org.graalvm.compiler.nodes.calc.ConditionalNode equalValue
        end local 4 // org.graalvm.compiler.core.common.type.Stamp stamp
        end local 3 // org.graalvm.compiler.nodes.LogicNode lessComp
        end local 2 // org.graalvm.compiler.nodes.LogicNode equalComp
        end local 1 // org.graalvm.compiler.nodes.StructuredGraph graph
        end local 0 // org.graalvm.compiler.nodes.calc.AbstractNormalizeCompareNode normalize
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    8     0   normalize  Lorg/graalvm/compiler/nodes/calc/AbstractNormalizeCompareNode;
            1    8     1       graph  Lorg/graalvm/compiler/nodes/StructuredGraph;
            2    8     2   equalComp  Lorg/graalvm/compiler/nodes/LogicNode;
            3    8     3    lessComp  Lorg/graalvm/compiler/nodes/LogicNode;
            4    8     4       stamp  Lorg/graalvm/compiler/core/common/type/Stamp;
            5    8     5  equalValue  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
            6    8     6       value  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
    MethodParameters:
           Name  Flags
      normalize  

  private static void processBinary(org.graalvm.compiler.nodes.ShortCircuitOrNode);
    descriptor: (Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.nodes.ShortCircuitOrNode binary
         0: .line 79
            goto 20
         1: .line 80
      StackMap locals:
      StackMap stack:
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.first:()Lorg/graalvm/compiler/graph/Node;
            astore 1 /* usage */
        start local 1 // org.graalvm.compiler.graph.Node usage
         2: .line 81
            aconst_null
            astore 2
            aconst_null
            astore 3
         3: aload 1 /* usage */
            invokevirtual org.graalvm.compiler.graph.Node.withNodeSourcePosition:()Lorg/graalvm/compiler/debug/DebugCloseable;
            astore 4 /* nsp */
        start local 4 // org.graalvm.compiler.debug.DebugCloseable nsp
         4: .line 82
            aload 1 /* usage */
            instanceof org.graalvm.compiler.nodes.ShortCircuitOrNode
            ifeq 7
         5: .line 83
            aload 1 /* usage */
            checkcast org.graalvm.compiler.nodes.ShortCircuitOrNode
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.processBinary:(Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;)V
         6: .line 84
            goto 14
      StackMap locals: org.graalvm.compiler.nodes.ShortCircuitOrNode org.graalvm.compiler.graph.Node java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable
      StackMap stack:
         7: aload 1 /* usage */
            instanceof org.graalvm.compiler.nodes.IfNode
            ifeq 10
         8: .line 85
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.getX:()Lorg/graalvm/compiler/nodes/LogicNode;
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.isXNegated:()Z
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.getY:()Lorg/graalvm/compiler/nodes/LogicNode;
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.isYNegated:()Z
            aload 1 /* usage */
            checkcast org.graalvm.compiler.nodes.IfNode
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.getShortCircuitProbability:()D
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.processIf:(Lorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/IfNode;D)V
         9: .line 86
            goto 14
      StackMap locals:
      StackMap stack:
        10: aload 1 /* usage */
            instanceof org.graalvm.compiler.nodes.calc.ConditionalNode
            ifeq 13
        11: .line 87
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.getX:()Lorg/graalvm/compiler/nodes/LogicNode;
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.isXNegated:()Z
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.getY:()Lorg/graalvm/compiler/nodes/LogicNode;
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.isYNegated:()Z
            aload 1 /* usage */
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.processConditional:(Lorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/calc/ConditionalNode;)V
        12: .line 88
            goto 14
        13: .line 89
      StackMap locals:
      StackMap stack:
            invokestatic org.graalvm.compiler.debug.GraalError.shouldNotReachHere:()Ljava/lang/RuntimeException;
            athrow
        14: .line 91
      StackMap locals:
      StackMap stack:
            aload 4 /* nsp */
            ifnull 20
            aload 4 /* nsp */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
            goto 20
      StackMap locals:
      StackMap stack: java.lang.Throwable
        15: astore 2
            aload 4 /* nsp */
            ifnull 16
            aload 4 /* nsp */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
        end local 4 // org.graalvm.compiler.debug.DebugCloseable nsp
      StackMap locals:
      StackMap stack:
        16: aload 2
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        17: astore 3
            aload 2
            ifnonnull 18
            aload 3
            astore 2
            goto 19
      StackMap locals:
      StackMap stack:
        18: aload 2
            aload 3
            if_acmpeq 19
            aload 2
            aload 3
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        19: aload 2
            athrow
        end local 1 // org.graalvm.compiler.graph.Node usage
        20: .line 79
      StackMap locals:
      StackMap stack:
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.usages:()Lorg/graalvm/compiler/graph/iterators/NodeIterable;
            invokeinterface org.graalvm.compiler.graph.iterators.NodeIterable.isNotEmpty:()Z
            ifne 1
        21: .line 93
            aload 0 /* binary */
            invokevirtual org.graalvm.compiler.nodes.ShortCircuitOrNode.safeDelete:()V
        22: .line 94
            return
        end local 0 // org.graalvm.compiler.nodes.ShortCircuitOrNode binary
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   23     0  binary  Lorg/graalvm/compiler/nodes/ShortCircuitOrNode;
            2   20     1   usage  Lorg/graalvm/compiler/graph/Node;
            4   16     4     nsp  Lorg/graalvm/compiler/debug/DebugCloseable;
      Exception table:
        from    to  target  type
           4    14      15  any
           3    17      17  any
    MethodParameters:
        Name  Flags
      binary  

  private static void processIf(org.graalvm.compiler.nodes.LogicNode, boolean, org.graalvm.compiler.nodes.LogicNode, boolean, org.graalvm.compiler.nodes.IfNode, double);
    descriptor: (Lorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/IfNode;D)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=24, args_size=6
        start local 0 // org.graalvm.compiler.nodes.LogicNode x
        start local 1 // boolean xNegated
        start local 2 // org.graalvm.compiler.nodes.LogicNode y
        start local 3 // boolean yNegated
        start local 4 // org.graalvm.compiler.nodes.IfNode ifNode
        start local 5 // double shortCircuitProbability
         0: .line 106
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.trueSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 7 /* trueTarget */
        start local 7 // org.graalvm.compiler.nodes.AbstractBeginNode trueTarget
         1: .line 107
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.falseSuccessor:()Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 8 /* falseTarget */
        start local 8 // org.graalvm.compiler.nodes.AbstractBeginNode falseTarget
         2: .line 111
            dload 5 /* shortCircuitProbability */
            dstore 9 /* firstIfTrueProbability */
        start local 9 // double firstIfTrueProbability
         3: .line 112
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getTrueSuccessorProbability:()D
            dload 5 /* shortCircuitProbability */
            dsub
            dconst_1
            dload 5 /* shortCircuitProbability */
            dsub
            ddiv
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.sanitizeProbability:(D)D
            dstore 11 /* secondIfTrueProbability */
        start local 11 // double secondIfTrueProbability
         4: .line 113
            dload 9 /* firstIfTrueProbability */
            dconst_1
            dload 9 /* firstIfTrueProbability */
            dsub
            dload 11 /* secondIfTrueProbability */
            dmul
            dadd
            dstore 13 /* expectedOriginalIfTrueProbability */
        start local 13 // double expectedOriginalIfTrueProbability
         5: .line 115
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getTrueSuccessorProbability:()D
            dload 13 /* expectedOriginalIfTrueProbability */
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.doubleEquals:(DD)Z
            ifne 8
         6: .line 126
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getTrueSuccessorProbability:()D
            dload 5 /* shortCircuitProbability */
            dmul
            dstore 9 /* firstIfTrueProbability */
         7: .line 127
            dconst_1
            aload 4 /* ifNode */
            aload 8 /* falseTarget */
            invokevirtual org.graalvm.compiler.nodes.IfNode.probability:(Lorg/graalvm/compiler/nodes/AbstractBeginNode;)D
            dconst_1
            dload 9 /* firstIfTrueProbability */
            dsub
            ddiv
            dsub
            invokestatic org.graalvm.compiler.phases.common.ExpandLogicPhase.sanitizeProbability:(D)D
            dstore 11 /* secondIfTrueProbability */
         8: .line 130
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double
      StackMap stack:
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.clearSuccessors:()V
         9: .line 131
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            astore 15 /* graph */
        start local 15 // org.graalvm.compiler.graph.Graph graph
        10: .line 132
            aload 15 /* graph */
            new org.graalvm.compiler.nodes.MergeNode
            dup
            invokespecial org.graalvm.compiler.nodes.MergeNode.<init>:()V
            invokevirtual org.graalvm.compiler.graph.Graph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.AbstractMergeNode
            astore 16 /* trueTargetMerge */
        start local 16 // org.graalvm.compiler.nodes.AbstractMergeNode trueTargetMerge
        11: .line 133
            aload 16 /* trueTargetMerge */
            aload 7 /* trueTarget */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.setNext:(Lorg/graalvm/compiler/nodes/FixedNode;)V
        12: .line 134
            aload 15 /* graph */
            new org.graalvm.compiler.nodes.EndNode
            dup
            invokespecial org.graalvm.compiler.nodes.EndNode.<init>:()V
            invokevirtual org.graalvm.compiler.graph.Graph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 17 /* firstTrueEnd */
        start local 17 // org.graalvm.compiler.nodes.EndNode firstTrueEnd
        13: .line 135
            aload 15 /* graph */
            new org.graalvm.compiler.nodes.EndNode
            dup
            invokespecial org.graalvm.compiler.nodes.EndNode.<init>:()V
            invokevirtual org.graalvm.compiler.graph.Graph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.EndNode
            astore 18 /* secondTrueEnd */
        start local 18 // org.graalvm.compiler.nodes.EndNode secondTrueEnd
        14: .line 136
            aload 16 /* trueTargetMerge */
            aload 17 /* firstTrueEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        15: .line 137
            aload 16 /* trueTargetMerge */
            aload 18 /* secondTrueEnd */
            invokevirtual org.graalvm.compiler.nodes.AbstractMergeNode.addForwardEnd:(Lorg/graalvm/compiler/nodes/EndNode;)V
        16: .line 138
            aload 17 /* firstTrueEnd */
            invokestatic org.graalvm.compiler.nodes.BeginNode.begin:(Lorg/graalvm/compiler/nodes/FixedNode;)Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 19 /* firstTrueTarget */
        start local 19 // org.graalvm.compiler.nodes.AbstractBeginNode firstTrueTarget
        17: .line 139
            aload 19 /* firstTrueTarget */
            aload 7 /* trueTarget */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        18: .line 140
            aload 18 /* secondTrueEnd */
            invokestatic org.graalvm.compiler.nodes.BeginNode.begin:(Lorg/graalvm/compiler/nodes/FixedNode;)Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 20 /* secondTrueTarget */
        start local 20 // org.graalvm.compiler.nodes.AbstractBeginNode secondTrueTarget
        19: .line 141
            aload 20 /* secondTrueTarget */
            aload 7 /* trueTarget */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        20: .line 142
            iload 3 /* yNegated */
            ifeq 22
        21: .line 143
            dconst_1
            dload 11 /* secondIfTrueProbability */
            dsub
            dstore 11 /* secondIfTrueProbability */
        22: .line 145
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack:
            iload 1 /* xNegated */
            ifeq 24
        23: .line 146
            dconst_1
            dload 9 /* firstIfTrueProbability */
            dsub
            dstore 9 /* firstIfTrueProbability */
        24: .line 148
      StackMap locals:
      StackMap stack:
            new org.graalvm.compiler.nodes.IfNode
            dup
            aload 2 /* y */
            iload 3 /* yNegated */
            ifeq 25
            aload 8 /* falseTarget */
            goto 26
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: new 24 new 24 org.graalvm.compiler.nodes.LogicNode
        25: aload 20 /* secondTrueTarget */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: new 24 new 24 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.AbstractBeginNode
        26: iload 3 /* yNegated */
            ifeq 27
            aload 20 /* secondTrueTarget */
            goto 28
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: new 24 new 24 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.AbstractBeginNode
        27: aload 8 /* falseTarget */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: new 24 new 24 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode
        28: dload 11 /* secondIfTrueProbability */
            invokespecial org.graalvm.compiler.nodes.IfNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;D)V
            astore 21 /* secondIf */
        start local 21 // org.graalvm.compiler.nodes.IfNode secondIf
        29: .line 149
            aload 21 /* secondIf */
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.IfNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        30: .line 150
            aload 15 /* graph */
            aload 21 /* secondIf */
            invokevirtual org.graalvm.compiler.graph.Graph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.FixedNode
            invokestatic org.graalvm.compiler.nodes.BeginNode.begin:(Lorg/graalvm/compiler/nodes/FixedNode;)Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            astore 22 /* secondIfBegin */
        start local 22 // org.graalvm.compiler.nodes.AbstractBeginNode secondIfBegin
        31: .line 151
            aload 22 /* secondIfBegin */
            aload 8 /* falseTarget */
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.AbstractBeginNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        32: .line 152
            aload 15 /* graph */
        33: new org.graalvm.compiler.nodes.IfNode
            dup
            aload 0 /* x */
            iload 1 /* xNegated */
            ifeq 34
            aload 22 /* secondIfBegin */
            goto 35
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 33 new 33 org.graalvm.compiler.nodes.LogicNode
        34: aload 19 /* firstTrueTarget */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 33 new 33 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.AbstractBeginNode
        35: iload 1 /* xNegated */
            ifeq 36
            aload 19 /* firstTrueTarget */
            goto 37
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 33 new 33 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.AbstractBeginNode
        36: aload 22 /* secondIfBegin */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.IfNode double org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode double double double org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.AbstractMergeNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.EndNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.IfNode org.graalvm.compiler.nodes.AbstractBeginNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 33 new 33 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.AbstractBeginNode org.graalvm.compiler.nodes.AbstractBeginNode
        37: dload 9 /* firstIfTrueProbability */
            invokespecial org.graalvm.compiler.nodes.IfNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;Lorg/graalvm/compiler/nodes/AbstractBeginNode;D)V
            invokevirtual org.graalvm.compiler.graph.Graph.add:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.IfNode
            astore 23 /* firstIf */
        start local 23 // org.graalvm.compiler.nodes.IfNode firstIf
        38: .line 153
            aload 23 /* firstIf */
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.getNodeSourcePosition:()Lorg/graalvm/compiler/graph/NodeSourcePosition;
            invokevirtual org.graalvm.compiler.nodes.IfNode.setNodeSourcePosition:(Lorg/graalvm/compiler/graph/NodeSourcePosition;)V
        39: .line 154
            aload 4 /* ifNode */
            aload 23 /* firstIf */
            invokevirtual org.graalvm.compiler.nodes.IfNode.replaceAtPredecessor:(Lorg/graalvm/compiler/graph/Node;)V
        40: .line 155
            aload 4 /* ifNode */
            invokevirtual org.graalvm.compiler.nodes.IfNode.safeDelete:()V
        41: .line 156
            return
        end local 23 // org.graalvm.compiler.nodes.IfNode firstIf
        end local 22 // org.graalvm.compiler.nodes.AbstractBeginNode secondIfBegin
        end local 21 // org.graalvm.compiler.nodes.IfNode secondIf
        end local 20 // org.graalvm.compiler.nodes.AbstractBeginNode secondTrueTarget
        end local 19 // org.graalvm.compiler.nodes.AbstractBeginNode firstTrueTarget
        end local 18 // org.graalvm.compiler.nodes.EndNode secondTrueEnd
        end local 17 // org.graalvm.compiler.nodes.EndNode firstTrueEnd
        end local 16 // org.graalvm.compiler.nodes.AbstractMergeNode trueTargetMerge
        end local 15 // org.graalvm.compiler.graph.Graph graph
        end local 13 // double expectedOriginalIfTrueProbability
        end local 11 // double secondIfTrueProbability
        end local 9 // double firstIfTrueProbability
        end local 8 // org.graalvm.compiler.nodes.AbstractBeginNode falseTarget
        end local 7 // org.graalvm.compiler.nodes.AbstractBeginNode trueTarget
        end local 5 // double shortCircuitProbability
        end local 4 // org.graalvm.compiler.nodes.IfNode ifNode
        end local 3 // boolean yNegated
        end local 2 // org.graalvm.compiler.nodes.LogicNode y
        end local 1 // boolean xNegated
        end local 0 // org.graalvm.compiler.nodes.LogicNode x
      LocalVariableTable:
        Start  End  Slot                               Name  Signature
            0   42     0                                  x  Lorg/graalvm/compiler/nodes/LogicNode;
            0   42     1                           xNegated  Z
            0   42     2                                  y  Lorg/graalvm/compiler/nodes/LogicNode;
            0   42     3                           yNegated  Z
            0   42     4                             ifNode  Lorg/graalvm/compiler/nodes/IfNode;
            0   42     5            shortCircuitProbability  D
            1   42     7                         trueTarget  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            2   42     8                        falseTarget  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
            3   42     9             firstIfTrueProbability  D
            4   42    11            secondIfTrueProbability  D
            5   42    13  expectedOriginalIfTrueProbability  D
           10   42    15                              graph  Lorg/graalvm/compiler/graph/Graph;
           11   42    16                    trueTargetMerge  Lorg/graalvm/compiler/nodes/AbstractMergeNode;
           13   42    17                       firstTrueEnd  Lorg/graalvm/compiler/nodes/EndNode;
           14   42    18                      secondTrueEnd  Lorg/graalvm/compiler/nodes/EndNode;
           17   42    19                    firstTrueTarget  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           19   42    20                   secondTrueTarget  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           29   42    21                           secondIf  Lorg/graalvm/compiler/nodes/IfNode;
           31   42    22                      secondIfBegin  Lorg/graalvm/compiler/nodes/AbstractBeginNode;
           38   42    23                            firstIf  Lorg/graalvm/compiler/nodes/IfNode;
    MethodParameters:
                         Name  Flags
      x                        
      xNegated                 
      y                        
      yNegated                 
      ifNode                   
      shortCircuitProbability  

  private static boolean doubleEquals(double, double);
    descriptor: (DD)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // double a
        start local 2 // double b
         0: .line 159
            getstatic org.graalvm.compiler.phases.common.ExpandLogicPhase.$assertionsDisabled:Z
            ifne 2
            dload 0 /* a */
            invokestatic java.lang.Double.isNaN:(D)Z
            ifne 1
            dload 2 /* b */
            invokestatic java.lang.Double.isNaN:(D)Z
            ifne 1
            dload 0 /* a */
            invokestatic java.lang.Double.isInfinite:(D)Z
            ifne 1
            dload 2 /* b */
            invokestatic java.lang.Double.isInfinite:(D)Z
            ifeq 2
      StackMap locals:
      StackMap stack:
         1: new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         2: .line 160
      StackMap locals:
      StackMap stack:
            dload 0 /* a */
            ldc 1.0E-6
            dsub
            dload 2 /* b */
            dcmpg
            ifge 3
            dload 0 /* a */
            ldc 1.0E-6
            dadd
            dload 2 /* b */
            dcmpl
            ifle 3
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         3: iconst_0
            ireturn
        end local 2 // double b
        end local 0 // double a
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0     a  D
            0    4     2     b  D
    MethodParameters:
      Name  Flags
      a     
      b     

  private static double sanitizeProbability(double);
    descriptor: (D)D
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=4, args_size=1
        start local 0 // double value
         0: .line 164
            dconst_1
            dconst_0
            dload 0 /* value */
            invokestatic java.lang.Math.max:(DD)D
            invokestatic java.lang.Math.min:(DD)D
            dstore 2 /* newValue */
        start local 2 // double newValue
         1: .line 165
            dload 2 /* newValue */
            invokestatic java.lang.Double.isNaN:(D)Z
            ifeq 3
         2: .line 166
            ldc 0.5
            dstore 2 /* newValue */
         3: .line 168
      StackMap locals: double
      StackMap stack:
            dload 2 /* newValue */
            dreturn
        end local 2 // double newValue
        end local 0 // double value
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0     value  D
            1    4     2  newValue  D
    MethodParameters:
       Name  Flags
      value  

  private static void processConditional(org.graalvm.compiler.nodes.LogicNode, boolean, org.graalvm.compiler.nodes.LogicNode, boolean, org.graalvm.compiler.nodes.calc.ConditionalNode);
    descriptor: (Lorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/LogicNode;ZLorg/graalvm/compiler/nodes/calc/ConditionalNode;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=13, args_size=5
        start local 0 // org.graalvm.compiler.nodes.LogicNode x
        start local 1 // boolean xNegated
        start local 2 // org.graalvm.compiler.nodes.LogicNode y
        start local 3 // boolean yNegated
        start local 4 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
         0: .line 173
            aconst_null
            astore 5
            aconst_null
            astore 6
         1: aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.withNodeSourcePosition:()Lorg/graalvm/compiler/debug/DebugCloseable;
            astore 7 /* context */
        start local 7 // org.graalvm.compiler.debug.DebugCloseable context
         2: .line 174
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.trueValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 8 /* trueTarget */
        start local 8 // org.graalvm.compiler.nodes.ValueNode trueTarget
         3: .line 175
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.falseValue:()Lorg/graalvm/compiler/nodes/ValueNode;
            astore 9 /* falseTarget */
        start local 9 // org.graalvm.compiler.nodes.ValueNode falseTarget
         4: .line 176
            aload 4 /* conditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.graph:()Lorg/graalvm/compiler/nodes/StructuredGraph;
            astore 10 /* graph */
        start local 10 // org.graalvm.compiler.graph.Graph graph
         5: .line 177
            aload 10 /* graph */
         6: new org.graalvm.compiler.nodes.calc.ConditionalNode
            dup
            aload 2 /* y */
            iload 3 /* yNegated */
            ifeq 7
            aload 9 /* falseTarget */
            goto 8
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph
      StackMap stack: org.graalvm.compiler.graph.Graph new 6 new 6 org.graalvm.compiler.nodes.LogicNode
         7: aload 8 /* trueTarget */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph
      StackMap stack: org.graalvm.compiler.graph.Graph new 6 new 6 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.ValueNode
         8: iload 3 /* yNegated */
            ifeq 9
            aload 8 /* trueTarget */
            goto 10
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph
      StackMap stack: org.graalvm.compiler.graph.Graph new 6 new 6 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.ValueNode
         9: aload 9 /* falseTarget */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph
      StackMap stack: org.graalvm.compiler.graph.Graph new 6 new 6 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode
        10: invokespecial org.graalvm.compiler.nodes.calc.ConditionalNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.graph.Graph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 11 /* secondConditional */
        start local 11 // org.graalvm.compiler.nodes.calc.ConditionalNode secondConditional
        11: .line 178
            aload 10 /* graph */
        12: new org.graalvm.compiler.nodes.calc.ConditionalNode
            dup
            aload 0 /* x */
            iload 1 /* xNegated */
            ifeq 13
            aload 11 /* secondConditional */
            goto 14
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.calc.ConditionalNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 12 new 12 org.graalvm.compiler.nodes.LogicNode
        13: aload 8 /* trueTarget */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.calc.ConditionalNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 12 new 12 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.ValueNode
        14: iload 1 /* xNegated */
            ifeq 15
            aload 8 /* trueTarget */
            goto 16
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.calc.ConditionalNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 12 new 12 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.ValueNode
        15: aload 11 /* secondConditional */
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.graph.Graph org.graalvm.compiler.nodes.calc.ConditionalNode
      StackMap stack: org.graalvm.compiler.graph.Graph new 12 new 12 org.graalvm.compiler.nodes.LogicNode org.graalvm.compiler.nodes.ValueNode org.graalvm.compiler.nodes.ValueNode
        16: invokespecial org.graalvm.compiler.nodes.calc.ConditionalNode.<init>:(Lorg/graalvm/compiler/nodes/LogicNode;Lorg/graalvm/compiler/nodes/ValueNode;Lorg/graalvm/compiler/nodes/ValueNode;)V
            invokevirtual org.graalvm.compiler.graph.Graph.unique:(Lorg/graalvm/compiler/graph/Node;)Lorg/graalvm/compiler/graph/Node;
            checkcast org.graalvm.compiler.nodes.calc.ConditionalNode
            astore 12 /* firstConditional */
        start local 12 // org.graalvm.compiler.nodes.calc.ConditionalNode firstConditional
        17: .line 179
            aload 4 /* conditional */
            aload 12 /* firstConditional */
            invokevirtual org.graalvm.compiler.nodes.calc.ConditionalNode.replaceAndDelete:(Lorg/graalvm/compiler/graph/Node;)V
        end local 12 // org.graalvm.compiler.nodes.calc.ConditionalNode firstConditional
        end local 11 // org.graalvm.compiler.nodes.calc.ConditionalNode secondConditional
        end local 10 // org.graalvm.compiler.graph.Graph graph
        end local 9 // org.graalvm.compiler.nodes.ValueNode falseTarget
        end local 8 // org.graalvm.compiler.nodes.ValueNode trueTarget
        18: .line 180
            aload 7 /* context */
            ifnull 24
            aload 7 /* context */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
            goto 24
      StackMap locals: org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.LogicNode int org.graalvm.compiler.nodes.calc.ConditionalNode java.lang.Throwable java.lang.Throwable org.graalvm.compiler.debug.DebugCloseable
      StackMap stack: java.lang.Throwable
        19: astore 5
            aload 7 /* context */
            ifnull 20
            aload 7 /* context */
            invokeinterface org.graalvm.compiler.debug.DebugCloseable.close:()V
        end local 7 // org.graalvm.compiler.debug.DebugCloseable context
      StackMap locals:
      StackMap stack:
        20: aload 5
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        21: astore 6
            aload 5
            ifnonnull 22
            aload 6
            astore 5
            goto 23
      StackMap locals:
      StackMap stack:
        22: aload 5
            aload 6
            if_acmpeq 23
            aload 5
            aload 6
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        23: aload 5
            athrow
        24: .line 181
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.graalvm.compiler.nodes.calc.ConditionalNode conditional
        end local 3 // boolean yNegated
        end local 2 // org.graalvm.compiler.nodes.LogicNode y
        end local 1 // boolean xNegated
        end local 0 // org.graalvm.compiler.nodes.LogicNode x
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   25     0                  x  Lorg/graalvm/compiler/nodes/LogicNode;
            0   25     1           xNegated  Z
            0   25     2                  y  Lorg/graalvm/compiler/nodes/LogicNode;
            0   25     3           yNegated  Z
            0   25     4        conditional  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
            2   20     7            context  Lorg/graalvm/compiler/debug/DebugCloseable;
            3   18     8         trueTarget  Lorg/graalvm/compiler/nodes/ValueNode;
            4   18     9        falseTarget  Lorg/graalvm/compiler/nodes/ValueNode;
            5   18    10              graph  Lorg/graalvm/compiler/graph/Graph;
           11   18    11  secondConditional  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
           17   18    12   firstConditional  Lorg/graalvm/compiler/nodes/calc/ConditionalNode;
      Exception table:
        from    to  target  type
           2    18      19  any
           1    21      21  any
    MethodParameters:
             Name  Flags
      x            
      xNegated     
      y            
      yNegated     
      conditional  

  public boolean checkContract();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.phases.common.ExpandLogicPhase this
         0: .line 185
            iconst_0
            ireturn
        end local 0 // org.graalvm.compiler.phases.common.ExpandLogicPhase this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/phases/common/ExpandLogicPhase;
}
SourceFile: "ExpandLogicPhase.java"
InnerClasses:
  public abstract ValueNumberable = org.graalvm.compiler.graph.Node$ValueNumberable of org.graalvm.compiler.graph.Node