GitXplorerGitXplorer
n

satelliteTracker

public
11 stars
0 forks
0 issues

Commits

List of commits on branch main.
Unverified
be3c2e1b2e1adccbb2184c280f8cc1ad5d71dd14

Updating README

nnfischer committed 9 years ago
Unverified
08171d861e9fa0d92ad03cd3fd93f480b143a6c6

Add requirements.txt

nnfischer committed 9 years ago
Unverified
33cf7f97cf58a165ec5cb0827cb3ab652c05824a

Minor changes to the `now` command

nnfischer committed 9 years ago
Unverified
3178ff0e933be7f51889df590ce7a9b39058f700

Editing comments about parallelism in the README

nnfischer committed 9 years ago
Unverified
16b8e5e4c56861fad140817d3233e6233f975e26

Getting rid of junk about dependencies, since installation isn't that tough.

nnfischer committed 9 years ago
Unverified
cb8d6427491168a5d82e78fc6d70bcf6c3d2eb3d

Removing some print statements

nnfischer committed 9 years ago

README

The README file for this repository.

satelliteTracker

A Python CLI program to track the location of the ISS and other satellites.

Installation

Cloning the project

The recommended installation method is to first clone this git repo, as such:

# make sure to specify '--recursive' in order to install the submodules
$ git clone --recursive https://github.com/nfischer/satelliteTracker.git

SunriseSunsetCalculator

This project uses Jacques-Etienne Beaudet's SunriseSunsetCalculator, based on this algorithm for calculating sunrise and sunset

If you specified the --recursive flag when cloning, you should see a directory structure like:

satelliteTracker/
  LICENSE
  README.md
  satTracker.py
  SunriseSunsetCalculator/
    __init__.py
    README.md
    sunrise_sunset.py

Before installing this module, you'll need to install pip:

$ sudo apt-get install python-pip python-dev

Then install dependencies with:

$ sudo pip install -r requirements.txt

And that's it, you're off to the races!

What can it do?

SatelliteTracker can:

  • update a satellite's location in real-time
  • provide accurate longitude, latitude, elevation, and other location parameters
  • display information about your ground station, as well as the next time your satellite passes overhead
  • automatically update TLEs for various satellites

How does it work?

This project is made using the pyephem module to do the cool computations for longitude, latitude, etc. in real-time for your satellite of choice.

This program has two basic threads:

  • The background thread that updates the values for the satellite's location.
  • The foreground thread that prompts you for commands and then executes them.

The advantage of this concurrent design is that the program will always know where the satellite is, so this leaves room for future development on automatic alerts in real-time for when the satellite is passing overhead or for other events.

A note about parallelism in Python

Python doesn't have great support for parallelism, which is unfortunate. Due to Global Interpreter Lock, a lot of Python code runs concurrently, even if you use the appropriate multithreading modules.

This project does still work though. The background thread runs concurrently with the foreground thread, and they context switch often enough that everything works. So this means the project will still run smoothly, even if you have a singe-core machine (such as a Raspberry Pi).