/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitModels                                                     *
 *    File: $Id$
 * Authors:                                                                  *
 *   GR, Gerhard Raven,   Nikhef & VU, Gerhard.Raven@nikhef.nl
 *                                                                           *
 * Copyright (c) 2010, Nikhef & VU. 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_SPHARMONIC
#define ROO_SPHARMONIC

#include "RooLegendre.h"
#include "RooRealProxy.h"

class RooSpHarmonic : public RooLegendre {
public:
  RooSpHarmonic() ;
  RooSpHarmonic(const char *name, const char *title, RooAbsReal& ctheta, RooAbsReal& phi, int l, int m);
  RooSpHarmonic(const char *name, const char *title, RooAbsReal& ctheta, RooAbsReal& phi, int l1, int m1, int l2, int m2);

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

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

  virtual Int_t getMaxVal( const RooArgSet& vars) const;
  virtual Double_t maxVal( Int_t code) const;

private:
  RooRealProxy _phi;
  double _n;
  int _sgn1,_sgn2;

  Double_t evaluate() const;

  ClassDef(RooSpHarmonic,1) // SpHarmonic polynomial
};

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