crown  1.0.0
include/crown/CrownMappingILPBalanced.hpp
Go to the documentation of this file.
00001 /*
00002  Copyright 2015 Nicolas Melot
00003 
00004  This file is part of Pelib.
00005 
00006  Pelib is free software: you can redistribute it and/or modify
00007  it under the terms of the GNU General Public License as published by
00008  the Free Software Foundation, either version 3 of the License, or
00009  (at your option) any later version.
00010 
00011  Pelib is distributed in the hope that it will be useful,
00012  but WITHOUT ANY WARRANTY; without even the implied warranty of
00013  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
00014  GNU General Public License for more details.
00015 
00016  You should have received a copy of the GNU General Public License
00017  along with Pelib. If not, see <http://www.gnu.org/licenses/>.
00018 */
00019 
00020 #include <crown/CrownConfig.hpp>
00021 #include <crown/CrownMapping.hpp>
00022 #include <pelib/Platform.hpp>
00023 #include <pelib/Taskgraph.hpp>
00024 #include <pelib/Algebra.hpp>
00025 
00026 #ifndef CROWN_MAPPING_ILP_BALANCED
00027 #define CROWN_MAPPING_ILP_BALANCED
00028 
00029 namespace pelib
00030 {
00031 namespace crown
00032 {
00033         class CrownMappingILPBalanced: public CrownMapping
00034         {
00035                 public:
00036                         CrownMappingILPBalanced(const CrownConfig* = NULL, const CrownAllocation *alloc = NULL, bool showOutput = false, bool showError = false);
00037                         CrownMappingILPBalanced(const Algebra &param, const CrownConfig* = NULL, const CrownAllocation *alloc = NULL, bool showOutput = false, bool showError = false);
00038                         CrownMappingILPBalanced(const Taskgraph &tg, const Platform &pt, const Algebra &param, const CrownConfig* = NULL, const CrownAllocation *alloc = NULL, bool showOutput = false, bool showError = false);
00039                         virtual Algebra map(const Algebra&, std::map<const string, double> &stats) const;
00040                         std::string getShortDescription() const;
00041                         virtual float complexity(const Algebra &problem) const;
00042                         virtual float complexity(const Taskgraph&, const Platform&, const Algebra&, const CrownConfig* = NULL) const;
00043                         virtual CrownMapping* clone() const;
00044                 protected:
00045         };
00046 }
00047 }
00048 
00049 #endif
00050