Class FieldQuadraticPenaltyCartesianFuel<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.FieldQuadraticPenaltyCartesianFuel<T>
- Type Parameters:
T- type of the field elements
- All Implemented Interfaces:
FieldCartesianCost<T>
public class FieldQuadraticPenaltyCartesianFuel<T extends CalculusFieldElement<T>>
extends FieldPenalizedCartesianFuelCost<T>
Fuel cost penalized with a quadratic term. For epsilon equal to 1, one gets the bounded energy cost.
- Since:
- 13.0
- Author:
- Romain Serra
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class org.orekit.control.indirect.adjoint.cost.FieldAbstractCartesianCost
FieldAbstractCartesianCost.FieldSwitchFunction -
Constructor Summary
ConstructorsConstructorDescriptionFieldQuadraticPenaltyCartesianFuel(String name, T massFlowRateFactor, T maximumThrustMagnitude, T epsilon) Constructor with default event detection settings.FieldQuadraticPenaltyCartesianFuel(String name, T massFlowRateFactor, T maximumThrustMagnitude, T epsilon, FieldEventDetectionSettings<T> eventDetectionSettings) Constructor. -
Method Summary
Modifier and TypeMethodDescriptionevaluateFieldPenaltyFunction(T controlNorm) Evaluate the penalty term (without the weight), assumed to be a function of the control norm.Getter for the event detection settings.getFieldEventDetectors(Field<T> field) Get the detectors needed for propagation.getFieldThrustAccelerationVector(T[] adjointVariables, T mass) Computes the thrust acceleration vector in propagation frame from the adjoint variables and the mass.Method returning equivalent in non-Field.voidupdateFieldAdjointDerivatives(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, getMaximumThrustMagnitudeMethods inherited from class org.orekit.control.indirect.adjoint.cost.FieldAbstractCartesianCost
buildSwitchDetector, getAdjointDimension, getAdjointName, getFieldAdjointVelocityNorm, getMassFlowRateFactorMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.orekit.control.indirect.adjoint.cost.FieldCartesianCost
getCostDerivativeProvider
-
Constructor Details
-
FieldQuadraticPenaltyCartesianFuel
public FieldQuadraticPenaltyCartesianFuel(String name, T massFlowRateFactor, T maximumThrustMagnitude, T epsilon, FieldEventDetectionSettings<T> eventDetectionSettings) Constructor.- Parameters:
name- adjoint namemassFlowRateFactor- mass flow rate factormaximumThrustMagnitude- maximum thrust magnitudeepsilon- penalty weighteventDetectionSettings- detection settings
-
FieldQuadraticPenaltyCartesianFuel
public FieldQuadraticPenaltyCartesianFuel(String name, T massFlowRateFactor, T maximumThrustMagnitude, T epsilon) Constructor with default event detection settings.- Parameters:
name- adjoint namemassFlowRateFactor- mass flow rate factormaximumThrustMagnitude- maximum thrust magnitudeepsilon- penalty weight
-
-
Method Details
-
getEventDetectionSettings
Getter for the event detection settings.- Returns:
- detection settings
-
evaluateFieldPenaltyFunction
Evaluate the penalty term (without the weight), assumed to be a function of the control norm.- Specified by:
evaluateFieldPenaltyFunctionin classFieldPenalizedCartesianFuelCost<T extends CalculusFieldElement<T>>- Parameters:
controlNorm- Euclidean norm of control vector- Returns:
- penalty function
-
getFieldThrustAccelerationVector
Computes the thrust acceleration vector in propagation frame from the adjoint variables and the mass.- Parameters:
adjointVariables- adjoint vectormass- mass- Returns:
- thrust vector
-
updateFieldAdjointDerivatives
Update the adjoint derivatives if necessary.- Parameters:
adjointVariables- adjoint vectormass- massadjointDerivatives- derivatives to update
-
getFieldEventDetectors
Get the detectors needed for propagation.- Parameters:
field- field- Returns:
- event detectors
-
toCartesianCost
Method returning equivalent in non-Field.- Returns:
- cost function for non-Field applications
-