▼NGravityEngine2 | |
CBodyInitData | Container class to hold common info for init of an orbital body |
►CBooster | Booster External Acceleration |
CStage | Utility class to bundle together the attributes for a rocket stage. Some redundancy (payload and dry mass) |
►CCR3BP | Circular Restricted Three Body Problem |
CCR3BPSystemData | |
CDisplayFunctionAsMesh | Started life with a snippet from https://catlikecoding.com/unity/tutorials/procedural-grid/ |
CDisplayMeshScale | Started life with a snippet from https://catlikecoding.com/unity/tutorials/procedural-grid/ |
CDustBall | |
CDustRing | Dust ring. Create a ring of particles in orbit around an NBody mass. Allows full control over the orbital attributes of the ring particles |
CEarthAtmosphere | Computes the acceleration due to drag in the Earth's atmosphere for a given height and velocity |
CEarthSunlight | Set the illumination direction for a directional light for the Earth based on evolving time in world seconds |
CEphemerisData | Contatiner class to hold info on ephemeris data read from a file |
CEphemerisLoader | Class to load ephemeris data and place is GEBodyState array |
►CEphemerisPropagator | Code used by GEPhysicsCore to evolve according to an ephemeris table. The data values have been repackaged by GECore and converted into GE units by the time this code acts on them |
CPropInfo | |
►CExternalAccel | The integrators in the GEPhysicsCore can be configured to include additional forces (beyond gravity) to their force computations. Typical examples include a continuous thrust rocket, atmospheric drag or changes to the gravitation force itself (e.g. 1/R) |
CEADesc | Struct to hold arbitrary parameters for an external acceleration computation and body |
CEAStateData | Data passed to an external accel function call. The state information for each of the two bodies and their effective masses are provided |
►CGBUnits | Gravity engine uses NBody units (nbu) (https://en.wikipedia.org/wiki/N-body_units) internally. This allows the numerical integration to work with values without worring about loss of precision due to odd choices of scale (e.g. galaxy simulation in cm) |
CGEScaler | |
CGE2_Documentation | Simple Script to provide a button to open related docs in a browser |
CGEBodyState | Struct to hold the state information of a body being evolved in the GECore. Typically the information is in world units (unless the request to GEcore.StateById() specifically asked for GE internal units) |
CGEConst | |
►CGECore | Gravity Engine Core Central class for evolution using gravity and propagators |
CGEConfig | |
CGEListenerIF | |
CGEManeuver | GEmaneuver is the CLASS that represents a maneuver while it is being created and planned. As a class it is easy to adjust member variables during creation. It5 also holds a reference to the body to be applied (and optionally center it is relative to) by id |
CGEManeuverStruct | Struct of types that are Burst/Job compatible to describe maneuvers for the IJob propagators |
►CGEPhysicsCore | This (plus the |
CColliderInfo | |
CGEBodies | Core state information for all bodies in GE (all types) |
CGEPhysicsJob | GEPhysicsJob Central engine for moving all objects based on NBody physics integrations and/or specific propagators on a per body basis. It can be run in Job mode or can be called "in-line" from GravityEngine |
CPatchInfo | Patches: A body may be tagged as patched. This means that it has different propagators for different time ranges. The canonical example is a sequence of conics (Kepler propagators) that cover e.g the path out of Earth orbit, navigation through cis-lunar space and then a Kepler propagator when it is within the moon's sphere of influence |
CPhysEvent | |
CGESphereCamera | Key control to rotate camera boom using Arrow keys for rotation and < > keys for zoom |
CGravityJ2 | |
CGravityMath | |
CGSBinary | Component to specify that two GSBody objects are in orbit around their mutual center of mass (CM). Use when the mass ratio of the two bodies m1/m2, m1 < m2 is non negligible. e.g. the Earth/Moon system |
CGSBody | A component for the in-scene representation of a body to be evolved with GE via a GravitySceneController |
CGSBoosterMultiStage | Specifies and controls a multi-stage rocket for launch from a planet surface |
CGSCollider | In Scene representation of a collider attached to a GSBody |
CGSCommon | |
CGSController | The GSController (GSC) manages a set of gravitational bodies in an orbital system and their associated scene display components. There may be zero, one or many GSControllers that make reference to the gravitational bodies managed by this controller |
►CGSDisplay | Control the display of all GSDisplay objects for a given GE. The GE is commonly implied by the use of GravitySceneController, otherwise it can be set via a script |
CGSDisplayObjectInfo | |
CGSDisplay2D | Display objects and trajectories on XY plot of ascent/launch path |
CGSDisplay2DCoro | Project the physical orbit onto the XZ view plane |
CGSDisplayBody | Class to display the location of a GSBody in a scene |
CGSDisplayObject | Abstract class to provide a API to allow display objects to add themselves to the GravitySceneDisplay (GSD) in the fashion they wish |
CGSDisplayOrbit | GSDisplayOrbit: This component has several usages: 1) Display an orbit for an existing (evolving) orbit in the scene |
CGSDisplayOrbitPoint | Display the specified point on the Orbit referenced by GSDisplayOrbit by moving the transform of this object to the correct location |
CGSDisplayOrbitSegment | Displays a segment of an orbit around a central body |
CGSEarthAtmosphere | Computes the acceleration due to drag in the Earth's atmosphere for a given height and velocity |
CGSExternalAcceleration | Display class to allow a constant external acceleration to be added to an object that has a GRAVITY propagator |
CGSLaunchDisplay | Display objects and trajectories on XY plot of ascent/launch path |
CGSMapDisplay | Display objects and trajectories on a map projection of a planet |
►CGSParticles | Evolve particles in the gravitation field computed by the GravityEngine |
CParticleData | Particle evolution |
CParticleJob | |
CGSStageDisplayMgr | Manages the display of stages for a multi-stage booster |
CGSTools | |
CGSTransferShip | Scene wrapper for the |
CHohmannGeneral | Hohmann transfer or rendezvous between any two circular orbits. Handles diffences in radius, inclination and RAAN (Omega) |
CI18N | |
CIGSParticlesInit | Interface defining methods to be implemented to define particle positions and velocities for GravityParticles |
►CIntegrators | |
CLeapfrogData | |
CRK4Data | |
CInverseR | |
CIonDrive | |
CJPLHorizonTools | |
CJPLThreeBodyCSV | Script to use in Editor to read a CSV exported from the JPL Three Body website (https://ssd.jpl.nasa.gov/tools/periodic_orbits.html#/intro) |
►CKeplerPropagator | Code to propagate Kepler orbits (ellipse, parabola, hyperbola) |
CPropInfo | |
CRVT | |
►CLambert | |
CLambertOutput | |
CLambertBattin | |
CLambertJob | |
CLambertPorkchop | |
CLambertUniversal | Calculate the universal Lambert transfer. This algorithm allows the transfer to be elliptic or hyperbolic as necessary to meet the designated transfer time. The transfer code can be used to determine the minimum energy transfer between the desired points/orbits - in this case the time of transfer is not specified. Additional API calls can be used to request a specific transfer time. It is frquently useful to obtain the most efficient transfer time and then use this as a baseline from which to investigate the dV cost of faster transfers |
CLaunchSiteShim | A kinda kludgy class to position a transform at the true physical surface of a planet and orient the indicated display axis model to be normal to the planets surface |
►CLeastSquaresFit | Routines to do a linear least-squares fit |
CLSPoint | |
CLineScaler | |
CMeshBuilder | Started life with a snippet from https://catlikecoding.com/unity/tutorials/procedural-grid/ |
►COrbital | Orbital utilities relating to classical orbital elements (COE) and converting between (r,v) <=> COE |
CCOE | Classical orbit elements |
CCOEStruct | Light weight struct to hold COE core data for the job system and propagators |
COrbitDisplayCommon | |
►CPKeplerPropagator | Propagation using the PKEPLER algorithm from Vallado |
CPropInfo | |
CPlot2D | Plot 2D data |
CPolynomialSolver | |
CSecantRootFind | Secant root find method |
►CSGP4Propagator | Code to propagate SGP4 satellites i.e. satellites in Earth orbit with modeling for atmosphere, oblate gravity, moon, sun etc |
CPropInfo | |
CSGP4SatData | |
CSGP4unit | |
►CSGP4utils | |
CMDHMS | |
CSolarMetaController | The Solar System has a GSController for the motion of planets around the sun and separate controllers for any planets with satellites. Due to the difference length and mass scales these controllers will have different internal integration times |
►CSolarSystemBuilder | SolarSystemBuilder is an Editor feature used to create a Solar System prior to running a scene. This class is just a struct like anchor for the editor operations |
CCOERequest | Container class to store the relevant info to make a Horizons Web API request |
CSolarSystemTools | |
CStructPool | Utility to manage a pool of structs in GECore |
►CTimeUtils | |
CMDHMS | |
CTransferShip | Class to determine the maneuvers required to get a ship at an existing position in orbit around a center body to a specified orbit |