public class NordsieckStepInterpolator extends AbstractStepInterpolator
This interpolator computes dense output around the current point. The interpolation equation is based on Taylor series formulas.
AdamsBashforthIntegrator
,
AdamsMoultonIntegrator
,
Serialized FormConstructor and Description |
---|
NordsieckStepInterpolator()
Simple constructor.
|
NordsieckStepInterpolator(NordsieckStepInterpolator interpolator)
Copy constructor.
|
Modifier and Type | Method and Description |
---|---|
double[] |
getInterpolatedStateVariation()
Get the state vector variation from current to interpolated state.
|
void |
readExternal(java.io.ObjectInput in) |
void |
reinitialize(double[] y,
boolean forward)
Reinitialize the instance.
|
void |
reinitialize(double time,
double stepSize,
double[] scaledDerivative,
Array2DRowRealMatrix nordsieckVector)
Reinitialize the instance.
|
void |
rescale(double stepSize)
Rescale the instance.
|
void |
writeExternal(java.io.ObjectOutput out) |
copy, finalizeStep, getCurrentTime, getGlobalCurrentTime, getGlobalPreviousTime, getInterpolatedDerivatives, getInterpolatedState, getInterpolatedTime, getPreviousTime, isForward, setInterpolatedTime, setSoftCurrentTime, setSoftPreviousTime, shift, storeTime
public NordsieckStepInterpolator()
AbstractStepInterpolator.reinitialize(double[], boolean)
method should be called
before using the instance in order to initialize the internal arrays. This
constructor is used only in order to delay the initialization in
some cases.public NordsieckStepInterpolator(NordsieckStepInterpolator interpolator)
interpolator
- interpolator to copy from. The copy is a deep
copy: its arrays are separated from the original arrays of the
instancepublic void reinitialize(double[] y, boolean forward)
Beware that all arrays must be references to integrator arrays, in order to ensure proper update without copy.
y
- reference to the integrator array holding the state at
the end of the stepforward
- integration direction indicatorpublic void reinitialize(double time, double stepSize, double[] scaledDerivative, Array2DRowRealMatrix nordsieckVector)
Beware that all arrays must be references to integrator arrays, in order to ensure proper update without copy.
time
- time at which all arrays are definedstepSize
- step size used in the scaled and nordsieck arraysscaledDerivative
- reference to the integrator array holding the first
scaled derivativenordsieckVector
- reference to the integrator matrix holding the
nordsieck vectorpublic void rescale(double stepSize)
Since the scaled and Nordiseck arrays are shared with the caller, this method has the side effect of rescaling this arrays in the caller too.
stepSize
- new step size to use in the scaled and nordsieck arrayspublic double[] getInterpolatedStateVariation() throws DerivativeException
This method is aimed at computing y(tinterpolation) -y(tcurrent) accurately by avoiding the cancellation errors that would occur if the subtraction were performed explicitly.
The returned vector is a reference to a reused array, so it should not be modified and it should be copied if it needs to be preserved across several calls.
AbstractStepInterpolator.getInterpolatedTime()
DerivativeException
- if this call induces an automatic
step finalization that throws oneAbstractStepInterpolator.getInterpolatedDerivatives()
public void writeExternal(java.io.ObjectOutput out) throws java.io.IOException
writeExternal
in interface java.io.Externalizable
writeExternal
in class AbstractStepInterpolator
java.io.IOException
public void readExternal(java.io.ObjectInput in) throws java.io.IOException, java.lang.ClassNotFoundException
readExternal
in interface java.io.Externalizable
readExternal
in class AbstractStepInterpolator
java.io.IOException
java.lang.ClassNotFoundException
"Copyright © 2010 - 2020 Adobe Systems Incorporated. All Rights Reserved"