from __future__ import absolute_import
from __future__ import print_function
import sys
import os
import subprocess
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
from sumolib import checkBinary
EDC = checkBinary("emissionsMap", os.path.join(
os.path.dirname(sys.argv[0]), '..', '..', '..', "bin"))
if len(sys.argv) > 2:
PHEMLIGHTp = sys.argv[2]
else:
PHEMLIGHTp = os.path.join(
os.environ["SUMO_HOME"], "data", "emissions", "PHEMlight")
if not os.path.exists(PHEMLIGHTp):
PHEMLIGHTp = os.path.join(os.path.dirname(
sys.argv[0]), '..', '..', '..', "data", "emissions", "PHEMlight")
fd = open("classes.txt")
emissionClasses = fd.readlines()
fd.close()
if emissionClasses[0].startswith("PHEMlight5"):
PHEMLIGHTp = os.path.join(PHEMLIGHTp, "V5")
if emissionClasses[0].startswith("HBEFA4"):
fdo = open("HBEFAresults.csv", "w")
else:
fdo = open("results.csv", "w")
for i, ec in enumerate(emissionClasses):
ec = ec.strip()
if len(ec) == 0:
continue
print("Running '%s'" % ec)
sys.stdout.flush()
sys.stderr.flush()
call = [EDC, "-e", ec, "-o", "tmp.csv", "--phemlight-path", PHEMLIGHTp,
"--v-max", "30",
"--v-step", "5",
"--a-step", "1",
"--s-min", "0",
"--s-max", "0",
]
call += sys.argv[2:]
retCode = subprocess.call(call)
sys.stdout.flush()
sys.stderr.flush()
if retCode != 0:
print("Error on building PHEMlight measurements")
sys.exit(1)
fdo.write("%s\n" % ec)
with open("tmp.csv") as fd:
fdo.write(fd.read())
fdo.write("-----\n\n")
fdo.close()