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