Revert "Remove redundant type arguments."
This reverts commit 8b5f4535ec
.
This commit is contained in:
parent
8b5f4535ec
commit
6df150da22
|
@ -126,7 +126,7 @@ public class DSCompiler {
|
||||||
|
|
||||||
/** Array of all compilers created so far. */
|
/** Array of all compilers created so far. */
|
||||||
private static AtomicReference<DSCompiler[][]> compilers =
|
private static AtomicReference<DSCompiler[][]> compilers =
|
||||||
new AtomicReference<>(null);
|
new AtomicReference<DSCompiler[][]>(null);
|
||||||
|
|
||||||
/** Number of free parameters. */
|
/** Number of free parameters. */
|
||||||
private final int parameters;
|
private final int parameters;
|
||||||
|
@ -358,14 +358,14 @@ public class DSCompiler {
|
||||||
|
|
||||||
for (int i = 0; i < dSize; ++i) {
|
for (int i = 0; i < dSize; ++i) {
|
||||||
final int[][] dRow = derivativeCompiler.multIndirection[i];
|
final int[][] dRow = derivativeCompiler.multIndirection[i];
|
||||||
List<int[]> row = new ArrayList<>(dRow.length * 2);
|
List<int[]> row = new ArrayList<int[]>(dRow.length * 2);
|
||||||
for (int j = 0; j < dRow.length; ++j) {
|
for (int j = 0; j < dRow.length; ++j) {
|
||||||
row.add(new int[] { dRow[j][0], lowerIndirection[dRow[j][1]], vSize + dRow[j][2] });
|
row.add(new int[] { dRow[j][0], lowerIndirection[dRow[j][1]], vSize + dRow[j][2] });
|
||||||
row.add(new int[] { dRow[j][0], vSize + dRow[j][1], lowerIndirection[dRow[j][2]] });
|
row.add(new int[] { dRow[j][0], vSize + dRow[j][1], lowerIndirection[dRow[j][2]] });
|
||||||
}
|
}
|
||||||
|
|
||||||
// combine terms with similar derivation orders
|
// combine terms with similar derivation orders
|
||||||
final List<int[]> combined = new ArrayList<>(row.size());
|
final List<int[]> combined = new ArrayList<int[]>(row.size());
|
||||||
for (int j = 0; j < row.size(); ++j) {
|
for (int j = 0; j < row.size(); ++j) {
|
||||||
final int[] termJ = row.get(j);
|
final int[] termJ = row.get(j);
|
||||||
if (termJ[0] > 0) {
|
if (termJ[0] > 0) {
|
||||||
|
@ -428,7 +428,7 @@ public class DSCompiler {
|
||||||
// with respect to the parameter this compiler handles and the
|
// with respect to the parameter this compiler handles and the
|
||||||
// underlying one did not handle
|
// underlying one did not handle
|
||||||
for (int i = 0; i < dSize; ++i) {
|
for (int i = 0; i < dSize; ++i) {
|
||||||
List<int[]> row = new ArrayList<>();
|
List<int[]> row = new ArrayList<int[]>();
|
||||||
for (int[] term : derivativeCompiler.compIndirection[i]) {
|
for (int[] term : derivativeCompiler.compIndirection[i]) {
|
||||||
|
|
||||||
// handle term p * f_k(g(x)) * g_l1(x) * g_l2(x) * ... * g_lp(x)
|
// handle term p * f_k(g(x)) * g_l1(x) * g_l2(x) * ... * g_lp(x)
|
||||||
|
@ -475,7 +475,7 @@ public class DSCompiler {
|
||||||
}
|
}
|
||||||
|
|
||||||
// combine terms with similar derivation orders
|
// combine terms with similar derivation orders
|
||||||
final List<int[]> combined = new ArrayList<>(row.size());
|
final List<int[]> combined = new ArrayList<int[]>(row.size());
|
||||||
for (int j = 0; j < row.size(); ++j) {
|
for (int j = 0; j < row.size(); ++j) {
|
||||||
final int[] termJ = row.get(j);
|
final int[] termJ = row.get(j);
|
||||||
if (termJ[0] > 0) {
|
if (termJ[0] > 0) {
|
||||||
|
|
|
@ -61,7 +61,7 @@ public class SparseGradient implements RealFieldElement<SparseGradient>, Seriali
|
||||||
*/
|
*/
|
||||||
private SparseGradient(final double value, final Map<Integer, Double> derivatives) {
|
private SparseGradient(final double value, final Map<Integer, Double> derivatives) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
this.derivatives = new HashMap<>();
|
this.derivatives = new HashMap<Integer, Double>();
|
||||||
if (derivatives != null) {
|
if (derivatives != null) {
|
||||||
this.derivatives.putAll(derivatives);
|
this.derivatives.putAll(derivatives);
|
||||||
}
|
}
|
||||||
|
@ -77,7 +77,7 @@ public class SparseGradient implements RealFieldElement<SparseGradient>, Seriali
|
||||||
private SparseGradient(final double value, final double scale,
|
private SparseGradient(final double value, final double scale,
|
||||||
final Map<Integer, Double> derivatives) {
|
final Map<Integer, Double> derivatives) {
|
||||||
this.value = value;
|
this.value = value;
|
||||||
this.derivatives = new HashMap<>();
|
this.derivatives = new HashMap<Integer, Double>();
|
||||||
if (derivatives != null) {
|
if (derivatives != null) {
|
||||||
for (final Map.Entry<Integer, Double> entry : derivatives.entrySet()) {
|
for (final Map.Entry<Integer, Double> entry : derivatives.entrySet()) {
|
||||||
this.derivatives.put(entry.getKey(), scale * entry.getValue());
|
this.derivatives.put(entry.getKey(), scale * entry.getValue());
|
||||||
|
|
|
@ -37,10 +37,10 @@ import org.apache.commons.math4.util.Pair;
|
||||||
public abstract class BaseRuleFactory<T extends Number> {
|
public abstract class BaseRuleFactory<T extends Number> {
|
||||||
/** List of points and weights, indexed by the order of the rule. */
|
/** List of points and weights, indexed by the order of the rule. */
|
||||||
private final Map<Integer, Pair<T[], T[]>> pointsAndWeights
|
private final Map<Integer, Pair<T[], T[]>> pointsAndWeights
|
||||||
= new TreeMap<>();
|
= new TreeMap<Integer, Pair<T[], T[]>>();
|
||||||
/** Cache for double-precision rules. */
|
/** Cache for double-precision rules. */
|
||||||
private final Map<Integer, Pair<double[], double[]>> pointsAndWeightsDouble
|
private final Map<Integer, Pair<double[], double[]>> pointsAndWeightsDouble
|
||||||
= new TreeMap<>();
|
= new TreeMap<Integer, Pair<double[], double[]>>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a copy of the quadrature rule with the given number of integration
|
* Gets a copy of the quadrature rule with the given number of integration
|
||||||
|
@ -75,7 +75,7 @@ public abstract class BaseRuleFactory<T extends Number> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return a copy.
|
// Return a copy.
|
||||||
return new Pair<>(cached.getFirst().clone(),
|
return new Pair<double[], double[]>(cached.getFirst().clone(),
|
||||||
cached.getSecond().clone());
|
cached.getSecond().clone());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,6 +149,6 @@ public abstract class BaseRuleFactory<T extends Number> {
|
||||||
wD[i] = wT[i].doubleValue();
|
wD[i] = wT[i].doubleValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Pair<>(pD, wD);
|
return new Pair<double[], double[]>(pD, wD);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -162,6 +162,6 @@ public class GaussIntegratorFactory {
|
||||||
weights[i] *= scale;
|
weights[i] *= scale;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Pair<>(points, weights);
|
return new Pair<double[], double[]>(points, weights);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -63,7 +63,7 @@ public class HermiteRuleFactory extends BaseRuleFactory<Double> {
|
||||||
|
|
||||||
if (numberOfPoints == 1) {
|
if (numberOfPoints == 1) {
|
||||||
// Break recursion.
|
// Break recursion.
|
||||||
return new Pair<>(new Double[] { 0d },
|
return new Pair<Double[], Double[]>(new Double[] { 0d },
|
||||||
new Double[] { SQRT_PI });
|
new Double[] { SQRT_PI });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -172,6 +172,6 @@ public class HermiteRuleFactory extends BaseRuleFactory<Double> {
|
||||||
weights[iMax] = w;
|
weights[iMax] = w;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Pair<>(points, weights);
|
return new Pair<Double[], Double[]>(points, weights);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -66,7 +66,7 @@ public class LegendreHighPrecisionRuleFactory extends BaseRuleFactory<BigDecimal
|
||||||
|
|
||||||
if (numberOfPoints == 1) {
|
if (numberOfPoints == 1) {
|
||||||
// Break recursion.
|
// Break recursion.
|
||||||
return new Pair<>(new BigDecimal[] { BigDecimal.ZERO },
|
return new Pair<BigDecimal[], BigDecimal[]>(new BigDecimal[] { BigDecimal.ZERO },
|
||||||
new BigDecimal[] { two });
|
new BigDecimal[] { two });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -210,6 +210,6 @@ public class LegendreHighPrecisionRuleFactory extends BaseRuleFactory<BigDecimal
|
||||||
weights[iMax] = tmp2;
|
weights[iMax] = tmp2;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Pair<>(points, weights);
|
return new Pair<BigDecimal[], BigDecimal[]>(points, weights);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,7 @@ public class LegendreRuleFactory extends BaseRuleFactory<Double> {
|
||||||
|
|
||||||
if (numberOfPoints == 1) {
|
if (numberOfPoints == 1) {
|
||||||
// Break recursion.
|
// Break recursion.
|
||||||
return new Pair<>(new Double[] { 0d },
|
return new Pair<Double[], Double[]>(new Double[] { 0d },
|
||||||
new Double[] { 2d });
|
new Double[] { 2d });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -135,6 +135,6 @@ public class LegendreRuleFactory extends BaseRuleFactory<Double> {
|
||||||
weights[iMax] = w;
|
weights[iMax] = w;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Pair<>(points, weights);
|
return new Pair<Double[], Double[]>(points, weights);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,9 +61,9 @@ public class FieldHermiteInterpolator<T extends FieldElement<T>> {
|
||||||
/** Create an empty interpolator.
|
/** Create an empty interpolator.
|
||||||
*/
|
*/
|
||||||
public FieldHermiteInterpolator() {
|
public FieldHermiteInterpolator() {
|
||||||
this.abscissae = new ArrayList<>();
|
this.abscissae = new ArrayList<T>();
|
||||||
this.topDiagonal = new ArrayList<>();
|
this.topDiagonal = new ArrayList<T[]>();
|
||||||
this.bottomDiagonal = new ArrayList<>();
|
this.bottomDiagonal = new ArrayList<T[]>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add a sample point.
|
/** Add a sample point.
|
||||||
|
|
|
@ -59,9 +59,9 @@ public class HermiteInterpolator implements UnivariateDifferentiableVectorFuncti
|
||||||
/** Create an empty interpolator.
|
/** Create an empty interpolator.
|
||||||
*/
|
*/
|
||||||
public HermiteInterpolator() {
|
public HermiteInterpolator() {
|
||||||
this.abscissae = new ArrayList<>();
|
this.abscissae = new ArrayList<Double>();
|
||||||
this.topDiagonal = new ArrayList<>();
|
this.topDiagonal = new ArrayList<double[]>();
|
||||||
this.bottomDiagonal = new ArrayList<>();
|
this.bottomDiagonal = new ArrayList<double[]>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add a sample point.
|
/** Add a sample point.
|
||||||
|
|
|
@ -93,8 +93,8 @@ public class InterpolatingMicrosphere {
|
||||||
this.maxDarkFraction = maxDarkFraction;
|
this.maxDarkFraction = maxDarkFraction;
|
||||||
this.darkThreshold = darkThreshold;
|
this.darkThreshold = darkThreshold;
|
||||||
this.background = background;
|
this.background = background;
|
||||||
microsphere = new ArrayList<>(size);
|
microsphere = new ArrayList<Facet>(size);
|
||||||
microsphereData = new ArrayList<>(size);
|
microsphereData = new ArrayList<FacetData>(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -150,7 +150,7 @@ public class InterpolatingMicrosphere {
|
||||||
microsphere = other.microsphere;
|
microsphere = other.microsphere;
|
||||||
|
|
||||||
// Field must be copied.
|
// Field must be copied.
|
||||||
microsphereData = new ArrayList<>(size);
|
microsphereData = new ArrayList<FacetData>(size);
|
||||||
for (FacetData fd : other.microsphereData) {
|
for (FacetData fd : other.microsphereData) {
|
||||||
microsphereData.add(new FacetData(fd.illumination(), fd.sample()));
|
microsphereData.add(new FacetData(fd.illumination(), fd.sample()));
|
||||||
}
|
}
|
||||||
|
|
|
@ -51,34 +51,34 @@ public class PolynomialsUtils {
|
||||||
|
|
||||||
// initialize recurrence for Chebyshev polynomials
|
// initialize recurrence for Chebyshev polynomials
|
||||||
// T0(X) = 1, T1(X) = 0 + 1 * X
|
// T0(X) = 1, T1(X) = 0 + 1 * X
|
||||||
CHEBYSHEV_COEFFICIENTS = new ArrayList<>();
|
CHEBYSHEV_COEFFICIENTS = new ArrayList<BigFraction>();
|
||||||
CHEBYSHEV_COEFFICIENTS.add(BigFraction.ONE);
|
CHEBYSHEV_COEFFICIENTS.add(BigFraction.ONE);
|
||||||
CHEBYSHEV_COEFFICIENTS.add(BigFraction.ZERO);
|
CHEBYSHEV_COEFFICIENTS.add(BigFraction.ZERO);
|
||||||
CHEBYSHEV_COEFFICIENTS.add(BigFraction.ONE);
|
CHEBYSHEV_COEFFICIENTS.add(BigFraction.ONE);
|
||||||
|
|
||||||
// initialize recurrence for Hermite polynomials
|
// initialize recurrence for Hermite polynomials
|
||||||
// H0(X) = 1, H1(X) = 0 + 2 * X
|
// H0(X) = 1, H1(X) = 0 + 2 * X
|
||||||
HERMITE_COEFFICIENTS = new ArrayList<>();
|
HERMITE_COEFFICIENTS = new ArrayList<BigFraction>();
|
||||||
HERMITE_COEFFICIENTS.add(BigFraction.ONE);
|
HERMITE_COEFFICIENTS.add(BigFraction.ONE);
|
||||||
HERMITE_COEFFICIENTS.add(BigFraction.ZERO);
|
HERMITE_COEFFICIENTS.add(BigFraction.ZERO);
|
||||||
HERMITE_COEFFICIENTS.add(BigFraction.TWO);
|
HERMITE_COEFFICIENTS.add(BigFraction.TWO);
|
||||||
|
|
||||||
// initialize recurrence for Laguerre polynomials
|
// initialize recurrence for Laguerre polynomials
|
||||||
// L0(X) = 1, L1(X) = 1 - 1 * X
|
// L0(X) = 1, L1(X) = 1 - 1 * X
|
||||||
LAGUERRE_COEFFICIENTS = new ArrayList<>();
|
LAGUERRE_COEFFICIENTS = new ArrayList<BigFraction>();
|
||||||
LAGUERRE_COEFFICIENTS.add(BigFraction.ONE);
|
LAGUERRE_COEFFICIENTS.add(BigFraction.ONE);
|
||||||
LAGUERRE_COEFFICIENTS.add(BigFraction.ONE);
|
LAGUERRE_COEFFICIENTS.add(BigFraction.ONE);
|
||||||
LAGUERRE_COEFFICIENTS.add(BigFraction.MINUS_ONE);
|
LAGUERRE_COEFFICIENTS.add(BigFraction.MINUS_ONE);
|
||||||
|
|
||||||
// initialize recurrence for Legendre polynomials
|
// initialize recurrence for Legendre polynomials
|
||||||
// P0(X) = 1, P1(X) = 0 + 1 * X
|
// P0(X) = 1, P1(X) = 0 + 1 * X
|
||||||
LEGENDRE_COEFFICIENTS = new ArrayList<>();
|
LEGENDRE_COEFFICIENTS = new ArrayList<BigFraction>();
|
||||||
LEGENDRE_COEFFICIENTS.add(BigFraction.ONE);
|
LEGENDRE_COEFFICIENTS.add(BigFraction.ONE);
|
||||||
LEGENDRE_COEFFICIENTS.add(BigFraction.ZERO);
|
LEGENDRE_COEFFICIENTS.add(BigFraction.ZERO);
|
||||||
LEGENDRE_COEFFICIENTS.add(BigFraction.ONE);
|
LEGENDRE_COEFFICIENTS.add(BigFraction.ONE);
|
||||||
|
|
||||||
// initialize map for Jacobi polynomials
|
// initialize map for Jacobi polynomials
|
||||||
JACOBI_COEFFICIENTS = new HashMap<>();
|
JACOBI_COEFFICIENTS = new HashMap<JacobiKey, List<BigFraction>>();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -228,7 +228,7 @@ public class PolynomialsUtils {
|
||||||
if (!JACOBI_COEFFICIENTS.containsKey(key)) {
|
if (!JACOBI_COEFFICIENTS.containsKey(key)) {
|
||||||
|
|
||||||
// allocate a new list for v, w
|
// allocate a new list for v, w
|
||||||
final List<BigFraction> list = new ArrayList<>();
|
final List<BigFraction> list = new ArrayList<BigFraction>();
|
||||||
JACOBI_COEFFICIENTS.put(key, list);
|
JACOBI_COEFFICIENTS.put(key, list);
|
||||||
|
|
||||||
// Pv,w,0(x) = 1;
|
// Pv,w,0(x) = 1;
|
||||||
|
|
|
@ -1209,7 +1209,7 @@ public class Complex implements FieldElement<Complex>, Serializable {
|
||||||
n);
|
n);
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<Complex> result = new ArrayList<>();
|
final List<Complex> result = new ArrayList<Complex>();
|
||||||
|
|
||||||
if (isNaN) {
|
if (isNaN) {
|
||||||
result.add(NaN);
|
result.add(NaN);
|
||||||
|
|
|
@ -117,7 +117,7 @@ public class EnumeratedDistribution<T> implements Serializable {
|
||||||
throws NotPositiveException, MathArithmeticException, NotFiniteNumberException, NotANumberException {
|
throws NotPositiveException, MathArithmeticException, NotFiniteNumberException, NotANumberException {
|
||||||
random = rng;
|
random = rng;
|
||||||
|
|
||||||
singletons = new ArrayList<>(pmf.size());
|
singletons = new ArrayList<T>(pmf.size());
|
||||||
final double[] probs = new double[pmf.size()];
|
final double[] probs = new double[pmf.size()];
|
||||||
|
|
||||||
for (int i = 0; i < pmf.size(); i++) {
|
for (int i = 0; i < pmf.size(); i++) {
|
||||||
|
@ -191,10 +191,10 @@ public class EnumeratedDistribution<T> implements Serializable {
|
||||||
* @return the probability mass function.
|
* @return the probability mass function.
|
||||||
*/
|
*/
|
||||||
public List<Pair<T, Double>> getPmf() {
|
public List<Pair<T, Double>> getPmf() {
|
||||||
final List<Pair<T, Double>> samples = new ArrayList<>(probabilities.length);
|
final List<Pair<T, Double>> samples = new ArrayList<Pair<T, Double>>(probabilities.length);
|
||||||
|
|
||||||
for (int i = 0; i < probabilities.length; i++) {
|
for (int i = 0; i < probabilities.length; i++) {
|
||||||
samples.add(new Pair<>(singletons.get(i), probabilities[i]));
|
samples.add(new Pair<T, Double>(singletons.get(i), probabilities[i]));
|
||||||
}
|
}
|
||||||
|
|
||||||
return samples;
|
return samples;
|
||||||
|
|
|
@ -97,7 +97,7 @@ public class EnumeratedIntegerDistribution extends AbstractIntegerDistribution {
|
||||||
throws DimensionMismatchException, NotPositiveException, MathArithmeticException,
|
throws DimensionMismatchException, NotPositiveException, MathArithmeticException,
|
||||||
NotFiniteNumberException, NotANumberException {
|
NotFiniteNumberException, NotANumberException {
|
||||||
super(rng);
|
super(rng);
|
||||||
innerDistribution = new EnumeratedDistribution<>(
|
innerDistribution = new EnumeratedDistribution<Integer>(
|
||||||
rng, createDistribution(singletons, probabilities));
|
rng, createDistribution(singletons, probabilities));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,7 +111,7 @@ public class EnumeratedIntegerDistribution extends AbstractIntegerDistribution {
|
||||||
*/
|
*/
|
||||||
public EnumeratedIntegerDistribution(final RandomGenerator rng, final int[] data) {
|
public EnumeratedIntegerDistribution(final RandomGenerator rng, final int[] data) {
|
||||||
super(rng);
|
super(rng);
|
||||||
final Map<Integer, Integer> dataMap = new HashMap<>();
|
final Map<Integer, Integer> dataMap = new HashMap<Integer, Integer>();
|
||||||
for (int value : data) {
|
for (int value : data) {
|
||||||
Integer count = dataMap.get(value);
|
Integer count = dataMap.get(value);
|
||||||
if (count == null) {
|
if (count == null) {
|
||||||
|
@ -129,7 +129,7 @@ public class EnumeratedIntegerDistribution extends AbstractIntegerDistribution {
|
||||||
probabilities[index] = entry.getValue().intValue() / denom;
|
probabilities[index] = entry.getValue().intValue() / denom;
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
innerDistribution = new EnumeratedDistribution<>(rng, createDistribution(values, probabilities));
|
innerDistribution = new EnumeratedDistribution<Integer>(rng, createDistribution(values, probabilities));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -156,10 +156,10 @@ public class EnumeratedIntegerDistribution extends AbstractIntegerDistribution {
|
||||||
throw new DimensionMismatchException(probabilities.length, singletons.length);
|
throw new DimensionMismatchException(probabilities.length, singletons.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<Pair<Integer, Double>> samples = new ArrayList<>(singletons.length);
|
final List<Pair<Integer, Double>> samples = new ArrayList<Pair<Integer, Double>>(singletons.length);
|
||||||
|
|
||||||
for (int i = 0; i < singletons.length; i++) {
|
for (int i = 0; i < singletons.length; i++) {
|
||||||
samples.add(new Pair<>(singletons[i], probabilities[i]));
|
samples.add(new Pair<Integer, Double>(singletons[i], probabilities[i]));
|
||||||
}
|
}
|
||||||
return samples;
|
return samples;
|
||||||
|
|
||||||
|
|
|
@ -99,7 +99,7 @@ public class EnumeratedRealDistribution extends AbstractRealDistribution {
|
||||||
NotFiniteNumberException, NotANumberException {
|
NotFiniteNumberException, NotANumberException {
|
||||||
super(rng);
|
super(rng);
|
||||||
|
|
||||||
innerDistribution = new EnumeratedDistribution<>(
|
innerDistribution = new EnumeratedDistribution<Double>(
|
||||||
rng, createDistribution(singletons, probabilities));
|
rng, createDistribution(singletons, probabilities));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,7 +113,7 @@ public class EnumeratedRealDistribution extends AbstractRealDistribution {
|
||||||
*/
|
*/
|
||||||
public EnumeratedRealDistribution(final RandomGenerator rng, final double[] data) {
|
public EnumeratedRealDistribution(final RandomGenerator rng, final double[] data) {
|
||||||
super(rng);
|
super(rng);
|
||||||
final Map<Double, Integer> dataMap = new HashMap<>();
|
final Map<Double, Integer> dataMap = new HashMap<Double, Integer>();
|
||||||
for (double value : data) {
|
for (double value : data) {
|
||||||
Integer count = dataMap.get(value);
|
Integer count = dataMap.get(value);
|
||||||
if (count == null) {
|
if (count == null) {
|
||||||
|
@ -131,7 +131,7 @@ public class EnumeratedRealDistribution extends AbstractRealDistribution {
|
||||||
probabilities[index] = entry.getValue().intValue() / denom;
|
probabilities[index] = entry.getValue().intValue() / denom;
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
innerDistribution = new EnumeratedDistribution<>(rng, createDistribution(values, probabilities));
|
innerDistribution = new EnumeratedDistribution<Double>(rng, createDistribution(values, probabilities));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -157,10 +157,10 @@ public class EnumeratedRealDistribution extends AbstractRealDistribution {
|
||||||
throw new DimensionMismatchException(probabilities.length, singletons.length);
|
throw new DimensionMismatchException(probabilities.length, singletons.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<Pair<Double, Double>> samples = new ArrayList<>(singletons.length);
|
final List<Pair<Double, Double>> samples = new ArrayList<Pair<Double, Double>>(singletons.length);
|
||||||
|
|
||||||
for (int i = 0; i < singletons.length; i++) {
|
for (int i = 0; i < singletons.length; i++) {
|
||||||
samples.add(new Pair<>(singletons[i], probabilities[i]));
|
samples.add(new Pair<Double, Double>(singletons[i], probabilities[i]));
|
||||||
}
|
}
|
||||||
return samples;
|
return samples;
|
||||||
|
|
||||||
|
|
|
@ -99,13 +99,13 @@ public class MixtureMultivariateNormalDistribution
|
||||||
double[][] means,
|
double[][] means,
|
||||||
double[][][] covariances) {
|
double[][][] covariances) {
|
||||||
final List<Pair<Double, MultivariateNormalDistribution>> mvns
|
final List<Pair<Double, MultivariateNormalDistribution>> mvns
|
||||||
= new ArrayList<>(weights.length);
|
= new ArrayList<Pair<Double, MultivariateNormalDistribution>>(weights.length);
|
||||||
|
|
||||||
for (int i = 0; i < weights.length; i++) {
|
for (int i = 0; i < weights.length; i++) {
|
||||||
final MultivariateNormalDistribution dist
|
final MultivariateNormalDistribution dist
|
||||||
= new MultivariateNormalDistribution(means[i], covariances[i]);
|
= new MultivariateNormalDistribution(means[i], covariances[i]);
|
||||||
|
|
||||||
mvns.add(new Pair<>(weights[i], dist));
|
mvns.add(new Pair<Double, MultivariateNormalDistribution>(weights[i], dist));
|
||||||
}
|
}
|
||||||
|
|
||||||
return mvns;
|
return mvns;
|
||||||
|
|
|
@ -93,7 +93,7 @@ public class MixtureMultivariateRealDistribution<T extends MultivariateRealDistr
|
||||||
}
|
}
|
||||||
|
|
||||||
// Store each distribution and its normalized weight.
|
// Store each distribution and its normalized weight.
|
||||||
distribution = new ArrayList<>();
|
distribution = new ArrayList<T>();
|
||||||
weight = new double[numComp];
|
weight = new double[numComp];
|
||||||
for (int i = 0; i < numComp; i++) {
|
for (int i = 0; i < numComp; i++) {
|
||||||
final Pair<Double, T> comp = components.get(i);
|
final Pair<Double, T> comp = components.get(i);
|
||||||
|
@ -161,10 +161,10 @@ public class MixtureMultivariateRealDistribution<T extends MultivariateRealDistr
|
||||||
* @return the component distributions and associated weights.
|
* @return the component distributions and associated weights.
|
||||||
*/
|
*/
|
||||||
public List<Pair<Double, T>> getComponents() {
|
public List<Pair<Double, T>> getComponents() {
|
||||||
final List<Pair<Double, T>> list = new ArrayList<>(weight.length);
|
final List<Pair<Double, T>> list = new ArrayList<Pair<Double, T>>(weight.length);
|
||||||
|
|
||||||
for (int i = 0; i < weight.length; i++) {
|
for (int i = 0; i < weight.length; i++) {
|
||||||
list.add(new Pair<>(weight[i], distribution.get(i)));
|
list.add(new Pair<Double, T>(weight[i], distribution.get(i)));
|
||||||
}
|
}
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
|
|
|
@ -328,7 +328,7 @@ public class MultivariateNormalMixtureExpectationMaximization {
|
||||||
|
|
||||||
// components of mixture model to be created
|
// components of mixture model to be created
|
||||||
final List<Pair<Double, MultivariateNormalDistribution>> components =
|
final List<Pair<Double, MultivariateNormalDistribution>> components =
|
||||||
new ArrayList<>(numComponents);
|
new ArrayList<Pair<Double, MultivariateNormalDistribution>>(numComponents);
|
||||||
|
|
||||||
// create a component based on data in each bin
|
// create a component based on data in each bin
|
||||||
for (int binIndex = 0; binIndex < numComponents; binIndex++) {
|
for (int binIndex = 0; binIndex < numComponents; binIndex++) {
|
||||||
|
@ -364,7 +364,7 @@ public class MultivariateNormalMixtureExpectationMaximization {
|
||||||
final MultivariateNormalDistribution mvn
|
final MultivariateNormalDistribution mvn
|
||||||
= new MultivariateNormalDistribution(columnMeans, covMat);
|
= new MultivariateNormalDistribution(columnMeans, covMat);
|
||||||
|
|
||||||
components.add(new Pair<>(weight, mvn));
|
components.add(new Pair<Double, MultivariateNormalDistribution>(weight, mvn));
|
||||||
}
|
}
|
||||||
|
|
||||||
return new MixtureMultivariateNormalDistribution(components);
|
return new MixtureMultivariateNormalDistribution(components);
|
||||||
|
|
|
@ -38,7 +38,7 @@ public class ArgUtils {
|
||||||
* {@code array}.
|
* {@code array}.
|
||||||
*/
|
*/
|
||||||
public static Object[] flatten(Object[] array) {
|
public static Object[] flatten(Object[] array) {
|
||||||
final List<Object> list = new ArrayList<>();
|
final List<Object> list = new ArrayList<Object>();
|
||||||
if (array != null) {
|
if (array != null) {
|
||||||
for (Object o : array) {
|
for (Object o : array) {
|
||||||
if (o instanceof Object[]) {
|
if (o instanceof Object[]) {
|
||||||
|
|
|
@ -62,9 +62,9 @@ public class ExceptionContext implements Serializable {
|
||||||
*/
|
*/
|
||||||
public ExceptionContext(final Throwable throwable) {
|
public ExceptionContext(final Throwable throwable) {
|
||||||
this.throwable = throwable;
|
this.throwable = throwable;
|
||||||
msgPatterns = new ArrayList<>();
|
msgPatterns = new ArrayList<Localizable>();
|
||||||
msgArguments = new ArrayList<>();
|
msgArguments = new ArrayList<Object[]>();
|
||||||
context = new HashMap<>();
|
context = new HashMap<String, Object>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get a reference to the exception to which the context relates.
|
/** Get a reference to the exception to which the context relates.
|
||||||
|
@ -256,8 +256,8 @@ public class ExceptionContext implements Serializable {
|
||||||
ClassNotFoundException {
|
ClassNotFoundException {
|
||||||
// Step 1.
|
// Step 1.
|
||||||
final int len = in.readInt();
|
final int len = in.readInt();
|
||||||
msgPatterns = new ArrayList<>(len);
|
msgPatterns = new ArrayList<Localizable>(len);
|
||||||
msgArguments = new ArrayList<>(len);
|
msgArguments = new ArrayList<Object[]>(len);
|
||||||
// Step 2.
|
// Step 2.
|
||||||
for (int i = 0; i < len; i++) {
|
for (int i = 0; i < len; i++) {
|
||||||
// Step 3.
|
// Step 3.
|
||||||
|
@ -311,7 +311,7 @@ public class ExceptionContext implements Serializable {
|
||||||
ClassNotFoundException {
|
ClassNotFoundException {
|
||||||
// Step 1.
|
// Step 1.
|
||||||
final int len = in.readInt();
|
final int len = in.readInt();
|
||||||
context = new HashMap<>();
|
context = new HashMap<String, Object>();
|
||||||
for (int i = 0; i < len; i++) {
|
for (int i = 0; i < len; i++) {
|
||||||
// Step 2.
|
// Step 2.
|
||||||
final String key = (String) in.readObject();
|
final String key = (String) in.readObject();
|
||||||
|
|
|
@ -248,7 +248,7 @@ public class GaussianCurveFitter extends AbstractCurveFitter {
|
||||||
* @return the input observations, sorted.
|
* @return the input observations, sorted.
|
||||||
*/
|
*/
|
||||||
private List<WeightedObservedPoint> sortObservations(Collection<WeightedObservedPoint> unsorted) {
|
private List<WeightedObservedPoint> sortObservations(Collection<WeightedObservedPoint> unsorted) {
|
||||||
final List<WeightedObservedPoint> observations = new ArrayList<>(unsorted);
|
final List<WeightedObservedPoint> observations = new ArrayList<WeightedObservedPoint>(unsorted);
|
||||||
|
|
||||||
final Comparator<WeightedObservedPoint> cmp = new Comparator<WeightedObservedPoint>() {
|
final Comparator<WeightedObservedPoint> cmp = new Comparator<WeightedObservedPoint>() {
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
|
|
@ -292,7 +292,7 @@ public class HarmonicCurveFitter extends AbstractCurveFitter {
|
||||||
* @return the input observations, sorted.
|
* @return the input observations, sorted.
|
||||||
*/
|
*/
|
||||||
private List<WeightedObservedPoint> sortObservations(Collection<WeightedObservedPoint> unsorted) {
|
private List<WeightedObservedPoint> sortObservations(Collection<WeightedObservedPoint> unsorted) {
|
||||||
final List<WeightedObservedPoint> observations = new ArrayList<>(unsorted);
|
final List<WeightedObservedPoint> observations = new ArrayList<WeightedObservedPoint>(unsorted);
|
||||||
|
|
||||||
// Since the samples are almost always already sorted, this
|
// Since the samples are almost always already sorted, this
|
||||||
// method is implemented as an insertion sort that reorders the
|
// method is implemented as an insertion sort that reorders the
|
||||||
|
|
|
@ -32,7 +32,7 @@ public class WeightedObservedPoints implements Serializable {
|
||||||
|
|
||||||
/** Observed points. */
|
/** Observed points. */
|
||||||
private final List<WeightedObservedPoint> observations
|
private final List<WeightedObservedPoint> observations
|
||||||
= new ArrayList<>();
|
= new ArrayList<WeightedObservedPoint>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a point to the sample.
|
* Adds a point to the sample.
|
||||||
|
@ -100,7 +100,7 @@ public class WeightedObservedPoints implements Serializable {
|
||||||
// The copy is necessary to ensure thread-safety because of the
|
// The copy is necessary to ensure thread-safety because of the
|
||||||
// "clear" method (which otherwise would be able to empty the
|
// "clear" method (which otherwise would be able to empty the
|
||||||
// list of points while it is being used by another thread).
|
// list of points while it is being used by another thread).
|
||||||
return new ArrayList<>(observations);
|
return new ArrayList<WeightedObservedPoint>(observations);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -294,7 +294,7 @@ public class GaussNewtonOptimizer implements LeastSquaresOptimizer {
|
||||||
normal.setEntry(i, j, normal.getEntry(j, i));
|
normal.setEntry(i, j, normal.getEntry(j, i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new Pair<>(normal, jTr);
|
return new Pair<RealMatrix, RealVector>(normal, jTr);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -332,7 +332,7 @@ public class LeastSquaresFactory {
|
||||||
final double[] p = point.toArray();
|
final double[] p = point.toArray();
|
||||||
|
|
||||||
// Evaluate.
|
// Evaluate.
|
||||||
return new Pair<>(computeValue(p),
|
return new Pair<RealVector, RealMatrix>(computeValue(p),
|
||||||
computeJacobian(p));
|
computeJacobian(p));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -59,7 +59,7 @@ public abstract class AbstractListChromosome<T> extends Chromosome {
|
||||||
public AbstractListChromosome(final List<T> representation, final boolean copyList) {
|
public AbstractListChromosome(final List<T> representation, final boolean copyList) {
|
||||||
checkValidity(representation);
|
checkValidity(representation);
|
||||||
this.representation =
|
this.representation =
|
||||||
Collections.unmodifiableList(copyList ? new ArrayList<>(representation) : representation);
|
Collections.unmodifiableList(copyList ? new ArrayList<T>(representation) : representation);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -67,7 +67,7 @@ public abstract class BinaryChromosome extends AbstractListChromosome<Integer> {
|
||||||
*/
|
*/
|
||||||
public static List<Integer> randomBinaryRepresentation(int length) {
|
public static List<Integer> randomBinaryRepresentation(int length) {
|
||||||
// random binary list
|
// random binary list
|
||||||
List<Integer> rList= new ArrayList<> (length);
|
List<Integer> rList= new ArrayList<Integer> (length);
|
||||||
for (int j=0; j<length; j++) {
|
for (int j=0; j<length; j++) {
|
||||||
rList.add(GeneticAlgorithm.getRandomGenerator().nextInt(2));
|
rList.add(GeneticAlgorithm.getRandomGenerator().nextInt(2));
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ public class BinaryMutation implements MutationPolicy {
|
||||||
}
|
}
|
||||||
|
|
||||||
BinaryChromosome origChrom = (BinaryChromosome) original;
|
BinaryChromosome origChrom = (BinaryChromosome) original;
|
||||||
List<Integer> newRepr = new ArrayList<>(origChrom.getRepresentation());
|
List<Integer> newRepr = new ArrayList<Integer>(origChrom.getRepresentation());
|
||||||
|
|
||||||
// randomly select a gene
|
// randomly select a gene
|
||||||
int geneIndex = GeneticAlgorithm.getRandomGenerator().nextInt(origChrom.getLength());
|
int geneIndex = GeneticAlgorithm.getRandomGenerator().nextInt(origChrom.getLength());
|
||||||
|
|
|
@ -129,13 +129,13 @@ public class CycleCrossover<T> implements CrossoverPolicy {
|
||||||
final List<T> parent1Rep = first.getRepresentation();
|
final List<T> parent1Rep = first.getRepresentation();
|
||||||
final List<T> parent2Rep = second.getRepresentation();
|
final List<T> parent2Rep = second.getRepresentation();
|
||||||
// and of the children: do a crossover copy to simplify the later processing
|
// and of the children: do a crossover copy to simplify the later processing
|
||||||
final List<T> child1Rep = new ArrayList<>(second.getRepresentation());
|
final List<T> child1Rep = new ArrayList<T>(second.getRepresentation());
|
||||||
final List<T> child2Rep = new ArrayList<>(first.getRepresentation());
|
final List<T> child2Rep = new ArrayList<T>(first.getRepresentation());
|
||||||
|
|
||||||
// the set of all visited indices so far
|
// the set of all visited indices so far
|
||||||
final Set<Integer> visitedIndices = new HashSet<>(length);
|
final Set<Integer> visitedIndices = new HashSet<Integer>(length);
|
||||||
// the indices of the current cycle
|
// the indices of the current cycle
|
||||||
final List<Integer> indices = new ArrayList<>(length);
|
final List<Integer> indices = new ArrayList<Integer>(length);
|
||||||
|
|
||||||
// determine the starting index
|
// determine the starting index
|
||||||
int idx = randomStart ? GeneticAlgorithm.getRandomGenerator().nextInt(length) : 0;
|
int idx = randomStart ? GeneticAlgorithm.getRandomGenerator().nextInt(length) : 0;
|
||||||
|
|
|
@ -76,7 +76,7 @@ public abstract class ListPopulation implements Population {
|
||||||
chromosomes.size(), populationLimit, false);
|
chromosomes.size(), populationLimit, false);
|
||||||
}
|
}
|
||||||
this.populationLimit = populationLimit;
|
this.populationLimit = populationLimit;
|
||||||
this.chromosomes = new ArrayList<>(populationLimit);
|
this.chromosomes = new ArrayList<Chromosome>(populationLimit);
|
||||||
this.chromosomes.addAll(chromosomes);
|
this.chromosomes.addAll(chromosomes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -139,8 +139,8 @@ public class NPointCrossover<T> implements CrossoverPolicy {
|
||||||
final List<T> parent1Rep = first.getRepresentation();
|
final List<T> parent1Rep = first.getRepresentation();
|
||||||
final List<T> parent2Rep = second.getRepresentation();
|
final List<T> parent2Rep = second.getRepresentation();
|
||||||
// and of the children
|
// and of the children
|
||||||
final List<T> child1Rep = new ArrayList<>(length);
|
final List<T> child1Rep = new ArrayList<T>(length);
|
||||||
final List<T> child2Rep = new ArrayList<>(length);
|
final List<T> child2Rep = new ArrayList<T>(length);
|
||||||
|
|
||||||
final RandomGenerator random = GeneticAlgorithm.getRandomGenerator();
|
final RandomGenerator random = GeneticAlgorithm.getRandomGenerator();
|
||||||
|
|
||||||
|
|
|
@ -105,8 +105,8 @@ public class OnePointCrossover<T> implements CrossoverPolicy {
|
||||||
final List<T> parent1Rep = first.getRepresentation();
|
final List<T> parent1Rep = first.getRepresentation();
|
||||||
final List<T> parent2Rep = second.getRepresentation();
|
final List<T> parent2Rep = second.getRepresentation();
|
||||||
// and of the children
|
// and of the children
|
||||||
final List<T> child1Rep = new ArrayList<>(length);
|
final List<T> child1Rep = new ArrayList<T>(length);
|
||||||
final List<T> child2Rep = new ArrayList<>(length);
|
final List<T> child2Rep = new ArrayList<T>(length);
|
||||||
|
|
||||||
// select a crossover point at random (0 and length makes no sense)
|
// select a crossover point at random (0 and length makes no sense)
|
||||||
final int crossoverIndex = 1 + (GeneticAlgorithm.getRandomGenerator().nextInt(length-2));
|
final int crossoverIndex = 1 + (GeneticAlgorithm.getRandomGenerator().nextInt(length-2));
|
||||||
|
|
|
@ -97,11 +97,11 @@ public class OrderedCrossover<T> implements CrossoverPolicy {
|
||||||
final List<T> parent1Rep = first.getRepresentation();
|
final List<T> parent1Rep = first.getRepresentation();
|
||||||
final List<T> parent2Rep = second.getRepresentation();
|
final List<T> parent2Rep = second.getRepresentation();
|
||||||
// and of the children
|
// and of the children
|
||||||
final List<T> child1 = new ArrayList<>(length);
|
final List<T> child1 = new ArrayList<T>(length);
|
||||||
final List<T> child2 = new ArrayList<>(length);
|
final List<T> child2 = new ArrayList<T>(length);
|
||||||
// sets of already inserted items for quick access
|
// sets of already inserted items for quick access
|
||||||
final Set<T> child1Set = new HashSet<>(length);
|
final Set<T> child1Set = new HashSet<T>(length);
|
||||||
final Set<T> child2Set = new HashSet<>(length);
|
final Set<T> child2Set = new HashSet<T>(length);
|
||||||
|
|
||||||
final RandomGenerator random = GeneticAlgorithm.getRandomGenerator();
|
final RandomGenerator random = GeneticAlgorithm.getRandomGenerator();
|
||||||
// choose random points, making sure that lb < ub.
|
// choose random points, making sure that lb < ub.
|
||||||
|
|
|
@ -72,7 +72,7 @@ public abstract class RandomKey<T> extends AbstractListChromosome<Double> implem
|
||||||
public RandomKey(final List<Double> representation) throws InvalidRepresentationException {
|
public RandomKey(final List<Double> representation) throws InvalidRepresentationException {
|
||||||
super(representation);
|
super(representation);
|
||||||
// store the sorted representation
|
// store the sorted representation
|
||||||
List<Double> sortedRepr = new ArrayList<> (getRepresentation());
|
List<Double> sortedRepr = new ArrayList<Double> (getRepresentation());
|
||||||
Collections.sort(sortedRepr);
|
Collections.sort(sortedRepr);
|
||||||
sortedRepresentation = Collections.unmodifiableList(sortedRepr);
|
sortedRepresentation = Collections.unmodifiableList(sortedRepr);
|
||||||
// store the permutation of [0,1,...,n-1] list for toString() and isSame() methods
|
// store the permutation of [0,1,...,n-1] list for toString() and isSame() methods
|
||||||
|
@ -126,10 +126,10 @@ public abstract class RandomKey<T> extends AbstractListChromosome<Double> implem
|
||||||
}
|
}
|
||||||
|
|
||||||
// do not modify the original representation
|
// do not modify the original representation
|
||||||
List<Double> reprCopy = new ArrayList<> (representation);
|
List<Double> reprCopy = new ArrayList<Double> (representation);
|
||||||
|
|
||||||
// now find the indices in the original repr and use them for permuting
|
// now find the indices in the original repr and use them for permuting
|
||||||
List<S> res = new ArrayList<> (l);
|
List<S> res = new ArrayList<S> (l);
|
||||||
for (int i=0; i<l; i++) {
|
for (int i=0; i<l; i++) {
|
||||||
int index = reprCopy.indexOf(sortedRepr.get(i));
|
int index = reprCopy.indexOf(sortedRepr.get(i));
|
||||||
res.add(sequence.get(index));
|
res.add(sequence.get(index));
|
||||||
|
@ -195,7 +195,7 @@ public abstract class RandomKey<T> extends AbstractListChromosome<Double> implem
|
||||||
* @return representation of a random permutation
|
* @return representation of a random permutation
|
||||||
*/
|
*/
|
||||||
public static final List<Double> randomPermutation(final int l) {
|
public static final List<Double> randomPermutation(final int l) {
|
||||||
List<Double> repr = new ArrayList<>(l);
|
List<Double> repr = new ArrayList<Double>(l);
|
||||||
for (int i=0; i<l; i++) {
|
for (int i=0; i<l; i++) {
|
||||||
repr.add(GeneticAlgorithm.getRandomGenerator().nextDouble());
|
repr.add(GeneticAlgorithm.getRandomGenerator().nextDouble());
|
||||||
}
|
}
|
||||||
|
@ -210,7 +210,7 @@ public abstract class RandomKey<T> extends AbstractListChromosome<Double> implem
|
||||||
* @return representation of an identity permutation
|
* @return representation of an identity permutation
|
||||||
*/
|
*/
|
||||||
public static final List<Double> identityPermutation(final int l) {
|
public static final List<Double> identityPermutation(final int l) {
|
||||||
List<Double> repr = new ArrayList<>(l);
|
List<Double> repr = new ArrayList<Double>(l);
|
||||||
for (int i=0; i<l; i++) {
|
for (int i=0; i<l; i++) {
|
||||||
repr.add((double)i/l);
|
repr.add((double)i/l);
|
||||||
}
|
}
|
||||||
|
@ -232,7 +232,7 @@ public abstract class RandomKey<T> extends AbstractListChromosome<Double> implem
|
||||||
*/
|
*/
|
||||||
public static <S> List<Double> comparatorPermutation(final List<S> data,
|
public static <S> List<Double> comparatorPermutation(final List<S> data,
|
||||||
final Comparator<S> comparator) {
|
final Comparator<S> comparator) {
|
||||||
List<S> sortedData = new ArrayList<>(data);
|
List<S> sortedData = new ArrayList<S>(data);
|
||||||
Collections.sort(sortedData, comparator);
|
Collections.sort(sortedData, comparator);
|
||||||
|
|
||||||
return inducedPermutation(data, sortedData);
|
return inducedPermutation(data, sortedData);
|
||||||
|
@ -264,7 +264,7 @@ public abstract class RandomKey<T> extends AbstractListChromosome<Double> implem
|
||||||
}
|
}
|
||||||
int l = originalData.size();
|
int l = originalData.size();
|
||||||
|
|
||||||
List<S> origDataCopy = new ArrayList<> (originalData);
|
List<S> origDataCopy = new ArrayList<S> (originalData);
|
||||||
|
|
||||||
Double[] res = new Double[l];
|
Double[] res = new Double[l];
|
||||||
for (int i=0; i<l; i++) {
|
for (int i=0; i<l; i++) {
|
||||||
|
@ -291,7 +291,7 @@ public abstract class RandomKey<T> extends AbstractListChromosome<Double> implem
|
||||||
* @return list of integers from 0 to l-1
|
* @return list of integers from 0 to l-1
|
||||||
*/
|
*/
|
||||||
private static List<Integer> baseSequence(final int l) {
|
private static List<Integer> baseSequence(final int l) {
|
||||||
List<Integer> baseSequence = new ArrayList<> (l);
|
List<Integer> baseSequence = new ArrayList<Integer> (l);
|
||||||
for (int i=0; i<l; i++) {
|
for (int i=0; i<l; i++) {
|
||||||
baseSequence.add(i);
|
baseSequence.add(i);
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,7 +46,7 @@ public class RandomKeyMutation implements MutationPolicy {
|
||||||
List<Double> repr = originalRk.getRepresentation();
|
List<Double> repr = originalRk.getRepresentation();
|
||||||
int rInd = GeneticAlgorithm.getRandomGenerator().nextInt(repr.size());
|
int rInd = GeneticAlgorithm.getRandomGenerator().nextInt(repr.size());
|
||||||
|
|
||||||
List<Double> newRepr = new ArrayList<> (repr);
|
List<Double> newRepr = new ArrayList<Double> (repr);
|
||||||
newRepr.set(rInd, GeneticAlgorithm.getRandomGenerator().nextDouble());
|
newRepr.set(rInd, GeneticAlgorithm.getRandomGenerator().nextDouble());
|
||||||
|
|
||||||
return originalRk.newFixedLengthChromosome(newRepr);
|
return originalRk.newFixedLengthChromosome(newRepr);
|
||||||
|
|
|
@ -84,7 +84,7 @@ public class TournamentSelection implements SelectionPolicy {
|
||||||
};
|
};
|
||||||
|
|
||||||
// create a copy of the chromosome list
|
// create a copy of the chromosome list
|
||||||
List<Chromosome> chromosomes = new ArrayList<> (population.getChromosomes());
|
List<Chromosome> chromosomes = new ArrayList<Chromosome> (population.getChromosomes());
|
||||||
for (int i=0; i<this.arity; i++) {
|
for (int i=0; i<this.arity; i++) {
|
||||||
// select a random individual and add it to the tournament
|
// select a random individual and add it to the tournament
|
||||||
int rind = GeneticAlgorithm.getRandomGenerator().nextInt(chromosomes.size());
|
int rind = GeneticAlgorithm.getRandomGenerator().nextInt(chromosomes.size());
|
||||||
|
|
|
@ -112,8 +112,8 @@ public class UniformCrossover<T> implements CrossoverPolicy {
|
||||||
final List<T> parent1Rep = first.getRepresentation();
|
final List<T> parent1Rep = first.getRepresentation();
|
||||||
final List<T> parent2Rep = second.getRepresentation();
|
final List<T> parent2Rep = second.getRepresentation();
|
||||||
// and of the children
|
// and of the children
|
||||||
final List<T> child1Rep = new ArrayList<>(length);
|
final List<T> child1Rep = new ArrayList<T>(length);
|
||||||
final List<T> child2Rep = new ArrayList<>(length);
|
final List<T> child2Rep = new ArrayList<T>(length);
|
||||||
|
|
||||||
final RandomGenerator random = GeneticAlgorithm.getRandomGenerator();
|
final RandomGenerator random = GeneticAlgorithm.getRandomGenerator();
|
||||||
|
|
||||||
|
|
|
@ -78,8 +78,8 @@ public class WelzlEncloser<S extends Space, P extends Point<S>> implements Enclo
|
||||||
private EnclosingBall<S, P> pivotingBall(final Iterable<P> points) {
|
private EnclosingBall<S, P> pivotingBall(final Iterable<P> points) {
|
||||||
|
|
||||||
final P first = points.iterator().next();
|
final P first = points.iterator().next();
|
||||||
final List<P> extreme = new ArrayList<>(first.getSpace().getDimension() + 1);
|
final List<P> extreme = new ArrayList<P>(first.getSpace().getDimension() + 1);
|
||||||
final List<P> support = new ArrayList<>(first.getSpace().getDimension() + 1);
|
final List<P> support = new ArrayList<P>(first.getSpace().getDimension() + 1);
|
||||||
|
|
||||||
// start with only first point selected as a candidate support
|
// start with only first point selected as a candidate support
|
||||||
extreme.add(first);
|
extreme.add(first);
|
||||||
|
|
|
@ -108,12 +108,12 @@ public class IntervalsSet extends AbstractRegion<Euclidean1D, Euclidean1D> imple
|
||||||
if (Double.isInfinite(lower) && (lower < 0)) {
|
if (Double.isInfinite(lower) && (lower < 0)) {
|
||||||
if (Double.isInfinite(upper) && (upper > 0)) {
|
if (Double.isInfinite(upper) && (upper > 0)) {
|
||||||
// the tree must cover the whole real line
|
// the tree must cover the whole real line
|
||||||
return new BSPTree<>(Boolean.TRUE);
|
return new BSPTree<Euclidean1D>(Boolean.TRUE);
|
||||||
}
|
}
|
||||||
// the tree must be open on the negative infinity side
|
// the tree must be open on the negative infinity side
|
||||||
final SubHyperplane<Euclidean1D> upperCut =
|
final SubHyperplane<Euclidean1D> upperCut =
|
||||||
new OrientedPoint(new Vector1D(upper), true, tolerance).wholeHyperplane();
|
new OrientedPoint(new Vector1D(upper), true, tolerance).wholeHyperplane();
|
||||||
return new BSPTree<>(upperCut,
|
return new BSPTree<Euclidean1D>(upperCut,
|
||||||
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
||||||
new BSPTree<Euclidean1D>(Boolean.TRUE),
|
new BSPTree<Euclidean1D>(Boolean.TRUE),
|
||||||
null);
|
null);
|
||||||
|
@ -122,7 +122,7 @@ public class IntervalsSet extends AbstractRegion<Euclidean1D, Euclidean1D> imple
|
||||||
new OrientedPoint(new Vector1D(lower), false, tolerance).wholeHyperplane();
|
new OrientedPoint(new Vector1D(lower), false, tolerance).wholeHyperplane();
|
||||||
if (Double.isInfinite(upper) && (upper > 0)) {
|
if (Double.isInfinite(upper) && (upper > 0)) {
|
||||||
// the tree must be open on the positive infinity side
|
// the tree must be open on the positive infinity side
|
||||||
return new BSPTree<>(lowerCut,
|
return new BSPTree<Euclidean1D>(lowerCut,
|
||||||
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
||||||
new BSPTree<Euclidean1D>(Boolean.TRUE),
|
new BSPTree<Euclidean1D>(Boolean.TRUE),
|
||||||
null);
|
null);
|
||||||
|
@ -131,9 +131,9 @@ public class IntervalsSet extends AbstractRegion<Euclidean1D, Euclidean1D> imple
|
||||||
// the tree must be bounded on the two sides
|
// the tree must be bounded on the two sides
|
||||||
final SubHyperplane<Euclidean1D> upperCut =
|
final SubHyperplane<Euclidean1D> upperCut =
|
||||||
new OrientedPoint(new Vector1D(upper), true, tolerance).wholeHyperplane();
|
new OrientedPoint(new Vector1D(upper), true, tolerance).wholeHyperplane();
|
||||||
return new BSPTree<>(lowerCut,
|
return new BSPTree<Euclidean1D>(lowerCut,
|
||||||
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
||||||
new BSPTree<>(upperCut,
|
new BSPTree<Euclidean1D>(upperCut,
|
||||||
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
new BSPTree<Euclidean1D>(Boolean.FALSE),
|
||||||
new BSPTree<Euclidean1D>(Boolean.TRUE),
|
new BSPTree<Euclidean1D>(Boolean.TRUE),
|
||||||
null),
|
null),
|
||||||
|
@ -222,9 +222,9 @@ public class IntervalsSet extends AbstractRegion<Euclidean1D, Euclidean1D> imple
|
||||||
final double previousOffset = x - previous;
|
final double previousOffset = x - previous;
|
||||||
final double currentOffset = a[0] - x;
|
final double currentOffset = a[0] - x;
|
||||||
if (previousOffset < currentOffset) {
|
if (previousOffset < currentOffset) {
|
||||||
return new BoundaryProjection<>(point, finiteOrNullPoint(previous), previousOffset);
|
return new BoundaryProjection<Euclidean1D>(point, finiteOrNullPoint(previous), previousOffset);
|
||||||
} else {
|
} else {
|
||||||
return new BoundaryProjection<>(point, finiteOrNullPoint(a[0]), currentOffset);
|
return new BoundaryProjection<Euclidean1D>(point, finiteOrNullPoint(a[0]), currentOffset);
|
||||||
}
|
}
|
||||||
} else if (x <= a[1]) {
|
} else if (x <= a[1]) {
|
||||||
// the test point lies within the current interval
|
// the test point lies within the current interval
|
||||||
|
@ -232,16 +232,16 @@ public class IntervalsSet extends AbstractRegion<Euclidean1D, Euclidean1D> imple
|
||||||
final double offset0 = a[0] - x;
|
final double offset0 = a[0] - x;
|
||||||
final double offset1 = x - a[1];
|
final double offset1 = x - a[1];
|
||||||
if (offset0 < offset1) {
|
if (offset0 < offset1) {
|
||||||
return new BoundaryProjection<>(point, finiteOrNullPoint(a[1]), offset1);
|
return new BoundaryProjection<Euclidean1D>(point, finiteOrNullPoint(a[1]), offset1);
|
||||||
} else {
|
} else {
|
||||||
return new BoundaryProjection<>(point, finiteOrNullPoint(a[0]), offset0);
|
return new BoundaryProjection<Euclidean1D>(point, finiteOrNullPoint(a[0]), offset0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
previous = a[1];
|
previous = a[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
// the test point if past the last sub-interval
|
// the test point if past the last sub-interval
|
||||||
return new BoundaryProjection<>(point, finiteOrNullPoint(previous), x - previous);
|
return new BoundaryProjection<Euclidean1D>(point, finiteOrNullPoint(previous), x - previous);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,7 +267,7 @@ public class IntervalsSet extends AbstractRegion<Euclidean1D, Euclidean1D> imple
|
||||||
* elements
|
* elements
|
||||||
*/
|
*/
|
||||||
public List<Interval> asList() {
|
public List<Interval> asList() {
|
||||||
final List<Interval> list = new ArrayList<>();
|
final List<Interval> list = new ArrayList<Interval>();
|
||||||
for (final double[] a : this) {
|
for (final double[] a : this) {
|
||||||
list.add(new Interval(a[0], a[1]));
|
list.add(new Interval(a[0], a[1]));
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,11 +61,11 @@ public class SubOrientedPoint extends AbstractSubHyperplane<Euclidean1D, Euclide
|
||||||
public SplitSubHyperplane<Euclidean1D> split(final Hyperplane<Euclidean1D> hyperplane) {
|
public SplitSubHyperplane<Euclidean1D> split(final Hyperplane<Euclidean1D> hyperplane) {
|
||||||
final double global = hyperplane.getOffset(((OrientedPoint) getHyperplane()).getLocation());
|
final double global = hyperplane.getOffset(((OrientedPoint) getHyperplane()).getLocation());
|
||||||
if (global < -1.0e-10) {
|
if (global < -1.0e-10) {
|
||||||
return new SplitSubHyperplane<>(null, this);
|
return new SplitSubHyperplane<Euclidean1D>(null, this);
|
||||||
} else if (global > 1.0e-10) {
|
} else if (global > 1.0e-10) {
|
||||||
return new SplitSubHyperplane<>(this, null);
|
return new SplitSubHyperplane<Euclidean1D>(this, null);
|
||||||
} else {
|
} else {
|
||||||
return new SplitSubHyperplane<>(null, null);
|
return new SplitSubHyperplane<Euclidean1D>(null, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -374,9 +374,9 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
public FieldRotation(final RotationOrder order, final RotationConvention convention,
|
public FieldRotation(final RotationOrder order, final RotationConvention convention,
|
||||||
final T alpha1, final T alpha2, final T alpha3) {
|
final T alpha1, final T alpha2, final T alpha3) {
|
||||||
final T one = alpha1.getField().getOne();
|
final T one = alpha1.getField().getOne();
|
||||||
final FieldRotation<T> r1 = new FieldRotation<>(new FieldVector3D<>(one, order.getA1()), alpha1, convention);
|
final FieldRotation<T> r1 = new FieldRotation<T>(new FieldVector3D<T>(one, order.getA1()), alpha1, convention);
|
||||||
final FieldRotation<T> r2 = new FieldRotation<>(new FieldVector3D<>(one, order.getA2()), alpha2, convention);
|
final FieldRotation<T> r2 = new FieldRotation<T>(new FieldVector3D<T>(one, order.getA2()), alpha2, convention);
|
||||||
final FieldRotation<T> r3 = new FieldRotation<>(new FieldVector3D<>(one, order.getA3()), alpha3, convention);
|
final FieldRotation<T> r3 = new FieldRotation<T>(new FieldVector3D<T>(one, order.getA3()), alpha3, convention);
|
||||||
final FieldRotation<T> composed = r1.compose(r2.compose(r3, convention), convention);
|
final FieldRotation<T> composed = r1.compose(r2.compose(r3, convention), convention);
|
||||||
q0 = composed.q0;
|
q0 = composed.q0;
|
||||||
q1 = composed.q1;
|
q1 = composed.q1;
|
||||||
|
@ -453,7 +453,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* of the instance
|
* of the instance
|
||||||
*/
|
*/
|
||||||
public FieldRotation<T> revert() {
|
public FieldRotation<T> revert() {
|
||||||
return new FieldRotation<>(q0.negate(), q1, q2, q3, false);
|
return new FieldRotation<T>(q0.negate(), q1, q2, q3, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get the scalar coordinate of the quaternion.
|
/** Get the scalar coordinate of the quaternion.
|
||||||
|
@ -509,17 +509,17 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
final T squaredSine = q1.multiply(q1).add(q2.multiply(q2)).add(q3.multiply(q3));
|
final T squaredSine = q1.multiply(q1).add(q2.multiply(q2)).add(q3.multiply(q3));
|
||||||
if (squaredSine.getReal() == 0) {
|
if (squaredSine.getReal() == 0) {
|
||||||
final Field<T> field = squaredSine.getField();
|
final Field<T> field = squaredSine.getField();
|
||||||
return new FieldVector3D<>(convention == RotationConvention.VECTOR_OPERATOR ? field.getOne(): field.getOne().negate(),
|
return new FieldVector3D<T>(convention == RotationConvention.VECTOR_OPERATOR ? field.getOne(): field.getOne().negate(),
|
||||||
field.getZero(),
|
field.getZero(),
|
||||||
field.getZero());
|
field.getZero());
|
||||||
} else {
|
} else {
|
||||||
final double sgn = convention == RotationConvention.VECTOR_OPERATOR ? +1 : -1;
|
final double sgn = convention == RotationConvention.VECTOR_OPERATOR ? +1 : -1;
|
||||||
if (q0.getReal() < 0) {
|
if (q0.getReal() < 0) {
|
||||||
T inverse = squaredSine.sqrt().reciprocal().multiply(sgn);
|
T inverse = squaredSine.sqrt().reciprocal().multiply(sgn);
|
||||||
return new FieldVector3D<>(q1.multiply(inverse), q2.multiply(inverse), q3.multiply(inverse));
|
return new FieldVector3D<T>(q1.multiply(inverse), q2.multiply(inverse), q3.multiply(inverse));
|
||||||
}
|
}
|
||||||
final T inverse = squaredSine.sqrt().reciprocal().negate().multiply(sgn);
|
final T inverse = squaredSine.sqrt().reciprocal().negate().multiply(sgn);
|
||||||
return new FieldVector3D<>(q1.multiply(inverse), q2.multiply(inverse), q3.multiply(inverse));
|
return new FieldVector3D<T>(q1.multiply(inverse), q2.multiply(inverse), q3.multiply(inverse));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1032,7 +1032,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
*/
|
*/
|
||||||
private FieldVector3D<T> vector(final double x, final double y, final double z) {
|
private FieldVector3D<T> vector(final double x, final double y, final double z) {
|
||||||
final T zero = q0.getField().getZero();
|
final T zero = q0.getField().getZero();
|
||||||
return new FieldVector3D<>(zero.add(x), zero.add(y), zero.add(z));
|
return new FieldVector3D<T>(zero.add(x), zero.add(y), zero.add(z));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get the 3X3 matrix corresponding to the instance
|
/** Get the 3X3 matrix corresponding to the instance
|
||||||
|
@ -1090,7 +1090,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
|
|
||||||
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
||||||
|
|
||||||
return new FieldVector3D<>(q0.multiply(x.multiply(q0).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
return new FieldVector3D<T>(q0.multiply(x.multiply(q0).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
||||||
q0.multiply(y.multiply(q0).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
q0.multiply(y.multiply(q0).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
||||||
q0.multiply(z.multiply(q0).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
q0.multiply(z.multiply(q0).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
||||||
|
|
||||||
|
@ -1108,7 +1108,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
|
|
||||||
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
||||||
|
|
||||||
return new FieldVector3D<>(q0.multiply(q0.multiply(x).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
return new FieldVector3D<T>(q0.multiply(q0.multiply(x).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
||||||
q0.multiply(q0.multiply(y).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
q0.multiply(q0.multiply(y).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
||||||
q0.multiply(q0.multiply(z).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
q0.multiply(q0.multiply(z).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
||||||
|
|
||||||
|
@ -1165,7 +1165,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
|
|
||||||
final T s = x.multiply(r.getQ1()).add(y.multiply(r.getQ2())).add(z.multiply(r.getQ3()));
|
final T s = x.multiply(r.getQ1()).add(y.multiply(r.getQ2())).add(z.multiply(r.getQ3()));
|
||||||
|
|
||||||
return new FieldVector3D<>(x.multiply(r.getQ0()).subtract(z.multiply(r.getQ2()).subtract(y.multiply(r.getQ3()))).multiply(r.getQ0()).add(s.multiply(r.getQ1())).multiply(2).subtract(x),
|
return new FieldVector3D<T>(x.multiply(r.getQ0()).subtract(z.multiply(r.getQ2()).subtract(y.multiply(r.getQ3()))).multiply(r.getQ0()).add(s.multiply(r.getQ1())).multiply(2).subtract(x),
|
||||||
y.multiply(r.getQ0()).subtract(x.multiply(r.getQ3()).subtract(z.multiply(r.getQ1()))).multiply(r.getQ0()).add(s.multiply(r.getQ2())).multiply(2).subtract(y),
|
y.multiply(r.getQ0()).subtract(x.multiply(r.getQ3()).subtract(z.multiply(r.getQ1()))).multiply(r.getQ0()).add(s.multiply(r.getQ2())).multiply(2).subtract(y),
|
||||||
z.multiply(r.getQ0()).subtract(y.multiply(r.getQ1()).subtract(x.multiply(r.getQ2()))).multiply(r.getQ0()).add(s.multiply(r.getQ3())).multiply(2).subtract(z));
|
z.multiply(r.getQ0()).subtract(y.multiply(r.getQ1()).subtract(x.multiply(r.getQ2()))).multiply(r.getQ0()).add(s.multiply(r.getQ3())).multiply(2).subtract(z));
|
||||||
|
|
||||||
|
@ -1184,7 +1184,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
||||||
final T m0 = q0.negate();
|
final T m0 = q0.negate();
|
||||||
|
|
||||||
return new FieldVector3D<>(m0.multiply(x.multiply(m0).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
return new FieldVector3D<T>(m0.multiply(x.multiply(m0).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
||||||
m0.multiply(y.multiply(m0).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
m0.multiply(y.multiply(m0).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
||||||
m0.multiply(z.multiply(m0).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
m0.multiply(z.multiply(m0).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
||||||
|
|
||||||
|
@ -1203,7 +1203,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
final T s = q1.multiply(x).add(q2.multiply(y)).add(q3.multiply(z));
|
||||||
final T m0 = q0.negate();
|
final T m0 = q0.negate();
|
||||||
|
|
||||||
return new FieldVector3D<>(m0.multiply(m0.multiply(x).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
return new FieldVector3D<T>(m0.multiply(m0.multiply(x).subtract(q2.multiply(z).subtract(q3.multiply(y)))).add(s.multiply(q1)).multiply(2).subtract(x),
|
||||||
m0.multiply(m0.multiply(y).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
m0.multiply(m0.multiply(y).subtract(q3.multiply(x).subtract(q1.multiply(z)))).add(s.multiply(q2)).multiply(2).subtract(y),
|
||||||
m0.multiply(m0.multiply(z).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
m0.multiply(m0.multiply(z).subtract(q1.multiply(y).subtract(q2.multiply(x)))).add(s.multiply(q3)).multiply(2).subtract(z));
|
||||||
|
|
||||||
|
@ -1263,7 +1263,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
final T s = x.multiply(r.getQ1()).add(y.multiply(r.getQ2())).add(z.multiply(r.getQ3()));
|
final T s = x.multiply(r.getQ1()).add(y.multiply(r.getQ2())).add(z.multiply(r.getQ3()));
|
||||||
final double m0 = -r.getQ0();
|
final double m0 = -r.getQ0();
|
||||||
|
|
||||||
return new FieldVector3D<>(x.multiply(m0).subtract(z.multiply(r.getQ2()).subtract(y.multiply(r.getQ3()))).multiply(m0).add(s.multiply(r.getQ1())).multiply(2).subtract(x),
|
return new FieldVector3D<T>(x.multiply(m0).subtract(z.multiply(r.getQ2()).subtract(y.multiply(r.getQ3()))).multiply(m0).add(s.multiply(r.getQ1())).multiply(2).subtract(x),
|
||||||
y.multiply(m0).subtract(x.multiply(r.getQ3()).subtract(z.multiply(r.getQ1()))).multiply(m0).add(s.multiply(r.getQ2())).multiply(2).subtract(y),
|
y.multiply(m0).subtract(x.multiply(r.getQ3()).subtract(z.multiply(r.getQ1()))).multiply(m0).add(s.multiply(r.getQ2())).multiply(2).subtract(y),
|
||||||
z.multiply(m0).subtract(y.multiply(r.getQ1()).subtract(x.multiply(r.getQ2()))).multiply(m0).add(s.multiply(r.getQ3())).multiply(2).subtract(z));
|
z.multiply(m0).subtract(y.multiply(r.getQ1()).subtract(x.multiply(r.getQ2()))).multiply(m0).add(s.multiply(r.getQ3())).multiply(2).subtract(z));
|
||||||
|
|
||||||
|
@ -1317,7 +1317,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* using vector operator convention
|
* using vector operator convention
|
||||||
*/
|
*/
|
||||||
private FieldRotation<T> composeInternal(final FieldRotation<T> r) {
|
private FieldRotation<T> composeInternal(final FieldRotation<T> r) {
|
||||||
return new FieldRotation<>(r.q0.multiply(q0).subtract(r.q1.multiply(q1).add(r.q2.multiply(q2)).add(r.q3.multiply(q3))),
|
return new FieldRotation<T>(r.q0.multiply(q0).subtract(r.q1.multiply(q1).add(r.q2.multiply(q2)).add(r.q3.multiply(q3))),
|
||||||
r.q1.multiply(q0).add(r.q0.multiply(q1)).add(r.q2.multiply(q3).subtract(r.q3.multiply(q2))),
|
r.q1.multiply(q0).add(r.q0.multiply(q1)).add(r.q2.multiply(q3).subtract(r.q3.multiply(q2))),
|
||||||
r.q2.multiply(q0).add(r.q0.multiply(q2)).add(r.q3.multiply(q1).subtract(r.q1.multiply(q3))),
|
r.q2.multiply(q0).add(r.q0.multiply(q2)).add(r.q3.multiply(q1).subtract(r.q1.multiply(q3))),
|
||||||
r.q3.multiply(q0).add(r.q0.multiply(q3)).add(r.q1.multiply(q2).subtract(r.q2.multiply(q1))),
|
r.q3.multiply(q0).add(r.q0.multiply(q3)).add(r.q1.multiply(q2).subtract(r.q2.multiply(q1))),
|
||||||
|
@ -1372,7 +1372,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* using vector operator convention
|
* using vector operator convention
|
||||||
*/
|
*/
|
||||||
private FieldRotation<T> composeInternal(final Rotation r) {
|
private FieldRotation<T> composeInternal(final Rotation r) {
|
||||||
return new FieldRotation<>(q0.multiply(r.getQ0()).subtract(q1.multiply(r.getQ1()).add(q2.multiply(r.getQ2())).add(q3.multiply(r.getQ3()))),
|
return new FieldRotation<T>(q0.multiply(r.getQ0()).subtract(q1.multiply(r.getQ1()).add(q2.multiply(r.getQ2())).add(q3.multiply(r.getQ3()))),
|
||||||
q0.multiply(r.getQ1()).add(q1.multiply(r.getQ0())).add(q3.multiply(r.getQ2()).subtract(q2.multiply(r.getQ3()))),
|
q0.multiply(r.getQ1()).add(q1.multiply(r.getQ0())).add(q3.multiply(r.getQ2()).subtract(q2.multiply(r.getQ3()))),
|
||||||
q0.multiply(r.getQ2()).add(q2.multiply(r.getQ0())).add(q1.multiply(r.getQ3()).subtract(q3.multiply(r.getQ1()))),
|
q0.multiply(r.getQ2()).add(q2.multiply(r.getQ0())).add(q1.multiply(r.getQ3()).subtract(q3.multiply(r.getQ1()))),
|
||||||
q0.multiply(r.getQ3()).add(q3.multiply(r.getQ0())).add(q2.multiply(r.getQ1()).subtract(q1.multiply(r.getQ2()))),
|
q0.multiply(r.getQ3()).add(q3.multiply(r.getQ0())).add(q2.multiply(r.getQ1()).subtract(q1.multiply(r.getQ2()))),
|
||||||
|
@ -1391,7 +1391,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new rotation which is the composition of r by the instance
|
* @return a new rotation which is the composition of r by the instance
|
||||||
*/
|
*/
|
||||||
public static <T extends RealFieldElement<T>> FieldRotation<T> applyTo(final Rotation r1, final FieldRotation<T> rInner) {
|
public static <T extends RealFieldElement<T>> FieldRotation<T> applyTo(final Rotation r1, final FieldRotation<T> rInner) {
|
||||||
return new FieldRotation<>(rInner.q0.multiply(r1.getQ0()).subtract(rInner.q1.multiply(r1.getQ1()).add(rInner.q2.multiply(r1.getQ2())).add(rInner.q3.multiply(r1.getQ3()))),
|
return new FieldRotation<T>(rInner.q0.multiply(r1.getQ0()).subtract(rInner.q1.multiply(r1.getQ1()).add(rInner.q2.multiply(r1.getQ2())).add(rInner.q3.multiply(r1.getQ3()))),
|
||||||
rInner.q1.multiply(r1.getQ0()).add(rInner.q0.multiply(r1.getQ1())).add(rInner.q2.multiply(r1.getQ3()).subtract(rInner.q3.multiply(r1.getQ2()))),
|
rInner.q1.multiply(r1.getQ0()).add(rInner.q0.multiply(r1.getQ1())).add(rInner.q2.multiply(r1.getQ3()).subtract(rInner.q3.multiply(r1.getQ2()))),
|
||||||
rInner.q2.multiply(r1.getQ0()).add(rInner.q0.multiply(r1.getQ2())).add(rInner.q3.multiply(r1.getQ1()).subtract(rInner.q1.multiply(r1.getQ3()))),
|
rInner.q2.multiply(r1.getQ0()).add(rInner.q0.multiply(r1.getQ2())).add(rInner.q3.multiply(r1.getQ1()).subtract(rInner.q1.multiply(r1.getQ3()))),
|
||||||
rInner.q3.multiply(r1.getQ0()).add(rInner.q0.multiply(r1.getQ3())).add(rInner.q1.multiply(r1.getQ2()).subtract(rInner.q2.multiply(r1.getQ1()))),
|
rInner.q3.multiply(r1.getQ0()).add(rInner.q0.multiply(r1.getQ3())).add(rInner.q1.multiply(r1.getQ2()).subtract(rInner.q2.multiply(r1.getQ1()))),
|
||||||
|
@ -1450,7 +1450,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* of the instance using vector operator convention
|
* of the instance using vector operator convention
|
||||||
*/
|
*/
|
||||||
private FieldRotation<T> composeInverseInternal(FieldRotation<T> r) {
|
private FieldRotation<T> composeInverseInternal(FieldRotation<T> r) {
|
||||||
return new FieldRotation<>(r.q0.multiply(q0).add(r.q1.multiply(q1).add(r.q2.multiply(q2)).add(r.q3.multiply(q3))).negate(),
|
return new FieldRotation<T>(r.q0.multiply(q0).add(r.q1.multiply(q1).add(r.q2.multiply(q2)).add(r.q3.multiply(q3))).negate(),
|
||||||
r.q0.multiply(q1).add(r.q2.multiply(q3).subtract(r.q3.multiply(q2))).subtract(r.q1.multiply(q0)),
|
r.q0.multiply(q1).add(r.q2.multiply(q3).subtract(r.q3.multiply(q2))).subtract(r.q1.multiply(q0)),
|
||||||
r.q0.multiply(q2).add(r.q3.multiply(q1).subtract(r.q1.multiply(q3))).subtract(r.q2.multiply(q0)),
|
r.q0.multiply(q2).add(r.q3.multiply(q1).subtract(r.q1.multiply(q3))).subtract(r.q2.multiply(q0)),
|
||||||
r.q0.multiply(q3).add(r.q1.multiply(q2).subtract(r.q2.multiply(q1))).subtract(r.q3.multiply(q0)),
|
r.q0.multiply(q3).add(r.q1.multiply(q2).subtract(r.q2.multiply(q1))).subtract(r.q3.multiply(q0)),
|
||||||
|
@ -1509,7 +1509,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* of the instance using vector operator convention
|
* of the instance using vector operator convention
|
||||||
*/
|
*/
|
||||||
private FieldRotation<T> composeInverseInternal(Rotation r) {
|
private FieldRotation<T> composeInverseInternal(Rotation r) {
|
||||||
return new FieldRotation<>(q0.multiply(r.getQ0()).add(q1.multiply(r.getQ1()).add(q2.multiply(r.getQ2())).add(q3.multiply(r.getQ3()))).negate(),
|
return new FieldRotation<T>(q0.multiply(r.getQ0()).add(q1.multiply(r.getQ1()).add(q2.multiply(r.getQ2())).add(q3.multiply(r.getQ3()))).negate(),
|
||||||
q1.multiply(r.getQ0()).add(q3.multiply(r.getQ2()).subtract(q2.multiply(r.getQ3()))).subtract(q0.multiply(r.getQ1())),
|
q1.multiply(r.getQ0()).add(q3.multiply(r.getQ2()).subtract(q2.multiply(r.getQ3()))).subtract(q0.multiply(r.getQ1())),
|
||||||
q2.multiply(r.getQ0()).add(q1.multiply(r.getQ3()).subtract(q3.multiply(r.getQ1()))).subtract(q0.multiply(r.getQ2())),
|
q2.multiply(r.getQ0()).add(q1.multiply(r.getQ3()).subtract(q3.multiply(r.getQ1()))).subtract(q0.multiply(r.getQ2())),
|
||||||
q3.multiply(r.getQ0()).add(q2.multiply(r.getQ1()).subtract(q1.multiply(r.getQ2()))).subtract(q0.multiply(r.getQ3())),
|
q3.multiply(r.getQ0()).add(q2.multiply(r.getQ1()).subtract(q1.multiply(r.getQ2()))).subtract(q0.multiply(r.getQ3())),
|
||||||
|
@ -1530,7 +1530,7 @@ public class FieldRotation<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* of the instance
|
* of the instance
|
||||||
*/
|
*/
|
||||||
public static <T extends RealFieldElement<T>> FieldRotation<T> applyInverseTo(final Rotation rOuter, final FieldRotation<T> rInner) {
|
public static <T extends RealFieldElement<T>> FieldRotation<T> applyInverseTo(final Rotation rOuter, final FieldRotation<T> rInner) {
|
||||||
return new FieldRotation<>(rInner.q0.multiply(rOuter.getQ0()).add(rInner.q1.multiply(rOuter.getQ1()).add(rInner.q2.multiply(rOuter.getQ2())).add(rInner.q3.multiply(rOuter.getQ3()))).negate(),
|
return new FieldRotation<T>(rInner.q0.multiply(rOuter.getQ0()).add(rInner.q1.multiply(rOuter.getQ1()).add(rInner.q2.multiply(rOuter.getQ2())).add(rInner.q3.multiply(rOuter.getQ3()))).negate(),
|
||||||
rInner.q0.multiply(rOuter.getQ1()).add(rInner.q2.multiply(rOuter.getQ3()).subtract(rInner.q3.multiply(rOuter.getQ2()))).subtract(rInner.q1.multiply(rOuter.getQ0())),
|
rInner.q0.multiply(rOuter.getQ1()).add(rInner.q2.multiply(rOuter.getQ3()).subtract(rInner.q3.multiply(rOuter.getQ2()))).subtract(rInner.q1.multiply(rOuter.getQ0())),
|
||||||
rInner.q0.multiply(rOuter.getQ2()).add(rInner.q3.multiply(rOuter.getQ1()).subtract(rInner.q1.multiply(rOuter.getQ3()))).subtract(rInner.q2.multiply(rOuter.getQ0())),
|
rInner.q0.multiply(rOuter.getQ2()).add(rInner.q3.multiply(rOuter.getQ1()).subtract(rInner.q1.multiply(rOuter.getQ3()))).subtract(rInner.q2.multiply(rOuter.getQ0())),
|
||||||
rInner.q0.multiply(rOuter.getQ3()).add(rInner.q1.multiply(rOuter.getQ2()).subtract(rInner.q2.multiply(rOuter.getQ1()))).subtract(rInner.q3.multiply(rOuter.getQ0())),
|
rInner.q0.multiply(rOuter.getQ3()).add(rInner.q1.multiply(rOuter.getQ2()).subtract(rInner.q2.multiply(rOuter.getQ1()))).subtract(rInner.q3.multiply(rOuter.getQ0())),
|
||||||
|
|
|
@ -408,7 +408,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> add(final FieldVector3D<T> v) {
|
public FieldVector3D<T> add(final FieldVector3D<T> v) {
|
||||||
return new FieldVector3D<>(x.add(v.x), y.add(v.y), z.add(v.z));
|
return new FieldVector3D<T>(x.add(v.x), y.add(v.y), z.add(v.z));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add a vector to the instance.
|
/** Add a vector to the instance.
|
||||||
|
@ -416,7 +416,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> add(final Vector3D v) {
|
public FieldVector3D<T> add(final Vector3D v) {
|
||||||
return new FieldVector3D<>(x.add(v.getX()), y.add(v.getY()), z.add(v.getZ()));
|
return new FieldVector3D<T>(x.add(v.getX()), y.add(v.getY()), z.add(v.getZ()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add a scaled vector to the instance.
|
/** Add a scaled vector to the instance.
|
||||||
|
@ -425,7 +425,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> add(final T factor, final FieldVector3D<T> v) {
|
public FieldVector3D<T> add(final T factor, final FieldVector3D<T> v) {
|
||||||
return new FieldVector3D<>(x.getField().getOne(), this, factor, v);
|
return new FieldVector3D<T>(x.getField().getOne(), this, factor, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add a scaled vector to the instance.
|
/** Add a scaled vector to the instance.
|
||||||
|
@ -434,7 +434,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> add(final T factor, final Vector3D v) {
|
public FieldVector3D<T> add(final T factor, final Vector3D v) {
|
||||||
return new FieldVector3D<>(x.add(factor.multiply(v.getX())),
|
return new FieldVector3D<T>(x.add(factor.multiply(v.getX())),
|
||||||
y.add(factor.multiply(v.getY())),
|
y.add(factor.multiply(v.getY())),
|
||||||
z.add(factor.multiply(v.getZ())));
|
z.add(factor.multiply(v.getZ())));
|
||||||
}
|
}
|
||||||
|
@ -445,7 +445,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> add(final double factor, final FieldVector3D<T> v) {
|
public FieldVector3D<T> add(final double factor, final FieldVector3D<T> v) {
|
||||||
return new FieldVector3D<>(1.0, this, factor, v);
|
return new FieldVector3D<T>(1.0, this, factor, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add a scaled vector to the instance.
|
/** Add a scaled vector to the instance.
|
||||||
|
@ -454,7 +454,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> add(final double factor, final Vector3D v) {
|
public FieldVector3D<T> add(final double factor, final Vector3D v) {
|
||||||
return new FieldVector3D<>(x.add(factor * v.getX()),
|
return new FieldVector3D<T>(x.add(factor * v.getX()),
|
||||||
y.add(factor * v.getY()),
|
y.add(factor * v.getY()),
|
||||||
z.add(factor * v.getZ()));
|
z.add(factor * v.getZ()));
|
||||||
}
|
}
|
||||||
|
@ -464,7 +464,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> subtract(final FieldVector3D<T> v) {
|
public FieldVector3D<T> subtract(final FieldVector3D<T> v) {
|
||||||
return new FieldVector3D<>(x.subtract(v.x), y.subtract(v.y), z.subtract(v.z));
|
return new FieldVector3D<T>(x.subtract(v.x), y.subtract(v.y), z.subtract(v.z));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Subtract a vector from the instance.
|
/** Subtract a vector from the instance.
|
||||||
|
@ -472,7 +472,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> subtract(final Vector3D v) {
|
public FieldVector3D<T> subtract(final Vector3D v) {
|
||||||
return new FieldVector3D<>(x.subtract(v.getX()), y.subtract(v.getY()), z.subtract(v.getZ()));
|
return new FieldVector3D<T>(x.subtract(v.getX()), y.subtract(v.getY()), z.subtract(v.getZ()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Subtract a scaled vector from the instance.
|
/** Subtract a scaled vector from the instance.
|
||||||
|
@ -481,7 +481,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> subtract(final T factor, final FieldVector3D<T> v) {
|
public FieldVector3D<T> subtract(final T factor, final FieldVector3D<T> v) {
|
||||||
return new FieldVector3D<>(x.getField().getOne(), this, factor.negate(), v);
|
return new FieldVector3D<T>(x.getField().getOne(), this, factor.negate(), v);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Subtract a scaled vector from the instance.
|
/** Subtract a scaled vector from the instance.
|
||||||
|
@ -490,7 +490,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> subtract(final T factor, final Vector3D v) {
|
public FieldVector3D<T> subtract(final T factor, final Vector3D v) {
|
||||||
return new FieldVector3D<>(x.subtract(factor.multiply(v.getX())),
|
return new FieldVector3D<T>(x.subtract(factor.multiply(v.getX())),
|
||||||
y.subtract(factor.multiply(v.getY())),
|
y.subtract(factor.multiply(v.getY())),
|
||||||
z.subtract(factor.multiply(v.getZ())));
|
z.subtract(factor.multiply(v.getZ())));
|
||||||
}
|
}
|
||||||
|
@ -501,7 +501,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> subtract(final double factor, final FieldVector3D<T> v) {
|
public FieldVector3D<T> subtract(final double factor, final FieldVector3D<T> v) {
|
||||||
return new FieldVector3D<>(1.0, this, -factor, v);
|
return new FieldVector3D<T>(1.0, this, -factor, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Subtract a scaled vector from the instance.
|
/** Subtract a scaled vector from the instance.
|
||||||
|
@ -510,7 +510,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> subtract(final double factor, final Vector3D v) {
|
public FieldVector3D<T> subtract(final double factor, final Vector3D v) {
|
||||||
return new FieldVector3D<>(x.subtract(factor * v.getX()),
|
return new FieldVector3D<T>(x.subtract(factor * v.getX()),
|
||||||
y.subtract(factor * v.getY()),
|
y.subtract(factor * v.getY()),
|
||||||
z.subtract(factor * v.getZ()));
|
z.subtract(factor * v.getZ()));
|
||||||
}
|
}
|
||||||
|
@ -551,13 +551,13 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
|
|
||||||
if (FastMath.abs(x.getReal()) <= threshold) {
|
if (FastMath.abs(x.getReal()) <= threshold) {
|
||||||
final T inverse = y.multiply(y).add(z.multiply(z)).sqrt().reciprocal();
|
final T inverse = y.multiply(y).add(z.multiply(z)).sqrt().reciprocal();
|
||||||
return new FieldVector3D<>(inverse.getField().getZero(), inverse.multiply(z), inverse.multiply(y).negate());
|
return new FieldVector3D<T>(inverse.getField().getZero(), inverse.multiply(z), inverse.multiply(y).negate());
|
||||||
} else if (FastMath.abs(y.getReal()) <= threshold) {
|
} else if (FastMath.abs(y.getReal()) <= threshold) {
|
||||||
final T inverse = x.multiply(x).add(z.multiply(z)).sqrt().reciprocal();
|
final T inverse = x.multiply(x).add(z.multiply(z)).sqrt().reciprocal();
|
||||||
return new FieldVector3D<>(inverse.multiply(z).negate(), inverse.getField().getZero(), inverse.multiply(x));
|
return new FieldVector3D<T>(inverse.multiply(z).negate(), inverse.getField().getZero(), inverse.multiply(x));
|
||||||
} else {
|
} else {
|
||||||
final T inverse = x.multiply(x).add(y.multiply(y)).sqrt().reciprocal();
|
final T inverse = x.multiply(x).add(y.multiply(y)).sqrt().reciprocal();
|
||||||
return new FieldVector3D<>(inverse.multiply(y), inverse.multiply(x).negate(), inverse.getField().getZero());
|
return new FieldVector3D<T>(inverse.multiply(y), inverse.multiply(x).negate(), inverse.getField().getZero());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -655,7 +655,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector which is opposite to the instance
|
* @return a new vector which is opposite to the instance
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> negate() {
|
public FieldVector3D<T> negate() {
|
||||||
return new FieldVector3D<>(x.negate(), y.negate(), z.negate());
|
return new FieldVector3D<T>(x.negate(), y.negate(), z.negate());
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Multiply the instance by a scalar.
|
/** Multiply the instance by a scalar.
|
||||||
|
@ -663,7 +663,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> scalarMultiply(final T a) {
|
public FieldVector3D<T> scalarMultiply(final T a) {
|
||||||
return new FieldVector3D<>(x.multiply(a), y.multiply(a), z.multiply(a));
|
return new FieldVector3D<T>(x.multiply(a), y.multiply(a), z.multiply(a));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Multiply the instance by a scalar.
|
/** Multiply the instance by a scalar.
|
||||||
|
@ -671,7 +671,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> scalarMultiply(final double a) {
|
public FieldVector3D<T> scalarMultiply(final double a) {
|
||||||
return new FieldVector3D<>(x.multiply(a), y.multiply(a), z.multiply(a));
|
return new FieldVector3D<T>(x.multiply(a), y.multiply(a), z.multiply(a));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -779,7 +779,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return the cross product this ^ v as a new Vector3D
|
* @return the cross product this ^ v as a new Vector3D
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> crossProduct(final FieldVector3D<T> v) {
|
public FieldVector3D<T> crossProduct(final FieldVector3D<T> v) {
|
||||||
return new FieldVector3D<>(x.linearCombination(y, v.z, z.negate(), v.y),
|
return new FieldVector3D<T>(x.linearCombination(y, v.z, z.negate(), v.y),
|
||||||
y.linearCombination(z, v.x, x.negate(), v.z),
|
y.linearCombination(z, v.x, x.negate(), v.z),
|
||||||
z.linearCombination(x, v.y, y.negate(), v.x));
|
z.linearCombination(x, v.y, y.negate(), v.x));
|
||||||
}
|
}
|
||||||
|
@ -789,7 +789,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
* @return the cross product this ^ v as a new Vector3D
|
* @return the cross product this ^ v as a new Vector3D
|
||||||
*/
|
*/
|
||||||
public FieldVector3D<T> crossProduct(final Vector3D v) {
|
public FieldVector3D<T> crossProduct(final Vector3D v) {
|
||||||
return new FieldVector3D<>(x.linearCombination(v.getZ(), y, -v.getY(), z),
|
return new FieldVector3D<T>(x.linearCombination(v.getZ(), y, -v.getY(), z),
|
||||||
y.linearCombination(v.getX(), z, -v.getZ(), x),
|
y.linearCombination(v.getX(), z, -v.getZ(), x),
|
||||||
z.linearCombination(v.getY(), x, -v.getX(), y));
|
z.linearCombination(v.getY(), x, -v.getX(), y));
|
||||||
}
|
}
|
||||||
|
@ -993,7 +993,7 @@ public class FieldVector3D<T extends RealFieldElement<T>> implements Serializabl
|
||||||
*/
|
*/
|
||||||
public static <T extends RealFieldElement<T>> FieldVector3D<T> crossProduct(final Vector3D v1,
|
public static <T extends RealFieldElement<T>> FieldVector3D<T> crossProduct(final Vector3D v1,
|
||||||
final FieldVector3D<T> v2) {
|
final FieldVector3D<T> v2) {
|
||||||
return new FieldVector3D<>(v2.x.linearCombination(v1.getY(), v2.z, -v1.getZ(), v2.y),
|
return new FieldVector3D<T>(v2.x.linearCombination(v1.getY(), v2.z, -v1.getZ(), v2.y),
|
||||||
v2.y.linearCombination(v1.getZ(), v2.x, -v1.getX(), v2.z),
|
v2.y.linearCombination(v1.getZ(), v2.x, -v1.getX(), v2.z),
|
||||||
v2.z.linearCombination(v1.getX(), v2.y, -v1.getY(), v2.x));
|
v2.z.linearCombination(v1.getX(), v2.y, -v1.getY(), v2.x));
|
||||||
}
|
}
|
||||||
|
|
|
@ -203,7 +203,7 @@ public class OutlineExtractor {
|
||||||
}
|
}
|
||||||
|
|
||||||
// compute the projection of the facet in the outline plane
|
// compute the projection of the facet in the outline plane
|
||||||
final ArrayList<SubHyperplane<Euclidean2D>> edges = new ArrayList<>();
|
final ArrayList<SubHyperplane<Euclidean2D>> edges = new ArrayList<SubHyperplane<Euclidean2D>>();
|
||||||
for (Vector2D[] loop : vertices) {
|
for (Vector2D[] loop : vertices) {
|
||||||
final boolean closed = loop[0] != null;
|
final boolean closed = loop[0] != null;
|
||||||
int previous = closed ? (loop.length - 1) : 1;
|
int previous = closed ? (loop.length - 1) : 1;
|
||||||
|
|
|
@ -162,7 +162,7 @@ public class PolyhedronsSet extends AbstractRegion<Euclidean3D, Euclidean2D> {
|
||||||
final double tolerance) {
|
final double tolerance) {
|
||||||
if ((xMin >= xMax - tolerance) || (yMin >= yMax - tolerance) || (zMin >= zMax - tolerance)) {
|
if ((xMin >= xMax - tolerance) || (yMin >= yMax - tolerance) || (zMin >= zMax - tolerance)) {
|
||||||
// too thin box, build an empty polygons set
|
// too thin box, build an empty polygons set
|
||||||
return new BSPTree<>(Boolean.FALSE);
|
return new BSPTree<Euclidean3D>(Boolean.FALSE);
|
||||||
}
|
}
|
||||||
final Plane pxMin = new Plane(new Vector3D(xMin, 0, 0), Vector3D.MINUS_I, tolerance);
|
final Plane pxMin = new Plane(new Vector3D(xMin, 0, 0), Vector3D.MINUS_I, tolerance);
|
||||||
final Plane pxMax = new Plane(new Vector3D(xMax, 0, 0), Vector3D.PLUS_I, tolerance);
|
final Plane pxMax = new Plane(new Vector3D(xMax, 0, 0), Vector3D.PLUS_I, tolerance);
|
||||||
|
@ -226,7 +226,7 @@ public class PolyhedronsSet extends AbstractRegion<Euclidean3D, Euclidean2D> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<SubHyperplane<Euclidean3D>> boundary = new ArrayList<>();
|
final List<SubHyperplane<Euclidean3D>> boundary = new ArrayList<SubHyperplane<Euclidean3D>>();
|
||||||
|
|
||||||
for (final int[] facet : facets) {
|
for (final int[] facet : facets) {
|
||||||
|
|
||||||
|
|
|
@ -37,15 +37,15 @@ public class SphereGenerator implements SupportBallGenerator<Euclidean3D, Vector
|
||||||
public EnclosingBall<Euclidean3D, Vector3D> ballOnSupport(final List<Vector3D> support) {
|
public EnclosingBall<Euclidean3D, Vector3D> ballOnSupport(final List<Vector3D> support) {
|
||||||
|
|
||||||
if (support.size() < 1) {
|
if (support.size() < 1) {
|
||||||
return new EnclosingBall<>(Vector3D.ZERO, Double.NEGATIVE_INFINITY);
|
return new EnclosingBall<Euclidean3D, Vector3D>(Vector3D.ZERO, Double.NEGATIVE_INFINITY);
|
||||||
} else {
|
} else {
|
||||||
final Vector3D vA = support.get(0);
|
final Vector3D vA = support.get(0);
|
||||||
if (support.size() < 2) {
|
if (support.size() < 2) {
|
||||||
return new EnclosingBall<>(vA, 0, vA);
|
return new EnclosingBall<Euclidean3D, Vector3D>(vA, 0, vA);
|
||||||
} else {
|
} else {
|
||||||
final Vector3D vB = support.get(1);
|
final Vector3D vB = support.get(1);
|
||||||
if (support.size() < 3) {
|
if (support.size() < 3) {
|
||||||
return new EnclosingBall<>(new Vector3D(0.5, vA, 0.5, vB),
|
return new EnclosingBall<Euclidean3D, Vector3D>(new Vector3D(0.5, vA, 0.5, vB),
|
||||||
0.5 * vA.distance(vB),
|
0.5 * vA.distance(vB),
|
||||||
vA, vB);
|
vA, vB);
|
||||||
} else {
|
} else {
|
||||||
|
@ -61,7 +61,7 @@ public class SphereGenerator implements SupportBallGenerator<Euclidean3D, Vector
|
||||||
p.toSubSpace(vC)));
|
p.toSubSpace(vC)));
|
||||||
|
|
||||||
// convert back to 3D
|
// convert back to 3D
|
||||||
return new EnclosingBall<>(p.toSpace(disk.getCenter()),
|
return new EnclosingBall<Euclidean3D, Vector3D>(p.toSpace(disk.getCenter()),
|
||||||
disk.getRadius(), vA, vB, vC);
|
disk.getRadius(), vA, vB, vC);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
@ -118,7 +118,7 @@ public class SphereGenerator implements SupportBallGenerator<Euclidean3D, Vector
|
||||||
final BigFraction dy = c3[0].subtract(centerY);
|
final BigFraction dy = c3[0].subtract(centerY);
|
||||||
final BigFraction dz = c4[0].subtract(centerZ);
|
final BigFraction dz = c4[0].subtract(centerZ);
|
||||||
final BigFraction r2 = dx.multiply(dx).add(dy.multiply(dy)).add(dz.multiply(dz));
|
final BigFraction r2 = dx.multiply(dx).add(dy.multiply(dy)).add(dz.multiply(dz));
|
||||||
return new EnclosingBall<>(new Vector3D(centerX.doubleValue(),
|
return new EnclosingBall<Euclidean3D, Vector3D>(new Vector3D(centerX.doubleValue(),
|
||||||
centerY.doubleValue(),
|
centerY.doubleValue(),
|
||||||
centerZ.doubleValue()),
|
centerZ.doubleValue()),
|
||||||
FastMath.sqrt(r2.doubleValue()),
|
FastMath.sqrt(r2.doubleValue()),
|
||||||
|
|
|
@ -85,7 +85,7 @@ public class SubLine {
|
||||||
public List<Segment> getSegments() {
|
public List<Segment> getSegments() {
|
||||||
|
|
||||||
final List<Interval> list = remainingRegion.asList();
|
final List<Interval> list = remainingRegion.asList();
|
||||||
final List<Segment> segments = new ArrayList<>(list.size());
|
final List<Segment> segments = new ArrayList<Segment>(list.size());
|
||||||
|
|
||||||
for (final Interval interval : list) {
|
for (final Interval interval : list) {
|
||||||
final Vector3D start = line.toSpace((Point<Euclidean1D>) new Vector1D(interval.getInf()));
|
final Vector3D start = line.toSpace((Point<Euclidean1D>) new Vector1D(interval.getInf()));
|
||||||
|
|
|
@ -67,11 +67,11 @@ public class SubPlane extends AbstractSubHyperplane<Euclidean3D, Euclidean2D> {
|
||||||
// the hyperplanes are parallel
|
// the hyperplanes are parallel
|
||||||
final double global = otherPlane.getOffset(thisPlane);
|
final double global = otherPlane.getOffset(thisPlane);
|
||||||
if (global < -tolerance) {
|
if (global < -tolerance) {
|
||||||
return new SplitSubHyperplane<>(null, this);
|
return new SplitSubHyperplane<Euclidean3D>(null, this);
|
||||||
} else if (global > tolerance) {
|
} else if (global > tolerance) {
|
||||||
return new SplitSubHyperplane<>(this, null);
|
return new SplitSubHyperplane<Euclidean3D>(this, null);
|
||||||
} else {
|
} else {
|
||||||
return new SplitSubHyperplane<>(null, null);
|
return new SplitSubHyperplane<Euclidean3D>(null, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,15 +92,15 @@ public class SubPlane extends AbstractSubHyperplane<Euclidean3D, Euclidean2D> {
|
||||||
final BSPTree<Euclidean2D> splitTree = getRemainingRegion().getTree(false).split(l2DMinus);
|
final BSPTree<Euclidean2D> splitTree = getRemainingRegion().getTree(false).split(l2DMinus);
|
||||||
final BSPTree<Euclidean2D> plusTree = getRemainingRegion().isEmpty(splitTree.getPlus()) ?
|
final BSPTree<Euclidean2D> plusTree = getRemainingRegion().isEmpty(splitTree.getPlus()) ?
|
||||||
new BSPTree<Euclidean2D>(Boolean.FALSE) :
|
new BSPTree<Euclidean2D>(Boolean.FALSE) :
|
||||||
new BSPTree<>(l2DPlus, new BSPTree<Euclidean2D>(Boolean.FALSE),
|
new BSPTree<Euclidean2D>(l2DPlus, new BSPTree<Euclidean2D>(Boolean.FALSE),
|
||||||
splitTree.getPlus(), null);
|
splitTree.getPlus(), null);
|
||||||
|
|
||||||
final BSPTree<Euclidean2D> minusTree = getRemainingRegion().isEmpty(splitTree.getMinus()) ?
|
final BSPTree<Euclidean2D> minusTree = getRemainingRegion().isEmpty(splitTree.getMinus()) ?
|
||||||
new BSPTree<Euclidean2D>(Boolean.FALSE) :
|
new BSPTree<Euclidean2D>(Boolean.FALSE) :
|
||||||
new BSPTree<>(l2DMinus, new BSPTree<Euclidean2D>(Boolean.FALSE),
|
new BSPTree<Euclidean2D>(l2DMinus, new BSPTree<Euclidean2D>(Boolean.FALSE),
|
||||||
splitTree.getMinus(), null);
|
splitTree.getMinus(), null);
|
||||||
|
|
||||||
return new SplitSubHyperplane<>(new SubPlane(thisPlane.copySelf(), new PolygonsSet(plusTree, tolerance)),
|
return new SplitSubHyperplane<Euclidean3D>(new SubPlane(thisPlane.copySelf(), new PolygonsSet(plusTree, tolerance)),
|
||||||
new SubPlane(thisPlane.copySelf(), new PolygonsSet(minusTree, tolerance)));
|
new SubPlane(thisPlane.copySelf(), new PolygonsSet(minusTree, tolerance)));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,15 +33,15 @@ public class DiskGenerator implements SupportBallGenerator<Euclidean2D, Vector2D
|
||||||
public EnclosingBall<Euclidean2D, Vector2D> ballOnSupport(final List<Vector2D> support) {
|
public EnclosingBall<Euclidean2D, Vector2D> ballOnSupport(final List<Vector2D> support) {
|
||||||
|
|
||||||
if (support.size() < 1) {
|
if (support.size() < 1) {
|
||||||
return new EnclosingBall<>(Vector2D.ZERO, Double.NEGATIVE_INFINITY);
|
return new EnclosingBall<Euclidean2D, Vector2D>(Vector2D.ZERO, Double.NEGATIVE_INFINITY);
|
||||||
} else {
|
} else {
|
||||||
final Vector2D vA = support.get(0);
|
final Vector2D vA = support.get(0);
|
||||||
if (support.size() < 2) {
|
if (support.size() < 2) {
|
||||||
return new EnclosingBall<>(vA, 0, vA);
|
return new EnclosingBall<Euclidean2D, Vector2D>(vA, 0, vA);
|
||||||
} else {
|
} else {
|
||||||
final Vector2D vB = support.get(1);
|
final Vector2D vB = support.get(1);
|
||||||
if (support.size() < 3) {
|
if (support.size() < 3) {
|
||||||
return new EnclosingBall<>(new Vector2D(0.5, vA, 0.5, vB),
|
return new EnclosingBall<Euclidean2D, Vector2D>(new Vector2D(0.5, vA, 0.5, vB),
|
||||||
0.5 * vA.distance(vB),
|
0.5 * vA.distance(vB),
|
||||||
vA, vB);
|
vA, vB);
|
||||||
} else {
|
} else {
|
||||||
|
@ -86,7 +86,7 @@ public class DiskGenerator implements SupportBallGenerator<Euclidean2D, Vector2D
|
||||||
final BigFraction dx = c2[0].subtract(centerX);
|
final BigFraction dx = c2[0].subtract(centerX);
|
||||||
final BigFraction dy = c3[0].subtract(centerY);
|
final BigFraction dy = c3[0].subtract(centerY);
|
||||||
final BigFraction r2 = dx.multiply(dx).add(dy.multiply(dy));
|
final BigFraction r2 = dx.multiply(dx).add(dy.multiply(dy));
|
||||||
return new EnclosingBall<>(new Vector2D(centerX.doubleValue(),
|
return new EnclosingBall<Euclidean2D, Vector2D>(new Vector2D(centerX.doubleValue(),
|
||||||
centerY.doubleValue()),
|
centerY.doubleValue()),
|
||||||
FastMath.sqrt(r2.doubleValue()),
|
FastMath.sqrt(r2.doubleValue()),
|
||||||
vA, vB, vC);
|
vA, vB, vC);
|
||||||
|
|
|
@ -71,7 +71,7 @@ class NestedLoops {
|
||||||
* @since 3.3
|
* @since 3.3
|
||||||
*/
|
*/
|
||||||
NestedLoops(final double tolerance) {
|
NestedLoops(final double tolerance) {
|
||||||
this.surrounded = new ArrayList<>();
|
this.surrounded = new ArrayList<NestedLoops>();
|
||||||
this.tolerance = tolerance;
|
this.tolerance = tolerance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -90,11 +90,11 @@ class NestedLoops {
|
||||||
}
|
}
|
||||||
|
|
||||||
this.loop = loop;
|
this.loop = loop;
|
||||||
this.surrounded = new ArrayList<>();
|
this.surrounded = new ArrayList<NestedLoops>();
|
||||||
this.tolerance = tolerance;
|
this.tolerance = tolerance;
|
||||||
|
|
||||||
// build the polygon defined by the loop
|
// build the polygon defined by the loop
|
||||||
final ArrayList<SubHyperplane<Euclidean2D>> edges = new ArrayList<>();
|
final ArrayList<SubHyperplane<Euclidean2D>> edges = new ArrayList<SubHyperplane<Euclidean2D>>();
|
||||||
Vector2D current = loop[loop.length - 1];
|
Vector2D current = loop[loop.length - 1];
|
||||||
for (int i = 0; i < loop.length; ++i) {
|
for (int i = 0; i < loop.length; ++i) {
|
||||||
final Vector2D previous = current;
|
final Vector2D previous = current;
|
||||||
|
@ -152,7 +152,7 @@ class NestedLoops {
|
||||||
}
|
}
|
||||||
|
|
||||||
// we should be separate from the remaining children
|
// we should be separate from the remaining children
|
||||||
RegionFactory<Euclidean2D> factory = new RegionFactory<>();
|
RegionFactory<Euclidean2D> factory = new RegionFactory<Euclidean2D>();
|
||||||
for (final NestedLoops child : surrounded) {
|
for (final NestedLoops child : surrounded) {
|
||||||
if (!factory.intersection(node.polygon, child.polygon).isEmpty()) {
|
if (!factory.intersection(node.polygon, child.polygon).isEmpty()) {
|
||||||
throw new MathIllegalArgumentException(LocalizedFormats.CROSSING_BOUNDARY_LOOPS);
|
throw new MathIllegalArgumentException(LocalizedFormats.CROSSING_BOUNDARY_LOOPS);
|
||||||
|
|
|
@ -199,7 +199,7 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
final int n = vertices.length;
|
final int n = vertices.length;
|
||||||
if (n == 0) {
|
if (n == 0) {
|
||||||
// the tree represents the whole space
|
// the tree represents the whole space
|
||||||
return new BSPTree<>(Boolean.TRUE);
|
return new BSPTree<Euclidean2D>(Boolean.TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// build the vertices
|
// build the vertices
|
||||||
|
@ -209,7 +209,7 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// build the edges
|
// build the edges
|
||||||
List<Edge> edges = new ArrayList<>(n);
|
List<Edge> edges = new ArrayList<Edge>(n);
|
||||||
for (int i = 0; i < n; ++i) {
|
for (int i = 0; i < n; ++i) {
|
||||||
|
|
||||||
// get the endpoints of the edge
|
// get the endpoints of the edge
|
||||||
|
@ -238,7 +238,7 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// build the tree top-down
|
// build the tree top-down
|
||||||
final BSPTree<Euclidean2D> tree = new BSPTree<>();
|
final BSPTree<Euclidean2D> tree = new BSPTree<Euclidean2D>();
|
||||||
insertEdges(hyperplaneThickness, tree, edges);
|
insertEdges(hyperplaneThickness, tree, edges);
|
||||||
|
|
||||||
return tree;
|
return tree;
|
||||||
|
@ -287,8 +287,8 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
|
|
||||||
// we have split the node by inserting an edge as a cut sub-hyperplane
|
// we have split the node by inserting an edge as a cut sub-hyperplane
|
||||||
// distribute the remaining edges in the two sub-trees
|
// distribute the remaining edges in the two sub-trees
|
||||||
final List<Edge> plusList = new ArrayList<>();
|
final List<Edge> plusList = new ArrayList<Edge>();
|
||||||
final List<Edge> minusList = new ArrayList<>();
|
final List<Edge> minusList = new ArrayList<Edge>();
|
||||||
for (final Edge edge : edges) {
|
for (final Edge edge : edges) {
|
||||||
if (edge != inserted) {
|
if (edge != inserted) {
|
||||||
final double startOffset = inserted.getLine().getOffset((Point<Euclidean2D>) edge.getStart().getLocation());
|
final double startOffset = inserted.getLine().getOffset((Point<Euclidean2D>) edge.getStart().getLocation());
|
||||||
|
@ -365,7 +365,7 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
this.location = location;
|
this.location = location;
|
||||||
this.incoming = null;
|
this.incoming = null;
|
||||||
this.outgoing = null;
|
this.outgoing = null;
|
||||||
this.lines = new ArrayList<>();
|
this.lines = new ArrayList<Line>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get Vertex location.
|
/** Get Vertex location.
|
||||||
|
@ -640,7 +640,7 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// create the segment loops
|
// create the segment loops
|
||||||
final ArrayList<List<Segment>> loops = new ArrayList<>();
|
final ArrayList<List<Segment>> loops = new ArrayList<List<Segment>>();
|
||||||
for (ConnectableSegment s = getUnprocessed(segments); s != null; s = getUnprocessed(segments)) {
|
for (ConnectableSegment s = getUnprocessed(segments); s != null; s = getUnprocessed(segments)) {
|
||||||
final List<Segment> loop = followLoop(s);
|
final List<Segment> loop = followLoop(s);
|
||||||
if (loop != null) {
|
if (loop != null) {
|
||||||
|
@ -824,7 +824,7 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
*/
|
*/
|
||||||
private List<Segment> followLoop(final ConnectableSegment defining) {
|
private List<Segment> followLoop(final ConnectableSegment defining) {
|
||||||
|
|
||||||
final List<Segment> loop = new ArrayList<>();
|
final List<Segment> loop = new ArrayList<Segment>();
|
||||||
loop.add(defining);
|
loop.add(defining);
|
||||||
defining.setProcessed(true);
|
defining.setProcessed(true);
|
||||||
|
|
||||||
|
@ -998,7 +998,7 @@ public class PolygonsSet extends AbstractRegion<Euclidean2D, Euclidean1D> {
|
||||||
*/
|
*/
|
||||||
SegmentsBuilder(final double tolerance) {
|
SegmentsBuilder(final double tolerance) {
|
||||||
this.tolerance = tolerance;
|
this.tolerance = tolerance;
|
||||||
this.segments = new ArrayList<>();
|
this.segments = new ArrayList<ConnectableSegment>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
|
|
@ -83,7 +83,7 @@ public class SubLine extends AbstractSubHyperplane<Euclidean2D, Euclidean1D> {
|
||||||
|
|
||||||
final Line line = (Line) getHyperplane();
|
final Line line = (Line) getHyperplane();
|
||||||
final List<Interval> list = ((IntervalsSet) getRemainingRegion()).asList();
|
final List<Interval> list = ((IntervalsSet) getRemainingRegion()).asList();
|
||||||
final List<Segment> segments = new ArrayList<>(list.size());
|
final List<Segment> segments = new ArrayList<Segment>(list.size());
|
||||||
|
|
||||||
for (final Interval interval : list) {
|
for (final Interval interval : list) {
|
||||||
final Vector2D start = line.toSpace((Point<Euclidean1D>) new Vector1D(interval.getInf()));
|
final Vector2D start = line.toSpace((Point<Euclidean1D>) new Vector1D(interval.getInf()));
|
||||||
|
@ -168,11 +168,11 @@ public class SubLine extends AbstractSubHyperplane<Euclidean2D, Euclidean1D> {
|
||||||
// the lines are parallel
|
// the lines are parallel
|
||||||
final double global = otherLine.getOffset(thisLine);
|
final double global = otherLine.getOffset(thisLine);
|
||||||
if (global < -tolerance) {
|
if (global < -tolerance) {
|
||||||
return new SplitSubHyperplane<>(null, this);
|
return new SplitSubHyperplane<Euclidean2D>(null, this);
|
||||||
} else if (global > tolerance) {
|
} else if (global > tolerance) {
|
||||||
return new SplitSubHyperplane<>(this, null);
|
return new SplitSubHyperplane<Euclidean2D>(this, null);
|
||||||
} else {
|
} else {
|
||||||
return new SplitSubHyperplane<>(null, null);
|
return new SplitSubHyperplane<Euclidean2D>(null, null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -187,13 +187,13 @@ public class SubLine extends AbstractSubHyperplane<Euclidean2D, Euclidean1D> {
|
||||||
final BSPTree<Euclidean1D> splitTree = getRemainingRegion().getTree(false).split(subMinus);
|
final BSPTree<Euclidean1D> splitTree = getRemainingRegion().getTree(false).split(subMinus);
|
||||||
final BSPTree<Euclidean1D> plusTree = getRemainingRegion().isEmpty(splitTree.getPlus()) ?
|
final BSPTree<Euclidean1D> plusTree = getRemainingRegion().isEmpty(splitTree.getPlus()) ?
|
||||||
new BSPTree<Euclidean1D>(Boolean.FALSE) :
|
new BSPTree<Euclidean1D>(Boolean.FALSE) :
|
||||||
new BSPTree<>(subPlus, new BSPTree<Euclidean1D>(Boolean.FALSE),
|
new BSPTree<Euclidean1D>(subPlus, new BSPTree<Euclidean1D>(Boolean.FALSE),
|
||||||
splitTree.getPlus(), null);
|
splitTree.getPlus(), null);
|
||||||
final BSPTree<Euclidean1D> minusTree = getRemainingRegion().isEmpty(splitTree.getMinus()) ?
|
final BSPTree<Euclidean1D> minusTree = getRemainingRegion().isEmpty(splitTree.getMinus()) ?
|
||||||
new BSPTree<Euclidean1D>(Boolean.FALSE) :
|
new BSPTree<Euclidean1D>(Boolean.FALSE) :
|
||||||
new BSPTree<>(subMinus, new BSPTree<Euclidean1D>(Boolean.FALSE),
|
new BSPTree<Euclidean1D>(subMinus, new BSPTree<Euclidean1D>(Boolean.FALSE),
|
||||||
splitTree.getMinus(), null);
|
splitTree.getMinus(), null);
|
||||||
return new SplitSubHyperplane<>(new SubLine(thisLine.copySelf(), new IntervalsSet(plusTree, tolerance)),
|
return new SplitSubHyperplane<Euclidean2D>(new SubLine(thisLine.copySelf(), new IntervalsSet(plusTree, tolerance)),
|
||||||
new SubLine(thisLine.copySelf(), new IntervalsSet(minusTree, tolerance)));
|
new SubLine(thisLine.copySelf(), new IntervalsSet(minusTree, tolerance)));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -84,7 +84,7 @@ public final class AklToussaintHeuristic {
|
||||||
return points;
|
return points;
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<Vector2D> reducedPoints = new ArrayList<>(quadrilateral);
|
final List<Vector2D> reducedPoints = new ArrayList<Vector2D>(quadrilateral);
|
||||||
for (final Vector2D p : points) {
|
for (final Vector2D p : points) {
|
||||||
// check all points if they are within the quadrilateral
|
// check all points if they are within the quadrilateral
|
||||||
// in which case they can not be part of the convex hull
|
// in which case they can not be part of the convex hull
|
||||||
|
@ -103,7 +103,7 @@ public final class AklToussaintHeuristic {
|
||||||
* @return the quadrilateral
|
* @return the quadrilateral
|
||||||
*/
|
*/
|
||||||
private static List<Vector2D> buildQuadrilateral(final Vector2D... points) {
|
private static List<Vector2D> buildQuadrilateral(final Vector2D... points) {
|
||||||
List<Vector2D> quadrilateral = new ArrayList<>();
|
List<Vector2D> quadrilateral = new ArrayList<Vector2D>();
|
||||||
for (Vector2D p : points) {
|
for (Vector2D p : points) {
|
||||||
if (!quadrilateral.contains(p)) {
|
if (!quadrilateral.contains(p)) {
|
||||||
quadrilateral.add(p);
|
quadrilateral.add(p);
|
||||||
|
|
|
@ -163,7 +163,7 @@ public class ConvexHull2D implements ConvexHull<Euclidean2D, Vector2D>, Serializ
|
||||||
if (vertices.length < 3) {
|
if (vertices.length < 3) {
|
||||||
throw new InsufficientDataException();
|
throw new InsufficientDataException();
|
||||||
}
|
}
|
||||||
final RegionFactory<Euclidean2D> factory = new RegionFactory<>();
|
final RegionFactory<Euclidean2D> factory = new RegionFactory<Euclidean2D>();
|
||||||
final Segment[] segments = retrieveLineSegments();
|
final Segment[] segments = retrieveLineSegments();
|
||||||
final Line[] lineArray = new Line[segments.length];
|
final Line[] lineArray = new Line[segments.length];
|
||||||
for (int i = 0; i < segments.length; i++) {
|
for (int i = 0; i < segments.length; i++) {
|
||||||
|
|
|
@ -77,7 +77,7 @@ public class MonotoneChain extends AbstractConvexHullGenerator2D {
|
||||||
@Override
|
@Override
|
||||||
public Collection<Vector2D> findHullVertices(final Collection<Vector2D> points) {
|
public Collection<Vector2D> findHullVertices(final Collection<Vector2D> points) {
|
||||||
|
|
||||||
final List<Vector2D> pointsSortedByXAxis = new ArrayList<>(points);
|
final List<Vector2D> pointsSortedByXAxis = new ArrayList<Vector2D>(points);
|
||||||
|
|
||||||
// sort the points in increasing order on the x-axis
|
// sort the points in increasing order on the x-axis
|
||||||
Collections.sort(pointsSortedByXAxis, new Comparator<Vector2D>() {
|
Collections.sort(pointsSortedByXAxis, new Comparator<Vector2D>() {
|
||||||
|
@ -97,13 +97,13 @@ public class MonotoneChain extends AbstractConvexHullGenerator2D {
|
||||||
});
|
});
|
||||||
|
|
||||||
// build lower hull
|
// build lower hull
|
||||||
final List<Vector2D> lowerHull = new ArrayList<>();
|
final List<Vector2D> lowerHull = new ArrayList<Vector2D>();
|
||||||
for (Vector2D p : pointsSortedByXAxis) {
|
for (Vector2D p : pointsSortedByXAxis) {
|
||||||
updateHull(p, lowerHull);
|
updateHull(p, lowerHull);
|
||||||
}
|
}
|
||||||
|
|
||||||
// build upper hull
|
// build upper hull
|
||||||
final List<Vector2D> upperHull = new ArrayList<>();
|
final List<Vector2D> upperHull = new ArrayList<Vector2D>();
|
||||||
for (int idx = pointsSortedByXAxis.size() - 1; idx >= 0; idx--) {
|
for (int idx = pointsSortedByXAxis.size() - 1; idx >= 0; idx--) {
|
||||||
final Vector2D p = pointsSortedByXAxis.get(idx);
|
final Vector2D p = pointsSortedByXAxis.get(idx);
|
||||||
updateHull(p, upperHull);
|
updateHull(p, upperHull);
|
||||||
|
@ -111,7 +111,7 @@ public class MonotoneChain extends AbstractConvexHullGenerator2D {
|
||||||
|
|
||||||
// concatenate the lower and upper hulls
|
// concatenate the lower and upper hulls
|
||||||
// the last point of each list is omitted as it is repeated at the beginning of the other list
|
// the last point of each list is omitted as it is repeated at the beginning of the other list
|
||||||
final List<Vector2D> hullVertices = new ArrayList<>(lowerHull.size() + upperHull.size() - 2);
|
final List<Vector2D> hullVertices = new ArrayList<Vector2D>(lowerHull.size() + upperHull.size() - 2);
|
||||||
for (int idx = 0; idx < lowerHull.size() - 1; idx++) {
|
for (int idx = 0; idx < lowerHull.size() - 1; idx++) {
|
||||||
hullVertices.add(lowerHull.get(idx));
|
hullVertices.add(lowerHull.get(idx));
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,7 +53,7 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
* @param tolerance tolerance below which points are considered identical.
|
* @param tolerance tolerance below which points are considered identical.
|
||||||
*/
|
*/
|
||||||
protected AbstractRegion(final double tolerance) {
|
protected AbstractRegion(final double tolerance) {
|
||||||
this.tree = new BSPTree<>(Boolean.TRUE);
|
this.tree = new BSPTree<S>(Boolean.TRUE);
|
||||||
this.tolerance = tolerance;
|
this.tolerance = tolerance;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -102,14 +102,14 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
if (boundary.size() == 0) {
|
if (boundary.size() == 0) {
|
||||||
|
|
||||||
// the tree represents the whole space
|
// the tree represents the whole space
|
||||||
tree = new BSPTree<>(Boolean.TRUE);
|
tree = new BSPTree<S>(Boolean.TRUE);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
// sort the boundary elements in decreasing size order
|
// sort the boundary elements in decreasing size order
|
||||||
// (we don't want equal size elements to be removed, so
|
// (we don't want equal size elements to be removed, so
|
||||||
// we use a trick to fool the TreeSet)
|
// we use a trick to fool the TreeSet)
|
||||||
final TreeSet<SubHyperplane<S>> ordered = new TreeSet<>(new Comparator<SubHyperplane<S>>() {
|
final TreeSet<SubHyperplane<S>> ordered = new TreeSet<SubHyperplane<S>>(new Comparator<SubHyperplane<S>>() {
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public int compare(final SubHyperplane<S> o1, final SubHyperplane<S> o2) {
|
public int compare(final SubHyperplane<S> o1, final SubHyperplane<S> o2) {
|
||||||
|
@ -121,7 +121,7 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
ordered.addAll(boundary);
|
ordered.addAll(boundary);
|
||||||
|
|
||||||
// build the tree top-down
|
// build the tree top-down
|
||||||
tree = new BSPTree<>();
|
tree = new BSPTree<S>();
|
||||||
insertCuts(tree, ordered);
|
insertCuts(tree, ordered);
|
||||||
|
|
||||||
// set up the inside/outside flags
|
// set up the inside/outside flags
|
||||||
|
@ -161,7 +161,7 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
public AbstractRegion(final Hyperplane<S>[] hyperplanes, final double tolerance) {
|
public AbstractRegion(final Hyperplane<S>[] hyperplanes, final double tolerance) {
|
||||||
this.tolerance = tolerance;
|
this.tolerance = tolerance;
|
||||||
if ((hyperplanes == null) || (hyperplanes.length == 0)) {
|
if ((hyperplanes == null) || (hyperplanes.length == 0)) {
|
||||||
tree = new BSPTree<>(Boolean.FALSE);
|
tree = new BSPTree<S>(Boolean.FALSE);
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
// use the first hyperplane to build the right class
|
// use the first hyperplane to build the right class
|
||||||
|
@ -218,8 +218,8 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
}
|
}
|
||||||
|
|
||||||
// distribute the remaining edges in the two sub-trees
|
// distribute the remaining edges in the two sub-trees
|
||||||
final ArrayList<SubHyperplane<S>> plusList = new ArrayList<>();
|
final ArrayList<SubHyperplane<S>> plusList = new ArrayList<SubHyperplane<S>>();
|
||||||
final ArrayList<SubHyperplane<S>> minusList = new ArrayList<>();
|
final ArrayList<SubHyperplane<S>> minusList = new ArrayList<SubHyperplane<S>>();
|
||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
final SubHyperplane<S> other = iterator.next();
|
final SubHyperplane<S> other = iterator.next();
|
||||||
final SubHyperplane.SplitSubHyperplane<S> split = other.split(inserted);
|
final SubHyperplane.SplitSubHyperplane<S> split = other.split(inserted);
|
||||||
|
@ -310,7 +310,7 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public BoundaryProjection<S> projectToBoundary(final Point<S> point) {
|
public BoundaryProjection<S> projectToBoundary(final Point<S> point) {
|
||||||
final BoundaryProjector<S, T> projector = new BoundaryProjector<>(point);
|
final BoundaryProjector<S, T> projector = new BoundaryProjector<S, T>(point);
|
||||||
getTree(true).visit(projector);
|
getTree(true).visit(projector);
|
||||||
return projector.getProjection();
|
return projector.getProjection();
|
||||||
}
|
}
|
||||||
|
@ -376,7 +376,7 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public double getBoundarySize() {
|
public double getBoundarySize() {
|
||||||
final BoundarySizeVisitor<S> visitor = new BoundarySizeVisitor<>();
|
final BoundarySizeVisitor<S> visitor = new BoundarySizeVisitor<S>();
|
||||||
getTree(true).visit(visitor);
|
getTree(true).visit(visitor);
|
||||||
return visitor.getSize();
|
return visitor.getSize();
|
||||||
}
|
}
|
||||||
|
@ -485,7 +485,7 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
public AbstractRegion<S, T> applyTransform(final Transform<S, T> transform) {
|
public AbstractRegion<S, T> applyTransform(final Transform<S, T> transform) {
|
||||||
|
|
||||||
// transform the tree, except for boundary attribute splitters
|
// transform the tree, except for boundary attribute splitters
|
||||||
final Map<BSPTree<S>, BSPTree<S>> map = new HashMap<>();
|
final Map<BSPTree<S>, BSPTree<S>> map = new HashMap<BSPTree<S>, BSPTree<S>>();
|
||||||
final BSPTree<S> transformedTree = recurseTransform(getTree(false), transform, map);
|
final BSPTree<S> transformedTree = recurseTransform(getTree(false), transform, map);
|
||||||
|
|
||||||
// set up the boundary attributes splitters
|
// set up the boundary attributes splitters
|
||||||
|
@ -519,7 +519,7 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
|
|
||||||
final BSPTree<S> transformedNode;
|
final BSPTree<S> transformedNode;
|
||||||
if (node.getCut() == null) {
|
if (node.getCut() == null) {
|
||||||
transformedNode = new BSPTree<>(node.getAttribute());
|
transformedNode = new BSPTree<S>(node.getAttribute());
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
final SubHyperplane<S> sub = node.getCut();
|
final SubHyperplane<S> sub = node.getCut();
|
||||||
|
@ -531,10 +531,10 @@ public abstract class AbstractRegion<S extends Space, T extends Space> implement
|
||||||
final SubHyperplane<S> tPI = (attribute.getPlusInside() == null) ?
|
final SubHyperplane<S> tPI = (attribute.getPlusInside() == null) ?
|
||||||
null : ((AbstractSubHyperplane<S, T>) attribute.getPlusInside()).applyTransform(transform);
|
null : ((AbstractSubHyperplane<S, T>) attribute.getPlusInside()).applyTransform(transform);
|
||||||
// we start with an empty list of splitters, it will be filled in out of recursion
|
// we start with an empty list of splitters, it will be filled in out of recursion
|
||||||
attribute = new BoundaryAttribute<>(tPO, tPI, new NodesSet<S>());
|
attribute = new BoundaryAttribute<S>(tPO, tPI, new NodesSet<S>());
|
||||||
}
|
}
|
||||||
|
|
||||||
transformedNode = new BSPTree<>(tSub,
|
transformedNode = new BSPTree<S>(tSub,
|
||||||
recurseTransform(node.getPlus(), transform, map),
|
recurseTransform(node.getPlus(), transform, map),
|
||||||
recurseTransform(node.getMinus(), transform, map),
|
recurseTransform(node.getMinus(), transform, map),
|
||||||
attribute);
|
attribute);
|
||||||
|
|
|
@ -116,7 +116,7 @@ public abstract class AbstractSubHyperplane<S extends Space, T extends Space>
|
||||||
final Hyperplane<S> tHyperplane = transform.apply(hyperplane);
|
final Hyperplane<S> tHyperplane = transform.apply(hyperplane);
|
||||||
|
|
||||||
// transform the tree, except for boundary attribute splitters
|
// transform the tree, except for boundary attribute splitters
|
||||||
final Map<BSPTree<T>, BSPTree<T>> map = new HashMap<>();
|
final Map<BSPTree<T>, BSPTree<T>> map = new HashMap<BSPTree<T>, BSPTree<T>>();
|
||||||
final BSPTree<T> tTree =
|
final BSPTree<T> tTree =
|
||||||
recurseTransform(remainingRegion.getTree(false), tHyperplane, transform, map);
|
recurseTransform(remainingRegion.getTree(false), tHyperplane, transform, map);
|
||||||
|
|
||||||
|
@ -153,7 +153,7 @@ public abstract class AbstractSubHyperplane<S extends Space, T extends Space>
|
||||||
|
|
||||||
final BSPTree<T> transformedNode;
|
final BSPTree<T> transformedNode;
|
||||||
if (node.getCut() == null) {
|
if (node.getCut() == null) {
|
||||||
transformedNode = new BSPTree<>(node.getAttribute());
|
transformedNode = new BSPTree<T>(node.getAttribute());
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
|
@ -164,10 +164,10 @@ public abstract class AbstractSubHyperplane<S extends Space, T extends Space>
|
||||||
final SubHyperplane<T> tPI = (attribute.getPlusInside() == null) ?
|
final SubHyperplane<T> tPI = (attribute.getPlusInside() == null) ?
|
||||||
null : transform.apply(attribute.getPlusInside(), hyperplane, transformed);
|
null : transform.apply(attribute.getPlusInside(), hyperplane, transformed);
|
||||||
// we start with an empty list of splitters, it will be filled in out of recursion
|
// we start with an empty list of splitters, it will be filled in out of recursion
|
||||||
attribute = new BoundaryAttribute<>(tPO, tPI, new NodesSet<T>());
|
attribute = new BoundaryAttribute<T>(tPO, tPI, new NodesSet<T>());
|
||||||
}
|
}
|
||||||
|
|
||||||
transformedNode = new BSPTree<>(transform.apply(node.getCut(), hyperplane, transformed),
|
transformedNode = new BSPTree<T>(transform.apply(node.getCut(), hyperplane, transformed),
|
||||||
recurseTransform(node.getPlus(), transformed, transform, map),
|
recurseTransform(node.getPlus(), transformed, transform, map),
|
||||||
recurseTransform(node.getMinus(), transformed, transform, map),
|
recurseTransform(node.getMinus(), transformed, transform, map),
|
||||||
attribute);
|
attribute);
|
||||||
|
|
|
@ -163,9 +163,9 @@ public class BSPTree<S extends Space> {
|
||||||
}
|
}
|
||||||
|
|
||||||
cut = chopped;
|
cut = chopped;
|
||||||
plus = new BSPTree<>();
|
plus = new BSPTree<S>();
|
||||||
plus.parent = this;
|
plus.parent = this;
|
||||||
minus = new BSPTree<>();
|
minus = new BSPTree<S>();
|
||||||
minus.parent = this;
|
minus.parent = this;
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
@ -181,10 +181,10 @@ public class BSPTree<S extends Space> {
|
||||||
public BSPTree<S> copySelf() {
|
public BSPTree<S> copySelf() {
|
||||||
|
|
||||||
if (cut == null) {
|
if (cut == null) {
|
||||||
return new BSPTree<>(attribute);
|
return new BSPTree<S>(attribute);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new BSPTree<>(cut.copySelf(), plus.copySelf(), minus.copySelf(),
|
return new BSPTree<S>(cut.copySelf(), plus.copySelf(), minus.copySelf(),
|
||||||
attribute);
|
attribute);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -340,7 +340,7 @@ public class BSPTree<S extends Space> {
|
||||||
* than maxOffset from the point)
|
* than maxOffset from the point)
|
||||||
*/
|
*/
|
||||||
public List<BSPTree<S>> getCloseCuts(final Point<S> point, final double maxOffset) {
|
public List<BSPTree<S>> getCloseCuts(final Point<S> point, final double maxOffset) {
|
||||||
final List<BSPTree<S>> close = new ArrayList<>();
|
final List<BSPTree<S>> close = new ArrayList<BSPTree<S>>();
|
||||||
recurseCloseCuts(point, maxOffset, close);
|
recurseCloseCuts(point, maxOffset, close);
|
||||||
return close;
|
return close;
|
||||||
}
|
}
|
||||||
|
@ -554,7 +554,7 @@ public class BSPTree<S extends Space> {
|
||||||
public BSPTree<S> split(final SubHyperplane<S> sub) {
|
public BSPTree<S> split(final SubHyperplane<S> sub) {
|
||||||
|
|
||||||
if (cut == null) {
|
if (cut == null) {
|
||||||
return new BSPTree<>(sub, copySelf(), new BSPTree<S>(attribute), null);
|
return new BSPTree<S>(sub, copySelf(), new BSPTree<S>(attribute), null);
|
||||||
}
|
}
|
||||||
|
|
||||||
final Hyperplane<S> cHyperplane = cut.getHyperplane();
|
final Hyperplane<S> cHyperplane = cut.getHyperplane();
|
||||||
|
@ -566,12 +566,12 @@ public class BSPTree<S extends Space> {
|
||||||
final BSPTree<S> split = plus.split(sub);
|
final BSPTree<S> split = plus.split(sub);
|
||||||
if (cut.split(sHyperplane).getSide() == Side.PLUS) {
|
if (cut.split(sHyperplane).getSide() == Side.PLUS) {
|
||||||
split.plus =
|
split.plus =
|
||||||
new BSPTree<>(cut.copySelf(), split.plus, minus.copySelf(), attribute);
|
new BSPTree<S>(cut.copySelf(), split.plus, minus.copySelf(), attribute);
|
||||||
split.plus.condense();
|
split.plus.condense();
|
||||||
split.plus.parent = split;
|
split.plus.parent = split;
|
||||||
} else {
|
} else {
|
||||||
split.minus =
|
split.minus =
|
||||||
new BSPTree<>(cut.copySelf(), split.minus, minus.copySelf(), attribute);
|
new BSPTree<S>(cut.copySelf(), split.minus, minus.copySelf(), attribute);
|
||||||
split.minus.condense();
|
split.minus.condense();
|
||||||
split.minus.parent = split;
|
split.minus.parent = split;
|
||||||
}
|
}
|
||||||
|
@ -582,12 +582,12 @@ public class BSPTree<S extends Space> {
|
||||||
final BSPTree<S> split = minus.split(sub);
|
final BSPTree<S> split = minus.split(sub);
|
||||||
if (cut.split(sHyperplane).getSide() == Side.PLUS) {
|
if (cut.split(sHyperplane).getSide() == Side.PLUS) {
|
||||||
split.plus =
|
split.plus =
|
||||||
new BSPTree<>(cut.copySelf(), plus.copySelf(), split.plus, attribute);
|
new BSPTree<S>(cut.copySelf(), plus.copySelf(), split.plus, attribute);
|
||||||
split.plus.condense();
|
split.plus.condense();
|
||||||
split.plus.parent = split;
|
split.plus.parent = split;
|
||||||
} else {
|
} else {
|
||||||
split.minus =
|
split.minus =
|
||||||
new BSPTree<>(cut.copySelf(), plus.copySelf(), split.minus, attribute);
|
new BSPTree<S>(cut.copySelf(), plus.copySelf(), split.minus, attribute);
|
||||||
split.minus.condense();
|
split.minus.condense();
|
||||||
split.minus.parent = split;
|
split.minus.parent = split;
|
||||||
}
|
}
|
||||||
|
@ -597,7 +597,7 @@ public class BSPTree<S extends Space> {
|
||||||
{
|
{
|
||||||
final SubHyperplane.SplitSubHyperplane<S> cutParts = cut.split(sHyperplane);
|
final SubHyperplane.SplitSubHyperplane<S> cutParts = cut.split(sHyperplane);
|
||||||
final BSPTree<S> split =
|
final BSPTree<S> split =
|
||||||
new BSPTree<>(sub, plus.split(subParts.getPlus()), minus.split(subParts.getMinus()),
|
new BSPTree<S>(sub, plus.split(subParts.getPlus()), minus.split(subParts.getMinus()),
|
||||||
null);
|
null);
|
||||||
split.plus.cut = cutParts.getPlus();
|
split.plus.cut = cutParts.getPlus();
|
||||||
split.minus.cut = cutParts.getMinus();
|
split.minus.cut = cutParts.getMinus();
|
||||||
|
@ -612,8 +612,8 @@ public class BSPTree<S extends Space> {
|
||||||
}
|
}
|
||||||
default :
|
default :
|
||||||
return cHyperplane.sameOrientationAs(sHyperplane) ?
|
return cHyperplane.sameOrientationAs(sHyperplane) ?
|
||||||
new BSPTree<>(sub, plus.copySelf(), minus.copySelf(), attribute) :
|
new BSPTree<S>(sub, plus.copySelf(), minus.copySelf(), attribute) :
|
||||||
new BSPTree<>(sub, minus.copySelf(), plus.copySelf(), attribute);
|
new BSPTree<S>(sub, minus.copySelf(), plus.copySelf(), attribute);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -710,16 +710,16 @@ public class BSPTree<S extends Space> {
|
||||||
final Object internalAttributes) {
|
final Object internalAttributes) {
|
||||||
|
|
||||||
// build the current cell leaf
|
// build the current cell leaf
|
||||||
BSPTree<S> tree = new BSPTree<>(cellAttribute);
|
BSPTree<S> tree = new BSPTree<S>(cellAttribute);
|
||||||
|
|
||||||
// build the pruned tree bottom-up
|
// build the pruned tree bottom-up
|
||||||
for (BSPTree<S> current = this; current.parent != null; current = current.parent) {
|
for (BSPTree<S> current = this; current.parent != null; current = current.parent) {
|
||||||
final SubHyperplane<S> parentCut = current.parent.cut.copySelf();
|
final SubHyperplane<S> parentCut = current.parent.cut.copySelf();
|
||||||
final BSPTree<S> sibling = new BSPTree<>(otherLeafsAttributes);
|
final BSPTree<S> sibling = new BSPTree<S>(otherLeafsAttributes);
|
||||||
if (current == current.parent.plus) {
|
if (current == current.parent.plus) {
|
||||||
tree = new BSPTree<>(parentCut, tree, sibling, internalAttributes);
|
tree = new BSPTree<S>(parentCut, tree, sibling, internalAttributes);
|
||||||
} else {
|
} else {
|
||||||
tree = new BSPTree<>(parentCut, sibling, tree, internalAttributes);
|
tree = new BSPTree<S>(parentCut, sibling, tree, internalAttributes);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -44,18 +44,18 @@ class BoundaryBuilder<S extends Space> implements BSPTreeVisitor<S> {
|
||||||
|
|
||||||
// characterize the cut sub-hyperplane,
|
// characterize the cut sub-hyperplane,
|
||||||
// first with respect to the plus sub-tree
|
// first with respect to the plus sub-tree
|
||||||
final Characterization<S> plusChar = new Characterization<>(node.getPlus(), node.getCut().copySelf());
|
final Characterization<S> plusChar = new Characterization<S>(node.getPlus(), node.getCut().copySelf());
|
||||||
|
|
||||||
if (plusChar.touchOutside()) {
|
if (plusChar.touchOutside()) {
|
||||||
// plusChar.outsideTouching() corresponds to a subset of the cut sub-hyperplane
|
// plusChar.outsideTouching() corresponds to a subset of the cut sub-hyperplane
|
||||||
// known to have outside cells on its plus side, we want to check if parts
|
// known to have outside cells on its plus side, we want to check if parts
|
||||||
// of this subset do have inside cells on their minus side
|
// of this subset do have inside cells on their minus side
|
||||||
final Characterization<S> minusChar = new Characterization<>(node.getMinus(), plusChar.outsideTouching());
|
final Characterization<S> minusChar = new Characterization<S>(node.getMinus(), plusChar.outsideTouching());
|
||||||
if (minusChar.touchInside()) {
|
if (minusChar.touchInside()) {
|
||||||
// this part belongs to the boundary,
|
// this part belongs to the boundary,
|
||||||
// it has the outside on its plus side and the inside on its minus side
|
// it has the outside on its plus side and the inside on its minus side
|
||||||
plusOutside = minusChar.insideTouching();
|
plusOutside = minusChar.insideTouching();
|
||||||
splitters = new NodesSet<>();
|
splitters = new NodesSet<S>();
|
||||||
splitters.addAll(minusChar.getInsideSplitters());
|
splitters.addAll(minusChar.getInsideSplitters());
|
||||||
splitters.addAll(plusChar.getOutsideSplitters());
|
splitters.addAll(plusChar.getOutsideSplitters());
|
||||||
}
|
}
|
||||||
|
@ -65,13 +65,13 @@ class BoundaryBuilder<S extends Space> implements BSPTreeVisitor<S> {
|
||||||
// plusChar.insideTouching() corresponds to a subset of the cut sub-hyperplane
|
// plusChar.insideTouching() corresponds to a subset of the cut sub-hyperplane
|
||||||
// known to have inside cells on its plus side, we want to check if parts
|
// known to have inside cells on its plus side, we want to check if parts
|
||||||
// of this subset do have outside cells on their minus side
|
// of this subset do have outside cells on their minus side
|
||||||
final Characterization<S> minusChar = new Characterization<>(node.getMinus(), plusChar.insideTouching());
|
final Characterization<S> minusChar = new Characterization<S>(node.getMinus(), plusChar.insideTouching());
|
||||||
if (minusChar.touchOutside()) {
|
if (minusChar.touchOutside()) {
|
||||||
// this part belongs to the boundary,
|
// this part belongs to the boundary,
|
||||||
// it has the inside on its plus side and the outside on its minus side
|
// it has the inside on its plus side and the outside on its minus side
|
||||||
plusInside = minusChar.outsideTouching();
|
plusInside = minusChar.outsideTouching();
|
||||||
if (splitters == null) {
|
if (splitters == null) {
|
||||||
splitters = new NodesSet<>();
|
splitters = new NodesSet<S>();
|
||||||
}
|
}
|
||||||
splitters.addAll(minusChar.getOutsideSplitters());
|
splitters.addAll(minusChar.getOutsideSplitters());
|
||||||
splitters.addAll(plusChar.getInsideSplitters());
|
splitters.addAll(plusChar.getInsideSplitters());
|
||||||
|
@ -86,7 +86,7 @@ class BoundaryBuilder<S extends Space> implements BSPTreeVisitor<S> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// set the boundary attribute at non-leaf nodes
|
// set the boundary attribute at non-leaf nodes
|
||||||
node.setAttribute(new BoundaryAttribute<>(plusOutside, plusInside, splitters));
|
node.setAttribute(new BoundaryAttribute<S>(plusOutside, plusInside, splitters));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -130,7 +130,7 @@ class BoundaryProjector<S extends Space, T extends Space> implements BSPTreeVisi
|
||||||
// fix offset sign
|
// fix offset sign
|
||||||
offset = FastMath.copySign(offset, (Boolean) leaf.getAttribute() ? -1 : +1);
|
offset = FastMath.copySign(offset, (Boolean) leaf.getAttribute() ? -1 : +1);
|
||||||
|
|
||||||
return new BoundaryProjection<>(original, projected, offset);
|
return new BoundaryProjection<S>(original, projected, offset);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,7 +140,7 @@ class BoundaryProjector<S extends Space, T extends Space> implements BSPTreeVisi
|
||||||
*/
|
*/
|
||||||
private List<Region<T>> boundaryRegions(final BSPTree<S> node) {
|
private List<Region<T>> boundaryRegions(final BSPTree<S> node) {
|
||||||
|
|
||||||
final List<Region<T>> regions = new ArrayList<>(2);
|
final List<Region<T>> regions = new ArrayList<Region<T>>(2);
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
final BoundaryAttribute<S> ba = (BoundaryAttribute<S>) node.getAttribute();
|
final BoundaryAttribute<S> ba = (BoundaryAttribute<S>) node.getAttribute();
|
||||||
|
|
|
@ -56,8 +56,8 @@ class Characterization<S extends Space> {
|
||||||
Characterization(final BSPTree<S> node, final SubHyperplane<S> sub) {
|
Characterization(final BSPTree<S> node, final SubHyperplane<S> sub) {
|
||||||
outsideTouching = null;
|
outsideTouching = null;
|
||||||
insideTouching = null;
|
insideTouching = null;
|
||||||
outsideSplitters = new NodesSet<>();
|
outsideSplitters = new NodesSet<S>();
|
||||||
insideSplitters = new NodesSet<>();
|
insideSplitters = new NodesSet<S>();
|
||||||
characterize(node, sub, new ArrayList<BSPTree<S>>());
|
characterize(node, sub, new ArrayList<BSPTree<S>>());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ public class NodesSet<S extends Space> implements Iterable<BSPTree<S>> {
|
||||||
/** Simple constructor.
|
/** Simple constructor.
|
||||||
*/
|
*/
|
||||||
public NodesSet() {
|
public NodesSet() {
|
||||||
list = new ArrayList<>();
|
list = new ArrayList<BSPTree<S>>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Add a node if not already known.
|
/** Add a node if not already known.
|
||||||
|
|
|
@ -176,7 +176,7 @@ public class RegionFactory<S extends Space> {
|
||||||
private BSPTree<S> recurseComplement(final BSPTree<S> node) {
|
private BSPTree<S> recurseComplement(final BSPTree<S> node) {
|
||||||
|
|
||||||
// transform the tree, except for boundary attribute splitters
|
// transform the tree, except for boundary attribute splitters
|
||||||
final Map<BSPTree<S>, BSPTree<S>> map = new HashMap<>();
|
final Map<BSPTree<S>, BSPTree<S>> map = new HashMap<BSPTree<S>, BSPTree<S>>();
|
||||||
final BSPTree<S> transformedTree = recurseComplement(node, map);
|
final BSPTree<S> transformedTree = recurseComplement(node, map);
|
||||||
|
|
||||||
// set up the boundary attributes splitters
|
// set up the boundary attributes splitters
|
||||||
|
@ -208,7 +208,7 @@ public class RegionFactory<S extends Space> {
|
||||||
|
|
||||||
final BSPTree<S> transformedNode;
|
final BSPTree<S> transformedNode;
|
||||||
if (node.getCut() == null) {
|
if (node.getCut() == null) {
|
||||||
transformedNode = new BSPTree<>(((Boolean) node.getAttribute()) ? Boolean.FALSE : Boolean.TRUE);
|
transformedNode = new BSPTree<S>(((Boolean) node.getAttribute()) ? Boolean.FALSE : Boolean.TRUE);
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
|
@ -219,10 +219,10 @@ public class RegionFactory<S extends Space> {
|
||||||
final SubHyperplane<S> plusInside =
|
final SubHyperplane<S> plusInside =
|
||||||
(attribute.getPlusOutside() == null) ? null : attribute.getPlusOutside().copySelf();
|
(attribute.getPlusOutside() == null) ? null : attribute.getPlusOutside().copySelf();
|
||||||
// we start with an empty list of splitters, it will be filled in out of recursion
|
// we start with an empty list of splitters, it will be filled in out of recursion
|
||||||
attribute = new BoundaryAttribute<>(plusOutside, plusInside, new NodesSet<S>());
|
attribute = new BoundaryAttribute<S>(plusOutside, plusInside, new NodesSet<S>());
|
||||||
}
|
}
|
||||||
|
|
||||||
transformedNode = new BSPTree<>(node.getCut().copySelf(),
|
transformedNode = new BSPTree<S>(node.getCut().copySelf(),
|
||||||
recurseComplement(node.getPlus(), map),
|
recurseComplement(node.getPlus(), map),
|
||||||
recurseComplement(node.getMinus(), map),
|
recurseComplement(node.getMinus(), map),
|
||||||
attribute);
|
attribute);
|
||||||
|
@ -330,7 +330,7 @@ public class RegionFactory<S extends Space> {
|
||||||
final BSPTree<S> cell = node.pruneAroundConvexCell(Boolean.TRUE, Boolean.FALSE, null);
|
final BSPTree<S> cell = node.pruneAroundConvexCell(Boolean.TRUE, Boolean.FALSE, null);
|
||||||
final Region<S> r = region1.buildNew(cell);
|
final Region<S> r = region1.buildNew(cell);
|
||||||
final Point<S> p = r.getBarycenter();
|
final Point<S> p = r.getBarycenter();
|
||||||
return new BSPTree<>(region1.checkPoint(p) == Location.INSIDE &&
|
return new BSPTree<S>(region1.checkPoint(p) == Location.INSIDE &&
|
||||||
region2.checkPoint(p) == Location.OUTSIDE);
|
region2.checkPoint(p) == Location.OUTSIDE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -376,10 +376,10 @@ public class RegionFactory<S extends Space> {
|
||||||
public BSPTree<S> fixNode(final BSPTree<S> node) {
|
public BSPTree<S> fixNode(final BSPTree<S> node) {
|
||||||
if (node.getPlus().getAttribute().equals(node.getMinus().getAttribute())) {
|
if (node.getPlus().getAttribute().equals(node.getMinus().getAttribute())) {
|
||||||
// no ambiguity
|
// no ambiguity
|
||||||
return new BSPTree<>(node.getPlus().getAttribute());
|
return new BSPTree<S>(node.getPlus().getAttribute());
|
||||||
} else {
|
} else {
|
||||||
// ambiguous node
|
// ambiguous node
|
||||||
return new BSPTree<>(inside);
|
return new BSPTree<S>(inside);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -132,7 +132,7 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
|
|
||||||
if (Precision.equals(lower, upper, 0) || (upper - lower) >= MathUtils.TWO_PI) {
|
if (Precision.equals(lower, upper, 0) || (upper - lower) >= MathUtils.TWO_PI) {
|
||||||
// the tree must cover the whole circle
|
// the tree must cover the whole circle
|
||||||
return new BSPTree<>(Boolean.TRUE);
|
return new BSPTree<Sphere1D>(Boolean.TRUE);
|
||||||
} else if (lower > upper) {
|
} else if (lower > upper) {
|
||||||
throw new NumberIsTooLargeException(LocalizedFormats.ENDPOINTS_NOT_AN_INTERVAL,
|
throw new NumberIsTooLargeException(LocalizedFormats.ENDPOINTS_NOT_AN_INTERVAL,
|
||||||
lower, upper, true);
|
lower, upper, true);
|
||||||
|
@ -148,9 +148,9 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
// simple arc starting after 0 and ending before 2 \pi
|
// simple arc starting after 0 and ending before 2 \pi
|
||||||
final SubHyperplane<Sphere1D> upperCut =
|
final SubHyperplane<Sphere1D> upperCut =
|
||||||
new LimitAngle(new S1Point(normalizedUpper), true, tolerance).wholeHyperplane();
|
new LimitAngle(new S1Point(normalizedUpper), true, tolerance).wholeHyperplane();
|
||||||
return new BSPTree<>(lowerCut,
|
return new BSPTree<Sphere1D>(lowerCut,
|
||||||
new BSPTree<Sphere1D>(Boolean.FALSE),
|
new BSPTree<Sphere1D>(Boolean.FALSE),
|
||||||
new BSPTree<>(upperCut,
|
new BSPTree<Sphere1D>(upperCut,
|
||||||
new BSPTree<Sphere1D>(Boolean.FALSE),
|
new BSPTree<Sphere1D>(Boolean.FALSE),
|
||||||
new BSPTree<Sphere1D>(Boolean.TRUE),
|
new BSPTree<Sphere1D>(Boolean.TRUE),
|
||||||
null),
|
null),
|
||||||
|
@ -159,8 +159,8 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
// arc wrapping around 2 \pi
|
// arc wrapping around 2 \pi
|
||||||
final SubHyperplane<Sphere1D> upperCut =
|
final SubHyperplane<Sphere1D> upperCut =
|
||||||
new LimitAngle(new S1Point(normalizedUpper - MathUtils.TWO_PI), true, tolerance).wholeHyperplane();
|
new LimitAngle(new S1Point(normalizedUpper - MathUtils.TWO_PI), true, tolerance).wholeHyperplane();
|
||||||
return new BSPTree<>(lowerCut,
|
return new BSPTree<Sphere1D>(lowerCut,
|
||||||
new BSPTree<>(upperCut,
|
new BSPTree<Sphere1D>(upperCut,
|
||||||
new BSPTree<Sphere1D>(Boolean.FALSE),
|
new BSPTree<Sphere1D>(Boolean.FALSE),
|
||||||
new BSPTree<Sphere1D>(Boolean.TRUE),
|
new BSPTree<Sphere1D>(Boolean.TRUE),
|
||||||
null),
|
null),
|
||||||
|
@ -504,9 +504,9 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
final double previousOffset = alpha - previous;
|
final double previousOffset = alpha - previous;
|
||||||
final double currentOffset = a[0] - alpha;
|
final double currentOffset = a[0] - alpha;
|
||||||
if (previousOffset < currentOffset) {
|
if (previousOffset < currentOffset) {
|
||||||
return new BoundaryProjection<>(point, new S1Point(previous), previousOffset);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(previous), previousOffset);
|
||||||
} else {
|
} else {
|
||||||
return new BoundaryProjection<>(point, new S1Point(a[0]), currentOffset);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(a[0]), currentOffset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (alpha <= a[1]) {
|
} else if (alpha <= a[1]) {
|
||||||
|
@ -515,9 +515,9 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
final double offset0 = a[0] - alpha;
|
final double offset0 = a[0] - alpha;
|
||||||
final double offset1 = alpha - a[1];
|
final double offset1 = alpha - a[1];
|
||||||
if (offset0 < offset1) {
|
if (offset0 < offset1) {
|
||||||
return new BoundaryProjection<>(point, new S1Point(a[1]), offset1);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(a[1]), offset1);
|
||||||
} else {
|
} else {
|
||||||
return new BoundaryProjection<>(point, new S1Point(a[0]), offset0);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(a[0]), offset0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -527,7 +527,7 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
if (Double.isNaN(previous)) {
|
if (Double.isNaN(previous)) {
|
||||||
|
|
||||||
// there are no points at all in the arcs set
|
// there are no points at all in the arcs set
|
||||||
return new BoundaryProjection<>(point, null, MathUtils.TWO_PI);
|
return new BoundaryProjection<Sphere1D>(point, null, MathUtils.TWO_PI);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
@ -538,18 +538,18 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
final double previousOffset = alpha - (previous - MathUtils.TWO_PI);
|
final double previousOffset = alpha - (previous - MathUtils.TWO_PI);
|
||||||
final double currentOffset = first - alpha;
|
final double currentOffset = first - alpha;
|
||||||
if (previousOffset < currentOffset) {
|
if (previousOffset < currentOffset) {
|
||||||
return new BoundaryProjection<>(point, new S1Point(previous), previousOffset);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(previous), previousOffset);
|
||||||
} else {
|
} else {
|
||||||
return new BoundaryProjection<>(point, new S1Point(first), currentOffset);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(first), currentOffset);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// the test point is between last and 2\pi
|
// the test point is between last and 2\pi
|
||||||
final double previousOffset = alpha - previous;
|
final double previousOffset = alpha - previous;
|
||||||
final double currentOffset = first + MathUtils.TWO_PI - alpha;
|
final double currentOffset = first + MathUtils.TWO_PI - alpha;
|
||||||
if (previousOffset < currentOffset) {
|
if (previousOffset < currentOffset) {
|
||||||
return new BoundaryProjection<>(point, new S1Point(previous), previousOffset);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(previous), previousOffset);
|
||||||
} else {
|
} else {
|
||||||
return new BoundaryProjection<>(point, new S1Point(first), currentOffset);
|
return new BoundaryProjection<Sphere1D>(point, new S1Point(first), currentOffset);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -565,7 +565,7 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
* @return a new ordered list containing {@link Arc Arc} elements
|
* @return a new ordered list containing {@link Arc Arc} elements
|
||||||
*/
|
*/
|
||||||
public List<Arc> asList() {
|
public List<Arc> asList() {
|
||||||
final List<Arc> list = new ArrayList<>();
|
final List<Arc> list = new ArrayList<Arc>();
|
||||||
for (final double[] a : this) {
|
for (final double[] a : this) {
|
||||||
list.add(new Arc(a[0], a[1], getTolerance()));
|
list.add(new Arc(a[0], a[1], getTolerance()));
|
||||||
}
|
}
|
||||||
|
@ -724,8 +724,8 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
*/
|
*/
|
||||||
public Split split(final Arc arc) {
|
public Split split(final Arc arc) {
|
||||||
|
|
||||||
final List<Double> minus = new ArrayList<>();
|
final List<Double> minus = new ArrayList<Double>();
|
||||||
final List<Double> plus = new ArrayList<>();
|
final List<Double> plus = new ArrayList<Double>();
|
||||||
|
|
||||||
final double reference = FastMath.PI + arc.getInf();
|
final double reference = FastMath.PI + arc.getInf();
|
||||||
final double arcLength = arc.getSup() - arc.getInf();
|
final double arcLength = arc.getSup() - arc.getInf();
|
||||||
|
@ -861,7 +861,7 @@ public class ArcsSet extends AbstractRegion<Sphere1D, Sphere1D> implements Itera
|
||||||
}
|
}
|
||||||
|
|
||||||
// build the tree by adding all angular sectors
|
// build the tree by adding all angular sectors
|
||||||
BSPTree<Sphere1D> tree = new BSPTree<>(Boolean.FALSE);
|
BSPTree<Sphere1D> tree = new BSPTree<Sphere1D>(Boolean.FALSE);
|
||||||
for (int i = 0; i < limits.size() - 1; i += 2) {
|
for (int i = 0; i < limits.size() - 1; i += 2) {
|
||||||
addArcLimit(tree, limits.get(i), true);
|
addArcLimit(tree, limits.get(i), true);
|
||||||
addArcLimit(tree, limits.get(i + 1), false);
|
addArcLimit(tree, limits.get(i + 1), false);
|
||||||
|
|
|
@ -59,8 +59,8 @@ public class SubLimitAngle extends AbstractSubHyperplane<Sphere1D, Sphere1D> {
|
||||||
public SplitSubHyperplane<Sphere1D> split(final Hyperplane<Sphere1D> hyperplane) {
|
public SplitSubHyperplane<Sphere1D> split(final Hyperplane<Sphere1D> hyperplane) {
|
||||||
final double global = hyperplane.getOffset(((LimitAngle) getHyperplane()).getLocation());
|
final double global = hyperplane.getOffset(((LimitAngle) getHyperplane()).getLocation());
|
||||||
return (global < -1.0e-10) ?
|
return (global < -1.0e-10) ?
|
||||||
new SplitSubHyperplane<>(null, this) :
|
new SplitSubHyperplane<Sphere1D>(null, this) :
|
||||||
new SplitSubHyperplane<>(this, null);
|
new SplitSubHyperplane<Sphere1D>(this, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,8 +55,8 @@ class EdgesBuilder implements BSPTreeVisitor<Sphere2D> {
|
||||||
EdgesBuilder(final BSPTree<Sphere2D> root, final double tolerance) {
|
EdgesBuilder(final BSPTree<Sphere2D> root, final double tolerance) {
|
||||||
this.root = root;
|
this.root = root;
|
||||||
this.tolerance = tolerance;
|
this.tolerance = tolerance;
|
||||||
this.edgeToNode = new IdentityHashMap<>();
|
this.edgeToNode = new IdentityHashMap<Edge, BSPTree<Sphere2D>>();
|
||||||
this.nodeToEdgesList = new IdentityHashMap<>();
|
this.nodeToEdgesList = new IdentityHashMap<BSPTree<Sphere2D>, List<Edge>>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -165,7 +165,7 @@ class EdgesBuilder implements BSPTreeVisitor<Sphere2D> {
|
||||||
previous.setNextEdge(getFollowingEdge(previous));
|
previous.setNextEdge(getFollowingEdge(previous));
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ArrayList<>(edgeToNode.keySet());
|
return new ArrayList<Edge>(edgeToNode.keySet());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -50,7 +50,7 @@ class PropertiesComputer implements BSPTreeVisitor<Sphere2D> {
|
||||||
this.tolerance = tolerance;
|
this.tolerance = tolerance;
|
||||||
this.summedArea = 0;
|
this.summedArea = 0;
|
||||||
this.summedBarycenter = Vector3D.ZERO;
|
this.summedBarycenter = Vector3D.ZERO;
|
||||||
this.convexCellsInsidePoints = new ArrayList<>();
|
this.convexCellsInsidePoints = new ArrayList<Vector3D>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
|
|
@ -59,7 +59,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
* @param tolerance below which points are consider to be identical
|
* @param tolerance below which points are consider to be identical
|
||||||
*/
|
*/
|
||||||
public SphericalPolygonsSet(final Vector3D pole, final double tolerance) {
|
public SphericalPolygonsSet(final Vector3D pole, final double tolerance) {
|
||||||
super(new BSPTree<>(new Circle(pole, tolerance).wholeHyperplane(),
|
super(new BSPTree<Sphere2D>(new Circle(pole, tolerance).wholeHyperplane(),
|
||||||
new BSPTree<Sphere2D>(Boolean.FALSE),
|
new BSPTree<Sphere2D>(Boolean.FALSE),
|
||||||
new BSPTree<Sphere2D>(Boolean.TRUE),
|
new BSPTree<Sphere2D>(Boolean.TRUE),
|
||||||
null),
|
null),
|
||||||
|
@ -198,7 +198,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
final int n = vertices.length;
|
final int n = vertices.length;
|
||||||
if (n == 0) {
|
if (n == 0) {
|
||||||
// the tree represents the whole space
|
// the tree represents the whole space
|
||||||
return new BSPTree<>(Boolean.TRUE);
|
return new BSPTree<Sphere2D>(Boolean.TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// build the vertices
|
// build the vertices
|
||||||
|
@ -208,7 +208,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// build the edges
|
// build the edges
|
||||||
List<Edge> edges = new ArrayList<>(n);
|
List<Edge> edges = new ArrayList<Edge>(n);
|
||||||
Vertex end = vArray[n - 1];
|
Vertex end = vArray[n - 1];
|
||||||
for (int i = 0; i < n; ++i) {
|
for (int i = 0; i < n; ++i) {
|
||||||
|
|
||||||
|
@ -241,7 +241,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// build the tree top-down
|
// build the tree top-down
|
||||||
final BSPTree<Sphere2D> tree = new BSPTree<>();
|
final BSPTree<Sphere2D> tree = new BSPTree<Sphere2D>();
|
||||||
insertEdges(hyperplaneThickness, tree, edges);
|
insertEdges(hyperplaneThickness, tree, edges);
|
||||||
|
|
||||||
return tree;
|
return tree;
|
||||||
|
@ -284,8 +284,8 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
|
|
||||||
// we have split the node by inserting an edge as a cut sub-hyperplane
|
// we have split the node by inserting an edge as a cut sub-hyperplane
|
||||||
// distribute the remaining edges in the two sub-trees
|
// distribute the remaining edges in the two sub-trees
|
||||||
final List<Edge> outsideList = new ArrayList<>();
|
final List<Edge> outsideList = new ArrayList<Edge>();
|
||||||
final List<Edge> insideList = new ArrayList<>();
|
final List<Edge> insideList = new ArrayList<Edge>();
|
||||||
for (final Edge edge : edges) {
|
for (final Edge edge : edges) {
|
||||||
if (edge != inserted) {
|
if (edge != inserted) {
|
||||||
edge.split(inserted.getCircle(), outsideList, insideList);
|
edge.split(inserted.getCircle(), outsideList, insideList);
|
||||||
|
@ -384,7 +384,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
|
|
||||||
|
|
||||||
// convert the list of all edges into a list of start vertices
|
// convert the list of all edges into a list of start vertices
|
||||||
loops = new ArrayList<>();
|
loops = new ArrayList<Vertex>();
|
||||||
while (!edges.isEmpty()) {
|
while (!edges.isEmpty()) {
|
||||||
|
|
||||||
// this is an edge belonging to a new loop, store it
|
// this is an edge belonging to a new loop, store it
|
||||||
|
@ -468,10 +468,10 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
|
|
||||||
// handle special cases first
|
// handle special cases first
|
||||||
if (isEmpty()) {
|
if (isEmpty()) {
|
||||||
return new EnclosingBall<>(S2Point.PLUS_K, Double.NEGATIVE_INFINITY);
|
return new EnclosingBall<Sphere2D, S2Point>(S2Point.PLUS_K, Double.NEGATIVE_INFINITY);
|
||||||
}
|
}
|
||||||
if (isFull()) {
|
if (isFull()) {
|
||||||
return new EnclosingBall<>(S2Point.PLUS_K, Double.POSITIVE_INFINITY);
|
return new EnclosingBall<Sphere2D, S2Point>(S2Point.PLUS_K, Double.POSITIVE_INFINITY);
|
||||||
}
|
}
|
||||||
|
|
||||||
// as the polygons is neither empty nor full, it has some boundaries and cut hyperplanes
|
// as the polygons is neither empty nor full, it has some boundaries and cut hyperplanes
|
||||||
|
@ -479,13 +479,13 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
if (isEmpty(root.getMinus()) && isFull(root.getPlus())) {
|
if (isEmpty(root.getMinus()) && isFull(root.getPlus())) {
|
||||||
// the polygon covers an hemisphere, and its boundary is one 2π long edge
|
// the polygon covers an hemisphere, and its boundary is one 2π long edge
|
||||||
final Circle circle = (Circle) root.getCut().getHyperplane();
|
final Circle circle = (Circle) root.getCut().getHyperplane();
|
||||||
return new EnclosingBall<>(new S2Point(circle.getPole()).negate(),
|
return new EnclosingBall<Sphere2D, S2Point>(new S2Point(circle.getPole()).negate(),
|
||||||
0.5 * FastMath.PI);
|
0.5 * FastMath.PI);
|
||||||
}
|
}
|
||||||
if (isFull(root.getMinus()) && isEmpty(root.getPlus())) {
|
if (isFull(root.getMinus()) && isEmpty(root.getPlus())) {
|
||||||
// the polygon covers an hemisphere, and its boundary is one 2π long edge
|
// the polygon covers an hemisphere, and its boundary is one 2π long edge
|
||||||
final Circle circle = (Circle) root.getCut().getHyperplane();
|
final Circle circle = (Circle) root.getCut().getHyperplane();
|
||||||
return new EnclosingBall<>(new S2Point(circle.getPole()),
|
return new EnclosingBall<Sphere2D, S2Point>(new S2Point(circle.getPole()),
|
||||||
0.5 * FastMath.PI);
|
0.5 * FastMath.PI);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -505,7 +505,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
// find the smallest enclosing 3D sphere
|
// find the smallest enclosing 3D sphere
|
||||||
final SphereGenerator generator = new SphereGenerator();
|
final SphereGenerator generator = new SphereGenerator();
|
||||||
final WelzlEncloser<Euclidean3D, Vector3D> encloser =
|
final WelzlEncloser<Euclidean3D, Vector3D> encloser =
|
||||||
new WelzlEncloser<>(getTolerance(), generator);
|
new WelzlEncloser<Euclidean3D, Vector3D>(getTolerance(), generator);
|
||||||
EnclosingBall<Euclidean3D, Vector3D> enclosing3D = encloser.enclose(points);
|
EnclosingBall<Euclidean3D, Vector3D> enclosing3D = encloser.enclose(points);
|
||||||
final Vector3D[] support3D = enclosing3D.getSupport();
|
final Vector3D[] support3D = enclosing3D.getSupport();
|
||||||
|
|
||||||
|
@ -516,12 +516,12 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
// the 3D sphere is centered on the unit sphere and covers it
|
// the 3D sphere is centered on the unit sphere and covers it
|
||||||
// fall back to a crude approximation, based only on outside convex cells
|
// fall back to a crude approximation, based only on outside convex cells
|
||||||
EnclosingBall<Sphere2D, S2Point> enclosingS2 =
|
EnclosingBall<Sphere2D, S2Point> enclosingS2 =
|
||||||
new EnclosingBall<>(S2Point.PLUS_K, Double.POSITIVE_INFINITY);
|
new EnclosingBall<Sphere2D, S2Point>(S2Point.PLUS_K, Double.POSITIVE_INFINITY);
|
||||||
for (Vector3D outsidePoint : getOutsidePoints()) {
|
for (Vector3D outsidePoint : getOutsidePoints()) {
|
||||||
final S2Point outsideS2 = new S2Point(outsidePoint);
|
final S2Point outsideS2 = new S2Point(outsidePoint);
|
||||||
final BoundaryProjection<Sphere2D> projection = projectToBoundary(outsideS2);
|
final BoundaryProjection<Sphere2D> projection = projectToBoundary(outsideS2);
|
||||||
if (FastMath.PI - projection.getOffset() < enclosingS2.getRadius()) {
|
if (FastMath.PI - projection.getOffset() < enclosingS2.getRadius()) {
|
||||||
enclosingS2 = new EnclosingBall<>(outsideS2.negate(),
|
enclosingS2 = new EnclosingBall<Sphere2D, S2Point>(outsideS2.negate(),
|
||||||
FastMath.PI - projection.getOffset(),
|
FastMath.PI - projection.getOffset(),
|
||||||
(S2Point) projection.getProjected());
|
(S2Point) projection.getProjected());
|
||||||
}
|
}
|
||||||
|
@ -534,7 +534,7 @@ public class SphericalPolygonsSet extends AbstractRegion<Sphere2D, Sphere1D> {
|
||||||
}
|
}
|
||||||
|
|
||||||
final EnclosingBall<Sphere2D, S2Point> enclosingS2 =
|
final EnclosingBall<Sphere2D, S2Point> enclosingS2 =
|
||||||
new EnclosingBall<>(new S2Point(enclosing3D.getCenter()),
|
new EnclosingBall<Sphere2D, S2Point>(new S2Point(enclosing3D.getCenter()),
|
||||||
FastMath.acos((1 + h * h - r * r) / (2 * h)),
|
FastMath.acos((1 + h * h - r * r) / (2 * h)),
|
||||||
support);
|
support);
|
||||||
|
|
||||||
|
|
|
@ -56,14 +56,14 @@ public class SubCircle extends AbstractSubHyperplane<Sphere2D, Sphere1D> {
|
||||||
|
|
||||||
if (angle < thisCircle.getTolerance() || angle > FastMath.PI - thisCircle.getTolerance()) {
|
if (angle < thisCircle.getTolerance() || angle > FastMath.PI - thisCircle.getTolerance()) {
|
||||||
// the two circles are aligned or opposite
|
// the two circles are aligned or opposite
|
||||||
return new SplitSubHyperplane<>(null, null);
|
return new SplitSubHyperplane<Sphere2D>(null, null);
|
||||||
} else {
|
} else {
|
||||||
// the two circles intersect each other
|
// the two circles intersect each other
|
||||||
final Arc arc = thisCircle.getInsideArc(otherCircle);
|
final Arc arc = thisCircle.getInsideArc(otherCircle);
|
||||||
final ArcsSet.Split split = ((ArcsSet) getRemainingRegion()).split(arc);
|
final ArcsSet.Split split = ((ArcsSet) getRemainingRegion()).split(arc);
|
||||||
final ArcsSet plus = split.getPlus();
|
final ArcsSet plus = split.getPlus();
|
||||||
final ArcsSet minus = split.getMinus();
|
final ArcsSet minus = split.getMinus();
|
||||||
return new SplitSubHyperplane<>(plus == null ? null : new SubCircle(thisCircle.copySelf(), plus),
|
return new SplitSubHyperplane<Sphere2D>(plus == null ? null : new SubCircle(thisCircle.copySelf(), plus),
|
||||||
minus == null ? null : new SubCircle(thisCircle.copySelf(), minus));
|
minus == null ? null : new SubCircle(thisCircle.copySelf(), minus));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -45,7 +45,7 @@ public class Vertex {
|
||||||
this.location = location;
|
this.location = location;
|
||||||
this.incoming = null;
|
this.incoming = null;
|
||||||
this.outgoing = null;
|
this.outgoing = null;
|
||||||
this.circles = new ArrayList<>();
|
this.circles = new ArrayList<Circle>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get Vertex location.
|
/** Get Vertex location.
|
||||||
|
|
|
@ -270,7 +270,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
|
|
||||||
final char[] binaryRepresentation = Integer.toBinaryString(power)
|
final char[] binaryRepresentation = Integer.toBinaryString(power)
|
||||||
.toCharArray();
|
.toCharArray();
|
||||||
final ArrayList<Integer> nonZeroPositions = new ArrayList<>();
|
final ArrayList<Integer> nonZeroPositions = new ArrayList<Integer>();
|
||||||
|
|
||||||
for (int i = 0; i < binaryRepresentation.length; ++i) {
|
for (int i = 0; i < binaryRepresentation.length; ++i) {
|
||||||
if (binaryRepresentation[i] == '1') {
|
if (binaryRepresentation[i] == '1') {
|
||||||
|
@ -279,7 +279,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ArrayList<FieldMatrix<T>> results = new ArrayList<>(
|
ArrayList<FieldMatrix<T>> results = new ArrayList<FieldMatrix<T>>(
|
||||||
binaryRepresentation.length);
|
binaryRepresentation.length);
|
||||||
|
|
||||||
results.add(0, this.copy());
|
results.add(0, this.copy());
|
||||||
|
@ -537,7 +537,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
@Override
|
@Override
|
||||||
public FieldVector<T> getRowVector(final int row)
|
public FieldVector<T> getRowVector(final int row)
|
||||||
throws OutOfRangeException {
|
throws OutOfRangeException {
|
||||||
return new ArrayFieldVector<>(field, getRow(row), false);
|
return new ArrayFieldVector<T>(field, getRow(row), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -560,7 +560,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
@Override
|
@Override
|
||||||
public FieldVector<T> getColumnVector(final int column)
|
public FieldVector<T> getColumnVector(final int column)
|
||||||
throws OutOfRangeException {
|
throws OutOfRangeException {
|
||||||
return new ArrayFieldVector<>(field, getColumn(column), false);
|
return new ArrayFieldVector<T>(field, getColumn(column), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -726,7 +726,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
public FieldVector<T> operate(final FieldVector<T> v)
|
public FieldVector<T> operate(final FieldVector<T> v)
|
||||||
throws DimensionMismatchException {
|
throws DimensionMismatchException {
|
||||||
try {
|
try {
|
||||||
return new ArrayFieldVector<>(field, operate(((ArrayFieldVector<T>) v).getDataRef()), false);
|
return new ArrayFieldVector<T>(field, operate(((ArrayFieldVector<T>) v).getDataRef()), false);
|
||||||
} catch (ClassCastException cce) {
|
} catch (ClassCastException cce) {
|
||||||
final int nRows = getRowDimension();
|
final int nRows = getRowDimension();
|
||||||
final int nCols = getColumnDimension();
|
final int nCols = getColumnDimension();
|
||||||
|
@ -743,7 +743,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
out[row] = sum;
|
out[row] = sum;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -774,7 +774,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
public FieldVector<T> preMultiply(final FieldVector<T> v)
|
public FieldVector<T> preMultiply(final FieldVector<T> v)
|
||||||
throws DimensionMismatchException {
|
throws DimensionMismatchException {
|
||||||
try {
|
try {
|
||||||
return new ArrayFieldVector<>(field, preMultiply(((ArrayFieldVector<T>) v).getDataRef()), false);
|
return new ArrayFieldVector<T>(field, preMultiply(((ArrayFieldVector<T>) v).getDataRef()), false);
|
||||||
} catch (ClassCastException cce) {
|
} catch (ClassCastException cce) {
|
||||||
final int nRows = getRowDimension();
|
final int nRows = getRowDimension();
|
||||||
final int nCols = getColumnDimension();
|
final int nCols = getColumnDimension();
|
||||||
|
@ -791,7 +791,7 @@ public abstract class AbstractFieldMatrix<T extends FieldElement<T>>
|
||||||
out[col] = sum;
|
out[col] = sum;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -198,7 +198,7 @@ public abstract class AbstractRealMatrix
|
||||||
*/
|
*/
|
||||||
|
|
||||||
final char[] binaryRepresentation = Integer.toBinaryString(power).toCharArray();
|
final char[] binaryRepresentation = Integer.toBinaryString(power).toCharArray();
|
||||||
final ArrayList<Integer> nonZeroPositions = new ArrayList<>();
|
final ArrayList<Integer> nonZeroPositions = new ArrayList<Integer>();
|
||||||
int maxI = -1;
|
int maxI = -1;
|
||||||
|
|
||||||
for (int i = 0; i < binaryRepresentation.length; ++i) {
|
for (int i = 0; i < binaryRepresentation.length; ++i) {
|
||||||
|
|
|
@ -208,13 +208,13 @@ public class Array2DRowFieldMatrix<T extends FieldElement<T>>
|
||||||
public FieldMatrix<T> createMatrix(final int rowDimension,
|
public FieldMatrix<T> createMatrix(final int rowDimension,
|
||||||
final int columnDimension)
|
final int columnDimension)
|
||||||
throws NotStrictlyPositiveException {
|
throws NotStrictlyPositiveException {
|
||||||
return new Array2DRowFieldMatrix<>(getField(), rowDimension, columnDimension);
|
return new Array2DRowFieldMatrix<T>(getField(), rowDimension, columnDimension);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public FieldMatrix<T> copy() {
|
public FieldMatrix<T> copy() {
|
||||||
return new Array2DRowFieldMatrix<>(getField(), copyOut(), false);
|
return new Array2DRowFieldMatrix<T>(getField(), copyOut(), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -242,7 +242,7 @@ public class Array2DRowFieldMatrix<T extends FieldElement<T>>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Array2DRowFieldMatrix<>(getField(), outData, false);
|
return new Array2DRowFieldMatrix<T>(getField(), outData, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -270,7 +270,7 @@ public class Array2DRowFieldMatrix<T extends FieldElement<T>>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Array2DRowFieldMatrix<>(getField(), outData, false);
|
return new Array2DRowFieldMatrix<T>(getField(), outData, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -303,7 +303,7 @@ public class Array2DRowFieldMatrix<T extends FieldElement<T>>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Array2DRowFieldMatrix<>(getField(), outData, false);
|
return new Array2DRowFieldMatrix<T>(getField(), outData, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -388,7 +388,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public FieldVector<T> copy() {
|
public FieldVector<T> copy() {
|
||||||
return new ArrayFieldVector<>(this, true);
|
return new ArrayFieldVector<T>(this, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -403,7 +403,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].add(v.getEntry(i));
|
out[i] = data[i].add(v.getEntry(i));
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -421,7 +421,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].add(v.data[i]);
|
out[i] = data[i].add(v.data[i]);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -436,7 +436,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].subtract(v.getEntry(i));
|
out[i] = data[i].subtract(v.getEntry(i));
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -454,7 +454,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].subtract(v.data[i]);
|
out[i] = data[i].subtract(v.data[i]);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -464,7 +464,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].add(d);
|
out[i] = data[i].add(d);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -483,7 +483,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].subtract(d);
|
out[i] = data[i].subtract(d);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -502,7 +502,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].multiply(d);
|
out[i] = data[i].multiply(d);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -523,7 +523,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].divide(d);
|
out[i] = data[i].divide(d);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -549,7 +549,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
throw new MathArithmeticException(LocalizedFormats.INDEX, i);
|
throw new MathArithmeticException(LocalizedFormats.INDEX, i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -578,7 +578,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].multiply(v.getEntry(i));
|
out[i] = data[i].multiply(v.getEntry(i));
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -596,7 +596,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
for (int i = 0; i < data.length; i++) {
|
for (int i = 0; i < data.length; i++) {
|
||||||
out[i] = data[i].multiply(v.data[i]);
|
out[i] = data[i].multiply(v.data[i]);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -615,7 +615,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
throw new MathArithmeticException(LocalizedFormats.INDEX, i);
|
throw new MathArithmeticException(LocalizedFormats.INDEX, i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -638,7 +638,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
throw new MathArithmeticException(LocalizedFormats.INDEX, i);
|
throw new MathArithmeticException(LocalizedFormats.INDEX, i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -710,7 +710,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
} catch (ClassCastException cce) {
|
} catch (ClassCastException cce) {
|
||||||
final int m = data.length;
|
final int m = data.length;
|
||||||
final int n = v.getDimension();
|
final int n = v.getDimension();
|
||||||
final FieldMatrix<T> out = new Array2DRowFieldMatrix<>(field, m, n);
|
final FieldMatrix<T> out = new Array2DRowFieldMatrix<T>(field, m, n);
|
||||||
for (int i = 0; i < m; i++) {
|
for (int i = 0; i < m; i++) {
|
||||||
for (int j = 0; j < n; j++) {
|
for (int j = 0; j < n; j++) {
|
||||||
out.setEntry(i, j, data[i].multiply(v.getEntry(j)));
|
out.setEntry(i, j, data[i].multiply(v.getEntry(j)));
|
||||||
|
@ -728,7 +728,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
public FieldMatrix<T> outerProduct(ArrayFieldVector<T> v) {
|
public FieldMatrix<T> outerProduct(ArrayFieldVector<T> v) {
|
||||||
final int m = data.length;
|
final int m = data.length;
|
||||||
final int n = v.data.length;
|
final int n = v.data.length;
|
||||||
final FieldMatrix<T> out = new Array2DRowFieldMatrix<>(field, m, n);
|
final FieldMatrix<T> out = new Array2DRowFieldMatrix<T>(field, m, n);
|
||||||
for (int i = 0; i < m; i++) {
|
for (int i = 0; i < m; i++) {
|
||||||
for (int j = 0; j < n; j++) {
|
for (int j = 0; j < n; j++) {
|
||||||
out.setEntry(i, j, data[i].multiply(v.data[j]));
|
out.setEntry(i, j, data[i].multiply(v.data[j]));
|
||||||
|
@ -755,7 +755,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
try {
|
try {
|
||||||
return append((ArrayFieldVector<T>) v);
|
return append((ArrayFieldVector<T>) v);
|
||||||
} catch (ClassCastException cce) {
|
} catch (ClassCastException cce) {
|
||||||
return new ArrayFieldVector<>(this,new ArrayFieldVector<>(v));
|
return new ArrayFieldVector<T>(this,new ArrayFieldVector<T>(v));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -765,7 +765,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
* @return a new vector
|
* @return a new vector
|
||||||
*/
|
*/
|
||||||
public ArrayFieldVector<T> append(ArrayFieldVector<T> v) {
|
public ArrayFieldVector<T> append(ArrayFieldVector<T> v) {
|
||||||
return new ArrayFieldVector<>(this, v);
|
return new ArrayFieldVector<T>(this, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -774,7 +774,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
final T[] out = MathArrays.buildArray(field, data.length + 1);
|
final T[] out = MathArrays.buildArray(field, data.length + 1);
|
||||||
System.arraycopy(data, 0, out, 0, data.length);
|
System.arraycopy(data, 0, out, 0, data.length);
|
||||||
out[data.length] = in;
|
out[data.length] = in;
|
||||||
return new ArrayFieldVector<>(field, out, false);
|
return new ArrayFieldVector<T>(field, out, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -784,7 +784,7 @@ public class ArrayFieldVector<T extends FieldElement<T>> implements FieldVector<
|
||||||
if (n < 0) {
|
if (n < 0) {
|
||||||
throw new NotPositiveException(LocalizedFormats.NUMBER_OF_ELEMENTS_SHOULD_BE_POSITIVE, n);
|
throw new NotPositiveException(LocalizedFormats.NUMBER_OF_ELEMENTS_SHOULD_BE_POSITIVE, n);
|
||||||
}
|
}
|
||||||
ArrayFieldVector<T> out = new ArrayFieldVector<>(field, n);
|
ArrayFieldVector<T> out = new ArrayFieldVector<T>(field, n);
|
||||||
try {
|
try {
|
||||||
System.arraycopy(data, index, out.data, 0, n);
|
System.arraycopy(data, index, out.data, 0, n);
|
||||||
} catch (IndexOutOfBoundsException e) {
|
} catch (IndexOutOfBoundsException e) {
|
||||||
|
|
|
@ -294,7 +294,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
public FieldMatrix<T> createMatrix(final int rowDimension,
|
public FieldMatrix<T> createMatrix(final int rowDimension,
|
||||||
final int columnDimension)
|
final int columnDimension)
|
||||||
throws NotStrictlyPositiveException {
|
throws NotStrictlyPositiveException {
|
||||||
return new BlockFieldMatrix<>(getField(), rowDimension,
|
return new BlockFieldMatrix<T>(getField(), rowDimension,
|
||||||
columnDimension);
|
columnDimension);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -303,7 +303,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
public FieldMatrix<T> copy() {
|
public FieldMatrix<T> copy() {
|
||||||
|
|
||||||
// create an empty matrix
|
// create an empty matrix
|
||||||
BlockFieldMatrix<T> copied = new BlockFieldMatrix<>(getField(), rows, columns);
|
BlockFieldMatrix<T> copied = new BlockFieldMatrix<T>(getField(), rows, columns);
|
||||||
|
|
||||||
// copy the blocks
|
// copy the blocks
|
||||||
for (int i = 0; i < blocks.length; ++i) {
|
for (int i = 0; i < blocks.length; ++i) {
|
||||||
|
@ -324,7 +324,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
// safety check
|
// safety check
|
||||||
checkAdditionCompatible(m);
|
checkAdditionCompatible(m);
|
||||||
|
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, columns);
|
||||||
|
|
||||||
// perform addition block-wise, to ensure good cache behavior
|
// perform addition block-wise, to ensure good cache behavior
|
||||||
int blockIndex = 0;
|
int blockIndex = 0;
|
||||||
|
@ -370,7 +370,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
// safety check
|
// safety check
|
||||||
checkAdditionCompatible(m);
|
checkAdditionCompatible(m);
|
||||||
|
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, columns);
|
||||||
|
|
||||||
// perform addition block-wise, to ensure good cache behavior
|
// perform addition block-wise, to ensure good cache behavior
|
||||||
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
||||||
|
@ -396,7 +396,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
// safety check
|
// safety check
|
||||||
checkSubtractionCompatible(m);
|
checkSubtractionCompatible(m);
|
||||||
|
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, columns);
|
||||||
|
|
||||||
// perform subtraction block-wise, to ensure good cache behavior
|
// perform subtraction block-wise, to ensure good cache behavior
|
||||||
int blockIndex = 0;
|
int blockIndex = 0;
|
||||||
|
@ -440,7 +440,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
// safety check
|
// safety check
|
||||||
checkSubtractionCompatible(m);
|
checkSubtractionCompatible(m);
|
||||||
|
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, columns);
|
||||||
|
|
||||||
// perform subtraction block-wise, to ensure good cache behavior
|
// perform subtraction block-wise, to ensure good cache behavior
|
||||||
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
||||||
|
@ -458,7 +458,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public FieldMatrix<T> scalarAdd(final T d) {
|
public FieldMatrix<T> scalarAdd(final T d) {
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, columns);
|
||||||
|
|
||||||
// perform subtraction block-wise, to ensure good cache behavior
|
// perform subtraction block-wise, to ensure good cache behavior
|
||||||
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
||||||
|
@ -476,7 +476,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
@Override
|
@Override
|
||||||
public FieldMatrix<T> scalarMultiply(final T d) {
|
public FieldMatrix<T> scalarMultiply(final T d) {
|
||||||
|
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, columns);
|
||||||
|
|
||||||
// perform subtraction block-wise, to ensure good cache behavior
|
// perform subtraction block-wise, to ensure good cache behavior
|
||||||
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
for (int blockIndex = 0; blockIndex < out.blocks.length; ++blockIndex) {
|
||||||
|
@ -501,7 +501,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
// safety check
|
// safety check
|
||||||
checkMultiplicationCompatible(m);
|
checkMultiplicationCompatible(m);
|
||||||
|
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, m.getColumnDimension());
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, m.getColumnDimension());
|
||||||
final T zero = getField().getZero();
|
final T zero = getField().getZero();
|
||||||
|
|
||||||
// perform multiplication block-wise, to ensure good cache behavior
|
// perform multiplication block-wise, to ensure good cache behavior
|
||||||
|
@ -564,7 +564,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
// safety check
|
// safety check
|
||||||
checkMultiplicationCompatible(m);
|
checkMultiplicationCompatible(m);
|
||||||
|
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, m.columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, m.columns);
|
||||||
final T zero = getField().getZero();
|
final T zero = getField().getZero();
|
||||||
|
|
||||||
// perform multiplication block-wise, to ensure good cache behavior
|
// perform multiplication block-wise, to ensure good cache behavior
|
||||||
|
@ -663,7 +663,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
|
|
||||||
// create the output matrix
|
// create the output matrix
|
||||||
final BlockFieldMatrix<T> out =
|
final BlockFieldMatrix<T> out =
|
||||||
new BlockFieldMatrix<>(getField(), endRow - startRow + 1, endColumn - startColumn + 1);
|
new BlockFieldMatrix<T>(getField(), endRow - startRow + 1, endColumn - startColumn + 1);
|
||||||
|
|
||||||
// compute blocks shifts
|
// compute blocks shifts
|
||||||
final int blockStartRow = startRow / BLOCK_SIZE;
|
final int blockStartRow = startRow / BLOCK_SIZE;
|
||||||
|
@ -836,7 +836,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
public FieldMatrix<T> getRowMatrix(final int row)
|
public FieldMatrix<T> getRowMatrix(final int row)
|
||||||
throws OutOfRangeException {
|
throws OutOfRangeException {
|
||||||
checkRowIndex(row);
|
checkRowIndex(row);
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), 1, columns);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), 1, columns);
|
||||||
|
|
||||||
// perform copy block-wise, to ensure good cache behavior
|
// perform copy block-wise, to ensure good cache behavior
|
||||||
final int iBlock = row / BLOCK_SIZE;
|
final int iBlock = row / BLOCK_SIZE;
|
||||||
|
@ -922,7 +922,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
public FieldMatrix<T> getColumnMatrix(final int column)
|
public FieldMatrix<T> getColumnMatrix(final int column)
|
||||||
throws OutOfRangeException {
|
throws OutOfRangeException {
|
||||||
checkColumnIndex(column);
|
checkColumnIndex(column);
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), rows, 1);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), rows, 1);
|
||||||
|
|
||||||
// perform copy block-wise, to ensure good cache behavior
|
// perform copy block-wise, to ensure good cache behavior
|
||||||
final int jBlock = column / BLOCK_SIZE;
|
final int jBlock = column / BLOCK_SIZE;
|
||||||
|
@ -1017,7 +1017,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
outIndex += jWidth;
|
outIndex += jWidth;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ArrayFieldVector<>(getField(), outData, false);
|
return new ArrayFieldVector<T>(getField(), outData, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -1051,7 +1051,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ArrayFieldVector<>(getField(), outData, false);
|
return new ArrayFieldVector<T>(getField(), outData, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -1220,7 +1220,7 @@ public class BlockFieldMatrix<T extends FieldElement<T>> extends AbstractFieldMa
|
||||||
public FieldMatrix<T> transpose() {
|
public FieldMatrix<T> transpose() {
|
||||||
final int nRows = getRowDimension();
|
final int nRows = getRowDimension();
|
||||||
final int nCols = getColumnDimension();
|
final int nCols = getColumnDimension();
|
||||||
final BlockFieldMatrix<T> out = new BlockFieldMatrix<>(getField(), nCols, nRows);
|
final BlockFieldMatrix<T> out = new BlockFieldMatrix<T>(getField(), nCols, nRows);
|
||||||
|
|
||||||
// perform transpose block-wise, to ensure good cache behavior
|
// perform transpose block-wise, to ensure good cache behavior
|
||||||
int blockIndex = 0;
|
int blockIndex = 0;
|
||||||
|
|
|
@ -171,7 +171,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
public FieldMatrix<T> getL() {
|
public FieldMatrix<T> getL() {
|
||||||
if ((cachedL == null) && !singular) {
|
if ((cachedL == null) && !singular) {
|
||||||
final int m = pivot.length;
|
final int m = pivot.length;
|
||||||
cachedL = new Array2DRowFieldMatrix<>(field, m, m);
|
cachedL = new Array2DRowFieldMatrix<T>(field, m, m);
|
||||||
for (int i = 0; i < m; ++i) {
|
for (int i = 0; i < m; ++i) {
|
||||||
final T[] luI = lu[i];
|
final T[] luI = lu[i];
|
||||||
for (int j = 0; j < i; ++j) {
|
for (int j = 0; j < i; ++j) {
|
||||||
|
@ -191,7 +191,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
public FieldMatrix<T> getU() {
|
public FieldMatrix<T> getU() {
|
||||||
if ((cachedU == null) && !singular) {
|
if ((cachedU == null) && !singular) {
|
||||||
final int m = pivot.length;
|
final int m = pivot.length;
|
||||||
cachedU = new Array2DRowFieldMatrix<>(field, m, m);
|
cachedU = new Array2DRowFieldMatrix<T>(field, m, m);
|
||||||
for (int i = 0; i < m; ++i) {
|
for (int i = 0; i < m; ++i) {
|
||||||
final T[] luI = lu[i];
|
final T[] luI = lu[i];
|
||||||
for (int j = i; j < m; ++j) {
|
for (int j = i; j < m; ++j) {
|
||||||
|
@ -214,7 +214,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
public FieldMatrix<T> getP() {
|
public FieldMatrix<T> getP() {
|
||||||
if ((cachedP == null) && !singular) {
|
if ((cachedP == null) && !singular) {
|
||||||
final int m = pivot.length;
|
final int m = pivot.length;
|
||||||
cachedP = new Array2DRowFieldMatrix<>(field, m, m);
|
cachedP = new Array2DRowFieldMatrix<T>(field, m, m);
|
||||||
for (int i = 0; i < m; ++i) {
|
for (int i = 0; i < m; ++i) {
|
||||||
cachedP.setEntry(i, pivot[i], field.getOne());
|
cachedP.setEntry(i, pivot[i], field.getOne());
|
||||||
}
|
}
|
||||||
|
@ -253,7 +253,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
* @return a solver
|
* @return a solver
|
||||||
*/
|
*/
|
||||||
public FieldDecompositionSolver<T> getSolver() {
|
public FieldDecompositionSolver<T> getSolver() {
|
||||||
return new Solver<>(field, lu, pivot, singular);
|
return new Solver<T>(field, lu, pivot, singular);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Specialized solver.
|
/** Specialized solver.
|
||||||
|
@ -332,7 +332,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ArrayFieldVector<>(field, bp, false);
|
return new ArrayFieldVector<T>(field, bp, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -377,7 +377,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new ArrayFieldVector<>(bp, false);
|
return new ArrayFieldVector<T>(bp, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -431,7 +431,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Array2DRowFieldMatrix<>(field, bp, false);
|
return new Array2DRowFieldMatrix<T>(field, bp, false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -440,7 +440,7 @@ public class FieldLUDecomposition<T extends FieldElement<T>> {
|
||||||
public FieldMatrix<T> getInverse() {
|
public FieldMatrix<T> getInverse() {
|
||||||
final int m = pivot.length;
|
final int m = pivot.length;
|
||||||
final T one = field.getOne();
|
final T one = field.getOne();
|
||||||
FieldMatrix<T> identity = new Array2DRowFieldMatrix<>(field, m, m);
|
FieldMatrix<T> identity = new Array2DRowFieldMatrix<T>(field, m, m);
|
||||||
for (int i = 0; i < m; ++i) {
|
for (int i = 0; i < m; ++i) {
|
||||||
identity.setEntry(i, i, one);
|
identity.setEntry(i, i, one);
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,7 +101,7 @@ public class MatrixUtils {
|
||||||
final int rows,
|
final int rows,
|
||||||
final int columns) {
|
final int columns) {
|
||||||
return (rows * columns <= 4096) ?
|
return (rows * columns <= 4096) ?
|
||||||
new Array2DRowFieldMatrix<>(field, rows, columns) : new BlockFieldMatrix<>(field, rows, columns);
|
new Array2DRowFieldMatrix<T>(field, rows, columns) : new BlockFieldMatrix<T>(field, rows, columns);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -161,7 +161,7 @@ public class MatrixUtils {
|
||||||
throw new NullArgumentException();
|
throw new NullArgumentException();
|
||||||
}
|
}
|
||||||
return (data.length * data[0].length <= 4096) ?
|
return (data.length * data[0].length <= 4096) ?
|
||||||
new Array2DRowFieldMatrix<>(data) : new BlockFieldMatrix<>(data);
|
new Array2DRowFieldMatrix<T>(data) : new BlockFieldMatrix<T>(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -200,7 +200,7 @@ public class MatrixUtils {
|
||||||
Arrays.fill(dRow, zero);
|
Arrays.fill(dRow, zero);
|
||||||
dRow[row] = one;
|
dRow[row] = one;
|
||||||
}
|
}
|
||||||
return new Array2DRowFieldMatrix<>(field, d, false);
|
return new Array2DRowFieldMatrix<T>(field, d, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -272,7 +272,7 @@ public class MatrixUtils {
|
||||||
if (data.length == 0) {
|
if (data.length == 0) {
|
||||||
throw new ZeroException(LocalizedFormats.VECTOR_MUST_HAVE_AT_LEAST_ONE_ELEMENT);
|
throw new ZeroException(LocalizedFormats.VECTOR_MUST_HAVE_AT_LEAST_ONE_ELEMENT);
|
||||||
}
|
}
|
||||||
return new ArrayFieldVector<>(data[0].getField(), data, true);
|
return new ArrayFieldVector<T>(data[0].getField(), data, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -315,8 +315,8 @@ public class RealMatrixFormat {
|
||||||
}
|
}
|
||||||
|
|
||||||
// parse components
|
// parse components
|
||||||
List<List<Number>> matrix = new ArrayList<>();
|
List<List<Number>> matrix = new ArrayList<List<Number>>();
|
||||||
List<Number> rowComponents = new ArrayList<>();
|
List<Number> rowComponents = new ArrayList<Number>();
|
||||||
for (boolean loop = true; loop;){
|
for (boolean loop = true; loop;){
|
||||||
|
|
||||||
if (!rowComponents.isEmpty()) {
|
if (!rowComponents.isEmpty()) {
|
||||||
|
@ -329,7 +329,7 @@ public class RealMatrixFormat {
|
||||||
CompositeFormat.parseAndIgnoreWhitespace(source, pos);
|
CompositeFormat.parseAndIgnoreWhitespace(source, pos);
|
||||||
if (CompositeFormat.parseFixedstring(source, trimmedRowSeparator, pos)) {
|
if (CompositeFormat.parseFixedstring(source, trimmedRowSeparator, pos)) {
|
||||||
matrix.add(rowComponents);
|
matrix.add(rowComponents);
|
||||||
rowComponents = new ArrayList<>();
|
rowComponents = new ArrayList<Number>();
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
loop = false;
|
loop = false;
|
||||||
|
|
|
@ -247,7 +247,7 @@ public class RealVectorFormat {
|
||||||
}
|
}
|
||||||
|
|
||||||
// parse components
|
// parse components
|
||||||
List<Number> components = new ArrayList<>();
|
List<Number> components = new ArrayList<Number>();
|
||||||
for (boolean loop = true; loop;){
|
for (boolean loop = true; loop;){
|
||||||
|
|
||||||
if (!components.isEmpty()) {
|
if (!components.isEmpty()) {
|
||||||
|
|
|
@ -51,7 +51,7 @@ public class SparseFieldMatrix<T extends FieldElement<T>> extends AbstractFieldM
|
||||||
super(field);
|
super(field);
|
||||||
rows = 0;
|
rows = 0;
|
||||||
columns= 0;
|
columns= 0;
|
||||||
entries = new OpenIntToFieldHashMap<>(field);
|
entries = new OpenIntToFieldHashMap<T>(field);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -69,7 +69,7 @@ public class SparseFieldMatrix<T extends FieldElement<T>> extends AbstractFieldM
|
||||||
super(field, rowDimension, columnDimension);
|
super(field, rowDimension, columnDimension);
|
||||||
this.rows = rowDimension;
|
this.rows = rowDimension;
|
||||||
this.columns = columnDimension;
|
this.columns = columnDimension;
|
||||||
entries = new OpenIntToFieldHashMap<>(field);
|
entries = new OpenIntToFieldHashMap<T>(field);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -81,7 +81,7 @@ public class SparseFieldMatrix<T extends FieldElement<T>> extends AbstractFieldM
|
||||||
super(other.getField(), other.getRowDimension(), other.getColumnDimension());
|
super(other.getField(), other.getRowDimension(), other.getColumnDimension());
|
||||||
rows = other.getRowDimension();
|
rows = other.getRowDimension();
|
||||||
columns = other.getColumnDimension();
|
columns = other.getColumnDimension();
|
||||||
entries = new OpenIntToFieldHashMap<>(other.entries);
|
entries = new OpenIntToFieldHashMap<T>(other.entries);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -93,7 +93,7 @@ public class SparseFieldMatrix<T extends FieldElement<T>> extends AbstractFieldM
|
||||||
super(other.getField(), other.getRowDimension(), other.getColumnDimension());
|
super(other.getField(), other.getRowDimension(), other.getColumnDimension());
|
||||||
rows = other.getRowDimension();
|
rows = other.getRowDimension();
|
||||||
columns = other.getColumnDimension();
|
columns = other.getColumnDimension();
|
||||||
entries = new OpenIntToFieldHashMap<>(getField());
|
entries = new OpenIntToFieldHashMap<T>(getField());
|
||||||
for (int i = 0; i < rows; i++) {
|
for (int i = 0; i < rows; i++) {
|
||||||
for (int j = 0; j < columns; j++) {
|
for (int j = 0; j < columns; j++) {
|
||||||
setEntry(i, j, other.getEntry(i, j));
|
setEntry(i, j, other.getEntry(i, j));
|
||||||
|
@ -118,13 +118,13 @@ public class SparseFieldMatrix<T extends FieldElement<T>> extends AbstractFieldM
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public FieldMatrix<T> copy() {
|
public FieldMatrix<T> copy() {
|
||||||
return new SparseFieldMatrix<>(this);
|
return new SparseFieldMatrix<T>(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public FieldMatrix<T> createMatrix(int rowDimension, int columnDimension) {
|
public FieldMatrix<T> createMatrix(int rowDimension, int columnDimension) {
|
||||||
return new SparseFieldMatrix<>(getField(), rowDimension, columnDimension);
|
return new SparseFieldMatrix<T>(getField(), rowDimension, columnDimension);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
|
|
@ -77,7 +77,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
public SparseFieldVector(Field<T> field, int dimension) {
|
public SparseFieldVector(Field<T> field, int dimension) {
|
||||||
this.field = field;
|
this.field = field;
|
||||||
virtualSize = dimension;
|
virtualSize = dimension;
|
||||||
entries = new OpenIntToFieldHashMap<>(field);
|
entries = new OpenIntToFieldHashMap<T>(field);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -89,7 +89,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
protected SparseFieldVector(SparseFieldVector<T> v, int resize) {
|
protected SparseFieldVector(SparseFieldVector<T> v, int resize) {
|
||||||
field = v.field;
|
field = v.field;
|
||||||
virtualSize = v.getDimension() + resize;
|
virtualSize = v.getDimension() + resize;
|
||||||
entries = new OpenIntToFieldHashMap<>(v.entries);
|
entries = new OpenIntToFieldHashMap<T>(v.entries);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -103,7 +103,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
public SparseFieldVector(Field<T> field, int dimension, int expectedSize) {
|
public SparseFieldVector(Field<T> field, int dimension, int expectedSize) {
|
||||||
this.field = field;
|
this.field = field;
|
||||||
virtualSize = dimension;
|
virtualSize = dimension;
|
||||||
entries = new OpenIntToFieldHashMap<>(field,expectedSize);
|
entries = new OpenIntToFieldHashMap<T>(field,expectedSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -118,7 +118,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
MathUtils.checkNotNull(values);
|
MathUtils.checkNotNull(values);
|
||||||
this.field = field;
|
this.field = field;
|
||||||
virtualSize = values.length;
|
virtualSize = values.length;
|
||||||
entries = new OpenIntToFieldHashMap<>(field);
|
entries = new OpenIntToFieldHashMap<T>(field);
|
||||||
for (int key = 0; key < values.length; key++) {
|
for (int key = 0; key < values.length; key++) {
|
||||||
T value = values[key];
|
T value = values[key];
|
||||||
entries.put(key, value);
|
entries.put(key, value);
|
||||||
|
@ -133,7 +133,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
public SparseFieldVector(SparseFieldVector<T> v) {
|
public SparseFieldVector(SparseFieldVector<T> v) {
|
||||||
field = v.field;
|
field = v.field;
|
||||||
virtualSize = v.getDimension();
|
virtualSize = v.getDimension();
|
||||||
entries = new OpenIntToFieldHashMap<>(v.getEntries());
|
entries = new OpenIntToFieldHashMap<T>(v.getEntries());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -179,7 +179,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
* @return a new vector.
|
* @return a new vector.
|
||||||
*/
|
*/
|
||||||
public FieldVector<T> append(SparseFieldVector<T> v) {
|
public FieldVector<T> append(SparseFieldVector<T> v) {
|
||||||
SparseFieldVector<T> res = new SparseFieldVector<>(this, v.getDimension());
|
SparseFieldVector<T> res = new SparseFieldVector<T>(this, v.getDimension());
|
||||||
OpenIntToFieldHashMap<T>.Iterator iter = v.entries.iterator();
|
OpenIntToFieldHashMap<T>.Iterator iter = v.entries.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
iter.advance();
|
iter.advance();
|
||||||
|
@ -195,7 +195,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
return append((SparseFieldVector<T>) v);
|
return append((SparseFieldVector<T>) v);
|
||||||
} else {
|
} else {
|
||||||
final int n = v.getDimension();
|
final int n = v.getDimension();
|
||||||
FieldVector<T> res = new SparseFieldVector<>(this, n);
|
FieldVector<T> res = new SparseFieldVector<T>(this, n);
|
||||||
for (int i = 0; i < n; i++) {
|
for (int i = 0; i < n; i++) {
|
||||||
res.setEntry(i + virtualSize, v.getEntry(i));
|
res.setEntry(i + virtualSize, v.getEntry(i));
|
||||||
}
|
}
|
||||||
|
@ -209,7 +209,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
@Override
|
@Override
|
||||||
public FieldVector<T> append(T d) throws NullArgumentException {
|
public FieldVector<T> append(T d) throws NullArgumentException {
|
||||||
MathUtils.checkNotNull(d);
|
MathUtils.checkNotNull(d);
|
||||||
FieldVector<T> res = new SparseFieldVector<>(this, 1);
|
FieldVector<T> res = new SparseFieldVector<T>(this, 1);
|
||||||
res.setEntry(virtualSize, d);
|
res.setEntry(virtualSize, d);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -217,7 +217,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public FieldVector<T> copy() {
|
public FieldVector<T> copy() {
|
||||||
return new SparseFieldVector<>(this);
|
return new SparseFieldVector<T>(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
|
@ -238,7 +238,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
public FieldVector<T> ebeDivide(FieldVector<T> v)
|
public FieldVector<T> ebeDivide(FieldVector<T> v)
|
||||||
throws DimensionMismatchException, MathArithmeticException {
|
throws DimensionMismatchException, MathArithmeticException {
|
||||||
checkVectorDimensions(v.getDimension());
|
checkVectorDimensions(v.getDimension());
|
||||||
SparseFieldVector<T> res = new SparseFieldVector<>(this);
|
SparseFieldVector<T> res = new SparseFieldVector<T>(this);
|
||||||
OpenIntToFieldHashMap<T>.Iterator iter = res.entries.iterator();
|
OpenIntToFieldHashMap<T>.Iterator iter = res.entries.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
iter.advance();
|
iter.advance();
|
||||||
|
@ -252,7 +252,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
public FieldVector<T> ebeMultiply(FieldVector<T> v)
|
public FieldVector<T> ebeMultiply(FieldVector<T> v)
|
||||||
throws DimensionMismatchException {
|
throws DimensionMismatchException {
|
||||||
checkVectorDimensions(v.getDimension());
|
checkVectorDimensions(v.getDimension());
|
||||||
SparseFieldVector<T> res = new SparseFieldVector<>(this);
|
SparseFieldVector<T> res = new SparseFieldVector<T>(this);
|
||||||
OpenIntToFieldHashMap<T>.Iterator iter = res.entries.iterator();
|
OpenIntToFieldHashMap<T>.Iterator iter = res.entries.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
iter.advance();
|
iter.advance();
|
||||||
|
@ -289,7 +289,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
}
|
}
|
||||||
checkIndex(index);
|
checkIndex(index);
|
||||||
checkIndex(index + n - 1);
|
checkIndex(index + n - 1);
|
||||||
SparseFieldVector<T> res = new SparseFieldVector<>(field,n);
|
SparseFieldVector<T> res = new SparseFieldVector<T>(field,n);
|
||||||
int end = index + n;
|
int end = index + n;
|
||||||
OpenIntToFieldHashMap<T>.Iterator iter = entries.iterator();
|
OpenIntToFieldHashMap<T>.Iterator iter = entries.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
|
@ -387,7 +387,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
*/
|
*/
|
||||||
public FieldMatrix<T> outerProduct(SparseFieldVector<T> v) {
|
public FieldMatrix<T> outerProduct(SparseFieldVector<T> v) {
|
||||||
final int n = v.getDimension();
|
final int n = v.getDimension();
|
||||||
SparseFieldMatrix<T> res = new SparseFieldMatrix<>(field, virtualSize, n);
|
SparseFieldMatrix<T> res = new SparseFieldMatrix<T>(field, virtualSize, n);
|
||||||
OpenIntToFieldHashMap<T>.Iterator iter = entries.iterator();
|
OpenIntToFieldHashMap<T>.Iterator iter = entries.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
iter.advance();
|
iter.advance();
|
||||||
|
@ -407,7 +407,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
return outerProduct((SparseFieldVector<T>)v);
|
return outerProduct((SparseFieldVector<T>)v);
|
||||||
} else {
|
} else {
|
||||||
final int n = v.getDimension();
|
final int n = v.getDimension();
|
||||||
FieldMatrix<T> res = new SparseFieldMatrix<>(field, virtualSize, n);
|
FieldMatrix<T> res = new SparseFieldMatrix<T>(field, virtualSize, n);
|
||||||
OpenIntToFieldHashMap<T>.Iterator iter = entries.iterator();
|
OpenIntToFieldHashMap<T>.Iterator iter = entries.iterator();
|
||||||
while (iter.hasNext()) {
|
while (iter.hasNext()) {
|
||||||
iter.advance();
|
iter.advance();
|
||||||
|
@ -495,7 +495,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
} else {
|
} else {
|
||||||
final int n = v.getDimension();
|
final int n = v.getDimension();
|
||||||
checkVectorDimensions(n);
|
checkVectorDimensions(n);
|
||||||
SparseFieldVector<T> res = new SparseFieldVector<>(this);
|
SparseFieldVector<T> res = new SparseFieldVector<T>(this);
|
||||||
for (int i = 0; i < n; i++) {
|
for (int i = 0; i < n; i++) {
|
||||||
if (entries.containsKey(i)) {
|
if (entries.containsKey(i)) {
|
||||||
res.setEntry(i, entries.get(i).subtract(v.getEntry(i)));
|
res.setEntry(i, entries.get(i).subtract(v.getEntry(i)));
|
||||||
|
@ -578,7 +578,7 @@ public class SparseFieldVector<T extends FieldElement<T>> implements FieldVector
|
||||||
} else {
|
} else {
|
||||||
final int n = v.getDimension();
|
final int n = v.getDimension();
|
||||||
checkVectorDimensions(n);
|
checkVectorDimensions(n);
|
||||||
SparseFieldVector<T> res = new SparseFieldVector<>(field,
|
SparseFieldVector<T> res = new SparseFieldVector<T>(field,
|
||||||
getDimension());
|
getDimension());
|
||||||
for (int i = 0; i < n; i++) {
|
for (int i = 0; i < n; i++) {
|
||||||
res.setEntry(i, v.getEntry(i).add(getEntry(i)));
|
res.setEntry(i, v.getEntry(i).add(getEntry(i)));
|
||||||
|
|
|
@ -38,7 +38,7 @@ public class Cluster<T extends Clusterable> implements Serializable {
|
||||||
* Build a cluster centered at a specified point.
|
* Build a cluster centered at a specified point.
|
||||||
*/
|
*/
|
||||||
public Cluster() {
|
public Cluster() {
|
||||||
points = new ArrayList<>();
|
points = new ArrayList<T>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -136,8 +136,8 @@ public class DBSCANClusterer<T extends Clusterable> extends Clusterer<T> {
|
||||||
// sanity checks
|
// sanity checks
|
||||||
MathUtils.checkNotNull(points);
|
MathUtils.checkNotNull(points);
|
||||||
|
|
||||||
final List<Cluster<T>> clusters = new ArrayList<>();
|
final List<Cluster<T>> clusters = new ArrayList<Cluster<T>>();
|
||||||
final Map<Clusterable, PointStatus> visited = new HashMap<>();
|
final Map<Clusterable, PointStatus> visited = new HashMap<Clusterable, PointStatus>();
|
||||||
|
|
||||||
for (final T point : points) {
|
for (final T point : points) {
|
||||||
if (visited.get(point) != null) {
|
if (visited.get(point) != null) {
|
||||||
|
@ -146,7 +146,7 @@ public class DBSCANClusterer<T extends Clusterable> extends Clusterer<T> {
|
||||||
final List<T> neighbors = getNeighbors(point, points);
|
final List<T> neighbors = getNeighbors(point, points);
|
||||||
if (neighbors.size() >= minPts) {
|
if (neighbors.size() >= minPts) {
|
||||||
// DBSCAN does not care about center points
|
// DBSCAN does not care about center points
|
||||||
final Cluster<T> cluster = new Cluster<>();
|
final Cluster<T> cluster = new Cluster<T>();
|
||||||
clusters.add(expandCluster(cluster, point, neighbors, points, visited));
|
clusters.add(expandCluster(cluster, point, neighbors, points, visited));
|
||||||
} else {
|
} else {
|
||||||
visited.put(point, PointStatus.NOISE);
|
visited.put(point, PointStatus.NOISE);
|
||||||
|
@ -174,7 +174,7 @@ public class DBSCANClusterer<T extends Clusterable> extends Clusterer<T> {
|
||||||
cluster.addPoint(point);
|
cluster.addPoint(point);
|
||||||
visited.put(point, PointStatus.PART_OF_CLUSTER);
|
visited.put(point, PointStatus.PART_OF_CLUSTER);
|
||||||
|
|
||||||
List<T> seeds = new ArrayList<>(neighbors);
|
List<T> seeds = new ArrayList<T>(neighbors);
|
||||||
int index = 0;
|
int index = 0;
|
||||||
while (index < seeds.size()) {
|
while (index < seeds.size()) {
|
||||||
final T current = seeds.get(index);
|
final T current = seeds.get(index);
|
||||||
|
@ -205,7 +205,7 @@ public class DBSCANClusterer<T extends Clusterable> extends Clusterer<T> {
|
||||||
* @return the List of neighbors
|
* @return the List of neighbors
|
||||||
*/
|
*/
|
||||||
private List<T> getNeighbors(final T point, final Collection<T> points) {
|
private List<T> getNeighbors(final T point, final Collection<T> points) {
|
||||||
final List<T> neighbors = new ArrayList<>();
|
final List<T> neighbors = new ArrayList<T>();
|
||||||
for (final T neighbor : points) {
|
for (final T neighbor : points) {
|
||||||
if (point != neighbor && distance(neighbor, point) <= eps) {
|
if (point != neighbor && distance(neighbor, point) <= eps) {
|
||||||
neighbors.add(neighbor);
|
neighbors.add(neighbor);
|
||||||
|
@ -222,7 +222,7 @@ public class DBSCANClusterer<T extends Clusterable> extends Clusterer<T> {
|
||||||
* @return merged lists
|
* @return merged lists
|
||||||
*/
|
*/
|
||||||
private List<T> merge(final List<T> one, final List<T> two) {
|
private List<T> merge(final List<T> one, final List<T> two) {
|
||||||
final Set<T> oneSet = new HashSet<>(one);
|
final Set<T> oneSet = new HashSet<T>(one);
|
||||||
for (T item : two) {
|
for (T item : two) {
|
||||||
if (!oneSet.contains(item)) {
|
if (!oneSet.contains(item)) {
|
||||||
one.add(item);
|
one.add(item);
|
||||||
|
|
|
@ -279,8 +279,8 @@ public class FuzzyKMeansClusterer<T extends Clusterable> extends Clusterer<T> {
|
||||||
}
|
}
|
||||||
|
|
||||||
// copy the input collection to an unmodifiable list with indexed access
|
// copy the input collection to an unmodifiable list with indexed access
|
||||||
points = Collections.unmodifiableList(new ArrayList<>(dataPoints));
|
points = Collections.unmodifiableList(new ArrayList<T>(dataPoints));
|
||||||
clusters = new ArrayList<>();
|
clusters = new ArrayList<CentroidCluster<T>>();
|
||||||
membershipMatrix = new double[size][k];
|
membershipMatrix = new double[size][k];
|
||||||
final double[][] oldMatrix = new double[size][k];
|
final double[][] oldMatrix = new double[size][k];
|
||||||
|
|
||||||
|
@ -316,7 +316,7 @@ public class FuzzyKMeansClusterer<T extends Clusterable> extends Clusterer<T> {
|
||||||
*/
|
*/
|
||||||
private void updateClusterCenters() {
|
private void updateClusterCenters() {
|
||||||
int j = 0;
|
int j = 0;
|
||||||
final List<CentroidCluster<T>> newClusters = new ArrayList<>(k);
|
final List<CentroidCluster<T>> newClusters = new ArrayList<CentroidCluster<T>>(k);
|
||||||
for (final CentroidCluster<T> cluster : clusters) {
|
for (final CentroidCluster<T> cluster : clusters) {
|
||||||
final Clusterable center = cluster.getCenter();
|
final Clusterable center = cluster.getCenter();
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
|
@ -216,7 +216,7 @@ public class KMeansPlusPlusClusterer<T extends Clusterable> extends Clusterer<T>
|
||||||
final int max = (maxIterations < 0) ? Integer.MAX_VALUE : maxIterations;
|
final int max = (maxIterations < 0) ? Integer.MAX_VALUE : maxIterations;
|
||||||
for (int count = 0; count < max; count++) {
|
for (int count = 0; count < max; count++) {
|
||||||
boolean emptyCluster = false;
|
boolean emptyCluster = false;
|
||||||
List<CentroidCluster<T>> newClusters = new ArrayList<>();
|
List<CentroidCluster<T>> newClusters = new ArrayList<CentroidCluster<T>>();
|
||||||
for (final CentroidCluster<T> cluster : clusters) {
|
for (final CentroidCluster<T> cluster : clusters) {
|
||||||
final Clusterable newCenter;
|
final Clusterable newCenter;
|
||||||
if (cluster.getPoints().isEmpty()) {
|
if (cluster.getPoints().isEmpty()) {
|
||||||
|
@ -288,7 +288,7 @@ public class KMeansPlusPlusClusterer<T extends Clusterable> extends Clusterer<T>
|
||||||
|
|
||||||
// Convert to list for indexed access. Make it unmodifiable, since removal of items
|
// Convert to list for indexed access. Make it unmodifiable, since removal of items
|
||||||
// would screw up the logic of this method.
|
// would screw up the logic of this method.
|
||||||
final List<T> pointList = Collections.unmodifiableList(new ArrayList<> (points));
|
final List<T> pointList = Collections.unmodifiableList(new ArrayList<T> (points));
|
||||||
|
|
||||||
// The number of points in the list.
|
// The number of points in the list.
|
||||||
final int numPoints = pointList.size();
|
final int numPoints = pointList.size();
|
||||||
|
@ -298,7 +298,7 @@ public class KMeansPlusPlusClusterer<T extends Clusterable> extends Clusterer<T>
|
||||||
final boolean[] taken = new boolean[numPoints];
|
final boolean[] taken = new boolean[numPoints];
|
||||||
|
|
||||||
// The resulting list of initial centers.
|
// The resulting list of initial centers.
|
||||||
final List<CentroidCluster<T>> resultSet = new ArrayList<>();
|
final List<CentroidCluster<T>> resultSet = new ArrayList<CentroidCluster<T>>();
|
||||||
|
|
||||||
// Choose one center uniformly at random from among the data points.
|
// Choose one center uniformly at random from among the data points.
|
||||||
final int firstPointIndex = random.nextInt(numPoints);
|
final int firstPointIndex = random.nextInt(numPoints);
|
||||||
|
|
|
@ -105,7 +105,7 @@ public class MapUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return new Pair<>(best[0], best[1]);
|
return new Pair<Neuron, Neuron>(best[0], best[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -130,7 +130,7 @@ public class MapUtils {
|
||||||
public static Neuron[] sort(double[] features,
|
public static Neuron[] sort(double[] features,
|
||||||
Iterable<Neuron> neurons,
|
Iterable<Neuron> neurons,
|
||||||
DistanceMeasure distance) {
|
DistanceMeasure distance) {
|
||||||
final List<PairNeuronDouble> list = new ArrayList<>();
|
final List<PairNeuronDouble> list = new ArrayList<PairNeuronDouble>();
|
||||||
|
|
||||||
for (final Neuron n : neurons) {
|
for (final Neuron n : neurons) {
|
||||||
final double d = distance.compute(n.getFeatures(), features);
|
final double d = distance.compute(n.getFeatures(), features);
|
||||||
|
@ -196,7 +196,7 @@ public class MapUtils {
|
||||||
public static int[][] computeHitHistogram(Iterable<double[]> data,
|
public static int[][] computeHitHistogram(Iterable<double[]> data,
|
||||||
NeuronSquareMesh2D map,
|
NeuronSquareMesh2D map,
|
||||||
DistanceMeasure distance) {
|
DistanceMeasure distance) {
|
||||||
final HashMap<Neuron, Integer> hit = new HashMap<>();
|
final HashMap<Neuron, Integer> hit = new HashMap<Neuron, Integer>();
|
||||||
final Network net = map.getNetwork();
|
final Network net = map.getNetwork();
|
||||||
|
|
||||||
for (double[] f : data) {
|
for (double[] f : data) {
|
||||||
|
|
|
@ -51,14 +51,14 @@ public class Network
|
||||||
private static final long serialVersionUID = 20130207L;
|
private static final long serialVersionUID = 20130207L;
|
||||||
/** Neurons. */
|
/** Neurons. */
|
||||||
private final ConcurrentHashMap<Long, Neuron> neuronMap
|
private final ConcurrentHashMap<Long, Neuron> neuronMap
|
||||||
= new ConcurrentHashMap<>();
|
= new ConcurrentHashMap<Long, Neuron>();
|
||||||
/** Next available neuron identifier. */
|
/** Next available neuron identifier. */
|
||||||
private final AtomicLong nextId;
|
private final AtomicLong nextId;
|
||||||
/** Neuron's features set size. */
|
/** Neuron's features set size. */
|
||||||
private final int featureSize;
|
private final int featureSize;
|
||||||
/** Links. */
|
/** Links. */
|
||||||
private final ConcurrentHashMap<Long, Set<Long>> linkMap
|
private final ConcurrentHashMap<Long, Set<Long>> linkMap
|
||||||
= new ConcurrentHashMap<>();
|
= new ConcurrentHashMap<Long, Set<Long>>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Comparator that prescribes an order of the neurons according
|
* Comparator that prescribes an order of the neurons according
|
||||||
|
@ -155,7 +155,7 @@ public class Network
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Map.Entry<Long, Set<Long>> e : linkMap.entrySet()) {
|
for (Map.Entry<Long, Set<Long>> e : linkMap.entrySet()) {
|
||||||
copy.linkMap.put(e.getKey(), new HashSet<>(e.getValue()));
|
copy.linkMap.put(e.getKey(), new HashSet<Long>(e.getValue()));
|
||||||
}
|
}
|
||||||
|
|
||||||
return copy;
|
return copy;
|
||||||
|
@ -178,7 +178,7 @@ public class Network
|
||||||
* @see NeuronIdentifierComparator
|
* @see NeuronIdentifierComparator
|
||||||
*/
|
*/
|
||||||
public Collection<Neuron> getNeurons(Comparator<Neuron> comparator) {
|
public Collection<Neuron> getNeurons(Comparator<Neuron> comparator) {
|
||||||
final List<Neuron> neurons = new ArrayList<>();
|
final List<Neuron> neurons = new ArrayList<Neuron>();
|
||||||
neurons.addAll(neuronMap.values());
|
neurons.addAll(neuronMap.values());
|
||||||
|
|
||||||
Collections.sort(neurons, comparator);
|
Collections.sort(neurons, comparator);
|
||||||
|
@ -356,7 +356,7 @@ public class Network
|
||||||
*/
|
*/
|
||||||
public Collection<Neuron> getNeighbours(Iterable<Neuron> neurons,
|
public Collection<Neuron> getNeighbours(Iterable<Neuron> neurons,
|
||||||
Iterable<Neuron> exclude) {
|
Iterable<Neuron> exclude) {
|
||||||
final Set<Long> idList = new HashSet<>();
|
final Set<Long> idList = new HashSet<Long>();
|
||||||
|
|
||||||
for (Neuron n : neurons) {
|
for (Neuron n : neurons) {
|
||||||
idList.addAll(linkMap.get(n.getIdentifier()));
|
idList.addAll(linkMap.get(n.getIdentifier()));
|
||||||
|
@ -367,7 +367,7 @@ public class Network
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<Neuron> neuronList = new ArrayList<>();
|
final List<Neuron> neuronList = new ArrayList<Neuron>();
|
||||||
for (Long id : idList) {
|
for (Long id : idList) {
|
||||||
neuronList.add(getNeuron(id));
|
neuronList.add(getNeuron(id));
|
||||||
}
|
}
|
||||||
|
@ -403,7 +403,7 @@ public class Network
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
final List<Neuron> neuronList = new ArrayList<>();
|
final List<Neuron> neuronList = new ArrayList<Neuron>();
|
||||||
for (Long id : idList) {
|
for (Long id : idList) {
|
||||||
neuronList.add(getNeuron(id));
|
neuronList.add(getNeuron(id));
|
||||||
}
|
}
|
||||||
|
|
|
@ -63,7 +63,7 @@ public class Neuron implements Serializable {
|
||||||
double[] features) {
|
double[] features) {
|
||||||
this.identifier = identifier;
|
this.identifier = identifier;
|
||||||
this.size = features.length;
|
this.size = features.length;
|
||||||
this.features = new AtomicReference<>(features.clone());
|
this.features = new AtomicReference<double[]>(features.clone());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -111,10 +111,10 @@ public class KohonenUpdateAction implements UpdateAction {
|
||||||
|
|
||||||
if (currentNeighbourhood > 0) {
|
if (currentNeighbourhood > 0) {
|
||||||
// Initial set of neurons only contains the winning neuron.
|
// Initial set of neurons only contains the winning neuron.
|
||||||
Collection<Neuron> neighbours = new HashSet<>();
|
Collection<Neuron> neighbours = new HashSet<Neuron>();
|
||||||
neighbours.add(best);
|
neighbours.add(best);
|
||||||
// Winning neuron must be excluded from the neighbours.
|
// Winning neuron must be excluded from the neighbours.
|
||||||
final HashSet<Neuron> exclude = new HashSet<>();
|
final HashSet<Neuron> exclude = new HashSet<Neuron>();
|
||||||
exclude.add(best);
|
exclude.add(best);
|
||||||
|
|
||||||
int radius = 1;
|
int radius = 1;
|
||||||
|
|
|
@ -423,7 +423,7 @@ public class NeuronSquareMesh2D
|
||||||
*/
|
*/
|
||||||
private void createLinks() {
|
private void createLinks() {
|
||||||
// "linkEnd" will store the identifiers of the "neighbours".
|
// "linkEnd" will store the identifiers of the "neighbours".
|
||||||
final List<Long> linkEnd = new ArrayList<>();
|
final List<Long> linkEnd = new ArrayList<Long>();
|
||||||
final int iLast = numberOfRows - 1;
|
final int iLast = numberOfRows - 1;
|
||||||
final int jLast = numberOfColumns - 1;
|
final int jLast = numberOfColumns - 1;
|
||||||
for (int i = 0; i < numberOfRows; i++) {
|
for (int i = 0; i < numberOfRows; i++) {
|
||||||
|
|
|
@ -29,7 +29,7 @@ import org.apache.commons.math4.exception.MathIllegalStateException;
|
||||||
*/
|
*/
|
||||||
public class LocationFinder {
|
public class LocationFinder {
|
||||||
/** Identifier to location mapping. */
|
/** Identifier to location mapping. */
|
||||||
private final Map<Long, Location> locations = new HashMap<>();
|
private final Map<Long, Location> locations = new HashMap<Long, Location>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Container holding a (row, column) pair.
|
* Container holding a (row, column) pair.
|
||||||
|
|
|
@ -95,10 +95,10 @@ public abstract class AbstractFieldIntegrator<T extends RealFieldElement<T>> imp
|
||||||
protected AbstractFieldIntegrator(final Field<T> field, final String name) {
|
protected AbstractFieldIntegrator(final Field<T> field, final String name) {
|
||||||
this.field = field;
|
this.field = field;
|
||||||
this.name = name;
|
this.name = name;
|
||||||
stepHandlers = new ArrayList<>();
|
stepHandlers = new ArrayList<FieldStepHandler<T>>();
|
||||||
stepStart = null;
|
stepStart = null;
|
||||||
stepSize = null;
|
stepSize = null;
|
||||||
eventsStates = new ArrayList<>();
|
eventsStates = new ArrayList<FieldEventState<T>>();
|
||||||
statesInitialized = false;
|
statesInitialized = false;
|
||||||
evaluations = IntegerSequence.Incrementor.create().withMaximalCount(Integer.MAX_VALUE);
|
evaluations = IntegerSequence.Incrementor.create().withMaximalCount(Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
@ -142,7 +142,7 @@ public abstract class AbstractFieldIntegrator<T extends RealFieldElement<T>> imp
|
||||||
final int maxIterationCount) {
|
final int maxIterationCount) {
|
||||||
addEventHandler(handler, maxCheckInterval, convergence,
|
addEventHandler(handler, maxCheckInterval, convergence,
|
||||||
maxIterationCount,
|
maxIterationCount,
|
||||||
new FieldBracketingNthOrderBrentSolver<>(field.getZero().add(DEFAULT_RELATIVE_ACCURACY),
|
new FieldBracketingNthOrderBrentSolver<T>(field.getZero().add(DEFAULT_RELATIVE_ACCURACY),
|
||||||
field.getZero().add(convergence),
|
field.getZero().add(convergence),
|
||||||
field.getZero().add(DEFAULT_FUNCTION_VALUE_ACCURACY),
|
field.getZero().add(DEFAULT_FUNCTION_VALUE_ACCURACY),
|
||||||
5));
|
5));
|
||||||
|
@ -155,14 +155,14 @@ public abstract class AbstractFieldIntegrator<T extends RealFieldElement<T>> imp
|
||||||
final double convergence,
|
final double convergence,
|
||||||
final int maxIterationCount,
|
final int maxIterationCount,
|
||||||
final BracketedRealFieldUnivariateSolver<T> solver) {
|
final BracketedRealFieldUnivariateSolver<T> solver) {
|
||||||
eventsStates.add(new FieldEventState<>(handler, maxCheckInterval, field.getZero().add(convergence),
|
eventsStates.add(new FieldEventState<T>(handler, maxCheckInterval, field.getZero().add(convergence),
|
||||||
maxIterationCount, solver));
|
maxIterationCount, solver));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public Collection<FieldEventHandler<T>> getEventHandlers() {
|
public Collection<FieldEventHandler<T>> getEventHandlers() {
|
||||||
final List<FieldEventHandler<T>> list = new ArrayList<>(eventsStates.size());
|
final List<FieldEventHandler<T>> list = new ArrayList<FieldEventHandler<T>>(eventsStates.size());
|
||||||
for (FieldEventState<T> state : eventsStates) {
|
for (FieldEventState<T> state : eventsStates) {
|
||||||
list.add(state.getEventHandler());
|
list.add(state.getEventHandler());
|
||||||
}
|
}
|
||||||
|
@ -223,7 +223,7 @@ public abstract class AbstractFieldIntegrator<T extends RealFieldElement<T>> imp
|
||||||
|
|
||||||
// set up derivatives of initial state
|
// set up derivatives of initial state
|
||||||
final T[] y0Dot = computeDerivatives(t0, y0);
|
final T[] y0Dot = computeDerivatives(t0, y0);
|
||||||
final FieldODEStateAndDerivative<T> state0 = new FieldODEStateAndDerivative<>(t0, y0, y0Dot);
|
final FieldODEStateAndDerivative<T> state0 = new FieldODEStateAndDerivative<T>(t0, y0, y0Dot);
|
||||||
|
|
||||||
// initialize event handlers
|
// initialize event handlers
|
||||||
for (final FieldEventState<T> state : eventsStates) {
|
for (final FieldEventState<T> state : eventsStates) {
|
||||||
|
@ -307,7 +307,7 @@ public abstract class AbstractFieldIntegrator<T extends RealFieldElement<T>> imp
|
||||||
|
|
||||||
// search for next events that may occur during the step
|
// search for next events that may occur during the step
|
||||||
final int orderingSign = interpolator.isForward() ? +1 : -1;
|
final int orderingSign = interpolator.isForward() ? +1 : -1;
|
||||||
SortedSet<FieldEventState<T>> occurringEvents = new TreeSet<>(new Comparator<FieldEventState<T>>() {
|
SortedSet<FieldEventState<T>> occurringEvents = new TreeSet<FieldEventState<T>>(new Comparator<FieldEventState<T>>() {
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -82,10 +82,10 @@ public abstract class AbstractIntegrator implements FirstOrderIntegrator {
|
||||||
*/
|
*/
|
||||||
public AbstractIntegrator(final String name) {
|
public AbstractIntegrator(final String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
stepHandlers = new ArrayList<>();
|
stepHandlers = new ArrayList<StepHandler>();
|
||||||
stepStart = Double.NaN;
|
stepStart = Double.NaN;
|
||||||
stepSize = Double.NaN;
|
stepSize = Double.NaN;
|
||||||
eventsStates = new ArrayList<>();
|
eventsStates = new ArrayList<EventState>();
|
||||||
statesInitialized = false;
|
statesInitialized = false;
|
||||||
evaluations = IntegerSequence.Incrementor.create().withMaximalCount(Integer.MAX_VALUE);
|
evaluations = IntegerSequence.Incrementor.create().withMaximalCount(Integer.MAX_VALUE);
|
||||||
}
|
}
|
||||||
|
@ -145,7 +145,7 @@ public abstract class AbstractIntegrator implements FirstOrderIntegrator {
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
public Collection<EventHandler> getEventHandlers() {
|
public Collection<EventHandler> getEventHandlers() {
|
||||||
final List<EventHandler> list = new ArrayList<>(eventsStates.size());
|
final List<EventHandler> list = new ArrayList<EventHandler>(eventsStates.size());
|
||||||
for (EventState state : eventsStates) {
|
for (EventState state : eventsStates) {
|
||||||
list.add(state.getEventHandler());
|
list.add(state.getEventHandler());
|
||||||
}
|
}
|
||||||
|
@ -341,7 +341,7 @@ public abstract class AbstractIntegrator implements FirstOrderIntegrator {
|
||||||
|
|
||||||
// search for next events that may occur during the step
|
// search for next events that may occur during the step
|
||||||
final int orderingSign = interpolator.isForward() ? +1 : -1;
|
final int orderingSign = interpolator.isForward() ? +1 : -1;
|
||||||
SortedSet<EventState> occurringEvents = new TreeSet<>(new Comparator<EventState>() {
|
SortedSet<EventState> occurringEvents = new TreeSet<EventState>(new Comparator<EventState>() {
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -33,7 +33,7 @@ public abstract class AbstractParameterizable implements Parameterizable {
|
||||||
* @param names names of the supported parameters
|
* @param names names of the supported parameters
|
||||||
*/
|
*/
|
||||||
protected AbstractParameterizable(final String ... names) {
|
protected AbstractParameterizable(final String ... names) {
|
||||||
parametersNames = new ArrayList<>();
|
parametersNames = new ArrayList<String>();
|
||||||
for (final String name : names) {
|
for (final String name : names) {
|
||||||
parametersNames.add(name);
|
parametersNames.add(name);
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,7 @@ public abstract class AbstractParameterizable implements Parameterizable {
|
||||||
* @param names names of the supported parameters
|
* @param names names of the supported parameters
|
||||||
*/
|
*/
|
||||||
protected AbstractParameterizable(final Collection<String> names) {
|
protected AbstractParameterizable(final Collection<String> names) {
|
||||||
parametersNames = new ArrayList<>();
|
parametersNames = new ArrayList<String>();
|
||||||
parametersNames.addAll(names);
|
parametersNames.addAll(names);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -100,7 +100,7 @@ public class ContinuousOutputFieldModel<T extends RealFieldElement<T>>
|
||||||
* Build an empty continuous output model.
|
* Build an empty continuous output model.
|
||||||
*/
|
*/
|
||||||
public ContinuousOutputFieldModel() {
|
public ContinuousOutputFieldModel() {
|
||||||
steps = new ArrayList<>();
|
steps = new ArrayList<FieldStepInterpolator<T>>();
|
||||||
initialTime = null;
|
initialTime = null;
|
||||||
finalTime = null;
|
finalTime = null;
|
||||||
forward = true;
|
forward = true;
|
||||||
|
|
|
@ -111,7 +111,7 @@ public class ContinuousOutputModel
|
||||||
* Build an empty continuous output model.
|
* Build an empty continuous output model.
|
||||||
*/
|
*/
|
||||||
public ContinuousOutputModel() {
|
public ContinuousOutputModel() {
|
||||||
steps = new ArrayList<>();
|
steps = new ArrayList<StepInterpolator>();
|
||||||
initialTime = Double.NaN;
|
initialTime = Double.NaN;
|
||||||
finalTime = Double.NaN;
|
finalTime = Double.NaN;
|
||||||
forward = true;
|
forward = true;
|
||||||
|
|
|
@ -76,7 +76,7 @@ public class ExpandableStatefulODE {
|
||||||
this.time = Double.NaN;
|
this.time = Double.NaN;
|
||||||
this.primaryState = new double[n];
|
this.primaryState = new double[n];
|
||||||
this.primaryStateDot = new double[n];
|
this.primaryStateDot = new double[n];
|
||||||
this.components = new ArrayList<>();
|
this.components = new ArrayList<ExpandableStatefulODE.SecondaryComponent>();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get the primary set of differential equations.
|
/** Get the primary set of differential equations.
|
||||||
|
@ -138,7 +138,7 @@ public class ExpandableStatefulODE {
|
||||||
final int firstIndex;
|
final int firstIndex;
|
||||||
if (components.isEmpty()) {
|
if (components.isEmpty()) {
|
||||||
// lazy creation of the components list
|
// lazy creation of the components list
|
||||||
components = new ArrayList<>();
|
components = new ArrayList<ExpandableStatefulODE.SecondaryComponent>();
|
||||||
firstIndex = primary.getDimension();
|
firstIndex = primary.getDimension();
|
||||||
} else {
|
} else {
|
||||||
final SecondaryComponent last = components.get(components.size() - 1);
|
final SecondaryComponent last = components.get(components.size() - 1);
|
||||||
|
|
|
@ -130,7 +130,7 @@ public class FieldEquationsMapper<T extends RealFieldElement<T>> implements Seri
|
||||||
final T[] state = extractEquationData(index, y);
|
final T[] state = extractEquationData(index, y);
|
||||||
final T[] derivative = extractEquationData(index, yDot);
|
final T[] derivative = extractEquationData(index, yDot);
|
||||||
if (n < 2) {
|
if (n < 2) {
|
||||||
return new FieldODEStateAndDerivative<>(t, state, derivative);
|
return new FieldODEStateAndDerivative<T>(t, state, derivative);
|
||||||
} else {
|
} else {
|
||||||
final T[][] secondaryState = MathArrays.buildArray(t.getField(), n - 1, -1);
|
final T[][] secondaryState = MathArrays.buildArray(t.getField(), n - 1, -1);
|
||||||
final T[][] secondaryDerivative = MathArrays.buildArray(t.getField(), n - 1, -1);
|
final T[][] secondaryDerivative = MathArrays.buildArray(t.getField(), n - 1, -1);
|
||||||
|
@ -138,7 +138,7 @@ public class FieldEquationsMapper<T extends RealFieldElement<T>> implements Seri
|
||||||
secondaryState[index - 1] = extractEquationData(index, y);
|
secondaryState[index - 1] = extractEquationData(index, y);
|
||||||
secondaryDerivative[index - 1] = extractEquationData(index, yDot);
|
secondaryDerivative[index - 1] = extractEquationData(index, yDot);
|
||||||
}
|
}
|
||||||
return new FieldODEStateAndDerivative<>(t, state, derivative, secondaryState, secondaryDerivative);
|
return new FieldODEStateAndDerivative<T>(t, state, derivative, secondaryState, secondaryDerivative);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -65,8 +65,8 @@ public class FieldExpandableODE<T extends RealFieldElement<T>> {
|
||||||
*/
|
*/
|
||||||
public FieldExpandableODE(final FirstOrderFieldDifferentialEquations<T> primary) {
|
public FieldExpandableODE(final FirstOrderFieldDifferentialEquations<T> primary) {
|
||||||
this.primary = primary;
|
this.primary = primary;
|
||||||
this.components = new ArrayList<>();
|
this.components = new ArrayList<FieldSecondaryEquations<T>>();
|
||||||
this.mapper = new FieldEquationsMapper<>(null, primary.getDimension());
|
this.mapper = new FieldEquationsMapper<T>(null, primary.getDimension());
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get the mapper for the set of equations.
|
/** Get the mapper for the set of equations.
|
||||||
|
@ -86,7 +86,7 @@ public class FieldExpandableODE<T extends RealFieldElement<T>> {
|
||||||
public int addSecondaryEquations(final FieldSecondaryEquations<T> secondary) {
|
public int addSecondaryEquations(final FieldSecondaryEquations<T> secondary) {
|
||||||
|
|
||||||
components.add(secondary);
|
components.add(secondary);
|
||||||
mapper = new FieldEquationsMapper<>(mapper, secondary.getDimension());
|
mapper = new FieldEquationsMapper<T>(mapper, secondary.getDimension());
|
||||||
|
|
||||||
return components.size();
|
return components.size();
|
||||||
|
|
||||||
|
|
|
@ -141,7 +141,7 @@ public class JacobianMatrices {
|
||||||
}
|
}
|
||||||
this.dirtyParameter = false;
|
this.dirtyParameter = false;
|
||||||
|
|
||||||
this.jacobianProviders = new ArrayList<>();
|
this.jacobianProviders = new ArrayList<ParameterJacobianProvider>();
|
||||||
|
|
||||||
// set the default initial state Jacobian to the identity
|
// set the default initial state Jacobian to the identity
|
||||||
// and the default initial parameters Jacobian to the null matrix
|
// and the default initial parameters Jacobian to the null matrix
|
||||||
|
|
|
@ -130,7 +130,7 @@ public abstract class MultistepFieldIntegrator<T extends RealFieldElement<T>>
|
||||||
nSteps, 2, true);
|
nSteps, 2, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
starter = new DormandPrince853FieldIntegrator<>(field, minStep, maxStep,
|
starter = new DormandPrince853FieldIntegrator<T>(field, minStep, maxStep,
|
||||||
scalAbsoluteTolerance,
|
scalAbsoluteTolerance,
|
||||||
scalRelativeTolerance);
|
scalRelativeTolerance);
|
||||||
this.nSteps = nSteps;
|
this.nSteps = nSteps;
|
||||||
|
@ -170,7 +170,7 @@ public abstract class MultistepFieldIntegrator<T extends RealFieldElement<T>>
|
||||||
final double[] vecAbsoluteTolerance,
|
final double[] vecAbsoluteTolerance,
|
||||||
final double[] vecRelativeTolerance) {
|
final double[] vecRelativeTolerance) {
|
||||||
super(field, name, minStep, maxStep, vecAbsoluteTolerance, vecRelativeTolerance);
|
super(field, name, minStep, maxStep, vecAbsoluteTolerance, vecRelativeTolerance);
|
||||||
starter = new DormandPrince853FieldIntegrator<>(field, minStep, maxStep,
|
starter = new DormandPrince853FieldIntegrator<T>(field, minStep, maxStep,
|
||||||
vecAbsoluteTolerance,
|
vecAbsoluteTolerance,
|
||||||
vecRelativeTolerance);
|
vecRelativeTolerance);
|
||||||
this.nSteps = nSteps;
|
this.nSteps = nSteps;
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue