forked from GooFit/GooFit
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDataSet.hh
50 lines (37 loc) · 1.3 KB
/
DataSet.hh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#ifndef DATASET_HH
#define DATASET_HH
#include "Variable.hh"
#include "GlobalCudaDefines.hh"
#include <vector>
#include <set>
#include <string>
typedef std::vector<Variable*>::const_iterator varConstIt;
typedef std::vector<Variable*>::const_reverse_iterator varConstRIt;
class DataSet {
public:
DataSet (Variable* var, string n = "");
DataSet (std::vector<Variable*>& vars, string n = "");
DataSet (std::set<Variable*>& vars, string n = "");
~DataSet ();
void addEvent ();
void addEvent (fptype val);
virtual void addEventVector (std::vector<fptype>& vals, fptype weight = 1) = 0;
void addWeightedEvent (fptype weight);
varConstIt varsBegin () const {return variables.begin();}
varConstIt varsEnd () const {return variables.end();}
void getVariables (std::vector<Variable*>& vars);
varConstRIt varsRBegin () const {return variables.rbegin();}
varConstRIt varsREnd () const {return variables.rend();}
int numVariables () const {return variables.size();}
int numEvents () const {return numEventsAdded;}
string getName () const {return name;}
protected:
vector<fptype> getCurrentValues () const;
unsigned int indexOfVariable (Variable* var) const;
int numEventsAdded;
private:
void generateName ();
std::vector<Variable*> variables;
string name;
};
#endif