Source code for pythermalcomfort.models.vertical_tmp_grad_ppd

from __future__ import annotations

import numpy as np

from pythermalcomfort.classes_input import VerticalTGradPPDInputs
from pythermalcomfort.classes_return import VerticalTGradPPD
from pythermalcomfort.models import pmv_ppd_ashrae
from pythermalcomfort.utilities import Models, _check_ashrae55_compliance


[docs] def vertical_tmp_grad_ppd( tdb: float | list[float], tr: float | list[float], vr: float | list[float], rh: float | list[float], met: float | list[float], clo: float | list[float], vertical_tmp_grad: float | list[float], round_output: bool = True, limit_inputs: bool = True, ) -> VerticalTGradPPD: """Calculate the percentage of thermally dissatisfied people with a vertical temperature gradient between feet and head [55ASHRAE2023]_. This equation is only applicable for vr < 0.2 m/s (40 fps). Parameters ---------- tdb : float or list of floats Dry bulb air temperature, [°C]. .. note:: The air temperature is the average value over two heights: 0.6 m (24 in.) and 1.1 m (43 in.) for seated occupants and 1.1 m (43 in.) and 1.7 m (67 in.) for standing occupants. tr : float or list of floats Mean radiant temperature, [°C]. vr : float or list of floats Relative air speed, [m/s]. .. note:: vr is the relative air speed caused by body movement and not the air speed measured by the air speed sensor. The relative air speed is the sum of the average air speed measured by the sensor plus the activity-generated air speed (Vag). Where Vag is the activity-generated air speed caused by motion of individual body parts. vr can be calculated using the function :py:meth:`pythermalcomfort.utilities.v_relative`. rh : float or list of floats Relative humidity, [%]. met : float or list of floats Metabolic rate, [met]. clo : float or list of floats Clothing insulation, [clo]. .. note:: this is the basic insulation also known as the intrinsic clothing insulation value of the clothing ensemble (`I`:sub:`cl,r`), this is the thermal insulation from the skin surface to the outer clothing surface, including enclosed air layers, under actual environmental conditions. This value is not the total insulation (`I`:sub:`T,r`). The dynamic clothing insulation, clo, can be calculated using the function :py:meth:`pythermalcomfort.utilities.clo_dynamic_ashrae`. vertical_tmp_grad : float or list of floats Vertical temperature gradient between the feet and the head, [°C/m]. round_output : bool, optional If True, rounds output value. If False, it does not round it. Defaults to True. limit_inputs : bool, optional By default, if the inputs are outside the standard applicability limits the function returns nan. If False, returns values even if input values are outside the applicability limits of the model. Defaults to True. The applicability limits are 10 < tdb [°C] < 40, 10 < tr [°C] < 40, 0 < vr [m/s] < 0.2, 1 < met [met] < 4, and 0 < clo [clo] < 1.5. Returns ------- VerticalTGradPPD A dataclass containing the Predicted Percentage of Dissatisfied occupants with vertical temperature gradient and acceptability. See :py:class:`~pythermalcomfort.classes_return.VerticalTmpGradPPD` for more details. To access the `ppd_vg` and `acceptability` values, use the corresponding attributes of the returned `VerticalTmpGradPPD` instance, e.g., `result.ppd_vg`. Examples -------- .. code-block:: python from pythermalcomfort.models import vertical_tmp_grad_ppd result = vertical_tmp_grad_ppd( tdb=25, tr=25, vr=0.1, rh=50, met=1.2, clo=0.5, vertical_tmp_grad=7 ) print(result.ppd_vg) # 12.6 print(result.acceptability) # False """ # Validate inputs using the VerticalTmpGradPPDInputs class VerticalTGradPPDInputs( tdb=tdb, tr=tr, vr=vr, rh=rh, met=met, clo=clo, vertical_tmp_grad=vertical_tmp_grad, limit_inputs=limit_inputs, ) tdb = np.asarray(tdb) tr = np.asarray(tr) vr = np.asarray(vr) met = np.asarray(met) clo = np.asarray(clo) vertical_tmp_grad = np.asarray(vertical_tmp_grad) tsv = pmv_ppd_ashrae( tdb=tdb, tr=tr, vr=vr, rh=rh, met=met, clo=clo, model=Models.ashrae_55_2023.value, limit_inputs=False, ).pmv numerator = np.exp(0.13 * (tsv - 1.91) ** 2 + 0.15 * vertical_tmp_grad - 1.6) ppd_val = (numerator / (1 + numerator) - 0.345) * 100 acceptability = ppd_val <= 5 if round_output: ppd_val = np.round(ppd_val, 1) if limit_inputs: ( tdb_valid, tr_valid, met_valid, clo_valid, v_limited_valid, ) = _check_ashrae55_compliance( tdb=tdb, tr=tr, v_limited=vr, met=met, clo=clo, ) all_valid = ~( np.isnan(tdb_valid) | np.isnan(tr_valid) | np.isnan(met_valid) | np.isnan(clo_valid) | np.isnan(v_limited_valid) ) ppd_val = np.where(all_valid, ppd_val, np.nan) acceptability = np.where(all_valid, acceptability, np.nan) return VerticalTGradPPD(ppd_vg=ppd_val, acceptability=acceptability)