44 if (frac_cut < 0 || frac_cut > 1)
return;
54 if (frac_cut < 0 || frac_cut > 1)
return;
64 if (frac_cut < 0 || frac_cut > 1)
return;
68 int num_roads[4] = { 0, 0, 0, 0 };
70 for (
int ir = 0; ir < 4; ir++) {
73 int n_ent = num_roads[ir] = roads->
Size();
74 for (
int ii = 0; ii < n_ent; ii++) w_tot += roads->
Get(ii)->
GetFoM();
79 m_ofs <<
" Last Five\n";
87 for (
int ir = 0; ir < 4; ir++) {
90 double fom = info->
GetFoM();
91 if (ir_min < 0 || fom < fom_min) {
96 RoadList* roads = list_roads[ir_min];
105 road_id4[ir_min] = road_id;
110 }
else if (road_id == 1) {
114 }
else if (road_id == 2) {
124 for (
int ir = 0; ir < 4; ir++) {
126 RoadMap* map_rd = map_roads[ir];
134 if (w_dis / w_tot >= frac_cut)
break;
151 m_ofs <<
" Last Five\n";
154 int n_ent = road_list->
Size();
156 for (
int ii = 0; ii < n_ent; ii++) w_tot += road_list->
Get(ii)->
GetWeight();
158 int i_ent = n_ent - 1;
163 if (w_dis / w_tot >= frac)
break;
166 int n_dis = n_ent - i_ent;
167 m_ofs <<
" Total : weight = " << w_tot <<
", N = " << n_ent <<
"\n"
168 <<
" Disabled: weight = " << w_dis <<
", N = " << n_dis <<
"\n"
169 <<
" " << w_dis/w_tot <<
", " << 1.0*n_dis/n_ent << endl;
179 m_ofs <<
" Last Five\n";
182 int n_ent = road_list->
Size();
184 for (
int ii = 0; ii < n_ent; ii++) w_tot += road_list->
Get(ii)->
GetFoM();
186 int i_ent = n_ent - 1;
191 if (w_dis / w_tot >= frac)
break;
194 int n_dis = n_ent - i_ent;
195 m_ofs <<
" Total : weight = " << w_tot <<
", N = " << n_ent <<
"\n"
196 <<
" Disabled: weight = " << w_dis <<
", N = " << n_dis <<
"\n"
197 <<
" " << w_dis/w_tot <<
", " << 1.0*n_dis/n_ent << endl;
202 int h1, h2, h3, h4, tb;
213 int h1, h2, h3, h4, tb;
220 map<int, int> road_count;
224 road_count[road_id]++;
229 road_count[road_id]++;
234 road_count[road_id]++;
239 road_count[road_id]++;
246 if (road_count[road_id] != 4) info->
SetOnOff(
false);
251 if (road_count[road_id] != 4) info->
SetOnOff(
false);
256 if (road_count[road_id] != 4) info->
SetOnOff(
false);
261 if (road_count[road_id] != 4) info->
SetOnOff(
false);
RoadMap * GetRoadMapPosTop()
RoadMap * GetRoadMapNegBot()
RoadMap * GetRoadMapNegTop()
RoadMap * GetRoadMapPosBot()
void DisableRoadsByFoM(RoadList *road_list, const double frac)
void GenerateSymmetricRoadSetByFoM(const double frac_cut, const std::string rs_id)
void DisableRoadsByWeightFraction(RoadList *road_list, const double frac)
void GenerateRoadSetBySignal(const double frac_cut, const std::string rs_id)
int FlipRoadTopBottom(const int road)
GenRoadset(const std::string label="gen_rs")
void GenerateRoadSetByFoM(const double frac_cut, const std::string rs_id)
void SetMap(AnaSignal *ana_signal)
int FlipRoadLeftRight(const int road)
void SetOnOff(const bool on_off)
void SetPNTB(const int pn, const int tb)
std::string GetPosNegStr() const
std::string GetTopBotStr() const
Class to hold an ordered set (i.e. vector) of roads.
void SortByFoM()
Sort the list by Figure of Merit, i.e. "signal / sqrt(bg)".
Class to hold a non-ordered set (i.e. map) of roads.
RoadInfo * Find(const int road) const
void PrintList(RoadList *road_list, int i_begin=0, int i_end=0, std::ostream &os=std::cout)
void WriteToFile(const RoadMap *pos_top, const RoadMap *pos_bot, const RoadMap *neg_top, const RoadMap *neg_bot, const std::string id)
void Road2Hodo(const int road, int &h1, int &h2, int &h3, int &h4, int &tb)
Convert a roadset ID to a set of hodo IDs.
int Hodo2Road(const int h1, const int h2, const int h3, const int h4, const int tb)
Convert a set of hodo IDs to a roadset ID.