User Manual, Developers Guide and API Documentation

AllPossibleGroupsGrouper.hpp

Go to the documentation of this file.
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 

Generated on Mon May 21 03:31:54 2012 for openWNS by  doxygen 1.5.5