TTTT Analysis  0.1
dataset.hpp
Go to the documentation of this file.
1 
31 #ifndef dataset_hpp
32 #define dataset_hpp
33 #include <iostream>
34 #include "value.hpp"
35 #include "container.hpp"
36 #include "log.hpp"
37 
38 namespace fv{
39 
40 typedef std::map<std::string, GenContainer*> ContainerSet;
41 
42 /*
43  * A DataSet is a generic source of data that is used to populate
44  * ObservedValues. For each ObservedValue, it is recommened that the DataSet
45  * have a field whose value is updated when the load_next() method is called. A
46  * pointer to this value is then passed during the creation of the
47  * ObservedValue. It is important, therefore, that the location in memory of
48  * the data not change from event to event.
49  */
50 class DataSet{
51  private:
52  void summary(){
53  INFO(GenValue::summary());
54  INFO(GenFunction::summary());
55  }
56 
57 
58  protected:
59  ContainerSet containers;
60  virtual bool load_next() = 0;
61  virtual int get_events() = 0;
62  virtual int get_current_event() = 0;
63 
64  std::map<std::string,std::string> get_container_name_value_map(){
65  std::map<std::string, std::string> value_map;
66  for(auto container : containers)
67  value_map[container.first] = container.second->get_value_name();
68  return value_map;
69  }
70  public:
71  void process(bool silent=false){
72  int events, current_event;
73  summary();
74  events = get_events();
75  if (!silent) std::cout << std::endl;
76  while( load_next() ){
77  current_event = get_current_event();
78  if (!silent) std::cout << "\rprocessing event: " << current_event+1 << "/" << events << std::flush;
79  GenValue::reset();
80  for(auto con : containers){
81  con.second->fill();
82  }
83  }
84  if (!silent) std::cout << " Finished!" << std::endl;
85  }
86 
87  virtual void save_all(){
88  for(auto container : containers)
89  container.second->save();
90  }
91 
92  template<typename C, typename... ArgTypes>
93  C* register_container(ArgTypes... args){
94  C* container = new C(args...);
95  if (containers[container->get_name()] != nullptr){
96  CRITICAL("Container with name \""+container->get_name()+"\" already exists.", -1);
97  }
98  containers[container->get_name()] = container;
99  return container;
100  }
101 
102  GenContainer* get_container(std::string container_name){
103  GenContainer* c = containers[container_name];
104  if (c == nullptr){
105  CRITICAL("Request for container \"" << container_name << "\" failed. Doesn't exist.", -1);
106  }
107  return c;
108  }
109 };
110 }
111 #endif // dataset_hpp
The namespace containing all filval classes and functions.
Definition: api.hpp:38