CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
lms_3d.cc
Go to the documentation of this file.
4 #include <vector>
5 
8 GlobalPoint lms_3d(std::vector<GlobalPoint> values) {
9  const int sze = values.size();
10  if (sze == 0) {
11  throw VertexException("lms_3d: no values given.");
12  };
13  std::vector<float> x_vals, y_vals, z_vals;
14  x_vals.reserve(sze - 1);
15  y_vals.reserve(sze - 1);
16  z_vals.reserve(sze - 1);
17  for (std::vector<GlobalPoint>::iterator i = values.begin(); i != values.end(); i++) {
18  x_vals.push_back(i->x());
19  y_vals.push_back(i->y());
20  z_vals.push_back(i->z());
21  };
22  return GlobalPoint(lms_1d(x_vals), lms_1d(y_vals), lms_1d(z_vals));
23 }
Common base class.
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
T lms_1d(std::vector< T > values)
Definition: lms_1d.h:15
GlobalPoint lms_3d(std::vector< GlobalPoint > values)
Definition: lms_3d.cc:8