![]() |
User Manual, Developers Guide and API Documentation |
![]() |
00001 /******************************************************************************* 00002 * This file is part of openWNS (open Wireless Network Simulator) 00003 * _____________________________________________________________________________ 00004 * 00005 * Copyright (C) 2004-2009 00006 * Chair of Communication Networks (ComNets) 00007 * Kopernikusstr. 5, D-52074 Aachen, Germany 00008 * phone: ++49-241-80-27910, 00009 * fax: ++49-241-80-22242 00010 * email: info@openwns.org 00011 * www: http://www.openwns.org 00012 * _____________________________________________________________________________ 00013 * 00014 * openWNS is free software; you can redistribute it and/or modify it under the 00015 * terms of the GNU Lesser General Public License version 2 as published by the 00016 * Free Software Foundation; 00017 * 00018 * openWNS is distributed in the hope that it will be useful, but WITHOUT ANY 00019 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR 00020 * A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more 00021 * details. 00022 * 00023 * You should have received a copy of the GNU Lesser General Public License 00024 * along with this program. If not, see <http://www.gnu.org/licenses/>. 00025 * 00026 ******************************************************************************/ 00027 00028 #ifndef WNS_SCHEDULER_GROUPER_TREEBASEDGROUPER_HPP 00029 #define WNS_SCHEDULER_GROUPER_TREEBASEDGROUPER_HPP 00030 00031 #include <WNS/scheduler/SchedulerTypes.hpp> 00032 #include <WNS/scheduler/grouper/SpatialGrouper.hpp> 00033 #include <WNS/StaticFactory.hpp> 00034 #include <WNS/PyConfigViewCreator.hpp> 00035 #include <WNS/pyconfig/View.hpp> 00036 #include <WNS/CandI.hpp> 00037 #include <vector> 00038 00039 namespace wns { namespace scheduler { namespace grouper { 00040 00041 class TreeBasedGrouper : 00042 public SpatialGrouper 00043 { 00044 public: 00045 TreeBasedGrouper(const wns::pyconfig::View& config); 00046 ~TreeBasedGrouper() {}; 00047 00048 virtual Grouping getTxGrouping(const UserSet activeUsers, int maxBeams); 00049 virtual Grouping getRxGrouping(const UserSet activeUsers, int maxBeams); 00050 00051 protected: 00052 enum ModeType { 00053 rx = 0, 00054 tx 00055 }; 00056 typedef std::vector<UserSet> TreeLevel; 00057 00058 // pure virtual, to be implemented by the different Heuristics: 00059 virtual Grouping treeAlgorithm(const UserSet activeUsers, unsigned int maxBeams, ModeType mode) = 0; 00060 // basic functionality 00061 virtual float getTPfromTreeLevelByMode(TreeLevel level, ModeType mode); 00062 virtual Grouping convertTreeLevelToGrouping(TreeLevel level, ModeType mode); 00063 virtual std::map<UserID, wns::CandI> getCandIsForGroup(const UserSet group, ModeType mode); 00064 00065 std::map<UserID, wns::CandI> individualCandIs; 00066 00067 int MonteCarloTreeHeuristicProbe; 00068 }; 00069 00070 00071 }}} // namespace wns::scheduler::grouper 00072 #endif // WNS_SCHEDULER_GROUPER_TREEBASEDGROUPER_HPP 00073 00074
1.5.5