Eclipse SUMO - Simulation of Urban MObility
|
Helper methods for PHEMlight-based emission computation. More...
#include <HelpersPHEMlight.h>
Public Member Functions | |
void | addAllClassesInto (std::vector< SUMOEmissionClass > &list) const |
Add all known emission classes of this model to the given container. | |
virtual double | compute (const SUMOEmissionClass c, const PollutantsInterface::EmissionType e, const double v, const double a, const double slope, const EnergyParams *param) const |
Returns the amount of emitted pollutant given the vehicle type and state (in mg/s or in ml/s for fuel) | |
std::string | getAmitranVehicleClass (const SUMOEmissionClass c) const |
Returns the vehicle class described by this emission class as described in the Amitran interface (Passenger, ...) | |
SUMOEmissionClass | getClass (const SUMOEmissionClass base, const std::string &vClass, const std::string &fuel, const std::string &eClass, const double weight) const |
Returns the emission class described by the given parameters. | |
virtual SUMOEmissionClass | getClassByName (const std::string &eClass, const SUMOVehicleClass vc) |
Checks whether the string describes a known vehicle class. | |
const std::string | getClassName (const SUMOEmissionClass c) const |
Returns the complete name of the emission class including the model. | |
virtual double | getCoastingDecel (const SUMOEmissionClass c, const double v, const double a, const double slope, const EnergyParams *param) const |
Returns the maximum deceleration value (as a negative number), which can still be considered as non-braking. | |
int | getEuroClass (const SUMOEmissionClass c) const |
Returns the Euro emission class described by this emission class as described in the Amitran interface (0, ..., 6) | |
std::string | getFuel (const SUMOEmissionClass c) const |
Returns the fuel type described by this emission class as described in the Amitran interface (Gasoline, Diesel, ...) | |
virtual double | getModifiedAccel (const SUMOEmissionClass c, const double v, const double a, const double slope, const EnergyParams *param) const |
Returns the adapted acceleration value, useful for comparing with external PHEMlight references. | |
const std::string & | getName () const |
Returns the name of the model. | |
double | getWeight (const SUMOEmissionClass c) const |
Returns a reference weight in kg described by this emission class as described in the Amitran interface This implementation returns only meaningful values for Solo_LKW (truck without trailer) and LNF (light duty vehicles). | |
HelpersPHEMlight () | |
Constructor. | |
bool | includesClass (const SUMOEmissionClass c) const |
virtual bool | isSilent (const SUMOEmissionClass c) |
Returns whether the class denotes a silent vehicle for interfacing with the noise model. By default the first class in each model is the silent class. | |
virtual | ~HelpersPHEMlight () |
Destructor. | |
Protected Member Functions | |
HelpersPHEMlight (std::string name, const int baseIndex, const int defaultClass) | |
Constructor for subclasses. | |
Protected Attributes | |
const int | myBaseIndex |
the starting index for classes of this model | |
StringBijection< SUMOEmissionClass > | myEmissionClassStrings |
Mapping between emission class names and integer representations. | |
const std::string | myName |
the name of the model | |
bool | myVolumetricFuel |
return fuel consumption in l instead of mg | |
Static Protected Attributes | |
static const double | ZERO_SPEED_ACCURACY = .5 |
the lowest speed which allows reliable coasting calculations | |
Private Member Functions | |
double | getEmission (const PHEMCEP *oldCep, PHEMlightdll::CEP *currCep, const std::string &e, const double p, const double v) const |
Returns the amount of emitted pollutant given the vehicle type and state (in mg/s or in ml/s for fuel) | |
Private Attributes | |
PHEMlightdll::CEPHandler | myCEPHandler |
std::map< SUMOEmissionClass, PHEMlightdll::CEP * > | myCEPs |
PHEMlightdll::Helpers | myHelper |
int | myIndex |
the index of the next class | |
Static Private Attributes | |
static const int | PHEMLIGHT_BASE = 3 << 16 |
Helper methods for PHEMlight-based emission computation.
Definition at line 46 of file HelpersPHEMlight.h.
HelpersPHEMlight::HelpersPHEMlight | ( | ) |
Constructor.
Definition at line 43 of file HelpersPHEMlight.cpp.
|
virtual |
|
inlineprotected |
Constructor for subclasses.
[in] | name | the name of the model (string before the '/' in the emission class attribute) |
Definition at line 63 of file HelpersPHEMlight.h.
|
inherited |
Add all known emission classes of this model to the given container.
[in] | list | the vector to add to |
Definition at line 214 of file PollutantsInterface.cpp.
Referenced by PollutantsInterface::getAllClasses(), and PollutantsInterface::getAllClassesStr().
|
virtual |
Returns the amount of emitted pollutant given the vehicle type and state (in mg/s or in ml/s for fuel)
[in] | c | The vehicle emission class |
[in] | v | The vehicle's current velocity |
[in] | a | The vehicle's current acceleration |
[in] | slope | The road's slope at vehicle's position [deg] |
Reimplemented from PollutantsInterface::Helper.
Reimplemented in HelpersPHEMlight5.
Definition at line 273 of file HelpersPHEMlight.cpp.
References PHEMlightdll::CEP::CalcPower(), PHEMCEP::CalcPower(), PollutantsInterface::CO, PollutantsInterface::CO2, PollutantsInterface::ELEC, PollutantsInterface::FUEL, PHEMCEPHandler::GetCep(), PHEMlightdll::CEP::GetCO2Emission(), getEmission(), PHEMlightdll::CEP::getFuelType(), PHEMCEPHandler::getHandlerInstance(), getModifiedAccel(), PHEMCEP::GetVehicleFuelType(), PollutantsInterface::HC, IDLE_SPEED, EnergyParams::isEngineOff(), MAX2(), myCEPs, myHelper, PollutantsInterface::Helper::myVolumetricFuel, PollutantsInterface::NO_X, PollutantsInterface::PM_X, SECONDS_PER_HOUR, PHEMlightdll::Constants::strBEV, PHEMlightdll::Constants::strDiesel, PHEMlightdll::Constants::strGasoline, and PHEMlightdll::Constants::ZERO_SPEED_ACCURACY.
|
virtual |
Returns the vehicle class described by this emission class as described in the Amitran interface (Passenger, ...)
[in] | c | the emission class |
Reimplemented from PollutantsInterface::Helper.
Definition at line 169 of file HelpersPHEMlight.cpp.
References StringBijection< T >::getString(), and PollutantsInterface::Helper::myEmissionClassStrings.
|
virtual |
Returns the emission class described by the given parameters.
[in] | base | the base class giving the default |
[in] | vClass | the vehicle class as described in the Amitran interface (Passenger, ...) |
[in] | fuel | the fuel type as described in the Amitran interface (Gasoline, Diesel, ...) |
[in] | eClass | the emission class as described in the Amitran interface (Euro0, ...) |
[in] | weight | the vehicle weight in kg as described in the Amitran interface |
Reimplemented from PollutantsInterface::Helper.
Definition at line 106 of file HelpersPHEMlight.cpp.
References StringBijection< T >::get(), StringBijection< T >::hasString(), and PollutantsInterface::Helper::myEmissionClassStrings.
|
virtual |
Checks whether the string describes a known vehicle class.
[in] | eClass | The string describing the vehicle emission class |
Reimplemented from PollutantsInterface::Helper.
Reimplemented in HelpersPHEMlight5.
Definition at line 57 of file HelpersPHEMlight.cpp.
References StringBijection< T >::addAlias(), StringBijection< T >::get(), OptionsCont::getBool(), PHEMlightdll::CEPHandler::GetCEP(), PHEMlightdll::CEPHandler::getCEPS(), getClassByName(), PHEMlightdll::Helpers::getErrMsg(), PHEMlightdll::Helpers::getgClass(), PHEMCEPHandler::getHandlerInstance(), OptionsCont::getOptions(), StringBijection< T >::hasString(), PollutantsInterface::HEAVY_BIT, StringBijection< T >::insert(), myCEPHandler, myCEPs, PollutantsInterface::Helper::myEmissionClassStrings, myHelper, myIndex, PollutantsInterface::Helper::myVolumetricFuel, StringBijection< T >::remove(), PHEMlightdll::Helpers::setclass(), PHEMlightdll::Helpers::setCommentPrefix(), PHEMlightdll::Helpers::setPHEMDataV(), and StringUtils::to_lower_case().
Referenced by getClassByName().
|
inherited |
Returns the complete name of the emission class including the model.
[in] | c | the emission class |
Definition at line 124 of file PollutantsInterface.cpp.
Referenced by PollutantsInterface::getName().
|
virtual |
Returns the maximum deceleration value (as a negative number), which can still be considered as non-braking.
[in] | c | the emission class |
[in] | v | the speed value |
[in] | a | the acceleration value |
[in] | slope | The road's slope at vehicle's position [deg] |
[in] | param | parameter of the emission model affecting the computation |
Reimplemented from PollutantsInterface::Helper.
Reimplemented in HelpersPHEMlight5.
Definition at line 267 of file HelpersPHEMlight.cpp.
References myCEPs.
|
private |
Returns the amount of emitted pollutant given the vehicle type and state (in mg/s or in ml/s for fuel)
[in] | currCep | The vehicle emission class |
[in] | e | The emission type |
[in] | p | The vehicle's current power |
[in] | v | The vehicle's current velocity |
Definition at line 248 of file HelpersPHEMlight.cpp.
References PHEMlightdll::CEP::GetEmission(), PHEMCEP::GetEmission(), and myHelper.
Referenced by compute().
|
virtual |
Returns the Euro emission class described by this emission class as described in the Amitran interface (0, ..., 6)
[in] | c | the emission class |
Reimplemented from PollutantsInterface::Helper.
Definition at line 205 of file HelpersPHEMlight.cpp.
References StringBijection< T >::getString(), and PollutantsInterface::Helper::myEmissionClassStrings.
|
virtual |
Returns the fuel type described by this emission class as described in the Amitran interface (Gasoline, Diesel, ...)
[in] | c | the emission class |
Reimplemented from PollutantsInterface::Helper.
Reimplemented in HelpersPHEMlight5.
Definition at line 191 of file HelpersPHEMlight.cpp.
References StringBijection< T >::getString(), and PollutantsInterface::Helper::myEmissionClassStrings.
|
virtual |
Returns the adapted acceleration value, useful for comparing with external PHEMlight references.
[in] | c | the emission class |
[in] | v | the speed value |
[in] | a | the acceleration value |
[in] | slope | The road's slope at vehicle's position [deg] |
Reimplemented from PollutantsInterface::Helper.
Reimplemented in HelpersPHEMlight5.
Definition at line 257 of file HelpersPHEMlight.cpp.
References PHEMlightdll::CEP::GetMaxAccel(), MIN2(), and myCEPs.
Referenced by compute().
|
inherited |
Returns the name of the model.
Definition at line 107 of file PollutantsInterface.cpp.
|
virtual |
Returns a reference weight in kg described by this emission class as described in the Amitran interface This implementation returns only meaningful values for Solo_LKW (truck without trailer) and LNF (light duty vehicles).
[in] | c | the emission class |
Reimplemented from PollutantsInterface::Helper.
Definition at line 225 of file HelpersPHEMlight.cpp.
References StringBijection< T >::getString(), and PollutantsInterface::Helper::myEmissionClassStrings.
|
inherited |
Definition at line 220 of file PollutantsInterface.cpp.
|
virtualinherited |
Returns whether the class denotes a silent vehicle for interfacing with the noise model. By default the first class in each model is the silent class.
[in] | c | the emission class |
Definition at line 130 of file PollutantsInterface.cpp.
References PollutantsInterface::HEAVY_BIT.
Referenced by PollutantsInterface::isSilent().
|
protectedinherited |
the starting index for classes of this model
Definition at line 228 of file PollutantsInterface.h.
|
private |
Definition at line 148 of file HelpersPHEMlight.h.
Referenced by getClassByName().
|
private |
Definition at line 150 of file HelpersPHEMlight.h.
Referenced by compute(), getClassByName(), getCoastingDecel(), getModifiedAccel(), and ~HelpersPHEMlight().
|
protectedinherited |
Mapping between emission class names and integer representations.
Definition at line 234 of file PollutantsInterface.h.
Referenced by HelpersHBEFA3::getAmitranVehicleClass(), HelpersHBEFA4::getAmitranVehicleClass(), getAmitranVehicleClass(), HelpersHBEFA3::getClass(), HelpersHBEFA4::getClass(), getClass(), getClassByName(), HelpersPHEMlight5::getClassByName(), HelpersHBEFA3::getEuroClass(), HelpersHBEFA4::getEuroClass(), getEuroClass(), HelpersHBEFA3::getFuel(), HelpersHBEFA4::getFuel(), getFuel(), HelpersPHEMlight5::getFuel(), getWeight(), PollutantsInterface::Helper::Helper(), HelpersHBEFA::HelpersHBEFA(), HelpersHBEFA3::HelpersHBEFA3(), and HelpersHBEFA4::HelpersHBEFA4().
|
mutableprivate |
Definition at line 149 of file HelpersPHEMlight.h.
Referenced by compute(), getClassByName(), and getEmission().
|
private |
the index of the next class
Definition at line 147 of file HelpersPHEMlight.h.
Referenced by getClassByName().
|
protectedinherited |
the name of the model
Definition at line 225 of file PollutantsInterface.h.
|
protectedinherited |
return fuel consumption in l instead of mg
Definition at line 231 of file PollutantsInterface.h.
Referenced by HelpersHBEFA::compute(), HelpersHBEFA3::compute(), HelpersHBEFA4::compute(), compute(), HelpersPHEMlight5::compute(), getClassByName(), and HelpersPHEMlight5::getClassByName().
|
staticprivate |
Definition at line 48 of file HelpersPHEMlight.h.
|
staticprotectedinherited |
the lowest speed which allows reliable coasting calculations
Definition at line 222 of file PollutantsInterface.h.
Referenced by HelpersHBEFA::compute(), HelpersHBEFA3::compute(), and HelpersHBEFA4::compute().