ROOT logo
/*****************************************************************************
 * Project: RooFit                                                           *
 * Package: RooFitCore                                                       *
 *    File: $Id: RooHashTable.h,v 1.12 2007/05/11 09:11:30 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_HASH_TABLE
#define ROO_HASH_TABLE

#include "TObject.h"
#include "TString.h"

class RooAbsArg ;
class RooLinkedList ;
class RooLinkedListElem ;
class RooSetPair ;
class RooArgSet ;

class RooHashTable : public TObject {
public:

  enum HashMethod { Pointer=0, Name=1, Intrinsic=2 } ;

  // Constructor
  RooHashTable(Int_t initSize = 17, HashMethod hashMethod=Name) ;
  RooHashTable(const RooHashTable& other) ;

  // Destructor
  virtual ~RooHashTable() ;

  void add(TObject* arg, TObject* hashArg=0) ;
  Bool_t remove(TObject* arg, TObject* hashArg=0) ;
  TObject* find(const char* name) const ;
  TObject* find(const TObject* arg) const ;
  RooLinkedListElem* findLinkTo(const TObject* arg) const ;
  RooSetPair* findSetPair(const RooArgSet* set1, const RooArgSet* set2) const ;  
  Bool_t replace(const TObject* oldArg, const TObject* newArg, const TObject* oldHashArg=0) ;
  Int_t size() const { return _size ; }
  Double_t avgCollisions() const ;

protected:  
  inline ULong_t hash(const TObject* arg) const {
    // Return hash value calculated by method chosen in constructor
    switch(_hashMethod) {
      case Pointer:   return TString::Hash((void*)(&arg),sizeof(void*)) ;
      case Name:      return TString::Hash(arg->GetName(),strlen(arg->GetName())) ;
      case Intrinsic: return arg->Hash() ;
    }
    return 0 ;
  }

  HashMethod _hashMethod ; // Hashing method
  Int_t _usedSlots ;       // Number of used slots
  Int_t _entries ;         // Number of entries stored
  Int_t _size ;            // Total number of slots
  RooLinkedList** _arr ;   //! Array of linked lists storing elements in each slot

  ClassDef(RooHashTable,1) // Hash table
};




#endif
 RooHashTable.h:1
 RooHashTable.h:2
 RooHashTable.h:3
 RooHashTable.h:4
 RooHashTable.h:5
 RooHashTable.h:6
 RooHashTable.h:7
 RooHashTable.h:8
 RooHashTable.h:9
 RooHashTable.h:10
 RooHashTable.h:11
 RooHashTable.h:12
 RooHashTable.h:13
 RooHashTable.h:14
 RooHashTable.h:15
 RooHashTable.h:16
 RooHashTable.h:17
 RooHashTable.h:18
 RooHashTable.h:19
 RooHashTable.h:20
 RooHashTable.h:21
 RooHashTable.h:22
 RooHashTable.h:23
 RooHashTable.h:24
 RooHashTable.h:25
 RooHashTable.h:26
 RooHashTable.h:27
 RooHashTable.h:28
 RooHashTable.h:29
 RooHashTable.h:30
 RooHashTable.h:31
 RooHashTable.h:32
 RooHashTable.h:33
 RooHashTable.h:34
 RooHashTable.h:35
 RooHashTable.h:36
 RooHashTable.h:37
 RooHashTable.h:38
 RooHashTable.h:39
 RooHashTable.h:40
 RooHashTable.h:41
 RooHashTable.h:42
 RooHashTable.h:43
 RooHashTable.h:44
 RooHashTable.h:45
 RooHashTable.h:46
 RooHashTable.h:47
 RooHashTable.h:48
 RooHashTable.h:49
 RooHashTable.h:50
 RooHashTable.h:51
 RooHashTable.h:52
 RooHashTable.h:53
 RooHashTable.h:54
 RooHashTable.h:55
 RooHashTable.h:56
 RooHashTable.h:57
 RooHashTable.h:58
 RooHashTable.h:59
 RooHashTable.h:60
 RooHashTable.h:61
 RooHashTable.h:62
 RooHashTable.h:63
 RooHashTable.h:64
 RooHashTable.h:65
 RooHashTable.h:66
 RooHashTable.h:67
 RooHashTable.h:68
 RooHashTable.h:69
 RooHashTable.h:70
 RooHashTable.h:71
 RooHashTable.h:72
 RooHashTable.h:73