arize-phoenix 4.5.0__py3-none-any.whl → 4.6.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of arize-phoenix might be problematic. Click here for more details.
- {arize_phoenix-4.5.0.dist-info → arize_phoenix-4.6.2.dist-info}/METADATA +16 -8
- {arize_phoenix-4.5.0.dist-info → arize_phoenix-4.6.2.dist-info}/RECORD +122 -58
- {arize_phoenix-4.5.0.dist-info → arize_phoenix-4.6.2.dist-info}/WHEEL +1 -1
- phoenix/__init__.py +0 -27
- phoenix/config.py +42 -7
- phoenix/core/model.py +25 -25
- phoenix/core/model_schema.py +64 -62
- phoenix/core/model_schema_adapter.py +27 -25
- phoenix/datetime_utils.py +4 -0
- phoenix/db/bulk_inserter.py +54 -14
- phoenix/db/insertion/dataset.py +237 -0
- phoenix/db/insertion/evaluation.py +10 -10
- phoenix/db/insertion/helpers.py +17 -14
- phoenix/db/insertion/span.py +3 -3
- phoenix/db/migrations/types.py +29 -0
- phoenix/db/migrations/versions/10460e46d750_datasets.py +291 -0
- phoenix/db/migrations/versions/cf03bd6bae1d_init.py +2 -28
- phoenix/db/models.py +236 -4
- phoenix/experiments/__init__.py +6 -0
- phoenix/experiments/evaluators/__init__.py +29 -0
- phoenix/experiments/evaluators/base.py +153 -0
- phoenix/experiments/evaluators/code_evaluators.py +99 -0
- phoenix/experiments/evaluators/llm_evaluators.py +244 -0
- phoenix/experiments/evaluators/utils.py +186 -0
- phoenix/experiments/functions.py +757 -0
- phoenix/experiments/tracing.py +85 -0
- phoenix/experiments/types.py +753 -0
- phoenix/experiments/utils.py +24 -0
- phoenix/inferences/fixtures.py +23 -23
- phoenix/inferences/inferences.py +7 -7
- phoenix/inferences/validation.py +1 -1
- phoenix/server/api/context.py +20 -0
- phoenix/server/api/dataloaders/__init__.py +20 -0
- phoenix/server/api/dataloaders/average_experiment_run_latency.py +54 -0
- phoenix/server/api/dataloaders/dataset_example_revisions.py +100 -0
- phoenix/server/api/dataloaders/dataset_example_spans.py +43 -0
- phoenix/server/api/dataloaders/experiment_annotation_summaries.py +85 -0
- phoenix/server/api/dataloaders/experiment_error_rates.py +43 -0
- phoenix/server/api/dataloaders/experiment_run_counts.py +42 -0
- phoenix/server/api/dataloaders/experiment_sequence_number.py +49 -0
- phoenix/server/api/dataloaders/project_by_name.py +31 -0
- phoenix/server/api/dataloaders/span_descendants.py +2 -3
- phoenix/server/api/dataloaders/span_projects.py +33 -0
- phoenix/server/api/dataloaders/trace_row_ids.py +39 -0
- phoenix/server/api/helpers/dataset_helpers.py +179 -0
- phoenix/server/api/input_types/AddExamplesToDatasetInput.py +16 -0
- phoenix/server/api/input_types/AddSpansToDatasetInput.py +14 -0
- phoenix/server/api/input_types/ClearProjectInput.py +15 -0
- phoenix/server/api/input_types/CreateDatasetInput.py +12 -0
- phoenix/server/api/input_types/DatasetExampleInput.py +14 -0
- phoenix/server/api/input_types/DatasetSort.py +17 -0
- phoenix/server/api/input_types/DatasetVersionSort.py +16 -0
- phoenix/server/api/input_types/DeleteDatasetExamplesInput.py +13 -0
- phoenix/server/api/input_types/DeleteDatasetInput.py +7 -0
- phoenix/server/api/input_types/DeleteExperimentsInput.py +9 -0
- phoenix/server/api/input_types/PatchDatasetExamplesInput.py +35 -0
- phoenix/server/api/input_types/PatchDatasetInput.py +14 -0
- phoenix/server/api/mutations/__init__.py +13 -0
- phoenix/server/api/mutations/auth.py +11 -0
- phoenix/server/api/mutations/dataset_mutations.py +520 -0
- phoenix/server/api/mutations/experiment_mutations.py +65 -0
- phoenix/server/api/{types/ExportEventsMutation.py → mutations/export_events_mutations.py} +17 -14
- phoenix/server/api/mutations/project_mutations.py +47 -0
- phoenix/server/api/openapi/__init__.py +0 -0
- phoenix/server/api/openapi/main.py +6 -0
- phoenix/server/api/openapi/schema.py +16 -0
- phoenix/server/api/queries.py +503 -0
- phoenix/server/api/routers/v1/__init__.py +77 -2
- phoenix/server/api/routers/v1/dataset_examples.py +178 -0
- phoenix/server/api/routers/v1/datasets.py +965 -0
- phoenix/server/api/routers/v1/evaluations.py +8 -13
- phoenix/server/api/routers/v1/experiment_evaluations.py +143 -0
- phoenix/server/api/routers/v1/experiment_runs.py +220 -0
- phoenix/server/api/routers/v1/experiments.py +302 -0
- phoenix/server/api/routers/v1/spans.py +9 -5
- phoenix/server/api/routers/v1/traces.py +1 -4
- phoenix/server/api/schema.py +2 -303
- phoenix/server/api/types/AnnotatorKind.py +10 -0
- phoenix/server/api/types/Cluster.py +19 -19
- phoenix/server/api/types/CreateDatasetPayload.py +8 -0
- phoenix/server/api/types/Dataset.py +282 -63
- phoenix/server/api/types/DatasetExample.py +85 -0
- phoenix/server/api/types/DatasetExampleRevision.py +34 -0
- phoenix/server/api/types/DatasetVersion.py +14 -0
- phoenix/server/api/types/Dimension.py +30 -29
- phoenix/server/api/types/EmbeddingDimension.py +40 -34
- phoenix/server/api/types/Event.py +16 -16
- phoenix/server/api/types/ExampleRevisionInterface.py +14 -0
- phoenix/server/api/types/Experiment.py +147 -0
- phoenix/server/api/types/ExperimentAnnotationSummary.py +13 -0
- phoenix/server/api/types/ExperimentComparison.py +19 -0
- phoenix/server/api/types/ExperimentRun.py +91 -0
- phoenix/server/api/types/ExperimentRunAnnotation.py +57 -0
- phoenix/server/api/types/Inferences.py +80 -0
- phoenix/server/api/types/InferencesRole.py +23 -0
- phoenix/server/api/types/Model.py +43 -42
- phoenix/server/api/types/Project.py +26 -12
- phoenix/server/api/types/Span.py +79 -2
- phoenix/server/api/types/TimeSeries.py +6 -6
- phoenix/server/api/types/Trace.py +15 -4
- phoenix/server/api/types/UMAPPoints.py +1 -1
- phoenix/server/api/types/node.py +5 -111
- phoenix/server/api/types/pagination.py +10 -52
- phoenix/server/app.py +103 -49
- phoenix/server/main.py +49 -27
- phoenix/server/openapi/docs.py +3 -0
- phoenix/server/static/index.js +2300 -1294
- phoenix/server/templates/index.html +1 -0
- phoenix/services.py +15 -15
- phoenix/session/client.py +581 -22
- phoenix/session/session.py +47 -37
- phoenix/trace/exporter.py +14 -9
- phoenix/trace/fixtures.py +133 -7
- phoenix/trace/schemas.py +1 -2
- phoenix/trace/span_evaluations.py +3 -3
- phoenix/trace/trace_dataset.py +6 -6
- phoenix/utilities/json.py +61 -0
- phoenix/utilities/re.py +50 -0
- phoenix/version.py +1 -1
- phoenix/server/api/types/DatasetRole.py +0 -23
- {arize_phoenix-4.5.0.dist-info → arize_phoenix-4.6.2.dist-info}/licenses/IP_NOTICE +0 -0
- {arize_phoenix-4.5.0.dist-info → arize_phoenix-4.6.2.dist-info}/licenses/LICENSE +0 -0
- /phoenix/server/api/{helpers.py → helpers/__init__.py} +0 -0
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
from contextlib import contextmanager
|
|
4
|
+
from contextvars import ContextVar
|
|
5
|
+
from threading import Lock
|
|
6
|
+
from typing import Any, Callable, Iterator, Optional
|
|
7
|
+
|
|
8
|
+
from opentelemetry.sdk.resources import Resource
|
|
9
|
+
from opentelemetry.sdk.trace import ReadableSpan
|
|
10
|
+
from opentelemetry.trace import INVALID_TRACE_ID
|
|
11
|
+
from wrapt import apply_patch, resolve_path, wrap_function_wrapper
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
class SpanModifier:
|
|
15
|
+
"""
|
|
16
|
+
A class that modifies spans with the specified resource attributes.
|
|
17
|
+
"""
|
|
18
|
+
|
|
19
|
+
__slots__ = ("_resource",)
|
|
20
|
+
|
|
21
|
+
def __init__(self, resource: Resource) -> None:
|
|
22
|
+
self._resource = resource
|
|
23
|
+
|
|
24
|
+
def modify_resource(self, span: ReadableSpan) -> None:
|
|
25
|
+
"""
|
|
26
|
+
Takes a span and merges in the resource attributes specified in the constructor.
|
|
27
|
+
|
|
28
|
+
Args:
|
|
29
|
+
span: ReadableSpan: the span to modify
|
|
30
|
+
"""
|
|
31
|
+
if (ctx := span._context) is None or ctx.span_id == INVALID_TRACE_ID:
|
|
32
|
+
return
|
|
33
|
+
span._resource = span._resource.merge(self._resource)
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
_ACTIVE_MODIFIER: ContextVar[Optional[SpanModifier]] = ContextVar("active_modifier")
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
def override_span(init: Callable[..., None], span: ReadableSpan, args: Any, kwargs: Any) -> None:
|
|
40
|
+
init(*args, **kwargs)
|
|
41
|
+
if isinstance(span_modifier := _ACTIVE_MODIFIER.get(None), SpanModifier):
|
|
42
|
+
span_modifier.modify_resource(span)
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
_SPAN_INIT_MONKEY_PATCH_LOCK = Lock()
|
|
46
|
+
_SPAN_INIT_MONKEY_PATCH_COUNT = 0
|
|
47
|
+
_SPAN_INIT_MODULE = ReadableSpan.__init__.__module__
|
|
48
|
+
_SPAN_INIT_NAME = ReadableSpan.__init__.__qualname__
|
|
49
|
+
_SPAN_INIT_PARENT, _SPAN_INIT_ATTR, _SPAN_INIT_ORIGINAL = resolve_path(
|
|
50
|
+
_SPAN_INIT_MODULE, _SPAN_INIT_NAME
|
|
51
|
+
)
|
|
52
|
+
|
|
53
|
+
|
|
54
|
+
@contextmanager
|
|
55
|
+
def _monkey_patch_span_init() -> Iterator[None]:
|
|
56
|
+
global _SPAN_INIT_MONKEY_PATCH_COUNT
|
|
57
|
+
with _SPAN_INIT_MONKEY_PATCH_LOCK:
|
|
58
|
+
_SPAN_INIT_MONKEY_PATCH_COUNT += 1
|
|
59
|
+
if _SPAN_INIT_MONKEY_PATCH_COUNT == 1:
|
|
60
|
+
wrap_function_wrapper(
|
|
61
|
+
module=_SPAN_INIT_MODULE, name=_SPAN_INIT_NAME, wrapper=override_span
|
|
62
|
+
)
|
|
63
|
+
yield
|
|
64
|
+
with _SPAN_INIT_MONKEY_PATCH_LOCK:
|
|
65
|
+
_SPAN_INIT_MONKEY_PATCH_COUNT -= 1
|
|
66
|
+
if _SPAN_INIT_MONKEY_PATCH_COUNT == 0:
|
|
67
|
+
apply_patch(_SPAN_INIT_PARENT, _SPAN_INIT_ATTR, _SPAN_INIT_ORIGINAL)
|
|
68
|
+
|
|
69
|
+
|
|
70
|
+
@contextmanager
|
|
71
|
+
def capture_spans(resource: Resource) -> Iterator[SpanModifier]:
|
|
72
|
+
"""
|
|
73
|
+
A context manager that captures spans and modifies them with the specified resources.
|
|
74
|
+
|
|
75
|
+
Args:
|
|
76
|
+
resource: Resource: The resource to merge into the spans created within the context.
|
|
77
|
+
|
|
78
|
+
Returns:
|
|
79
|
+
modifier: Iterator[SpanModifier]: The span modifier that is active within the context.
|
|
80
|
+
"""
|
|
81
|
+
modifier = SpanModifier(resource)
|
|
82
|
+
with _monkey_patch_span_init():
|
|
83
|
+
token = _ACTIVE_MODIFIER.set(modifier)
|
|
84
|
+
yield modifier
|
|
85
|
+
_ACTIVE_MODIFIER.reset(token)
|