finite_support_conversion.hxx

00001 // finite_support_conversion.hxx: this file is part of the Vaucanson project.
00002 //
00003 // Vaucanson, a generic library for finite state machines.
00004 //
00005 // Copyright (C) 2001, 2002, 2003, 2004 The Vaucanson Group.
00006 //
00007 // This program is free software; you can redistribute it and/or
00008 // modify it under the terms of the GNU General Public License
00009 // as published by the Free Software Foundation; either version 2
00010 // of the License, or (at your option) any later version.
00011 //
00012 // The complete GNU General Public Licence Notice can be found as the
00013 // `COPYING' file in the root directory.
00014 //
00015 // The Vaucanson Group consists of people listed in the `AUTHORS' file.
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> // For zero_as.
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

Generated on Sat Jul 29 17:12:59 2006 for Vaucanson by  doxygen 1.4.6