hub/exports/exports_factory.py

95 lines
2.4 KiB
Python
Raw Normal View History

"""
ExportsFactory export a city into several formats
SPDX - License - Identifier: LGPL - 3.0 - or -later
Copyright © 2020 Project Author Guille Gutierrez guillermo.gutierrezmorote@concordia.ca
"""
from pathlib import Path
from os.path import exists
from exports.formats.stl import Stl
from exports.formats.obj import Obj
2021-03-16 20:14:40 -04:00
from exports.formats.energy_ade import EnergyAde
from exports.formats.simplified_radiosity_algorithm import SimplifiedRadiosityAlgorithm
2021-08-11 10:29:54 -04:00
from exports.formats.idf import Idf
2021-03-16 16:58:52 -04:00
class ExportsFactory:
"""
Exports factory class
"""
def __init__(self, export_type, city, path):
self._city = city
self._export_type = '_' + export_type.lower()
self._path = path
@property
def _citygml(self):
"""
2021-06-04 09:22:06 -04:00
Export to citygml_classes with application domain extensions
:return: None
"""
raise NotImplementedError
2021-03-16 20:14:40 -04:00
@property
def _energy_ade(self):
"""
2021-06-04 09:22:06 -04:00
Export to citygml_classes with application domain extensions
2021-03-16 20:14:40 -04:00
:return: None
"""
return EnergyAde(self._city, self._path)
@property
def _stl(self):
"""
Export the city geometry to stl
:return: None
"""
return Stl(self._city, self._path)
@property
def _obj(self):
"""
Export the city geometry to obj
:return: None
"""
return Obj(self._city, self._path)
@property
def _grounded_obj(self):
"""
Export the city geometry to obj
:return: None
"""
2021-03-16 16:58:52 -04:00
return Obj(self._city, self._path).to_ground_points()
@property
def _idf(self):
"""
Export the city to Energy+ idf format
:return:
"""
idf_data_path = (Path(__file__).parent / './formats/idf_files/').resolve()
# todo: create a get epw file function based on the city
weather_path = (Path(__file__).parent / '../data/weather/epw/CAN_PQ_Montreal.Intl.AP.716270_CWEC.epw').resolve()
Idf(self._city, self._path, (idf_data_path / f'Minimal.idf'), (idf_data_path / f'Energy+.idd'), weather_path)
@property
def _sra(self):
2021-04-13 19:00:28 -04:00
return SimplifiedRadiosityAlgorithm(self._city, (self._path / f'{self._city.name}_sra.xml'))
def export(self):
"""
Export the city model structure to the given export type
:return: None
"""
return getattr(self, self._export_type, lambda: None)
2021-08-12 11:58:24 -04:00
def _debug_export(self):
"""
Export the city model structure to the given export type
:return: None
"""
self._idf()