2015-02-26 09:02:31 -06:00
|
|
|
|
2015-06-24 15:58:17 -05:00
|
|
|
#include <sys/time.h>
|
|
|
|
|
2015-06-01 10:28:29 -05:00
|
|
|
#include "trick/MonteCarlo.hh"
|
2015-06-02 08:29:34 -05:00
|
|
|
#include "trick/ExecutiveException.hh"
|
2015-02-26 09:02:31 -06:00
|
|
|
|
|
|
|
/** @par Detailed Design: */
|
|
|
|
int Trick::MonteCarlo::master() {
|
|
|
|
struct timeval time_val;
|
|
|
|
gettimeofday(&time_val, NULL);
|
|
|
|
start_time = time_val.tv_sec + (double)time_val.tv_usec / 1000000;
|
|
|
|
|
|
|
|
/** <ul><li> Run the Phase 0 master initialization jobs. */
|
|
|
|
run_queue(&master_init_queue, "in master_initialization queue") ;
|
|
|
|
|
|
|
|
/** <li> If this is a dry run: */
|
|
|
|
if (dry_run) dryrun() ;
|
|
|
|
|
|
|
|
try {
|
|
|
|
/** <li> While we do not have a result for every run: */
|
|
|
|
while (num_results < actual_num_runs) {
|
|
|
|
|
|
|
|
/**
|
2015-03-23 16:03:14 -05:00
|
|
|
* <ul><li> Spawn any uninitialized slaves.
|
2015-02-26 09:02:31 -06:00
|
|
|
*/
|
|
|
|
spawn_slaves();
|
2015-03-23 16:03:14 -05:00
|
|
|
|
2015-02-26 09:02:31 -06:00
|
|
|
/** <li> Receive any finished runs. */
|
|
|
|
receive_results();
|
|
|
|
|
|
|
|
/** <li> Check to see if any dispatched units have timed out. */
|
|
|
|
check_timeouts();
|
|
|
|
|
|
|
|
/** <li> Dispatch the next run to a ready slave. </ul> */
|
|
|
|
dispatch_run_to_slave(get_next_dispatch(), get_ready_slave());
|
|
|
|
}
|
2015-06-02 08:29:34 -05:00
|
|
|
} catch (Trick::ExecutiveException & ex ) {
|
2015-02-26 09:02:31 -06:00
|
|
|
|
2015-06-02 08:29:34 -05:00
|
|
|
/* Handle exception type Trick::ExecutiveException. Set the file name and error message.
|
2015-02-26 09:02:31 -06:00
|
|
|
Return the exception return code. */
|
|
|
|
except_return = ex.ret_code ;
|
|
|
|
except_file = ex.file ;
|
|
|
|
except_message = ex.message ;
|
|
|
|
} catch (const std::exception &ex) {
|
|
|
|
except_return = -1;
|
|
|
|
if ( curr_job != NULL ) {
|
|
|
|
except_file = curr_job->name ;
|
|
|
|
} else {
|
|
|
|
except_file = "somewhere in Trick::MonteCarlo::master" ;
|
|
|
|
}
|
|
|
|
except_message = ex.what();
|
|
|
|
} catch (...) {
|
|
|
|
/* Handle unknown exceptions. Set the file name and error message to unknown. Return -1. */
|
|
|
|
except_return = -1 ;
|
|
|
|
except_file = "somewhere in Trick::MonteCarlo::master" ;
|
|
|
|
except_message = "unknown error" ;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/** <li> Shutdown. */
|
|
|
|
master_shutdown();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|