1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 package org.hipparchus.geometry.spherical.oned;
23
24 import org.hipparchus.geometry.partitioning.AbstractSubHyperplane;
25 import org.hipparchus.geometry.partitioning.Region;
26
27
28
29 public class SubLimitAngle
30 extends AbstractSubHyperplane<Sphere1D, S1Point, LimitAngle, SubLimitAngle, Sphere1D, S1Point, LimitAngle, SubLimitAngle> {
31
32
33
34
35
36 public SubLimitAngle(final LimitAngle hyperplane, final Region<Sphere1D, S1Point, LimitAngle, SubLimitAngle> remainingRegion) {
37 super(hyperplane, remainingRegion);
38 }
39
40
41 @Override
42 public double getSize() {
43 return 0;
44 }
45
46
47 @Override
48 public boolean isEmpty() {
49 return false;
50 }
51
52
53 @Override
54 protected SubLimitAngle buildNew(final LimitAngle hyperplane, final Region<Sphere1D, S1Point, LimitAngle, SubLimitAngle> remainingRegion) {
55 return new SubLimitAngle(hyperplane, remainingRegion);
56 }
57
58
59 @Override
60 public S1Point getInteriorPoint() {
61 return getHyperplane().getLocation();
62 }
63
64
65 @Override
66 public SplitSubHyperplane<Sphere1D, S1Point, LimitAngle, SubLimitAngle> split(final LimitAngle hyperplane) {
67 final double global = hyperplane.getOffset(getHyperplane().getLocation());
68 if (global < -hyperplane.getTolerance()) {
69 return new SplitSubHyperplane<>(null, this);
70 } else if (global > hyperplane.getTolerance()) {
71 return new SplitSubHyperplane<>(this, null);
72 } else {
73 return new SplitSubHyperplane<>(null, null);
74 }
75 }
76
77 }