From 3659a1175da35ac46702e76cc9b3acb3cb96d7a2 Mon Sep 17 00:00:00 2001 From: Drew Camron Date: Tue, 24 Dec 2024 12:04:36 -0700 Subject: [PATCH] update to process_units --- src/metpy/calc/thermo.py | 46 ++++++++++++++++++++++++---------------- 1 file changed, 28 insertions(+), 18 deletions(-) diff --git a/src/metpy/calc/thermo.py b/src/metpy/calc/thermo.py index edeb22d825..8420db8c59 100644 --- a/src/metpy/calc/thermo.py +++ b/src/metpy/calc/thermo.py @@ -31,7 +31,9 @@ @exporter.export @preprocess_and_wrap(wrap_like='specific_humidity') -@check_units('[dimensionless]') +@process_units(input_dimensionalities={'specific_humidity': 'dimensionless'}, + output_dimensionalities='[specific_heat_capacity]', + output_to='J K**-1 kg**-1 ') def moist_air_gas_constant(specific_humidity): r"""Calculate R_m, the specific gas constant for a parcel of moist air. @@ -62,13 +64,15 @@ def moist_air_gas_constant(specific_humidity): Eq 16, [Romps2017]_ using MetPy-defined constants in place of cited values. """ - return ((1 - specific_humidity) * mpconsts.dry_air_gas_constant - + specific_humidity * mpconsts.water_gas_constant) + return ((1 - specific_humidity) * mpconsts.nounit.Rd + + specific_humidity * mpconsts.nounit.Rv) @exporter.export @preprocess_and_wrap(wrap_like='specific_humidity') -@check_units('[dimensionless]') +@process_units(input_dimensionalities={'specific_humidity': 'dimensionless'}, + output_dimensionalities='[specific_heat_capacity]', + output_to='J K**-1 kg**-1 ') def moist_air_specific_heat_pressure(specific_humidity): r"""Calculate C_pm, the specific heat at constant pressure for a moist air parcel. @@ -99,13 +103,15 @@ def moist_air_specific_heat_pressure(specific_humidity): Eq 17, [Romps2017]_ using MetPy-defined constants in place of cited values. """ - return ((1 - specific_humidity) * mpconsts.dry_air_spec_heat_press - + specific_humidity * mpconsts.wv_specific_heat_press) + return ((1 - specific_humidity) * mpconsts.nounit.Cp_d + + specific_humidity * mpconsts.nounit.Cp_v) @exporter.export @preprocess_and_wrap(wrap_like='temperature') -@check_units('[temperature]') +@process_units(input_dimensionalities={'temperature': '[temperature]'}, + output_dimensionalities='[specific_enthalpy]', + output_to='J kg**-1') def water_latent_heat_vaporization(temperature): r"""Calculate the latent heat of vaporization for water. @@ -140,14 +146,16 @@ def water_latent_heat_vaporization(temperature): Eq 15, [Ambaum2020]_, using MetPy-defined constants in place of cited values. """ - return (mpconsts.water_heat_vaporization - - (mpconsts.water_specific_heat - mpconsts.wv_specific_heat_press) - * (temperature - mpconsts.water_triple_point_temperature)) + return (mpconsts.nounit.Lv + - (mpconsts.nounit.Cp_l - mpconsts.nounit.Cp_v) + * (temperature - mpconsts.nounit.T0)) @exporter.export @preprocess_and_wrap(wrap_like='temperature') -@check_units('[temperature]') +@process_units(input_dimensionalities={'temperature': '[temperature]'}, + output_dimensionalities='[specific_enthalpy]', + output_to='J kg**-1') def water_latent_heat_sublimation(temperature): r"""Calculate the latent heat of sublimation for water. @@ -180,14 +188,16 @@ def water_latent_heat_sublimation(temperature): Eq 18, [Ambaum2020]_, using MetPy-defined constants in place of cited values. """ - return (mpconsts.water_heat_sublimation - - (mpconsts.ice_specific_heat - mpconsts.wv_specific_heat_press) - * (temperature - mpconsts.water_triple_point_temperature)) + return (mpconsts.nounit.Ls + - (mpconsts.nounit.Cp_i - mpconsts.nounit.Cp_v) + * (temperature - mpconsts.nounit.T0)) @exporter.export @preprocess_and_wrap(wrap_like='temperature') -@check_units('[temperature]') +@process_units(input_dimensionalities={'temperature': '[temperature]'}, + output_dimensionalities='[specific_enthalpy]', + output_to='J kg**-1') def water_latent_heat_melting(temperature): r"""Calculate the latent heat of melting for water. @@ -221,9 +231,9 @@ def water_latent_heat_melting(temperature): Uses MetPy-defined constants in place of cited values. """ - return (mpconsts.water_heat_fusion - - (mpconsts.water_specific_heat - mpconsts.ice_specific_heat) - * (temperature - mpconsts.water_triple_point_temperature)) + return (mpconsts.nounit.Lf + - (mpconsts.nounit.Cp_l - mpconsts.nounit.Cp_i) + * (temperature - mpconsts.nounit.T0)) @exporter.export