mirror of
https://github.com/nasa/trick.git
synced 2025-01-20 11:39:13 +00:00
60 lines
1.9 KiB
C++
60 lines
1.9 KiB
C++
|
|
#ifndef _INTEG_LOOP_SIMOBJECT_
|
|
#define _INTEG_LOOP_SIMOBJECT_
|
|
|
|
#include "sim_services/Integrator/include/IntegLoopScheduler.hh"
|
|
#include "sim_services/Integrator/include/Integrator.hh"
|
|
#include "sim_services/SimObject/include/SimObject.hh"
|
|
#include "sim_services/SimObject/include/JobData.hh"
|
|
|
|
#ifdef SWIG
|
|
// SWIG macros are not normally run on classes in sim_services. We can add the the processed code manually
|
|
%trick_swig_class_typemap(IntegLoopSimObject, IntegLoopSimObject)
|
|
#endif
|
|
|
|
class IntegLoopSimObject : public Trick::SimObject {
|
|
|
|
public:
|
|
Trick::IntegLoopScheduler integ_sched ;
|
|
|
|
IntegLoopSimObject() : integ_sched(0.01, this) {
|
|
add_jobs(0.01, 0) ;
|
|
}
|
|
|
|
IntegLoopSimObject(double in_cycle, unsigned int child, Trick::SimObject* s_obj, ... ) : integ_sched(in_cycle, this) {
|
|
va_list ap ;
|
|
Trick::SimObject* next_sobj;
|
|
|
|
va_start(ap, s_obj);
|
|
next_sobj = s_obj;
|
|
while (next_sobj != (Trick::SimObject*)NULL) {
|
|
integ_sched.add_sim_object( *next_sobj );
|
|
next_sobj = va_arg(ap, Trick::SimObject*);
|
|
};
|
|
|
|
add_jobs(in_cycle, child) ;
|
|
}
|
|
|
|
// Adds common set of jobs for all constructors.
|
|
void add_jobs(double in_cycle, unsigned int child) ;
|
|
|
|
virtual int call_function( Trick::JobData * curr_job ) ;
|
|
virtual double call_function_double( Trick::JobData * curr_job ) ;
|
|
|
|
|
|
Trick::Integrator * getIntegrator( Integrator_type Alg, unsigned int State_size ) {
|
|
return integ_sched.getIntegrator(Alg , State_size) ;
|
|
}
|
|
|
|
int set_integ_cycle( double in_cycle ) {
|
|
return integ_sched.set_integ_cycle(in_cycle) ;
|
|
}
|
|
} ;
|
|
|
|
#ifdef SWIG
|
|
// SWIG macros are not normally run on classes in sim_services. We can add the the processed code manually
|
|
%trick_cast_as(IntegLoopSimObject, IntegLoopSimObject)
|
|
#endif
|
|
|
|
#endif
|