+#ifdef DO_GINAC_ASSERT
+ auto i = seq.begin();
+ while (i != seq.end()) {
+ auto ip1 = i+1;
+ if (ip1 != seq.end())
+ GINAC_ASSERT(!is_order_function(i->rest));
+ else
+ break;
+ GINAC_ASSERT(is_a<numeric>(i->coeff));
+ GINAC_ASSERT(ex_to<numeric>(i->coeff) < ex_to<numeric>(ip1->coeff));
+ ++i;
+ }
+#endif // def DO_GINAC_ASSERT
+ GINAC_ASSERT(is_a<relational>(rel_));
+ GINAC_ASSERT(is_a<symbol>(rel_.lhs()));
+ point = rel_.rhs();
+ var = rel_.lhs();
+}
+pseries::pseries(const ex &rel_, epvector &&ops_)
+ : seq(std::move(ops_))
+{
+#ifdef DO_GINAC_ASSERT
+ auto i = seq.begin();
+ while (i != seq.end()) {
+ auto ip1 = i+1;
+ if (ip1 != seq.end())
+ GINAC_ASSERT(!is_order_function(i->rest));
+ else
+ break;
+ GINAC_ASSERT(is_a<numeric>(i->coeff));
+ GINAC_ASSERT(ex_to<numeric>(i->coeff) < ex_to<numeric>(ip1->coeff));
+ ++i;
+ }
+#endif // def DO_GINAC_ASSERT