Using CCDD to Automate Software development on AA2

Slides:



Advertisements
Similar presentations
Brian Alderman | MCT, CEO / Founder of MicroTechPoint Pete Harris | Microsoft Senior Content Publisher.
Advertisements

GLAST LAT ProjectISOC CDR, 4 August 2004 Document: LAT-PR-04500Section 3.11 GLAST Large Area Telescope: Instrument Science Operations Center CDR Section.
Slide 1 of 9 Presenting 24x7 Scheduler The art of computer automation Press PageDown key or click to advance.
March 2004 At A Glance ITOS is a highly configurable low-cost control and monitoring system. Benefits Extreme low cost Database driven - ITOS software.
Windows Server MIS 424 Professor Sandvig. Overview Role of servers Performance Requirements Server Hardware Software Windows Server IIS.
Section 6.1 Explain the development of operating systems Differentiate between operating systems Section 6.2 Demonstrate knowledge of basic GUI components.
Overview of SQL Server Alka Arora.
At A Glance VOLT is a freeware, platform independent tool set that coordinates cross-mission observation planning and scheduling among one or more space.
GEONS Ground Support System Java 7, JavaFX and the NetBeans Platform supporting NASA Missions Operations.
August 2003 At A Glance VMOC-CE is an application framework that facilitates real- time, remote cooperative work among geographically dispersed mission.
Development of a Distributed MATLAB Environment with Real-Time Data Visualization Authors: Joseph Diamond, Richard McEver Affiliation: Dr. Jian Huang,
March 2004 At A Glance NASA’s GSFC GMSEC architecture provides a scalable, extensible ground and flight system approach for future missions. Benefits Simplifies.
Experiment Management System CSE 423 Aaron Kloc Jordan Harstad Robert Sorensen Robert Trevino Nicolas Tjioe Status Report Presentation Industry Mentor:
March 2004 At A Glance autoProducts is an automated flight dynamics product generation system. It provides a mission flight operations team with the capability.
Overview of SOIS Electronic Data Sheets (EDS) & Dictionary of Terms (DoT) SOIS APP WG Fall 2012.
Reduce Development and Testing Time on Embedded Space Programs With Auto- Generated Code Software Engineer Northrop Grumman Electronic Systems Matthew.
August 2003 At A Glance The IRC is a platform independent, extensible, and adaptive framework that provides robust, interactive, and distributed control.
The business logic engine for Microsoft IIS Speaker T.M. Arnett.
Intro to Web Services Dr. John P. Abraham UTPA. What are Web Services? Applications execute across multiple computers on a network.  The machine on which.
March 2004 At A Glance The AutoFDS provides a web- based interface to acquire, generate, and distribute products, using the GMSEC Reference Architecture.
Database Principles: Fundamentals of Design, Implementation, and Management Chapter 1 The Database Approach.
©Ian Sommerville 2004Software Engineering, 7th edition. Chapter 17 Slide 1 Rapid software development.
Space FSW Conference 2016 Matthew Conte Software Engineer
CIS 375 Bruce R. Maxim UM-Dearborn
Test Executive Trades (1)
cFS Workshop Ground Systems & Kits
Development Environment
Software.
Adopting the Python language for On-board Programmable Payload Autonomy Steven Doran 2016 Flight Software Workshop 12/14/2016.
Module 3: Operating-System Structures
Simulink Interface Layer (SIL)
Prototyping in the software process
Integrating MBSE into a Multi-Disciplinary Engineering Environment A Software Engineering Perspective Mark Hoffman 20 June 2011 Copyright © 2011 by Lockheed.
The Components of Information Systems
Operating Systems & System Software
SOIS APP Working Group Overview
Software Prototyping.
Mapping for the interwebs
Design Components are Code Components
Flight Software Development Through Python
Code Generation from SEDS
Exemplar CFS Architecture
Overview of SOIS Electronic Data Sheets (EDS) & Dictionary of Terms (DoT) SOIS APP WG Fall 2012.
TECH SESSION #1 STANDARDS AND BUILD TOOLS
SOIS-APP Working Group Report Jonathan Wilmot (WG Chair)
TECH SESSION #1 ELECTRONIC DATA SHEETS
Prototyping.
CFS Community Day Core Flight System Command and Data Dictionary Utility December 4, 2017 NASA JSC/Kevin McCluney December 4, 2017.
Course Name: QTP Trainer: Laxmi Duration: 25 Hrs Session: Daily 1 Hr.
Integrating CCSDS Electronic Data Sheets into Flight Software
Study of Tools for Command and Telemetry Dictionaries
Tutorial 8 Objectives Continue presenting methods to import data into Access, export data from Access, link applications with data stored in Access, and.
The Components of Information Systems
Big Data The huge amount of data being collected and stored about individuals, items, and activities and to the process of drawing useful information from.
Soo Park and Janine Aquino
CIS16 Application Development – Programming with Visual Basic
Topics Introduction Hardware and Software How Computers Store Data
Resources and Schedule
and Device Interfaces from CCSDS Electronic Data Sheets
Advanced Exploration Systems (AES) Core Flight Software (CFS) Project
Design Components are Code Components
NASA/ Johnson Space Center
Smart Integration Express
Outline Chapter 2 (cont) OS Design OS structure
Mark Suder
SOFTWARE TECHNOLOGIES
Software - Operating Systems
Rapid software development
Chapter-1 Computer is an advanced electronic device that takes raw data as an input from the user and processes it under the control of a set of instructions.
Introducing MagicInfo 6
Presentation transcript:

Using CCDD to Automate Software development on AA2 Robert Hirsh Robert.l.Hirsh@nasa.gov NASA/ Johnson Space Center 12/3/2018 Using CCDD to Automate Software development on AA2

cFS Command and Data Dictionary (CCDD) Overview Agenda AA2 Background cFS Command and Data Dictionary (CCDD) Overview CCDD Products used on AA2 Development on AA2 Next Steps

Ascent Abort 2 (AA-2) AA-2 is a development flight test for Multi Purpose Crew Vehicle (MPCV) Launch planned for May 2019 from Space Launch Complex 46 AA-1 test was dropped, but AA-2 was not renumbered Pad Abort 1 (PA1) demonstrated similar LAS functionality from a launch pad. (May 2010) Largely a test of the Launch Abort System (LAS) on Orion Safety system to quickly separate crew capsule from the Booster (during a failure) Verify LAS works under flight-like conditions to help certify system for crewed missions Two identical CPU’s running, only 1 is required (redundancy) Each CPU is cFS instance running on vxWorks ( on a PPC) Each CPU has separate serial link to the LAS, but only 1 is needed (redundancy) Code is essentially identical on each computer, but each computer used a different value for each MID that it sends on the Software Bus (SB) since various groups use various types of computer hardware (32/64-bit, big/little endian, Linux/VxWorks/Windows) many additional complications exist in interfacing all the various components into a final integrated system. cFS is used on the majority the flight software (FSW) in running in Habulous.

AA-2 Background Altitude (feet) AA-2 Avionics & Software 1 2 3 4 5 6 7 8 9 10 11 12 5,000 10,000 15,000 20,000 25,000 30,000 35,000 40,000 45,000 13 50,000 Downrange (statute miles) Altitude (feet) ATB Ignition Begin Reorientation Reorient Complete LAS Jettison Impact , CM Impact Initiate Abort LAS/CM Separate from ATB Apollo Pad Abort Test Apollo Abort Test (Little Joe Ascent II Booster) The purpose of this slide is to provide objective evidence of and/or support the accomplishment of the following CMMI requirements: IPM-IPPD SG 1Use the projects Defined Process IPM-IPPD SG2 Coordinate and Collaborate with Relevant Stakeholders IPM-IPPD SG3 Apply integrated product & process development GP 2.3 Provide Resources GP 2.4 Assign Responsibility GP 2.7 Identify and Involve relevant stakeholders AA-2 Avionics & Software Designed to use COTS avionics wherever possible Dual string design using cFE/CFS on VxWorks Reuse of ANTARES Trick Simulation CFS wrapped GNC Matlab/Simulink Autocode from mainline MPCV Orion PA-1 Test AA-2 Flight Test Vehicle

CCDD Background CCDD stands for cFS Command and Data Dictionary Goddard’s Core Flight System (cFS) has been, is, and is intended to be used by many projects Examples: Lunar Reconnaissance Orbiter (LRO), Morpheus, Exploration EMU (xEMU) spacesuit, Orion Backup Flight Software (BFS) Success of the cFS concept is shown by the number cFS projects at FSW-2018 A command and data dictionary (CDD) defines telemetry/command messages Each cFS project must select a way to manage their CDD Frequently involves using a spreadsheet, with custom SW to convert into useful files cFS Command and Data Dictionary utility (CCDD) was designed as a generic utility to eliminate duplication of effort in order to make CDD management easier

CCDD Goals Create a configurable CDD utility that runs on multiple operating systems Written in Java for maximum portability Easy creation/modification of CDD information Graphical user interface (GUI) to interact with the database Store all CDD information into a standard database (postgreSQL) Bidirectional transfer of information to/from the CCDD Cut-n-paste to Excel, import/export via XTCE/CSV/JSON Easy access to CDD information (via scripting languages and web applications ) Allows user to code in various languages (ruby/python/js) and access CDD information Create vehicle and ground software products, data summary, etc Generate complicated CFS products: Schedule or network tables, copy table, etc

Imported/exported via: CCDD at a glance Data is accessible to scripting languages (JavaScript, Python, etc.) Example scripts provided for common products Imported/exported via: CSV (comma-separated values) JSON (JavaScript Object Notation) XML (Extensible Markup Language) EDS (Electronic Data Sheet) XTCE (XML Telemetric and Command Exchange) OS clipboard (“cut & paste”) Web-based dataserver (JSON)

CCDD Demo

CCDD Products in AA-2 C header files defining SB command/telemetry messages Define the structure for all software bus (SB) messages. MID file generation ( Same file used by both CPUs ) Defines all the MIDs for each cFS message sent/received on each CPU CPU2 adds 0x100 to all the MID values sent out by CPU1 Allows Ground SW to know which computer sent a message HK copy table generation Telemetry link is constrained. Select various parts of messages to go at different rates 2 separate telemetry paths (per CPU), so 4 separate messages are sent ITOS “rec” files (ground control system) Used to define commands/messages in ITOS Data decom config files (post-flight data processing) Provides CSV files with desired parameters to be analyzed Custom built utilities to decode data from “raw” recorded telemetry files Significantly faster than data replay and seqprt utility in ITOS

Major AA-2 Activity in 2018 Worked to develop the CDD before the SW development was complete CDD not treated as an “as built” post-development documentation effort Required iterations on data structures and MIDs, but minimized interface issues Added ability to track ~900 DFI system parameters (in addition to OFI) Allows additional insight into vehicle for all ground controllers Automated data processing and “quicklook” of key parameters after tests Allows rapid verification of how the system performs during simulation runs Automated regression testing to perform SW verification activities Test framework consumed CCDD-generated files to define CCSDS messages Can verify any parameter (of any messages) meets expected values (at specific times) Automated remote control/monitoring of ground power supplies Quite useful since people need to stay miles away during launch window

Future Work Launch (with a successful abort!) in May 2019 Working with Education/Outreach on student outreach contest Build a real-time application to show the position of the vehicle during the test Winning team to view KSC launch (and see app in use) The CCDD tool has successfully been used to automate/autocode a large amount of software used on AA-2. Pass on the lessons learned so they can be leveraged on other programs