arize-phoenix 11.28.0__tar.gz → 11.30.0__tar.gz
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-11.28.0 → arize_phoenix-11.30.0}/PKG-INFO +3 -2
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/pyproject.toml +2 -1
- arize_phoenix-11.30.0/src/phoenix/server/api/dataloaders/average_experiment_run_latency.py +47 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/document_evaluations.py +3 -3
- arize_phoenix-11.30.0/src/phoenix/server/api/dataloaders/experiment_annotation_summaries.py +133 -0
- arize_phoenix-11.30.0/src/phoenix/server/api/dataloaders/experiment_error_rates.py +51 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/__init__.py +2 -0
- arize_phoenix-11.30.0/src/phoenix/server/api/routers/v1/documents.py +175 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/spans.py +5 -3
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/traces.py +5 -3
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Dataset.py +69 -21
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Evaluation.py +5 -4
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Experiment.py +4 -5
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Span.py +2 -2
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/.vite/manifest.json +9 -9
- arize_phoenix-11.28.0/src/phoenix/server/static/assets/components-C3HQDu_r.js → arize_phoenix-11.30.0/src/phoenix/server/static/assets/components-BBwXqJXQ.js +4 -3
- arize_phoenix-11.28.0/src/phoenix/server/static/assets/index-C-sjZRYC.js → arize_phoenix-11.30.0/src/phoenix/server/static/assets/index-C_gU3x10.js +1 -1
- arize_phoenix-11.28.0/src/phoenix/server/static/assets/pages-DvrxSPg3.js → arize_phoenix-11.30.0/src/phoenix/server/static/assets/pages-YmQb55Uo.js +399 -392
- arize_phoenix-11.30.0/src/phoenix/version.py +1 -0
- arize_phoenix-11.28.0/src/phoenix/server/api/dataloaders/average_experiment_run_latency.py +0 -54
- arize_phoenix-11.28.0/src/phoenix/server/api/dataloaders/experiment_annotation_summaries.py +0 -79
- arize_phoenix-11.28.0/src/phoenix/server/api/dataloaders/experiment_error_rates.py +0 -58
- arize_phoenix-11.28.0/src/phoenix/version.py +0 -1
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/.gitignore +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/IP_NOTICE +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/LICENSE +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/README.md +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/auth.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/config.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/embedding_dimension.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/model.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/model_schema.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/core/model_schema_adapter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/datetime_utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/README.md +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/alembic.ini +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/bulk_inserter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/constants.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/engines.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/enums.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/facilitator.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/helpers.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/constants.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/dataset.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/document_annotation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/evaluation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/helpers.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/span.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/span_annotation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/trace_annotation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/insertion/types.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrate.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/data_migration_scripts/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/data_migration_scripts/populate_project_sessions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/env.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/script.py.mako +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/10460e46d750_datasets.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/2f9d1a65945f_annotation_config_migration.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/3be8647b87d8_add_token_columns_to_spans_table.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/4ded9e43755f_create_project_sessions_table.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/6a88424799fe_update_users_with_auth_method.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/8a3764fe7f1a_change_jsonb_to_json_for_prompts.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/a20694b15f82_cost.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/bb8139330879_create_project_trace_retention_policies_table.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/bc8fea3c2bc8_add_prompt_tables.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/cd164e83824f_users_and_tokens.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/migrations/versions/cf03bd6bae1d_init.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/models.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/pg_config.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/annotation_configs.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/db_models.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/identifier.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/model_provider.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/token_price_customization.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/db/types/trace_retention.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/exceptions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/base.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/code_evaluators.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/llm_evaluators.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/evaluators/utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/functions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/tracing.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/types.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/experiments/utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/errors.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/fixtures.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/inferences.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/schema.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/inferences/validation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/_config.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/_filter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/logging/_formatter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/README.md +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/binning.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/metrics.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/mixins.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/retrieval_metrics.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/timeseries.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/metrics/wrappers.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/clustering.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/pointcloud.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/projectors.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/pointcloud/umap_parameters.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/py.typed +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/README.md +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/auth.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/context.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/annotation_configs_by_project.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/annotation_summaries.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/cache/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/cache/two_tier_cache.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/dataset_example_revisions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/dataset_example_spans.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/document_evaluation_summaries.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/document_retrieval_metrics.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/experiment_run_annotations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/experiment_run_counts.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/experiment_sequence_number.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/last_used_times_by_generative_model_id.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/latency_ms_quantile.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/min_start_or_max_end_times.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/num_child_spans.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/num_spans_per_trace.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/project_by_name.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/project_ids_by_trace_retention_policy_id.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/prompt_version_sequence_number.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/record_counts.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_io.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_num_traces.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_num_traces_with_error.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_token_usages.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/session_trace_latency_ms_quantile.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_annotations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_by_id.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_by_span.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_generative_model.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_project_session.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_span.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_detail_summary_entries_by_trace.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_details_by_span_cost.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_experiment.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_experiment_run.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_generative_model.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_project.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_project_session.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_cost_summary_by_trace.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_costs.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_dataset_examples.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_descendants.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/span_projects.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/table_fields.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/token_counts.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/trace_by_trace_ids.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/trace_retention_policy_id_by_project_id.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/trace_root_spans.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/types.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/user_roles.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/dataloaders/users.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/exceptions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/annotations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/dataset_helpers.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/experiment_run_filters.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/playground_clients.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/playground_registry.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/playground_spans.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/anthropic.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/aws.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/conversions/openai.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/helpers/prompts/models.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/AddExamplesToDatasetInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/AddSpansToDatasetInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ChatCompletionInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ChatCompletionMessageInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ClearProjectInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ClusterInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/Coordinates.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateDatasetInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateProjectInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateSpanAnnotationInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/CreateTraceAnnotationInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DataQualityMetricInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetExampleInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetFilter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetSort.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DatasetVersionSort.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteAnnotationsInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteDatasetExamplesInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteDatasetInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DeleteExperimentsInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DimensionFilter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/DimensionInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/GenerativeCredentialInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/GenerativeModelInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/Granularity.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/InvocationParameters.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PatchAnnotationInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PatchDatasetExamplesInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PatchDatasetInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PerformanceMetricInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ProjectFilter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ProjectSessionSort.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/ProjectSort.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PromptFilter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PromptTemplateOptions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/PromptVersionInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/SpanAnnotationFilter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/SpanAnnotationSort.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/SpanSort.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/TimeBinConfig.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/TimeRange.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/TraceAnnotationSort.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/UserRoleInput.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/input_types/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/interceptor.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/annotation_config_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/api_key_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/chat_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/dataset_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/experiment_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/export_events_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/model_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/project_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/project_trace_retention_policy_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/prompt_label_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/prompt_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/prompt_version_tag_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/span_annotations_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/trace_annotations_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/trace_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/mutations/user_mutations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/openapi/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/openapi/main.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/openapi/schema.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/queries.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/auth.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/embeddings.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/oauth2.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/annotation_configs.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/annotations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/datasets.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/evaluations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/experiment_evaluations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/experiment_runs.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/experiments.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/models.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/projects.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/prompts.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/users.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/schema.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/subscriptions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Annotation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotationConfig.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotationSource.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotationSummary.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AnnotatorKind.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ApiKey.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/AuthMethod.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ChatCompletionMessageRole.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ChatCompletionSubscriptionPayload.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Cluster.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/CostBreakdown.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/CreateDatasetPayload.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/CronExpression.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DataQualityMetric.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetExample.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetExampleRevision.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetValues.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DatasetVersion.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Dimension.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionDataType.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionShape.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionType.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DimensionWithValue.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DocumentEvaluationSummary.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/DocumentRetrievalMetrics.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EmbeddingDimension.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EmbeddingMetadata.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EvaluationSummary.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Event.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/EventMetadata.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExampleRevisionInterface.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentAnnotationSummary.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentComparison.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentRun.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExperimentRunAnnotation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ExportedFile.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Functionality.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/GenerativeModel.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/GenerativeProvider.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Identifier.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/InferenceModel.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Inferences.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/InferencesRole.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/LabelFraction.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/MimeType.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ModelInterface.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/NumericRange.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PerformanceMetric.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PlaygroundModel.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Project.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ProjectSession.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ProjectTraceRetentionPolicy.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Prompt.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptLabel.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptResponse.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptVersion.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptVersionTag.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/PromptVersionTemplate.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ResponseFormat.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Retrieval.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ScalarDriftMetricEnum.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Segments.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ServerStatus.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SortDir.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanAnnotation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanCostDetailSummaryEntry.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanCostSummary.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SpanIOValue.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/SystemApiKey.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TimeSeries.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TokenCountPromptDetails.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TokenPrice.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TokenUsage.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ToolDefinition.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/Trace.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/TraceAnnotation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/UMAPPoints.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/User.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/UserApiKey.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/UserRole.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/ValidationResult.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/VectorDriftMetricEnum.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/node.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/types/pagination.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/app.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/authorization.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/bearer_auth.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/cost_details_calculator.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/cost_model_lookup.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/helpers.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/model_cost_manifest.json +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/regex_specificity.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/cost_tracking/token_cost_calculator.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/db_disk_usage_monitor.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/generative_model_store.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/daemons/span_cost_calculator.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/dml_event.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/dml_event_handler.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/sender.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/db_disk_usage_notification.html +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/password_reset.html +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/templates/welcome.html +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/email/types.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/experiments/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/experiments/utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/grpc_server.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/jwt_store.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/main.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/middleware/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/middleware/gzip.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/oauth2.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/openapi/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/prometheus.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/rate_limiters.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/retention.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/session_filters.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-114x114.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-120x120.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-144x144.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-152x152.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-180x180.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-72x72.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon-76x76.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/apple-touch-icon.png +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-CqDb5u4o.css +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-RdRDaQiR.js +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-arizeai-DsYDNOqt.js +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-codemirror-BzJDUbEx.js +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-recharts-BTHn5Y2R.js +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-shiki-BAcocHFl.js +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/assets/vendor-three-BLWp5bic.js +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/favicon.ico +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/static/modernizr.js +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/telemetry.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/templates/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/templates/index.html +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/thread_server.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/types.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/services.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/client.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/data_extractor.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/evaluation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/session/session.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/settings.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/attributes.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/README.md +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/filter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/helpers.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/dsl/query.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/errors.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/evaluation_conventions.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/exporter.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/fixtures.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/otel.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/projects.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/schemas.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/span_evaluations.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/span_json_decoder.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/span_json_encoder.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/trace_dataset.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/utils.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/v1/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/v1/evaluation_pb2.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/trace/v1/evaluation_pb2.pyi +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/__init__.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/client.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/deprecation.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/error_handling.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/json.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/logging.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/project.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/re.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/span_store.py +0 -0
- {arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/utilities/template_formatters.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: arize-phoenix
|
|
3
|
-
Version: 11.
|
|
3
|
+
Version: 11.30.0
|
|
4
4
|
Summary: AI Observability and Evaluation
|
|
5
5
|
Project-URL: Documentation, https://arize.com/docs/phoenix/
|
|
6
6
|
Project-URL: Issues, https://github.com/Arize-ai/phoenix/issues
|
|
@@ -50,7 +50,8 @@ Requires-Dist: python-multipart
|
|
|
50
50
|
Requires-Dist: scikit-learn
|
|
51
51
|
Requires-Dist: scipy
|
|
52
52
|
Requires-Dist: sqlalchemy[asyncio]<3,>=2.0.4
|
|
53
|
-
Requires-Dist: sqlean-py
|
|
53
|
+
Requires-Dist: sqlean-py<3.50,>=3.45.1; platform_system == 'Windows'
|
|
54
|
+
Requires-Dist: sqlean-py>=3.45.1; platform_system != 'Windows'
|
|
54
55
|
Requires-Dist: starlette
|
|
55
56
|
Requires-Dist: strawberry-graphql==0.270.1
|
|
56
57
|
Requires-Dist: tqdm
|
|
@@ -49,7 +49,8 @@ dependencies = [
|
|
|
49
49
|
"alembic>=1.3.0, <2",
|
|
50
50
|
"aiosqlite",
|
|
51
51
|
"aioitertools",
|
|
52
|
-
"sqlean.py>=3.45.1",
|
|
52
|
+
"sqlean.py>=3.45.1; platform_system != 'Windows'",
|
|
53
|
+
"sqlean.py>=3.45.1,<3.50; platform_system == 'Windows'", # https://github.com/nalgeon/sqlean.py/commit/2714a4789998811b7dd9f102f5b45ea071ed879e
|
|
53
54
|
"cachetools",
|
|
54
55
|
"python-multipart", # see https://www.starlette.io/#dependencies
|
|
55
56
|
"arize-phoenix-evals>=0.20.6",
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
from typing import Optional
|
|
2
|
+
|
|
3
|
+
from sqlalchemy import func, select
|
|
4
|
+
from strawberry.dataloader import DataLoader
|
|
5
|
+
from typing_extensions import TypeAlias
|
|
6
|
+
|
|
7
|
+
from phoenix.db import models
|
|
8
|
+
from phoenix.server.types import DbSessionFactory
|
|
9
|
+
|
|
10
|
+
ExperimentID: TypeAlias = int
|
|
11
|
+
RunLatency: TypeAlias = Optional[float]
|
|
12
|
+
Key: TypeAlias = ExperimentID
|
|
13
|
+
Result: TypeAlias = RunLatency
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
class AverageExperimentRunLatencyDataLoader(DataLoader[Key, Result]):
|
|
17
|
+
def __init__(
|
|
18
|
+
self,
|
|
19
|
+
db: DbSessionFactory,
|
|
20
|
+
) -> None:
|
|
21
|
+
super().__init__(load_fn=self._load_fn)
|
|
22
|
+
self._db = db
|
|
23
|
+
|
|
24
|
+
async def _load_fn(self, keys: list[Key]) -> list[Result]:
|
|
25
|
+
experiment_ids = keys
|
|
26
|
+
average_repetition_latency_ms = (
|
|
27
|
+
select(
|
|
28
|
+
models.ExperimentRun.experiment_id.label("experiment_id"),
|
|
29
|
+
func.avg(models.ExperimentRun.latency_ms).label("average_repetition_latency_ms"),
|
|
30
|
+
)
|
|
31
|
+
.select_from(models.ExperimentRun)
|
|
32
|
+
.where(models.ExperimentRun.experiment_id.in_(experiment_ids))
|
|
33
|
+
.group_by(models.ExperimentRun.dataset_example_id, models.ExperimentRun.experiment_id)
|
|
34
|
+
.subquery()
|
|
35
|
+
)
|
|
36
|
+
query = select(
|
|
37
|
+
average_repetition_latency_ms.c.experiment_id,
|
|
38
|
+
func.avg(average_repetition_latency_ms.c.average_repetition_latency_ms).label(
|
|
39
|
+
"average_run_latency_ms"
|
|
40
|
+
),
|
|
41
|
+
).group_by(average_repetition_latency_ms.c.experiment_id)
|
|
42
|
+
async with self._db() as session:
|
|
43
|
+
average_run_latencies_ms = {
|
|
44
|
+
experiment_id: average_run_latency_ms
|
|
45
|
+
async for experiment_id, average_run_latency_ms in await session.stream(query)
|
|
46
|
+
}
|
|
47
|
+
return [average_run_latencies_ms.get(experiment_id) for experiment_id in keys]
|
|
@@ -5,11 +5,11 @@ from strawberry.dataloader import DataLoader
|
|
|
5
5
|
from typing_extensions import TypeAlias
|
|
6
6
|
|
|
7
7
|
from phoenix.db import models
|
|
8
|
-
from phoenix.server.api.types.Evaluation import
|
|
8
|
+
from phoenix.server.api.types.Evaluation import DocumentAnnotation
|
|
9
9
|
from phoenix.server.types import DbSessionFactory
|
|
10
10
|
|
|
11
11
|
Key: TypeAlias = int
|
|
12
|
-
Result: TypeAlias = list[
|
|
12
|
+
Result: TypeAlias = list[DocumentAnnotation]
|
|
13
13
|
|
|
14
14
|
|
|
15
15
|
class DocumentEvaluationsDataLoader(DataLoader[Key, Result]):
|
|
@@ -26,6 +26,6 @@ class DocumentEvaluationsDataLoader(DataLoader[Key, Result]):
|
|
|
26
26
|
)
|
|
27
27
|
async for document_evaluation in data:
|
|
28
28
|
document_evaluations_by_id[document_evaluation.span_rowid].append(
|
|
29
|
-
|
|
29
|
+
DocumentAnnotation.from_sql_document_annotation(document_evaluation)
|
|
30
30
|
)
|
|
31
31
|
return [document_evaluations_by_id[key] for key in keys]
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
from collections import defaultdict
|
|
2
|
+
from dataclasses import dataclass
|
|
3
|
+
from typing import Optional
|
|
4
|
+
|
|
5
|
+
from sqlalchemy import and_, func, select
|
|
6
|
+
from strawberry.dataloader import AbstractCache, DataLoader
|
|
7
|
+
from typing_extensions import TypeAlias
|
|
8
|
+
|
|
9
|
+
from phoenix.db import models
|
|
10
|
+
from phoenix.server.types import DbSessionFactory
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
@dataclass
|
|
14
|
+
class ExperimentAnnotationSummary:
|
|
15
|
+
annotation_name: str
|
|
16
|
+
min_score: float
|
|
17
|
+
max_score: float
|
|
18
|
+
mean_score: float
|
|
19
|
+
count: int
|
|
20
|
+
error_count: int
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
ExperimentID: TypeAlias = int
|
|
24
|
+
Key: TypeAlias = ExperimentID
|
|
25
|
+
Result: TypeAlias = list[ExperimentAnnotationSummary]
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
class ExperimentAnnotationSummaryDataLoader(DataLoader[Key, Result]):
|
|
29
|
+
def __init__(
|
|
30
|
+
self,
|
|
31
|
+
db: DbSessionFactory,
|
|
32
|
+
cache_map: Optional[AbstractCache[Key, Result]] = None,
|
|
33
|
+
) -> None:
|
|
34
|
+
super().__init__(load_fn=self._load_fn)
|
|
35
|
+
self._db = db
|
|
36
|
+
|
|
37
|
+
async def _load_fn(self, keys: list[Key]) -> list[Result]:
|
|
38
|
+
experiment_ids = keys
|
|
39
|
+
summaries: defaultdict[ExperimentID, Result] = defaultdict(list)
|
|
40
|
+
repetition_mean_scores_by_example_subquery = (
|
|
41
|
+
select(
|
|
42
|
+
models.ExperimentRun.experiment_id.label("experiment_id"),
|
|
43
|
+
models.ExperimentRunAnnotation.name.label("annotation_name"),
|
|
44
|
+
func.avg(models.ExperimentRunAnnotation.score).label("mean_repetition_score"),
|
|
45
|
+
)
|
|
46
|
+
.select_from(models.ExperimentRunAnnotation)
|
|
47
|
+
.join(
|
|
48
|
+
models.ExperimentRun,
|
|
49
|
+
models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
|
|
50
|
+
)
|
|
51
|
+
.where(models.ExperimentRun.experiment_id.in_(experiment_ids))
|
|
52
|
+
.group_by(
|
|
53
|
+
models.ExperimentRun.experiment_id,
|
|
54
|
+
models.ExperimentRun.dataset_example_id,
|
|
55
|
+
models.ExperimentRunAnnotation.name,
|
|
56
|
+
)
|
|
57
|
+
.subquery()
|
|
58
|
+
.alias("repetition_mean_scores_by_example")
|
|
59
|
+
)
|
|
60
|
+
repetition_mean_scores_subquery = (
|
|
61
|
+
select(
|
|
62
|
+
repetition_mean_scores_by_example_subquery.c.experiment_id.label("experiment_id"),
|
|
63
|
+
repetition_mean_scores_by_example_subquery.c.annotation_name.label(
|
|
64
|
+
"annotation_name"
|
|
65
|
+
),
|
|
66
|
+
func.avg(repetition_mean_scores_by_example_subquery.c.mean_repetition_score).label(
|
|
67
|
+
"mean_score"
|
|
68
|
+
),
|
|
69
|
+
)
|
|
70
|
+
.select_from(repetition_mean_scores_by_example_subquery)
|
|
71
|
+
.group_by(
|
|
72
|
+
repetition_mean_scores_by_example_subquery.c.experiment_id,
|
|
73
|
+
repetition_mean_scores_by_example_subquery.c.annotation_name,
|
|
74
|
+
)
|
|
75
|
+
.subquery()
|
|
76
|
+
.alias("repetition_mean_scores")
|
|
77
|
+
)
|
|
78
|
+
repetitions_subquery = (
|
|
79
|
+
select(
|
|
80
|
+
models.ExperimentRun.experiment_id.label("experiment_id"),
|
|
81
|
+
models.ExperimentRunAnnotation.name.label("annotation_name"),
|
|
82
|
+
func.min(models.ExperimentRunAnnotation.score).label("min_score"),
|
|
83
|
+
func.max(models.ExperimentRunAnnotation.score).label("max_score"),
|
|
84
|
+
func.count().label("count"),
|
|
85
|
+
func.count(models.ExperimentRunAnnotation.error).label("error_count"),
|
|
86
|
+
)
|
|
87
|
+
.select_from(models.ExperimentRunAnnotation)
|
|
88
|
+
.join(
|
|
89
|
+
models.ExperimentRun,
|
|
90
|
+
models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
|
|
91
|
+
)
|
|
92
|
+
.where(models.ExperimentRun.experiment_id.in_(experiment_ids))
|
|
93
|
+
.group_by(models.ExperimentRun.experiment_id, models.ExperimentRunAnnotation.name)
|
|
94
|
+
.subquery()
|
|
95
|
+
)
|
|
96
|
+
run_scores_query = (
|
|
97
|
+
select(
|
|
98
|
+
repetition_mean_scores_subquery.c.experiment_id.label("experiment_id"),
|
|
99
|
+
repetition_mean_scores_subquery.c.annotation_name.label("annotation_name"),
|
|
100
|
+
repetition_mean_scores_subquery.c.mean_score.label("mean_score"),
|
|
101
|
+
repetitions_subquery.c.min_score.label("min_score"),
|
|
102
|
+
repetitions_subquery.c.max_score.label("max_score"),
|
|
103
|
+
repetitions_subquery.c.count.label("count_"),
|
|
104
|
+
repetitions_subquery.c.error_count.label("error_count"),
|
|
105
|
+
)
|
|
106
|
+
.select_from(repetition_mean_scores_subquery)
|
|
107
|
+
.join(
|
|
108
|
+
repetitions_subquery,
|
|
109
|
+
and_(
|
|
110
|
+
repetitions_subquery.c.experiment_id
|
|
111
|
+
== repetition_mean_scores_subquery.c.experiment_id,
|
|
112
|
+
repetitions_subquery.c.annotation_name
|
|
113
|
+
== repetition_mean_scores_subquery.c.annotation_name,
|
|
114
|
+
),
|
|
115
|
+
)
|
|
116
|
+
.order_by(repetition_mean_scores_subquery.c.annotation_name)
|
|
117
|
+
)
|
|
118
|
+
async with self._db() as session:
|
|
119
|
+
async for scores_tuple in await session.stream(run_scores_query):
|
|
120
|
+
summaries[scores_tuple.experiment_id].append(
|
|
121
|
+
ExperimentAnnotationSummary(
|
|
122
|
+
annotation_name=scores_tuple.annotation_name,
|
|
123
|
+
min_score=scores_tuple.min_score,
|
|
124
|
+
max_score=scores_tuple.max_score,
|
|
125
|
+
mean_score=scores_tuple.mean_score,
|
|
126
|
+
count=scores_tuple.count_,
|
|
127
|
+
error_count=scores_tuple.error_count,
|
|
128
|
+
)
|
|
129
|
+
)
|
|
130
|
+
return [
|
|
131
|
+
sorted(summaries[experiment_id], key=lambda summary: summary.annotation_name)
|
|
132
|
+
for experiment_id in experiment_ids
|
|
133
|
+
]
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
from typing import Optional
|
|
2
|
+
|
|
3
|
+
from sqlalchemy import func, select
|
|
4
|
+
from strawberry.dataloader import DataLoader
|
|
5
|
+
from typing_extensions import TypeAlias
|
|
6
|
+
|
|
7
|
+
from phoenix.db import models
|
|
8
|
+
from phoenix.server.types import DbSessionFactory
|
|
9
|
+
|
|
10
|
+
ExperimentID: TypeAlias = int
|
|
11
|
+
ErrorRate: TypeAlias = float
|
|
12
|
+
Key: TypeAlias = ExperimentID
|
|
13
|
+
Result: TypeAlias = Optional[ErrorRate]
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
class ExperimentErrorRatesDataLoader(DataLoader[Key, Result]):
|
|
17
|
+
def __init__(
|
|
18
|
+
self,
|
|
19
|
+
db: DbSessionFactory,
|
|
20
|
+
) -> None:
|
|
21
|
+
super().__init__(load_fn=self._load_fn)
|
|
22
|
+
self._db = db
|
|
23
|
+
|
|
24
|
+
async def _load_fn(self, keys: list[Key]) -> list[Result]:
|
|
25
|
+
experiment_ids = keys
|
|
26
|
+
average_repetition_error_rates_subquery = (
|
|
27
|
+
select(
|
|
28
|
+
models.ExperimentRun.experiment_id.label("experiment_id"),
|
|
29
|
+
(
|
|
30
|
+
func.count(models.ExperimentRun.error) / func.count(models.ExperimentRun.id)
|
|
31
|
+
).label("average_repetition_error_rate"),
|
|
32
|
+
)
|
|
33
|
+
.where(models.ExperimentRun.experiment_id.in_(experiment_ids))
|
|
34
|
+
.group_by(models.ExperimentRun.dataset_example_id, models.ExperimentRun.experiment_id)
|
|
35
|
+
.subquery()
|
|
36
|
+
.alias("average_repetition_error_rates")
|
|
37
|
+
)
|
|
38
|
+
average_run_error_rates_query = select(
|
|
39
|
+
average_repetition_error_rates_subquery.c.experiment_id,
|
|
40
|
+
func.avg(average_repetition_error_rates_subquery.c.average_repetition_error_rate).label(
|
|
41
|
+
"average_run_error_rates"
|
|
42
|
+
),
|
|
43
|
+
).group_by(average_repetition_error_rates_subquery.c.experiment_id)
|
|
44
|
+
async with self._db() as session:
|
|
45
|
+
average_run_error_rates = {
|
|
46
|
+
experiment_id: error_rate
|
|
47
|
+
async for experiment_id, error_rate in await session.stream(
|
|
48
|
+
average_run_error_rates_query
|
|
49
|
+
)
|
|
50
|
+
}
|
|
51
|
+
return [average_run_error_rates.get(experiment_id) for experiment_id in experiment_ids]
|
{arize_phoenix-11.28.0 → arize_phoenix-11.30.0}/src/phoenix/server/api/routers/v1/__init__.py
RENAMED
|
@@ -7,6 +7,7 @@ from phoenix.server.bearer_auth import is_authenticated
|
|
|
7
7
|
from .annotation_configs import router as annotation_configs_router
|
|
8
8
|
from .annotations import router as annotations_router
|
|
9
9
|
from .datasets import router as datasets_router
|
|
10
|
+
from .documents import router as documents_router
|
|
10
11
|
from .evaluations import router as evaluations_router
|
|
11
12
|
from .experiment_evaluations import router as experiment_evaluations_router
|
|
12
13
|
from .experiment_runs import router as experiment_runs_router
|
|
@@ -70,5 +71,6 @@ def create_v1_router(authentication_enabled: bool) -> APIRouter:
|
|
|
70
71
|
router.include_router(evaluations_router)
|
|
71
72
|
router.include_router(prompts_router)
|
|
72
73
|
router.include_router(projects_router)
|
|
74
|
+
router.include_router(documents_router)
|
|
73
75
|
router.include_router(users_router)
|
|
74
76
|
return router
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
from datetime import datetime, timezone
|
|
2
|
+
from typing import Any, Literal, Optional
|
|
3
|
+
|
|
4
|
+
from fastapi import APIRouter, Depends, HTTPException, Query
|
|
5
|
+
from pydantic import Field
|
|
6
|
+
from sqlalchemy import select
|
|
7
|
+
from starlette.requests import Request
|
|
8
|
+
from starlette.status import HTTP_404_NOT_FOUND
|
|
9
|
+
from strawberry.relay import GlobalID
|
|
10
|
+
|
|
11
|
+
from phoenix.db import models
|
|
12
|
+
from phoenix.db.helpers import SupportedSQLDialect
|
|
13
|
+
from phoenix.db.insertion.helpers import as_kv, insert_on_conflict
|
|
14
|
+
from phoenix.db.insertion.types import Precursors
|
|
15
|
+
from phoenix.server.api.types.Evaluation import DocumentAnnotation
|
|
16
|
+
from phoenix.server.authorization import is_not_locked
|
|
17
|
+
from phoenix.server.bearer_auth import PhoenixUser
|
|
18
|
+
from phoenix.server.dml_event import DocumentAnnotationInsertEvent
|
|
19
|
+
|
|
20
|
+
from .models import V1RoutesBaseModel
|
|
21
|
+
from .spans import SpanAnnotationResult
|
|
22
|
+
from .utils import RequestBody, ResponseBody, add_errors_to_responses
|
|
23
|
+
|
|
24
|
+
# Since the document annotations are spans related, we place it under spans
|
|
25
|
+
router = APIRouter(tags=["spans"])
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
class SpanDocumentAnnotationData(V1RoutesBaseModel):
|
|
29
|
+
span_id: str = Field(description="OpenTelemetry Span ID (hex format w/o 0x prefix)")
|
|
30
|
+
name: str = Field(description="The name of the document annotation. E.x. relevance")
|
|
31
|
+
annotator_kind: Literal["LLM", "CODE", "HUMAN"] = Field(
|
|
32
|
+
description="The kind of annotator. E.g. llm judge, a heuristic piece of code, or a human"
|
|
33
|
+
)
|
|
34
|
+
document_position: int = Field(
|
|
35
|
+
description="A 0 based index of the document. E.x. the first document during retrieval is 0"
|
|
36
|
+
)
|
|
37
|
+
result: Optional[SpanAnnotationResult] = Field(
|
|
38
|
+
default=None, description="The score and or label of the annotation"
|
|
39
|
+
)
|
|
40
|
+
metadata: Optional[dict[str, Any]] = Field(
|
|
41
|
+
default=None, description="Metadata for custom values of the annotation"
|
|
42
|
+
)
|
|
43
|
+
identifier: str = Field(
|
|
44
|
+
default="",
|
|
45
|
+
description=(
|
|
46
|
+
"An custom ID for the annotation. "
|
|
47
|
+
"If provided, the annotation will be updated if it already exists."
|
|
48
|
+
),
|
|
49
|
+
)
|
|
50
|
+
|
|
51
|
+
# Precursor here means a value to add to a queue for processing async
|
|
52
|
+
def as_precursor(self, *, user_id: Optional[int] = None) -> Precursors.DocumentAnnotation:
|
|
53
|
+
return Precursors.DocumentAnnotation(
|
|
54
|
+
datetime.now(timezone.utc),
|
|
55
|
+
self.span_id,
|
|
56
|
+
self.document_position,
|
|
57
|
+
models.DocumentAnnotation(
|
|
58
|
+
name=self.name,
|
|
59
|
+
annotator_kind=self.annotator_kind,
|
|
60
|
+
document_position=self.document_position,
|
|
61
|
+
score=self.result.score if self.result else None,
|
|
62
|
+
label=self.result.label if self.result else None,
|
|
63
|
+
explanation=self.result.explanation if self.result else None,
|
|
64
|
+
metadata_=self.metadata or {},
|
|
65
|
+
identifier=self.identifier,
|
|
66
|
+
source="API",
|
|
67
|
+
user_id=user_id,
|
|
68
|
+
),
|
|
69
|
+
)
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
class AnnotateSpanDocumentsRequestBody(RequestBody[list[SpanDocumentAnnotationData]]):
|
|
73
|
+
pass
|
|
74
|
+
|
|
75
|
+
|
|
76
|
+
class InsertedSpanDocumentAnnotation(V1RoutesBaseModel):
|
|
77
|
+
id: str = Field(description="The ID of the inserted span document annotation")
|
|
78
|
+
|
|
79
|
+
|
|
80
|
+
class AnnotateSpanDocumentsResponseBody(ResponseBody[list[InsertedSpanDocumentAnnotation]]):
|
|
81
|
+
pass
|
|
82
|
+
|
|
83
|
+
|
|
84
|
+
@router.post(
|
|
85
|
+
"/document_annotations",
|
|
86
|
+
dependencies=[Depends(is_not_locked)],
|
|
87
|
+
operation_id="annotateSpanDocuments",
|
|
88
|
+
responses=add_errors_to_responses(
|
|
89
|
+
[
|
|
90
|
+
{
|
|
91
|
+
"status_code": HTTP_404_NOT_FOUND,
|
|
92
|
+
"description": "Span not found",
|
|
93
|
+
}
|
|
94
|
+
]
|
|
95
|
+
),
|
|
96
|
+
response_description="Span document annotation inserted successfully",
|
|
97
|
+
include_in_schema=True,
|
|
98
|
+
)
|
|
99
|
+
async def annotate_span_documents(
|
|
100
|
+
request: Request,
|
|
101
|
+
request_body: AnnotateSpanDocumentsRequestBody,
|
|
102
|
+
sync: bool = Query(
|
|
103
|
+
default=False, description="If set to true, the annotations are inserted synchronously."
|
|
104
|
+
),
|
|
105
|
+
) -> AnnotateSpanDocumentsResponseBody:
|
|
106
|
+
if not request_body.data:
|
|
107
|
+
return AnnotateSpanDocumentsResponseBody(data=[])
|
|
108
|
+
|
|
109
|
+
user_id: Optional[int] = None
|
|
110
|
+
if request.app.state.authentication_enabled and isinstance(request.user, PhoenixUser):
|
|
111
|
+
user_id = int(request.user.identity)
|
|
112
|
+
|
|
113
|
+
span_document_annotations = request_body.data
|
|
114
|
+
|
|
115
|
+
precursors = [
|
|
116
|
+
annotation.as_precursor(user_id=user_id) for annotation in span_document_annotations
|
|
117
|
+
]
|
|
118
|
+
if not sync:
|
|
119
|
+
await request.state.enqueue(*precursors)
|
|
120
|
+
|
|
121
|
+
span_ids = {p.span_id for p in precursors}
|
|
122
|
+
# Account for the fact that the spans could arrive after the annotation
|
|
123
|
+
async with request.app.state.db() as session:
|
|
124
|
+
existing_spans = {
|
|
125
|
+
span_id: (id_, num_docs)
|
|
126
|
+
async for span_id, id_, num_docs in await session.stream(
|
|
127
|
+
select(models.Span.span_id, models.Span.id, models.Span.num_documents).filter(
|
|
128
|
+
models.Span.span_id.in_(span_ids)
|
|
129
|
+
)
|
|
130
|
+
)
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
missing_span_ids = span_ids - set(existing_spans.keys())
|
|
134
|
+
# We prefer to fail the entire operation if there are missing spans in sync mode
|
|
135
|
+
if missing_span_ids:
|
|
136
|
+
raise HTTPException(
|
|
137
|
+
detail=f"Spans with IDs {', '.join(missing_span_ids)} do not exist.",
|
|
138
|
+
status_code=HTTP_404_NOT_FOUND,
|
|
139
|
+
)
|
|
140
|
+
|
|
141
|
+
# Validate that document positions are within bounds
|
|
142
|
+
for annotation in span_document_annotations:
|
|
143
|
+
_, num_docs = existing_spans[annotation.span_id]
|
|
144
|
+
if annotation.document_position not in range(num_docs):
|
|
145
|
+
raise HTTPException(
|
|
146
|
+
detail=f"Document position {annotation.document_position} is out of bounds for "
|
|
147
|
+
f"span {annotation.span_id} (max: {num_docs - 1})",
|
|
148
|
+
status_code=422, # Unprocessable Entity
|
|
149
|
+
)
|
|
150
|
+
|
|
151
|
+
inserted_document_annotation_ids = []
|
|
152
|
+
dialect = SupportedSQLDialect(session.bind.dialect.name)
|
|
153
|
+
for anno in precursors:
|
|
154
|
+
span_rowid, _ = existing_spans[anno.span_id]
|
|
155
|
+
values = dict(as_kv(anno.as_insertable(span_rowid).row))
|
|
156
|
+
span_document_annotation_id = await session.scalar(
|
|
157
|
+
insert_on_conflict(
|
|
158
|
+
values,
|
|
159
|
+
dialect=dialect,
|
|
160
|
+
table=models.DocumentAnnotation,
|
|
161
|
+
unique_by=("name", "span_rowid", "identifier", "document_position"),
|
|
162
|
+
).returning(models.DocumentAnnotation.id)
|
|
163
|
+
)
|
|
164
|
+
inserted_document_annotation_ids.append(span_document_annotation_id)
|
|
165
|
+
|
|
166
|
+
# We queue an event to let the application know that annotations have changed
|
|
167
|
+
request.state.event_queue.put(
|
|
168
|
+
DocumentAnnotationInsertEvent(tuple(inserted_document_annotation_ids))
|
|
169
|
+
)
|
|
170
|
+
return AnnotateSpanDocumentsResponseBody(
|
|
171
|
+
data=[
|
|
172
|
+
InsertedSpanDocumentAnnotation(id=str(GlobalID(DocumentAnnotation.__name__, str(id_))))
|
|
173
|
+
for id_ in inserted_document_annotation_ids
|
|
174
|
+
]
|
|
175
|
+
)
|
|
@@ -949,9 +949,11 @@ async def annotate_spans(
|
|
|
949
949
|
span_ids = {p.span_id for p in precursors}
|
|
950
950
|
async with request.app.state.db() as session:
|
|
951
951
|
existing_spans = {
|
|
952
|
-
|
|
953
|
-
async for
|
|
954
|
-
select(models.Span
|
|
952
|
+
span_id: id_
|
|
953
|
+
async for span_id, id_ in await session.stream(
|
|
954
|
+
select(models.Span.span_id, models.Span.id).filter(
|
|
955
|
+
models.Span.span_id.in_(span_ids)
|
|
956
|
+
)
|
|
955
957
|
)
|
|
956
958
|
}
|
|
957
959
|
|
|
@@ -193,9 +193,11 @@ async def annotate_traces(
|
|
|
193
193
|
trace_ids = {p.trace_id for p in precursors}
|
|
194
194
|
async with request.app.state.db() as session:
|
|
195
195
|
existing_traces = {
|
|
196
|
-
|
|
197
|
-
async for
|
|
198
|
-
select(models.Trace
|
|
196
|
+
trace_id: id_
|
|
197
|
+
async for trace_id, id_ in await session.stream(
|
|
198
|
+
select(models.Trace.trace_id, models.Trace.id).filter(
|
|
199
|
+
models.Trace.trace_id.in_(trace_ids)
|
|
200
|
+
)
|
|
199
201
|
)
|
|
200
202
|
}
|
|
201
203
|
|
|
@@ -272,15 +272,53 @@ class Dataset(Node):
|
|
|
272
272
|
self, info: Info[Context, None]
|
|
273
273
|
) -> list[ExperimentAnnotationSummary]:
|
|
274
274
|
dataset_id = self.id_attr
|
|
275
|
-
|
|
275
|
+
repetition_mean_scores_by_example_subquery = (
|
|
276
276
|
select(
|
|
277
|
+
models.ExperimentRunAnnotation.name.label("annotation_name"),
|
|
278
|
+
func.avg(models.ExperimentRunAnnotation.score).label("mean_repetition_score"),
|
|
279
|
+
)
|
|
280
|
+
.select_from(models.ExperimentRunAnnotation)
|
|
281
|
+
.join(
|
|
282
|
+
models.ExperimentRun,
|
|
283
|
+
models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
|
|
284
|
+
)
|
|
285
|
+
.join(
|
|
286
|
+
models.Experiment,
|
|
287
|
+
models.ExperimentRun.experiment_id == models.Experiment.id,
|
|
288
|
+
)
|
|
289
|
+
.where(models.Experiment.dataset_id == dataset_id)
|
|
290
|
+
.group_by(
|
|
291
|
+
models.ExperimentRun.dataset_example_id,
|
|
277
292
|
models.ExperimentRunAnnotation.name,
|
|
278
|
-
func.min(models.ExperimentRunAnnotation.score),
|
|
279
|
-
func.max(models.ExperimentRunAnnotation.score),
|
|
280
|
-
func.avg(models.ExperimentRunAnnotation.score),
|
|
281
|
-
func.count(),
|
|
282
|
-
func.count(models.ExperimentRunAnnotation.error),
|
|
283
293
|
)
|
|
294
|
+
.subquery()
|
|
295
|
+
.alias("repetition_mean_scores_by_example")
|
|
296
|
+
)
|
|
297
|
+
repetition_mean_scores_subquery = (
|
|
298
|
+
select(
|
|
299
|
+
repetition_mean_scores_by_example_subquery.c.annotation_name.label(
|
|
300
|
+
"annotation_name"
|
|
301
|
+
),
|
|
302
|
+
func.avg(repetition_mean_scores_by_example_subquery.c.mean_repetition_score).label(
|
|
303
|
+
"mean_score"
|
|
304
|
+
),
|
|
305
|
+
)
|
|
306
|
+
.select_from(repetition_mean_scores_by_example_subquery)
|
|
307
|
+
.group_by(
|
|
308
|
+
repetition_mean_scores_by_example_subquery.c.annotation_name,
|
|
309
|
+
)
|
|
310
|
+
.subquery()
|
|
311
|
+
.alias("repetition_mean_scores")
|
|
312
|
+
)
|
|
313
|
+
repetitions_subquery = (
|
|
314
|
+
select(
|
|
315
|
+
models.ExperimentRunAnnotation.name.label("annotation_name"),
|
|
316
|
+
func.min(models.ExperimentRunAnnotation.score).label("min_score"),
|
|
317
|
+
func.max(models.ExperimentRunAnnotation.score).label("max_score"),
|
|
318
|
+
func.count().label("count"),
|
|
319
|
+
func.count(models.ExperimentRunAnnotation.error).label("error_count"),
|
|
320
|
+
)
|
|
321
|
+
.select_from(models.ExperimentRunAnnotation)
|
|
284
322
|
.join(
|
|
285
323
|
models.ExperimentRun,
|
|
286
324
|
models.ExperimentRunAnnotation.experiment_run_id == models.ExperimentRun.id,
|
|
@@ -291,26 +329,36 @@ class Dataset(Node):
|
|
|
291
329
|
)
|
|
292
330
|
.where(models.Experiment.dataset_id == dataset_id)
|
|
293
331
|
.group_by(models.ExperimentRunAnnotation.name)
|
|
294
|
-
.
|
|
332
|
+
.subquery()
|
|
333
|
+
)
|
|
334
|
+
run_scores_query = (
|
|
335
|
+
select(
|
|
336
|
+
repetition_mean_scores_subquery.c.annotation_name.label("annotation_name"),
|
|
337
|
+
repetition_mean_scores_subquery.c.mean_score.label("mean_score"),
|
|
338
|
+
repetitions_subquery.c.min_score.label("min_score"),
|
|
339
|
+
repetitions_subquery.c.max_score.label("max_score"),
|
|
340
|
+
repetitions_subquery.c.count.label("count_"),
|
|
341
|
+
repetitions_subquery.c.error_count.label("error_count"),
|
|
342
|
+
)
|
|
343
|
+
.select_from(repetition_mean_scores_subquery)
|
|
344
|
+
.join(
|
|
345
|
+
repetitions_subquery,
|
|
346
|
+
repetitions_subquery.c.annotation_name
|
|
347
|
+
== repetition_mean_scores_subquery.c.annotation_name,
|
|
348
|
+
)
|
|
349
|
+
.order_by(repetition_mean_scores_subquery.c.annotation_name)
|
|
295
350
|
)
|
|
296
351
|
async with info.context.db() as session:
|
|
297
352
|
return [
|
|
298
353
|
ExperimentAnnotationSummary(
|
|
299
|
-
annotation_name=annotation_name,
|
|
300
|
-
min_score=min_score,
|
|
301
|
-
max_score=max_score,
|
|
302
|
-
mean_score=mean_score,
|
|
303
|
-
count=count_,
|
|
304
|
-
error_count=error_count,
|
|
354
|
+
annotation_name=scores_tuple.annotation_name,
|
|
355
|
+
min_score=scores_tuple.min_score,
|
|
356
|
+
max_score=scores_tuple.max_score,
|
|
357
|
+
mean_score=scores_tuple.mean_score,
|
|
358
|
+
count=scores_tuple.count_,
|
|
359
|
+
error_count=scores_tuple.error_count,
|
|
305
360
|
)
|
|
306
|
-
async for (
|
|
307
|
-
annotation_name,
|
|
308
|
-
min_score,
|
|
309
|
-
max_score,
|
|
310
|
-
mean_score,
|
|
311
|
-
count_,
|
|
312
|
-
error_count,
|
|
313
|
-
) in await session.stream(query)
|
|
361
|
+
async for scores_tuple in await session.stream(run_scores_query)
|
|
314
362
|
]
|
|
315
363
|
|
|
316
364
|
@strawberry.field
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import strawberry
|
|
2
2
|
|
|
3
|
-
from phoenix.db.models import DocumentAnnotation
|
|
3
|
+
from phoenix.db.models import DocumentAnnotation as DBDocumentAnnotation
|
|
4
|
+
from phoenix.db.models import TraceAnnotation
|
|
4
5
|
|
|
5
6
|
from .Annotation import Annotation
|
|
6
7
|
|
|
@@ -20,15 +21,15 @@ class TraceEvaluation(Annotation):
|
|
|
20
21
|
|
|
21
22
|
|
|
22
23
|
@strawberry.type
|
|
23
|
-
class
|
|
24
|
+
class DocumentAnnotation(Annotation):
|
|
24
25
|
document_position: int = strawberry.field(
|
|
25
26
|
description="The zero-based index among retrieved documents, which "
|
|
26
27
|
"is collected as a list (even when ordering is not inherently meaningful)."
|
|
27
28
|
)
|
|
28
29
|
|
|
29
30
|
@staticmethod
|
|
30
|
-
def from_sql_document_annotation(annotation:
|
|
31
|
-
return
|
|
31
|
+
def from_sql_document_annotation(annotation: DBDocumentAnnotation) -> "DocumentAnnotation":
|
|
32
|
+
return DocumentAnnotation(
|
|
32
33
|
name=annotation.name,
|
|
33
34
|
score=annotation.score,
|
|
34
35
|
label=annotation.label,
|