2021-08-11 11:14:06 -04:00
|
|
|
"""
|
|
|
|
CaUsageParameters model the usage properties
|
|
|
|
SPDX - License - Identifier: LGPL - 3.0 - or -later
|
2022-04-08 09:35:33 -04:00
|
|
|
Copyright © 2022 Concordia CERC group
|
|
|
|
Project Coder Pilar Monsalvete Alvarez de Uribarri pilar.monsalvete@concordia.ca
|
2021-08-11 11:14:06 -04:00
|
|
|
"""
|
|
|
|
import sys
|
|
|
|
|
2022-03-24 16:51:01 -04:00
|
|
|
from imports.geometry.helpers.geometry_helper import GeometryHelper
|
2021-08-11 11:14:06 -04:00
|
|
|
from imports.usage.hft_usage_interface import HftUsageInterface
|
2022-03-24 16:51:01 -04:00
|
|
|
from imports.usage.helpers.usage_helper import UsageHelper
|
2021-08-11 11:14:06 -04:00
|
|
|
from city_model_structure.building_demand.usage_zone import UsageZone
|
|
|
|
from city_model_structure.building_demand.internal_gains import InternalGains
|
2022-03-17 18:49:44 -04:00
|
|
|
from city_model_structure.building_demand.occupancy import Occupancy
|
|
|
|
from city_model_structure.building_demand.appliances import Appliances
|
|
|
|
from city_model_structure.building_demand.thermal_control import ThermalControl
|
2021-08-11 11:14:06 -04:00
|
|
|
|
|
|
|
|
|
|
|
class CaUsageParameters(HftUsageInterface):
|
|
|
|
"""
|
|
|
|
CaUsageParameters class
|
|
|
|
"""
|
|
|
|
def __init__(self, city, base_path):
|
|
|
|
super().__init__(base_path, 'ca_archetypes_reduced.xml')
|
|
|
|
self._city = city
|
|
|
|
|
|
|
|
def enrich_buildings(self):
|
|
|
|
"""
|
|
|
|
Returns the city with the usage parameters assigned to the buildings
|
|
|
|
:return:
|
|
|
|
"""
|
|
|
|
city = self._city
|
|
|
|
for building in city.buildings:
|
2022-03-24 16:51:01 -04:00
|
|
|
usage = GeometryHelper().libs_usage_from_libs_function(building.function)
|
2022-03-17 18:49:44 -04:00
|
|
|
try:
|
2022-03-24 16:51:01 -04:00
|
|
|
archetype = self._search_archetype(usage)
|
2022-03-17 18:49:44 -04:00
|
|
|
except KeyError:
|
2021-08-11 11:14:06 -04:00
|
|
|
sys.stderr.write(f'Building {building.name} has unknown archetype for building function:'
|
2022-03-17 18:49:44 -04:00
|
|
|
f' {building.function}\n')
|
|
|
|
return
|
2022-03-08 20:08:03 -05:00
|
|
|
|
|
|
|
for internal_zone in building.internal_zones:
|
2021-08-11 11:14:06 -04:00
|
|
|
usage_zone = UsageZone()
|
2022-03-17 18:49:44 -04:00
|
|
|
usage_zone.usage = building.function
|
|
|
|
usage_zone.percentage = 1
|
|
|
|
self._assign_values_usage_zone(usage_zone, archetype)
|
|
|
|
internal_zone.usage_zones = [usage_zone]
|
2021-08-11 11:14:06 -04:00
|
|
|
|
2022-03-24 16:51:01 -04:00
|
|
|
def _search_archetype(self, libs_usage):
|
|
|
|
building_usage = UsageHelper().hft_from_libs_usage(libs_usage)
|
2021-08-11 11:14:06 -04:00
|
|
|
for building_archetype in self._usage_archetypes:
|
|
|
|
if building_archetype.usage == building_usage:
|
|
|
|
return building_archetype
|
|
|
|
return None
|
|
|
|
|
|
|
|
@staticmethod
|
2022-03-17 18:49:44 -04:00
|
|
|
def _assign_values_usage_zone(usage_zone, archetype):
|
2021-08-11 11:14:06 -04:00
|
|
|
# Due to the fact that python is not a typed language, the wrong object type is assigned to
|
|
|
|
# usage_zone.internal_gains when writing usage_zone.internal_gains = archetype.internal_gains.
|
|
|
|
# Therefore, this walk around has been done.
|
2022-03-17 18:49:44 -04:00
|
|
|
usage_zone.mechanical_air_change = archetype.mechanical_air_change
|
|
|
|
_occupancy = Occupancy()
|
|
|
|
_occupancy.occupancy_density = archetype.occupancy.occupancy_density
|
|
|
|
usage_zone.occupancy = _occupancy
|
2021-08-11 11:14:06 -04:00
|
|
|
usage_zone.hours_day = archetype.hours_day
|
|
|
|
usage_zone.days_year = archetype.days_year
|
2022-03-17 18:49:44 -04:00
|
|
|
_appliances = Appliances()
|
|
|
|
_appliances.appliances_density = archetype.appliances.appliances_density
|
|
|
|
usage_zone.appliances = _appliances
|
|
|
|
_control = ThermalControl()
|
|
|
|
_control.mean_heating_set_point = archetype.thermal_control.mean_heating_set_point
|
|
|
|
_control.heating_set_back = archetype.thermal_control.heating_set_back
|
|
|
|
_control.mean_cooling_set_point = archetype.thermal_control.mean_cooling_set_point
|
|
|
|
usage_zone.thermal_control = _control
|
|
|
|
_internal_gains = []
|
|
|
|
for archetype_internal_gain in archetype.not_detailed_source_mean_annual_internal_gains:
|
|
|
|
_internal_gain = InternalGains()
|
|
|
|
_internal_gain.average_internal_gain = archetype_internal_gain.average_internal_gain
|
|
|
|
_internal_gain.convective_fraction = archetype_internal_gain.convective_fraction
|
|
|
|
_internal_gain.radiative_fraction = archetype_internal_gain.radiative_fraction
|
|
|
|
_internal_gain.latent_fraction = archetype_internal_gain.latent_fraction
|
|
|
|
_internal_gains.append(_internal_gain)
|
|
|
|
usage_zone.not_detailed_source_mean_annual_internal_gains = _internal_gains
|