00001 /****************************************************************************/ 00007 // ------------------- 00008 /****************************************************************************/ 00009 // SUMO, Simulation of Urban MObility; see http://sumo.sourceforge.net/ 00010 // Copyright 2001-2010 DLR (http://www.dlr.de/) and contributors 00011 /****************************************************************************/ 00012 // 00013 // This program is free software; you can redistribute it and/or modify 00014 // it under the terms of the GNU General Public License as published by 00015 // the Free Software Foundation; either version 2 of the License, or 00016 // (at your option) any later version. 00017 // 00018 /****************************************************************************/ 00019 #ifndef NIVissimTrafficDescription_h 00020 #define NIVissimTrafficDescription_h 00021 00022 00023 // =========================================================================== 00024 // included modules 00025 // =========================================================================== 00026 #ifdef _MSC_VER 00027 #include <windows_config.h> 00028 #else 00029 #include <config.h> 00030 #endif 00031 00032 00033 #include <string> 00034 #include <map> 00035 #include "NIVissimVehicleClassVector.h" 00036 00037 // =========================================================================== 00038 // class definitions 00039 // =========================================================================== 00043 class NIVissimTrafficDescription { 00044 public: 00045 NIVissimTrafficDescription(int id, const std::string &name, 00046 const NIVissimVehicleClassVector &vehicleTypes); 00047 ~NIVissimTrafficDescription(); 00048 static bool dictionary(int id, const std::string &name, 00049 const NIVissimVehicleClassVector &vehicleTypes); 00050 static bool dictionary(int id, NIVissimTrafficDescription *o); 00051 static NIVissimTrafficDescription *dictionary(int id); 00052 static void clearDict(); 00053 static SUMOReal meanSpeed(int id); 00054 SUMOReal meanSpeed() const; 00055 private: 00056 int myID; 00057 std::string myName; 00058 NIVissimVehicleClassVector myVehicleTypes; 00059 private: 00060 typedef std::map<int, NIVissimTrafficDescription*> DictType; 00061 static DictType myDict; 00062 }; 00063 00064 00065 #endif 00066 00067 /****************************************************************************/ 00068
1.5.6