![]() |
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_ALLPOSSIBLEGROUPSGROUPER_HPP 00029 #define WNS_SCHEDULER_GROUPER_ALLPOSSIBLEGROUPSGROUPER_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 <bitset> 00038 #include <vector> 00039 00040 #define MAX_STATIONS 64 00041 00042 namespace wns { namespace scheduler { namespace grouper { 00043 00044 class AllPossibleGroupsGrouper : 00045 public SpatialGrouper 00046 { 00047 public: 00048 AllPossibleGroupsGrouper(const wns::pyconfig::View& config) 00049 : SpatialGrouper(config) 00050 {}; 00051 ~AllPossibleGroupsGrouper() {}; 00052 00053 virtual Grouping getTxGrouping(const UserSet activeUsers, int maxBeams); 00054 virtual Grouping getRxGrouping(const UserSet activeUsers, int maxBeams); 00055 00056 virtual void setColleagues(RegistryProxyInterface* _registry); 00057 00058 protected: 00059 enum ModeType { 00060 rx = 0, 00061 tx 00062 }; 00063 00064 typedef struct 00065 { // datastructure to store the stations served in a beam and the 00066 // resulting throughput 00067 std::bitset<MAX_STATIONS> servedStations; 00068 float throughPut; 00069 } Beams; 00070 00071 typedef struct 00072 { // datastructure to store the stations served by a (preliminary) 00073 // grouping, the throughput achieved and the beams used. 00074 // The grouping is a partition of all served stations into groups 00075 // (the beams) 00076 std::bitset<MAX_STATIONS> servedStations; 00077 std::vector<int> groups; // store the group indices from allPossibleGroups 00078 float totalThroughput; 00079 } Partition; 00080 00081 virtual Partition makeGrouping(int maxBeams, unsigned int noOfStations) = 0; 00082 virtual std::map<UserID, wns::CandI> getCandIs(std::vector<UserID> users, std::bitset<MAX_STATIONS> bitset, ModeType mode); 00083 virtual std::vector<Beams> calculateAllPossibleGroups(std::vector<UserID> allUsers, unsigned int maxBeams, ModeType mode); 00084 virtual float getTPperGroupTrivialGrouping(int noOfStations); 00085 virtual Grouping convertPartitionToGrouping(Partition partition, ModeType mode, std::vector<UserID> allUsers); 00086 virtual std::vector<UserID> getServableUserVectorFromSet(const UserSet userSet, ModeType mode); 00087 00088 00089 std::vector<Beams> allPossibleGroups; 00090 00091 }; 00092 00093 00094 00095 }}} // namespace wns::scheduler::grouper 00096 00097 #endif // WNS_SCHEDULER_GROUPER_ALLPOSSIBLEGROUPSGROUPER 00098 00099
1.5.5