Class FieldLogarithmicBarrierCartesianFuel<T extends CalculusFieldElement<T>>
- java.lang.Object
-
- org.orekit.control.indirect.adjoint.cost.FieldAbstractCartesianCost<T>
-
- org.orekit.control.indirect.adjoint.cost.FieldPenalizedCartesianFuelCost<T>
-
- org.orekit.control.indirect.adjoint.cost.FieldLogarithmicBarrierCartesianFuel<T>
-
- All Implemented Interfaces:
FieldCartesianCost<T>
public class FieldLogarithmicBarrierCartesianFuel<T extends CalculusFieldElement<T>> extends FieldPenalizedCartesianFuelCost<T>
Fuel cost penalized with a logarithmic term, which is a barrier so is not defined for epsilon equal to 0 or 1.- Since:
- 13.0
- Author:
- Romain Serra
-
-
Constructor Summary
Constructors Constructor Description FieldLogarithmicBarrierCartesianFuel(String name, T massFlowRateFactor, T maximumThrustMagnitude, T epsilon)
Constructor.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description T
evaluateFieldPenaltyFunction(T controlNorm)
Evaluate the penalty term (without the weight), assumed to be a function of the control norm.FieldVector3D<T>
getFieldThrustAccelerationVector(T[] adjointVariables, T mass)
Computes the thrust acceleration vector in propagation frame from the adjoint variables and the mass.LogarithmicBarrierCartesianFuel
toCartesianCost()
Method returning equivalent in non-Field.void
updateFieldAdjointDerivatives(T[] adjointVariables, T mass, T[] adjointDerivatives)
Update the adjoint derivatives if necessary.-
Methods inherited from class org.orekit.control.indirect.adjoint.cost.FieldPenalizedCartesianFuelCost
getEpsilon, getFieldHamiltonianContribution, getFieldThrustDirection, getMaximumThrustMagnitude
-
Methods inherited from class org.orekit.control.indirect.adjoint.cost.FieldAbstractCartesianCost
getAdjointName, getFieldAdjointVelocityNorm, getMassFlowRateFactor
-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.orekit.control.indirect.adjoint.cost.FieldCartesianCost
getAdjointDimension, getFieldEventDetectors
-
-
-
-
Constructor Detail
-
FieldLogarithmicBarrierCartesianFuel
public FieldLogarithmicBarrierCartesianFuel(String name, T massFlowRateFactor, T maximumThrustMagnitude, T epsilon)
Constructor.- Parameters:
name
- adjoint namemassFlowRateFactor
- mass flow rate factormaximumThrustMagnitude
- maximum thrust magnitudeepsilon
- penalty weight
-
-
Method Detail
-
evaluateFieldPenaltyFunction
public T evaluateFieldPenaltyFunction(T controlNorm)
Evaluate the penalty term (without the weight), assumed to be a function of the control norm.- Specified by:
evaluateFieldPenaltyFunction
in classFieldPenalizedCartesianFuelCost<T extends CalculusFieldElement<T>>
- Parameters:
controlNorm
- Euclidean norm of control vector- Returns:
- penalty function
-
getFieldThrustAccelerationVector
public FieldVector3D<T> getFieldThrustAccelerationVector(T[] adjointVariables, T mass)
Computes the thrust acceleration vector in propagation frame from the adjoint variables and the mass.- Parameters:
adjointVariables
- adjoint vectormass
- mass- Returns:
- thrust vector
-
updateFieldAdjointDerivatives
public void updateFieldAdjointDerivatives(T[] adjointVariables, T mass, T[] adjointDerivatives)
Update the adjoint derivatives if necessary.- Parameters:
adjointVariables
- adjoint vectormass
- massadjointDerivatives
- derivatives to update
-
toCartesianCost
public LogarithmicBarrierCartesianFuel toCartesianCost()
Method returning equivalent in non-Field.- Returns:
- cost function for non-Field applications
-
-