87 std::pair< std::map<iterator, bool>, std::map<iterator, bool> >,
88 std::owner_less<std::weak_ptr<Ex>>
Definition lru_cache.hh:25
Base class for all algorithms, containing generic routines and in particular the logic for index clas...
Definition Algorithm.hh:59
Ex::iterator iterator
Definition Algorithm.hh:70
Ex & tr
Definition Algorithm.hh:151
A generic tree comparison class which will take into account index contractions and will also keep tr...
Definition Compare.hh:192
Basic storage class for symbolic mathemematical expressions.
Definition Storage.hh:142
result_t
Keeping track of what algorithms have done to this expression.
Definition Storage.hh:168
Definition sort_product.hh:8
Definition substitute.hh:59
Rules(size_t max_size_=1000, size_t cleanup_threshold_=100)
Definition substitute.hh:62
void store(Ex &rules, std::map< iterator, bool > &lhs_contains_dummies, std::map< iterator, bool > &rhs_contains_dummies)
Definition substitute.cc:466
LRUcache< std::weak_ptr< Ex >, std::pair< std::map< iterator, bool >, std::map< iterator, bool > >, std::owner_less< std::weak_ptr< Ex > > > properties
Definition substitute.hh:89
void retrieve(Ex &rules, std::map< iterator, bool > &lhs_contains_dummies, std::map< iterator, bool > &rhs_contains_dummies) const
Definition substitute.cc:497
size_t cleanup_threshold
Definition substitute.hh:93
bool is_present(Ex &rules) const
Definition substitute.cc:508
size_t size() const
Definition substitute.cc:535
void cleanup()
Definition substitute.cc:540
size_t max_size
Definition substitute.hh:91
Generic substitution algorithm.
Definition substitute.hh:14
sort_product sort_product_
Definition substitute.hh:53
static size_t cache_misses
Definition substitute.hh:100
static Rules replacement_rules
Definition substitute.hh:99
iterator conditions
Definition substitute.hh:48
iterator use_rule
Definition substitute.hh:47
bool partial
Definition substitute.hh:54
Ex & args
Definition substitute.hh:45
static size_t cache_hits
Definition substitute.hh:100
static size_t cache_size()
Return the number of substitution rules which have been pre-processed and sit in the cache.
Definition substitute.cc:461
std::map< iterator, bool > lhs_contains_dummies
Definition substitute.hh:50
std::map< iterator, bool > rhs_contains_dummies
Definition substitute.hh:50
virtual result_t apply(iterator &)
Definition substitute.cc:196
virtual bool can_apply(iterator st)
Match the lhs of the replacement rule to the subtree 'st' under consideration.
Definition substitute.cc:111
Ex_comparator comparator
Definition substitute.hh:38
Functions to handle the exchange properties of two or more symbols in a product.
Definition Adjform.cc:83
void set(rset_t::iterator &num, multiplier_t fac)
Definition Storage.cc:1063