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

//#include "THashList.h"
#include "RooSimultaneous.h"

namespace RooStats{
namespace HistFactory{


class HistFactorySimultaneous : public RooSimultaneous {
public:

  // Constructors, assignment etc
  inline HistFactorySimultaneous() : RooSimultaneous() {} //_plotCoefNormRange(0) { }
  HistFactorySimultaneous(const char *name, const char *title, RooAbsCategoryLValue& indexCat) ;
  HistFactorySimultaneous(const char *name, const char *title, std::map<std::string,RooAbsPdf*> pdfMap, RooAbsCategoryLValue& inIndexCat) ;
  HistFactorySimultaneous(const char *name, const char *title, const RooArgList& pdfList, RooAbsCategoryLValue& indexCat) ;
  HistFactorySimultaneous(const HistFactorySimultaneous& other, const char* name=0);
  HistFactorySimultaneous(const RooSimultaneous& other, const char* name=0);
  ~HistFactorySimultaneous();

  virtual TObject* clone(const char* newname) const { return new HistFactorySimultaneous(*this,newname) ; }

  virtual RooAbsReal* createNLL(RooAbsData& data, const RooLinkedList& cmdList);

  virtual RooAbsReal* createNLL(RooAbsData& data, 
				const RooCmdArg& arg1 = RooCmdArg::none(), const RooCmdArg& arg2 = RooCmdArg::none(), 
				const RooCmdArg& arg3 = RooCmdArg::none(), const RooCmdArg& arg4 = RooCmdArg::none(), 
				const RooCmdArg& arg5 = RooCmdArg::none(), const RooCmdArg& arg6 = RooCmdArg::none(), 
				const RooCmdArg& arg7 = RooCmdArg::none(), const RooCmdArg& arg8 = RooCmdArg::none());
    
  
protected:

  ClassDef(RooStats::HistFactory::HistFactorySimultaneous,2)  // Simultaneous operator p.d.f, functions like C++  'switch()' on input p.d.fs operating on index category5A
};

}
}

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