本文整理汇总了C#中Orbit.SwappedAbsolutePositionAtUT方法的典型用法代码示例。如果您正苦于以下问题:C# Orbit.SwappedAbsolutePositionAtUT方法的具体用法?C# Orbit.SwappedAbsolutePositionAtUT怎么用?C# Orbit.SwappedAbsolutePositionAtUT使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Orbit
的用法示例。
在下文中一共展示了Orbit.SwappedAbsolutePositionAtUT方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: DeltaVAndTimeForCheapestCourseCorrection
public static Vector3d DeltaVAndTimeForCheapestCourseCorrection(Orbit o, double UT, Orbit target, CelestialBody targetBody, double finalPeR, out double burnUT)
{
Vector3d collisionDV = DeltaVAndTimeForCheapestCourseCorrection(o, UT, target, out burnUT);
Orbit collisionOrbit = o.PerturbedOrbit(burnUT, collisionDV);
double collisionUT = collisionOrbit.NextClosestApproachTime(target, burnUT);
Vector3d collisionPosition = target.SwappedAbsolutePositionAtUT(collisionUT);
Vector3d collisionRelVel = collisionOrbit.SwappedOrbitalVelocityAtUT(collisionUT) - target.SwappedOrbitalVelocityAtUT(collisionUT);
double soiEnterUT = collisionUT - targetBody.sphereOfInfluence / collisionRelVel.magnitude;
Vector3d soiEnterRelVel = collisionOrbit.SwappedOrbitalVelocityAtUT(soiEnterUT) - target.SwappedOrbitalVelocityAtUT(soiEnterUT);
double E = 0.5 * soiEnterRelVel.sqrMagnitude - targetBody.gravParameter / targetBody.sphereOfInfluence; //total orbital energy on SoI enter
double finalPeSpeed = Math.Sqrt(2 * (E + targetBody.gravParameter / finalPeR)); //conservation of energy gives the orbital speed at finalPeR.
double desiredImpactParameter = finalPeR * finalPeSpeed / soiEnterRelVel.magnitude; //conservation of angular momentum gives the required impact parameter
Vector3d displacementDir = Vector3d.Cross(collisionRelVel, o.SwappedOrbitNormal()).normalized;
Vector3d interceptTarget = collisionPosition + desiredImpactParameter * displacementDir;
Vector3d velAfterBurn;
Vector3d arrivalVel;
LambertSolver.Solve(o.SwappedRelativePositionAtUT(burnUT), interceptTarget - o.referenceBody.position, collisionUT - burnUT, o.referenceBody, true, out velAfterBurn, out arrivalVel);
Vector3d deltaV = velAfterBurn - o.SwappedOrbitalVelocityAtUT(burnUT);
return deltaV;
}
示例2: DrawOrbit
public static void DrawOrbit(Orbit o, Color c)
{
List<Vector3d> points = new List<Vector3d>();
if (o.eccentricity < 1)
{
//elliptical orbits:
for (int trueAnomaly = 0; trueAnomaly < 360; trueAnomaly += 1)
{
points.Add(o.SwappedAbsolutePositionAtUT(o.TimeOfTrueAnomaly(trueAnomaly, 0)));
}
points.Add(points[0]); //close the loop
}
else
{
//hyperbolic orbits:
for (int meanAnomaly = -1000; meanAnomaly <= 1000; meanAnomaly += 5)
{
points.Add(o.SwappedAbsolutePositionAtUT(o.UTAtMeanAnomaly(meanAnomaly * Math.PI / 180, 0)));
}
}
DrawPath(o.referenceBody, points, c, false);
}
示例3: DeltaVAndTimeForCheapestCourseCorrection
public static Vector3d DeltaVAndTimeForCheapestCourseCorrection(Orbit o, double UT, Orbit target, double caDistance, out double burnUT)
{
Vector3d collisionDV = DeltaVAndTimeForCheapestCourseCorrection(o, UT, target, out burnUT);
Orbit collisionOrbit = o.PerturbedOrbit(burnUT, collisionDV);
double collisionUT = collisionOrbit.NextClosestApproachTime(target, burnUT);
Vector3d position = o.SwappedAbsolutePositionAtUT(collisionUT);
Vector3d targetPos = target.SwappedAbsolutePositionAtUT(collisionUT);
Vector3d direction = targetPos - position;
Vector3d interceptTarget = targetPos + target.NormalPlus(collisionUT) * caDistance;
Vector3d velAfterBurn;
Vector3d arrivalVel;
LambertSolver.Solve(o.SwappedRelativePositionAtUT(burnUT), interceptTarget - o.referenceBody.position, collisionUT - burnUT, o.referenceBody, true, out velAfterBurn, out arrivalVel);
Vector3d deltaV = velAfterBurn - o.SwappedOrbitalVelocityAtUT(burnUT);
return deltaV;
}
示例4: DeltaVToChangeInclination
//Computes the delta-V of the burn required to change an orbit's inclination to a given value
//at a given UT. If the latitude at that time is too high, so that the desired inclination
//cannot be attained, the burn returned will achieve as low an inclination as possible (namely, inclination = latitude).
//The input inclination is in degrees.
//Note that there are two orbits through each point with a given inclination. The convention used is:
// - first, clamp newInclination to the range -180, 180
// - if newInclination > 0, do the cheaper burn to set that inclination
// - if newInclination < 0, do the more expensive burn to set that inclination
public static Vector3d DeltaVToChangeInclination(Orbit o, double UT, double newInclination)
{
double latitude = o.referenceBody.GetLatitude(o.SwappedAbsolutePositionAtUT(UT));
double desiredHeading = HeadingForInclination(newInclination, latitude);
Vector3d actualHorizontalVelocity = Vector3d.Exclude(o.Up(UT), o.SwappedOrbitalVelocityAtUT(UT));
Vector3d eastComponent = actualHorizontalVelocity.magnitude * Math.Sin(Math.PI / 180 * desiredHeading) * o.East(UT);
Vector3d northComponent = actualHorizontalVelocity.magnitude * Math.Cos(Math.PI / 180 * desiredHeading) * o.North(UT);
if (Vector3d.Dot(actualHorizontalVelocity, northComponent) < 0) northComponent *= -1;
if (MuUtils.ClampDegrees180(newInclination) < 0) northComponent *= -1;
Vector3d desiredHorizontalVelocity = eastComponent + northComponent;
return desiredHorizontalVelocity - actualHorizontalVelocity;
}
示例5: Separation
//distance between two orbiting objects at a given time
public static double Separation(this Orbit a, Orbit b, double UT)
{
return (a.SwappedAbsolutePositionAtUT(UT) - b.SwappedAbsolutePositionAtUT(UT)).magnitude;
}
示例6: DeltaVToShiftNodeLongitude
public static Vector3d DeltaVToShiftNodeLongitude(Orbit o, double UT, double newNodeLong)
{
// Get the location underneath the burn location at the current moment.
// Note that this does NOT account for the rotation of the body that will happen between now
// and when the vessel reaches the apoapsis.
Vector3d pos = o.SwappedAbsolutePositionAtUT (UT);
double burnRadius = o.Radius (UT);
double oppositeRadius = 0;
// Back out the rotation of the body to calculate the longitude of the apoapsis when the vessel reaches the node
double degreeRotationToNode = (UT - Planetarium.GetUniversalTime ()) * 360 / o.referenceBody.rotationPeriod;
double NodeLongitude = o.referenceBody.GetLongitude(pos) - degreeRotationToNode;
double LongitudeOffset = NodeLongitude - newNodeLong; // Amount we need to shift the Ap's longitude
// Calculate a semi-major axis that gives us an orbital period that will rotate the body to place
// the burn location directly over the newNodeLong longitude, over the course of one full orbit.
// N tracks the number of full body rotations desired in a vessal orbit.
// If N=0, we calculate the SMA required to let the body rotate less than a full local day.
// If the resulting SMA would drop us under the 5x time warp limit, we deem it to be too low, and try again with N+1.
// In other words, we allow the body to rotate more than 1 day, but less then 2 days.
// As long as the resulting SMA is below the 5x limit, we keep increasing N until we find a viable solution.
// This may place the apside out the sphere of influence, however.
// TODO: find the cheapest SMA, instead of the smallest
int N = -1;
double target_sma = 0;
while (oppositeRadius-o.referenceBody.Radius < o.referenceBody.timeWarpAltitudeLimits [4] && N < 20) {
N++;
double target_period = o.referenceBody.rotationPeriod * (LongitudeOffset / 360 + N);
target_sma = Math.Pow ((o.referenceBody.gravParameter * target_period * target_period) / (4 * Math.PI * Math.PI), 1.0 / 3.0); // cube roo
oppositeRadius = 2 * (target_sma) - burnRadius;
}
return DeltaVForSemiMajorAxis (o, UT, target_sma);
}
示例7: DeltaVToShiftLAN
//Computes the deltaV of the burn needed to set a given LAN at a given UT.
public static Vector3d DeltaVToShiftLAN(Orbit o, double UT, double newLAN)
{
Vector3d pos = o.SwappedAbsolutePositionAtUT(UT);
// Burn position in the same reference frame as LAN
double burn_latitude = o.referenceBody.GetLatitude(pos);
double burn_longitude = o.referenceBody.GetLongitude(pos) + o.referenceBody.rotationAngle;
const double target_latitude = 0; // Equator
double target_longitude = 0; // Prime Meridian
// Select the location of either the descending or ascending node.
// If the descending node is closer than the ascending node, or there is no ascending node, target the reverse of the newLAN
// Otherwise target the newLAN
if (o.AscendingNodeEquatorialExists() && o.DescendingNodeEquatorialExists())
{
if (o.TimeOfDescendingNodeEquatorial(UT) < o.TimeOfAscendingNodeEquatorial(UT))
{
// DN is closer than AN
// Burning for the AN would entail flipping the orbit around, and would be very expensive
// therefore, burn for the corresponding Longitude of the Descending Node
target_longitude = MuUtils.ClampDegrees360(newLAN + 180.0);
}
else
{
// DN is closer than AN
target_longitude = MuUtils.ClampDegrees360(newLAN);
}
}
else if (o.AscendingNodeEquatorialExists() && !o.DescendingNodeEquatorialExists())
{
// No DN
target_longitude = MuUtils.ClampDegrees360(newLAN);
}
else if (!o.AscendingNodeEquatorialExists() && o.DescendingNodeEquatorialExists())
{
// No AN
target_longitude = MuUtils.ClampDegrees360(newLAN + 180.0);
}
else
{
throw new ArgumentException("OrbitalManeuverCalculator.DeltaVToShiftLAN: No Equatorial Nodes");
}
double desiredHeading = MuUtils.ClampDegrees360(Heading(burn_latitude, burn_longitude, target_latitude, target_longitude));
Vector3d actualHorizontalVelocity = Vector3d.Exclude(o.Up(UT), o.SwappedOrbitalVelocityAtUT(UT));
Vector3d eastComponent = actualHorizontalVelocity.magnitude * Math.Sin(Math.PI / 180 * desiredHeading) * o.East(UT);
Vector3d northComponent = actualHorizontalVelocity.magnitude * Math.Cos(Math.PI / 180 * desiredHeading) * o.North(UT);
Vector3d desiredHorizontalVelocity = eastComponent + northComponent;
return desiredHorizontalVelocity - actualHorizontalVelocity;
}