A library that computes the ephemerides.
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.
 
 

63 lines
1.7 KiB

  1. #!/usr/bin/env python3
  2. # Kosmorrolib - The Library To Compute Your Ephemerides
  3. # Copyright (C) 2021 Jérôme Deuchnord <jerome@deuchnord.fr>
  4. #
  5. # This program is free software: you can redistribute it and/or modify
  6. # it under the terms of the GNU Affero General Public License as
  7. # published by the Free Software Foundation, either version 3 of the
  8. # License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU Affero General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU Affero General Public License
  16. # along with this program. If not, see <https://www.gnu.org/licenses/>.
  17. from warnings import warn
  18. from skyfield.api import Loader
  19. from skyfield.timelib import Time
  20. from skyfield.nutationlib import iau2000b
  21. from skyfield_data import get_skyfield_data_path
  22. LOADER = Loader(get_skyfield_data_path())
  23. def get_timescale():
  24. return LOADER.timescale()
  25. def get_skf_objects():
  26. return LOADER("de421.bsp")
  27. def get_iau2000b(time: Time):
  28. return iau2000b(time.tt)
  29. def flatten_list(the_list: list):
  30. new_list = []
  31. for item in the_list:
  32. if isinstance(item, list):
  33. for item2 in flatten_list(item):
  34. new_list.append(item2)
  35. continue
  36. new_list.append(item)
  37. return new_list
  38. def deprecated(message):
  39. def inner(decorated):
  40. def f(*args, **kwargs):
  41. warn(message, DeprecationWarning, stacklevel=2)
  42. return decorated(*args, **kwargs)
  43. return f
  44. return inner