/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 *    File: $Id$
 * Authors:                                                                  *
 *   WV, Wouter Verkerke, UC Santa Barbara, verkerke@slac.stanford.edu       *
 *   DK, David Kirkby,    UC Irvine,         dkirkby@uci.edu                 *
 *                                                                           *
 * Copyright (c) 2000-2005, Regents of the University of California          *
 *                          and Stanford University. All rights reserved.    *
 *                                                                           *
 * Redistribution and use in source and binary forms,                        *
 * with or without modification, are permitted according to the terms        *
 * listed in LICENSE (http://roofit.sourceforge.net/license.txt)             *
 *****************************************************************************/
#ifndef ROO_STUDY_MANAGER
#define ROO_STUDY_MANAGER

#include "TNamed.h"

class RooAbsPdf;
class RooDataSet ;
class RooAbsData ;
class RooFitResult ;
class RooPlot ;
class RooRealVar ;
class RooWorkspace ;
class RooAbsStudy ;
#include "RooStudyPackage.h" 
#include <list>
#include <string>

class RooStudyManager : public TNamed {
public:

  RooStudyManager(RooWorkspace& w) ;
  RooStudyManager(RooWorkspace& w, RooAbsStudy& study) ;
  RooStudyManager(const char* studyPackFileName) ;
  void addStudy(RooAbsStudy& study) ;

  // Interactive running
  void run(Int_t nExperiments) ;

  // PROOF-based paralllel running
  void runProof(Int_t nExperiments, const char* proofHost="", Bool_t showGui=kTRUE) ;
  static void closeProof(Option_t *option = "s") ;

  // Batch running
  void prepareBatchInput(const char* studyName, Int_t nExpPerJob, Bool_t unifiedInput) ;
  void processBatchOutput(const char* filePat) ;

  RooWorkspace& wspace() { return _pkg->wspace() ; }
  std::list<RooAbsStudy*>& studies() { return _pkg->studies() ; }  

protected:

  void aggregateData(TList* olist) ;
  void expandWildCardSpec(const char* spec, std::list<std::string>& result) ;

  RooStudyPackage* _pkg ;

  RooStudyManager(const RooStudyManager&) ;
	
  ClassDef(RooStudyManager,1) // A general purpose workspace oriented parallelizing study manager
} ;


#endif

 RooStudyManager.h:1
 RooStudyManager.h:2
 RooStudyManager.h:3
 RooStudyManager.h:4
 RooStudyManager.h:5
 RooStudyManager.h:6
 RooStudyManager.h:7
 RooStudyManager.h:8
 RooStudyManager.h:9
 RooStudyManager.h:10
 RooStudyManager.h:11
 RooStudyManager.h:12
 RooStudyManager.h:13
 RooStudyManager.h:14
 RooStudyManager.h:15
 RooStudyManager.h:16
 RooStudyManager.h:17
 RooStudyManager.h:18
 RooStudyManager.h:19
 RooStudyManager.h:20
 RooStudyManager.h:21
 RooStudyManager.h:22
 RooStudyManager.h:23
 RooStudyManager.h:24
 RooStudyManager.h:25
 RooStudyManager.h:26
 RooStudyManager.h:27
 RooStudyManager.h:28
 RooStudyManager.h:29
 RooStudyManager.h:30
 RooStudyManager.h:31
 RooStudyManager.h:32
 RooStudyManager.h:33
 RooStudyManager.h:34
 RooStudyManager.h:35
 RooStudyManager.h:36
 RooStudyManager.h:37
 RooStudyManager.h:38
 RooStudyManager.h:39
 RooStudyManager.h:40
 RooStudyManager.h:41
 RooStudyManager.h:42
 RooStudyManager.h:43
 RooStudyManager.h:44
 RooStudyManager.h:45
 RooStudyManager.h:46
 RooStudyManager.h:47
 RooStudyManager.h:48
 RooStudyManager.h:49
 RooStudyManager.h:50
 RooStudyManager.h:51
 RooStudyManager.h:52
 RooStudyManager.h:53
 RooStudyManager.h:54
 RooStudyManager.h:55
 RooStudyManager.h:56
 RooStudyManager.h:57
 RooStudyManager.h:58
 RooStudyManager.h:59
 RooStudyManager.h:60
 RooStudyManager.h:61
 RooStudyManager.h:62
 RooStudyManager.h:63
 RooStudyManager.h:64
 RooStudyManager.h:65
 RooStudyManager.h:66
 RooStudyManager.h:67
 RooStudyManager.h:68
 RooStudyManager.h:69