Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
96 changes: 82 additions & 14 deletions onair/src/ai_components/ai_plugin_abstract/ai_plugin.py
Original file line number Diff line number Diff line change
@@ -1,40 +1,108 @@
# GSC-19165-1, "The On-Board Artificial Intelligence Research (OnAIR) Platform"
#
# Copyright © 2023 United States Government as represented by the Administrator of
# the National Aeronautics and Space Administration. No copyright is claimed in the
# United States under Title 17, U.S. Code. All Other Rights Reserved.
# Copyright © 2023 United States Government as represented by the Administrator
# of the National Aeronautics and Space Administration. No copyright is claimed
# in the United States under Title 17, U.S. Code. All Other Rights Reserved.
#
# Licensed under the NASA Open Source Agreement version 1.3
# See "NOSA GSC-19165-1 OnAIR.pdf"

from abc import ABC, abstractmethod
"""
This module defines the AIPlugIn abstract base class for the OnAIR Platform.

"""This object serves as a proxy for all plugins.
Therefore, the AIPlugin object is meant to induce
standards and structures of compliance for user-created
and/or imported plugins/libraries
The AIPlugIn class serves as a foundation for all AI plugins in the OnAIR system.
It establishes standards and structures for compliance that must be adhered to by
the four imported plugin types: Knowledge Representation, Learner, Planner, or
Complex Reasoner.

This abstract base class defines the basic structure and required methods that
all AI plugins must implement.
"""


from abc import ABC, abstractmethod
from typing import Any


class AIPlugin(ABC):
def __init__(self, _name, _headers):
"""
This serves as a base for all plugins.

This is the superclass for data driven components. It is
meant to induce standards and structures of compliance for imported
plugins: Knowledge Representation, Learner, Planner or Complex Reasoner.
Those plugins must inherit this class.

Attributes
----------
component_name : str
Name given to instance of plugin.
headers : list of str
Names for each data point, corresponding to the OnAIR low_level_data and frame
elements by matching index position.
"""

def __init__(self, _name: str, _headers: list):
"""
Superclass for data driven components: VAE, PPO, etc. Allows for easier modularity.
Initialize a new AIPlugIn object.

Parameters
----------
_name : str
The name of this plugin instance.
_headers : list of str
Sequenced list of names for each item in OnAIR low_level_data and frame.
"""
assert len(_headers) > 0
self.component_name = _name
self.headers = _headers

@abstractmethod
def update(self, low_level_data=[], high_level_data={}):
def update(
self,
low_level_data: list = None,
high_level_data: dict = None,
) -> None:
"""
Given streamed data point, system should update internally
Update the plugin's internal state with new data.

This method is called to update the plugin with the latest data from the system.
It can process either low-level sensor data or high-level reasoning results
from other plugins, or both dependent upon plugin type.

Parameters
----------
low_level_data : list of float, optional
Raw sensor data as a list of floats, corresponding to the headers defined in the plugin.
high_level_data : dict of {str: dict of {str: any}}, optional
Processed data and reasoning results from other plugins, organized by plugin type and name.

Returns
-------
None
This method does not return any value.

Raises
------
NotImplementedError
This method must be implemented by subclasses.
"""
raise NotImplementedError

@abstractmethod
def render_reasoning(self):
def render_reasoning(self) -> Any:
"""
System should return its diagnosis
Plugin reasons with current data and provides analysis.

Returns
-------
Any
The reasoned outcome, which can be of any type.
May return None if there are no results.

Raises
------
NotImplementedError
This method must be implemented by subclasses.
"""
raise NotImplementedError
Loading