Skip to content

Commit

Permalink
Use SimplePowerFormula in ProducerPowerFormula
Browse files Browse the repository at this point in the history
This should simplify code

Signed-off-by: Elzbieta Kotulska <[email protected]>
  • Loading branch information
ela-kotulska-frequenz committed Aug 29, 2024
1 parent 54a6877 commit ff0c626
Showing 1 changed file with 21 additions and 33 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,10 @@
from ._fallback_formula_metric_fetcher import FallbackFormulaMetricFetcher
from ._formula_generator import (
NON_EXISTING_COMPONENT_ID,
ComponentNotFound,
FormulaGenerator,
FormulaGeneratorConfig,
)
from ._simple_power_formula import SimplePowerFormula

_logger = logging.getLogger(__name__)

Expand Down Expand Up @@ -50,39 +50,27 @@ def generate( # noqa: DOC502
)

component_graph = connection_manager.get().component_graph
if self._config.component_ids is None:
# if in the future we support additional producers, we need to add them to the lambda
producer_components = component_graph.dfs(
self._get_grid_component(),
set(),
lambda component: component_graph.is_pv_chain(component)
or component_graph.is_chp_chain(component),
)

if not producer_components:
_logger.warning(
"Unable to find any producer components in the component graph. "
"Subscribing to the resampling actor with a non-existing "
"component id, so that `0` values are sent from the formula."
)
# If there are no producer components, we have to send 0 values at the same
# frequency as the other streams. So we subscribe with a non-existing
# component id, just to get a `None` message at the resampling interval.
builder.push_component_metric(
NON_EXISTING_COMPONENT_ID, nones_are_zeros=True
)
return builder.build()
# if in the future we support additional producers, we need to add them to the lambda
producer_components = component_graph.dfs(
self._get_grid_component(),
set(),
lambda component: component_graph.is_pv_chain(component)
or component_graph.is_chp_chain(component),
)

else:
producer_components = component_graph.components(
component_ids=set(self._config.component_ids)
if not producer_components:
_logger.warning(
"Unable to find any producer components in the component graph. "
"Subscribing to the resampling actor with a non-existing "
"component id, so that `0` values are sent from the formula."
)
if len(producer_components) != len(self._config.component_ids):
raise ComponentNotFound(
"Unable to find all requested producer components."
f"Requested {self._config.component_ids}, "
f" found {producer_components}."
)
# If there are no producer components, we have to send 0 values at the same
# frequency as the other streams. So we subscribe with a non-existing
# component id, just to get a `None` message at the resampling interval.
builder.push_component_metric(
NON_EXISTING_COMPONENT_ID, nones_are_zeros=True
)
return builder.build()

is_not_meter: Callable[[Component], bool] = (
lambda component: component.category != ComponentCategory.METER
Expand Down Expand Up @@ -143,7 +131,7 @@ def _get_fallback_formulas(
continue

fallback_ids = [c.component_id for c in fallback_components]
generator = ProducerPowerFormula(
generator = SimplePowerFormula(
f"{self._namespace}_fallback_{fallback_ids}",
self._channel_registry,
self._resampler_subscription_sender,
Expand Down

0 comments on commit ff0c626

Please sign in to comment.