/***************************************************************************** 
  * Project: RooFit                                                           * 
  * @(#)root/roofit:$Id$ *
  *                                                                           * 
  * RooFit Lognormal PDF                                                      *
  *                                                                           * 
  * Author: Gregory Schott and Stefan Schmitz                                 *
  *                                                                           * 
  *****************************************************************************/ 

#ifndef ROO_LOGNORMAL
#define ROO_LOGNORMAL

#include "RooAbsPdf.h"
#include "RooRealProxy.h"

class RooRealVar;

class RooLognormal : public RooAbsPdf {
public:
  RooLognormal() {} ;
  RooLognormal(const char *name, const char *title,
	      RooAbsReal& _x, RooAbsReal& _m0, RooAbsReal& _k);
  RooLognormal(const RooLognormal& other, const char* name=0) ;
  virtual TObject* clone(const char* newname) const { return new RooLognormal(*this,newname); }
  inline virtual ~RooLognormal() { }

  Int_t getAnalyticalIntegral(RooArgSet& allVars, RooArgSet& analVars, const char* rangeName=0) const ;
  Double_t analyticalIntegral(Int_t code, const char* rangeName=0) const ;

  Int_t getGenerator(const RooArgSet& directVars, RooArgSet &generateVars, Bool_t staticInitOK=kTRUE) const;
  void generateEvent(Int_t code);

protected:

  RooRealProxy x ;
  RooRealProxy m0 ;
  RooRealProxy k ;
  
  Double_t evaluate() const ;

private:

  ClassDef(RooLognormal,1) // log-normal PDF
};

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