Revert "Remove redundant type arguments."

This reverts commit 8b5f4535ec.
This commit is contained in:
Gary Gregory 2016-09-20 10:30:57 -07:00
parent 8b5f4535ec
commit 6df150da22
270 changed files with 1554 additions and 1552 deletions

View File

@ -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) {

View File

@ -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());

View File

@ -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);
} }
} }

View File

@ -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);
} }
} }

View File

@ -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);
} }
} }

View File

@ -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);
} }
} }

View File

@ -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);
} }
} }

View File

@ -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.

View File

@ -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.

View File

@ -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()));
} }

View File

@ -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;

View File

@ -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);

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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;

View File

@ -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);

View File

@ -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[]) {

View File

@ -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();

View File

@ -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} */

View File

@ -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

View File

@ -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);
} }
/** /**

View File

@ -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);
} }
} }

View File

@ -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));
} }

View File

@ -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);
} }
/** /**

View File

@ -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));
} }

View File

@ -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());

View File

@ -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;

View File

@ -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);
} }

View File

@ -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();

View File

@ -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));

View File

@ -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.

View File

@ -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);
} }

View File

@ -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);

View File

@ -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());

View File

@ -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();

View File

@ -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);

View File

@ -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]));
} }

View File

@ -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);
} }
} }

View File

@ -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())),

View File

@ -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));
} }

View File

@ -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;

View File

@ -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) {

View File

@ -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()),

View File

@ -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()));

View File

@ -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)));
} }

View File

@ -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);

View File

@ -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);

View File

@ -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} */

View File

@ -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)));
} }

View File

@ -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);

View File

@ -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++) {

View File

@ -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));
} }

View File

@ -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);

View File

@ -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);

View File

@ -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);
} }
} }

View File

@ -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));
} }

View File

@ -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();

View File

@ -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>>());
} }

View File

@ -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.

View File

@ -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);
} }
} }

View File

@ -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);

View File

@ -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);
} }
} }

View File

@ -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());
} }

View File

@ -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} */

View File

@ -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 long edge // the polygon covers an hemisphere, and its boundary is one 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 long edge // the polygon covers an hemisphere, and its boundary is one 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);

View File

@ -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));
} }

View File

@ -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.

View File

@ -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);
} }
} }

View File

@ -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) {

View File

@ -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);
} }

View File

@ -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) {

View File

@ -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;

View File

@ -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);
} }

View File

@ -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);
} }
/** /**

View File

@ -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;

View File

@ -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()) {

View File

@ -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} */

View File

@ -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)));

View File

@ -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>();
} }
/** /**

View File

@ -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);

View File

@ -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;

View File

@ -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);

View File

@ -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) {

View File

@ -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));
} }

View File

@ -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());
} }
/** /**

View File

@ -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;

View File

@ -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++) {

View File

@ -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.

View File

@ -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

View File

@ -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

View File

@ -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);
} }

View File

@ -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;

View File

@ -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;

View File

@ -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);

View File

@ -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);
} }
} }

View File

@ -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();

View File

@ -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

View File

@ -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