00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017 #ifndef VCSN_ALGORITHMS_FINITE_SUPPORT_CONVERSION_HXX
00018 # define VCSN_ALGORITHMS_FINITE_SUPPORT_CONVERSION_HXX
00019
00020 # include <vaucanson/algorithms/finite_support_conversion.hh>
00021 # include <vaucanson/algebra/concept/monoid_base.hh>
00022
00023 # include <vaucanson/misc/contract.hh>
00024
00025 namespace vcsn
00026 {
00027
00028 template<typename S, typename T, typename Ss, typename Ts>
00029 void finite_support_convert(Element<S, T>& dst, const Element<Ss, Ts>& org)
00030 {
00031 precondition(org.is_finite_app());
00032
00033 typedef typename Element<S, T>::monoid_elt_t me_t;
00034 typedef typename Element<S, T>::semiring_elt_t se_t;
00035 typedef typename Element<Ss, Ts>::monoid_elt_t sme_t;
00036 typedef typename Element<Ss, Ts>::semiring_elt_t sse_t;
00037
00038 typedef typename Element<Ss, Ts>::support_t support_t;
00039
00040 dst = algebra::zero_as<T>::of(dst.structure());
00041
00042 const support_t& org_supp = org.supp();
00043 for (typename support_t::const_iterator i = org_supp.begin();
00044 i != org_supp.end();
00045 ++i)
00046 {
00047 const sme_t &sm = sme_t(org.structure().monoid(), *i);
00048
00049 const me_t &m = me_t(dst.structure().monoid(), sm);
00050 const se_t &w = se_t(dst.structure().semiring(), org.get(sm));
00051
00052 dst += w * Element<S, T>(dst.structure(), m);
00053 }
00054
00055 postcondition(dst.is_finite_app());
00056 }
00057
00058 }
00059
00060 #endif // ! VCSN_ALGORITHMS_FINITE_SUPPORT_CONVERSION_HXX