public class FieldAttitude<T extends RealFieldElement<T>> extends Object implements FieldTimeStamped<T>, FieldTimeShiftable<FieldAttitude<T>,T>, FieldTimeInterpolable<FieldAttitude<T>,T>
This class represents the rotation between a reference frame and the satellite frame, as well as the spin of the satellite (axis and rotation rate).
The state can be slightly shifted to close dates. This shift is based on a linear extrapolation for attitude taking the spin rate into account. It is not intended as a replacement for proper attitude propagation but should be sufficient for either small time shifts or coarse accuracy.
The instance Attitude
is guaranteed to be immutable.
Orbit
,
AttitudeProvider
Constructor and Description |
---|
FieldAttitude(Field<T> field,
Attitude attitude)
Builds an instance for a regular
Attitude . |
FieldAttitude(FieldAbsoluteDate<T> date,
Frame referenceFrame,
FieldAngularCoordinates<T> orientation)
Creates a new instance.
|
FieldAttitude(FieldAbsoluteDate<T> date,
Frame referenceFrame,
FieldRotation<T> attitude,
FieldVector3D<T> spin,
FieldVector3D<T> acceleration)
Creates a new instance.
|
FieldAttitude(FieldAbsoluteDate<T> date,
Frame referenceFrame,
Rotation attitude,
Vector3D spin,
Vector3D acceleration,
Field<T> field)
Creates a new instance.
|
FieldAttitude(Frame referenceFrame,
TimeStampedFieldAngularCoordinates<T> orientation)
Creates a new instance.
|
Modifier and Type | Method and Description |
---|---|
FieldAbsoluteDate<T> |
getDate()
Get the date of attitude parameters.
|
TimeStampedFieldAngularCoordinates<T> |
getOrientation()
Get the complete orientation including spin.
|
Frame |
getReferenceFrame()
Get the reference frame.
|
FieldRotation<T> |
getRotation()
Get the attitude rotation.
|
FieldVector3D<T> |
getRotationAcceleration()
Get the satellite rotation acceleration.
|
FieldVector3D<T> |
getSpin()
Get the satellite spin.
|
FieldAttitude<T> |
interpolate(FieldAbsoluteDate<T> interpolationDate,
Stream<FieldAttitude<T>> sample)
Get an interpolated instance.
|
FieldAttitude<T> |
shiftedBy(double dt)
Get a time-shifted attitude.
|
FieldAttitude<T> |
shiftedBy(T dt)
Get a time-shifted attitude.
|
Attitude |
toAttitude()
Converts to an Attitude instance.
|
FieldAttitude<T> |
withReferenceFrame(Frame newReferenceFrame)
Get a similar attitude with a specific reference frame.
|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
interpolate
public FieldAttitude(Frame referenceFrame, TimeStampedFieldAngularCoordinates<T> orientation)
referenceFrame
- reference frame from which attitude is definedorientation
- complete orientation between reference frame and satellite frame,
including rotation ratepublic FieldAttitude(FieldAbsoluteDate<T> date, Frame referenceFrame, FieldAngularCoordinates<T> orientation)
date
- date at which attitude is definedreferenceFrame
- reference frame from which attitude is definedorientation
- complete orientation between reference frame and satellite frame,
including rotation ratepublic FieldAttitude(FieldAbsoluteDate<T> date, Frame referenceFrame, FieldRotation<T> attitude, FieldVector3D<T> spin, FieldVector3D<T> acceleration)
date
- date at which attitude is definedreferenceFrame
- reference frame from which attitude is definedattitude
- rotation between reference frame and satellite framespin
- satellite spin (axis and velocity, in satellite frame)acceleration
- satellite rotation acceleration (in satellite frame)public FieldAttitude(FieldAbsoluteDate<T> date, Frame referenceFrame, Rotation attitude, Vector3D spin, Vector3D acceleration, Field<T> field)
date
- date at which attitude is definedreferenceFrame
- reference frame from which attitude is definedattitude
- rotation between reference frame and satellite framespin
- satellite spin (axis and velocity, in satellite frame)acceleration
- satellite rotation acceleration (in satellite frame)field
- field used by defaultpublic FieldAttitude<T> shiftedBy(double dt)
The state can be slightly shifted to close dates. This shift is based on a linear extrapolation for attitude taking the spin rate into account. It is not intended as a replacement for proper attitude propagation but should be sufficient for either small time shifts or coarse accuracy.
shiftedBy
in interface FieldTimeShiftable<FieldAttitude<T extends RealFieldElement<T>>,T extends RealFieldElement<T>>
dt
- time shift in secondspublic FieldAttitude<T> shiftedBy(T dt)
The state can be slightly shifted to close dates. This shift is based on a linear extrapolation for attitude taking the spin rate into account. It is not intended as a replacement for proper attitude propagation but should be sufficient for either small time shifts or coarse accuracy.
shiftedBy
in interface FieldTimeShiftable<FieldAttitude<T extends RealFieldElement<T>>,T extends RealFieldElement<T>>
dt
- time shift in secondspublic FieldAttitude<T> withReferenceFrame(Frame newReferenceFrame)
If the instance reference frame is already the specified one, the instance itself is returned without any object creation. Otherwise, a new instance will be created with the specified reference frame. In this case, the required intermediate rotation and spin between the specified and the original reference frame will be inserted.
newReferenceFrame
- desired reference frame for attitudepublic FieldAbsoluteDate<T> getDate()
getDate
in interface FieldTimeStamped<T extends RealFieldElement<T>>
public Frame getReferenceFrame()
public TimeStampedFieldAngularCoordinates<T> getOrientation()
getRotation()
,
getSpin()
public FieldRotation<T> getRotation()
getOrientation()
,
getSpin()
public FieldVector3D<T> getSpin()
The spin vector is defined in satellite frame.
getOrientation()
,
getRotation()
public FieldVector3D<T> getRotationAcceleration()
The rotation acceleration. vector is defined in satellite frame.
getOrientation()
,
getRotation()
public FieldAttitude<T> interpolate(FieldAbsoluteDate<T> interpolationDate, Stream<FieldAttitude<T>> sample)
The interpolated instance is created by polynomial Hermite interpolation on Rodrigues vector ensuring rotation rate remains the exact derivative of rotation.
As this implementation of interpolation is polynomial, it should be used only with small samples (about 10-20 points) in order to avoid Runge's phenomenon and numerical problems (including NaN appearing).
interpolate
in interface FieldTimeInterpolable<FieldAttitude<T extends RealFieldElement<T>>,T extends RealFieldElement<T>>
interpolationDate
- interpolation datesample
- sample points on which interpolation should be donepublic Attitude toAttitude()
Copyright © 2002-2019 CS Systèmes d'information. All rights reserved.