From 7cbf9dba5a382a1c67c4cf4659378a94d5ee5228 Mon Sep 17 00:00:00 2001 From: Kjetil Brakstad <64000017+kjbrak@users.noreply.github.com> Date: Thu, 24 Oct 2024 09:44:37 +0200 Subject: [PATCH] refactor: numpy2 ready - avoid Numpy DeprecationWarnings Will make ecalc ready for numpy 2 upgrade. * Closes issue ECALC-1531 * Changed some deprecated numpy functions to new ones. * Avoided calling float directly on arrays to get the first element with various approaches. * (It includes one small refactor to avoid a pydantic deprecation warning for test collection purposes.) --- .../compressor/train/simplified_train.py | 22 ++--- .../core/models/results/compressor.py | 4 +- src/libecalc/expression/expression.py | 8 +- .../cases/ltp_export/installation_setup.py | 87 ++++++++++--------- .../presentation/yaml/test_venting_emitter.py | 17 ++-- 5 files changed, 64 insertions(+), 74 deletions(-) diff --git a/src/libecalc/core/models/compressor/train/simplified_train.py b/src/libecalc/core/models/compressor/train/simplified_train.py index 7a967c7b75..af1fbc7d59 100644 --- a/src/libecalc/core/models/compressor/train/simplified_train.py +++ b/src/libecalc/core/models/compressor/train/simplified_train.py @@ -15,14 +15,9 @@ ) from libecalc.core.models.compressor.train.base import CompressorTrainModel from libecalc.core.models.compressor.train.chart import VariableSpeedCompressorChart -from libecalc.core.models.compressor.train.chart.chart_creator import ( - CompressorChartCreator, -) +from libecalc.core.models.compressor.train.chart.chart_creator import CompressorChartCreator from libecalc.core.models.compressor.train.fluid import FluidStream -from libecalc.core.models.compressor.train.stage import ( - CompressorTrainStage, - UndefinedCompressorStage, -) +from libecalc.core.models.compressor.train.stage import CompressorTrainStage, UndefinedCompressorStage from libecalc.core.models.compressor.train.utils.enthalpy_calculations import ( calculate_enthalpy_change_head_iteration, calculate_polytropic_head_campbell, @@ -511,18 +506,19 @@ def calculate_maximum_rate_given_outlet_pressure_single_calculation_point( expected_diff = 1e-3 max_iterations = 20 while not converged and i < max_iterations: - maximum_actual_volume_rate = float( + maximum_actual_volume_rate: float = float( maximum_rate_function( heads=polytropic_head, extrapolate_heads_below_minimum=False, ) ) - polytropic_efficiency = float( - compressor_chart.efficiency_as_function_of_rate_and_head( - rates=np.atleast_1d(maximum_actual_volume_rate), - heads=np.atleast_1d(polytropic_head), - ) + + efficiency_array: NDArray[np.float64] = compressor_chart.efficiency_as_function_of_rate_and_head( + rates=np.atleast_1d(maximum_actual_volume_rate), + heads=np.atleast_1d(polytropic_head), ) + polytropic_efficiency = efficiency_array[0] + polytropic_head = calculate_polytropic_head_campbell( polytropic_efficiency=polytropic_efficiency, kappa=kappa, diff --git a/src/libecalc/core/models/results/compressor.py b/src/libecalc/core/models/results/compressor.py index a8fd11650e..2c3bbc9cbf 100644 --- a/src/libecalc/core/models/results/compressor.py +++ b/src/libecalc/core/models/results/compressor.py @@ -227,11 +227,11 @@ def is_valid(self) -> List[bool]: ) stage_results_are_valid = ( - np.alltrue([stage.is_valid for stage in self.stage_results], axis=0) + np.all([stage.is_valid for stage in self.stage_results], axis=0) if self.stage_results is not None else [not isnan(x) for x in self.energy_usage] ) - return list(np.alltrue([failure_status_are_valid, turbine_are_valid, stage_results_are_valid], axis=0)) + return list(np.all([failure_status_are_valid, turbine_are_valid, stage_results_are_valid], axis=0)) @property def inlet_stream(self) -> CompressorStreamCondition: diff --git a/src/libecalc/expression/expression.py b/src/libecalc/expression/expression.py index ea3446dfc0..62609b2811 100644 --- a/src/libecalc/expression/expression.py +++ b/src/libecalc/expression/expression.py @@ -10,13 +10,7 @@ from libecalc.common.errors.exceptions import EcalcError, EcalcErrorType from libecalc.common.logger import logger -from libecalc.expression.expression_evaluator import ( - Operators, - Token, - TokenTag, - eval_tokens, - lexer, -) +from libecalc.expression.expression_evaluator import Operators, Token, TokenTag, eval_tokens, lexer LEFT_PARENTHESIS_TOKEN = Token(tag=TokenTag.operator, value=Operators.left_parenthesis.value) RIGHT_PARENTHESIS_TOKEN = Token(tag=TokenTag.operator, value=Operators.right_parenthesis.value) diff --git a/src/libecalc/fixtures/cases/ltp_export/installation_setup.py b/src/libecalc/fixtures/cases/ltp_export/installation_setup.py index 3ead68dd3d..0a43953d28 100644 --- a/src/libecalc/fixtures/cases/ltp_export/installation_setup.py +++ b/src/libecalc/fixtures/cases/ltp_export/installation_setup.py @@ -1,6 +1,8 @@ from datetime import datetime from typing import Dict, List +import numpy as np + import libecalc.common.component_type from libecalc.common.energy_usage_type import EnergyUsageType from libecalc.common.time_utils import Period @@ -363,107 +365,112 @@ def generator_set_mobile_diesel() -> GeneratorSet: ) -def expected_fuel_consumption(): - consumption = float(fuel_rate * days_year2_second_half * regularity_consumer) +def expected_fuel_consumption() -> float: + n_days = np.sum(days_year2_second_half) + consumption = float(fuel_rate * n_days * regularity_consumer) return consumption -def expected_diesel_consumption(): - consumption = float(diesel_rate * (days_year1_first_half + days_year2_first_half) * regularity_consumer) +def expected_diesel_consumption() -> float: + n_days = np.sum([days_year1_first_half, days_year2_first_half]) + consumption = float(diesel_rate * n_days * regularity_consumer) return consumption -def expected_pfs_el_consumption(): - consumption_mw_per_day = power_usage_mw * days_year1_second_half * regularity_consumer +def expected_pfs_el_consumption() -> float: + n_days = np.sum(days_year1_second_half) + consumption_mw_per_day = power_usage_mw * n_days * regularity_consumer consumption = float(Unit.MEGA_WATT_DAYS.to(Unit.GIGA_WATT_HOURS)(consumption_mw_per_day)) return consumption -def expected_gas_turbine_el_generated(): - consumption_mw_per_day = ( - power_usage_mw * (days_year1_first_half + days_year2_first_half + days_year2_second_half) * regularity_consumer - ) +def expected_gas_turbine_el_generated() -> float: + n_days = np.sum([(days_year1_first_half + days_year2_first_half + days_year2_second_half)]) + consumption_mw_per_day = power_usage_mw * n_days * regularity_consumer consumption = float(Unit.MEGA_WATT_DAYS.to(Unit.GIGA_WATT_HOURS)(consumption_mw_per_day)) return consumption -def expected_co2_from_fuel(): +def expected_co2_from_fuel() -> float: emission_kg_per_day = float(fuel_rate * co2_factor) emission_tons_per_day = Unit.KILO_PER_DAY.to(Unit.TONS_PER_DAY)(emission_kg_per_day) - emission_tons = float(emission_tons_per_day * days_year2_second_half * regularity_consumer) + n_days = np.sum(days_year2_second_half) + emission_tons = float(emission_tons_per_day * n_days * regularity_consumer) return emission_tons -def expected_co2_from_diesel(): +def expected_co2_from_diesel() -> float: emission_kg_per_day = float(diesel_rate * co2_factor) emission_tons_per_day = Unit.KILO_PER_DAY.to(Unit.TONS_PER_DAY)(emission_kg_per_day) - emission_tons = float(emission_tons_per_day * (days_year1_first_half + days_year2_first_half) * regularity_consumer) + n_days = np.sum([days_year1_first_half, days_year2_first_half]) + emission_tons = float(emission_tons_per_day * n_days * regularity_consumer) return emission_tons -def expected_ch4_from_diesel(): +def expected_ch4_from_diesel() -> float: emission_kg_per_day = float(diesel_rate * ch4_factor) emission_tons_per_day = Unit.KILO_PER_DAY.to(Unit.TONS_PER_DAY)(emission_kg_per_day) - emission_tons = float(emission_tons_per_day * (days_year1_first_half + days_year2_first_half) * regularity_consumer) + n_days = np.sum([days_year1_first_half, days_year2_first_half]) + emission_tons = float(emission_tons_per_day * n_days * regularity_consumer) return emission_tons -def expected_nox_from_diesel(): +def expected_nox_from_diesel() -> float: emission_kg_per_day = float(diesel_rate * nox_factor) emission_tons_per_day = Unit.KILO_PER_DAY.to(Unit.TONS_PER_DAY)(emission_kg_per_day) - emission_tons = float(emission_tons_per_day * (days_year1_first_half + days_year2_first_half) * regularity_consumer) + n_days = np.sum([days_year1_first_half, days_year2_first_half]) + emission_tons = float(emission_tons_per_day * n_days * regularity_consumer) return emission_tons -def expected_nmvoc_from_diesel(): +def expected_nmvoc_from_diesel() -> float: emission_kg_per_day = float(diesel_rate * nmvoc_factor) emission_tons_per_day = Unit.KILO_PER_DAY.to(Unit.TONS_PER_DAY)(emission_kg_per_day) - emission_tons = float(emission_tons_per_day * (days_year1_first_half + days_year2_first_half) * regularity_consumer) + n_days = np.sum([days_year1_first_half, days_year2_first_half]) + emission_tons = float(emission_tons_per_day * n_days * regularity_consumer) return emission_tons -def expected_offshore_wind_el_consumption(): - consumption_mw_per_day = ( - power_offshore_wind_mw * (days_year1_second_half + days_year2_second_half) * regularity_consumer - ) +def expected_offshore_wind_el_consumption() -> float: + n_days = np.sum([days_year1_second_half, days_year2_second_half]) + consumption_mw_per_day = power_offshore_wind_mw * n_days * regularity_consumer consumption = -float(Unit.MEGA_WATT_DAYS.to(Unit.GIGA_WATT_HOURS)(consumption_mw_per_day)) return consumption # Why is this the only one without regularity? -def expected_gas_turbine_compressor_el_consumption(): - consumption_mw_per_day = power_compressor_mw * (days_year1_second_half + days_year2_second_half) +def expected_gas_turbine_compressor_el_consumption() -> float: + n_days = np.sum([days_year1_second_half, days_year2_second_half]) + consumption_mw_per_day = power_compressor_mw * n_days consumption = float(Unit.MEGA_WATT_DAYS.to(Unit.GIGA_WATT_HOURS)(consumption_mw_per_day)) return consumption -def expected_boiler_fuel_consumption(): - consumption = float( - fuel_rate * (days_year1_first_half + days_year1_second_half + days_year2_first_half) * regularity_consumer - ) +def expected_boiler_fuel_consumption() -> float: + n_days = np.sum([days_year1_first_half, days_year1_second_half, days_year2_first_half]) + consumption = float(fuel_rate * n_days * regularity_consumer) return consumption -def expected_heater_fuel_consumption(): - consumption = float(fuel_rate * days_year2_second_half * regularity_consumer) +def expected_heater_fuel_consumption() -> float: + n_days = np.sum(days_year2_second_half) + consumption = float(fuel_rate * n_days * regularity_consumer) return consumption -def expected_co2_from_boiler(): +def expected_co2_from_boiler() -> float: emission_kg_per_day = float(fuel_rate * co2_factor) emission_tons_per_day = Unit.KILO_PER_DAY.to(Unit.TONS_PER_DAY)(emission_kg_per_day) - emission_tons = float( - emission_tons_per_day - * (days_year1_first_half + days_year1_second_half + days_year2_first_half) - * regularity_consumer - ) + n_days = np.sum([days_year1_first_half, days_year1_second_half, days_year2_first_half]) + emission_tons = float(emission_tons_per_day * n_days * regularity_consumer) return emission_tons -def expected_co2_from_heater(): +def expected_co2_from_heater() -> float: emission_kg_per_day = float(fuel_rate * co2_factor) emission_tons_per_day = Unit.KILO_PER_DAY.to(Unit.TONS_PER_DAY)(emission_kg_per_day) - emission_tons = float(emission_tons_per_day * days_year2_second_half * regularity_consumer) + n_days = np.sum(days_year2_second_half) + emission_tons = float(emission_tons_per_day * n_days * regularity_consumer) return emission_tons diff --git a/src/tests/libecalc/presentation/yaml/test_venting_emitter.py b/src/tests/libecalc/presentation/yaml/test_venting_emitter.py index 3561402664..8e33e27acc 100644 --- a/src/tests/libecalc/presentation/yaml/test_venting_emitter.py +++ b/src/tests/libecalc/presentation/yaml/test_venting_emitter.py @@ -11,13 +11,8 @@ from libecalc.dto.types import ConsumerUserDefinedCategoryType from libecalc.expression import Expression from libecalc.fixtures.cases import venting_emitters -from libecalc.fixtures.cases.ltp_export.utilities import ( - get_consumption, - get_sum_ltp_column, -) -from libecalc.fixtures.cases.venting_emitters.venting_emitter_yaml import ( - venting_emitter_yaml_factory, -) +from libecalc.fixtures.cases.ltp_export.utilities import get_consumption, get_sum_ltp_column +from libecalc.fixtures.cases.venting_emitters.venting_emitter_yaml import venting_emitter_yaml_factory from libecalc.presentation.yaml.yaml_types.emitters.yaml_venting_emitter import ( YamlDirectTypeEmitter, YamlOilTypeEmitter, @@ -101,6 +96,7 @@ def test_venting_emitter_oil_volume(variables_map): """ emitter_name = "venting_emitter" emission_factor = 0.1 + regularity_expected = 1.0 venting_emitter = YamlOilTypeEmitter( name=emitter_name, @@ -121,7 +117,7 @@ def test_venting_emitter_oil_volume(variables_map): ), ) - regularity = {Period(datetime(1900, 1, 1)): Expression.setup_from_expression(1)} + regularity = {Period(datetime(1900, 1, 1)): Expression.setup_from_expression(regularity_expected)} emission_rate = venting_emitter.get_emissions(expression_evaluator=variables_map, regularity=regularity)[ "ch4" @@ -136,10 +132,7 @@ def test_venting_emitter_oil_volume(variables_map): } emissions_ch4 = emission_result["ch4"] - regularity_evaluated = float( - Expression.evaluate(regularity[Period(datetime(1900, 1, 1))], fill_length=1, variables=variables_map.variables) - ) - expected_result = [oil_value * regularity_evaluated * emission_factor / 1000 for oil_value in oil_values()] + expected_result = [oil_value * regularity_expected * emission_factor / 1000 for oil_value in oil_values()] assert emissions_ch4.rate.values == expected_result