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

#include "RooAbsMoment.h"
#include "RooRealProxy.h"
#include "RooSetProxy.h"


class RooRealVar;
class RooArgList ;

class RooMoment : public RooAbsMoment {
public:

  RooMoment() ;
  RooMoment(const char *name, const char *title, RooAbsReal& func, RooRealVar& x, Int_t order=1, Bool_t central=kFALSE, Bool_t takeRoot=kFALSE) ;
  RooMoment(const char *name, const char *title, RooAbsReal& func, RooRealVar& x, const RooArgSet& nset, Int_t order=1, Bool_t central=kFALSE, Bool_t takeRoot=kFALSE,
	    Bool_t intNSet=kFALSE) ;
  virtual ~RooMoment() ;

  RooMoment(const RooMoment& other, const char* name = 0);
  virtual TObject* clone(const char* newname) const { return new RooMoment(*this, newname); }

  const RooAbsReal& xF() { return _xf.arg() ; }
  const RooAbsReal& ixF() { return _ixf.arg() ; }
  const RooAbsReal& iF() { return _if.arg() ; }

protected:

  RooRealProxy _xf ;                     // X*F 
  RooRealProxy _ixf ;                    // Int(X*F(X))dx ;
  RooRealProxy _if ;                     // Int(F(x))dx ;
  Double_t evaluate() const;

  ClassDef(RooMoment,1) // Representation of moment in a RooAbsReal in a given RooRealVar
};

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