- GINAC_ASSERT(is_exactly_of_type(other, constant));
- const constant *o = static_cast<const constant *>(&other);
- return serial==o->serial;
+ GINAC_ASSERT(is_exactly_a<constant>(other));
+ const constant &o = static_cast<const constant &>(other);
+
+ if (serial == o.serial)
+ return 0;
+ else
+ return serial < o.serial ? -1 : 1;
+}
+
+bool constant::is_equal_same_type(const basic & other) const
+{
+ GINAC_ASSERT(is_exactly_a<constant>(other));
+ const constant &o = static_cast<const constant &>(other);
+
+ return serial == o.serial;
+}
+
+unsigned constant::calchash() const
+{
+ hashvalue = golden_ratio_hash(tinfo() ^ serial);
+
+ setflag(status_flags::hash_calculated);
+
+ return hashvalue;