CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Public Attributes
dataset.CMSDataset Class Reference
Inheritance diagram for dataset.CMSDataset:
dataset.BaseDataset

Public Member Functions

def __init__ (self, name, run_range=None)
 
def buildListOfFiles (self, pattern='.*root')
 
def buildListOfFilesDBS (self, pattern, begin=-1, end=-1)
 
def getPrimaryDatasetEntries (self)
 
- Public Member Functions inherited from dataset.BaseDataset
def __init__ (self, name, user, pattern='.*root', run_range=None, dbsInstance=None)
 def init(self, name, user, pattern='. More...
 
def buildListOfBadFiles (self)
 
def buildListOfFiles (self, pattern)
 
def extractFileSizes (self)
 
def getPrimaryDatasetEntries (self)
 
def listOfFiles (self)
 
def listOfGoodFiles (self)
 
def listOfGoodFilesWithPrescale (self, prescale)
 
def printFiles (self, abspath=True, info=True)
 
def printInfo (self)
 

Static Public Member Functions

def findPrimaryDatasetEntries (dataset, runmin, runmax)
 
def findPrimaryDatasetNumFiles (dataset, runmin, runmax)
 

Public Attributes

 files
 
- Public Attributes inherited from dataset.BaseDataset
 bad_files
 
 dbsInstance
 MM. More...
 
 files
 
 filesAndSizes
 
 good_files
 
 name
 
 pattern
 
 primaryDatasetEntries
 MM. More...
 
 report
 
 run_range
 
 user
 

Detailed Description

Definition at line 128 of file dataset.py.

Constructor & Destructor Documentation

def dataset.CMSDataset.__init__ (   self,
  name,
  run_range = None 
)

Definition at line 130 of file dataset.py.

130  def __init__(self, name, run_range = None):
131  super(CMSDataset, self).__init__( name, 'CMS', run_range=run_range)
132 
def __init__(self, name, run_range=None)
Definition: dataset.py:130

Member Function Documentation

def dataset.CMSDataset.buildListOfFiles (   self,
  pattern = '.*root' 
)

Definition at line 162 of file dataset.py.

References dataset.CMSDataset.findPrimaryDatasetNumFiles(), dataset.int, and dataset.BaseDataset.run_range.

162  def buildListOfFiles(self, pattern='.*root'):
163  runs = (-1,-1)
164  if self.run_range is not None:
165  runs = self.run_range
166  num_files=self.findPrimaryDatasetNumFiles(self.name.rstrip('/'),
167  runs[0],runs[1])
168  limit = 10000
169  if num_files > limit:
170  num_steps = int(num_files/limit)+1
171  self.files = []
172  for i in xrange(num_steps):
173  DBSFiles=self.buildListOfFilesDBS(pattern,
174  i*limit,
175  ((i+1)*limit)-1)
176  self.files.extend(DBSFiles)
177  else:
178  self.files = self.buildListOfFilesDBS(pattern)
179 
def findPrimaryDatasetNumFiles(dataset, runmin, runmax)
Definition: dataset.py:204
def buildListOfFilesDBS(self, pattern, begin=-1, end=-1)
Definition: dataset.py:133
def buildListOfFiles(self, pattern='.*root')
Definition: dataset.py:162
def dataset.CMSDataset.buildListOfFilesDBS (   self,
  pattern,
  begin = -1,
  end = -1 
)

Definition at line 133 of file dataset.py.

References edm.print(), and dataset.BaseDataset.run_range.

133  def buildListOfFilesDBS(self, pattern, begin=-1, end=-1):
134  print('buildListOfFilesDBS',begin,end)
135  sampleName = self.name.rstrip('/')
136  query, qwhat = sampleName, "dataset"
137  if "#" in sampleName: qwhat = "block"
138  if self.run_range is not None and self.run_range != (-1,-1):
139  if self.run_range[0] == self.run_range[1]:
140  query += " run=%s" % self.run_range[0]
141  else:
142  print("WARNING: queries with run ranges are slow in DAS")
143  query += " run between [%s,%s]" % ( self.run_range[0],self.run_range[1] )
144  dbs='das_client.py --query="file %s=%s"'%(qwhat,query)
145  if begin >= 0:
146  dbs += ' --index %d' % begin
147  if end >= 0:
148  dbs += ' --limit %d' % (end-begin+1)
149  else:
150  dbs += ' --limit 0'
151  print('dbs\t: %s' % dbs)
152  dbsOut = os.popen(dbs)
153  files = []
154  for line in dbsOut:
155  if line.find('/store')==-1:
156  continue
157  line = line.rstrip()
158  # print 'line',line
159  files.append(line)
160  return files
161 
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def buildListOfFilesDBS(self, pattern, begin=-1, end=-1)
Definition: dataset.py:133
def dataset.CMSDataset.findPrimaryDatasetEntries (   dataset,
  runmin,
  runmax 
)
static

Definition at line 181 of file dataset.py.

References dataset.int, and edm.print().

Referenced by dataset.CMSDataset.getPrimaryDatasetEntries(), and dataset.PrivateDataset.getPrimaryDatasetEntries().

181  def findPrimaryDatasetEntries(dataset, runmin, runmax):
182 
183  query, qwhat = dataset, "dataset"
184  if "#" in dataset: qwhat = "block"
185  if runmin >0 or runmax > 0:
186  if runmin == runmax:
187  query = "%s run=%d" % (query,runmin)
188  else:
189  print("WARNING: queries with run ranges are slow in DAS")
190  query = "%s run between [%d, %d]" % (query,runmin if runmin > 0 else 1, runmax if runmax > 0 else 999999)
191  dbs='das_client.py --query="summary %s=%s"'%(qwhat,query)
192  dbsOut = os.popen(dbs).readlines()
193 
194  entries = []
195  for line in dbsOut:
196  line = line.replace('\n','')
197  if "nevents" in line:
198  entries.append(int(line.split(":")[1]))
199  if entries:
200  return sum(entries)
201  return -1
202 
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def findPrimaryDatasetEntries(dataset, runmin, runmax)
Definition: dataset.py:181
def dataset.CMSDataset.findPrimaryDatasetNumFiles (   dataset,
  runmin,
  runmax 
)
static

Definition at line 204 of file dataset.py.

References dataset.int, and edm.print().

Referenced by dataset.CMSDataset.buildListOfFiles(), and dataset.PrivateDataset.buildListOfFilesDBS().

204  def findPrimaryDatasetNumFiles(dataset, runmin, runmax):
205 
206  query, qwhat = dataset, "dataset"
207  if "#" in dataset: qwhat = "block"
208  if runmin >0 or runmax > 0:
209  if runmin == runmax:
210  query = "%s run=%d" % (query,runmin)
211  else:
212  print("WARNING: queries with run ranges are slow in DAS")
213  query = "%s run between [%d, %d]" % (query,runmin if runmin > 0 else 1, runmax if runmax > 0 else 999999)
214  dbs='das_client.py --query="summary %s=%s"'%(qwhat,query)
215  dbsOut = os.popen(dbs).readlines()
216 
217  entries = []
218  for line in dbsOut:
219  line = line.replace('\n','')
220  if "nfiles" in line:
221  entries.append(int(line.split(":")[1]))
222  if entries:
223  return sum(entries)
224  return -1
225 
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def findPrimaryDatasetNumFiles(dataset, runmin, runmax)
Definition: dataset.py:204
def dataset.CMSDataset.getPrimaryDatasetEntries (   self)

Definition at line 226 of file dataset.py.

References dataset.CMSDataset.findPrimaryDatasetEntries(), ElectronMVAID.ElectronMVAID.name, counter.Counter.name, average.Average.name, AlignableObjectId::entry.name, histograms.Histograms.name, cond::persistency::TAG::NAME.name, TmModule.name, cond::persistency::GLOBAL_TAG::NAME.name, core.autovars.NTupleVariable.name, cond::persistency::RUN_INFO::RUN_NUMBER.name, cond::persistency::TAG::TIME_TYPE.name, cond::persistency::GLOBAL_TAG::VALIDITY.name, cond::persistency::RUN_INFO::START_TIME.name, cond::persistency::RUN_INFO::END_TIME.name, cond::persistency::TAG::OBJECT_TYPE.name, cond::persistency::GLOBAL_TAG::DESCRIPTION.name, cond::persistency::TAG::SYNCHRONIZATION.name, cond::persistency::GLOBAL_TAG::RELEASE.name, MEPSet.name, cond::persistency::TAG::END_OF_VALIDITY.name, cond::persistency::GLOBAL_TAG::SNAPSHOT_TIME.name, cond::persistency::TAG::DESCRIPTION.name, cond::persistency::GTEditorData.name, cond::persistency::GLOBAL_TAG::INSERTION_TIME.name, nanoaod::MergeableCounterTable::SingleColumn< T >.name, cond::persistency::TAG::LAST_VALIDATED_TIME.name, cond::persistency::TAG::INSERTION_TIME.name, cond::persistency::TAG::MODIFICATION_TIME.name, FWTGeoRecoGeometry::Info.name, Types._Untracked.name, preexistingValidation.PreexistingValidation.name, dataset.BaseDataset.name, OutputMEPSet.name, personalPlayback.Applet.name, ParameterSet.name, PixelDCSObject< T >::Item.name, DQMRivetClient::LumiOption.name, MagCylinder.name, analyzer.Analyzer.name, ParSet.name, DQMRivetClient::ScaleFactorOption.name, EgHLTOfflineSummaryClient::SumHistBinData.name, SingleObjectCondition.name, cond::persistency::GTProxyData.name, core.autovars.NTupleObjectType.name, MyWatcher.name, edm::PathTimingSummary.name, nanoaod::MergeableCounterTable::VectorColumn< T >.name, cms::DDAlgoArguments.name, cond::TimeTypeSpecs.name, lumi::TriggerInfo.name, alignment.Alignment.name, edm::PathSummary.name, cond::persistency::GLOBAL_TAG_MAP::GLOBAL_TAG_NAME.name, PixelEndcapLinkMaker::Item.name, perftools::EdmEventSize::BranchRecord.name, DQMGenericClient::EfficOption.name, FWTableViewManager::TableEntry.name, PixelBarrelLinkMaker::Item.name, cond::persistency::GLOBAL_TAG_MAP::RECORD.name, EcalLogicID.name, cond::persistency::GLOBAL_TAG_MAP::LABEL.name, validateAlignments.ParallelMergeJob.name, MEtoEDM< T >::MEtoEDMObject.name, cond::persistency::GLOBAL_TAG_MAP::TAG_NAME.name, ExpressionHisto< T >.name, XMLProcessor::_loaderBaseConfig.name, cond::persistency::PAYLOAD::HASH.name, cond::persistency::PAYLOAD::OBJECT_TYPE.name, TreeCrawler.Package.name, genericValidation.GenericValidation.name, cond::persistency::PAYLOAD::DATA.name, cond::persistency::PAYLOAD::STREAMER_INFO.name, cond::persistency::PAYLOAD::VERSION.name, options.ConnectionHLTMenu.name, MagGeoBuilderFromDDD::volumeHandle.name, cond::persistency::PAYLOAD::INSERTION_TIME.name, DQMGenericClient::ProfileOption.name, dqmoffline::l1t::HistDefinition.name, DQMGenericClient::NormOption.name, emtf::Node.name, h4DSegm.name, PhysicsTools::Calibration::Variable.name, core.TriggerMatchAnalyzer.TriggerMatchAnalyzer.name, FastHFShowerLibrary.name, DQMGenericClient::CDOption.name, CounterChecker.name, cond::TagInfo_t.name, looper.Looper.name, DQMGenericClient::NoFlowOption.name, cond::persistency::IOV::TAG_NAME.name, EDMtoMEConverter.name, cond::persistency::IOV::SINCE.name, TrackerSectorStruct.name, Mapper::definition< ScannerT >.name, cond::persistency::IOV::PAYLOAD_HASH.name, classes.MonitorData.name, cond::persistency::IOV::INSERTION_TIME.name, HistogramManager.name, MuonGeometrySanityCheckPoint.name, classes.OutputData.name, options.HLTProcessOptions.name, h2DSegm.name, core.TriggerBitAnalyzer.TriggerBitAnalyzer.name, nanoaod::FlatTable::Column.name, geometry.Structure.name, config.Analyzer.name, core.autovars.NTupleSubObject.name, DQMNet::WaitObject.name, AlpgenParameterName.name, SiStripMonitorDigi.name, core.autovars.NTupleObject.name, config.Service.name, cond::persistency::TAG_LOG::TAG_NAME.name, cond::persistency::TAG_LOG::EVENT_TIME.name, cond::persistency::TAG_LOG::USER_NAME.name, cond::persistency::TAG_LOG::HOST_NAME.name, cond::persistency::TAG_LOG::COMMAND.name, cond::persistency::TAG_LOG::ACTION.name, cond::persistency::TAG_LOG::USER_TEXT.name, core.autovars.NTupleCollection.name, BPHRecoBuilder::BPHRecoSource.name, BPHRecoBuilder::BPHCompSource.name, personalPlayback.FrameworkJob.name, plotscripts.SawTeethFunction.name, crabFunctions.CrabTask.name, hTMaxCell.name, cscdqm::ParHistoDef.name, BeautifulSoup.Tag.name, SummaryOutputProducer::GenericSummary.name, BeautifulSoup.SoupStrainer.name, and dataset.BaseDataset.run_range.

227  runmin = -1
228  runmax = -1
229  if self.run_range is not None:
230  runmin = self.run_range[0]
231  runmax = self.run_range[1]
232  return self.findPrimaryDatasetEntries(self.name, runmin, runmax)
233 
def getPrimaryDatasetEntries(self)
Definition: dataset.py:226
def findPrimaryDatasetEntries(dataset, runmin, runmax)
Definition: dataset.py:181

Member Data Documentation

dataset.CMSDataset.files

Definition at line 171 of file dataset.py.