You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

71 lines
3.2 KiB

  1. # Kosmorro - Compute The Next Ephemeris
  2. # Copyright (C) 2019 Jérôme Deuchnord <jerome@deuchnord.fr>
  3. #
  4. # This program is free software: you can redistribute it and/or modify
  5. # it under the terms of the GNU Affero General Public License as
  6. # published by the Free Software Foundation, either version 3 of the
  7. # License, or (at your option) any later version.
  8. #
  9. # This program is distributed in the hope that it will be useful,
  10. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. # GNU Affero General Public License for more details.
  13. #
  14. # You should have received a copy of the GNU Affero General Public License
  15. # along with this program. If not, see <https://www.gnu.org/licenses/>.
  16. import argparse
  17. from datetime import date
  18. import numpy
  19. import dumper
  20. from ephemeris import Ephemeris
  21. # Fixes the "TypeError: Object of type int64 is not JSON serializable"
  22. # See https://stackoverflow.com/a/50577730
  23. def json_default(obj):
  24. if isinstance(obj, numpy.int64):
  25. return int(obj)
  26. raise TypeError('Object of type ' + str(type(obj)) + ' could not be integrated in the JSON')
  27. def main():
  28. args = get_args()
  29. year = args.year
  30. month = args.month
  31. day = args.date
  32. position = {'lat': args.latitude, 'lon': args.longitude, 'alt': args.altitude}
  33. if day is not None and month is None:
  34. month = date.today().month
  35. ephemeris = Ephemeris(position)
  36. ephemerides = ephemeris.compute_ephemeris(year, month, day)
  37. dump = dumper.TextDumper(ephemerides)
  38. print(dump.to_string())
  39. def get_args():
  40. parser = argparse.ArgumentParser(description='Compute the ephemeris for a given day/month/year.',
  41. epilog='By default, the observer will be set at position (0,0) with an altitude'
  42. ' of 0. You will more likely want to change that.')
  43. parser.add_argument('--latitude', '-lat', type=float, default=0., help="The observer's position on Earth"
  44. " (latitude)")
  45. parser.add_argument('--longitude', '-lon', type=float, default=0., help="The observer's position on Earth"
  46. " (longitude)")
  47. parser.add_argument('--altitude', '-alt', type=float, default=0., help="The observer's position on Earth"
  48. " (altitude)")
  49. parser.add_argument('--date', '-d', type=int, help='A number between 1 and 28, 29, 30 or 31 (depending on the'
  50. ' month). The date you want to compute the ephemeris for')
  51. parser.add_argument('--month', '-m', type=int, help='A number between 1 and 12. The month you want to compute the'
  52. ' ephemeris for (defaults to the current month if the day is'
  53. ' defined)')
  54. parser.add_argument('year', type=int, help='The year you want to compute the ephemeris for')
  55. return parser.parse_args()
  56. if __name__ == '__main__':
  57. main()