-
Notifications
You must be signed in to change notification settings - Fork 28
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
getGroundTracks isn't generating points all the way to the antemeridian #43
Comments
The reason why it is failing is because in getOrbitTrack there is an assumption that maxTimeMS is 6000000. However, in this case, the duration of the orbit is longer. The average duration is, however, shorter than 6000000, as specified by the TLE itself. I can think of a few fixes...
Are there others? I am not sure what the most appropriate fix would be given my limited knowledge in this space. However, if you can tell me what it should be, I should be able to find the time to submit a PR for the fix, especially if the PR can be reviewed and accepted quickly. |
That TLE has an orbit of ~96.4 minutes, which should be less than the 100 minute maxTimeMS. I am not sure what you mean by "average duration" vs "duration of the orbit". Edit: I get you were referencing the variable names now.
Let me pull the repo and do a little testing this morning. |
I think the issue might be related to the earth rotating under the satellite. In ECI coordinates, where we pretend the earth isn't spinning, then the satellite makes a complete orbit in < 100 minutes, but if the earth rotates for 90+ minutes then the ground track of the satellite does not wrap around from -180 to +180. You can solve your problem immediately by just increasing the maxTimeMS parameter you are passing to getOrbitTrack (mainly stating that for anyone else reading). I agree that it would be more intuitive that maxTimeMS is used almost exclusively for limiting the ground track and it is not intuitive that you need to increase it sometimes - but I do not use this library regularly. I added a PR to fix the issue, but I am not sure how active @davidcalhoun is on the library. |
The primary issue is that I am calling getGroundTracks which does not accept a maxTimeMS parameter to pass along into getOrbitTrack. If simply increasing maxTimeMS is an appropriate solution, then perhaps getGroundTracks can add maxTimeMS to its parameter list and pass it into getOrbitTrack. As for my term usage, please excuse it...I am not that familiar with this space and am approaching it from the angle of a simple user. But, it looks like you were able to reproduce the issue. Thanks for the PR. I hope @davidcalhoun will accept it soon. Or, perhaps, you could simply fork and maintain this library now if @davidcalhoun has abandoned it. |
Thank you both! I'll take a look when I'm able to. |
Fix is now in 4.9.0 - thank you both! |
I will test the fix on Monday. I expect it will work and this issue can be closed. |
works perfectly now. Thanks again for getting this done quickly. It is appreciated. |
I just came across another case where the ground track is not being computed to the antemeridian. The TLE is:
generated with the start time of I am guessing that this TLE differs from the first in that the curve is tighter than the previous one. My guess is the factor used to allow more points to be computed in the hope that they will cross the antemeridian is not large enough yet. Not sure what the best fix for this is...increase the factor, have getGroundTracks to accept a custom maxTimeMS...? |
"Problem" is here: Line 549 in ce8f7b8
That TLE is for one of the GPS satellites that goes around the earth twice (2.00552469) a day. The minimum for that function is 4 passes a day. Anything with a mean motion less than 4 will not draw the ground trace. You can try raising that number further, but the original intention was for plotting LEO satellites, there might be some other unintended consequences if you just raise it. |
The TLE I am using is:
(from https://celestrak.org/NORAD/elements/)
stepMS was set to 10000
startTimeMS was set to 1698152211870
The final coordinates were:
first track - ( 168.64888285189693, 23.240111501597084 )
second track - ( 166.54109672164154, 9.207423700081948 )
third track - ( 165.9980830743187, -8.892570482834437 )
I tried setting stepMS to 100, for example, but the behavior was the same.
My expectation was for the track coordinates to end somewhere close to 180.
The text was updated successfully, but these errors were encountered: