OPAL (Object Oriented Parallel Accelerator Library) 2022.1
OPAL
Public Member Functions | Protected Types | Protected Member Functions | Protected Attributes | Private Attributes | List of all members
SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t > Class Template Reference

#include <SamplePilot.h>

Inheritance diagram for SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >:
Inheritance graph
[legend]
Collaboration diagram for SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >:
Collaboration graph
[legend]

Public Member Functions

 SamplePilot (CmdArguments_t args, boost::shared_ptr< Comm_t > comm, functionDictionary_t known_expr_funcs, const DVarContainer_t &dvar, const Expressions::Named_t &obj, const std::map< std::string, std::shared_ptr< SamplingMethod > > &sampleMethods, const std::vector< std::string > &storeobjstr, const std::vector< std::string > &filesToKeep, const std::map< std::string, std::string > &userVariables)
 
virtual ~SamplePilot ()
 

Protected Types

typedef std::map< size_t, Param_tJobs_t
 keep track of requests and running jobs More...
 
typedef Jobs_t::iterator JobIter_t
 
- Protected Types inherited from Pilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >
typedef MasterNode< typename Opt_t::SolutionState_t, SolPropagationGraph_t > MasterNode_t
 
typedef std::map< size_t, std::pair< Param_t, reqVarContainer_t > > Jobs_t
 keep track of requests and running jobs More...
 
typedef Jobs_t::iterator JobIter_t
 

Protected Member Functions

virtual void setup (functionDictionary_t known_expr_funcs, const std::vector< std::string > &storeobjstr, const std::vector< std::string > &filesToKeep, const std::map< std::string, std::string > &userVariables)
 
virtual void startSampler ()
 
void startWorker (const std::vector< std::string > &storeobjstr, const std::vector< std::string > &filesToKeep, const std::map< std::string, std::string > &userVariables)
 
virtual void postPoll ()
 executed after handling (if any) new request More...
 
virtual void sendNewJobToWorker (int worker)
 
virtual bool onMessage (MPI_Status status, size_t recv_value)
 
- Protected Member Functions inherited from Pilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >
void parseInputFile (functionDictionary_t, bool isOptimizationRun)
 
virtual void startOptimizer ()
 
virtual void startWorker (const std::map< std::string, std::string > &userVariables)
 
virtual void startPilot ()
 
virtual void setupPoll ()
 executed before starting polling loop More...
 
virtual void prePoll ()
 executed before checking for new request More...
 
virtual void onStop ()
 enable implementation to react to STOP tag More...
 
virtual void postPoll ()
 executed after handling (if any) new request More...
 
virtual void sendNewJobToWorker (int worker)
 
virtual bool onMessage (MPI_Status status, size_t recv_value)
 
bool stop (bool isOpt=true)
 
void run ()
 
 Pilot (CmdArguments_t args, boost::shared_ptr< Comm_t > comm, const DVarContainer_t &dvar)
 
 Pilot (CmdArguments_t args, boost::shared_ptr< Comm_t > comm, functionDictionary_t known_expr_funcs)
 
 Pilot (CmdArguments_t args, boost::shared_ptr< Comm_t > comm, functionDictionary_t known_expr_funcs, const DVarContainer_t &dvar, const Expressions::Named_t &obj, const Expressions::Named_t &cons, std::vector< double > hypervolRef={}, bool isOptimizerRun=true, const std::map< std::string, std::string > &userVariables={})
 
virtual ~Pilot ()
 
virtual bool onMessage (MPI_Status status, size_t recv_value)=0
 
virtual void onStop ()=0
 enable implementation to react to STOP tag More...
 
virtual void setupPoll ()=0
 executed before starting polling loop More...
 
virtual void prePoll ()=0
 executed before checking for new request More...
 
virtual void postPoll ()=0
 executed after handling (if any) new request More...
 
virtual void run ()
 
 Poller (MPI_Comm comm, double delay=0.1)
 
virtual ~Poller ()
 

Protected Attributes

Jobs_t running_job_list_
 
Jobs_t request_queue_
 
- Protected Attributes inherited from Pilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >
MPI_Comm worker_comm_
 MPI communicator used for messages to/from worker. More...
 
MPI_Comm opt_comm_
 MPI communicator used for messages to/from optimizer. More...
 
MPI_Comm coworker_comm_
 MPI communicator used for messages between all pilots. More...
 
boost::shared_ptr< Comm_t > comm_
 
CmdArguments_t cmd_args_
 
int global_rank_
 
int my_rank_in_worker_comm_
 
int my_rank_in_opt_comm_
 
int num_coworkers_
 
boost::scoped_ptr< MasterNode_tmaster_node_
 
std::string input_file_
 input file for simulation with embedded optimization problem More...
 
int total_available_workers_
 
bool has_opt_converged_
 
bool continue_polling_
 
Expressions::Named_t objectives_
 objectives More...
 
Expressions::Named_t constraints_
 constraints More...
 
DVarContainer_t dvars_
 design variables More...
 
std::vector< double > hypervolRef_
 hypervolume reference point More...
 
std::vector< bool > is_worker_idle_
 
Jobs_t running_job_list_
 
Jobs_t request_queue_
 
boost::scoped_ptr< Tracejob_trace_
 
- Protected Attributes inherited from Poller
MPI_Comm comm_m
 communicator the poller listens to requests More...
 
bool is_running_
 
double last_polled_
 time of last MPI_Test More...
 
double poll_delay_
 delay in seconds between polls More...
 

Private Attributes

std::map< std::string, std::shared_ptr< SamplingMethod > > sampleMethods_m
 

Detailed Description

template<class Opt_t, class Sim_t, class SolPropagationGraph_t, class Comm_t>
class SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >

Definition at line 46 of file SamplePilot.h.

Member Typedef Documentation

◆ JobIter_t

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
typedef Jobs_t::iterator SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::JobIter_t
protected

Definition at line 96 of file SamplePilot.h.

◆ Jobs_t

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
typedef std::map<size_t, Param_t > SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::Jobs_t
protected

keep track of requests and running jobs

Definition at line 95 of file SamplePilot.h.

Constructor & Destructor Documentation

◆ SamplePilot()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::SamplePilot ( CmdArguments_t  args,
boost::shared_ptr< Comm_t >  comm,
functionDictionary_t  known_expr_funcs,
const DVarContainer_t dvar,
const Expressions::Named_t obj,
const std::map< std::string, std::shared_ptr< SamplingMethod > > &  sampleMethods,
const std::vector< std::string > &  storeobjstr,
const std::vector< std::string > &  filesToKeep,
const std::map< std::string, std::string > &  userVariables 
)
inline

Definition at line 54 of file SamplePilot.h.

◆ ~SamplePilot()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
virtual SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::~SamplePilot ( )
inlinevirtual

Definition at line 88 of file SamplePilot.h.

Member Function Documentation

◆ onMessage()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
virtual bool SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::onMessage ( MPI_Status  status,
size_t  recv_value 
)
inlineprotectedvirtual

◆ postPoll()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
virtual void SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::postPoll ( )
inlineprotectedvirtual

◆ sendNewJobToWorker()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
virtual void SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::sendNewJobToWorker ( int  worker)
inlineprotectedvirtual

◆ setup()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
virtual void SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::setup ( functionDictionary_t  known_expr_funcs,
const std::vector< std::string > &  storeobjstr,
const std::vector< std::string > &  filesToKeep,
const std::map< std::string, std::string > &  userVariables 
)
inlineprotectedvirtual

◆ startSampler()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
virtual void SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::startSampler ( )
inlineprotectedvirtual

◆ startWorker()

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
void SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::startWorker ( const std::vector< std::string > &  storeobjstr,
const std::vector< std::string > &  filesToKeep,
const std::map< std::string, std::string > &  userVariables 
)
inlineprotected

Member Data Documentation

◆ request_queue_

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
Jobs_t SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::request_queue_
protected

◆ running_job_list_

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
Jobs_t SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::running_job_list_
protected

◆ sampleMethods_m

template<class Opt_t , class Sim_t , class SolPropagationGraph_t , class Comm_t >
std::map< std::string, std::shared_ptr<SamplingMethod> > SamplePilot< Opt_t, Sim_t, SolPropagationGraph_t, Comm_t >::sampleMethods_m
private

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