Skip to content

Commit

Permalink
2.19.1.1
Browse files Browse the repository at this point in the history
-Fixes "Leap Year Bug" impacting celestial calculations and Julian date conversions prior to 1582 (pre-Gregorian).
-Exposes the Obliquity of Ecliptic value within the SolarCoordinate class.
  • Loading branch information
Tronald committed Jul 26, 2023
1 parent 4e0d483 commit 29da8af
Show file tree
Hide file tree
Showing 6 changed files with 66 additions and 13 deletions.
4 changes: 2 additions & 2 deletions CoordinateSharp.Magnetic/CoordinateSharp.Magnetic.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ For more information, please contact Signature Group, LLC at this address: sales
<TargetFrameworks>net40; netstandard1.3; netstandard1.4; netstandard2.0; netstandard2.1; net50; net60; net70</TargetFrameworks>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<GenerateDocumentationFile>true</GenerateDocumentationFile>
<Version>1.1.8.0</Version>
<Version>1.1.9.0</Version>
<Authors>Signature Group, LLC</Authors>
<Company />
<PackageProjectUrl>https://github.com/Tronald/CoordinateSharp</PackageProjectUrl>
Expand All @@ -61,7 +61,7 @@ For more information, please contact Signature Group, LLC at this address: sales
<PackageIconUrl></PackageIconUrl>
<PackageId>CoordinateSharp.Magnetic</PackageId>
<Title>CoordinateSharp.Magnetic</Title>
<AssemblyVersion>1.1.7.0</AssemblyVersion>
<AssemblyVersion>1.1.9.0</AssemblyVersion>
<PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
<SignAssembly>true</SignAssembly>
<PackageIcon>128x128.png</PackageIcon>
Expand Down
8 changes: 7 additions & 1 deletion CoordinateSharp/Celestial/Celestial.Coordinates.cs
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ namespace CoordinateSharp
public class SolarCoordinates
{
//Test Against https://www.timeanddate.com/worldclock/sunearth.html

internal double trueLongitude;
internal double trueLatitude;
internal double julianDayDecimal;
Expand All @@ -64,7 +65,7 @@ public class SolarCoordinates
internal double rightAscension;
internal double declination;
internal double geometricMeanLongitude;

internal double obliquityOfEcliptic;

/// <summary>
/// Radius Vector (expressed in astronomical units).
Expand Down Expand Up @@ -96,6 +97,11 @@ public class SolarCoordinates
/// </summary>
public double GeometricMeanLongitude { get { return geometricMeanLongitude; } }

/// <summary>
/// Obliquity of the Ecliptic
/// </summary>
public double ObliquityOfEcliptic { get { return obliquityOfEcliptic; } }

/// <summary>
/// Subsolar Latitude. The point at which the sun is perceived to be directly overhead of the Earth (at the zenith).
/// </summary>
Expand Down
6 changes: 4 additions & 2 deletions CoordinateSharp/Celestial/Solar/SunCalculations.cs
Original file line number Diff line number Diff line change
Expand Up @@ -433,7 +433,7 @@ public static SolarCoordinates Get_Solar_Coordinates(DateTime d, double offset)

double tdec = Math.Asin(Math.Sin(E.ToRadians()) * Math.Sin(trueLongitude.ToRadians())); //25.7 True declination. Asin used in liu of sin.

double CE = E + .00256 * Math.Cos(ascendingNode.ToRadians());//22.2 Obliquity of the ecliptic
double CE = E + .00256 * Math.Cos(ascendingNode.ToRadians());//25.6 & 25.7 Apparent position of the sun.

double ara = Math.Atan2(Math.Cos(CE.ToRadians()) * Math.Sin(apparentLongitude.ToRadians()), Math.Cos(apparentLongitude.ToRadians())); //25.8 Apparent Right Ascensions. Using Atan2 we can move tan to the right side of the function with Numerator, Denominator
double adec = Math.Asin(Math.Sin(CE.ToRadians()) * Math.Sin(apparentLongitude.ToRadians())); //25.8 Apparent declination. Asin used in liu of sin.
Expand All @@ -443,14 +443,16 @@ public static SolarCoordinates Get_Solar_Coordinates(DateTime d, double offset)
//Set to degrees
//celC.trueRightAscension = tra.ToDegrees();
//celC.trueDeclination = tdec.ToDegrees();
var tr = tra.ToDegrees().NormalizeDegrees360();
celC.rightAscension = ara.ToDegrees().NormalizeDegrees360();
celC.declination = adec.ToDegrees();
celC.julianDayDecimal = JD-.5 - Math.Floor(JD-.5);
celC.trueLongitude = trueLongitude.NormalizeDegrees360();
celC.longitude = apparentLongitude.NormalizeDegrees360();
celC.radiusVector = R;
celC.geometricMeanLongitude = L0.NormalizeDegrees360();
//Latitude is always 0 for sun as perturbations no accounted for in low accuracy formulas
celC.obliquityOfEcliptic = E.NormalizeDegrees360();
//Latitude is always 0 for sun as perturbations not accounted for in low accuracy formulas
celC.latitude = 0;
celC.trueLatitude = 0;

Expand Down
12 changes: 5 additions & 7 deletions CoordinateSharp/CoordinateSharp.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -50,29 +50,27 @@ Please visit http://coordinatesharp.com/licensing or contact Signature Group, LL
<TargetFrameworks>net40; netstandard1.3; netstandard1.4; netstandard2.0; netstandard2.1; net50; net60; net70</TargetFrameworks>
<GeneratePackageOnBuild>true</GeneratePackageOnBuild>
<GenerateDocumentationFile>true</GenerateDocumentationFile>
<Version>2.18.1.1</Version>
<Version>2.19.1.1</Version>
<Authors>Signature Group, LLC</Authors>
<Company />
<PackageProjectUrl>https://github.com/Tronald/CoordinateSharp</PackageProjectUrl>
<PackageLicenseUrl></PackageLicenseUrl>
<Copyright>Copyright 2023</Copyright>
<Description>CoordinateSharp is a high powered, lightweight .NET library that can convert geographical coordinates, perform distance logic, and calculate location based sun, moon, and magnetic information with minimal code.</Description>
<PackageReleaseNotes>-Improves UTM and MGRS conversion efficiency by 13x.
-Adds ability create geofence from a specified GEOREF coordinate and precision level.
-Adds ability to locate GEOREF box corners based on a given precision level.
-Restricts GEOREF easting and northing minutes and seconds to 59.999... to comply with library standards.</PackageReleaseNotes>
<PackageReleaseNotes>-Fixes "Leap Year Bug" impacting celestial calculations and Julian date conversions prior to 1582 (pre-Gregorian).
-Exposes the Obliquity of Ecliptic value within the SolarCoordinate class.</PackageReleaseNotes>
<PackageTags>Conversion; Latitude; Longitude; Coordinates; Geography; Sun; Moon; Solar; Lunar; Time; MGRS; UTM; EPSG:3857; ECEF; GEOREF; Web Mercator;</PackageTags>
<!-- <PackageLicenseExpression>AGPL-3.0-or-later</PackageLicenseExpression>-->
<PackageLicenseFile>License.txt</PackageLicenseFile> <PackageIconUrl></PackageIconUrl>
<PackageId>CoordinateSharp</PackageId>
<Title>CoordinateSharp</Title>
<AssemblyVersion>2.17.1.1</AssemblyVersion>
<AssemblyVersion>2.19.1.1</AssemblyVersion>
<PackageRequireLicenseAcceptance>true</PackageRequireLicenseAcceptance>
<SignAssembly>true</SignAssembly>
<PackageIcon>128x128.png</PackageIcon>
<AssemblyOriginatorKeyFile>CoordinateSharp Strong Name.snk</AssemblyOriginatorKeyFile>
<DelaySign>false</DelaySign>
<FileVersion>2.17.1.1</FileVersion>
<FileVersion>2.19.1.1</FileVersion>
<RepositoryUrl>https://github.com/Tronald/CoordinateSharp</RepositoryUrl>
<PackageReadmeFile>README.md</PackageReadmeFile>
<SymbolPackageFormat>snupkg</SymbolPackageFormat>
Expand Down
29 changes: 28 additions & 1 deletion CoordinateSharp/Julian/Julian.cs
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ or shipping CoordinateSharp with a closed source product.
Please visit http://coordinatesharp.com/licensing or contact Signature Group, LLC to purchase a commercial license, or for any questions regarding the AGPL 3.0 license requirements or free use license: [email protected].
*/
using System;
using System.Diagnostics;

namespace CoordinateSharp
{
/// <summary>
Expand Down Expand Up @@ -125,6 +127,10 @@ public static double GetJulian_Epoch1970(DateTime d)
/// Returns date from Julian
/// Meeus ch. 7
/// </summary>
/// <remarks>
/// The Gregorian calendar (started in 1582) contains different leap year rules than the Julian calendar. To avoid exceptions, any invalid pre-1582 Gregorian leap year conversions of
/// February 29th will shift to March 1st. As such you may see two consecutive Julian to Gregorian conversions produce a date of March 1st on rare occasions.
/// </remarks>
/// <param name="j">Julian date</param>
/// <returns>DateTime</returns>
/// <example>
Expand All @@ -136,7 +142,7 @@ public static double GetJulian_Epoch1970(DateTime d)
/// </example>
public static DateTime? GetDate_FromJulian(double j)
{
if (Double.IsNaN(j)) { return null; } //No Event Occured
if (Double.IsNaN(j)) { return null; } //No Event Occurred

j = j + .5;
double Z = Math.Floor(j);
Expand Down Expand Up @@ -176,13 +182,30 @@ public static double GetJulian_Epoch1970(DateTime d)
hours = Math.Floor(hours);
minutes = Math.Floor(minutes);

//Leap year safety check due to differences in Julian and Gregorian calendars.
//This limitation of CoordinateSharp is documented. Safety check implemented to prevent breakage.
if (month == 2 && day == 29)
{
if (year / 100 == (int)(year / 100) && year / 400 != (int)(year / 400))
{
Debug.WriteLine($"CAUTION: Julian date {j} does not exist on the Gregorian calendar (29-FEB-{year}). Shifting to next Gregorian day (1-MAR-{year}).");
month++;
day = 1;

}
}

DateTime? date = new DateTime?(new DateTime((int)year, (int)month, (int)day, (int)hours, (int)minutes, (int)seconds));
return date;
}
/// <summary>
/// Returns date from Julian based on epoch 2000
/// Meeus ch. 7
/// </summary>
/// <remarks>
/// The Gregorian calendar (started in 1582) contains different leap year rules than the Julian calendar. To avoid exceptions, any invalid pre-1582 Gregorian leap year conversions of
/// February 29th will shift to March 1st. As such you may see two consecutive Julian to Gregorian conversions produce a date of March 1st on rare occasions.
/// </remarks>
/// <param name="j">Julian date (epoch 2000)</param>
/// <returns>DateTime</returns>
/// <example>
Expand All @@ -200,6 +223,10 @@ public static double GetJulian_Epoch1970(DateTime d)
/// Returns date from Julian based on epoch 1970
/// Meeus ch. 7
/// </summary>
/// <remarks>
/// The Gregorian calendar (started in 1582) contains different leap year rules than the Julian calendar. To avoid exceptions, any invalid pre-1582 Gregorian leap year conversions of
/// February 29th will shift to March 1st. As such you may see two consecutive Julian to Gregorian conversions produce a date of March 1st on rare occasions.
/// </remarks>
/// <param name="j">Julian date (epoch 1970)</param>
/// <returns>DateTime</returns>
/// <example>
Expand Down
20 changes: 20 additions & 0 deletions CoordinateSharp_UnitTests/Formatters.cs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@
using System.IO;
using System.Runtime.Serialization.Formatters.Binary;
using System.Threading;
using NuGet.Frameworks;

namespace CoordinateSharp_UnitTests
{
[TestClass]
Expand Down Expand Up @@ -116,6 +118,24 @@ public void Normalize360()
Assert.AreEqual(201.80720, Format.NormalizeDegrees360(signed),.000000001);
}

[TestMethod]
public void JulianLeapYearSafetyCheck()
{
//Ensure no throws due to calendar differences
JulianConversions.GetDate_FromJulian(1757641.5);

for (int x = 100; x < 2400; x += 100)
{
Celestial.CalculateCelestialTimes(39, -72, new DateTime(x, 2, 26));
Celestial.CalculateCelestialTimes(39, -72, new DateTime(x, 4, 21, 10, 10, 12));
}



}



/// <summary>
/// Ensures Coordinate and serialize in binary and deserialze properly
/// </summary>
Expand Down

0 comments on commit 29da8af

Please sign in to comment.