8 #include <boost/multi_array.hpp>
10 #include <boost/archive/text_iarchive.hpp>
11 #include <boost/archive/text_oarchive.hpp>
12 #include <boost/serialization/access.hpp>
21 SegmentSnapshotTable::SegmentSnapshotTable()
27 SegmentSnapshotTable::SegmentSnapshotTable (
const SegmentSnapshotTable&)
33 SegmentSnapshotTable::
34 SegmentSnapshotTable (
const Key_T& iKey) : _key (iKey), _parent (NULL) {
43 std::ostringstream oStr;
54 _classIndexMap.insert (iClassIndexMap.begin(), iClassIndexMap.end());
64 resize (boost::extents[lNumberOfSegmentCabins*lNumberOfClasses]
67 resize (boost::extents[lNumberOfSegmentCabins*lNumberOfClasses]
70 resize (boost::extents[lNumberOfSegmentCabins*lNumberOfClasses]
73 resize (boost::extents[lNumberOfSegmentCabins*lNumberOfClasses]
76 resize (boost::extents[lNumberOfSegmentCabins*lNumberOfClasses]
79 resize (boost::extents[lNumberOfSegmentCabins*lNumberOfClasses]
82 resize (boost::extents[lNumberOfSegmentCabins*lNumberOfClasses]
90 ClassIndexMap_T::const_iterator itVTIdx =
93 return itVTIdx->second;
99 SegmentCabinIndexMap_T::const_iterator itSCIdx =
102 return itSCIdx->second;
109 const DTD_T iDTD)
const {
111 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
112 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
121 const DTD_T iDTDBegin,
const DTD_T iDTDEnd)
const {
122 const unsigned int lNbOfClasses = _classIndexMap.size();
123 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
124 const unsigned int lClassIdxEnd = (iSCIdxEnd +1) * lNbOfClasses;
135 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
136 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
145 const DTD_T iDTDBegin,
146 const DTD_T iDTDEnd) {
148 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
149 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
158 const DTD_T iDTD)
const {
160 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
161 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
170 const DTD_T iDTDBegin,
const DTD_T iDTDEnd)
const {
171 const unsigned int lNbOfClasses = _classIndexMap.size();
172 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
173 const unsigned int lClassIdxEnd = (iSCIdxEnd +1) * lNbOfClasses;
184 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
185 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
194 const DTD_T iDTDBegin,
195 const DTD_T iDTDEnd) {
197 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
198 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
207 const DTD_T iDTD)
const {
209 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
210 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
219 const DTD_T iDTDBegin,
const DTD_T iDTDEnd)
const {
220 const unsigned int lNbOfClasses = _classIndexMap.size();
221 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
222 const unsigned int lClassIdxEnd = (iSCIdxEnd +1) * lNbOfClasses;
233 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
234 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
243 const DTD_T iDTDBegin,
244 const DTD_T iDTDEnd) {
246 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
247 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
257 const DTD_T iDTD)
const {
259 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
260 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
269 const DTD_T iDTDBegin,
const DTD_T iDTDEnd)
const {
270 const unsigned int lNbOfClasses = _classIndexMap.size();
271 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
272 const unsigned int lClassIdxEnd = (iSCIdxEnd +1) * lNbOfClasses;
283 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
284 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
293 const DTD_T iDTDBegin,
294 const DTD_T iDTDEnd) {
296 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
297 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
306 const DTD_T iDTD)
const {
308 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
309 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
318 const DTD_T iDTDBegin,
const DTD_T iDTDEnd)
const {
319 const unsigned int lNbOfClasses = _classIndexMap.size();
320 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
321 const unsigned int lClassIdxEnd = (iSCIdxEnd +1) * lNbOfClasses;
332 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
333 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
342 const DTD_T iDTDBegin,
343 const DTD_T iDTDEnd) {
345 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
346 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
356 const DTD_T iDTD)
const {
358 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
359 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
368 const DTD_T iDTDBegin,
const DTD_T iDTDEnd)
const {
369 const unsigned int lNbOfClasses = _classIndexMap.size();
370 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
371 const unsigned int lClassIdxEnd = (iSCIdxEnd +1) * lNbOfClasses;
381 const unsigned int lNbOfClasses = _classIndexMap.size();
382 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
383 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
385 return _priceOrientedGrossBookingSnapshotBlock [ boost::indices[
SnapshotBlockRange_T(lClassIdxBegin, lClassIdxEnd)][iDTD] ];
393 const unsigned int lNbOfClasses = _classIndexMap.size();
394 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
395 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
404 const DTD_T iDTD)
const {
405 const unsigned int lNbOfClasses = _classIndexMap.size();
406 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
407 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
409 return _availabilitySnapshotBlock [ boost::indices[
SnapshotBlockRange_T(lClassIdxBegin, lClassIdxEnd)][iDTD] ];
416 const DTD_T iDTDBegin,
const DTD_T iDTDEnd)
const {
417 const unsigned int lNbOfClasses = _classIndexMap.size();
418 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
419 const unsigned int lClassIdxEnd = (iSCIdxEnd +1) * lNbOfClasses;
430 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
431 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
440 const DTD_T iDTDBegin,
441 const DTD_T iDTDEnd) {
443 const unsigned int lClassIdxBegin = iSCIdxBegin * lNbOfClasses;
444 const unsigned int lClassIdxEnd = (iSCIdxEnd + 1) * lNbOfClasses;
450 void SegmentSnapshotTable::serialisationImplementationExport()
const {
451 std::ostringstream oStr;
452 boost::archive::text_oarchive oa (oStr);
457 void SegmentSnapshotTable::serialisationImplementationImport() {
458 std::istringstream iStr;
459 boost::archive::text_iarchive ia (iStr);
464 template<
class Archive>
466 const unsigned int iFileVersion) {