2024-09-24 10:52:03 -04:00
|
|
|
from pathlib import Path
|
|
|
|
from building_modelling.ep_run_enrich import energy_plus_workflow
|
|
|
|
from hub.imports.geometry_factory import GeometryFactory
|
|
|
|
from hub.helpers.dictionaries import Dictionaries
|
|
|
|
from hub.imports.construction_factory import ConstructionFactory
|
|
|
|
from hub.imports.usage_factory import UsageFactory
|
|
|
|
from hub.imports.weather_factory import WeatherFactory
|
2024-09-25 05:49:28 -04:00
|
|
|
from enrich_demand import enrich
|
|
|
|
import pandas as pd
|
2024-09-24 10:52:03 -04:00
|
|
|
|
|
|
|
# Directory management
|
|
|
|
input_files_path = (Path(__file__).parent / 'input_files')
|
|
|
|
input_files_path.mkdir(parents=True, exist_ok=True)
|
|
|
|
geojson_file_path = input_files_path / 'Lachine_Geojson_Mixed_Use.geojson'
|
|
|
|
output_path = (Path(__file__).parent / 'out_files').resolve()
|
|
|
|
output_path.mkdir(parents=True, exist_ok=True)
|
|
|
|
energy_plus_output_path = output_path / 'energy_plus_outputs'
|
|
|
|
energy_plus_output_path.mkdir(parents=True, exist_ok=True)
|
|
|
|
simulation_results_path = (Path(__file__).parent / 'out_files' / 'simulation_results').resolve()
|
|
|
|
simulation_results_path.mkdir(parents=True, exist_ok=True)
|
|
|
|
sra_output_path = output_path / 'sra_outputs'
|
|
|
|
sra_output_path.mkdir(parents=True, exist_ok=True)
|
|
|
|
cost_analysis_output_path = output_path / 'cost_analysis'
|
2024-09-25 05:54:03 -04:00
|
|
|
cost_analysis_output_path.mkdir(parents=True, exist_ok=True)
|
2024-09-25 05:49:28 -04:00
|
|
|
lachine_output_path = output_path / 'lachine_outputs'
|
|
|
|
|
|
|
|
# Create City from HUB to run EP_Workflow
|
|
|
|
city_ep_workflow = GeometryFactory(
|
|
|
|
file_type='geojson',
|
|
|
|
path=geojson_file_path,
|
|
|
|
height_field='maximum_roof_height',
|
|
|
|
year_of_construction_field='year_built',
|
|
|
|
function_field='building_type',
|
|
|
|
function_to_hub=Dictionaries().montreal_function_to_hub_function
|
|
|
|
).city
|
|
|
|
|
|
|
|
ConstructionFactory('nrcan', city_ep_workflow).enrich()
|
|
|
|
UsageFactory('nrcan', city_ep_workflow).enrich()
|
|
|
|
WeatherFactory('epw', city_ep_workflow).enrich()
|
|
|
|
energy_plus_workflow(city_ep_workflow, energy_plus_output_path)
|
|
|
|
|
|
|
|
# Create City from HUB to use Grasshopper results
|
|
|
|
city_grasshopper = GeometryFactory(
|
|
|
|
file_type='geojson',
|
|
|
|
path=geojson_file_path,
|
|
|
|
height_field='maximum_roof_height',
|
|
|
|
year_of_construction_field='year_built',
|
|
|
|
function_field='building_type',
|
|
|
|
function_to_hub=Dictionaries().montreal_function_to_hub_function
|
|
|
|
).city
|
|
|
|
|
|
|
|
ConstructionFactory('nrcan', city_grasshopper).enrich()
|
|
|
|
UsageFactory('nrcan', city_grasshopper).enrich()
|
|
|
|
WeatherFactory('epw', city_grasshopper).enrich()
|
|
|
|
|
|
|
|
enrich(city_grasshopper)
|
|
|
|
|
|
|
|
# Collect data from city_ep_workflow
|
|
|
|
ep_building_data = []
|
|
|
|
|
|
|
|
for building in city_ep_workflow.buildings:
|
|
|
|
building_name = building.name
|
|
|
|
|
|
|
|
# Get total floor area
|
|
|
|
total_floor_area = 0
|
|
|
|
for zone in building.thermal_zones_from_internal_zones:
|
|
|
|
total_floor_area += zone.total_floor_area # Assuming area is in m^2
|
|
|
|
|
|
|
|
# Get yearly heating demand in Joules
|
|
|
|
yearly_heating_demand_J = building.heating_demand['year'][0] # Should be a single value
|
|
|
|
# Convert to kWh
|
|
|
|
yearly_heating_demand_kWh = yearly_heating_demand_J / 3.6e6
|
|
|
|
# Compute heating demand intensity (kWh/m²)
|
|
|
|
heating_demand_intensity = yearly_heating_demand_kWh / total_floor_area if total_floor_area > 0 else 0
|
|
|
|
|
|
|
|
# Get yearly cooling demand in Joules
|
|
|
|
yearly_cooling_demand_J = building.cooling_demand['year'][0] # Should be a single value
|
|
|
|
# Convert to kWh
|
|
|
|
yearly_cooling_demand_kWh = yearly_cooling_demand_J / 3.6e6
|
|
|
|
# Compute cooling demand intensity (kWh/m²)
|
|
|
|
cooling_demand_intensity = yearly_cooling_demand_kWh / total_floor_area if total_floor_area > 0 else 0
|
|
|
|
|
|
|
|
# Append data to list
|
|
|
|
ep_building_data.append({
|
|
|
|
'Building Name': building_name,
|
|
|
|
'Yearly Heating Demand EP (kWh)': yearly_heating_demand_kWh,
|
|
|
|
'Demand Intensity Heating EP (kWh/m²)': heating_demand_intensity,
|
|
|
|
'Yearly Cooling Demand EP (kWh)': yearly_cooling_demand_kWh,
|
|
|
|
'Demand Intensity Cooling EP (kWh/m²)': cooling_demand_intensity,
|
|
|
|
'Total Floor Area (m²)': total_floor_area
|
|
|
|
})
|
|
|
|
|
|
|
|
# Collect data from city_grasshopper
|
|
|
|
grasshopper_building_data = []
|
|
|
|
|
|
|
|
for building in city_grasshopper.buildings:
|
|
|
|
building_name = building.name
|
|
|
|
|
|
|
|
# Get total floor area
|
|
|
|
total_floor_area = 0
|
|
|
|
for zone in building.thermal_zones_from_internal_zones:
|
|
|
|
total_floor_area += zone.total_floor_area # Assuming area is in m^2
|
|
|
|
|
|
|
|
# Get yearly heating demand in Joules
|
|
|
|
yearly_heating_demand_J = building.heating_demand['year'][0] # Should be a single value
|
|
|
|
# Convert to kWh
|
|
|
|
yearly_heating_demand_kWh = yearly_heating_demand_J / 3.6e6
|
|
|
|
# Compute heating demand intensity (kWh/m²)
|
|
|
|
heating_demand_intensity = yearly_heating_demand_kWh / total_floor_area if total_floor_area > 0 else 0
|
|
|
|
|
|
|
|
# Get yearly cooling demand in Joules
|
|
|
|
yearly_cooling_demand_J = building.cooling_demand['year'][0] # Should be a single value
|
|
|
|
# Convert to kWh
|
|
|
|
yearly_cooling_demand_kWh = yearly_cooling_demand_J / 3.6e6
|
|
|
|
# Compute cooling demand intensity (kWh/m²)
|
|
|
|
cooling_demand_intensity = yearly_cooling_demand_kWh / total_floor_area if total_floor_area > 0 else 0
|
|
|
|
|
|
|
|
# Append data to list
|
|
|
|
grasshopper_building_data.append({
|
|
|
|
'Building Name': building_name,
|
|
|
|
'Yearly Heating Demand Grasshopper (kWh)': yearly_heating_demand_kWh,
|
|
|
|
'Demand Intensity Heating Grasshopper (kWh/m²)': heating_demand_intensity,
|
|
|
|
'Yearly Cooling Demand Grasshopper (kWh)': yearly_cooling_demand_kWh,
|
|
|
|
'Demand Intensity Cooling Grasshopper (kWh/m²)': cooling_demand_intensity
|
|
|
|
})
|
|
|
|
|
|
|
|
# Create DataFrames
|
|
|
|
ep_df = pd.DataFrame(ep_building_data)
|
|
|
|
grasshopper_df = pd.DataFrame(grasshopper_building_data)
|
|
|
|
|
|
|
|
# Merge DataFrames on 'Building Name' and 'Total Floor Area (m²)'
|
|
|
|
# Since Total Floor Area should be the same for both, we can use it from ep_df
|
|
|
|
merged_df = pd.merge(ep_df, grasshopper_df, on='Building Name')
|
|
|
|
|
|
|
|
# Rearrange columns if needed
|
|
|
|
merged_df = merged_df[[
|
|
|
|
'Building Name',
|
|
|
|
'Yearly Heating Demand EP (kWh)',
|
|
|
|
'Demand Intensity Heating EP (kWh/m²)',
|
|
|
|
'Yearly Cooling Demand EP (kWh)',
|
|
|
|
'Demand Intensity Cooling EP (kWh/m²)',
|
|
|
|
'Yearly Heating Demand Grasshopper (kWh)',
|
|
|
|
'Demand Intensity Heating Grasshopper (kWh/m²)',
|
|
|
|
'Yearly Cooling Demand Grasshopper (kWh)',
|
|
|
|
'Demand Intensity Cooling Grasshopper (kWh/m²)',
|
|
|
|
'Total Floor Area (m²)'
|
|
|
|
]]
|
|
|
|
|
|
|
|
# Write to Excel
|
|
|
|
output_excel_path = lachine_output_path / 'building_heating_cooling_demands.xlsx'
|
|
|
|
merged_df.to_excel(output_excel_path, index=False)
|