hub/city_model_structure/building_demand/material.py

194 lines
4.0 KiB
Python
Raw Normal View History

2020-10-28 13:42:58 -04:00
"""
Material module
SPDX - License - Identifier: LGPL - 3.0 - or -later
Copyright © 2022 Concordia CERC group
Project Coder Guille Gutierrez guillermo.gutierrezmorote@concordia.ca
2020-10-28 13:42:58 -04:00
"""
2021-09-14 13:46:48 -04:00
from typing import Union
2020-10-28 13:42:58 -04:00
class Material:
"""
Material class
"""
2021-11-18 17:13:27 -05:00
def __init__(self):
self._id = None
self._name = None
2020-10-28 13:42:58 -04:00
self._conductivity = None
self._specific_heat = None
2021-11-18 17:13:27 -05:00
self._density = None
2020-10-28 13:42:58 -04:00
self._solar_absorptance = None
self._thermal_absorptance = None
self._visible_absorptance = None
self._no_mass = False
self._thermal_resistance = None
2021-11-18 16:55:49 -05:00
@property
def id(self):
"""
Get material id
:return: int
"""
return self._id
@id.setter
def id(self, value):
"""
Set material id
:param value: int
"""
self._id = int(value)
2020-10-28 13:42:58 -04:00
@property
def name(self):
"""
Get material name
:return: str
"""
return self._name
@name.setter
def name(self, value):
"""
Set material name
:param value: string
"""
2021-09-13 15:14:54 -04:00
self._name = str(value)
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def conductivity(self) -> Union[None, float]:
2020-10-28 13:42:58 -04:00
"""
Get material conductivity in W/mK
2021-09-14 13:46:48 -04:00
:return: None or float
2020-10-28 13:42:58 -04:00
"""
return self._conductivity
@conductivity.setter
def conductivity(self, value):
"""
Set material conductivity in W/mK
:param value: float
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._conductivity = float(value)
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def specific_heat(self) -> Union[None, float]:
2020-10-28 13:42:58 -04:00
"""
Get material conductivity in J/kgK
2021-09-14 13:46:48 -04:00
:return: None or float
2020-10-28 13:42:58 -04:00
"""
return self._specific_heat
@specific_heat.setter
def specific_heat(self, value):
"""
Get material conductivity in J/kgK
:param value: float
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._specific_heat = float(value)
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def density(self) -> Union[None, float]:
2020-10-28 13:42:58 -04:00
"""
Get material density in kg/m3
2021-09-14 13:46:48 -04:00
:return: None or float
2020-10-28 13:42:58 -04:00
"""
return self._density
@density.setter
def density(self, value):
"""
2021-11-18 16:55:49 -05:00
Set material density
2020-10-28 13:42:58 -04:00
:param value: float
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._density = float(value)
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def solar_absorptance(self) -> Union[None, float]:
2020-10-28 13:42:58 -04:00
"""
Get material solar absorptance
2021-09-14 13:46:48 -04:00
:return: None or float
2020-10-28 13:42:58 -04:00
"""
return self._solar_absorptance
@solar_absorptance.setter
def solar_absorptance(self, value):
"""
Set material solar absorptance
:param value: float
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._solar_absorptance = float(value)
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def thermal_absorptance(self) -> Union[None, float]:
2020-10-28 13:42:58 -04:00
"""
Get material thermal absorptance
2021-09-14 13:46:48 -04:00
:return: None or float
2020-10-28 13:42:58 -04:00
"""
return self._thermal_absorptance
@thermal_absorptance.setter
def thermal_absorptance(self, value):
"""
Set material thermal absorptance
:param value: float
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._thermal_absorptance = float(value)
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def visible_absorptance(self) -> Union[None, float]:
2020-10-28 13:42:58 -04:00
"""
Get material visible absorptance
2021-09-14 13:46:48 -04:00
:return: None or float
2020-10-28 13:42:58 -04:00
"""
return self._visible_absorptance
@visible_absorptance.setter
def visible_absorptance(self, value):
"""
Set material visible absorptance
:param value: float
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._visible_absorptance = float(value)
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def no_mass(self) -> Union[None, bool]:
2020-10-28 13:42:58 -04:00
"""
Get material no mass flag
2021-09-14 13:46:48 -04:00
:return: None or Boolean
2020-10-28 13:42:58 -04:00
"""
return self._no_mass
@no_mass.setter
def no_mass(self, value):
"""
Set material no mass flag
:param value: Boolean
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._no_mass = value
2020-10-28 13:42:58 -04:00
@property
2021-09-14 13:46:48 -04:00
def thermal_resistance(self) -> Union[None, float]:
2020-10-28 13:42:58 -04:00
"""
Get material thermal resistance in m2K/W
2021-09-14 13:46:48 -04:00
:return: None or float
2020-10-28 13:42:58 -04:00
"""
return self._thermal_resistance
@thermal_resistance.setter
def thermal_resistance(self, value):
"""
Set material thermal resistance in m2K/W
:param value: float
"""
2021-09-14 13:46:48 -04:00
if value is not None:
self._thermal_resistance = float(value)