![]() |
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-2007 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 _ROADMAPCROSSING_HPP 00029 #define _ROADMAPCROSSING_HPP 00030 00031 #include <vector> 00032 #include <WNS/distribution/Uniform.hpp> 00033 #include <WNS/pyconfig/View.hpp> 00034 00035 #include <RISE/scenario/mobility/roadmap/MapUser.hpp> 00036 #include <RISE/scenario/mobility/roadmap/MapObject.hpp> 00037 00038 namespace rise { namespace scenario { namespace mobility { namespace roadmap { 00039 00040 typedef std::vector< std::vector<double> > matrix; 00041 matrix getMatrix(const wns::pyconfig::View& aView, const std::string& aName); 00042 00046 class Crossing : 00047 public MapObject 00048 { 00049 wns::Position position; 00050 std::vector<MapObject::ID> connections; 00051 std::vector< std::vector<double> > probMatrix; 00052 wns::distribution::StandardUniform* uniDis; 00053 public: 00055 Crossing(const wns::pyconfig::View& crossingView, Map* _map); 00056 virtual ~Crossing(){delete uniDis;}; 00058 virtual wns::Position getNextPosition(MapUser* user, simTimeType dt) const; 00060 virtual wns::Position getPosition(const MapUser* user) const; 00062 virtual std::vector<MapObject::ID> getDependencies() const; 00063 }; 00064 00065 }}}} 00066 00067 #endif // _ROADMAPCROSSING_HPP 00068 00069
1.5.5