mirror of
https://github.com/nasa/trick.git
synced 2025-01-25 13:49:51 +00:00
221 lines
8.7 KiB
C++
221 lines
8.7 KiB
C++
|
/*******************************************************************************
|
||
|
* *
|
||
|
* Trick Simulation Environment Software *
|
||
|
* *
|
||
|
* Copyright (c) 1996,1997 LinCom Corporation, Houston, TX *
|
||
|
* All rights reserved. *
|
||
|
* *
|
||
|
* Copyrighted by LinCom Corporation and proprietary to it. Any unauthorized *
|
||
|
* use of Trick Software including source code, object code or executables is *
|
||
|
* strictly prohibited and LinCom assumes no liability for such actions or *
|
||
|
* results thereof. *
|
||
|
* *
|
||
|
* Trick Software has been developed under NASA Government Contracts and *
|
||
|
* access to it may be granted for Government work by the following contact: *
|
||
|
* *
|
||
|
* Contact: Michael Red, Branch Chief *
|
||
|
* Simulation and Graphics Branch *
|
||
|
* Software, Robotics, & Simulation Division *
|
||
|
* NASA, Johnson Space Center, Houston, TX *
|
||
|
* *
|
||
|
*******************************************************************************/
|
||
|
|
||
|
/*
|
||
|
PURPOSE:
|
||
|
( FrameLog base class)
|
||
|
PROGRAMMERS:
|
||
|
(((Alex Lin) (NASA) (2009)))
|
||
|
*/
|
||
|
|
||
|
/*
|
||
|
* $Id: FrameLog.hh 3763 2014-12-04 19:51:50Z alin $
|
||
|
*/
|
||
|
|
||
|
#ifndef _FRAMELOGOBJECT_HH_
|
||
|
#define _FRAMELOGOBJECT_HH_
|
||
|
|
||
|
#include <vector>
|
||
|
#include "sim_services/FrameLog/include/FrameDataRecordGroup.hh"
|
||
|
#include "sim_services/MemoryManager/include/attributes.h"
|
||
|
#include "sim_services/SimObject/include/JobData.hh"
|
||
|
|
||
|
namespace Trick {
|
||
|
|
||
|
/** Data to save for each timeline sample.\n */
|
||
|
struct timeline_t {
|
||
|
bool trick_job;
|
||
|
double id;
|
||
|
long long start;
|
||
|
long long stop;
|
||
|
} ;
|
||
|
|
||
|
/**
|
||
|
This class provides (optional) logging of Trick frame timing and job performance statistics.
|
||
|
@author Danny Strauss
|
||
|
*/
|
||
|
|
||
|
class FrameLog {
|
||
|
|
||
|
public:
|
||
|
|
||
|
/** Enable real-time frame logging.\n */
|
||
|
bool frame_log_flag ; /**< trick_io(*io) trick_units(--) */
|
||
|
|
||
|
/** Data recording groups for logging user jobs.\n */
|
||
|
std::vector< Trick::FrameDataRecordGroup *> drg_users ; /**< trick_io(*io) trick_units(--) */
|
||
|
/** Data recording group for logging trick jobs.\n */
|
||
|
Trick::FrameDataRecordGroup * drg_trick; /**< trick_io(*io) trick_units(--) */
|
||
|
/** Data recording group for logging frame/overrun time.\n trick_units(--) */
|
||
|
Trick::FrameDataRecordGroup * drg_frame; /**< trick_io(*io) trick_units(--) */
|
||
|
|
||
|
/** Cyclic jobs timeline to log, dimensioned as [num_threads][tl_max_samples].\n */
|
||
|
Trick::timeline_t **timeline; /**< trick_io(**) */
|
||
|
/** Non-Cyclic jobs timeline to log, dimensioned as [num_threads][tl_max_samples].\n */
|
||
|
Trick::timeline_t **timeline_other; /**< trick_io(**) */
|
||
|
|
||
|
/** Number of threads in this sim.\n */
|
||
|
int num_threads; /**< trick_io(**) */
|
||
|
/** The maximum number of job samples we can timeline (user settable).\n */
|
||
|
int tl_max_samples; /**< trick_io(**) */
|
||
|
/** Count how many Cyclic jobs are in the timeline per thread.\n */
|
||
|
int *tl_count; /**< trick_io(**) */
|
||
|
/** Count how many Non-Cyclic jobs are in the timeline per thread.\n */
|
||
|
int *tl_other_count; /**< trick_io(**) */
|
||
|
|
||
|
/** True when logging of initialization jobs started.\n */
|
||
|
bool log_init_start; /**< trick_io(**) */
|
||
|
/** True when logging of initialization jobs is done.\n */
|
||
|
bool log_init_end; /**< trick_io(**) */
|
||
|
/** For creating log_timeline logging file.\n */
|
||
|
FILE *fp_time_main; /**< trick_io(**) */
|
||
|
/** For creating log_timeline_other logging file.\n */
|
||
|
FILE *fp_time_other; /**< trick_io(**) */
|
||
|
/** Fake attributes to use for setting up data recording.\n */
|
||
|
ATTRIBUTES time_value_attr ; /**< trick_io(**) */
|
||
|
|
||
|
/** Save the name of the trick messaging sim object.\n */
|
||
|
std::string msg_sim_object_name; /**< trick_io(**) */
|
||
|
/** Save the name of the trick data recording sim object.\n */
|
||
|
std::string dr_sim_object_name; /**< trick_io(**) */
|
||
|
/** Save the name of the trick real-time sync sim object.\n */
|
||
|
std::string rt_sim_object_name; /**< trick_io(**) */
|
||
|
/** Save the name of the trick master/slave sim object.\n */
|
||
|
std::string ms_sim_object_name; /**< trick_io(**) */
|
||
|
|
||
|
/**
|
||
|
@brief Constructor.
|
||
|
*/
|
||
|
FrameLog() ;
|
||
|
|
||
|
/**
|
||
|
@brief Destructor.
|
||
|
*/
|
||
|
~FrameLog() ;
|
||
|
|
||
|
/**
|
||
|
@brief Instrumentation job to save job timeline start time.
|
||
|
@param curr_job - pointer to self (current frame_clock_start job)
|
||
|
*/
|
||
|
int frame_clock_start(Trick::JobData * curr_job) ;
|
||
|
|
||
|
/**
|
||
|
@brief Instrumentation job to save job timeline stop time and frame time.
|
||
|
@param curr_job - pointer to self (current frame_clock_stop job)
|
||
|
*/
|
||
|
int frame_clock_stop(Trick::JobData * curr_job) ;
|
||
|
|
||
|
/**
|
||
|
@brief @userdesc Command to turn on frame logs.
|
||
|
@par Python Usage:
|
||
|
@code trick.frame_log_on() @endcode
|
||
|
@return always 0
|
||
|
*/
|
||
|
int framelog_on() ;
|
||
|
|
||
|
/**
|
||
|
@brief @userdesc Command to turn off frame logs.
|
||
|
@par Python Usage:
|
||
|
@code trick.frame_log_off() @endcode
|
||
|
@return always 0
|
||
|
*/
|
||
|
int framelog_off() ;
|
||
|
|
||
|
/**
|
||
|
@brief @userdesc Allocates and partially sets up frame logging.
|
||
|
*/
|
||
|
void default_data() ;
|
||
|
|
||
|
/**
|
||
|
@brief Routine to call all create routines below for the DP directory and files.
|
||
|
*/
|
||
|
int create_DP_files() ;
|
||
|
|
||
|
/**
|
||
|
@brief @userdesc Command to set the maximum number of job timeline samples to be taken (default = 100000).
|
||
|
@par Python Usage:
|
||
|
@code trick.frame_log_set_max_samples(<num>) @endcode
|
||
|
@param num - the max number of samples
|
||
|
@return always 0
|
||
|
*/
|
||
|
int set_max_samples(int num) ;
|
||
|
|
||
|
/**
|
||
|
@brief Clears data_record informtion realted to frame logging durning the checkpoint reload.
|
||
|
@return always 0
|
||
|
*/
|
||
|
int clear_data_record_info() ;
|
||
|
|
||
|
/**
|
||
|
@brief Restores the frame log state upon checkpoint restart
|
||
|
@return always 0
|
||
|
*/
|
||
|
int restart() ;
|
||
|
|
||
|
/**
|
||
|
@brief Shutdown job that writes the job timeline data to disk and closes log files.
|
||
|
@return always 0
|
||
|
*/
|
||
|
int shutdown() ;
|
||
|
|
||
|
private:
|
||
|
std::vector<std::string> trick_jobs; // -- vector containing all trick job names
|
||
|
std::vector<std::string> user_jobs; // -- vector containing all user job names
|
||
|
|
||
|
std::string DP_dir; // ** name of DP_Product directory
|
||
|
|
||
|
void allocate_recording_groups() ;
|
||
|
|
||
|
void add_recording_vars_for_jobs() ;
|
||
|
void add_recording_vars_for_frame() ;
|
||
|
|
||
|
void add_recording_groups_to_sim() ;
|
||
|
void remove_recording_groups_from_sim() ;
|
||
|
|
||
|
void enable_recording_groups() ;
|
||
|
void disable_recording_groups() ;
|
||
|
void init_recording_groups() ;
|
||
|
|
||
|
void add_instrument_jobs() ;
|
||
|
void remove_instrument_jobs() ;
|
||
|
|
||
|
/**
|
||
|
@brief Create the DP_Product directory where all DP files will be stored.
|
||
|
*/
|
||
|
int create_DP_Product_dir() ;
|
||
|
|
||
|
/**
|
||
|
@brief Create the DP files to display trick and user job execution times.
|
||
|
*/
|
||
|
int create_DP_job_files();
|
||
|
|
||
|
/**
|
||
|
@brief Create the DP files to display job timelines.
|
||
|
*/
|
||
|
int create_DP_timeline_files();
|
||
|
|
||
|
} ;
|
||
|
|
||
|
} ;
|
||
|
|
||
|
#endif
|