fixed too long first step in fixed Runge-Kutta integrators.

This change is similar to the one done two years ago for adaptive step sizes integrator.

JIRA: MATH-727
This commit is contained in:
Luc Maisonobe 2014-10-08 14:25:05 +02:00
parent 86b92b4e56
commit 69273dca61
2 changed files with 37 additions and 1 deletions

View File

@ -119,7 +119,19 @@ public abstract class RungeKuttaIntegrator extends AbstractIntegrator {
// set up integration control objects // set up integration control objects
stepStart = equations.getTime(); stepStart = equations.getTime();
stepSize = forward ? step : -step; if (forward) {
if (stepStart + step >= t) {
stepSize = t - stepStart;
} else {
stepSize = step;
}
} else {
if (stepStart - step <= t) {
stepSize = t - stepStart;
} else {
stepSize = -step;
}
}
initIntegration(equations.getTime(), y0, t); initIntegration(equations.getTime(), y0, t);
// main integration loop // main integration loop

View File

@ -310,4 +310,28 @@ public class ClassicalRungeKuttaIntegratorTest {
}, 0.0, new double[] { 0.0 }, 5.0, new double[1]); }, 0.0, new double[] { 0.0 }, 5.0, new double[1]);
} }
@Test
public void testTooLargeFirstStep() {
RungeKuttaIntegrator integ = new ClassicalRungeKuttaIntegrator(0.5);
final double start = 0.0;
final double end = 0.001;
FirstOrderDifferentialEquations equations = new FirstOrderDifferentialEquations() {
public int getDimension() {
return 1;
}
public void computeDerivatives(double t, double[] y, double[] yDot) {
Assert.assertTrue(t >= FastMath.nextAfter(start, Double.NEGATIVE_INFINITY));
Assert.assertTrue(t <= FastMath.nextAfter(end, Double.POSITIVE_INFINITY));
yDot[0] = -100.0 * y[0];
}
};
integ.integrate(equations, start, new double[] { 1.0 }, end, new double[1]);
}
} }