| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215 |
- // Copyright 2015-2017 Hans Dembinski
- //
- // Distributed under the Boost Software License, Version 1.0.
- // (See accompanying file LICENSE_1_0.txt
- // or copy at http://www.boost.org/LICENSE_1_0.txt)
- #ifndef BOOST_HISTOGRAM_SERIALIZATION_HPP
- #define BOOST_HISTOGRAM_SERIALIZATION_HPP
- #include <boost/assert.hpp>
- #include <boost/histogram/accumulators/mean.hpp>
- #include <boost/histogram/accumulators/sum.hpp>
- #include <boost/histogram/accumulators/weighted_mean.hpp>
- #include <boost/histogram/accumulators/weighted_sum.hpp>
- #include <boost/histogram/axis/category.hpp>
- #include <boost/histogram/axis/integer.hpp>
- #include <boost/histogram/axis/regular.hpp>
- #include <boost/histogram/axis/variable.hpp>
- #include <boost/histogram/axis/variant.hpp>
- #include <boost/histogram/histogram.hpp>
- #include <boost/histogram/storage_adaptor.hpp>
- #include <boost/histogram/unlimited_storage.hpp>
- #include <boost/histogram/unsafe_access.hpp>
- #include <boost/mp11/tuple.hpp>
- #include <boost/serialization/array.hpp>
- #include <boost/serialization/map.hpp>
- #include <boost/serialization/nvp.hpp>
- #include <boost/serialization/string.hpp>
- #include <boost/serialization/variant.hpp>
- #include <boost/serialization/vector.hpp>
- #include <tuple>
- #include <type_traits>
- /**
- \file boost/histogram/serialization.hpp
- Implemenations of the serialization functions using
- [Boost.Serialization](https://www.boost.org/doc/libs/develop/libs/serialization/doc/index.html).
- */
- #ifndef BOOST_HISTOGRAM_DOXYGEN_INVOKED
- namespace std {
- template <class Archive, class... Ts>
- void serialize(Archive& ar, tuple<Ts...>& t, unsigned /* version */) {
- ::boost::mp11::tuple_for_each(
- t, [&ar](auto& x) { ar& boost::serialization::make_nvp("item", x); });
- }
- } // namespace std
- namespace boost {
- namespace histogram {
- namespace accumulators {
- template <class RealType>
- template <class Archive>
- void sum<RealType>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("large", large_);
- ar& serialization::make_nvp("small", small_);
- }
- template <class RealType>
- template <class Archive>
- void weighted_sum<RealType>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("sum_of_weights", sum_of_weights_);
- ar& serialization::make_nvp("sum_of_weights_squared", sum_of_weights_squared_);
- }
- template <class RealType>
- template <class Archive>
- void mean<RealType>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("sum", sum_);
- ar& serialization::make_nvp("mean", mean_);
- ar& serialization::make_nvp("sum_of_deltas_squared", sum_of_deltas_squared_);
- }
- template <class RealType>
- template <class Archive>
- void weighted_mean<RealType>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("sum_of_weights", sum_of_weights_);
- ar& serialization::make_nvp("sum_of_weights_squared", sum_of_weights_squared_);
- ar& serialization::make_nvp("weighted_mean", weighted_mean_);
- ar& serialization::make_nvp("sum_of_weighted_deltas_squared",
- sum_of_weighted_deltas_squared_);
- }
- } // namespace accumulators
- namespace axis {
- namespace transform {
- template <class Archive>
- void serialize(Archive&, id&, unsigned /* version */) {}
- template <class Archive>
- void serialize(Archive&, log&, unsigned /* version */) {}
- template <class Archive>
- void serialize(Archive&, sqrt&, unsigned /* version */) {}
- template <class Archive>
- void serialize(Archive& ar, pow& t, unsigned /* version */) {
- ar& serialization::make_nvp("power", t.power);
- }
- } // namespace transform
- template <class Archive>
- void serialize(Archive&, null_type&, unsigned /* version */) {}
- template <class T, class Tr, class M, class O>
- template <class Archive>
- void regular<T, Tr, M, O>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("transform", static_cast<transform_type&>(*this));
- ar& serialization::make_nvp("size", size_meta_.first());
- ar& serialization::make_nvp("meta", size_meta_.second());
- ar& serialization::make_nvp("min", min_);
- ar& serialization::make_nvp("delta", delta_);
- }
- template <class T, class M, class O>
- template <class Archive>
- void integer<T, M, O>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("size", size_meta_.first());
- ar& serialization::make_nvp("meta", size_meta_.second());
- ar& serialization::make_nvp("min", min_);
- }
- template <class T, class M, class O, class A>
- template <class Archive>
- void variable<T, M, O, A>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("seq", vec_meta_.first());
- ar& serialization::make_nvp("meta", vec_meta_.second());
- }
- template <class T, class M, class O, class A>
- template <class Archive>
- void category<T, M, O, A>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("seq", vec_meta_.first());
- ar& serialization::make_nvp("meta", vec_meta_.second());
- }
- template <class... Ts>
- template <class Archive>
- void variant<Ts...>::serialize(Archive& ar, unsigned /* version */) {
- ar& serialization::make_nvp("variant", impl);
- }
- } // namespace axis
- namespace detail {
- template <class Archive, class T>
- void serialize(Archive& ar, vector_impl<T>& impl, unsigned /* version */) {
- ar& serialization::make_nvp("vector", static_cast<T&>(impl));
- }
- template <class Archive, class T>
- void serialize(Archive& ar, array_impl<T>& impl, unsigned /* version */) {
- ar& serialization::make_nvp("size", impl.size_);
- ar& serialization::make_nvp("array",
- serialization::make_array(&impl.front(), impl.size_));
- }
- template <class Archive, class T>
- void serialize(Archive& ar, map_impl<T>& impl, unsigned /* version */) {
- ar& serialization::make_nvp("size", impl.size_);
- ar& serialization::make_nvp("map", static_cast<T&>(impl));
- }
- template <class Archive, class Allocator>
- void serialize(Archive& ar, mp_int<Allocator>& x, unsigned /* version */) {
- ar& serialization::make_nvp("data", x.data);
- }
- } // namespace detail
- template <class Archive, class T>
- void serialize(Archive& ar, storage_adaptor<T>& s, unsigned /* version */) {
- ar& serialization::make_nvp("impl", static_cast<detail::storage_adaptor_impl<T>&>(s));
- }
- template <class A>
- template <class Archive>
- void unlimited_storage<A>::serialize(Archive& ar, unsigned /* version */) {
- if (Archive::is_loading::value) {
- buffer_type dummy(buffer.alloc);
- std::size_t size;
- ar& serialization::make_nvp("type", dummy.type);
- ar& serialization::make_nvp("size", size);
- dummy.apply([this, size](auto* tp) {
- BOOST_ASSERT(tp == nullptr);
- using T = detail::remove_cvref_t<decltype(*tp)>;
- buffer.template make<T>(size);
- });
- } else {
- ar& serialization::make_nvp("type", buffer.type);
- ar& serialization::make_nvp("size", buffer.size);
- }
- buffer.apply([this, &ar](auto* tp) {
- using T = detail::remove_cvref_t<decltype(*tp)>;
- ar& serialization::make_nvp(
- "buffer",
- serialization::make_array(reinterpret_cast<T*>(buffer.ptr), buffer.size));
- });
- }
- template <class Archive, class A, class S>
- void serialize(Archive& ar, histogram<A, S>& h, unsigned /* version */) {
- ar& serialization::make_nvp("axes", unsafe_access::axes(h));
- ar& serialization::make_nvp("storage", unsafe_access::storage(h));
- }
- } // namespace histogram
- } // namespace boost
- #endif
- #endif
|