105 vector<TrackJetParticlePtr> particle_list;
107 const vector<PseudoJet> & jets = clust_seq.
jets();
109 for (vector<PseudoJet>::const_iterator mom_it = jets.begin(); mom_it != jets.end(); mom_it++){
110 particle_list.push_back(TrackJetParticlePtr(index, mom_it->perp2()));
115 stable_sort(particle_list.begin(), particle_list.end());
121 vector<PseudoJet> tuned_particles = clust_seq.
jets();
122 vector<PseudoJet> tuned_tracks = clust_seq.
jets();
123 for (vector<PseudoJet>::iterator pit = tuned_particles.begin();
124 pit != tuned_particles.end(); pit++)
125 _jet_recombiner.preprocess(*pit);
126 for (vector<PseudoJet>::iterator pit = tuned_tracks.begin();
127 pit != tuned_tracks.end(); pit++)
128 _track_recombiner.preprocess(*pit);
132 list<int> sorted_pt_index;
133 for (vector<TrackJetParticlePtr>::iterator mom_it = particle_list.begin();
134 mom_it != particle_list.end(); mom_it++)
135 sorted_pt_index.push_back(mom_it->index);
138 while (sorted_pt_index.size()){
142 int current_jet_index = sorted_pt_index.front();
143 PseudoJet current_jet = tuned_particles[current_jet_index];
144 PseudoJet current_track = tuned_tracks[current_jet_index];
147 list<int>::iterator index_it = sorted_pt_index.begin();
148 sorted_pt_index.erase(index_it);
151 index_it = sorted_pt_index.begin();
152 while (index_it != sorted_pt_index.end()){
153 const PseudoJet & current_particle = tuned_particles[*index_it];
154 const PseudoJet & current_particle_track = tuned_tracks[*index_it];
157 double distance2 = current_track.
plain_distance(current_particle_track);
158 if (distance2 <= _radius2){
162 _jet_recombiner.recombine(current_jet, current_particle, new_jet);
163 _track_recombiner.recombine(current_track, current_particle_track, new_track);
168 current_jet = new_jet;
169 current_track = new_track;
170 current_jet_index = new_jet_index;
173 sorted_pt_index.erase(index_it);
177 index_it = sorted_pt_index.begin();