The goal of this rewrite is to increase the simplicity, readability, and conciseness of the TJREVERB PFS. General structure overview is below:
- registry.py contains code for the StateFieldRegistry.
- StateFieldRegistry stores global variables that all parts of the PFS can access.
- __init__
- On instantiation, StateFieldRegistry attempts to read log file and set object attributes to the saved values. If this fails, it sets object attributes to the dictionary of defaults. NEEDS TESTING
- START_TIME is always set to the current time. This is because deploying the antenna later is better than deploying it early.
- to_dict returns a dictionary containing the StateFieldRegistry’s variables and values. NEEDS TESTING
- dump writes the current values of the StateFieldRegistry to the log file. NEEDS TESTING
- reset clears the log file so that on the next boot, StateFieldRegistry sets object attributes to default values. NEEDS TESTING
- __init__
- data/state_field_log.txt contains a backup of the StateFieldRegistry in case the pi crashes in space.
- StateFieldRegistry stores global variables that all parts of the PFS can access.
- mission_control.py calls run in main_control_loop.py.
- Iterates through main_control_loop and catches any errors that show up and troubleshoots them, continuing the MCL if troubleshooting is succesful.
- If troubleshooting fails, the program errors out.
- main_control_loop.py iterates forever, reading input from its components and deciding what to do in each cycle. The following are the attributes of the MainControlLoop class.
- On init it creates the StateFieldRegistry object.
- The start method initializes everything for the MCL.
- Saves current time in the StateFieldRegistry vars as LAST_STARTUP.
- Instantiates a Recovery mode object if (antenna deployed) or (aprs or ad are locked off). Otherwise, instantiates a Startup mode object.
- Calls the Mode's start method.
- The iterate method is what iterates forever
- If there hasn't been contact from Iridium in a long time, it switches the primary radio to APRS.
- It iterates the Mode object.
- If there isn't a mode lock, it checks for if the Mode object wants to changes to another mode.
- It then calls the command_executor to execute any commands.
- It then logs the StateFieldRegistry.
- command_executor.py contains all code pertaining to executing commands from TransmissionPackets
- The primary_registry dictionary contains method declarations for all of the commands that APRS and Iridium can execute.
- The secondary_registry dictionary contains method declarations for all of the commands that are accessible to outreach partners.
- The execute method is called through execute_buffers, reading any TransmissionPackets that have been received.
- It reads the packet for whatever command is given, handling any garbled messages.
- It then tries to execute the command, handling any exceptions in the process.
- It then logs the command through the StateFieldRegistry.
- startup.py extends the Mode class and is the mode responsible for operations at startup
- The start method powers on the Iridium radio.
- The deploy_antenna method attempts to deploy the APRS antenna if we've detumbled and enough time has passed.
- The ping method attempts to establish connection with ground using the command_executor.
- execute_cycle
- If the battery is low, it turns off all PDMs and sleeps for an orbit.
- Else, it turns on the primary radio, tries deploy_antenna, and attempts to beacon.
- suggested_mode
- If the antennae haven't been deployed, or contact hasn't been established, returns Startup.
- Else if low battery, returns Charging.
- Else returns Science.
- charging.py extends the Mode class and is the mode responsible for operations while charging
- The start method powers on the primary radio.
- Does nothing in order to preserve power.
- outreach.py extends the Mode class and is the mode responsible for operations while outreaching
- The start method powers on the APRS radio.
- suggested_mode returns Charging if there is low power, and self if there is not low power.
- Does nothing. It acts as a buffer while waiting for APRS commands using the command_executor. (soon to be gaming mode)
- science.py extends the Mode class and is the mode responsible for operations while conducting science
- The start method powers on the Iridium radio.
- suggested_mode returns the following 3. Returns Charging if low battery 4. Returns Outreach if done with data collection or Iridium is offline. 5. Else returns Science.
- The ping method pings ground with Iridium, logging geolocation data and signal strength.
- The transmit_results method transmits logged results using the command_executor.
- execute_cycle iterates through the required amount of pings and then transmits results.
- recovery.py extends the Mode class and is the mode responsible for fixing problems with the satellite mid-flight.
- execute_cycle attempts to run a systems_check from mode.py and attempts to contact ground
- systems_check goes through all unlocked devices and attempts to power it on.
- suggested_mode returns Recovery if the systems check failed and no ground contact was made. Otherwise, it either returns Charging if we have low battery, Science if we haven't finished our science mission, or else Outreach mode.
- execute_cycle attempts to run a systems_check from mode.py and attempts to contact ground
- aprs.py contains all code pertaining to the APRS.
- The read method reads and returns a message received over the APRS, and adds it to the StateFieldRegistry.
- The write method transmits a message through the APRS.
- The functional method tests if the component is connected properly and responsive to commands NEEDS TESTING, NOT FULLY IMPLEMENTED
- eps.py contains all code pertaining to the EPS.
-
The components dictionary contains a list of all components connected to the EPS and their respective PDMs.
- “APRS”: APRS
- “Iridium”: Iridium
- “Antenna Deployer”: Antenna deployer
-
The commands dictionary contains a list of lambda functions to request data from and send commands to the EPS. The returned data (for request commands) is in a raw, uninterpreted bytes format. Refer to pages 40-50 on the EPS manual for more information on EPS commands. Format:
self.eps.commands[COMMAND]()
-
Board Info Commands: Basic board information.
- “Board Status”: Reads and returns board status
- “Last Error”: Reads and returns last error
- “Firmware Version”: Reads and returns firmware version
- “Checksum”: Reads and returns generated checksum of ROM contents
- “Firmware Revision”: Reads and returns firmware revision number
- “Battery Voltage”: Reads and returns battery voltage
-
Watchdog Commands: Watchdog will reset the EPS after a period of time (default 4 minutes) with no commands received.
- “Watchdog Period”: Reads and returns current watchdog period
- “Reset Watchdog”: Resets communications watchdog timer. Any command will reset the timer, this command can be used if no action from the EPS is needed.
-
Reset Count Commands: The EPS resets under various conditions. These commands return the number of times the EPS has reset due to each condition. Counts roll over from 255 to 0.
- “Brownout Resets”: Reads and returns number of brownout resets
- “Software Resets”: Reads and returns number of software resets
- “Manual Resets”: Reads and returns number of manual resets
- “Watchdog Resets”: Reads and returns number of watchdog resets
-
PDM Control: Get information about PDMs and switch PDMs on and off to control power to components.
- “All Actual States”: Reads and returns actual state of all PDMs in byte form. PDMs may be shut off due to protections, and this command shows the actual state of all PDMs.
- “All Expected States”: Reads and returns expected state of all PDMs in byte form. These depend on whether they have been commanded on or off, regardless of protection trips.
- “All Initial States”: Reads and returns initial states of all PDMs in byte form. These are the states the PDMs will be in after a reset.
- “Pin Actual State”: Reads and returns actual state of one PDM
- “All On”: Turn all PDMs on
- “All Off”: Turn all PDMs off
- “Set All Initial”: Set all PDMs to their initial state
- “Pin On”: Enable component
- “Pin Off”: Disable component
- “Pin Init On”: Set initial state of component to “on”
- “Pin Init Off”: Set initial state of component to “off”
-
PDM Timers: When enabled with timer restrictions, a PDM will remain on for only a set period of time. By default each PDM does not have restrictions.
- “PDM Timer Limit”: Reads and returns timer limit for given PDM
- “PDM Timer Value”: Reads and returns passed time since PDM timer was enabled
-
Manual Reset
- “Manual Reset”: Manually resets EPS to initial state, and increments manual reset counter.
-
-
The telemetry dictionary contains a list of lambda functions which request and return interpreted telemetry from the EPS. Format:
self.eps.telemetry[TELEMETRY]()
NOT ALL COMMANDS UNDERSTOOD- “IBCROUT”: Battery current
- “VBCROUT”: Battery voltage
- See comments in code for full documentation
-
The pcm_busses dictionary contains a list of values for each of the busses on the EPS. Used for the bus_reset method. To reset multiple busses, add the values for each bus to be reset and send the result to bus_reset.
-
The request method requests and returns an uninterpreted bytes object from the EPS.
-
The command method sends a command to the EPS.
-
The telemetry_request method requests and returns interpreted telemetry data given tle and a multiplier.
-
- antenna_deployer.py contains all code pertaining to the antenna.
- The deploy method deploys the antenna.
- The control method deploys the antenna if 30 minutes have elapsed and the antenna is not already deployed.
- iridium.py contians all code pertaining to the Iridium.
- The commands dictionary contains a list of all commands which can be sent to the Iridium.
- “Test”: Tests iridium by sending “AT”. Correct reply is “OK”.
- “Geolocation”: NOT UNDERSTOOD
- “Active Config”: NOT UNDERSTOOD
- “Check Registration”: NOT UNDERSTOOD
- “Phone Model”: NOT UNDERSTOOD
- “Phone Revision”: NOT UNDERSTOOD
- “Phone IMEI”: NOT UNDERSTOOD
- “Check Network”: NOT UNDERSTOOD
- “Shut Down”: NOT UNDERSTOOD
- “Signal Quality”: Returns strength of satellite signal.
- “Send SMS”: NOT UNDERSTOOD
- “Transmit”: Transmits a message as an email to the ground station via the Iridium constellation.
- “SBD Ring Alert On”: NOT UNDERSTOOD
- “SBD Ring Alert Off”: NOT UNDERSTOOD
- “Battery Check”: NOT UNDERSTOOD
- “Call Status”: NOT UNDERSTOOD
- “Soft Reset”: NOT UNDERSTOOD
- The functional method verifies that the serial port is open and that sending AT returns OK.
- The request method requests information from the Iridium and returns the parsed response.
- The wave method transmits a simple hardcoded message to the ground station. This is to accomplish our mission objective of testing Iridium.
- The write method writes a command to the Iridium.
- The read method reads in as many bytes as are available from the Iridium, serial timeout permitting.
- The commands dictionary contains a list of all commands which can be sent to the Iridium.
- reset.sh that attempts to reset the pi using reset0.py or reset1.py
- reset0.py either generates a reset1.py or writes off commands to all busses on the pi.
- reset1.py does the same thing.
For more details on each specific part of the PFS, refer to the comments within the code. This README will be kept as up-to-date as possible.