HPCToolkit
FilteredBaseData.cpp
Go to the documentation of this file.
1 // -*-Mode: C++;-*-
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL: https://hpctoolkit.googlecode.com/svn/branches/hpctoolkit-hpcserver/src/tool/hpcserver/FilteredBaseData.cpp $
6 // $Id: FilteredBaseData.cpp 4307 2013-07-18 17:04:52Z felipet1326@gmail.com $
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 //***************************************************************************
48 //
49 // File:
50 // $HeadURL: https://hpctoolkit.googlecode.com/svn/branches/hpctoolkit-hpcserver/src/tool/hpcserver/FilteredBaseData.cpp $
51 //
52 // Purpose:
53 // The highest level of the filtering implementation. Abstracts the filter
54 // away from the classes that access the file directly.
55 // From highest level of abstraction of the file to lowest:
56 // FilteredBaseData, BaseDataFile, LargeByteBuffer, VersatileMemoryPage
57 //
58 // Description:
59 // [The set of functions, macros, etc. defined in the file]
60 //
61 //***************************************************************************
62 
63 
64 #include <assert.h>
65 #include <iostream>
66 
67 
68 #include "DebugUtils.hpp"
69 #include "FilteredBaseData.hpp"
70 
71 namespace TraceviewerServer {
72 FilteredBaseData::FilteredBaseData(string filename, int _headerSize) {
73  baseDataFile = new BaseDataFile(filename, _headerSize);
74  headerSize = _headerSize;
76  //Filters are default, which is allow everything, so this will initialize the vector
77  filter();
78 
79 }
80 
82  delete baseDataFile;
83 }
84 
86 {
87  DEBUGCOUT(1) << "setting filters" <<endl;
88  currentlyAppliedFilter = _filter;
89  filter();
90 }
91 
93 {
94  int numFiles = baseDataFile->getNumberOfFiles();
95  rankMapping.clear();
96  for (int i = 0; i < numFiles; i++) {
98  rankMapping.push_back(i);
99  }
100  }
101 
102  DEBUGCOUT(1) << "Filtering matched " << rankMapping.size() << " out of "<<numFiles<<endl;
103 }
104 
106  assert((unsigned int)pseudoRank < rankMapping.size());
107  return baseOffsets[rankMapping[pseudoRank]].start + headerSize;
108 }
109 
111  assert((unsigned int)pseudoRank < rankMapping.size());
112  return baseOffsets[rankMapping[pseudoRank]].end;
113 }
114 
116 {
117  return baseDataFile->getMasterBuffer()->getLong(position);
118 }
120 {
121  return baseDataFile->getMasterBuffer()->getInt(position);
122 }
123 
125 {
126  return rankMapping.size();
127 }
128 
130 {
131  return baseDataFile->processIDs;
132 }
134 {
135  return baseDataFile->threadIDs;
136 }
137 }
bool matches(int proc, int thread)
Definition: FilterSet.hpp:81
int64_t getLong(FileOffset position)
FileOffset getMaxLoc(int pseudoRank)
uint64_t FileOffset
Definition: FileUtils.hpp:78
FileOffset getMinLoc(int pseudoRank)
FilteredBaseData(string filename, int _headerSize)
#define DEBUGCOUT(a)
Definition: DebugUtils.hpp:72
LargeByteBuffer * getMasterBuffer()