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

Class to manage time for the simulation object. More...

#include <SimTimeManager.h>

Inheritance diagram for modelspace::SimTimeManager:
Collaboration diagram for modelspace::SimTimeManager:

Public Member Functions

 SimTimeManager ()
 Base constructor – time manager should initialize to zeros and then be set.
 
virtual void stepTime (const clockwerk::Time &step)
 Function to increment all times.
 
virtual clockwerk::Time wallClockTimer () override
 Function to return the wall clock time since run start.
 
double str2tdb (const std::string &time_input)
 
std::string tdbTime ()
 Function to return the TDB time as a string.
 
std::string utcTime ()
 Function to return the TDB time as a string.
 
std::string jdTime ()
 Function to return the Julian date as a string.
 
std::string gpsTime ()
 Function to return the GPS time as a string.
 
void setTime (const std::string &time_input=DEFAULT_SIMULATION_TIME)
 Function to set time by string input.
 
void updateStep (const Time &step)
 Function to increment step start and end time.
 
Time operator() ()
 Function to return base time by call for easy access.
 
bool wallClockIsStarted ()
 Function to return whether the wall clock timer is started.
 
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

clockwerk::DataIO< clockwerk::Timetdb_time = clockwerk::DataIO<clockwerk::Time>(this, "tdb_time")
 Incrementing clocks – these are standard clocks that begin on start and continue incrementing as the scheduler steps forward.
 
DataIO< Time > step_start_time = DataIO<Time>(this, "step_start_time")
 
DataIO< Time > step_end_time = DataIO<Time>(this, "step_end_time")
 This is the time at the end of a given scheduler step.
 
DataIO< Time > base_time = DataIO<Time>(this, "base_time")
 This is the exact current time as the scheduler steps forward.
 

Protected Member Functions

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

clockwerk::Time_tdb_ptr
 Pointers to our time objects.
 
clockwerk::Time _diff
 
struct timespec _tmp
 
Time * _start_step_ptr
 Pointers to our time objects.
 
Time * _end_step_ptr
 
Time * _base_time_ptr
 
bool _started = false
 
Time _start
 
Time _now
 
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 manage time for the simulation object.

This class uses the SPICE module to manage time within the simulation. Internally it steps the sim time and the spice ephemeris time (TDB time), which is used to cast UTC and JD time scales. All are published on the time manager.

Time representations are based on the clockwerk Time class.

Member Function Documentation

◆ 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

◆ 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

◆ 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

◆ gpsTime()

std::string modelspace::SimTimeManager::gpsTime ( )

Function to return the GPS time as a string.

Returns
GPS time in the format

◆ header()

◆ header_info()

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

Reimplemented in clockwerk::Time.

◆ jdTime()

std::string modelspace::SimTimeManager::jdTime ( )

Function to return the Julian date as a string.

Returns
Julian date as a days since the JD epoch as JDUTC

◆ 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()

◆ operator()()

Time clockwerk::TimeManager::operator() ( )
inlineinherited

Function to return base time by call for easy access.

Note
Returns the base time because it is the most default time

◆ 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

◆ 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

◆ setTime()

void modelspace::SimTimeManager::setTime ( const std::string &  time_input = DEFAULT_SIMULATION_TIME)

Function to set time by string input.


Methods to set time The following functions allow users to set time based on string

input.

valid inputs are any input which is accepted by the SPICE function STR2ET. More info here: https://naif.jpl.nasa.gov/pub/naif/toolkit_docs/FORTRAN/spicelib/str2et.html This value defaults to 2023 September 26, 12:00:00 MDT

◆ stepTime()

void modelspace::SimTimeManager::stepTime ( const clockwerk::Time step)
virtual

Function to increment all times.

Parameters
stepTime object to step by

◆ str2tdb()

double modelspace::SimTimeManager::str2tdb ( const std::string &  time_input)

Time converters

The following functions convert time between representations

◆ tdbTime()

std::string modelspace::SimTimeManager::tdbTime ( )
inline

Function to return the TDB time as a string.


Useful Time Representations The following functions return time as any one of a number of

useful representations such as UTC and GPS time

Returns
TDB time as seconds since J2000

◆ 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

◆ updateStep()

void clockwerk::TimeManager::updateStep ( const Time step)
inherited

Function to increment step start and end time.

Parameters
stepTime object to step by

◆ utcTime()

std::string modelspace::SimTimeManager::utcTime ( )

Function to return the TDB time as a string.

Returns
UTC time in the format 'YYYY MMM DD HH:MM:SS'

◆ wallClockIsStarted()

bool clockwerk::TimeManager::wallClockIsStarted ( )
inlineinherited

Function to return whether the wall clock timer is started.

Returns
Whether the wall clock timer is started

◆ wallClockTimer()

clockwerk::Time modelspace::SimTimeManager::wallClockTimer ( )
overridevirtual

Function to return the wall clock time since run start.


Other time functions – These functions return other forms of time

Returns
A time object containing the time since run start

Reimplemented from clockwerk::TimeManager.

Member Data Documentation

◆ step_start_time

DataIO<Time> clockwerk::TimeManager::step_start_time = DataIO<Time>(this, "step_start_time")
inherited

Incrementing clocks – these are standard clocks that begin on start and continue incrementing as the scheduler steps forward

in time.

This is the time at the start of a given scheduler step

◆ tdb_time

clockwerk::DataIO<clockwerk::Time> modelspace::SimTimeManager::tdb_time = clockwerk::DataIO<clockwerk::Time>(this, "tdb_time")

Incrementing clocks – these are standard clocks that begin on start and continue incrementing as the scheduler steps forward.

in time.

TDB time is represented as seconds relative to the J2000 epoch, which is January 1, 2000, at 12:00 TT (Terrestrial Time). This is also known as "ephemeris time"


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