]> www.ginac.de Git - ginac.git/blobdiff - ginac/remember.cpp
- indentation is now done with tabs
[ginac.git] / ginac / remember.cpp
index 21e19716ca1f8961fad29fd231c374cf45c04b5a..2c442162ebb5bbf3aaf262564341b70ac5defb07 100644 (file)
@@ -36,22 +36,22 @@ namespace GiNaC {
 //////////
 
 remember_table_entry::remember_table_entry(function const & f, ex const & r) :
-    hashvalue(f.gethash()), seq(f.seq), result(r)
+       hashvalue(f.gethash()), seq(f.seq), result(r)
 {
-    ++last_access=access_counter;
-    successful_hits=0;
+       ++last_access=access_counter;
+       successful_hits=0;
 }
 
 bool remember_table_entry::is_equal(function const & f) const
 {
-    GINAC_ASSERT(f.seq.size()==seq.size());
-    if (f.gethash()!=hashvalue) return false;
-    for (unsigned i=0; i<seq.size(); ++i) {
-        if (!seq[i].is_equal(f.seq[i])) return false;
-    }
-    ++last_access=access_counter;
-    ++successful_hits;
-    return true;
+       GINAC_ASSERT(f.seq.size()==seq.size());
+       if (f.gethash()!=hashvalue) return false;
+       for (unsigned i=0; i<seq.size(); ++i) {
+               if (!seq[i].is_equal(f.seq[i])) return false;
+       }
+       ++last_access=access_counter;
+       ++successful_hits;
+       return true;
 }
 
 unsigned long remember_table_entry::access_counter=0;
@@ -62,75 +62,75 @@ unsigned long remember_table_entry::access_counter=0;
 
 remember_table_list::remember_table_list(unsigned as, unsigned strat)
 {
-    max_assoc_size=as;
-    remember_strategy=strat;
+       max_assoc_size=as;
+       remember_strategy=strat;
 }
 
 
 void remember_table_list::add_entry(function const & f, ex const & result)
 {
-    if ((max_assoc_size!=0)&&
-        (remember_strategy!=remember_strategies::delete_never)&&
-        (size()>=max_assoc_size)) {
-        // table is full, we must delete an older entry
-        GINAC_ASSERT(size()>0); // there must be at least one entry
+       if ((max_assoc_size!=0)&&
+               (remember_strategy!=remember_strategies::delete_never)&&
+               (size()>=max_assoc_size)) {
+               // table is full, we must delete an older entry
+               GINAC_ASSERT(size()>0); // there must be at least one entry
  
-        switch (remember_strategy) {
-        case remember_strategies::delete_cyclic:
-            // delete oldest entry (first in list)
-            erase(begin());
-            break;
-        case remember_strategies::delete_lru:
-            {
-                // delete least recently used entry
-                iterator it=begin();
-                iterator lowest_access_it=it;
-                unsigned long lowest_access=it->get_last_access();
-                ++it;
-                while (it!=end()) {
-                    if (it->get_last_access()<lowest_access) {
-                        lowest_access=it->get_last_access();
-                        lowest_access_it=it;
-                    }
-                    ++it;
-                }
-                erase(lowest_access_it);
-            }
-            break;
-        case remember_strategies::delete_lfu:
-            {
-                // delete least frequently used entry
-                iterator it=begin();
-                iterator lowest_hits_it=it;
-                unsigned lowest_hits=it->get_successful_hits();
-                ++it;
-                while (it!=end()) {
-                    if (it->get_successful_hits()<lowest_hits) {
-                        lowest_hits=it->get_successful_hits();
-                        lowest_hits_it=it;
-                    }
-                    ++it;
-                }
-                erase(lowest_hits_it);
-            }
-            break;
-        default:
-            throw(std::logic_error("remember_table_list::add_entry(): invalid remember_strategy"));
-        }
-        GINAC_ASSERT(size()==max_assoc_size-1);
-    }
-    push_back(remember_table_entry(f,result));
+               switch (remember_strategy) {
+               case remember_strategies::delete_cyclic:
+                       // delete oldest entry (first in list)
+                       erase(begin());
+                       break;
+               case remember_strategies::delete_lru:
+                       {
+                               // delete least recently used entry
+                               iterator it=begin();
+                               iterator lowest_access_it=it;
+                               unsigned long lowest_access=it->get_last_access();
+                               ++it;
+                               while (it!=end()) {
+                                       if (it->get_last_access()<lowest_access) {
+                                               lowest_access=it->get_last_access();
+                                               lowest_access_it=it;
+                                       }
+                                       ++it;
+                               }
+                               erase(lowest_access_it);
+                       }
+                       break;
+               case remember_strategies::delete_lfu:
+                       {
+                               // delete least frequently used entry
+                               iterator it=begin();
+                               iterator lowest_hits_it=it;
+                               unsigned lowest_hits=it->get_successful_hits();
+                               ++it;
+                               while (it!=end()) {
+                                       if (it->get_successful_hits()<lowest_hits) {
+                                               lowest_hits=it->get_successful_hits();
+                                               lowest_hits_it=it;
+                                       }
+                                       ++it;
+                               }
+                               erase(lowest_hits_it);
+                       }
+                       break;
+               default:
+                       throw(std::logic_error("remember_table_list::add_entry(): invalid remember_strategy"));
+               }
+               GINAC_ASSERT(size()==max_assoc_size-1);
+       }
+       push_back(remember_table_entry(f,result));
 }        
 
 bool remember_table_list::lookup_entry(function const & f, ex & result) const
 {
-    for (const_iterator cit=begin(); cit!=end(); ++cit) {
-        if (cit->is_equal(f)) {
-            result=cit->get_result();
-            return true;
-        }
-    }
-    return false;
+       for (const_iterator cit=begin(); cit!=end(); ++cit) {
+               if (cit->is_equal(f)) {
+                       result=cit->get_result();
+                       return true;
+               }
+       }
+       return false;
 }
 
 //////////
@@ -139,54 +139,54 @@ bool remember_table_list::lookup_entry(function const & f, ex & result) const
 
 remember_table::remember_table()
 {
-    table_size=0;
-    max_assoc_size=0;
-    remember_strategy=remember_strategies::delete_never;
+       table_size=0;
+       max_assoc_size=0;
+       remember_strategy=remember_strategies::delete_never;
 }
 
 remember_table::remember_table(unsigned s, unsigned as, unsigned strat) :
-    max_assoc_size(as), remember_strategy(strat)
+       max_assoc_size(as), remember_strategy(strat)
 {
-    // we keep max_assoc_size and remember_strategy if we need to clear
-    // all entries
+       // we keep max_assoc_size and remember_strategy if we need to clear
+       // all entries
 
-    // use some power of 2 next to s
-    table_size=1 << log2(s);
-    init_table();
+       // use some power of 2 next to s
+       table_size=1 << log2(s);
+       init_table();
 }
 
 bool remember_table::lookup_entry(function const & f, ex & result) const
 {
-    unsigned entry=f.gethash() & (table_size-1);
-    GINAC_ASSERT(entry<size());
-    return operator[](entry).lookup_entry(f,result);
+       unsigned entry=f.gethash() & (table_size-1);
+       GINAC_ASSERT(entry<size());
+       return operator[](entry).lookup_entry(f,result);
 }
 
 void remember_table::add_entry(function const & f, ex const & result)
 {
-    unsigned entry=f.gethash() & (table_size-1);
-    GINAC_ASSERT(entry<size());
-    operator[](entry).add_entry(f,result);
+       unsigned entry=f.gethash() & (table_size-1);
+       GINAC_ASSERT(entry<size());
+       operator[](entry).add_entry(f,result);
 }        
 
 void remember_table::clear_all_entries(void)
 {
-    clear();
-    init_table();
+       clear();
+       init_table();
 }
 
 void remember_table::init_table(void)
 {
-    reserve(table_size);
-    for (unsigned i=0; i<table_size; ++i) {
-        push_back(remember_table_list(max_assoc_size,remember_strategy));
-    }
+       reserve(table_size);
+       for (unsigned i=0; i<table_size; ++i) {
+               push_back(remember_table_list(max_assoc_size,remember_strategy));
+       }
 }
 
 std::vector<remember_table> & remember_table::remember_tables(void)
 {
-    static std::vector<remember_table> * rt = new std::vector<remember_table>;
-    return *rt;
+       static std::vector<remember_table> * rt = new std::vector<remember_table>;
+       return *rt;
 }
 
 #ifndef NO_NAMESPACE_GINAC