added min/max getters for real vectors
For compatibility reasons, these methods have been put in the topmost abstract class but not in the interface yet. It could be pushed to the interface when next major version will be released. JIRA: MATH-334 git-svn-id: https://svn.apache.org/repos/asf/commons/proper/math/trunk@904231 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
8dd2239074
commit
73e340ab6e
|
@ -292,6 +292,58 @@ public abstract class AbstractRealVector implements RealVector {
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Get the index of the minimum entry.
|
||||||
|
* @return index of the minimum entry or -1 if vector length is 0
|
||||||
|
* or all entries are NaN
|
||||||
|
*/
|
||||||
|
public int getMinIndex() {
|
||||||
|
int minIndex = -1;
|
||||||
|
double minValue = Double.POSITIVE_INFINITY;
|
||||||
|
Iterator<Entry> iterator = iterator();
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
final Entry entry = iterator.next();
|
||||||
|
if (entry.getValue() <= minValue) {
|
||||||
|
minIndex = entry.getIndex();
|
||||||
|
minValue = entry.getValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return minIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Get the value of the minimum entry.
|
||||||
|
* @return value of the minimum entry or NaN if all entries are NaN
|
||||||
|
*/
|
||||||
|
public double getMinValue() {
|
||||||
|
final int minIndex = getMinIndex();
|
||||||
|
return minIndex < 0 ? Double.NaN : getEntry(minIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Get the index of the maximum entry.
|
||||||
|
* @return index of the maximum entry or -1 if vector length is 0
|
||||||
|
* or all entries are NaN
|
||||||
|
*/
|
||||||
|
public int getMaxIndex() {
|
||||||
|
int maxIndex = -1;
|
||||||
|
double maxValue = Double.NEGATIVE_INFINITY;
|
||||||
|
Iterator<Entry> iterator = iterator();
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
final Entry entry = iterator.next();
|
||||||
|
if (entry.getValue() >= maxValue) {
|
||||||
|
maxIndex = entry.getIndex();
|
||||||
|
maxValue = entry.getValue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return maxIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Get the value of the maximum entry.
|
||||||
|
* @return value of the maximum entry or NaN if all entries are NaN
|
||||||
|
*/
|
||||||
|
public double getMaxValue() {
|
||||||
|
final int maxIndex = getMaxIndex();
|
||||||
|
return maxIndex < 0 ? Double.NaN : getEntry(maxIndex);
|
||||||
|
}
|
||||||
|
|
||||||
/** {@inheritDoc} */
|
/** {@inheritDoc} */
|
||||||
public RealVector mapAbs() {
|
public RealVector mapAbs() {
|
||||||
return copy().mapAbsToSelf();
|
return copy().mapAbsToSelf();
|
||||||
|
|
|
@ -39,6 +39,10 @@ The <action> type attribute can be add,update,fix,remove.
|
||||||
</properties>
|
</properties>
|
||||||
<body>
|
<body>
|
||||||
<release version="2.1" date="TBD" description="TBD">
|
<release version="2.1" date="TBD" description="TBD">
|
||||||
|
<action dev="luc" type="add" issue="MATH-334" >
|
||||||
|
Added min/max getters for real vectors (not yet in the RealVector interface for
|
||||||
|
compatibility purposes, but in the AbstractRealVector abstract class).
|
||||||
|
</action>
|
||||||
<action dev="luc" type="fix" issue="MATH-338" due-to="Vincent Morand">
|
<action dev="luc" type="fix" issue="MATH-338" due-to="Vincent Morand">
|
||||||
Fixed automatic step initialization in embedded Runge-Kutta integrators.
|
Fixed automatic step initialization in embedded Runge-Kutta integrators.
|
||||||
The relative tolerance setting was never used, only the absolute tolerance
|
The relative tolerance setting was never used, only the absolute tolerance
|
||||||
|
|
|
@ -1308,6 +1308,30 @@ public class ArrayRealVectorTest extends TestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void testMinMax() {
|
||||||
|
ArrayRealVector v1 = new ArrayRealVector(new double[] { 0, -6, 4, 12, 7 });
|
||||||
|
assertEquals(1, v1.getMinIndex());
|
||||||
|
assertEquals(-6, v1.getMinValue(), 1.0e-12);
|
||||||
|
assertEquals(3, v1.getMaxIndex());
|
||||||
|
assertEquals(12, v1.getMaxValue(), 1.0e-12);
|
||||||
|
ArrayRealVector v2 = new ArrayRealVector(new double[] { Double.NaN, 3, Double.NaN, -2 });
|
||||||
|
assertEquals(3, v2.getMinIndex());
|
||||||
|
assertEquals(-2, v2.getMinValue(), 1.0e-12);
|
||||||
|
assertEquals(1, v2.getMaxIndex());
|
||||||
|
assertEquals(3, v2.getMaxValue(), 1.0e-12);
|
||||||
|
ArrayRealVector v3 = new ArrayRealVector(new double[] { Double.NaN, Double.NaN });
|
||||||
|
assertEquals(-1, v3.getMinIndex());
|
||||||
|
assertTrue(Double.isNaN(v3.getMinValue()));
|
||||||
|
assertEquals(-1, v3.getMaxIndex());
|
||||||
|
assertTrue(Double.isNaN(v3.getMaxValue()));
|
||||||
|
ArrayRealVector v4 = new ArrayRealVector(new double[0]);
|
||||||
|
assertEquals(-1, v4.getMinIndex());
|
||||||
|
assertTrue(Double.isNaN(v4.getMinValue()));
|
||||||
|
assertEquals(-1, v4.getMaxIndex());
|
||||||
|
assertTrue(Double.isNaN(v4.getMaxValue()));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/** verifies that two vectors are close (sup norm) */
|
/** verifies that two vectors are close (sup norm) */
|
||||||
protected void assertClose(String msg, double[] m, double[] n,
|
protected void assertClose(String msg, double[] m, double[] n,
|
||||||
double tolerance) {
|
double tolerance) {
|
||||||
|
|
Loading…
Reference in New Issue