Skip to content

Commit

Permalink
/* PR_START p--query-resolution-perf 16 */ Make patterns dataclasses.
Browse files Browse the repository at this point in the history
  • Loading branch information
plypaul committed Jul 19, 2024
1 parent 01914ca commit 8c2baac
Show file tree
Hide file tree
Showing 8 changed files with 26 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ def _resolve_group_by_item_input(
input_str=str(group_by_item_input.input_obj),
candidate_filters=QueryItemSuggestionGenerator.GROUP_BY_ITEM_CANDIDATE_FILTERS
+ (
MatchListSpecPattern(
MatchListSpecPattern.create(
listed_specs=valid_group_by_item_specs_for_querying,
),
),
Expand Down
Original file line number Diff line number Diff line change
@@ -1,22 +1,27 @@
from __future__ import annotations

from typing import Sequence
from dataclasses import dataclass
from typing import Sequence, Tuple

from typing_extensions import override

from metricflow_semantics.specs.instance_spec import InstanceSpec
from metricflow_semantics.specs.patterns.spec_pattern import SpecPattern


@dataclass(frozen=True)
class MatchListSpecPattern(SpecPattern):
"""A spec pattern that matches based on a configured list of specs.
This is useful for filtering possible group-by-items to ones valid for a query.
"""

def __init__(self, listed_specs: Sequence[InstanceSpec]) -> None: # noqa: D107
self._listed_specs = set(listed_specs)
listed_specs: Tuple[InstanceSpec, ...]

@staticmethod
def create(listed_specs: Sequence[InstanceSpec]) -> MatchListSpecPattern: # noqa: D102
return MatchListSpecPattern(tuple(listed_specs))

@override
def match(self, candidate_specs: Sequence[InstanceSpec]) -> Sequence[InstanceSpec]:
return tuple(spec for spec in candidate_specs if spec in self._listed_specs)
return tuple(spec for spec in candidate_specs if spec in self.listed_specs)
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
from __future__ import annotations

from collections import defaultdict
from dataclasses import dataclass
from typing import Dict, Optional, Sequence, Set, Tuple

from dbt_semantic_interfaces.type_enums import TimeGranularity
Expand All @@ -16,6 +17,7 @@
)


@dataclass(frozen=True)
class MetricTimeDefaultGranularityPattern(SpecPattern):
"""A pattern that matches metric_time specs if they have the default granularity for the requested metrics.
Expand All @@ -40,15 +42,14 @@ class MetricTimeDefaultGranularityPattern(SpecPattern):
]
"""

def __init__(self, max_metric_default_time_granularity: Optional[TimeGranularity]) -> None: # noqa: D107
self._max_metric_default_time_granularity = max_metric_default_time_granularity
max_metric_default_time_granularity: Optional[TimeGranularity]

@override
def match(self, candidate_specs: Sequence[InstanceSpec]) -> Sequence[InstanceSpec]:
spec_set = group_specs_by_type(candidate_specs)

# If there are no metrics or metric_time specs in the query, skip this filter.
if not (self._max_metric_default_time_granularity and spec_set.metric_time_specs):
if not (self.max_metric_default_time_granularity and spec_set.metric_time_specs):
return candidate_specs

spec_key_to_grains: Dict[TimeDimensionSpecComparisonKey, Set[TimeGranularity]] = defaultdict(set)
Expand All @@ -60,9 +61,9 @@ def match(self, candidate_specs: Sequence[InstanceSpec]) -> Sequence[InstanceSpe

matched_metric_time_specs: Tuple[TimeDimensionSpec, ...] = ()
for spec_key, time_grains in spec_key_to_grains.items():
if self._max_metric_default_time_granularity in time_grains:
if self.max_metric_default_time_granularity in time_grains:
matched_metric_time_specs += (
spec_key_to_specs[spec_key][0].with_grain(self._max_metric_default_time_granularity),
spec_key_to_specs[spec_key][0].with_grain(self.max_metric_default_time_granularity),
)
else:
# If default_granularity is not in the available options, then time granularity was specified in the request
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
from __future__ import annotations

from dataclasses import dataclass
from typing import Sequence

from dbt_semantic_interfaces.naming.keywords import METRIC_TIME_ELEMENT_NAME
Expand All @@ -11,6 +12,7 @@
from metricflow_semantics.specs.time_dimension_spec import TimeDimensionSpec


@dataclass(frozen=True)
class MetricTimePattern(SpecPattern):
"""Pattern that matches to only metric_time specs.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
from __future__ import annotations

from collections import defaultdict
from dataclasses import dataclass
from typing import Dict, List, Sequence, Set

from dbt_semantic_interfaces.type_enums import TimeGranularity
Expand All @@ -16,6 +17,7 @@
)


@dataclass(frozen=True)
class MinimumTimeGrainPattern(SpecPattern):
"""A pattern that matches linkable specs, but for time dimension specs, only the one with the finest grain.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
from __future__ import annotations

from collections import defaultdict
from dataclasses import dataclass
from typing import Dict, List, Sequence, Set

from dbt_semantic_interfaces.type_enums import TimeGranularity
Expand All @@ -16,6 +17,7 @@
)


@dataclass(frozen=True)
class MinimumTimeGrainPattern(SpecPattern):
"""A pattern that matches linkable specs, but for time dimension specs, only the one with the finest grain.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
from __future__ import annotations

from dataclasses import dataclass
from typing import List, Sequence

from typing_extensions import override
Expand All @@ -9,6 +10,7 @@
from metricflow_semantics.specs.spec_set import group_specs_by_type


@dataclass(frozen=True)
class NoGroupByMetricPattern(SpecPattern):
"""Matches to linkable specs, but only if they're not group by metrics.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
from __future__ import annotations

from dataclasses import dataclass
from typing import List, Sequence

from typing_extensions import override
Expand All @@ -9,6 +10,7 @@
from metricflow_semantics.specs.spec_set import group_specs_by_type


@dataclass(frozen=True)
class NoneDatePartPattern(SpecPattern):
"""Matches to linkable specs, but for time dimension specs, only matches to ones without date_part.
Expand Down

0 comments on commit 8c2baac

Please sign in to comment.