Date: 2021 OCT 31
Attendees:
- Greg H (gregh)
- Chris R (xionbox)
- Everyone:
- Greg:
- Start working on the Rust project with the
specs
repo as a submodule - Investigate whether Flatbuffers could be used to write tests, or if another framework can be used to write generic tests in several languages to avoid cloning the test suite for each supported language
- Start working on the Rust project with the
- Chris R:
- Write meeting notes and requirement process
- Create Google documents for requirements and for LSIC 18 Nov 2021 meeting
- Send next meeting invite
- Send LSIC meeting invite, and ask Sarah Whitee for Greg and Chris DC to join too
- Check that Greg can create a project on nyx-space/anise gitlab group
- Everyone:
- Think / write about top level requirements of ANISE
- Chris R:
- Write meeting notes
- Send next meeting invite
- Share
flatc
command to generate Rust bindings -- Greg and Chris actually had the same command
These are Greg's requirements with a summary of the conversation that followed.
- Test driven development should be done before any code, including specs
- A common compilation and build script to ensure reproducibility of builds
- Can test suite be generated for all languages at once to avoid cloning the test suite -- best would be if that could be done in the FBS format
- Fuzzy testing (possibly formal verification) should be added where possible
- Shape model work should be a big module, and should include GPU based computations for shadow mapping, etc.
- Greg has lots of experience on this, so he could be responsible for this part of the requirements.
- Time management, frame computations, light-time corrections, etc. shall be supported
- Chris has lots of experience with this when working on XBs, so he can tackle that.
- Basic satellite operations, like event management, servo control, and the like could be useful too
- Chris thinks that each spacecraft is too specific to have a common framework for most operations.
- At the same time, if this isn't supported, what's the point of having the libraries be flight software ready?
- Maybe a middle ground can be found where a subset of functions can be FSW-ready and plug-and-playable (as Juno mentioned last time), including quaternion math and frame transformations
- It should be possible to incorporate MPC and HORIZON-generated ephemerides
- Some basic functions like visibility analysis for inter-satellite links and eclipses should be provided
- All rotations and translations should be provided only as interpolation data, no "exact" state/quaternion or equations defining this information. For example, SPICE allows defining a low precision rotation with time variying equations of right ascension, declination, and twist angles. This is problematic for on-board computation because it needs to be interpreted each time. Instead, ANISE should provide a command line tool to generate a kernel for that rotation (which would be a set of interpolation splines for each component of the quaternion), and that kernel can be merged into another kernel pool. The downside of this approach is the need for the tool, and maybe even for a domain-specific language to define these rotations, but overall it'll make operations smoother.
A requirement answers the question of "what needs to be done", not "how it should be done" (that's architecture and implementation). A requirement include a title, a description, and a verification method. The title must includes the verb "shall". The verification method is either "inspection" for a human verification of that the requirement is met, or "testing" when a specific test suite must be provided. It would be great if a few requirements could have a formal verification.
- Drafting process - deadline of 15 November 2021
- This process is done in the Google Spreadsheet for rapid iteration and commenting
- Any new requirement should fit in a section, or a section should be created. The section identifier is specified in the four leftmost columns
- Once the requirement has been drafted by author X, then the author should mark is as "Ready" (column H) and another author shall review it. If approved as is, then the reviewer shall mark it as "Accepted." If any comment is made, the status of the requirement shall be "Rejected" and the original author must address the changes.
- On the day of the deadline,
- All of the Approved requirements will be transcribed into a Markdown file and will serve as the first basis of implementation.
- Hopefully no more requirements will be outstanding until the first batch is implemented. But if that isn't the case, we'll create a new document with the updated set of requirements for draft 0.2