T
- type of the field elements
public class FieldKeplerianOrbit<T extends org.hipparchus.CalculusFieldElement<T>> extends FieldOrbit<T> implements PositionAngleBased
内部使用的参数是经典的开普勒元素:
a e i ω Ω v其中,ω代表近地点幅角,Ω代表升交点赤经,v代表真近点角。
此类支持双曲线轨道,使用半长轴为负值表示这种轨道(当然离心率大于1)。
当轨道是赤道轨道或圆形轨道时,一些开普勒元素(更准确地说是ω和Ω)变得模糊,因此不应将此类用于这些轨道。因此,赤道轨道
是推荐表示轨道的方式。
实例KeplerianOrbit
保证是不可变的。
Orbit
, CircularOrbit
, CartesianOrbit
, EquinoctialOrbit
Constructor and Description |
---|
FieldKeplerianOrbit(org.hipparchus.Field<T> field, KeplerianOrbit op)
从Field和KeplerianOrbit构造函数。
|
FieldKeplerianOrbit(org.hipparchus.Field<T> field, Orbit op)
从Field和Orbit构造函数。
|
FieldKeplerianOrbit(FieldOrbit<T> op)
从任何类型的轨道参数构造函数。
|
FieldKeplerianOrbit(FieldPVCoordinates<T> FieldPVCoordinates, Frame frame, FieldAbsoluteDate<T> date, T mu)
从笛卡尔参数构造函数。
|
FieldKeplerianOrbit(TimeStampedFieldPVCoordinates<T> pvCoordinates, Frame frame, T mu)
从笛卡尔参数构造函数。
|
FieldKeplerianOrbit(T a, T e, T i, T pa, T raan, T anomaly, PositionAngleType type, Frame frame, FieldAbsoluteDate<T> date, T mu)
创建一个新实例。
|
FieldKeplerianOrbit(T a, T e, T i, T pa, T raan, T anomaly, T aDot, T eDot, T iDot, T paDot, T raanDot, T anomalyDot, PositionAngleType type, Frame frame, FieldAbsoluteDate<T> date, T mu)
创建一个新实例。
|
Modifier and Type | Method and Description |
---|---|
void |
addKeplerContribution(PositionAngleType type, T gm, T[] pDot)
将开普勒运动的贡献添加到参数导数中
|
protected T[][] |
computeJacobianEccentricWrtCartesian()
计算轨道参数相对于笛卡尔参数的偏心角的雅可比矩阵。
|
protected T[][] |
computeJacobianMeanWrtCartesian()
计算轨道参数相对于笛卡尔参数的平均角的雅可比矩阵。
|
protected T[][] |
computeJacobianTrueWrtCartesian()
计算轨道参数相对于笛卡尔参数的真角的雅可比矩阵。
|
T |
getA()
获取半长轴。
|
T |
getADot()
获取半长轴导数。
|
T |
getAnomaly(PositionAngleType type)
获取异常。
|
T |
getAnomalyDot(PositionAngleType type)
获取异常导数。
|
PositionAngleType |
getCachedPositionAngleType()
获取缓存的 PositionAngleType 。
|
T |
getE()
获取离心率。
|
T |
getEccentricAnomaly()
获取偏心率异常。
|
T |
getEccentricAnomalyDot()
获取偏心率异常导数。
|
T |
getEDot()
获取离心率导数。
|
T |
getEquinoctialEx()
获取赤道偏心率向量的第一个分量。
|
T |
getEquinoctialExDot()
获取赤道偏心率向量的第一个分量。
|
T |
getEquinoctialEy()
获取赤道偏心率向量的第二个分量。
|
T |
getEquinoctialEyDot()
获取赤道偏心率向量的第二个分量。
|
T |
getHx()
获取倾角的第一个分量。
|
T |
getHxDot()
获取倾角的第一个分量导数。
|
T |
getHy()
获取倾角的第二个分量。
|
T |
getHyDot()
获取倾角的第二个分量导数。
|
T |
getI()
获取倾角。
|
T |
getIDot()
获取倾角导数。
|
T |
getLE()
获取偏心经度参数。
|
T |
getLEDot()
获取偏心经度参数导数。
|
T |
getLM()
获取平均经度参数。
|
T |
getLMDot()
获取平均经度参数导数。
|
T |
getLv()
获取真经度参数。
|
T |
getLvDot()
获取真经度参数导数。
|
T |
getMeanAnomaly()
获取平均异常。
|
T |
getMeanAnomalyDot()
获取平均异常导数。
|
T |
getPerigeeArgument()
获取近地点幅角。
|
T |
getPerigeeArgumentDot()
获取近地点幅角导数。
|
T |
getRightAscensionOfAscendingNode()
获取升交点赤经。
|
T |
getRightAscensionOfAscendingNodeDot()
获取升交点赤经导数。
|
T |
getTrueAnomaly()
获取真近点角。
|
T |
getTrueAnomalyDot()
获取真近点角导数。
|
OrbitType |
getType()
获取轨道类型。
|
boolean |
hasDerivatives()
检查轨道是否包含导数。
|
boolean |
hasRates()
告诉实例是否保存相关变量的速率(一阶时间导数)。
|
protected org.hipparchus.geometry.euclidean.threed.FieldVector3D<T> |
initPosition()
从规范参数计算位置坐标。
|
protected TimeStampedFieldPVCoordinates<T> |
initPVCoordinates()
从规范参数计算位置/速度坐标。
|
FieldKeplerianOrbit<T> |
removeRates()
创建一个新实例,使得 PositionAngleBased.hasRates() 为false。
|
FieldKeplerianOrbit<T> |
shiftedBy(double dt)
获取时间偏移的实例。
|
FieldKeplerianOrbit<T> |
shiftedBy(T dt)
获取时间偏移的轨道。
|
KeplerianOrbit |
toOrbit()
将FieldOrbit实例转换为Orbit实例。
|
String |
toString()
返回此开普勒参数对象的字符串表示形式。
|
fillHalfRow, fillHalfRow, fillHalfRow, fillHalfRow, fillHalfRow, fillHalfRow, getDate, getField, getFrame, getJacobianWrtCartesian, getJacobianWrtParameters, getKeplerianMeanMotion, getKeplerianPeriod, getMeanAnomalyDotWrtA, getMu, getOne, getPosition, getPosition, getPVCoordinates, getPVCoordinates, getPVCoordinates, getZero, hasNonKeplerianAcceleration, isElliptical
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
getPosition
durationFrom
public FieldKeplerianOrbit(T a, T e, T i, T pa, T raan, T anomaly, PositionAngleType type, Frame frame, FieldAbsoluteDate<T> date, T mu) throws IllegalArgumentException
a
- 半长轴(m),双曲线轨道为负值
e
- 离心率(大于等于0)
i
- 倾角(弧度)
pa
- 近地点幅角(ω,弧度)
raan
- 升交点赤经(Ω,弧度)
anomaly
- 平均、离心或真异常(弧度)
type
- 异常类型
frame
- 参数定义的参考系(必须是一个伪惯性参考系
)
date
- 轨道参数的日期
mu
- 中心引力系数(m³/s²)
IllegalArgumentException
- 如果参考系不是一个伪惯性参考系
,或者双曲线轨道的a和e不匹配,或者双曲线轨道的v超出范围
public FieldKeplerianOrbit(T a, T e, T i, T pa, T raan, T anomaly, T aDot, T eDot, T iDot, T paDot, T raanDot, T anomalyDot, PositionAngleType type, Frame frame, FieldAbsoluteDate<T> date, T mu) throws IllegalArgumentException
a
- 半长轴(m),双曲线轨道为负值
e
- 离心率(大于等于0)
i
- 倾角(弧度)
pa
- 近地点幅角(ω,弧度)
raan
- 升交点赤经(Ω,弧度)
anomaly
- 平均、离心或真异常(弧度)
aDot
- 半长轴导数,如果未知则为null(m/s)
eDot
- 离心率导数,如果未知则为null
iDot
- 倾角导数,如果未知则为null(rad/s)
paDot
- 近地点幅角导数,如果未知则为null(rad/s)
raanDot
- 升交点赤经导数,如果未知则为null(rad/s)
anomalyDot
- 平均、离心或真异常导数,如果未知则为null(rad/s)
type
- 异常类型
frame
- 参数定义的参考系(必须是一个伪惯性参考系
)
date
- 轨道参数的日期
mu
- 中心引力系数(m³/s²)
IllegalArgumentException
- 如果参考系不是一个伪惯性参考系
,或者双曲线轨道的a和e不匹配,或者双曲线轨道的v超出范围
public FieldKeplerianOrbit(TimeStampedFieldPVCoordinates<T> pvCoordinates, Frame frame, T mu) throws IllegalArgumentException
在FieldPVCoordinates
中提供的加速度可通过FieldOrbit.getPVCoordinates()
和FieldOrbit.getPVCoordinates(Frame)
访问。所有其他方法使用mu
和位置来计算加速度,包括shiftedBy(CalculusFieldElement)
和FieldOrbit.getPVCoordinates(FieldAbsoluteDate, Frame)
。
pvCoordinates
- 卫星的PVCoordinates
frame
- 定义FieldPVCoordinates
的参考系(必须是一个伪惯性参考系
)
mu
- 中心引力系数(m³/s²)
IllegalArgumentException
- 如果参考系不是一个伪惯性参考系
public FieldKeplerianOrbit(FieldPVCoordinates<T> FieldPVCoordinates, Frame frame, FieldAbsoluteDate<T> date, T mu) throws IllegalArgumentException
在FieldPVCoordinates
中提供的加速度可通过FieldOrbit.getPVCoordinates()
和FieldOrbit.getPVCoordinates(Frame)
访问。所有其他方法使用mu
和位置来计算加速度,包括shiftedBy(CalculusFieldElement)
和FieldOrbit.getPVCoordinates(FieldAbsoluteDate, Frame)
。
FieldPVCoordinates
- 卫星的PVCoordinates
frame
- 定义FieldPVCoordinates
的参考系(必须是一个伪惯性参考系
)
date
- 轨道参数的日期
mu
- 中心引力系数(m³/s²)
IllegalArgumentException
- 如果参考系不是一个伪惯性参考系
public FieldKeplerianOrbit(FieldOrbit<T> op)
op
- 要复制的轨道参数
public FieldKeplerianOrbit(org.hipparchus.Field<T> field, KeplerianOrbit op)
从非Field KeplerianOrbit构建FieldKeplerianOrbit。
field
- 基于的CalculusField对象
op
- 只有“常数”项的非Field轨道
public OrbitType getType()
getType
在类 FieldOrbit<T extends org.hipparchus.CalculusFieldElement<T>>
public T getA()
请注意,对于双曲线轨道,半长轴被认为是负的。
getA
在类 FieldOrbit<T extends org.hipparchus.CalculusFieldElement<T>>
public T getADot()
请注意,对于双曲线轨道,半长轴被认为是负的。
如果轨道是没有导数创建的,则返回的值为null。
getADot
在类 FieldOrbit<T extends org.hipparchus.CalculusFieldElement<T>>
public T getE()
getE
在类 FieldOrbit<T extends org.hipparchus.CalculusFieldElement<T>>
public T getEDot()
如果轨道是没有导数创建的,则返回的值为null。
getEDot
在类 FieldOrbit<T extends org.hipparchus.CalculusFieldElement<T>>
public T getI()
如果轨道是没有导数创建的,则返回的值为null。
getI
在类 FieldOrbit<T extends org.hipparchus.CalculusFieldElement<T>>
public T getIDot()
getIDot
在类 FieldOrbit<T extends org.hipparchus.CalculusFieldElement<T>>
public T getPerigeeArgument()
public T getPerigeeArgumentDot()
如果轨道是没有导数创建的,则返回的值为null。
public T getRightAscensionOfAscendingNode()
public T getRightAscensionOfAscendingNodeDot()
如果轨道是没有导数创建的,则返回的值为null。
public T getTrueAnomaly()
public T getTrueAnomalyDot()
如果轨道是没有导数创建的,则返回的值为null。
public T getEccentricAnomaly()
public T getEccentricAnomalyDot()
如果轨道是没有导数创建的,则返回的值为null。
public T getMeanAnomaly()
public T getMeanAnomalyDot()
如果轨道是没有导数创建的,则返回的值为null。
public T getAnomaly(PositionAngleType type)
type
- 角度类型
public T getAnomalyDot(PositionAngleType type)
如果轨道是没有导数创建的,则返回的值为null。
type
- 角度类型
public boolean hasDerivatives()
hasDerivatives
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
FieldOrbit.getADot()
, FieldOrbit.getEquinoctialExDot()
, FieldOrbit.getEquinoctialEyDot()
, FieldOrbit.getHxDot()
, FieldOrbit.getHyDot()
, FieldOrbit.getLEDot()
, FieldOrbit.getLvDot()
, FieldOrbit.getLMDot()
, FieldOrbit.getEDot()
, FieldOrbit.getIDot()
public T getEquinoctialEx()
getEquinoctialEx
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getEquinoctialExDot()
如果轨道是在没有导数的情况下创建的,则返回的值为null。
getEquinoctialExDot
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getEquinoctialEy()
getEquinoctialEy
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getEquinoctialEyDot()
如果轨道是在没有导数的情况下创建的,则返回的值为null。
getEquinoctialEyDot
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getHx()
getHx
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getHxDot()
如果轨道是在没有导数的情况下创建的,则返回的值为null。
getHxDot
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getHy()
getHy
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getHyDot()
getHyDot
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getLv()
getLv
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getLvDot()
如果轨道是在没有导数的情况下创建的,则返回的值为null。
getLvDot
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getLE()
getLE
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getLEDot()
如果轨道是在没有导数的情况下创建的,则返回的值为null。
getLEDot
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getLM()
getLM
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public T getLMDot()
如果轨道是没有导数创建的,则返回的值为null。
getLMDot
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
protected org.hipparchus.geometry.euclidean.threed.FieldVector3D<T> initPosition()
initPosition
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
protected TimeStampedFieldPVCoordinates<T> initPVCoordinates()
initPVCoordinates
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
public FieldKeplerianOrbit<T> shiftedBy(double dt)
shiftedBy
在接口 TimeShiftable<FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>>
dt
- 时间偏移(秒)
public FieldKeplerianOrbit<T> shiftedBy(T dt)
轨道可以稍微偏移以接近日期。此偏移基于简单的开普勒模型。它不旨在替代正确的轨道和姿态传播,但对于小时间偏移或粗略精度应该足够。
shiftedBy
在接口 FieldTimeShiftable<FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>,T 扩展 org.hipparchus.CalculusFieldElement<T>>
shiftedBy
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
dt
- 时间偏移(秒)
protected T[][] computeJacobianMeanWrtCartesian()
元素jacobian[i][j]
是轨道参数i相对于笛卡尔坐标j的导数。这意味着每行对应一个轨道参数,而列0到5对应笛卡尔坐标x、y、z、xDot、yDot和zDot。
computeJacobianMeanWrtCartesian
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
FieldOrbit.computeJacobianEccentricWrtCartesian()
, FieldOrbit.computeJacobianTrueWrtCartesian()
protected T[][] computeJacobianEccentricWrtCartesian()
元素jacobian[i][j]
是轨道参数i相对于笛卡尔坐标j的导数。这意味着每行对应一个轨道参数,而列0到5对应笛卡尔坐标x、y、z、xDot、yDot和zDot。
computeJacobianEccentricWrtCartesian
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
FieldOrbit.computeJacobianMeanWrtCartesian()
, FieldOrbit.computeJacobianTrueWrtCartesian()
protected T[][] computeJacobianTrueWrtCartesian()
元素jacobian[i][j]
是轨道参数i相对于笛卡尔坐标j的导数。这意味着每行对应一个轨道参数,而列0到5对应笛卡尔坐标x、y、z、xDot、yDot和zDot。
computeJacobianTrueWrtCartesian
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
FieldOrbit.computeJacobianMeanWrtCartesian()
, FieldOrbit.computeJacobianEccentricWrtCartesian()
public void addKeplerContribution(PositionAngleType type, T gm, T[] pDot)
此方法由基于积分的传播器用于评估开普勒运动对轨道状态演变的部分。
addKeplerContribution
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
type
- 状态中位置角的类型
gm
- 要使用的引力系数
pDot
- 包含要更新的轨道状态导数的数组(开普勒部分必须添加到数组分量中,因为数组可能已经包含一些非零元素,对应于非开普勒部分)
public PositionAngleType getCachedPositionAngleType()
PositionAngleType
。
getCachedPositionAngleType
在接口 PositionAngleBased
public boolean hasRates()
hasRates
在接口 PositionAngleBased
public FieldKeplerianOrbit<T> removeRates()
PositionAngleBased.hasRates()
为false。
removeRates
在接口 PositionAngleBased
public KeplerianOrbit toOrbit()
toOrbit
在类 FieldOrbit<T 扩展 org.hipparchus.CalculusFieldElement<T>>
Copyright © 2002-2023 CS GROUP. All rights reserved.