ModelSpace
All Classes Namespaces Functions Variables Enumerations Pages
modelspace::VisualsModel Class Reference

Class to write out frame information via socket using a standard interface as follows: More...

#include <VisualsModel.h>

Inheritance diagram for modelspace::VisualsModel:
Collaboration diagram for modelspace::VisualsModel:

Classes

struct  Inputs
 
struct  Outputs
 
struct  Params
 

Public Member Functions

int addVisualFrame (clockwerk::Frame< double > *frame_ptr, const std::string &type="SAT")
 Function to add a simulation frame to the model as a visual output for 3D graphics.
 
void setVisualsReference (clockwerk::Frame< double > *frame_ptr)
 Function to set the reference frame for the visuals. If not set, the default is the root frame.
 
 VisualsModel (clockwerk::Executive &e, int schedule_slot=END_STEP, const std::string &m_name="visuals_model")
 
int startup ()
 Function to perform startup activities (step once at start after creation). Should not be modified in derived task.
 
virtual int step ()
 Function to step the task. This will be called every step.
 
virtual int activate ()
 Function to activate the task.
 
virtual int deactivate ()
 Function to deactivate the task.
 
void recordTiming ()
 Function to command this task to record timing information.
 
void logLevel (log_level_e new_level)
 Function to set the local model log level.
 
GraphTreeObjectparent ()
 Functions to get object's parent/children.
 
int parent (GraphTreeObject *new_parent)
 Function to assign the node's parent via pointer.
 
int parent (GraphTreeObject &new_parent)
 Function to assign the node's parent via reference.
 
std::vector< GraphTreeObject * > & children ()
 
unsigned int nChildren ()
 Getters for number of children and descendants.
 
unsigned int nDescendants ()
 
std::string name () const
 Getter and setter for object name.
 
int name (const std::string &new_name)
 
int rank ()
 Getter for the object rank.
 
virtual int type ()
 Function to indicate type – -1 by default unless implemented downstream.
 
bool loggable ()
 Getter for object logability flag – note no setter because should only be set by this or a derived class in its definition.
 
std::string address ()
 Getter for object's string address.
 
std::vector< std::string > search (const std::string &address)
 Function to search through the graph tree by string address.
 
GraphTreeObjectgetByAddress (const std::string &address)
 Function to get an object from the graph tree by string address.
 
void dump (bool recursive=false)
 Function to dump the graph node, optionally including descendents.
 
void graphNodeInfo ()
 Function to return all info associated with a given graph node.
 
void recurseGraphNodeInfo (unsigned int counter)
 Function to recurse through graph tree and print all node info.
 
virtual int header (void *logger)
 Function to pass headers for this object to the logger.
 
virtual std::vector< std::string > header_info () const
 
void findLoggable (std::vector< GraphTreeObject * > &matches)
 Function to find all loggable parameters in this node and its children.
 
virtual int log (void *logger)
 Function to log data to a logger.
 
void lock (bool recursive=true)
 Function to lock the graph tree object and its children to changes.
 
void unlock (bool recursive=true)
 Function to unlock the graph tree and its children for changes.
 
bool locked ()
 Function to return whether graph tree object is locked.
 

Public Attributes

Params params = Params(this, "params")
 
Inputs inputs = Inputs(this, "inputs")
 
Outputs outputs = Outputs(this, "outputs")
 
DataIO< bool > active = DataIO<bool>(this, "active", true)
 The active flag for the task – set to true by default.
 
DataIO< int > schedule_slot = DataIO<int>(this, "schedule_slot", 0)
 The schedule slot this task will step in – set to 0 by default.
 
DataIO< Time > entry_time = DataIO<Time>(this, "entry_time", Time())
 Time of entry (per wallClockTimer) of the last step of this task.
 
DataIO< Time > exit_time = DataIO<Time>(this, "exit_time", Time())
 Time of exit (per wallClockTimer) of the last step of this task.
 

Protected Member Functions

int start ()
 Function to perform task startup activities (step once after creation)
 
int execute ()
 Function to execute the task. All math and calculations should be here.
 
void _writeFrameRootPosition (clockwerk::Frame< double > *frame_ptr, std::string &str)
 Function to write the frame root position in the appropriate format to str.
 
void _writeFrameRootAttitude (clockwerk::Frame< double > *frame_ptr, std::string &str)
 Function to write the frame root attitude in the appropriate format to str.
 
void _writeFullFrameNameState (clockwerk::Frame< double > *frame_ptr, const std::string &type, std::string &str)
 Function to write the full frame state in json format to string.
 
int rangeCheck (double min, double max, DataIO< double > signal)
 Overloaded function to check range on a parameter.
 
int rangeCheck (float min, float max, DataIO< float > signal)
 
int rangeCheck (int min, int max, DataIO< int > signal)
 
void recalculateDescendants ()
 Function to recursively re-calculate the number of descendants of a given node on the tree.
 
void recalculateRank ()
 Function to recursively re-calculate the rank of a given node on the tree.
 
std::vector< std::string > decomposeAddress (std::string address)
 Function to decompose a string into a series of substrings via indexing.
 
void findMatches (const std::vector< std::string > &subaddresses, const unsigned int &num_subaddresses, unsigned int index, bool match_found, std::vector< GraphTreeObject * > &matches)
 Function to find all addresses mathcing the set of substrings @parem subaddresses A vector of subaddresses to match.
 
std::vector< GraphTreeObject * > searchNodes (const std::string &address)
 Function to search through the graph tree by string address.
 
int addChild (GraphTreeObject *child)
 Function to add a child to the graph tree object.
 
int removeChild (GraphTreeObject *child)
 Function to remove a child from the graph node's children.
 

Protected Attributes

int _client_socket = -9999
 
clockwerk::Frame< double > * _reference_frame_ptr = nullptr
 
std::vector< clockwerk::Frame< double > * > _tracked_frame_ptrs
 
std::vector< std::string > _types
 
std::string _pos_str
 
std::string _att_str
 
std::string _full_frame_str
 
std::string _full_str
 
clockwerk::CartesianVector< double, 3 > _tmp_vec
 
clockwerk::Quaternion< double > _tmp_quat
 
clockwerk::DCM< double > _tmp_dcm
 
clockwerk::Time _step_size
 
clockwerk::Time _next_write
 
log_level_e _local_log_level = NONE
 Our local log level – allows a higher log level locally than the overall system.
 
int _error = 0
 Simple variable to track error in task.
 
bool _record_timing = false
 Variable to enable or disable timing.
 
Executive * exc = nullptr
 Pointer to the executive object.
 
GraphTreeObject_parent = nullptr
 Pointer to the object's parent – should be null if the object is the root. Is set to null by default.
 
std::vector< GraphTreeObject * > _children
 Pointers to the object's children – automatically set to an empty vector, and can be increased to any size.
 
std::string _name = DEFAULT_NAME
 String name for object.
 
uint16_t _num_descendants = 0
 Total number of descendants (includes children of children) of the tree, again not including the tree itself.
 
uint8_t _num_children = 0
 Number of direct children of the tree (not including the tree itself)
 
uint8_t _rank = 0
 Rank for how far down on the graph tree the object is – starts at zero and maxes out at 256 via variable size.
 
uint8_t _graph_tree_type = BASE_GRAPH_TREE
 Variable to store graph tree object type.
 
bool _locked = false
 Variable to lock the graph tree object and prevent structural updates.
 
bool _loggable = false
 Variable to indicate whether the selected object is loggable. Set to false by default.
 

Detailed Description

Class to write out frame information via socket using a standard interface as follows:

INTERFACE DEFINITION Data is written to the interface in JSON format with any number of named objects, which correspond to the frame names, and expected fields (x,y,z)pos and (x,y,z,w)rot for each named object. Quaternions are written in scalar-last format.

Full example: {'Mickey':[]'xpos':

,'ypos':

,'zpos':

,'xrot':

,'yrot':

,'zrot':

,'wrot':

]}

This interface is designed to communicate frame state information in a frame-agnostic way across a socket interface. Every step, based on real time timing, this model will broadcast frame state information across a socket via the interface definition above.

Alex Reynolds alex..nosp@m.reyn.nosp@m.olds@.nosp@m.attx.nosp@m..tech

Member Function Documentation

◆ _writeFrameRootAttitude()

void modelspace::VisualsModel::_writeFrameRootAttitude ( clockwerk::Frame< double > *  frame_ptr,
std::string &  str 
)
protected

Function to write the frame root attitude in the appropriate format to str.

Parameters
frame_ptrFrame to write attitude of
strImplicit return of state string

◆ _writeFrameRootPosition()

void modelspace::VisualsModel::_writeFrameRootPosition ( clockwerk::Frame< double > *  frame_ptr,
std::string &  str 
)
protected

Function to write the frame root position in the appropriate format to str.

Parameters
frame_ptrFrame to write position of
strImplicit return of state string

◆ _writeFullFrameNameState()

void modelspace::VisualsModel::_writeFullFrameNameState ( clockwerk::Frame< double > *  frame_ptr,
const std::string &  type,
std::string &  str 
)
protected

Function to write the full frame state in json format to string.

Parameters
frame_ptrFrame to write state of
typeThe type of frame
strImplicit return of state string

◆ activate()

virtual int clockwerk::Task::activate ( )
inlinevirtualinherited

Function to activate the task.

Returns
Error code corresponding to success/failure
Note
This is an inherited function that should be overwritten in inherited task class, if implemented. If it is not implemented in the inherited class, step() function will do nothing

◆ addChild()

int clockwerk::GraphTreeObject::addChild ( GraphTreeObject child)
protectedinherited

Function to add a child to the graph tree object.

Parameters
childA pointer to the graph tree object to add to the tree
Returns
An error code corresponding to success/failure

◆ address()

std::string clockwerk::GraphTreeObject::address ( )
inherited

Getter for object's string address.

Returns
Returns the string address for the object

◆ addVisualFrame()

int modelspace::VisualsModel::addVisualFrame ( clockwerk::Frame< double > *  frame_ptr,
const std::string &  type = "SAT" 
)

Function to add a simulation frame to the model as a visual output for 3D graphics.

Parameters
frame_ptrThe frame to be added as a visual output
typeThe type of object being output. Valid choices are: [SAT]

◆ deactivate()

virtual int clockwerk::Task::deactivate ( )
inlinevirtualinherited

Function to deactivate the task.

Returns
Error code corresponding to success/failure
Note
This is an inherited function that should be overwritten in inherited task class, if implemented. If it is not implemented in the inherited class, step() function will do nothing

◆ decomposeAddress()

std::vector< std::string > clockwerk::GraphTreeObject::decomposeAddress ( std::string  address)
protectedinherited

Function to decompose a string into a series of substrings via indexing.

Parameters
addressThe address to be decomposed
Returns
A vector of strings containing each delimeter-separated substring

◆ dump()

void clockwerk::GraphTreeObject::dump ( bool  recursive = false)
inherited

Function to dump the graph node, optionally including descendents.

Parameters
recursiveParameter indicating whether to dump only one node (default/false) or the entire tree (true)
Note
Recursive dumps the whole tree... be careful what you wish for

◆ execute()

int modelspace::VisualsModel::execute ( )
protectedvirtual

Function to execute the task. All math and calculations should be here.

Returns
Error code corresponding to success/failure
Note
This is an inherited function that should be overwritten in inherited task class, if implemented. If it is not implemented in the inherited class, it will do nothing.

Reimplemented from clockwerk::Task.

◆ findLoggable()

void clockwerk::GraphTreeObject::findLoggable ( std::vector< GraphTreeObject * > &  matches)
inherited

Function to find all loggable parameters in this node and its children.

Parameters
matchesExpandable vector to hold all matches in the tree

◆ findMatches()

void clockwerk::GraphTreeObject::findMatches ( const std::vector< std::string > &  subaddresses,
const unsigned int num_subaddresses,
unsigned int  index,
bool  match_found,
std::vector< GraphTreeObject * > &  matches 
)
protectedinherited

Function to find all addresses mathcing the set of substrings @parem subaddresses A vector of subaddresses to match.

Parameters
num_subaddressesThe number of subaddresses to match
indexThe index of subaddresses to search in
match_foundVariable indicating whether a match was found higher in the tree
matchesImplicit return of all matches to the specified address

◆ getByAddress()

GraphTreeObject * clockwerk::GraphTreeObject::getByAddress ( const std::string &  address)
inherited

Function to get an object from the graph tree by string address.

Parameters
addressThe exact string address to access the variable with
Returns
Pointer to the graph tree object at the address, or nullptr if address is not valid or returns

◆ header()

◆ header_info()

virtual std::vector< std::string > clockwerk::GraphTreeObject::header_info ( ) const
inlinevirtualinherited

Reimplemented in clockwerk::Time.

◆ lock()

void clockwerk::GraphTreeObject::lock ( bool  recursive = true)
inherited

Function to lock the graph tree object and its children to changes.

Parameters
recursiveFlag to indicate whether lock should be recursive

◆ log()

◆ logLevel()

void clockwerk::Task::logLevel ( log_level_e  new_level)
inlineinherited

Function to set the local model log level.

Parameters
new_levelThe new level to set logging to

◆ parent() [1/2]

int clockwerk::GraphTreeObject::parent ( GraphTreeObject new_parent)
inherited

Function to assign the node's parent via reference.

Parameters
new_parentThe new parent to assign the node to
Returns
Error code corresponding to success/failure
Note
This function is the only method to ADD or REMOVE a node from a tree. To add, pass the address to a GraphTreeObject to this function. To remove, pass a nullptr. Note that parents for objects on an existing tree can be reassigned

◆ parent() [2/2]

int clockwerk::GraphTreeObject::parent ( GraphTreeObject new_parent)
inherited

Function to assign the node's parent via pointer.

Parameters
new_parentThe new parent to assign the node to
Returns
Error code corresponding to success/failure
Note
This function is the only method to ADD or REMOVE a node from a tree. To add, pass the address to a GraphTreeObject to this function. To remove, pass a nullptr. Note that parents for objects on an existing tree can be reassigned

◆ rangeCheck()

int clockwerk::Task::rangeCheck ( double  min,
double  max,
DataIO< double signal 
)
protectedinherited

Overloaded function to check range on a parameter.


General utility functions for models

Parameters
minThe minimum acceptable value
maxThe maximum acceptable value
signalThe signal to be evaluated
Returns
Error code corresponding to value validity

◆ recurseGraphNodeInfo()

void clockwerk::GraphTreeObject::recurseGraphNodeInfo ( unsigned int  counter)
inherited

Function to recurse through graph tree and print all node info.

Returns
String containing all recursive graph node information in tab cascade format

◆ removeChild()

int clockwerk::GraphTreeObject::removeChild ( GraphTreeObject child)
protectedinherited

Function to remove a child from the graph node's children.

Parameters
childThe child to remove
Returns
Success/fail error code based on whether the child is present

◆ search()

std::vector< std::string > clockwerk::GraphTreeObject::search ( const std::string &  address)
inherited

Function to search through the graph tree by string address.

Parameters
address`The address or address chunk to search for
Returns
A vector of string addresses meeting the criteria specified by address

◆ searchNodes()

std::vector< GraphTreeObject * > clockwerk::GraphTreeObject::searchNodes ( const std::string &  address)
protectedinherited

Function to search through the graph tree by string address.

Parameters
address`The address or address chunk to search for
Returns
A vector of objects addresses meeting the criteria specified by address

◆ setVisualsReference()

void modelspace::VisualsModel::setVisualsReference ( clockwerk::Frame< double > *  frame_ptr)

Function to set the reference frame for the visuals. If not set, the default is the root frame.

Parameters
frame_ptrPointer to the reference frame for the visuals

◆ start()

int modelspace::VisualsModel::start ( )
protectedvirtual

Function to perform task startup activities (step once after creation)

Returns
Error code corresponding to success/failure
Note
This is an inherited function that should be overwritten in inherited task class, if implemented. If it is not implemented in the inherited class, it will do nothing.

Reimplemented from clockwerk::Task.

◆ startup()

int clockwerk::Task::startup ( )
inherited

Function to perform startup activities (step once at start after creation). Should not be modified in derived task.

Returns
Error code corresponding to success/failure
Note
This is the master task function, which calls start internally and performs other tasks before and after

◆ step()

int clockwerk::Task::step ( )
virtualinherited

Function to step the task. This will be called every step.

Returns
Error code corresponding to success/failure
Note
Inherited in derived monitor/event for special cases but should not be implemented directly in inherited classes

Reimplemented in clockwerk::Monitor, and clockwerk::Event.

◆ type()

virtual int clockwerk::GraphTreeObject::type ( )
inlinevirtualinherited

Function to indicate type – -1 by default unless implemented downstream.

Returns
Int indicating frame type – unimplemented always -1

◆ unlock()

void clockwerk::GraphTreeObject::unlock ( bool  recursive = true)
inherited

Function to unlock the graph tree and its children for changes.

Parameters
recursiveFlag to indicate whether unlock should be recursive

The documentation for this class was generated from the following files: