sub_normalize.hh

Go to the documentation of this file.
00001 // sub_normalize.hh: this file is part of the Vaucanson project.
00002 //
00003 // Vaucanson, a generic library for finite state machines.
00004 //
00005 // Copyright (C) 2005, 2006 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_SUB_NORMALIZE_HH
00018 # define VCSN_ALGORITHMS_SUB_NORMALIZE_HH
00019 
00020 
00035 # include <vaucanson/algebra/concept/freemonoid_product.hh>
00036 # include <vaucanson/automata/concept/copy.hh>
00037 # include <vaucanson/algorithms/cut_up.hh>
00038 # include <vector>
00039 
00040 namespace vcsn
00041 {
00042 
00052   template <class S, class T>
00053   Element<S, T>
00054   sub_normalize(const Element<S, T>& a);
00055 
00063   template <class S, class T1, class T2>
00064   void
00065   sub_normalize(const Element<S, T1>& a, Element<S, T2>& res);
00066 
00067 
00073   template <class S, class T>
00074   void
00075   sub_normalize_here(Element<S, T>& a);
00076 
00077 
00085   template <class S, class T>
00086   bool is_sub_normalized(const Element<S, T>& a);
00087 
00090 } // ! vcsn
00091 
00092 # if !defined VCSN_USE_INTERFACE_ONLY && !defined VCSN_USE_LIB
00093 #  include <vaucanson/algorithms/sub_normalize.hxx>
00094 # endif // VCSN_USE_INTERFACE_ONLY
00095 
00096 #endif // ! VCSN_ALGORITHMS_SUB_NORMALIZE_HH

Generated on Sun Jul 29 19:35:29 2007 for Vaucanson by  doxygen 1.5.2