commons-math/RELEASE-NOTES.txt

121 lines
8.1 KiB
Plaintext

commons-math-2.1 RELEASE NOTES
This is a maintenance release including numerous bug fixes and enhancements.
Changes in this version include:
New features:
o Added a way to compute both the final state in an Initial Value Problem (IVP)
for Ordinary Differential Equations (ODE) and its derivatives with respect to
initial state and with respect to some problem parameters. This allows wrapping
ODE solvers into optimization or root finding algorithms, which in turn can be
used to solve Boundary Value Problems (BVP). There are no implementations (yet)
of BVP solvers in the library.
o MATH-323: Added SemiVariance statistic. Thanks to Larry Diamond.
o MATH-341: Added a warning in the getCoefficients method documentation for
PolynomialFunctionLagrangeForm. Computation may be ill-conditioned
so this method should be used with care.
o MATH-340: Fixed an error in BigFraction multiplication for large numerators that don't
fit in a primitive int.
o MATH-334: Added min/max getters for real vectors (not yet in the RealVector interface for
compatibility purposes, but in the AbstractRealVector abstract class).
o MATH-321: Singular Value Decomposition now computes either the compact SVD (using only
positive singular values) or truncated SVD (using a user-specified maximal
number of singular values).
o MATH-300: Added support for multidimensional interpolation using the robust microsphere algorithm. Thanks to Gilles Sadowski.
o MATH-287: Added support for weighted descriptive statistics. Thanks to Matthew Rowles.
o Added normalizeArray method to MathUtils.
Fixed Bugs:
o MATH-335: Fraction.hashCode() implementation was not fully consistent with Fraction.equals().
Changed hashCode() to use fields directly to agree with equals().
o MATH-282: Resolved multiple problems leading to inaccuracy and/or failure to compute Normal,
ChiSquare and Poisson probabilities, Erf and Gamma functions. Made Brent solver
absolute accuracy configurable for all continuous distributions.
o MATH-347: Fixed too stringent interval check in Brent solver: initial guess is now
allowed to be at either interval end
o Fixed a problem with getInterpolatedDerivatives returning zero derivatives when
an ODE step handler is configured to not use interpolation. It now returns a
constant but non-zero value consistent with at least one point inside the step
o MATH-344: Fixed wrong return values when enpoints are roots in Brent solver with
a user provided initial guess
o MATH-343: Fixed a missing bracketing check of initial interval in Brent solver.
o MATH-342: In SVD, the matrices passed to EigenDecomposition are now symmetric
by construction (rather than simply by definition). In EigenDecomposition,
once the tridiagonal form is obtained, the non-significant elements are
set to 0.
o MATH-333: A EigenDecompositionImpl simplified makes it possible to compute
the SVD of a singular matrix (with the right number of elements in
the diagonal matrix) or a matrix with singular value(s) of multiplicity
greater than 1.
o Fixed a spurious exception in EigenDecompositionImpl when a 3x3 block
had two identical eigenvalues.
o MATH-338: Fixed automatic step initialization in embedded Runge-Kutta integrators.
The relative tolerance setting was never used, only the absolute tolerance
was used. Thanks to Vincent Morand.
o MATH-329: Fixed regression in Frequency.getPct(Object) introduced in 2.0. Cumulative
percent was being returned for Object arguments in place of percent.
o MATH-320: Fixed Singular Value Decomposition solving of singular systems.
o MATH-326: Fixed a wrong implementation of the Linf norm in vectors. Thanks to Jake Mannix.
o MATH-324: Fixed a convergence discrepancy with respect to theory in Gragg-Bulirsch-Stoer
integrator. Thanks to Vincent Morand.
o Fixed a wrong dimension check in SVD solver. Thanks to Dimitri Pourbaix.
o MATH-313: Added composition features for real functions. Thanks to Jake Mannix.
o MATH-312: Added mapping and iteration methods to vectors. Provided a default implementation
for the numerous simple methods in the RealVectorInterface. Thanks to Jake Mannix.
o MATH-322: Fixed an error in handling very close events in ODE integration.
o MATH-305: Fixed an overflow error in MathUtils.distance that was causing KMeansPlusPlusClusterer
to fail with a NullPointerException when component distances between points
exceeded Integer.MAXVALUE. Thanks to Erik van Ingen.
o MATH-318: Fixed an index computation error in eigen decomposition. Once again, kudos to Dimitri
for debugging this. Thanks to Dimitri Pourbaix.
o MATH-308: Fixed an ArrayIndexOutOfBoundsException in eigen decomposition. Kudos to Dimitri
for debugging this, it was really difficult. Thanks to Dimitri Pourbaix.
o MATH-309: Fixed parameter test in RandomDataImpl#nextExponential. The method now throws
IllegalArgumentException for mean = 0. Thanks to Mikkel Meyer Andersen.
o MATH-306: Removed dead code from Complex#divide. Thanks to Joerg Huber.
o MATH-294: Fixed implementation of RandomDataImpl#nextPoisson by implementing an alternative
algorithm for large means.
o MATH-298: Fixed implementation of EmpiricalDistributionImpl#getUpperBounds to match
interface contract. Added getGeneratorUpperBounds method to
EmpiricalDistributionImpl providing previous behavior.
o MATH-296: Fixed wrong results on Loess interpolation, also added a way to set weights
for smoothing and to ignore zero weights for coefficients computation Thanks to Eugene Kirpichov.
o MATH-293: Fixed a OutOfBoundException in simplex solver when some constraints are tight. Thanks to Benjamin McCann.
o MATH-291: Fixed misleading number formats in error messages for adaptive
stepsize integrators. Thanks to Sebb.
o MATH-290: Fixed a NullPointerException in simplex solver when no solution is possible
and some constraints are negative. Thanks to Benjamin McCann.
o MATH-289: Removed an unused argument in a private method in simplex solver.
o MATH-288: Fixed an error induced by entries set to 0 in simplex solver. Thanks to Benjamin McCann.
o MATH-286: Fixed an error leading the simplex solver to compute the right solution
but return another one. Thanks to Benjamin McCann.
o MATH-283: Prevent infinite loops in multi-directional direct optimization method when
the start point is exactly at the optimal point. Thanks to Michael Nischt.
o MATH-297: Prevent possible zero divides on eigenvectors of indefinite matrices Thanks to Axel Kramer.
Changes:
o MATH-332: Added density functions to remaining continuous distributions (F, T, Weibull, Cauchy).
As of Math 2.1, all continuous distributions implement density functions. The HasDensity
interface has been deprecated and in version 3.0, density(double) will be added to the
ContinuousDistribution interface. Thanks to Mikkel Meyer Andersen.
o MATH-337: Changed equals() methods to use instanceof check rather than catching ClassCastException;
this also allows some null checks to be omitted.
o MATH-336: Removed unnecessary null checks in equals methods.
o MATH-239: Added MathUtils methods to compute gcd and lcm for long arguments. Thanks to Christian Semrau.
o MATH-287: Added support for weighted univariate statistics. Thanks to Matthew Rowles.
o MATH-315: Added generationsEvolved property to GeneticAlgorithm to track the number of generations
evolved by the evolve() method before reaching the StoppingCondition. Thanks to Mikkel Meyer Andersen.
o MATH-311: Changed probability calculations for Binomial, Poisson, and Hypergeometric
distributions to use Catherine Loader's saddle point approximations. Thanks to Nipun Jawalkar.
For complete information on commons-math, including instructions on how to submit bug reports,
patches, or suggestions for improvement, see the commons-math website:
http://commons.apache.org/math/