25 theCmsTrackerStringBuilder.
build(fv,subdet,s);
28 theCmsTrackerRodBuilder.
build(fv,subdet,s);
31 theCmsTrackerLadderBuilder.
build(fv,subdet,s);
43 const std::function<double(const GeometricDet*)> getPhiFunc{
getPhi};
53 float layerRadius = (det->
params()[2]+det->
params()[1])/2.;
68 for(
size_t i = 0;
i< comp.size(); ++
i) {
70 if(component->translation().z()<0.){
71 neg.emplace_back(component);
73 pos.emplace_back(component);
78 double rPos =
i->translation().Rho();
79 if(rPos > layerRadius ){
80 extneg.emplace_back(
i);
82 intneg.emplace_back(
i);
87 double rPos = po->translation().Rho();
88 if(rPos > layerRadius ){
89 extpos.emplace_back(po);
91 intpos.emplace_back(po);
100 for(uint32_t
i=0;
i<intneg.size();
i++){
104 intneg[
i]->setGeographicalID(
DetId(temp));
107 for(uint32_t
i=0;
i<extneg.size();
i++){
111 extneg[
i]->setGeographicalID(
DetId(temp));
114 for(uint32_t
i=0;
i<intpos.size();
i++){
118 intpos[
i]->setGeographicalID(
DetId(temp));
121 for(uint32_t
i=0;
i<extpos.size();
i++){
125 extpos[
i]->setGeographicalID(
DetId(temp));
141 for(
size_t i=0;
i<comp.size(); ++
i) {
143 if(component->translation().z()<0.){
144 neg.emplace_back(component);
146 pos.emplace_back(component);
153 for(uint32_t
i=0;
i<neg.size();
i++){
156 neg[
i]->setGeographicalID(
DetId(temp));
159 for(uint32_t
i=0;
i<pos.size();
i++){
162 pos[
i]->setGeographicalID(
DetId(temp));
173 for(uint32_t
i=0;
i<comp.size();
i++){
178 edm::LogError(
"CmsTrackerLayerBuilder")<<
"ERROR - wrong SubDet to sort..... "<<det->
components().front()->type();
void buildComponent(DDFilteredView &, GeometricDet *, std::string) override
void addComponent(GeometricDet *)
void build(DDFilteredView &, GeometricDet *, std::string) override
static double getPhi(const GeometricDet *a)
void setGeographicalID(DetId id)
std::vector< GeometricDet * > GeometricDetContainer
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e g
ConstGeometricDetContainer & components()
std::vector< double > const & params() const
void sortNS(DDFilteredView &, GeometricDet *) override
void TrackerStablePhiSort(RandomAccessIterator begin, RandomAccessIterator end, const Extractor &extr)
GeometricDet * component(size_t index)
std::vector< GeometricDet const * > ConstGeometricDetContainer
void addComponents(GeometricDetContainer const &cont)
GeometricDet::GeometricEnumType type(std::string const &) const
CmsTrackerStringToEnum theCmsTrackerStringToEnum