4 #include "TLorentzVector.h" 8 class LorentzVectors :
public DerivedValue<std::vector<TLorentzVector>>{
10 Value<std::vector<float>> *pt_val;
11 Value<std::vector<float>> *eta_val;
12 Value<std::vector<float>> *phi_val;
13 Value<std::vector<float>> *mass_val;
16 auto pt = pt_val->get_value();
17 auto eta = eta_val->get_value();
18 auto phi = phi_val->get_value();
19 auto mass = mass_val->get_value();
20 std::vector<int> sizes = {pt.size(), eta.size(), phi.size(), mass.size()};
21 int size = *std::min_element(sizes.begin(), sizes.end());
24 for (
int i =0; i<size; i++){
25 lv.SetPtEtaPhiM(pt[i], eta[i], phi[i], mass[i]);
26 this->value.push_back(lv);
31 static std::string fmt_name(Value<std::vector<float>>* pt, Value<std::vector<float>>* eta,
32 Value<std::vector<float>>* phi, Value<std::vector<float>>* mass){
33 return "lorentz_vectors("+pt->get_name()+
"," +eta->get_name()+
","+
34 phi->get_name()+
"," +mass->get_name()+
")";
37 LorentzVectors(Value<std::vector<float>>* pt,
38 Value<std::vector<float>>* eta,
39 Value<std::vector<float>>* phi,
40 Value<std::vector<float>>* mass,
41 const std::string& alias)
42 :DerivedValue<
std::vector<TLorentzVector>>(fmt_name(pt,eta,phi,mass), alias),
43 pt_val(pt), eta_val(eta), phi_val(phi), mass_val(mass) { }
46 class Energies :
public DerivedValue<std::vector<float>>{
48 Value<std::vector<TLorentzVector>> *vectors;
50 std::vector<TLorentzVector>& vecs = vectors->get_value();
53 this->value.push_back(v.Energy());
58 static std::string fmt_name(Value<std::vector<TLorentzVector>> *vectors){
59 return "energies("+vectors->get_name()+
")";
62 Energies(Value<std::vector<TLorentzVector>> *vectors,
63 const std::string& alias)
64 :DerivedValue<
std::vector<float>>(fmt_name(vectors), alias),
69 #endif // root_value_hpp