From 15aaaa6c1cb794633ffb63d514c89a624d419404 Mon Sep 17 00:00:00 2001 From: mike0sv Date: Thu, 12 Dec 2024 15:49:08 +0000 Subject: [PATCH 1/3] add customdata for distribution --- src/evidently/ui/dashboards/reports.py | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/src/evidently/ui/dashboards/reports.py b/src/evidently/ui/dashboards/reports.py index 38276f99cf..2f1c5ae092 100644 --- a/src/evidently/ui/dashboards/reports.py +++ b/src/evidently/ui/dashboards/reports.py @@ -29,6 +29,7 @@ from evidently.ui.type_aliases import DataPointsAsType from evidently.ui.type_aliases import PointInfo from evidently.ui.type_aliases import ProjectID +from evidently.ui.type_aliases import SnapshotID if TYPE_CHECKING: from evidently.ui.base import DataStorage @@ -173,10 +174,13 @@ async def build( raise ValueError(f"Cannot build hist from {self.value}") if len(bins_for_hists) > 1: raise ValueError(f"Ambiguious metrics for {self.value}") - bins_for_hist: List[Tuple[datetime.datetime, HistogramData]] = next( + metric = next(iter(bins_for_hists.keys())) + fingerprint = metric.get_fingerprint() + bins_for_hist: List[Tuple[datetime.datetime, SnapshotID, HistogramData]] = next( [ ( d.timestamp, + d.snapshot_id, d.value if isinstance(d.value, HistogramData) else HistogramData.from_distribution(d.value), ) for d in v @@ -187,26 +191,31 @@ async def build( timestamps: List[datetime.datetime] = [] names: Set[str] = set() values: List[Dict[str, Any]] = [] + snapshot_ids = [] - for timestamp, hist in bins_for_hist: + for timestamp, snapshot_id, hist in bins_for_hist: timestamps.append(timestamp) data = dict(zip(hist.x, hist.count)) - names.update(data.keys()) values.append(data) + names.update(data.keys()) + snapshot_ids.append(snapshot_id) names_sorted = list(sorted(names)) - name_to_date_value: Dict[str, List[Any]] = {name: [] for name in names_sorted} - for timestamp, data in zip(timestamps, values): + name_to_date_value: Dict[str, List[Tuple[SnapshotID, Any]]] = {name: [] for name in names_sorted} + for timestamp, snapshot_id, data in zip(timestamps, snapshot_ids, values): for name in names_sorted: - name_to_date_value[name].append(data.get(name)) + name_to_date_value[name].append((snapshot_id, data.get(name))) hovertemplate = "{name}: %{{y}}
Timestamp: %{{x}}" fig = go.Figure( data=[ go.Bar( name=name, x=timestamps, - y=name_to_date_value.get(name), + y=name_to_date_value.get(name)[1], hovertemplate=hovertemplate.format(name=name), + customdata=[ + {"metric_fingerprint": fingerprint, "snapshot_id": str(name_to_date_value.get(name)[0])} + ], ) for name in names_sorted ] From 1df1fcc3c1e17c6559f6c565ff4bab8678b2d42a Mon Sep 17 00:00:00 2001 From: mike0sv Date: Thu, 12 Dec 2024 18:02:37 +0000 Subject: [PATCH 2/3] fix --- src/evidently/ui/dashboards/reports.py | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/src/evidently/ui/dashboards/reports.py b/src/evidently/ui/dashboards/reports.py index 2f1c5ae092..a0c556085d 100644 --- a/src/evidently/ui/dashboards/reports.py +++ b/src/evidently/ui/dashboards/reports.py @@ -1,4 +1,5 @@ import datetime +from collections import defaultdict from typing import TYPE_CHECKING from typing import Any from typing import Dict @@ -201,20 +202,24 @@ async def build( snapshot_ids.append(snapshot_id) names_sorted = list(sorted(names)) - name_to_date_value: Dict[str, List[Tuple[SnapshotID, Any]]] = {name: [] for name in names_sorted} + name_to_date_value: Dict[str, List[Any]] = defaultdict(list) + name_to_snapshot_id: Dict[str, List[SnapshotID]] = defaultdict(list) for timestamp, snapshot_id, data in zip(timestamps, snapshot_ids, values): for name in names_sorted: - name_to_date_value[name].append((snapshot_id, data.get(name))) + name_to_date_value[name].append(data.get(name)) + name_to_snapshot_id[name].append(snapshot_id) + hovertemplate = "{name}: %{{y}}
Timestamp: %{{x}}" fig = go.Figure( data=[ go.Bar( name=name, x=timestamps, - y=name_to_date_value.get(name)[1], + y=name_to_date_value.get(name), hovertemplate=hovertemplate.format(name=name), customdata=[ - {"metric_fingerprint": fingerprint, "snapshot_id": str(name_to_date_value.get(name)[0])} + {"metric_fingerprint": fingerprint, "snapshot_id": str(snapshot_id)} + for snapshot_id in name_to_snapshot_id.get(name) ], ) for name in names_sorted From 5152adeb50aa5a4507de33eaff855538fa8bc1a6 Mon Sep 17 00:00:00 2001 From: mike0sv Date: Thu, 12 Dec 2024 21:01:15 +0000 Subject: [PATCH 3/3] fix --- src/evidently/ui/dashboards/reports.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/evidently/ui/dashboards/reports.py b/src/evidently/ui/dashboards/reports.py index a0c556085d..f241ff408e 100644 --- a/src/evidently/ui/dashboards/reports.py +++ b/src/evidently/ui/dashboards/reports.py @@ -215,11 +215,11 @@ async def build( go.Bar( name=name, x=timestamps, - y=name_to_date_value.get(name), + y=name_to_date_value[name], hovertemplate=hovertemplate.format(name=name), customdata=[ {"metric_fingerprint": fingerprint, "snapshot_id": str(snapshot_id)} - for snapshot_id in name_to_snapshot_id.get(name) + for snapshot_id in name_to_snapshot_id[name] ], ) for name in names_sorted