/*****************************************************************************
 * 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_PACKAGE
#define ROO_STUDY_PACKAGE

#include "TNamed.h"

class RooAbsPdf;
class RooDataSet ;
class RooAbsData ;
class RooFitResult ;
class RooPlot ;
class RooRealVar ;
class RooWorkspace ;
class RooAbsStudy ;
#include <list>

class RooStudyPackage : public TNamed {
public:

  RooStudyPackage() ;
  RooStudyPackage(RooWorkspace& w) ;
  RooStudyPackage(const RooStudyPackage&) ;
  void addStudy(RooAbsStudy& study) ;
  TObject* Clone(const char* /*newname*/="") const { return new RooStudyPackage(*this) ; }
  
  RooWorkspace& wspace() { return *_ws ; }
  std::list<RooAbsStudy*>& studies() { return _studies ; }
    
  void driver(Int_t nExperiments) ;

  Int_t initRandom() ;
  void initialize() ;
  void runOne() ;
  void run(Int_t nExperiments) ;
  void finalize() ;
  
  void exportData(TList* olist, Int_t seqno) ;

  static void processFile(const char* infile, Int_t nexp) ;

protected:

  RooWorkspace* _ws ;
  std::list<RooAbsStudy*> _studies ; 

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


#endif

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