225 |
static Dimensions getDimensionsForRegionGroup(RegionGroup& regionGroup) { |
static Dimensions getDimensionsForRegionGroup(RegionGroup& regionGroup) { |
226 |
std::map<gig::dimension_t, std::set<int> > dimUpperLimits; |
std::map<gig::dimension_t, std::set<int> > dimUpperLimits; |
227 |
|
|
228 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
229 |
|
printf("dimUpperLimits = {\n"); |
230 |
|
#endif |
231 |
// collect all dimension region zones' upper limits |
// collect all dimension region zones' upper limits |
232 |
for (RegionGroup::iterator it = regionGroup.begin(); |
for (RegionGroup::iterator it = regionGroup.begin(); |
233 |
it != regionGroup.end(); ++it) |
it != regionGroup.end(); ++it) |
236 |
int previousBits = 0; |
int previousBits = 0; |
237 |
for (uint d = 0; d < rgn->Dimensions; ++d) { |
for (uint d = 0; d < rgn->Dimensions; ++d) { |
238 |
const gig::dimension_def_t& def = rgn->pDimensionDefinitions[d]; |
const gig::dimension_def_t& def = rgn->pDimensionDefinitions[d]; |
239 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
240 |
|
printf("\t[rgn=%p,dim=%#x] = {", rgn, def.dimension); |
241 |
|
#endif |
242 |
for (uint z = 0; z < def.zones; ++z) { |
for (uint z = 0; z < def.zones; ++z) { |
243 |
int dr = z << previousBits; |
int dr = z << previousBits; |
244 |
gig::DimensionRegion* dimRgn = rgn->pDimensionRegions[dr]; |
gig::DimensionRegion* dimRgn = rgn->pDimensionRegions[dr]; |
251 |
// velocity splits of all regions is stored here, and when their |
// velocity splits of all regions is stored here, and when their |
252 |
// individual DimensionRegions are finally copied (later), the |
// individual DimensionRegions are finally copied (later), the |
253 |
// individual velocity split size are copied by that. |
// individual velocity split size are copied by that. |
254 |
dimUpperLimits[def.dimension].insert( |
const int upperLimit = |
255 |
(def.dimension == gig::dimension_velocity) ? |
(def.dimension == gig::dimension_velocity) ? |
256 |
z : (def.split_type == gig::split_type_bit) ? |
z : (def.split_type == gig::split_type_bit) ? |
257 |
((z+1) * 128/def.zones - 1) : dimRgn->DimensionUpperLimits[dr] |
((z+1) * 128/def.zones - 1) : dimRgn->DimensionUpperLimits[dr]; |
258 |
); |
#if DEBUG_COMBINE_INSTRUMENTS |
259 |
|
printf(" %d,", upperLimit); |
260 |
|
#endif |
261 |
|
dimUpperLimits[def.dimension].insert(upperLimit); |
262 |
} |
} |
263 |
previousBits += def.bits; |
previousBits += def.bits; |
264 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
265 |
|
printf(" }\n"); |
266 |
|
#endif |
267 |
} |
} |
268 |
} |
} |
269 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
270 |
|
printf("}\n"); |
271 |
|
#endif |
272 |
|
|
273 |
// convert upper limit set to range vector |
// convert upper limit set to range vector |
274 |
Dimensions dims; |
Dimensions dims; |
275 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
276 |
|
printf("dims = {\n"); |
277 |
|
#endif |
278 |
for (std::map<gig::dimension_t, std::set<int> >::const_iterator it = dimUpperLimits.begin(); |
for (std::map<gig::dimension_t, std::set<int> >::const_iterator it = dimUpperLimits.begin(); |
279 |
it != dimUpperLimits.end(); ++it) |
it != dimUpperLimits.end(); ++it) |
280 |
{ |
{ |
281 |
gig::dimension_t type = it->first; |
gig::dimension_t type = it->first; |
282 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
283 |
|
printf("\t[dim=%#x] = {", type); |
284 |
|
#endif |
285 |
int iLow = 0; |
int iLow = 0; |
286 |
for (std::set<int>::const_iterator itNums = it->second.begin(); |
for (std::set<int>::const_iterator itNums = it->second.begin(); |
287 |
itNums != it->second.end(); ++itNums) |
itNums != it->second.end(); ++itNums) |
289 |
const int iUpperLimit = *itNums; |
const int iUpperLimit = *itNums; |
290 |
DLS::range_t range = { uint16_t(iLow), uint16_t(iUpperLimit) }; |
DLS::range_t range = { uint16_t(iLow), uint16_t(iUpperLimit) }; |
291 |
dims[type].push_back(range); |
dims[type].push_back(range); |
292 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
293 |
|
printf(" %d..%d,", iLow, iUpperLimit); |
294 |
|
#endif |
295 |
iLow = iUpperLimit + 1; |
iLow = iUpperLimit + 1; |
296 |
} |
} |
297 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
298 |
|
printf(" }\n"); |
299 |
|
#endif |
300 |
} |
} |
301 |
|
#if DEBUG_COMBINE_INSTRUMENTS |
302 |
|
printf("}\n"); |
303 |
|
#endif |
304 |
|
|
305 |
return dims; |
return dims; |
306 |
} |
} |