AmpTools
LikelihoodManagerMPI.h
Go to the documentation of this file.
1
#if !defined(LIKELIHOODMANAGERMPI)
2
#define LIKELIHOODMANAGERMPI
3
4
//******************************************************************************
5
// This file is part of AmpTools, a package for performing Amplitude Analysis
6
//
7
// Copyright Trustees of Indiana University 2010, all rights reserved
8
//
9
// This software written by Matthew Shepherd, Ryan Mitchell, and
10
// Hrayr Matevosyan at Indiana University, Bloomington
11
//
12
// Redistribution and use in source and binary forms, with or without
13
// modification, are permitted provided that the following conditions
14
// are met:
15
// 1. Redistributions of source code must retain the above copyright
16
// notice and author attribution, this list of conditions and the
17
// following disclaimer.
18
// 2. Redistributions in binary form must reproduce the above copyright
19
// notice and author attribution, this list of conditions and the
20
// following disclaimer in the documentation and/or other materials
21
// provided with the distribution.
22
// 3. Neither the name of the University nor the names of its contributors
23
// may be used to endorse or promote products derived from this software
24
// without specific prior written permission.
25
//
26
// Creation of derivative forms of this software for commercial
27
// utilization may be subject to restriction; written permission may be
28
// obtained from the Trustees of Indiana University.
29
//
30
// INDIANA UNIVERSITY AND THE AUTHORS MAKE NO REPRESENTATIONS OR WARRANTIES,
31
// EXPRESS OR IMPLIED. By way of example, but not limitation, INDIANA
32
// UNIVERSITY MAKES NO REPRESENTATIONS OR WARRANTIES OF MERCANTABILITY OR
33
// FITNESS FOR ANY PARTICULAR PURPOSE OR THAT THE USE OF THIS SOFTWARE OR
34
// DOCUMENTATION WILL NOT INFRINGE ANY PATENTS, COPYRIGHTS, TRADEMARKS,
35
// OR OTHER RIGHTS. Neither Indiana University nor the authors shall be
36
// held liable for any liability with respect to any claim by the user or
37
// any other party arising from use of the program.
38
//******************************************************************************
39
40
#include <map>
41
42
class
LikelihoodCalculatorMPI
;
43
44
using namespace
std
;
45
46
class
LikelihoodManagerMPI
47
{
48
49
public
:
50
51
enum
FitCommand
{
kComputeLikelihood
,
52
kComputeIntegrals
,
53
kUpdateParameters
,
54
kUpdateAmpParameter
,
55
kExit };
56
57
LikelihoodManagerMPI
(){};
58
59
static
void
registerCalculator(
int
id
,
LikelihoodCalculatorMPI
* calc );
60
61
static
void
deliverLikelihood();
62
63
static
void
broadcastToFirst(
FitCommand
command );
64
65
private
:
66
67
static
void
setupMPI();
68
69
static
bool
m_mpiSetup;
70
static
bool
m_isMaster;
71
static
int
m_numProc;
72
73
static
map< int, LikelihoodCalculatorMPI* > m_calcMap;
74
};
75
76
#endif
LikelihoodManagerMPI::LikelihoodManagerMPI
LikelihoodManagerMPI()
Definition:
LikelihoodManagerMPI.h:57
LikelihoodManagerMPI
Definition:
LikelihoodManagerMPI.h:46
LikelihoodManagerMPI::FitCommand
FitCommand
Definition:
LikelihoodManagerMPI.h:51
std
LikelihoodCalculatorMPI
Definition:
LikelihoodCalculatorMPI.h:57
LikelihoodManagerMPI::kComputeLikelihood
Definition:
LikelihoodManagerMPI.h:51
LikelihoodManagerMPI::kUpdateParameters
Definition:
LikelihoodManagerMPI.h:53
LikelihoodManagerMPI::kComputeIntegrals
Definition:
LikelihoodManagerMPI.h:52
LikelihoodManagerMPI::kUpdateAmpParameter
Definition:
LikelihoodManagerMPI.h:54
AmpTools
IUAmpToolsMPI
LikelihoodManagerMPI.h
Generated on Sun May 7 2017 06:12:49 for AmpTools by
1.8.13