Several todos added
This commit is contained in:
parent
844a2241a6
commit
fa18c0445a
9
main.py
9
main.py
@ -15,25 +15,18 @@ try:
|
|||||||
energy_systems_format = 'montreal_custom'
|
energy_systems_format = 'montreal_custom'
|
||||||
|
|
||||||
out_path = (Path(__file__).parent / 'output_files')
|
out_path = (Path(__file__).parent / 'output_files')
|
||||||
tmp_folder = (Path(__file__).parent / 'tmp')
|
|
||||||
|
|
||||||
print('[simulation start]')
|
|
||||||
city = GeometryFactory('geojson',
|
city = GeometryFactory('geojson',
|
||||||
path=file_path,
|
path=file_path,
|
||||||
height_field='citygml_me',
|
height_field='citygml_me',
|
||||||
year_of_construction_field='ANNEE_CONS',
|
year_of_construction_field='ANNEE_CONS',
|
||||||
function_field='CODE_UTILI',
|
function_field='CODE_UTILI',
|
||||||
function_to_hub=Dictionaries().montreal_function_to_hub_function).city
|
function_to_hub=Dictionaries().montreal_function_to_hub_function).city
|
||||||
|
|
||||||
print(f'city created from {file_path}')
|
|
||||||
ConstructionFactory(construction_format, city).enrich()
|
ConstructionFactory(construction_format, city).enrich()
|
||||||
print('enrich constructions... done')
|
|
||||||
UsageFactory(usage_format, city).enrich()
|
UsageFactory(usage_format, city).enrich()
|
||||||
print('enrich usage... done')
|
|
||||||
|
|
||||||
MatSimEngine(city, 'output_files')
|
MatSimEngine(city, 'output_files')
|
||||||
|
|
||||||
# visualizer = MatSimVisualizer('output/output_network.xml.gz', 'output/output_events.xml.gz')
|
# visualizer = MatSimVisualizer('output_files/network.xml.gz', 'output_files/output_events.xml.gz')
|
||||||
# visualizer.visualize()
|
# visualizer.visualize()
|
||||||
|
|
||||||
except Exception as ex:
|
except Exception as ex:
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import math
|
||||||
import subprocess
|
import subprocess
|
||||||
import xmltodict
|
import xmltodict
|
||||||
|
|
||||||
@ -7,6 +8,9 @@ from shapely.geometry import Point
|
|||||||
from matsim_activity_to_matsim_schedule import MatsimActivityToMatsimSchedule
|
from matsim_activity_to_matsim_schedule import MatsimActivityToMatsimSchedule
|
||||||
from hub_function_to_matsim_activity import HubFunctionToMatsimActivity
|
from hub_function_to_matsim_activity import HubFunctionToMatsimActivity
|
||||||
|
|
||||||
|
|
||||||
|
# TODO: Please check this https://github.com/matsim-org/matsim-code-examples/issues/63 for the CRS in matsim should match the city
|
||||||
|
|
||||||
class MatSimEngine:
|
class MatSimEngine:
|
||||||
def __init__(self, city, output_file_path):
|
def __init__(self, city, output_file_path):
|
||||||
self._city = city
|
self._city = city
|
||||||
@ -29,18 +33,15 @@ class MatSimEngine:
|
|||||||
|
|
||||||
# 1- Facilities
|
# 1- Facilities
|
||||||
# TODO: Add the ability for a building to have multiple activities
|
# TODO: Add the ability for a building to have multiple activities
|
||||||
|
# TODO: this should come from the factories, please check idf generation
|
||||||
for building in city.buildings:
|
for building in city.buildings:
|
||||||
activity = hub_function_to_matsim.dictionary[building.function].split(',')
|
activity = hub_function_to_matsim.dictionary[building.function].split(',')
|
||||||
schedule = matsim_schedule.dictionary[activity[0]]
|
schedule = matsim_schedule.dictionary[activity[0]]
|
||||||
start_time, end_time = schedule.split('-')
|
start_time, end_time = schedule.split('-')
|
||||||
|
|
||||||
new_id = 0
|
for surface in building.grounds:
|
||||||
|
|
||||||
# TODO: building.grounds (TBD)
|
|
||||||
for surface in building.surfaces:
|
|
||||||
for coord in surface.solid_polygon.coordinates:
|
for coord in surface.solid_polygon.coordinates:
|
||||||
new_id += 1
|
buildings_shape_data['id'].append(f"{building.name}")
|
||||||
buildings_shape_data['id'].append(f"{new_id}_building.name")
|
|
||||||
buildings_shape_data['geometry'].append(Point(coord[0], coord[1]))
|
buildings_shape_data['geometry'].append(Point(coord[0], coord[1]))
|
||||||
|
|
||||||
facility = {
|
facility = {
|
||||||
@ -49,11 +50,22 @@ class MatSimEngine:
|
|||||||
'@y': str(building.centroid[1]),
|
'@y': str(building.centroid[1]),
|
||||||
'activity': []
|
'activity': []
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if len(building.thermal_zones_from_internal_zones) > 1:
|
||||||
|
raise NotImplementedError("multi-zone buildings aren't yet supported")
|
||||||
|
|
||||||
|
for thermal_zone in building.thermal_zones_from_internal_zones:
|
||||||
|
capacity = thermal_zone.occupancy.occupancy_density * building.floor_area * building.storeys_above_ground
|
||||||
|
for schedule in thermal_zone.occupancy.occupancy_schedules:
|
||||||
|
print(schedule.values) # TODO: use this schedules values to generate more accurate opentimes.
|
||||||
|
|
||||||
|
# TODO: check http://www.matsim.org/files/dtd/facilities_v1.dtd seems to be missing values here
|
||||||
|
|
||||||
for new_activity in activity:
|
for new_activity in activity:
|
||||||
facility['activity'].append({
|
facility['activity'].append({
|
||||||
'@type': new_activity,
|
'@type': new_activity,
|
||||||
'capacity': {
|
'capacity': {
|
||||||
'@value': '4.0' # TODO: Replace with a proper value taken from function
|
'@value': math.ceil(capacity)
|
||||||
},
|
},
|
||||||
'opentime': {
|
'opentime': {
|
||||||
'@day': 'wkday',
|
'@day': 'wkday',
|
||||||
@ -66,7 +78,7 @@ class MatSimEngine:
|
|||||||
|
|
||||||
gdf = gpd.GeoDataFrame(
|
gdf = gpd.GeoDataFrame(
|
||||||
buildings_shape_data,
|
buildings_shape_data,
|
||||||
crs="EPSG:26911"
|
crs=city.srs_name
|
||||||
)
|
)
|
||||||
|
|
||||||
gdf.to_file("input_files/buildings_shapefile.shp")
|
gdf.to_file("input_files/buildings_shapefile.shp")
|
||||||
@ -75,14 +87,20 @@ class MatSimEngine:
|
|||||||
xml_content = xmltodict.unparse(facilities_dict, pretty=True)
|
xml_content = xmltodict.unparse(facilities_dict, pretty=True)
|
||||||
|
|
||||||
# Write the XML to the file
|
# Write the XML to the file
|
||||||
with open(f"{output_file_path}/montreal_facilities.xml", 'w') as file:
|
with open(f"{output_file_path}/{city.name}_facilities.xml", 'w') as file:
|
||||||
file.write(xml_content)
|
file.write(xml_content)
|
||||||
|
|
||||||
# 2- Network
|
# 2- Network
|
||||||
# First get only the part of the network necessary for the simulation
|
# First get only the part of the network necessary for the simulation
|
||||||
java_path = "java"
|
java_path = "java"
|
||||||
jar_path = "matsim-network-from-osm.jar"
|
jar_path = "matsim-network-from-osm.jar"
|
||||||
command = [java_path, "-jar", jar_path, "input_files/merged-network.osm.pbf", "input_files/buildings_shapefile.shp", f"{output_file_path}/network.xml.gz"]
|
command = [
|
||||||
|
java_path,
|
||||||
|
"-jar", jar_path,
|
||||||
|
"input_files/merged-network.osm.pbf",
|
||||||
|
"input_files/buildings_shapefile.shp",
|
||||||
|
f"{output_file_path}/network.xml.gz"
|
||||||
|
]
|
||||||
subprocess.run(command)
|
subprocess.run(command)
|
||||||
|
|
||||||
# 3- Population
|
# 3- Population
|
||||||
@ -99,4 +117,4 @@ class MatSimEngine:
|
|||||||
# Must generate this config file first.
|
# Must generate this config file first.
|
||||||
# command.append(config_file_path)
|
# command.append(config_file_path)
|
||||||
|
|
||||||
subprocess.run(command)
|
subprocess.run(command)
|
||||||
|
Loading…
Reference in New Issue
Block a user