std::vector<_RealType> _M_int;
std::vector<double> _M_den;
std::vector<double> _M_cp;
+
+ template<typename _RealType1, typename _CharT, typename _Traits>
+ friend std::basic_ostream<_CharT, _Traits>&
+ operator<<(std::basic_ostream<_CharT, _Traits>&,
+ const std::piecewise_constant_distribution<_RealType1>&);
};
piecewise_constant_distribution()
std::vector<double> _M_den;
std::vector<double> _M_cp;
std::vector<double> _M_m;
+
+ template<typename _RealType1, typename _CharT, typename _Traits>
+ friend std::basic_ostream<_CharT, _Traits>&
+ operator<<(std::basic_ostream<_CharT, _Traits>&,
+ const std::piecewise_linear_distribution<_RealType1>&);
};
piecewise_linear_distribution()
__os.fill(__space);
__os.precision(std::numeric_limits<_RealType>::max_digits10);
- std::vector<_RealType> __int = __x.intervals();
- __os << __int.size() - 1;
-
- for (auto __xit = __int.begin(); __xit != __int.end(); ++__xit)
- __os << __space << *__xit;
-
- std::vector<double> __den = __x.densities();
- for (auto __dit = __den.begin(); __dit != __den.end(); ++__dit)
- __os << __space << *__dit;
+ const auto& __int = __x._M_param._M_int;
+ if (__int.empty())
+ __os << size_t(1)
+ << __space << _RealType(0) << __space << _RealType(1)
+ << __space << _RealType(1);
+ else
+ {
+ __os << __int.size() - 1;
+ for (auto __xv : __int)
+ __os << __space << __xv;
+ for (auto __dv : __x._M_param._M_den)
+ __os << __space << __dv;
+ }
__os.flags(__flags);
__os.fill(__fill);
__os.fill(__space);
__os.precision(std::numeric_limits<_RealType>::max_digits10);
- std::vector<_RealType> __int = __x.intervals();
- __os << __int.size() - 1;
-
- for (auto __xit = __int.begin(); __xit != __int.end(); ++__xit)
- __os << __space << *__xit;
-
- std::vector<double> __den = __x.densities();
- for (auto __dit = __den.begin(); __dit != __den.end(); ++__dit)
- __os << __space << *__dit;
+ auto const& __int = __x._M_param._M_int;
+ if (__int.empty())
+ __os << size_t(1)
+ << __space << _RealType(0) << __space << _RealType(1)
+ << __space << _RealType(1) << __space << _RealType(1);
+ else
+ {
+ __os << __int.size() - 1;
+ for (auto __xv : __int)
+ __os << __space << __xv;
+ for (auto __dv : __x._M_param._M_den)
+ __os << __space << __dv;
+ }
__os.flags(__flags);
__os.fill(__fill);