SwitchableSegment Class | 
Namespace: AGI.Foundation.SegmentPropagation
The SwitchableSegment type exposes the following members.
| Name | Description | |
|---|---|---|
| SwitchableSegment | 
            Initializes a new instance. PrimarySegment and AlternateSegment 
            must both be set before calling 
            GetSegmentPropagator(EvaluatorGroup, SegmentDefinition).
              | |
| SwitchableSegment(SegmentDefinition, SegmentDefinition) | 
            Initializes a new instance.
              | |
| SwitchableSegment(SwitchableSegment, CopyContext) | Initializes a new instance as a copy of an existing instance.  | 
| Name | Description | |
|---|---|---|
| AlternateSegment | 
            Gets or sets the alternate segment. By default, this is the segment that will 
            be propagated and then swapped out. The results will be in the defined-in's (ReferenceFrame, Axes) 
            of the PrimarySegment.
              | |
| Elements | 
            Gets the names of all of the elements that this segment is propagating. 
              (Overrides SegmentDefinitionElements.) | |
| IsFrozen | 
            Gets a value indicating whether this object is frozen.  A frozen object cannot be modified and an
            ObjectFrozenException will be thrown if an attempt is made to do so.
              (Inherited from DefinitionalObject.) | |
| Name | 
            Gets or sets a name to describe the segment. This is optional.
              (Inherited from SegmentDefinition.) | |
| NextStateBehavior | 
            Gets or sets the behavior for passing states to the next segment. See StateForNextSegmentBehavior for more information.
              (Inherited from SegmentDefinition.) | |
| PassAllElementsToNextSegment | 
            Gets a value indicating whether the segment is such that it will not define any Elements or 
            StateElementAdapters. Such a segment typically
            affects the control flow of multiple segments instead of propagating state elements. By default this is 
            , but if the specific derived segment can use the previous segment's adapters, 
            override this property to always return . Even if this is  
            some segments may require adapters to be set with the 
            SetElementAndAdapter(StateElementAdapterDefinition) method.
              (Overrides SegmentDefinitionPassAllElementsToNextSegment.) | |
| PrimarySegment | 
            Gets or sets the primary segment. For all cases where there is ambiguity 
            between what settings the SwitchableSegment will use, 
            this segment may be assumed to contain those settings.  
            For example, the final states generated by the overall SwitchableSegment 
            will be in the defined-in objects (ReferenceFrame, Axes...) of this segment.
              | |
| PropagationDirection | 
            Gets or sets the direction that this segment will be initially propagated. If this segment propagates 
            multiple segments, the child segments will be propagated in the direction that they are configured with. 
            If the overall list is going forward, segments that go back in time will override the immediate previous 
            segments ephemeris, but if another segment going forward follows the backwards segment, that backwards 
            segment will be ignored when the overall trajectory is resolved into a single ephemeris set. If you are using a 
            StoppingCondition that depends on time, the time span of 
            those stopping conditions must match this property (for example, a 
            DurationStoppingCondition must have a negative 
            threshold if this is set to Decreasing,
            otherwise, the condition will never be tripped).
              (Inherited from SegmentDefinition.) | |
| SegmentToRun | 
            Gets the definition of the evaluator that will tell the SegmentPropagator 
            which segment to run.
              | |
| SegmentToRunInitially | 
            Gets or sets which segment should be propagated initially. Defaults to 
            Alternate.
              | |
| SegmentToRunParameter | 
            Gets the ValueParameterT that can be used 
            to change which SegmentDefinition gets propagated.
              | 
| Name | Description | |
|---|---|---|
| CheckForSameDefinition(DefinitionalObject) | 
        Checks to determine if another instance has the same definition as this instance and
        returns  if it does.  Derived classes MUST override this method and check
        all new fields introduced by the derived class for definitional equivalence.  It is NOT necessary
        to check base class fields because the base class will already have done that.  When overriding this method,
        you should NOT call the base implementation because it will return  for all derived-class instances.
        Derived classes should check the type of other to preserve the symmetric nature of IsSameDefinition(Object).
        (Inherited from SegmentDefinition.) | |
| CheckForSameDefinition(SegmentDefinition) | 
        Checks to determine if another instance has the same definition as this instance and
        returns  if it does.  Derived classes MUST override this method and check
        all new fields introduced by the derived class for definitional equivalence.  It is NOT necessary
        to check base class fields because the base class will already have done that.  When overriding this method,
        you should NOT call the base implementation because it will return  for all derived-class instances.
        Derived classes should check the type of other to preserve the symmetric nature of IsSameDefinition(Object).
        (Overrides SegmentDefinitionCheckForSameDefinition(SegmentDefinition).) | |
| CheckForSameDefinition(SwitchableSegment) | 
        Checks to determine if another instance has the same definition as this instance and
        returns  if it does.  Derived classes MUST override this method and check
        all new fields introduced by the derived class for definitional equivalence.  It is NOT necessary
        to check base class fields because the base class will already have done that.  When overriding this method,
        you should NOT call the base implementation because it will return  for all derived-class instances.
        Derived classes should check the type of other to preserve the symmetric nature of IsSameDefinition(Object).
        | |
| Clone | 
            Clones this object using the specified context.
              (Overrides DefinitionalObjectClone(CopyContext).) | |
| ComputeCurrentDefinitionHashCode | 
        Computes a hash code based on the current properties of this object. Derived classes MUST override this
        method and compute a hash code that combines: a unique hash code seed, the base implementation result, and
        the hash codes of all new fields introduced by the derived class which are used in the
        CheckForSameDefinition(DefinitionalObject) method.
        (Overrides SegmentDefinitionComputeCurrentDefinitionHashCode.) | |
| ContainsElement | 
            Checks to see if there is a StateElementAdapterDefinition for the provided 
            element.
              (Inherited from SegmentDefinition.) | |
| CreateSegmentPropagator | 
            Creates, configures, and returns the SegmentPropagator for this 
            segment. This method should check that all of the required properties on the 
            concrete instance are configured properly before constructing the 
            SegmentPropagator to be returned. 
              (Overrides SegmentDefinitionCreateSegmentPropagator(EvaluatorGroup, SegmentDefinition).) | |
| EnumerateDependencies | 
        Enumerates the dependencies of this object by calling
        EnumerateT(T) for each object that this object directly depends upon.
        Derived classes which contain additional dependencies MUST override this method, call the base
        implementation, and enumerate dependencies introduced by the derived class.
        (Overrides DefinitionalObjectEnumerateDependencies(DependencyEnumerator).) | |
| Equals | Determines whether the specified object is equal to the current object.  (Inherited from Object.) | |
| Finalize | Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection.  (Inherited from Object.) | |
| Freeze | 
            Freezes this object.  Further attempts to modify it will result
            in an ObjectFrozenException.
              (Inherited from DefinitionalObject.) | |
| FreezeAggregatedObjects | 
        Called by Freeze to also freeze any objects that are considered to be a part of this object.
        Derived classes which contain additional aggregated objects MUST override this method, call the base
        implementation, and freeze aggregated objects introduced by the derived class. The objects that need to be
        frozen in this method are frequently created in this object's constructor and are not settable via
        properties.
        (Inherited from DefinitionalObject.) | |
| GetDefinedIn | 
            Gets the object (for example, a ReferenceFrame, an Axes, etc.) 
            in which the specified element is defined in. This can return  if there 
            is no such object. When overriding this method, you generally should not call the base method, 
            instead the derived segment should keep track of the elements and defined in objects itself.
              (Overrides SegmentDefinitionGetDefinedIn(String).) | |
| GetDefinitionHashCode | 
            Gets a hash code representing the definition of this object.
              (Inherited from DefinitionalObject.) | |
| GetElementAdapter | 
            Returns the adapter for the given state element. The 
            StateElementAdapters handle the various 
            transformations of the propagated elements between segments (for example, if 
            the integration frame of a point being propagated changes 
            from one segment to another, the 
            adapter is what handles that transformation between 
            segment). All elements propagated by this segment must have
            an adapter returned by this method (even if that adapter 
            simply returns the original state). 
            If multiple segments are being propagated by this segment (as a SegmentList would), this 
            must return the adapter of the StateElementAdapter of the element for the final 
            known segment getting propagated.
              (Overrides SegmentDefinitionGetElementAdapter(String).) | |
| GetHashCode | Serves as the default hash function.   (Inherited from Object.) | |
| GetSegmentPropagator | 
            Creates, configures, and returns the SegmentPropagator for this 
            segment. This method assumes that no previous segment is needed to configure 
            this segment's propagator.
              (Inherited from SegmentDefinition.) | |
| GetSegmentPropagator(EvaluatorGroup) | 
            Creates, configures, and returns the SegmentPropagator for this 
            segment. This method assumes that no previous segment is needed to configure 
            this segment's propagator.
              (Inherited from SegmentDefinition.) | |
| GetSegmentPropagator(SegmentDefinition) | 
            Creates, configures, and returns the SegmentPropagator for this 
            segment.
              (Inherited from SegmentDefinition.) | |
| GetSegmentPropagator(EvaluatorGroup, SegmentDefinition) | 
            Creates, configures, and returns the SegmentPropagator for this 
            segment.
              (Inherited from SegmentDefinition.) | |
| GetType | Gets the Type of the current instance.  (Inherited from Object.) | |
| IsSameDefinition | 
        Determines if this object has the same definition as another object.
        (Inherited from DefinitionalObject.) | |
| MemberwiseClone | Creates a shallow copy of the current Object.  (Inherited from Object.) | |
| RemoveElement | 
            Removes the StateElementAdapterDefinition for the specified element.
              (Inherited from SegmentDefinition.) | |
| SetElementAndAdapter | 
            Normally this method would set the StateElementAdapterDefinition 
            on this segment, but instead you must set the adapter on 
            either the PrimarySegment or AlternateSegment.
              (Overrides SegmentDefinitionSetElementAndAdapter(StateElementAdapterDefinition).) | |
| ThrowIfFrozen | 
            Throws ObjectFrozenException if this object IsFrozen.
            This method should be called from any method or property that modifies this object.
              (Inherited from DefinitionalObject.) | |
| ToString | Returns a string that represents the current object.  (Inherited from SegmentDefinition.) | 
| Name | Description | |
|---|---|---|
| PropagationFinishedEvent | 
            An event that gets raised when propagation is complete.
              (Overrides SegmentDefinitionPropagationFinishedEvent.) |