public class org.apache.commons.math3.geometry.enclosing.WelzlEncloser<S extends org.apache.commons.math3.geometry.Space, P extends org.apache.commons.math3.geometry.Point<S>> implements org.apache.commons.math3.geometry.enclosing.Encloser<S, P>
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.apache.commons.math3.geometry.enclosing.WelzlEncloser
super_class: java.lang.Object
{
private final double tolerance;
descriptor: D
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final org.apache.commons.math3.geometry.enclosing.SupportBallGenerator<S, P> generator;
descriptor: Lorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator<TS;TP;>;
public void <init>(double, org.apache.commons.math3.geometry.enclosing.SupportBallGenerator<S, P>);
descriptor: (DLorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=4, args_size=3
start local 0 start local 1 start local 3 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
dload 1
putfield org.apache.commons.math3.geometry.enclosing.WelzlEncloser.tolerance:D
2: aload 0
aload 3
putfield org.apache.commons.math3.geometry.enclosing.WelzlEncloser.generator:Lorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator;
3: return
end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/apache/commons/math3/geometry/enclosing/WelzlEncloser<TS;TP;>;
0 4 1 tolerance D
0 4 3 generator Lorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator<TS;TP;>;
Signature: (DLorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator<TS;TP;>;)V
MethodParameters:
Name Flags
tolerance final
generator final
public org.apache.commons.math3.geometry.enclosing.EnclosingBall<S, P> enclose(java.lang.Iterable<P>);
descriptor: (Ljava/lang/Iterable;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 1
ifnull 1
aload 1
invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
1: StackMap locals:
StackMap stack:
aload 0
getfield org.apache.commons.math3.geometry.enclosing.WelzlEncloser.generator:Lorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator;
new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
invokeinterface org.apache.commons.math3.geometry.enclosing.SupportBallGenerator.ballOnSupport:(Ljava/util/List;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
areturn
2: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual org.apache.commons.math3.geometry.enclosing.WelzlEncloser.pivotingBall:(Ljava/lang/Iterable;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/apache/commons/math3/geometry/enclosing/WelzlEncloser<TS;TP;>;
0 3 1 points Ljava/lang/Iterable<TP;>;
Signature: (Ljava/lang/Iterable<TP;>;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;
MethodParameters:
Name Flags
points final
private org.apache.commons.math3.geometry.enclosing.EnclosingBall<S, P> pivotingBall(java.lang.Iterable<P>);
descriptor: (Ljava/lang/Iterable;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=8, args_size=2
start local 0 start local 1 0: aload 1
invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.commons.math3.geometry.Point
astore 2
start local 2 1: new java.util.ArrayList
dup
aload 2
invokeinterface org.apache.commons.math3.geometry.Point.getSpace:()Lorg/apache/commons/math3/geometry/Space;
invokeinterface org.apache.commons.math3.geometry.Space.getDimension:()I
iconst_1
iadd
invokespecial java.util.ArrayList.<init>:(I)V
astore 3
start local 3 2: new java.util.ArrayList
dup
aload 2
invokeinterface org.apache.commons.math3.geometry.Point.getSpace:()Lorg/apache/commons/math3/geometry/Space;
invokeinterface org.apache.commons.math3.geometry.Space.getDimension:()I
iconst_1
iadd
invokespecial java.util.ArrayList.<init>:(I)V
astore 4
start local 4 3: aload 3
aload 2
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
4: aload 0
aload 3
aload 3
invokeinterface java.util.List.size:()I
aload 4
invokevirtual org.apache.commons.math3.geometry.enclosing.WelzlEncloser.moveToFrontBall:(Ljava/util/List;ILjava/util/List;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
astore 5
start local 5 5: StackMap locals: org.apache.commons.math3.geometry.enclosing.WelzlEncloser java.lang.Iterable org.apache.commons.math3.geometry.Point java.util.List java.util.List org.apache.commons.math3.geometry.enclosing.EnclosingBall
StackMap stack:
aload 0
aload 1
aload 5
invokevirtual org.apache.commons.math3.geometry.enclosing.WelzlEncloser.selectFarthest:(Ljava/lang/Iterable;Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;)Lorg/apache/commons/math3/geometry/Point;
astore 6
start local 6 6: aload 5
aload 6
aload 0
getfield org.apache.commons.math3.geometry.enclosing.WelzlEncloser.tolerance:D
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.contains:(Lorg/apache/commons/math3/geometry/Point;D)Z
ifeq 8
7: aload 5
areturn
8: StackMap locals: org.apache.commons.math3.geometry.Point
StackMap stack:
aload 4
invokeinterface java.util.List.clear:()V
9: aload 4
aload 6
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
10: aload 5
astore 7
start local 7 11: aload 0
aload 3
aload 3
invokeinterface java.util.List.size:()I
aload 4
invokevirtual org.apache.commons.math3.geometry.enclosing.WelzlEncloser.moveToFrontBall:(Ljava/util/List;ILjava/util/List;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
astore 5
12: aload 5
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.getRadius:()D
aload 7
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.getRadius:()D
dcmpg
ifge 14
13: new org.apache.commons.math3.exception.MathInternalError
dup
invokespecial org.apache.commons.math3.exception.MathInternalError.<init>:()V
athrow
14: StackMap locals: org.apache.commons.math3.geometry.enclosing.EnclosingBall
StackMap stack:
aload 3
iconst_0
aload 6
invokeinterface java.util.List.add:(ILjava/lang/Object;)V
15: aload 3
aload 5
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.getSupportSize:()I
aload 3
invokeinterface java.util.List.size:()I
invokeinterface java.util.List.subList:(II)Ljava/util/List;
invokeinterface java.util.List.clear:()V
end local 7 end local 6 16: goto 5
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Lorg/apache/commons/math3/geometry/enclosing/WelzlEncloser<TS;TP;>;
0 17 1 points Ljava/lang/Iterable<TP;>;
1 17 2 first TP;
2 17 3 extreme Ljava/util/List<TP;>;
3 17 4 support Ljava/util/List<TP;>;
5 17 5 ball Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;
6 16 6 farthest TP;
11 16 7 savedBall Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;
Signature: (Ljava/lang/Iterable<TP;>;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;
MethodParameters:
Name Flags
points final
private org.apache.commons.math3.geometry.enclosing.EnclosingBall<S, P> moveToFrontBall(java.util.List<P>, int, java.util.List<P>);
descriptor: (Ljava/util/List;ILjava/util/List;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=8, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield org.apache.commons.math3.geometry.enclosing.WelzlEncloser.generator:Lorg/apache/commons/math3/geometry/enclosing/SupportBallGenerator;
aload 3
invokeinterface org.apache.commons.math3.geometry.enclosing.SupportBallGenerator.ballOnSupport:(Ljava/util/List;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
astore 4
start local 4 1: aload 4
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.getSupportSize:()I
aload 4
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.getCenter:()Lorg/apache/commons/math3/geometry/Point;
invokeinterface org.apache.commons.math3.geometry.Point.getSpace:()Lorg/apache/commons/math3/geometry/Space;
invokeinterface org.apache.commons.math3.geometry.Space.getDimension:()I
if_icmpgt 17
2: iconst_0
istore 5
start local 5 3: goto 16
4: StackMap locals: org.apache.commons.math3.geometry.enclosing.EnclosingBall int
StackMap stack:
aload 1
iload 5
invokeinterface java.util.List.get:(I)Ljava/lang/Object;
checkcast org.apache.commons.math3.geometry.Point
astore 6
start local 6 5: aload 4
aload 6
aload 0
getfield org.apache.commons.math3.geometry.enclosing.WelzlEncloser.tolerance:D
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.contains:(Lorg/apache/commons/math3/geometry/Point;D)Z
ifne 15
6: aload 3
aload 6
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
7: aload 0
aload 1
iload 5
aload 3
invokevirtual org.apache.commons.math3.geometry.enclosing.WelzlEncloser.moveToFrontBall:(Ljava/util/List;ILjava/util/List;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;
astore 4
8: aload 3
aload 3
invokeinterface java.util.List.size:()I
iconst_1
isub
invokeinterface java.util.List.remove:(I)Ljava/lang/Object;
pop
9: iload 5
istore 7
start local 7 10: goto 13
11: StackMap locals: org.apache.commons.math3.geometry.Point int
StackMap stack:
aload 1
iload 7
aload 1
iload 7
iconst_1
isub
invokeinterface java.util.List.get:(I)Ljava/lang/Object;
checkcast org.apache.commons.math3.geometry.Point
invokeinterface java.util.List.set:(ILjava/lang/Object;)Ljava/lang/Object;
pop
12: iinc 7 -1
StackMap locals:
StackMap stack:
13: iload 7
ifgt 11
end local 7 14: aload 1
iconst_0
aload 6
invokeinterface java.util.List.set:(ILjava/lang/Object;)Ljava/lang/Object;
pop
end local 6 15: StackMap locals:
StackMap stack:
iinc 5 1
StackMap locals:
StackMap stack:
16: iload 5
iload 2
if_icmplt 4
end local 5 17: StackMap locals:
StackMap stack:
aload 4
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lorg/apache/commons/math3/geometry/enclosing/WelzlEncloser<TS;TP;>;
0 18 1 extreme Ljava/util/List<TP;>;
0 18 2 nbExtreme I
0 18 3 support Ljava/util/List<TP;>;
1 18 4 ball Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;
3 17 5 i I
5 15 6 pi TP;
10 14 7 j I
Signature: (Ljava/util/List<TP;>;ILjava/util/List<TP;>;)Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;
MethodParameters:
Name Flags
extreme final
nbExtreme final
support final
public P selectFarthest(java.lang.Iterable<P>, org.apache.commons.math3.geometry.enclosing.EnclosingBall<S, P>);
descriptor: (Ljava/lang/Iterable;Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall;)Lorg/apache/commons/math3/geometry/Point;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=11, args_size=3
start local 0 start local 1 start local 2 0: aload 2
invokevirtual org.apache.commons.math3.geometry.enclosing.EnclosingBall.getCenter:()Lorg/apache/commons/math3/geometry/Point;
astore 3
start local 3 1: aconst_null
astore 4
start local 4 2: ldc -1.0
dstore 5
start local 5 3: aload 1
invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
astore 8
goto 9
StackMap locals: org.apache.commons.math3.geometry.enclosing.WelzlEncloser java.lang.Iterable org.apache.commons.math3.geometry.enclosing.EnclosingBall org.apache.commons.math3.geometry.Point org.apache.commons.math3.geometry.Point double top java.util.Iterator
StackMap stack:
4: aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.apache.commons.math3.geometry.Point
astore 7
start local 7 5: aload 7
aload 3
invokeinterface org.apache.commons.math3.geometry.Point.distance:(Lorg/apache/commons/math3/geometry/Point;)D
dstore 9
start local 9 6: dload 9
dload 5
dcmpl
ifle 9
7: aload 7
astore 4
8: dload 9
dstore 5
end local 9 end local 7 9: StackMap locals:
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
10: aload 4
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lorg/apache/commons/math3/geometry/enclosing/WelzlEncloser<TS;TP;>;
0 11 1 points Ljava/lang/Iterable<TP;>;
0 11 2 ball Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;
1 11 3 center TP;
2 11 4 farthest TP;
3 11 5 dMax D
5 9 7 point TP;
6 9 9 d D
Signature: (Ljava/lang/Iterable<TP;>;Lorg/apache/commons/math3/geometry/enclosing/EnclosingBall<TS;TP;>;)TP;
MethodParameters:
Name Flags
points final
ball final
}
Signature: <S::Lorg/apache/commons/math3/geometry/Space;P::Lorg/apache/commons/math3/geometry/Point<TS;>;>Ljava/lang/Object;Lorg/apache/commons/math3/geometry/enclosing/Encloser<TS;TP;>;
SourceFile: "WelzlEncloser.java"