ROOT logo
/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitModels                                                     *
 *    File: $Id: RooUnblindCPAsymVar.h,v 1.15 2007/05/11 10:15:52 verkerke Exp $
 * 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_UNBLIND_CPASYM_VAR
#define ROO_UNBLIND_CPASYM_VAR

#include "RooAbsHiddenReal.h"
#include "RooAbsCategory.h"
#include "RooRealProxy.h"
#include "RooCategoryProxy.h"
#include "RooBlindTools.h"

class RooCategory ;

class RooUnblindCPAsymVar : public RooAbsHiddenReal {
public:
  // Constructors, assignment etc
  RooUnblindCPAsymVar() ;
  RooUnblindCPAsymVar(const char *name, const char *title, 
			const char *blindString, RooAbsReal& cpasym);
  RooUnblindCPAsymVar(const char *name, const char *title, 
		      const char *blindString, RooAbsReal& cpasym, RooAbsCategory& blindState);
  RooUnblindCPAsymVar(const RooUnblindCPAsymVar& other, const char* name=0);
  virtual TObject* clone(const char* newname) const { return new RooUnblindCPAsymVar(*this,newname); }  
  virtual ~RooUnblindCPAsymVar();

protected:

  // Function evaluation
  virtual Double_t evaluate() const ;

  RooRealProxy _asym ;
  RooBlindTools _blindEngine ;

  ClassDef(RooUnblindCPAsymVar,1) // CP-Asymmetry unblinding transformation
};

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