00001 /****************************************************************************/ 00007 // The car-following model abstraction 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 00020 00021 // =========================================================================== 00022 // included modules 00023 // =========================================================================== 00024 #ifdef _MSC_VER 00025 #include <windows_config.h> 00026 #else 00027 #include <config.h> 00028 #endif 00029 00030 #include "MSCFModel.h" 00031 #include "MSVehicleType.h" 00032 #include "MSVehicle.h" 00033 00034 00035 // =========================================================================== 00036 // method definitions 00037 // =========================================================================== 00038 MSCFModel::MSCFModel(const MSVehicleType* vtype, SUMOReal decel) throw() 00039 : myType(vtype), myDecel(decel) { 00040 myInverseTwoDecel = SUMOReal(1) / (SUMOReal(2) * decel); 00041 } 00042 00043 00044 MSCFModel::~MSCFModel() throw() {} 00045 00046 00047 void 00048 MSCFModel::leftVehicleVsafe(const MSVehicle * const ego, const MSVehicle * const neigh, SUMOReal &vSafe) const throw() { 00049 if (neigh!=0&&neigh->getSpeed()>60./3.6) { 00050 SUMOReal mgap = MAX2((SUMOReal) 0, neigh->getPositionOnLane()-neigh->getVehicleType().getLength()-ego->getPositionOnLane()); 00051 SUMOReal nVSafe = ffeV(ego, mgap, neigh->getSpeed()); 00052 if (mgap-neigh->getSpeed()>=0) { 00053 vSafe = MIN2(vSafe, nVSafe); 00054 } 00055 } 00056 } 00057 00058 00059 SUMOReal 00060 MSCFModel::maxNextSpeed(SUMOReal speed) const throw() { 00061 return MIN2(speed + (SUMOReal) ACCEL2SPEED(getMaxAccel(speed)), myType->getMaxSpeed()); 00062 } 00063 00064 00065 SUMOReal 00066 MSCFModel::brakeGap(SUMOReal speed) const throw() { 00067 return speed * speed * myInverseTwoDecel + speed * getTau(); 00068 } 00069 00070 00071 void MSCFModel::saveState(std::ostream &os) {} 00072
1.5.6